/* ==========================================================================
   Q2W Generator — universal block styles
   Per-site variables (--q2w-primary, --q2w-accent, fonts) are written to
   /wp-content/uploads/custom-site-{ID}.css by the builder. This file covers
   layout, typography, and variant styles. Works for all block libraries.
   ========================================================================== */

:root {
  --q2w-primary:      #1e40af;
  --q2w-accent:       #f59e0b;
  --q2w-text:         #0f172a;
  --q2w-muted:        #64748b;
  --q2w-surface:      #ffffff;
  --q2w-alt:          #f8fafc;
  --q2w-border:       #e2e8f0;
  --q2w-radius:       12px;
  --q2w-shadow:       0 4px 20px rgba(15,23,42,.08);
  --q2w-font-heading: 'Manrope', system-ui, -apple-system, sans-serif;
  --q2w-font-body:    'Inter', system-ui, -apple-system, sans-serif;
  --q2w-max:          1200px;
}

.q2w-block { font-family: var(--q2w-font-body); color: var(--q2w-text); }
.q2w-block * { box-sizing: border-box; }
.q2w-block h1, .q2w-block h2, .q2w-block h3 { font-family: var(--q2w-font-heading); line-height: 1.15; letter-spacing: -0.02em; margin: 0 0 .5em; }
.q2w-block h1 { font-size: clamp(2rem, 5vw, 3.5rem); font-weight: 800; }
.q2w-block h2 { font-size: clamp(1.6rem, 3.5vw, 2.4rem); font-weight: 700; }
.q2w-block h3 { font-size: clamp(1.1rem, 2vw, 1.25rem); font-weight: 600; }
.q2w-block p { margin: 0 0 1em; line-height: 1.65; font-size: 1.05rem; color: var(--q2w-muted); }
.q2w-block img { max-width: 100%; height: auto; display: block; border-radius: var(--q2w-radius); }

.q2w-section { padding: clamp(2.5rem, 6vw, 5rem) clamp(1.25rem, 4vw, 2rem); max-width: var(--q2w-max); margin: 0 auto; width: 100%; }
.q2w-block { width: 100%; max-width: 100%; }
.entry-content > .q2w-block:first-child .q2w-hero { padding-top: 0; }

/* Default mobile safety — anything wider stacks */
@media (max-width: 640px) {
  .q2w-block h1 { font-size: 2rem; line-height: 1.2; }
  .q2w-block h2 { font-size: 1.5rem; }
  .q2w-cta-row { flex-direction: column; align-items: stretch; }
  .q2w-cta-row .q2w-btn { text-align: center; }
  .q2w-trust-badges { justify-content: center; }
}

