/*
Theme Name: STEMA Learning - Vancouver
Theme URI: https://vancouver.stemalearning.com
Author: STEMA Learning Centre
Description: Location theme for STEMA Vancouver. WooCommerce-ready and on-brand. Schools, team, FAQ and trial form managed from the Customizer; camps from products tagged "camp".
Version: 1.5.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: stemavan
*/

/* ============================================================
   STEMA Learning Centre — design system
   Colours aligned to the brand logo / COLOR_PALETTE.pdf
   coral · blue · blush · amber · green
   ============================================================ */
:root {
  --ink:        #2e4a6b;   /* navy from logo "LEARNING CENTER" — body text */
  --ink-soft:   #50607a;
  --blue:       #2c6fb4;   /* logo "m" blue — primary */
  --blue-dark:  #1f5390;
  --blue-soft:  #e9f1fa;
  --coral:      #e76a4e;   /* logo "S"/"a" coral — primary warm */
  --coral-dark: #d2553b;
  --coral-soft: #fdeee9;
  --blush:      #f2b4ac;   /* logo "e" blush pink */
  --blush-soft: #fdeeec;
  --amber:      #f4b63c;   /* logo "+" amber — energy / CTA */
  --amber-dark: #e0a21f;
  --amber-soft: #fdf3dd;
  --green:      #4fa37a;   /* logo rocket green */
  --green-dark: #3c8763;
  --green-soft: #e7f3ed;

  --paper:      #ffffff;
  --mist:       #f6f8fb;   /* alternating section bg */
  --line:       #e2e8f1;
  --muted:      #6a7890;

  --font-display: "Poppins", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-body:    "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  --maxw: 1140px;
  --radius: 16px;
  --shadow: 0 10px 30px rgba(46, 74, 107, 0.08);
  --shadow-lg: 0 20px 50px rgba(46, 74, 107, 0.14);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--blue); text-decoration: none; }
h1, h2, h3, h4 { font-family: var(--font-display); line-height: 1.15; margin: 0 0 .5em; color: var(--ink); }
h1 { font-weight: 700; }
h2 { font-weight: 700; font-size: clamp(1.7rem, 3.5vw, 2.5rem); }
h3 { font-weight: 600; }
p { margin: 0 0 1rem; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.section { padding: 84px 0; }
.section--mist { background: var(--mist); }
.section--blue { background: var(--blue-soft); }
.section--tight { padding: 56px 0; }
.eyebrow {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .78rem;
  color: var(--coral);
  margin-bottom: .8rem;
}
.lead { font-size: 1.12rem; color: var(--muted); max-width: 64ch; }
.center { text-align: center; }
.center .lead { margin-left: auto; margin-right: auto; }

/* buttons */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--font-display); font-weight: 600; font-size: 1rem;
  padding: 14px 26px; border-radius: 999px; border: 2px solid transparent;
  cursor: pointer; transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn--primary { background: var(--amber); color: var(--ink); box-shadow: 0 8px 20px rgba(244,182,60,.4); }
.btn--primary:hover { background: var(--amber-dark); transform: translateY(-2px); color:#fff; }
.btn--coral { background: var(--coral); color:#fff; box-shadow: 0 8px 20px rgba(231,106,78,.35); }
.btn--coral:hover { background: var(--coral-dark); transform: translateY(-2px); }
.btn--ghost { background: transparent; color: var(--blue); border-color: var(--blue); }
.btn--ghost:hover { background: var(--blue); color: #fff; }
.btn--white { background: #fff; color: var(--blue); }
.btn--white:hover { transform: translateY(-2px); box-shadow: var(--shadow); }

/* header */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.94);
  backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--line);
}
.site-header .wrap { display: flex; align-items: center; justify-content: space-between; min-height: 76px; gap: 1rem; }
.brand { display: flex; align-items: center; }
.brand img { height: 52px; width: auto; }
.nav { display: flex; align-items: center; gap: 1.35rem; }
.nav a.navlink { font-family: var(--font-display); font-weight: 500; font-size: .95rem; color: var(--ink); }
.nav a.navlink:hover, .nav a.navlink.active { color: var(--coral); }
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; font-size: 1.7rem; color: var(--ink); line-height:1; }

/* About dropdown */
.navdrop { position: relative; }
.navdrop > .navlink { cursor: pointer; }
/* invisible hover bridge so the menu doesn't vanish when crossing the gap */
.navdrop::after { content:""; position:absolute; top:100%; left:-10px; right:-10px; height:16px; }
.navdrop-menu {
  position: absolute; top: calc(100% + 12px); left: 50%; transform: translateX(-50%) translateY(6px);
  min-width: 170px; background:#fff; border:1px solid var(--line); border-radius:12px;
  box-shadow: var(--shadow-lg); padding:8px; opacity:0; visibility:hidden;
  transition: opacity .18s ease, transform .18s ease, visibility .18s; z-index:60;
}
.navdrop:hover .navdrop-menu, .navdrop:focus-within .navdrop-menu { opacity:1; visibility:visible; transform: translateX(-50%) translateY(0); }
.navdrop-menu a { display:block; padding:9px 14px; border-radius:8px; font-family:var(--font-display); font-weight:500; font-size:.92rem; color:var(--ink); }
.navdrop-menu a:hover { background: var(--mist); color: var(--coral); }

/* hero */
.hero { position: relative; overflow: hidden; background:
    radial-gradient(1200px 500px at 82% -10%, var(--amber-soft), transparent 60%),
    linear-gradient(180deg, #fff 0%, var(--mist) 100%); }
.hero .wrap { display: grid; grid-template-columns: 1.05fr .95fr; gap: 48px; align-items: center; padding-top: 72px; padding-bottom: 72px; }
.hero h1 { font-size: clamp(2.2rem, 5vw, 3.4rem); }
.hero h1 .hl { color: var(--coral); position: relative; white-space: nowrap; }
.hero h1 .hl::after { content:""; position:absolute; left:0; right:0; bottom:.05em; height:.28em; background: rgba(244,182,60,.45); z-index:-1; border-radius:4px; }
.hero .lead { margin-bottom: 1.8rem; }
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; }
.hero-trust { display:flex; gap:1.4rem; margin-top:1.8rem; flex-wrap:wrap; }
.hero-trust div { font-size:.86rem; color:var(--muted); }
.hero-trust b { display:block; font-family:var(--font-display); font-size:1.5rem; color:var(--ink); }

/* dual-photo banner */
.hero-stack { display:grid; grid-template-columns: 1fr 1fr; gap:16px; }
.hero-stack figure { margin:0; border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-lg); aspect-ratio: 3 / 4; }
.hero-stack figure:first-child { transform: translateY(-14px) rotate(-2deg); }
.hero-stack figure:last-child  { transform: translateY(14px) rotate(2deg); }
.hero-stack img { width:100%; height:100%; object-fit: cover; }