/* Buttons */
.q2w-btn { display: inline-block; padding: 0.95rem 1.6rem; border-radius: var(--q2w-radius); font-weight: 600; font-size: 1rem; text-decoration: none; transition: transform .15s ease, box-shadow .15s ease, background .2s; white-space: nowrap; }
.q2w-btn-primary { background: var(--q2w-primary); color: #fff; box-shadow: 0 4px 12px rgba(30,64,175,.25); }
.q2w-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 8px 20px rgba(30,64,175,.35); }
.q2w-btn-secondary { background: transparent; color: var(--q2w-primary); border: 2px solid var(--q2w-primary); }
.q2w-btn-secondary:hover { background: var(--q2w-primary); color: #fff; }
.q2w-cta-row { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.5rem; }

/* ========== HERO ========== */
.q2w-hero { padding: clamp(3rem,6vw,5rem) clamp(1rem,4vw,2rem); max-width: var(--q2w-max); margin: 0 auto; }
.q2w-hero-centred { text-align: center; max-width: 900px; }
.q2w-hero-centred .q2w-cta-row, .q2w-hero-centred .q2w-trust-badges { justify-content: center; }

.q2w-hero-split { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.q2w-hero-split.q2w-reverse { direction: rtl; }
.q2w-hero-split.q2w-reverse > * { direction: ltr; }
.q2w-hero-media img { border-radius: var(--q2w-radius); box-shadow: var(--q2w-shadow); aspect-ratio: 4/3; object-fit: cover; width: 100%; }

.q2w-hero-fullbleed { position: relative; min-height: 540px; background-size: cover; background-position: center; border-radius: var(--q2w-radius); overflow: hidden; padding: 0; max-width: none; }
.q2w-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(15,23,42,.85), rgba(15,23,42,.5) 60%, transparent); display: flex; flex-direction: column; justify-content: center; padding: clamp(2rem, 6vw, 5rem); max-width: 720px; }
.q2w-hero-fullbleed h1, .q2w-hero-fullbleed p { color: #fff; }
.q2w-hero-fullbleed p { color: rgba(255,255,255,.9); }

.q2w-hero-stacked { text-align: center; max-width: 900px; }
.q2w-hero-stacked .q2w-trust-badges, .q2w-hero-stacked .q2w-cta-row { justify-content: center; }

.q2w-trust-badges { display: flex; flex-wrap: wrap; gap: 1.5rem; margin: 1.75rem 0; }
.q2w-badge { display: flex; flex-direction: column; gap: .15rem; padding: .75rem 1.25rem; background: var(--q2w-alt); border-radius: var(--q2w-radius); border: 1px solid var(--q2w-border); min-width: 110px; }
.q2w-badge strong { font-size: 1.4rem; font-weight: 800; color: var(--q2w-primary); font-family: var(--q2w-font-heading); }
.q2w-badge span { font-size: .82rem; color: var(--q2w-muted); text-transform: uppercase; letter-spacing: .05em; }

@media (max-width: 768px) {
  .q2w-hero-split { grid-template-columns: 1fr; }
  .q2w-hero-split.q2w-reverse { direction: ltr; }
  .q2w-hero-media { order: -1; }
  .q2w-hero-overlay { background: linear-gradient(to bottom, rgba(15,23,42,.3), rgba(15,23,42,.85) 60%); max-width: none; }
}

/* ========== PAIN POINTS ========== */
.q2w-pain { background: var(--q2w-alt); border-radius: var(--q2w-radius); }
.q2w-pain h2 { text-align: center; margin-bottom: 2.5rem; }
.q2w-pain-grid { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.q2w-pain-item { background: #fff; padding: 1.75rem; border-radius: var(--q2w-radius); box-shadow: var(--q2w-shadow); }
.q2w-pain-item h3 { color: var(--q2w-text); margin-bottom: .75rem; }
.q2w-pain-icon { width: 48px; height: 48px; background: var(--q2w-primary); border-radius: 12px; margin-bottom: 1rem; position: relative; opacity: .9; }
.q2w-pain-icon::after { content: '!'; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 1.4rem; font-weight: 800; }

.q2w-pain-icon_grid_3 .q2w-pain-grid { grid-template-columns: repeat(3, 1fr); }
.q2w-pain-icon_grid_4 .q2w-pain-grid { grid-template-columns: repeat(4, 1fr); }
.q2w-pain-alt_rows .q2w-pain-grid { grid-template-columns: 1fr; max-width: 780px; margin: 0 auto; }
.q2w-pain-before_after .q2w-pain-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
@media (max-width: 860px) {
  .q2w-pain-icon_grid_3 .q2w-pain-grid,
  .q2w-pain-icon_grid_4 .q2w-pain-grid,
  .q2w-pain-before_after .q2w-pain-grid { grid-template-columns: 1fr; }
}

/* ========== SERVICES ========== */
.q2w-services h2 { text-align: center; margin-bottom: 2.5rem; }
.q2w-services-grid { display: grid; gap: 1.5rem; }
.q2w-service-item { background: #fff; padding: 2rem; border-radius: var(--q2w-radius); border: 1px solid var(--q2w-border); transition: transform .2s, box-shadow .2s; }
.q2w-service-item:hover { transform: translateY(-4px); box-shadow: var(--q2w-shadow); border-color: var(--q2w-primary); }
.q2w-service-icon { width: 54px; height: 54px; background: linear-gradient(135deg, var(--q2w-primary), var(--q2w-accent)); border-radius: 14px; margin-bottom: 1rem; }
.q2w-service-price { display: inline-block; margin-top: .5rem; padding: .25rem .75rem; background: var(--q2w-alt); border-radius: 8px; font-weight: 600; color: var(--q2w-primary); font-size: .92rem; }

.q2w-services-icon_grid_3 .q2w-services-grid { grid-template-columns: repeat(3, 1fr); }
.q2w-services-icon_grid_4 .q2w-services-grid { grid-template-columns: repeat(4, 1fr); }
.q2w-services-alt_rows .q2w-services-grid { grid-template-columns: 1fr; max-width: 820px; margin: 0 auto; gap: 1rem; }
.q2w-services-cards_priced .q2w-services-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.q2w-services-scroll_horiz .q2w-services-grid { grid-auto-flow: column; grid-auto-columns: minmax(280px, 320px); overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: 1rem; }
.q2w-services-scroll_horiz .q2w-service-item { scroll-snap-align: start; }
@media (max-width: 980px) {
  .q2w-services-icon_grid_3 .q2w-services-grid,
  .q2w-services-icon_grid_4 .q2w-services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .q2w-services-icon_grid_3 .q2w-services-grid,
  .q2w-services-icon_grid_4 .q2w-services-grid { grid-template-columns: 1fr; }
}

/* ========== PROCESS ========== */
.q2w-process h2 { text-align: center; margin-bottom: 2.5rem; }
.q2w-process-list { display: grid; gap: 2rem; }
.q2w-process-step { padding: 1.5rem; position: relative; }
.q2w-step-num { width: 48px; height: 48px; border-radius: 50%; background: var(--q2w-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 1.25rem; font-family: var(--q2w-font-heading); margin-bottom: 1rem; }
.q2w-process-numbered_horiz .q2w-process-list { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); text-align: center; }
.q2w-process-numbered_horiz .q2w-step-num { margin: 0 auto 1rem; }
.q2w-process-numbered_vert .q2w-process-list { grid-template-columns: 1fr; max-width: 640px; margin: 0 auto; }
.q2w-process-icons_row .q2w-process-list { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); text-align: center; }
.q2w-process-icons_row .q2w-step-num { margin: 0 auto 1rem; background: linear-gradient(135deg, var(--q2w-primary), var(--q2w-accent)); }

/* ========== TRUST ========== */
.q2w-trust { text-align: center; }
.q2w-trust-row { display: flex; flex-wrap: wrap; gap: 1.5rem; justify-content: center; margin-top: 1.5rem; }
.q2w-trust-item { display: flex; flex-direction: column; gap: .25rem; min-width: 140px; padding: 1rem 1.5rem; }
.q2w-trust-item strong { font-size: 2.25rem; font-weight: 800; color: var(--q2w-primary); font-family: var(--q2w-font-heading); }
.q2w-trust-item span { color: var(--q2w-muted); font-size: .95rem; }
.q2w-trust-banner { background: var(--q2w-primary); border-radius: var(--q2w-radius); padding: 1.5rem; }
.q2w-trust-banner .q2w-trust-item strong, .q2w-trust-banner .q2w-trust-item span { color: #fff; }
.q2w-trust-named_team .q2w-trust-row { gap: 2rem; }
.q2w-trust-named_team .q2w-trust-item { max-width: 200px; }

/* ========== REVIEWS ========== */
.q2w-reviews h2 { text-align: center; margin-bottom: 1rem; }
.q2w-reviews-summary { text-align: center; margin-bottom: 2.5rem; display: flex; gap: .75rem; align-items: center; justify-content: center; flex-wrap: wrap; }
.q2w-reviews-summary strong { font-size: 2rem; font-weight: 800; color: var(--q2w-primary); }
.q2w-stars { display: inline-block; color: #fbbf24; letter-spacing: .1em; }
.q2w-stars::before { content: '★★★★★'; }
.q2w-reviews-list { display: grid; gap: 1.5rem; }
.q2w-review { background: #fff; border: 1px solid var(--q2w-border); padding: 1.75rem; border-radius: var(--q2w-radius); margin: 0; }
.q2w-review p { color: var(--q2w-text); font-size: 1.05rem; font-style: italic; margin: .75rem 0 1rem; }
.q2w-review cite { color: var(--q2w-muted); font-style: normal; font-weight: 600; font-size: .92rem; }
.q2w-reviews-grid_3 .q2w-reviews-list { grid-template-columns: repeat(3, 1fr); }
.q2w-reviews-big_quote .q2w-reviews-list { grid-template-columns: 1fr; }
.q2w-reviews-big_quote .q2w-review:first-child { grid-column: 1 / -1; text-align: center; padding: 3rem; background: linear-gradient(135deg, var(--q2w-primary), var(--q2w-accent)); color: #fff; border: none; }
.q2w-reviews-big_quote .q2w-review:first-child p { color: #fff; font-size: 1.5rem; }
.q2w-reviews-big_quote .q2w-review:first-child cite { color: rgba(255,255,255,.9); }
.q2w-reviews-masonry .q2w-reviews-list { columns: 3; column-gap: 1.5rem; display: block; }
.q2w-reviews-masonry .q2w-review { break-inside: avoid; margin-bottom: 1.5rem; }
.q2w-reviews-avatar_list .q2w-reviews-list { grid-template-columns: 1fr; max-width: 680px; margin: 0 auto; gap: 1rem; }
.q2w-reviews-avatar_list .q2w-review { display: flex; gap: 1rem; align-items: flex-start; padding: 1.25rem; }
.q2w-reviews-carousel .q2w-reviews-list { grid-template-columns: 1fr; max-width: 760px; margin: 0 auto; }
@media (max-width: 980px) {
  .q2w-reviews-grid_3 .q2w-reviews-list { grid-template-columns: 1fr; }
  .q2w-reviews-masonry .q2w-reviews-list { columns: 1; }
}

/* ========== GALLERY ========== */
.q2w-gallery h2 { text-align: center; margin-bottom: 2rem; }
.q2w-gallery-grid { display: grid; gap: 1rem; }
.q2w-gallery-grid figure { margin: 0; position: relative; overflow: hidden; border-radius: var(--q2w-radius); }
.q2w-gallery-grid img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/3; transition: transform .4s ease; }
.q2w-gallery-grid figure:hover img { transform: scale(1.05); }
.q2w-gallery-grid figcaption { position: absolute; bottom: 0; left: 0; right: 0; padding: .75rem 1rem; background: linear-gradient(to top, rgba(15,23,42,.85), transparent); color: #fff; font-size: .9rem; }
.q2w-gallery-grid_3_col .q2w-gallery-grid { grid-template-columns: repeat(3, 1fr); }
.q2w-gallery-grid_4_col .q2w-gallery-grid { grid-template-columns: repeat(4, 1fr); }
.q2w-gallery-masonry .q2w-gallery-grid { columns: 3; column-gap: 1rem; display: block; }
.q2w-gallery-masonry figure { margin-bottom: 1rem; break-inside: avoid; }
.q2w-gallery-masonry img { aspect-ratio: auto; }
@media (max-width: 860px) {
  .q2w-gallery-grid_3_col .q2w-gallery-grid,
  .q2w-gallery-grid_4_col .q2w-gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .q2w-gallery-masonry .q2w-gallery-grid { columns: 2; }
}

/* ========== FAQ ========== */
.q2w-faq h2 { text-align: center; margin-bottom: 2rem; }
.q2w-faq-list { max-width: 820px; margin: 0 auto; display: grid; gap: .75rem; }
.q2w-faq-item { background: #fff; border: 1px solid var(--q2w-border); border-radius: var(--q2w-radius); overflow: hidden; }
.q2w-faq-item summary { padding: 1.25rem 1.5rem; font-weight: 600; cursor: pointer; font-family: var(--q2w-font-heading); font-size: 1.05rem; list-style: none; display: flex; justify-content: space-between; align-items: center; }
.q2w-faq-item summary::-webkit-details-marker { display: none; }
.q2w-faq-item summary::after { content: '+'; font-size: 1.5rem; color: var(--q2w-primary); transition: transform .2s; }
.q2w-faq-item[open] summary::after { transform: rotate(45deg); }
.q2w-faq-item > div { padding: 0 1.5rem 1.25rem; color: var(--q2w-muted); line-height: 1.7; }
.q2w-faq-two_column .q2w-faq-list { grid-template-columns: 1fr 1fr; max-width: var(--q2w-max); }

/* ========== CTA ========== */
.q2w-cta { background: linear-gradient(135deg, var(--q2w-primary), #1e3a8a); color: #fff; border-radius: var(--q2w-radius); text-align: center; }
.q2w-cta-inner { max-width: 700px; margin: 0 auto; }
.q2w-cta h2 { color: #fff; }
.q2w-cta p { color: rgba(255,255,255,.9); font-size: 1.15rem; }
.q2w-cta .q2w-cta-row { justify-content: center; }
.q2w-cta .q2w-btn-primary { background: #fff; color: var(--q2w-primary); }
.q2w-cta .q2w-btn-primary:hover { background: var(--q2w-accent); color: #fff; }
.q2w-cta-phone { color: #fff; font-size: 2rem; font-weight: 800; text-decoration: none; display: inline-block; margin-top: .5rem; font-family: var(--q2w-font-heading); }
.q2w-cta-boxed_centred { background: var(--q2w-alt); color: var(--q2w-text); max-width: 900px; }
.q2w-cta-boxed_centred h2, .q2w-cta-boxed_centred p { color: var(--q2w-text); }
.q2w-cta-boxed_centred p { color: var(--q2w-muted); }
.q2w-cta-boxed_centred .q2w-btn-primary { background: var(--q2w-primary); color: #fff; }
.q2w-cta-phone_led { background: var(--q2w-primary); }

/* ========== CONTACT FORM ========== */
.q2w-form h2 { text-align: center; margin-bottom: .5rem; }
.q2w-form > p { text-align: center; color: var(--q2w-muted); margin-bottom: 2rem; }
.q2w-form-wrap { max-width: 640px; margin: 0 auto; background: #fff; padding: 2rem; border-radius: var(--q2w-radius); box-shadow: var(--q2w-shadow); }
.q2w-form-wrap input, .q2w-form-wrap textarea, .q2w-form-wrap select { width: 100%; padding: .85rem 1rem; border: 1px solid var(--q2w-border); border-radius: 8px; font-family: var(--q2w-font-body); font-size: 1rem; margin-bottom: 1rem; transition: border-color .15s; }
.q2w-form-wrap input:focus, .q2w-form-wrap textarea:focus { outline: none; border-color: var(--q2w-primary); box-shadow: 0 0 0 3px rgba(30,64,175,.1); }
.q2w-form-wrap .wpcf7-submit { background: var(--q2w-primary); color: #fff; border: none; padding: 1rem 2rem; border-radius: var(--q2w-radius); font-weight: 600; cursor: pointer; width: 100%; font-size: 1.05rem; }
.q2w-form-split_with_info .q2w-form-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; max-width: 960px; }

/* ========== MAP ========== */
.q2w-map iframe { width: 100%; border-radius: var(--q2w-radius); }
.q2w-map-embed_split { display: grid; grid-template-columns: 2fr 1fr; gap: 2rem; align-items: start; }
.q2w-areas { background: var(--q2w-alt); padding: 2rem; border-radius: var(--q2w-radius); }
.q2w-areas ul { list-style: none; padding: 0; margin: 1rem 0 0; columns: 2; column-gap: 1.5rem; }
.q2w-areas li { padding: .35rem 0; color: var(--q2w-muted); }
@media (max-width: 780px) { .q2w-map-embed_split { grid-template-columns: 1fr; } }

/* ========== INTRO ========== */
.q2w-intro-centred { text-align: center; max-width: 780px; background: var(--q2w-alt); border-radius: var(--q2w-radius); }
.q2w-intro-two_col { display: grid; grid-template-columns: 1fr 2fr; gap: 3rem; }
@media (max-width: 780px) { .q2w-intro-two_col { grid-template-columns: 1fr; } }

/* ========== Restaurant menu block ========== */
.q2w-menu h2 { text-align: center; margin-bottom: 2rem; }
.q2w-menu-category { margin-bottom: 2.5rem; }
.q2w-menu-category h3 { border-bottom: 2px solid var(--q2w-primary); padding-bottom: .5rem; margin-bottom: 1rem; }
.q2w-menu-item { display: flex; justify-content: space-between; gap: 1rem; padding: .85rem 0; border-bottom: 1px dashed var(--q2w-border); }
.q2w-menu-item-info { flex: 1; }
.q2w-menu-item-info strong { font-weight: 600; }
.q2w-menu-item-info p { margin: .25rem 0 0; font-size: .92rem; }
.q2w-menu-item-price { font-weight: 700; color: var(--q2w-primary); white-space: nowrap; }

/* ========== Rooms block (hospitality) ========== */
.q2w-rooms-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.5rem; }
.q2w-room-card { background: #fff; border: 1px solid var(--q2w-border); border-radius: var(--q2w-radius); overflow: hidden; }
.q2w-room-card img { border-radius: 0; aspect-ratio: 4/3; object-fit: cover; }
.q2w-room-card-body { padding: 1.25rem; }
.q2w-room-card-price { color: var(--q2w-primary); font-weight: 700; margin-top: .5rem; }

/* ========== Product grid (retail) ========== */
.q2w-products-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.5rem; }
.q2w-product-card { background: #fff; text-align: center; padding: 1rem; border-radius: var(--q2w-radius); border: 1px solid var(--q2w-border); }
.q2w-product-card img { aspect-ratio: 1; object-fit: cover; margin-bottom: .75rem; }
.q2w-product-card h3 { font-size: 1rem; }
.q2w-product-card .q2w-product-price { color: var(--q2w-primary); font-weight: 700; }

/* ========== Class schedule (fitness) ========== */
.q2w-schedule table { width: 100%; border-collapse: collapse; background: #fff; border-radius: var(--q2w-radius); overflow: hidden; box-shadow: var(--q2w-shadow); }
.q2w-schedule th, .q2w-schedule td { padding: .75rem 1rem; border-bottom: 1px solid var(--q2w-border); text-align: left; }
.q2w-schedule th { background: var(--q2w-primary); color: #fff; }

/* ========== Pricing/membership tiers ========== */
.q2w-tiers-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.5rem; }
.q2w-tier { background: #fff; border: 2px solid var(--q2w-border); border-radius: var(--q2w-radius); padding: 2rem; text-align: center; }
.q2w-tier.q2w-tier-featured { border-color: var(--q2w-primary); transform: scale(1.03); box-shadow: var(--q2w-shadow); }
.q2w-tier-price { font-size: 2.5rem; font-weight: 800; color: var(--q2w-primary); font-family: var(--q2w-font-heading); margin: 1rem 0; }
.q2w-tier-price small { font-size: 1rem; color: var(--q2w-muted); }
.q2w-tier ul { list-style: none; padding: 0; margin: 1.5rem 0; text-align: left; }
.q2w-tier li { padding: .5rem 0; border-bottom: 1px solid var(--q2w-border); }
.q2w-tier li::before { content: '✓'; color: var(--q2w-primary); margin-right: .5rem; font-weight: 700; }

/* ========== Case studies / team (professional) ========== */
.q2w-cases-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.5rem; }
.q2w-case { background: var(--q2w-alt); padding: 2rem; border-radius: var(--q2w-radius); border-left: 4px solid var(--q2w-primary); }
.q2w-case h3 { margin-bottom: .5rem; }
.q2w-case-outcome { font-weight: 700; color: var(--q2w-primary); margin-top: 1rem; }

.q2w-team-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.5rem; text-align: center; }
.q2w-team-member img { width: 140px; height: 140px; border-radius: 50%; object-fit: cover; margin: 0 auto 1rem; }
.q2w-team-role { color: var(--q2w-muted); font-size: .92rem; }