/* page banner (interior pages) */
.page-hero { background:
    radial-gradient(900px 400px at 85% -20%, var(--blue-soft), transparent 60%),
    linear-gradient(180deg,#fff,var(--mist)); padding: 64px 0 52px; border-bottom:1px solid var(--line); }
.page-hero h1 { font-size: clamp(2rem,4.4vw,3rem); }
.page-hero .lead { margin: .4rem auto 0; }

/* location cards */
.loc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 2.4rem; }
.loc-card { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 30px; box-shadow: var(--shadow); transition: transform .15s ease, box-shadow .15s ease; }
.loc-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.loc-card h3 { color: var(--blue); font-size: 1.4rem; margin-bottom: .8rem; }
.loc-card .row { display: flex; gap: .6rem; align-items: flex-start; margin-bottom: .5rem; color: var(--muted); }
.loc-card .row b { color: var(--ink); font-weight: 500; }
.loc-card .btn { margin-top: 1.2rem; }
.map-frame { border:0; width:100%; height:300px; border-radius: var(--radius); box-shadow: var(--shadow); margin-bottom: 18px; }

/* pillars */
.pillars { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; margin-top: 2.6rem; }
.pillar { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 26px; }
.pillar .ico { width: 50px; height: 50px; border-radius: 13px; display:flex; align-items:center; justify-content:center; font-size:1.5rem; margin-bottom: 1rem; }
.pillar:nth-child(1) .ico { background: var(--coral-soft); }
.pillar:nth-child(2) .ico { background: var(--amber-soft); }
.pillar:nth-child(3) .ico { background: var(--green-soft); }
.pillar:nth-child(4) .ico { background: var(--blue-soft); }
.pillar h3 { font-size: 1.1rem; margin-bottom: .4rem; }
.pillar p { font-size: .95rem; color: var(--muted); margin: 0; }

/* program cards with image */
.prog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 2.6rem; }
.pcard { background:#fff; border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow); transition: transform .15s ease, box-shadow .15s ease; }
.pcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.pcard .ph { height: 210px; overflow:hidden; background:var(--mist); }
.pcard .ph img { width:100%; height:100%; object-fit: cover; display:block; }
.pcard .body { padding: 22px 24px 26px; }
.pcard h3 { font-size: 1.12rem; margin-bottom: .4rem; }
.pcard p { font-size: .94rem; color: var(--muted); margin:0; }
.pcard .tag { display:inline-block; font-family:var(--font-display); font-weight:600; font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; padding:3px 10px; border-radius:999px; margin-bottom:.7rem; background:var(--blue-soft); color:var(--blue); }
.pcard a.ph { display:block; }
.pcard h3 a { color:inherit; }
.pcard h3 a:hover { color:var(--coral); }
.pcard .more { display:inline-block; margin-top:.8rem; font-family:var(--font-display); font-weight:600; font-size:.9rem; color:var(--coral); }
.pcard .more:hover { color:var(--coral-dark); }

/* blog pagination (WordPress the_posts_pagination) */
.pagination .nav-links { display:flex; gap:8px; justify-content:center; flex-wrap:wrap; }
.pagination .page-numbers { display:inline-flex; align-items:center; justify-content:center; min-width:42px; height:42px; padding:0 12px; border:1px solid var(--line); border-radius:10px; font-family:var(--font-display); font-weight:600; color:var(--ink); background:#fff; }
.pagination .page-numbers.current { background:var(--coral); color:#fff; border-color:var(--coral); }
.pagination a.page-numbers:hover { border-color:var(--coral); color:var(--coral); }

/* age pathways */
.ages { display:grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 2.4rem; }
.age-card { border-radius: var(--radius); padding: 34px; color:#fff; box-shadow: var(--shadow); }
.age-card.explorer { background: linear-gradient(135deg, var(--coral), var(--coral-dark)); }
.age-card.genius   { background: linear-gradient(135deg, var(--blue), var(--blue-dark)); }
.age-card h3 { color:#fff; font-size: 1.5rem; }
.age-card p { color: rgba(255,255,255,.94); margin:0 0 1rem; }
.age-card ul { margin:0 0 1.2rem; padding-left: 1.1rem; color: rgba(255,255,255,.92); font-size:.95rem; }
.age-card li { margin-bottom:.3rem; }
.age-card .tag { display:inline-block; font-family:var(--font-display); font-weight:600; font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; background: rgba(255,255,255,.22); padding:4px 12px; border-radius:999px; margin-bottom: .8rem; }
.age-card .btn--white { margin-top:.4rem; }

/* curriculum stat band */
.statband { display:grid; grid-template-columns: repeat(4,1fr); gap:24px; margin-top:2.4rem; }
.stat { text-align:center; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:28px 18px; }
.stat b { display:block; font-family:var(--font-display); font-weight:700; font-size:2rem; color:var(--coral); }
.stat span { font-size:.92rem; color:var(--muted); }
.track { display:grid; grid-template-columns: repeat(3,1fr); gap:24px; margin-top:2.4rem; text-align:left; }
.track .t { background:#fff; border:1px solid var(--line); border-top:4px solid var(--blue); border-radius:var(--radius); padding:26px; }
.track .t:nth-child(2){ border-top-color: var(--coral); }
.track .t:nth-child(3){ border-top-color: var(--green); }

/* partners */
.partners { display:flex; flex-wrap:wrap; gap: 20px; align-items:center; justify-content:center; margin-top: 2rem; }
.partner-logo { height: 64px; min-width: 120px; border:1px solid var(--line); border-radius:10px; display:flex; align-items:center; justify-content:center; color:var(--muted); font-size:.82rem; font-family:var(--font-display); padding: 0 16px; background:#fff; text-align:center; }

/* lms / dashboard */
.lms { display:grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items:center; }
.lms .badges { display:flex; gap:14px; flex-wrap:wrap; margin-top:1.2rem; }
.store-badge { height:48px; border-radius:10px; background:var(--ink); color:#fff; display:flex; align-items:center; gap:.5rem; padding:0 18px; font-family:var(--font-display); font-size:.85rem; }
.lms-media { border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-lg); border:1px solid var(--line); }
.lms-media img { width:100%; height:auto; }

/* testimonials */
.tgrid { display:grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 2.6rem; }
.tcard { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 28px; box-shadow: var(--shadow); }
.tcard .stars { color: var(--amber); margin-bottom: .6rem; letter-spacing:2px; }
.tcard p { font-size: 1rem; }
.tcard .who { font-family:var(--font-display); font-weight:600; font-size:.9rem; color: var(--coral); margin-top: 1rem; }

/* gallery */
.gallery { display:grid; grid-template-columns: repeat(4,1fr); gap:14px; margin-top:2.4rem; }
.gallery a { display:block; border-radius:12px; overflow:hidden; aspect-ratio: 1 / 1; box-shadow: var(--shadow); }
.gallery img { width:100%; height:100%; object-fit:cover; transition: transform .3s ease; }
.gallery a:hover img { transform: scale(1.06); }
.lightbox { position:fixed; inset:0; background:rgba(20,30,45,.92); display:none; align-items:center; justify-content:center; z-index:200; padding:24px; }
.lightbox.open { display:flex; }
.lightbox img { max-width:92vw; max-height:88vh; border-radius:10px; box-shadow: var(--shadow-lg); }
.lightbox .x { position:absolute; top:20px; right:28px; color:#fff; font-size:2.4rem; cursor:pointer; line-height:1; font-family:var(--font-display); }

/* FAQ accordion */
.faq { max-width: 820px; margin: 2.4rem auto 0; }
.faq details { background:#fff; border:1px solid var(--line); border-radius:12px; margin-bottom:12px; box-shadow: var(--shadow); overflow:hidden; }
.faq summary { list-style:none; cursor:pointer; padding:20px 24px; font-family:var(--font-display); font-weight:600; color:var(--ink); display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:"+"; color:var(--coral); font-size:1.5rem; font-weight:400; transition: transform .2s ease; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq .a { padding: 0 24px 22px; color: var(--muted); }
.faq .a a { color: var(--blue); }

/* contact form */
.contact-grid { display:grid; grid-template-columns: 1.1fr .9fr; gap: 40px; align-items:start; }
.lead-form { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 32px; box-shadow: var(--shadow); }
.lead-form .field { margin-bottom: 16px; }
.lead-form label { display:block; font-family:var(--font-display); font-weight:600; font-size:.85rem; margin-bottom:6px; color:var(--ink); }
.lead-form input, .lead-form select, .lead-form textarea {
  width:100%; padding:12px 14px; border:1px solid var(--line); border-radius:10px;
  font-family:var(--font-body); font-size:1rem; color:var(--ink); background:#fff; }
.lead-form input:focus, .lead-form select:focus, .lead-form textarea:focus { outline:none; border-color: var(--blue); box-shadow:0 0 0 3px var(--blue-soft); }
.lead-form .row2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.lead-form .btn { width:100%; justify-content:center; margin-top:6px; }
.form-actions { display:flex; gap:12px; margin-top:6px; }
.form-actions .btn { width:auto; flex:1; margin-top:0; }
@media (max-width:420px){ .form-actions { flex-direction:column; } }
.info-card { background: var(--blue-soft); border-radius: var(--radius); padding: 30px; }
.info-card h3 { color: var(--blue); }
.info-card .row { display:flex; gap:.6rem; margin-bottom:.6rem; color:var(--ink); align-items:flex-start; }
.cf7-note { font-size:.82rem; color:var(--muted); margin-top:1rem; }

/* legal pages (terms / privacy) */
.legal { max-width: 820px; margin: 0 auto; }
.legal h2 { font-size: 1.25rem; margin: 2.2rem 0 .5rem; color: var(--blue); }
.legal h3 { font-size: 1.02rem; margin: 1.5rem 0 .3rem; color: var(--ink); }
.legal p { color: var(--ink-soft); }
.legal ul { color: var(--ink-soft); padding-left: 1.2rem; margin: 0 0 1rem; }
.legal li { margin-bottom: .35rem; }
.legal a { color: var(--blue); }
.legal-updated { font-family: var(--font-display); font-weight: 600; font-size: .85rem; color: var(--muted); letter-spacing:.04em; text-transform: uppercase; }
.legal-note { margin-top: 2.4rem; padding: 18px 22px; background: var(--amber-soft); border-radius: 12px; font-size: .9rem; color: var(--ink-soft); }

/* final cta */
.cta-band { background: linear-gradient(135deg, var(--coral), var(--coral-dark)); color:#fff; border-radius: 24px; padding: 56px; text-align:center; box-shadow: var(--shadow-lg); }
.cta-band h2 { color:#fff; }
.cta-band p { color: rgba(255,255,255,.92); max-width: 52ch; margin: 0 auto 1.6rem; }
.cta-band .hero-cta { justify-content:center; }
.cta-band .btn--ghost { color:#fff; border-color:#fff; }
.cta-band .btn--ghost:hover { background:#fff; color: var(--coral); }

/* footer */
.site-footer { background: var(--ink); color: #c7d3e6; padding: 56px 0 28px; }
.site-footer a { color:#c7d3e6; }
.site-footer a:hover { color:#fff; }
.site-footer img.flogo { height:50px; width:auto; margin-bottom:1rem; background:#fff; padding:9px 13px; border-radius:12px; box-shadow:var(--shadow); }
.foot-grid { display:flex; justify-content:space-between; flex-wrap:wrap; gap: 30px; }
.foot-col h4 { color:#fff; font-size:.95rem; letter-spacing:.04em; margin-bottom:.9rem; }
.foot-links { display:flex; flex-direction:column; gap:.55rem; font-family:var(--font-display); font-size:.92rem; }
.foot-social { display:flex; gap: .8rem; margin-top:.2rem; }
.foot-social a { width:38px; height:38px; border-radius:10px; background:rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; }
.foot-social a:hover { background:var(--coral); }
.foot-social svg { width:18px; height:18px; fill:#fff; }
.foot-bottom { border-top:1px solid rgba(255,255,255,.12); margin-top: 30px; padding-top: 20px; font-size:.85rem; color:#90a0bd; display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem; }

/* block divider (signature: building blocks in brand colours) */
.blocks { display:flex; gap:6px; justify-content:center; margin: 0 0 1.4rem; }
.blocks span { width:14px; height:14px; border-radius:4px; }
.blocks span:nth-child(1){ background: var(--coral); }
.blocks span:nth-child(2){ background: var(--amber); transform: translateY(-4px); }
.blocks span:nth-child(3){ background: var(--green); }
.blocks span:nth-child(4){ background: var(--blue); transform: translateY(-4px); }

/* responsive */
@media (max-width: 920px) {
  .hero .wrap { grid-template-columns: 1fr; }
  .hero-stack { order:-1; max-width:460px; }
  .pillars { grid-template-columns: 1fr 1fr; }
  .prog-grid { grid-template-columns: 1fr 1fr; }
  .loc-grid, .ages, .lms, .tgrid, .contact-grid, .track, .statband { grid-template-columns: 1fr; }
  .gallery { grid-template-columns: repeat(3,1fr); }
  .nav { position:absolute; top:76px; left:0; right:0; flex-direction:column; align-items:stretch; gap:0; background:#fff; border-bottom:1px solid var(--line); padding:.5rem 24px 1rem; display:none; box-shadow: var(--shadow); }
  .nav.open { display:flex; }
  .nav a.navlink { padding:.7rem 0; border-bottom:1px solid var(--line); }
  .nav .btn { margin-top:.8rem; justify-content:center; }
  /* dropdown expands inline on mobile */
  .navdrop-menu { position:static; transform:none; opacity:1; visibility:visible; box-shadow:none; border:0; padding:0 0 0 1rem; min-width:0; }
  .navdrop-menu a { padding:.6rem 0; border-bottom:1px solid var(--line); border-radius:0; }
  .nav-toggle { display:block; }
  .section { padding: 60px 0; }
  .statband { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .pillars, .prog-grid, .gallery { grid-template-columns: 1fr 1fr; }
  .hero-trust { gap:1rem; }
  .cta-band { padding: 36px 24px; }
  .foot-bottom { flex-direction:column; }
}
@media (prefers-reduced-motion: reduce) { * { scroll-behavior:auto !important; transition:none !important; } }

/* ============================================================
   LOCATION SITE — additional components (Vancouver)
   Reuses the main-site tokens above for visual consistency.
   ============================================================ */

/* slim sticky utility bar above header */
.topbar { background: var(--ink); color:#fff; font-size:.86rem; }
.topbar .wrap { display:flex; align-items:center; justify-content:space-between; min-height:42px; gap:1rem; }
.topbar a { color:#fff; }
.topbar .tb-left { display:flex; gap:1.2rem; align-items:center; flex-wrap:wrap; }
.topbar .tb-left span { display:inline-flex; gap:.4rem; align-items:center; }
.topbar .btn { padding:6px 16px; font-size:.82rem; }
.brand .city { display:inline-block; margin-left:.6rem; font-family:var(--font-display); font-weight:600; font-size:.8rem; color:#fff; background:var(--coral); padding:3px 10px; border-radius:999px; vertical-align:middle; }

/* funnel badges */
.funnel { display:inline-block; font-family:var(--font-display); font-weight:600; font-size:.66rem; letter-spacing:.03em; padding:3px 10px; border-radius:6px; }
.funnel.lead { background:var(--amber-soft); color:var(--amber-dark); border:1px solid #f0d290; }
.funnel.buy  { background:var(--green-soft); color:var(--green-dark); border:1px solid #a9ddc3; }
.funnel.inq  { background:var(--blue-soft);  color:var(--blue);       border:1px solid #bcd3ef; }

/* quick-facts bar */
.qfacts { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:-34px; position:relative; z-index:3; }
.qfact { background:#fff; border:1px solid var(--line); border-radius:14px; padding:20px 22px; box-shadow:var(--shadow); }
.qfact .ic { font-size:1.4rem; }
.qfact .lab { font-family:var(--font-display); font-weight:600; font-size:.92rem; margin:.4rem 0 .15rem; }
.qfact .val { font-size:.9rem; color:var(--muted); }

/* "ways to learn" cards */
.ways { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; margin-top:2.4rem; text-align:left; }
.way { background:#fff; border:1px solid var(--line); border-top:4px solid var(--coral); border-radius:var(--radius); padding:24px; }
.way:nth-child(2){ border-top-color:var(--blue); }
.way:nth-child(3){ border-top-color:var(--green); }
.way:nth-child(4){ border-top-color:var(--amber); }
.way .ic { font-size:1.7rem; }
.way h3 { font-size:1.06rem; margin:.5rem 0 .35rem; }
.way p { font-size:.9rem; color:var(--muted); margin:0 0 .8rem; }

/* flagship product band */
.flagship { background: var(--amber-soft); }
.product-grid { display:grid; grid-template-columns:1.1fr .9fr; gap:36px; align-items:start; margin-top:2rem; }
.product-grid .feat { display:flex; flex-wrap:wrap; gap:8px; margin:.8rem 0 1.2rem; }
.product-grid .feat span { background:#fff; border:1px solid var(--line); border-radius:999px; padding:5px 12px; font-size:.82rem; font-family:var(--font-display); font-weight:500; }
.avail-table { width:100%; border-collapse:collapse; font-size:.92rem; margin-top:.5rem; background:#fff; border-radius:10px; overflow:hidden; }
.avail-table th, .avail-table td { border:1px solid var(--line); padding:9px 14px; text-align:left; }
.avail-table th { background:var(--blue-soft); color:var(--blue); font-family:var(--font-display); }
.price-card { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:26px; box-shadow:var(--shadow-lg); }
.price-card .pimg { border-radius:12px; overflow:hidden; margin-bottom:1rem; border:1px solid var(--line); }
.price-card .prow { display:flex; justify-content:space-between; align-items:baseline; padding:8px 0; border-bottom:1px dashed var(--line); }
.price-card .prow b { font-family:var(--font-display); }
.price-card .big { font-family:var(--font-display); font-weight:700; color:var(--coral); font-size:1.5rem; }
.price-card .note { font-size:.82rem; color:var(--muted); margin:.6rem 0 0; }
.price-card .btn { width:100%; justify-content:center; margin-top:1rem; }
.wc-note { font-size:.78rem; color:var(--muted); margin-top:1rem; padding:10px 14px; background:var(--mist); border-radius:8px; }

/* schools (in-school programs) */
.schools { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:2rem; }
.school { display:flex; flex-direction:column; align-items:center; text-align:center; gap:.7rem; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:24px 18px; box-shadow:var(--shadow); transition:transform .15s ease, box-shadow .15s ease; }
.school:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--coral); }
.school img { height:88px; width:auto; object-fit:contain; }
.school .nm { font-family:var(--font-display); font-weight:600; color:var(--ink); font-size:.98rem; }
.school .go { font-size:.84rem; color:var(--coral); font-family:var(--font-display); font-weight:600; }
.school .logo-fallback { height:88px; width:88px; border-radius:14px; background:var(--blue-soft); color:var(--blue); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:700; font-size:1.6rem; }

/* camps */
.camp-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:2rem; text-align:left; }
.camp { display:grid; grid-template-columns:120px 1fr; gap:18px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow); align-items:center; }
.camp .cimg { width:120px; height:120px; border-radius:12px; overflow:hidden; background:var(--mist); }
.camp .cimg img { width:100%; height:100%; object-fit:cover; }
.camp h3 { font-size:1.05rem; margin:0 0 .3rem; }
.camp .meta { font-size:.86rem; color:var(--muted); margin-bottom:.2rem; }
.camp .price { font-family:var(--font-display); font-weight:700; color:var(--coral); }

/* team */
.team { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:1.4rem; }
.member { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:22px; text-align:center; box-shadow:var(--shadow); }
.member .av { width:84px; height:84px; border-radius:50%; margin:0 auto .7rem; background:var(--blue-soft); display:flex; align-items:center; justify-content:center; font-size:2rem; }
.member b { font-family:var(--font-display); }
.member .role { font-size:.85rem; color:var(--muted); }

/* team carousel */
.carousel { position:relative; margin-top:2.4rem; }
.c-track { display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 4px 14px; scrollbar-width:thin; -webkit-overflow-scrolling:touch; }
.c-track::-webkit-scrollbar { height:8px; }
.c-track::-webkit-scrollbar-thumb { background:var(--line); border-radius:99px; }
.tc-card { flex:0 0 178px; scroll-snap-align:start; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:24px 18px; text-align:center; }
.tc-card .av { width:72px; height:72px; border-radius:50%; margin:0 auto .8rem; display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:700; font-size:1.4rem; color:#fff; background:var(--blue); }
.tc-card b { font-family:var(--font-display); display:block; font-size:.98rem; }
.tc-card .role { font-size:.84rem; color:var(--muted); margin-top:.2rem; }
.tc-card:nth-child(5n+1) .av { background:var(--coral); }
.tc-card:nth-child(5n+2) .av { background:var(--blue); }
.tc-card:nth-child(5n+3) .av { background:var(--green); }
.tc-card:nth-child(5n+4) .av { background:var(--amber); color:var(--ink); }
.tc-card:nth-child(5n+5) .av { background:#7a5cc0; }
.tc-card.lead-mgr { border-color:var(--coral); box-shadow:0 12px 30px rgba(231,106,78,.18); }
.tc-card.lead-mgr .av { background:var(--coral); }
.c-btn { position:absolute; top:36%; z-index:2; width:42px; height:42px; border-radius:50%; border:1px solid var(--line); background:#fff; box-shadow:var(--shadow); cursor:pointer; font-size:1.6rem; line-height:1; color:var(--ink); display:flex; align-items:center; justify-content:center; }
.c-btn.prev { left:-8px; }
.c-btn.next { right:-8px; }
.c-btn:hover { background:var(--coral); color:#fff; border-color:var(--coral); }
@media (max-width:560px) { .c-btn { display:none; } }

/* header cart / account icons */
.nav-icon { display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:10px; color:var(--ink); position:relative; }
.nav-icon svg { width:22px; height:22px; fill:currentColor; }
.nav-icon:hover { background:var(--blue-soft); color:var(--coral); }
.nav-icon + .nav-icon { margin-left:-4px; }

/* product gallery (thumbnails) */
.pg-main { border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; box-shadow:var(--shadow); }
.pg-main img { width:100%; display:block; aspect-ratio:4/3; object-fit:cover; }
.pg-thumbs { display:flex; gap:10px; margin-top:12px; flex-wrap:wrap; }
.pg-thumb { width:72px; height:72px; border:2px solid var(--line); border-radius:10px; overflow:hidden; padding:0; cursor:pointer; background:#fff; }
.pg-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.pg-thumb.active, .pg-thumb:hover { border-color:var(--coral); }

/* flattened product description */
.product-desc { max-width:840px; margin:3rem 0 0; }
.product-desc h2 { font-size:1.5rem; }
.product-desc h3 { color:var(--blue); margin:1.5rem 0 .3rem; font-size:1.1rem; }
.product-desc p { color:var(--ink-soft); }

/* getting-here card */
.gethere { background:var(--blue-soft); border-radius:var(--radius); padding:26px; }
.gethere h3 { color:var(--blue); }
.gethere .row { display:flex; gap:.6rem; margin-bottom:.5rem; color:var(--ink); align-items:flex-start; }

@media (max-width: 920px){
  .qfacts, .ways, .schools, .team { grid-template-columns:1fr 1fr; }
  .product-grid, .camp-grid { grid-template-columns:1fr; }
  .qfacts { margin-top:1.6rem; }
  .camp { grid-template-columns:90px 1fr; } .camp .cimg{width:90px;height:90px;}
  .topbar .tb-left .hide-sm { display:none; }
}
@media (max-width: 560px){
  .qfacts, .ways, .schools, .team { grid-template-columns:1fr; }
}

/* ============================================================
   WOOCOMMERCE-STYLE PAGES (shop · product · cart · checkout)
   ============================================================ */
.breadcrumb { font-size:.85rem; color:var(--muted); }
.breadcrumb a { color:var(--blue); }
.breadcrumb { margin-bottom:.4rem; }

.shop-toolbar { display:flex; justify-content:space-between; align-items:center; gap:1rem; margin:0 0 1.6rem; flex-wrap:wrap; }
.shop-toolbar .count { color:var(--muted); font-size:.9rem; }
.shop-cats { display:flex; gap:.5rem; flex-wrap:wrap; }
.shop-cats a { font-family:var(--font-display); font-weight:500; font-size:.86rem; padding:7px 14px; border-radius:999px; border:1px solid var(--line); color:var(--ink); background:#fff; }
.shop-cats a.active, .shop-cats a:hover { background:var(--coral); color:#fff; border-color:var(--coral); }
select.sort { padding:9px 12px; border:1px solid var(--line); border-radius:8px; font-family:var(--font-body); background:#fff; }

.wc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.wc-card { background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); display:flex; flex-direction:column; transition:transform .15s ease, box-shadow .15s ease; position:relative; }
.wc-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.wc-card .img { aspect-ratio:4/3; background:var(--mist); overflow:hidden; }
.wc-card .img img { width:100%; height:100%; object-fit:cover; }
.wc-card .pad { padding:18px 20px 22px; display:flex; flex-direction:column; flex:1; }
.wc-card .cat { font-size:.72rem; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); font-family:var(--font-display); font-weight:600; }
.wc-card h3 { font-size:1.05rem; margin:.3rem 0 .5rem; }
.wc-card h3 a { color:inherit; } .wc-card h3 a:hover { color:var(--coral); }
.wc-card .btn { margin-top:auto; }
.wc-price { font-family:var(--font-display); font-weight:700; color:var(--coral); font-size:1.1rem; margin-bottom:.9rem; }
.wc-price .unit { font-weight:500; font-size:.8rem; color:var(--muted); }
.wc-price del { color:var(--muted); font-weight:500; font-size:.95rem; margin-right:.4rem; }
.badge-sale, .badge-sub { position:absolute; top:12px; color:#fff; font-family:var(--font-display); font-weight:600; font-size:.7rem; padding:4px 10px; border-radius:999px; z-index:2; }
.badge-sale { left:12px; background:var(--green); }
.badge-sub  { right:12px; background:var(--blue); }

/* single product */
.product-single { display:grid; grid-template-columns:1fr 1fr; gap:44px; margin-top:1rem; align-items:start; }
.product-gallery { border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); background:#fff; }
.product-gallery img { width:100%; display:block; }
.product-summary h1 { font-size:2rem; margin-bottom:.3rem; }
.product-summary .wc-price { font-size:1.6rem; margin:.4rem 0 1rem; }
.product-summary .short { color:var(--muted); margin:0 0 1rem; }
.var-row { display:flex; align-items:center; gap:1rem; margin:.7rem 0; flex-wrap:wrap; }
.var-row > label { font-family:var(--font-display); font-weight:600; font-size:.9rem; min-width:110px; }
.var-row select, .qty input { padding:10px 12px; border:1px solid var(--line); border-radius:8px; font-family:var(--font-body); font-size:1rem; background:#fff; }
.qty input { width:64px; text-align:center; }
.add-row { display:flex; gap:12px; margin-top:1.2rem; flex-wrap:wrap; }
.product-meta { margin-top:1.6rem; font-size:.85rem; color:var(--muted); border-top:1px solid var(--line); padding-top:1rem; }
.product-meta span { display:block; margin-bottom:.25rem; }
.stock { color:var(--green-dark); font-weight:600; font-size:.9rem; }

.wc-tabs { margin-top:3.2rem; }
.wc-tabnav { display:flex; gap:.4rem; border-bottom:2px solid var(--line); flex-wrap:wrap; }
.wc-tabnav button { background:none; border:0; border-bottom:3px solid transparent; margin-bottom:-2px; padding:12px 18px; font-family:var(--font-display); font-weight:600; font-size:.95rem; color:var(--muted); cursor:pointer; }
.wc-tabnav button.active { color:var(--coral); border-bottom-color:var(--coral); }
.wc-tabpanel { padding:1.6rem 0; display:none; } .wc-tabpanel.active { display:block; }
.wc-tabpanel ul { color:var(--muted); }

/* cart */
.cart-table { width:100%; border-collapse:collapse; }
.cart-table th { text-align:left; font-family:var(--font-display); font-size:.78rem; text-transform:uppercase; letter-spacing:.04em; color:var(--muted); padding:0 8px 12px 0; border-bottom:2px solid var(--line); }
.cart-table td { padding:18px 8px 18px 0; border-bottom:1px solid var(--line); vertical-align:middle; }
.cart-prod { display:flex; gap:14px; align-items:center; }
.cart-prod img { width:72px; height:72px; border-radius:10px; object-fit:cover; }
.cart-prod b { font-family:var(--font-display); }
.cart-prod .mini { font-size:.8rem; color:var(--muted); }
.cart-x { color:var(--muted); text-decoration:none; font-size:1.2rem; }
.cart-x:hover { color:var(--coral); }
.cart-layout { display:grid; grid-template-columns:1.6fr .9fr; gap:36px; align-items:start; margin-top:1rem; }
.totals { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:26px; box-shadow:var(--shadow); }
.totals h3 { margin-top:0; }
.totals .line { display:flex; justify-content:space-between; padding:11px 0; border-bottom:1px solid var(--line); font-size:.95rem; }
.totals .grand { font-family:var(--font-display); font-weight:700; font-size:1.25rem; color:var(--ink); border-bottom:0; padding-top:14px; }
.totals .btn { width:100%; justify-content:center; margin-top:1rem; }
.coupon { display:flex; gap:10px; margin-top:1.2rem; }
.coupon input { flex:1; padding:11px 12px; border:1px solid var(--line); border-radius:8px; font-family:var(--font-body); }

/* checkout */
.checkout-layout { display:grid; grid-template-columns:1.2fr .8fr; gap:40px; align-items:start; margin-top:1rem; }
.order-summary { background:var(--mist); border:1px solid var(--line); border-radius:var(--radius); padding:26px; position:sticky; top:90px; }
.order-summary h3 { margin-top:0; }
.order-row { display:flex; justify-content:space-between; gap:1rem; padding:11px 0; border-bottom:1px solid var(--line); font-size:.92rem; }
.order-row.grand { font-family:var(--font-display); font-weight:700; font-size:1.15rem; color:var(--ink); border-bottom:0; }
.pay-method { display:block; border:1px solid var(--line); border-radius:10px; padding:14px 16px; margin-bottom:10px; background:#fff; cursor:pointer; }
.pay-method.sel { border-color:var(--blue); box-shadow:0 0 0 3px var(--blue-soft); }
.pay-method input { vertical-align:-2px; margin-right:8px; accent-color:var(--blue); }
.pay-method .lab { font-family:var(--font-display); font-weight:600; }
.pay-method .mini { display:block; font-size:.84rem; color:var(--muted); margin-top:.3rem; padding-left:25px; }

@media (max-width: 920px){
  .wc-grid { grid-template-columns:1fr 1fr; }
  .product-single, .cart-layout, .checkout-layout { grid-template-columns:1fr; }
  .order-summary { position:static; }
}
@media (max-width: 560px){ .wc-grid { grid-template-columns:1fr; } }

/* ===== Camp product — theme/week variation cards ===== */
.theme-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:1.2rem; }
.theme-card { border:2px solid var(--line); border-radius:14px; overflow:hidden; background:#fff; cursor:pointer; transition:border-color .15s ease, box-shadow .15s ease, transform .15s ease; display:flex; flex-direction:column; }
.theme-card:hover { transform:translateY(-3px); box-shadow:var(--shadow); }
.theme-card.sel { border-color:var(--coral); box-shadow:0 0 0 3px var(--coral-soft); }
.theme-card.soldout { opacity:.55; cursor:not-allowed; }
.theme-thumb { height:92px; display:flex; align-items:center; justify-content:center; font-size:2.2rem; color:#fff; position:relative; }
.theme-thumb .wk { position:absolute; top:8px; left:10px; font-family:var(--font-display); font-weight:700; font-size:.68rem; letter-spacing:.03em; background:rgba(255,255,255,.28); padding:2px 9px; border-radius:999px; }
.theme-body { padding:12px 14px 8px; display:flex; flex-direction:column; flex:1; }
.theme-body h4 { font-family:var(--font-display); font-size:.95rem; margin:0 0 .25rem; line-height:1.25; }
.theme-body .desc { font-size:.8rem; color:var(--muted); margin:0 0 .6rem; flex:1; }
.theme-body .meta { display:flex; justify-content:space-between; align-items:center; gap:.5rem; }
.theme-body .dates { font-size:.78rem; color:var(--ink); font-family:var(--font-display); font-weight:600; }
.theme-body .tp { font-family:var(--font-display); font-weight:700; color:var(--coral); font-size:.92rem; white-space:nowrap; }
.theme-card .pick { text-align:center; font-family:var(--font-display); font-weight:600; font-size:.8rem; padding:9px; background:var(--mist); color:var(--ink); border-top:1px solid var(--line); margin-top:8px; }
.theme-card.sel .pick { background:var(--coral); color:#fff; }
.theme-card.sel .pick::before { content:"✓ "; }
.camp-options { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:1.6rem; max-width:560px; }
.camp-selected { margin-top:1rem; padding:14px 18px; border:1px dashed var(--coral); border-radius:12px; background:var(--coral-soft); font-size:.9rem; display:none; }
.camp-selected.show { display:block; }
@media (max-width:920px){ .theme-grid { grid-template-columns:1fr 1fr; } .camp-options { grid-template-columns:1fr; } }
@media (max-width:560px){ .theme-grid { grid-template-columns:1fr; } }

/* ============================================================
   WOOCOMMERCE - on-brand overrides
   ============================================================ */
.woocommerce, .woocommerce-page { color: var(--ink); }
.woocommerce .woocommerce-breadcrumb { font-size:.85rem; color:var(--muted); margin-bottom:1.4rem; }
.woocommerce .woocommerce-breadcrumb a { color:var(--blue); }

.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce .button, .woocommerce-page .button,
.woocommerce a.button.alt, .woocommerce button.button.alt, .woocommerce input.button.alt, .wc-block-components-button {
  background: var(--amber) !important; color: var(--ink) !important; border:0 !important; border-radius:999px !important;
  font-family:var(--font-display) !important; font-weight:600 !important; padding:12px 26px !important; text-transform:none !important; transition:background .15s ease; }
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce #respond input#submit:hover, .woocommerce .button:hover, .woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover, .wc-block-components-button:hover { background: var(--amber-dark) !important; color:#fff !important; }

.woocommerce span.price, .woocommerce div.product p.price, .woocommerce ul.products li.product .price { color: var(--blue) !important; font-weight:700; }
.woocommerce div.product p.price del, .woocommerce ul.products li.product .price del { color:var(--muted); font-weight:400; }

.woocommerce ul.products li.product, .woocommerce-page ul.products li.product {
  background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow);
  padding:0 0 18px !important; overflow:hidden; transition:transform .15s ease, box-shadow .15s ease; }
.woocommerce ul.products li.product:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.woocommerce ul.products li.product a img { width:100% !important; height:210px !important; object-fit:cover !important; margin:0 0 14px !important; border-radius:0 !important; display:block; }
.woocommerce ul.products li.product .woocommerce-loop-product__title { padding:0 16px; font-family:var(--font-display); font-size:1.05rem; }
.woocommerce ul.products li.product .price, .woocommerce ul.products li.product .button, .woocommerce ul.products li.product .star-rating { margin-left:16px; margin-right:16px; }
.woocommerce ul.products li.product .button { margin-top:8px; display:inline-block; }
.woocommerce span.onsale { background:var(--coral) !important; color:#fff !important; border-radius:999px; min-height:auto; min-width:auto; padding:4px 12px; font-family:var(--font-display); font-weight:600; top:10px; left:10px; margin:0; }

.woocommerce div.product div.images img { border-radius:var(--radius); }
.woocommerce div.product .product_title { font-family:var(--font-display); }
.woocommerce div.product form.cart .quantity input.qty { border:1px solid var(--line); border-radius:10px; padding:10px; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { border-bottom-color:var(--coral); }
.woocommerce div.product .woocommerce-tabs ul.tabs li a { color:var(--ink); font-family:var(--font-display); }
.woocommerce .stock.in-stock { color:var(--green-dark); }
.woocommerce div.product .product_meta { display:none !important; }

.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea,
.woocommerce-page form .form-row input.input-text, .woocommerce select, .woocommerce input[type="date"],
.select2-container .select2-selection { border:1px solid var(--line) !important; border-radius:10px !important; padding:11px 14px !important; min-height:46px; font-family:var(--font-body); color:var(--ink); }
.woocommerce form .form-row label { font-family:var(--font-display); font-weight:600; font-size:.9rem; color:var(--ink); }

.woocommerce table.cart img, .woocommerce #content table.cart img, .woocommerce-page table.cart img,
.woocommerce-cart table.cart td.product-thumbnail img { width:90px !important; height:auto !important; border-radius:10px; }
.woocommerce table.shop_table { border-radius:var(--radius); border-color:var(--line); overflow:hidden; }

.woocommerce-checkout form.checkout.woocommerce-checkout { display:grid; grid-template-columns:1.25fr .85fr; gap:40px; align-items:start; }
.woocommerce-checkout #customer_details { grid-column:1; }
.woocommerce-checkout #customer_details .col2-set .col-1, .woocommerce-checkout #customer_details .col2-set .col-2 { width:100%; float:none; margin-bottom:1rem; }
.woocommerce-checkout h3#order_review_heading { grid-column:2; margin-top:0; }
.woocommerce-checkout #order_review { grid-column:2; position:sticky; top:90px; background:var(--mist); border:1px solid var(--line); border-radius:var(--radius); padding:24px; }
.woocommerce-checkout #payment { background:transparent; }
.woocommerce-checkout #place_order, .woocommerce #respond input#submit.alt { width:100%; justify-content:center; }
@media (max-width:900px){
  .woocommerce-checkout form.checkout.woocommerce-checkout { grid-template-columns:1fr; }
  .woocommerce-checkout #customer_details, .woocommerce-checkout h3#order_review_heading, .woocommerce-checkout #order_review { grid-column:1; }
  .woocommerce-checkout #order_review { position:static; }
}

.woocommerce-message, .woocommerce-info, .woocommerce-error { border-top-color:var(--coral); border-radius:10px; }
.woocommerce-message { border-top-color:var(--green); }

.nav-cart { position:relative; }
.cart-count { position:absolute; top:2px; right:2px; min-width:17px; height:17px; padding:0 4px; border-radius:999px; background:var(--coral); color:#fff; font-family:var(--font-display); font-size:.66rem; font-weight:700; display:flex; align-items:center; justify-content:center; line-height:1; }

/* team avatar photo support */
.tc-card .av { overflow:hidden; }
.tc-card .av img { width:100%; height:100%; object-fit:cover; border-radius:50%; display:block; }

/* product page - bigger quantity selector */
.woocommerce div.product form.cart .quantity { display:inline-flex; align-items:stretch; vertical-align:middle; }
.woocommerce div.product form.cart .quantity input.qty { width:88px !important; height:54px !important; font-size:1.15rem; text-align:center; padding:10px; border:1px solid var(--line); border-radius:10px; }
.woocommerce div.product form.cart .quantity .plus, .woocommerce div.product form.cart .quantity .minus, .woocommerce div.product form.cart .quantity .qib-button { width:46px !important; height:54px !important; font-size:1.3rem; }
.woocommerce div.product form.cart .single_add_to_cart_button { min-height:54px; }

/* cart page - two-column layout + bigger product image */
.woocommerce-cart .woocommerce { display:grid; grid-template-columns:minmax(0,1fr) 350px; gap:32px; align-items:start; }
.woocommerce-cart .woocommerce > .woocommerce-message, .woocommerce-cart .woocommerce > .woocommerce-info, .woocommerce-cart .woocommerce > .woocommerce-error { grid-column:1 / -1; }
.woocommerce-cart .woocommerce-cart-form { grid-column:1; }
.woocommerce-cart .cart-collaterals { grid-column:2; width:auto !important; float:none !important; }
.woocommerce-cart .cart-collaterals .cart_totals { width:auto !important; float:none !important; background:var(--mist); border:1px solid var(--line); border-radius:var(--radius); padding:24px; }
.woocommerce-cart .cart-collaterals .cart_totals h2 { margin-top:0; }
.woocommerce-cart table.cart td.product-thumbnail img { width:110px !important; height:auto !important; border-radius:12px; }
@media (max-width:820px){ .woocommerce-cart .woocommerce { grid-template-columns:1fr; } .woocommerce-cart .cart-collaterals, .woocommerce-cart .woocommerce-cart-form { grid-column:1; } }

/* checkout - date selector + all inputs consistent */
.woocommerce form .form-row input[type="date"], .woocommerce-checkout input[type="date"],
.woocommerce form .form-row input[type="text"], .woocommerce form .form-row input[type="email"],
.woocommerce form .form-row input[type="tel"], .woocommerce form .form-row input[type="number"],
.woocommerce form .form-row input.input-text {
  border:1px solid var(--line) !important; border-radius:10px !important; padding:11px 14px !important; min-height:48px !important; width:100%; box-sizing:border-box; font-family:var(--font-body); color:var(--ink); background:#fff; }
.woocommerce form .form-row input[type="date"]::-webkit-calendar-picker-indicator { opacity:.6; cursor:pointer; }

/* wider shop/cart container, less side space */
.wrap.wc-wrap { max-width:1340px; padding-left:18px; padding-right:18px; }
.woocommerce-cart .woocommerce { grid-template-columns:minmax(0,1fr) 360px !important; gap:28px; }
@media (max-width:820px){ .woocommerce-cart .woocommerce { grid-template-columns:1fr !important; } }
/* shop grid uses full width of the wider container */
.woocommerce ul.products { margin-left:0; margin-right:0; }

/* === FIXES v1.4 === */
/* cart product image - broad, forceful */
td.product-thumbnail img,
.woocommerce-cart td.product-thumbnail img,
.woocommerce-cart-form td.product-thumbnail img,
table.cart td.product-thumbnail img { width:96px !important; height:auto !important; max-width:none !important; border-radius:12px; }
.woocommerce-cart table.cart td.product-thumbnail, .woocommerce-cart-form td.product-thumbnail { width:120px; }

/* checkout - correct two-column: details left (spans), order review top-right */
.woocommerce-checkout form.checkout.woocommerce-checkout { display:grid; grid-template-columns:1.2fr .8fr; column-gap:40px; row-gap:0; align-items:start; }
.woocommerce-checkout #customer_details { grid-column:1; grid-row:1 / span 2; }
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 { width:100% !important; float:none !important; margin:0 0 1.2rem !important; }
.woocommerce-checkout h3#order_review_heading { grid-column:2; grid-row:1; margin-top:0; }
.woocommerce-checkout #order_review { grid-column:2; grid-row:2; position:sticky; top:90px; background:var(--mist); border:1px solid var(--line); border-radius:var(--radius); padding:24px; }
@media (max-width:900px){
  .woocommerce-checkout form.checkout.woocommerce-checkout { display:block; }
  .woocommerce-checkout #order_review { position:static; margin-top:1.5rem; }
}
