/* 4 Season's Techs, Inc. — Warm-craftsman archetype: "you know your tech by name."
   Warm cream base, terracotta + warm-green accents, friendly geometry. A family
   shop, not a corporate template. Native scroll. */

:root{
  /* warm neutrals */
  --bg:        oklch(0.975 0.012 75);   /* warm cream */
  --surface:   oklch(0.995 0.006 80);   /* near-white, faint warm */
  --ink:       oklch(0.30 0.025 55);    /* warm deep brown-charcoal (never #000) */
  --muted:     oklch(0.52 0.030 55);    /* warm secondary text */
  --faint:     oklch(0.66 0.025 60);
  --line:      oklch(0.90 0.013 70);    /* warm hairline */

  /* primary warm accent — terracotta */
  --terra:      oklch(0.64 0.135 45);   /* terracotta CTA / accent */
  --terra-deep: oklch(0.52 0.13 42);    /* hover / accent text */
  --terra-soft: oklch(0.94 0.030 50);   /* soft terracotta tint surface */

  /* secondary warm accent — friendly warm green (trust/comfort) */
  --green:      oklch(0.58 0.085 145);  /* warm sage-green */
  --green-deep: oklch(0.46 0.085 145);
  --green-soft: oklch(0.94 0.028 140);

  /* warm amber — stars / heat highlight */
  --amber:     oklch(0.78 0.135 70);
  --amber-deep:oklch(0.62 0.135 62);

  /* tinted surfaces */
  --sand:      oklch(0.955 0.022 70);   /* soft sand surface */
  --mint:      oklch(0.95 0.026 140);   /* soft green surface */

  /* legacy aliases kept so existing rules cascade to the warm scheme */
  --teal:      var(--terra);
  --teal-deep: var(--terra-deep);
  --teal-soft: var(--terra-soft);
  --sky:       var(--sand);

  --shadow-sm: 0 1px 2px rgba(70,40,20,.05), 0 4px 14px rgba(70,40,20,.06);
  --shadow-md: 0 6px 22px rgba(70,40,20,.09), 0 18px 50px rgba(70,40,20,.08);
  --shadow-lg: 0 14px 40px rgba(70,40,20,.12), 0 30px 80px rgba(70,40,20,.11);
  --r-sm:12px; --r:18px; --r-lg:26px; --r-xl:34px;
  --maxw:1180px;
  --font-head:"Bricolage Grotesque", system-ui, sans-serif;
  --font-body:"Inter", system-ui, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-body); font-size:17px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-head); font-weight:700; line-height:1.08; letter-spacing:-0.02em; margin:0}
p{margin:0}
.wrap{width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--font-head); font-weight:600; font-size:1rem; letter-spacing:-0.01em;
  padding:.85em 1.4em; border-radius:999px; border:1px solid transparent;
  cursor:pointer; transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  white-space:nowrap;
}
.btn svg{flex:0 0 auto}
.btn-primary{ background:var(--teal); color:#fff; box-shadow:0 6px 18px oklch(0.64 0.135 45 / .34); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 12px 28px oklch(0.64 0.135 45 / .42); }
.btn-ghost{ background:var(--surface); color:var(--teal-deep); border-color:var(--line); box-shadow:var(--shadow-sm); }
.btn-ghost:hover{ transform:translateY(-2px); border-color:oklch(0.80 0.07 50); box-shadow:var(--shadow-md); }
.btn-lg{ font-size:1.06rem; padding:1em 1.6em }
.btn-xl{ font-size:1.16rem; padding:1.1em 2em }
.btn-white{ background:#fff; color:var(--teal-deep) }
.btn-white:hover{ transform:translateY(-2px); box-shadow:0 12px 30px rgba(0,0,0,.16) }

/* ---------- nav ---------- */
.nav{
  position:sticky; top:0; z-index:100;
  background:oklch(0.975 0.012 75 / 0.74); backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid transparent; transition:border-color .25s ease, background .25s ease, box-shadow .25s ease;
}
.nav.scrolled{ border-bottom-color:var(--line); background:oklch(0.985 0.010 75 / 0.90); box-shadow:0 6px 24px rgba(70,40,20,.06); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:74px; gap:18px }
.brand{ display:inline-flex; align-items:center; gap:.6em; font-family:var(--font-head); font-weight:800; font-size:1.18rem; letter-spacing:-0.03em; color:var(--ink) }
.brand-mark{
  width:38px; height:38px; border-radius:11px; display:grid; place-items:center; flex:0 0 auto;
  background:linear-gradient(150deg, var(--teal), var(--teal-deep)); color:#fff;
  box-shadow:0 4px 12px oklch(0.64 0.135 45 / .35);
}
.brand-mark svg{width:21px; height:21px}
.brand-text{display:flex; flex-direction:column; line-height:1}
.brand-text small{ font-family:var(--font-body); font-weight:500; font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-top:3px }
.nav-links{ display:flex; align-items:center; gap:6px; margin-left:auto }
.nav-links a{
  font-family:var(--font-head); font-weight:500; font-size:.96rem; color:var(--muted);
  padding:.5em .9em; border-radius:999px; transition:color .18s ease, background .18s ease;
}
.nav-links a:hover{ color:var(--ink); background:var(--teal-soft) }
.nav-links a.is-current{ color:var(--teal-deep); background:var(--teal-soft) }
.nav-cta{ margin-left:8px }
@media(max-width:860px){
  .nav-links{display:none}
  .nav-inner{height:66px}
}
@media(max-width:520px){
  /* compact call button so the nav never overflows on small phones */
  .nav-cta{ font-size:.9rem; padding:.7em 1em }
  .nav-cta .nav-cta-full{ display:none }
  .nav-cta .nav-cta-short{ display:inline }
  .brand-text small{ display:none }
}
.nav-cta-short{ display:none }

/* ---------- hero ---------- */
.hero{ position:relative; padding:64px 0 40px }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:54px; align-items:center }
.eyebrow{
  display:inline-flex; align-items:center; gap:.6em; font-family:var(--font-head); font-weight:600;
  font-size:.82rem; letter-spacing:.02em; color:var(--teal-deep);
  background:var(--teal-soft); padding:.5em 1em; border-radius:999px;
}
.eyebrow .stars{ color:var(--amber-deep); letter-spacing:.05em }
.hero h1{ font-size:clamp(2.6rem, 5.6vw, 4.25rem); font-weight:800; margin:22px 0 0 }
.hero h1 .soft{ color:var(--teal-deep) }
.hero-sub{ font-size:1.18rem; color:var(--muted); margin:22px 0 0; max-width:30em }
.hero-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:14px; margin-top:30px }
.hero-trust{ display:flex; flex-wrap:wrap; gap:22px; margin-top:30px }
.hero-sub strong{ color:var(--ink); font-weight:600 }
.hero-trust{ align-items:center }
.hero-trust .ti{ display:flex; align-items:center; gap:.55em; font-size:.92rem; color:var(--muted) }
.hero-trust .ti svg{ width:18px; height:18px; color:var(--green-deep); flex:0 0 auto }
/* Hablamos Espanol — a real differentiator, given prominence */
.hero-trust .ti.hablamos{
  font-family:var(--font-head); font-weight:600; font-size:.95rem; color:var(--green-deep);
  background:var(--green-soft); padding:.45em 1em; border-radius:999px;
}
.hero-trust .ti.hablamos svg{ width:17px; height:17px; color:var(--green-deep) }

/* hero media + meet-your-techs name card */
.hero-media{ position:relative }
.hero-photo{
  border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg);
  border:1px solid oklch(1 0 0 / .6); aspect-ratio:4/3;
}
.hero-photo img{ width:100%; height:100%; object-fit:cover }
.rating-pill{
  position:absolute; left:-18px; top:26px; background:var(--surface); border-radius:var(--r);
  box-shadow:var(--shadow-md); padding:14px 18px; display:flex; align-items:center; gap:12px;
  border:1px solid var(--line);
}
.rating-pill .rp-num{ font-family:var(--font-head); font-weight:800; font-size:1.7rem; line-height:1; color:var(--ink) }
.rating-pill .rp-stars{ color:var(--amber-deep); font-size:.85rem; letter-spacing:.06em }
.rating-pill .rp-sub{ font-size:.75rem; color:var(--muted); margin-top:2px }
.name-card{
  position:absolute; right:-16px; bottom:-22px; background:var(--surface); border-radius:var(--r-lg);
  box-shadow:var(--shadow-md); padding:16px 20px; border:1px solid var(--line);
  display:flex; align-items:center; gap:14px; min-width:208px;
}
.nc-avatars{ display:inline-flex; flex:0 0 auto }
.nc-av{
  width:42px; height:42px; border-radius:50%; display:grid; place-items:center;
  font-family:var(--font-head); font-weight:800; font-size:1.1rem; color:#fff;
  background:linear-gradient(150deg, var(--terra), var(--terra-deep));
  border:2.5px solid var(--surface); box-shadow:0 2px 6px rgba(70,40,20,.18);
}
.nc-av2{ background:linear-gradient(150deg, var(--green), var(--green-deep)); margin-left:-14px }
.nc-meta b{ display:block; font-family:var(--font-head); font-weight:800; font-size:1.02rem; color:var(--ink) }
.nc-meta span{ font-size:.8rem; color:var(--muted) }
@media(max-width:920px){
  .hero-grid{ grid-template-columns:1fr; gap:46px }
  .hero{ padding:44px 0 24px }
  .name-card{ right:14px }
}
@media(max-width:520px){
  .rating-pill{ left:8px; top:14px; padding:11px 14px }
  .rating-pill .rp-num{ font-size:1.4rem }
  .name-card{ right:50%; transform:translateX(50%); bottom:-26px; min-width:0 }
}

/* ---------- section scaffolding ---------- */
.section{ padding:84px 0 }
.section.tight{ padding:64px 0 }
.sec-head{ max-width:40rem }
.sec-head.center{ margin:0 auto; text-align:center }
.kicker{ font-family:var(--font-head); font-weight:600; font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:var(--teal-deep) }
.sec-head h2{ font-size:clamp(2rem, 3.6vw, 2.85rem); margin:14px 0 0 }
.sec-head p{ color:var(--muted); font-size:1.12rem; margin:16px 0 0 }

/* reveal */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1) }
.reveal.is-in{ opacity:1; transform:none }

/* ---------- promise / why ---------- */
.promise{ background:var(--surface); border-top:1px solid var(--line); border-bottom:1px solid var(--line) }
.promise-grid{ display:grid; grid-template-columns:.82fr 1.18fr; gap:54px; align-items:center }
.promise-copy h2{ font-size:clamp(1.9rem, 3.4vw, 2.7rem); margin:14px 0 0 }
.promise-copy .lede{ font-size:1.18rem; color:var(--ink); margin:18px 0 0 }
.promise-copy p.body{ color:var(--muted); margin:14px 0 0 }
.named{ display:inline-flex; align-items:center; gap:.5em; margin-top:24px; padding:.6em 1em; background:var(--mint); border-radius:999px; font-family:var(--font-head); font-weight:600; font-size:.95rem; color:var(--green-deep) }
.named svg{ width:18px; height:18px }
/* promise photo (warm, human — the team) */
.promise-photo{ position:relative; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid oklch(1 0 0 / .6); aspect-ratio:4/5 }
.promise-photo img{ width:100%; height:100%; object-fit:cover }
.promise-photo .pp-tag{
  position:absolute; left:16px; bottom:16px; right:16px; background:oklch(0.995 0.006 80 / 0.92);
  backdrop-filter:blur(6px); border-radius:var(--r); padding:.7em 1em; box-shadow:var(--shadow-sm);
  font-family:var(--font-head); font-weight:600; font-size:.92rem; color:var(--ink);
  display:flex; align-items:center; gap:.55em;
}
.promise-photo .pp-tag .qstars{ color:var(--amber-deep); letter-spacing:.04em; font-size:.85rem; flex:0 0 auto }
.promise-quote{
  margin:26px 0 0; padding:18px 22px; border-left:3px solid var(--terra);
  background:var(--terra-soft); border-radius:0 var(--r) var(--r) 0;
  font-size:1.05rem; line-height:1.55; color:var(--ink);
}
.promise-quote strong{ color:var(--terra-deep) }
.promise-quote cite{ display:block; margin-top:10px; font-style:normal; font-weight:600; font-size:.9rem; color:var(--muted) }
.quote-card{
  background:linear-gradient(160deg, var(--teal-soft), var(--sky));
  border:1px solid var(--line); border-radius:var(--r-lg); padding:34px 32px; box-shadow:var(--shadow-sm);
}
.quote-card .qm{ font-family:var(--font-head); font-weight:800; font-size:3rem; color:var(--teal); line-height:.6; height:.5em }
.quote-card blockquote{ margin:0; font-size:1.18rem; line-height:1.55; color:var(--ink) }
.quote-card blockquote strong{ color:var(--teal-deep) }
.quote-card figcaption{ margin-top:18px; font-weight:600; color:var(--muted); font-size:.95rem }
.quote-card .qstars{ color:var(--amber-deep); letter-spacing:.05em }
@media(max-width:880px){ .promise-grid{ grid-template-columns:1fr; gap:40px } }

/* ---------- stat strip ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px }
.stat{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:26px 22px; box-shadow:var(--shadow-sm); text-align:center }
.stat .n{ font-family:var(--font-head); font-weight:800; font-size:2.1rem; color:var(--teal-deep); line-height:1 }
.stat .n .star{ color:var(--amber-deep) }
.stat .l{ font-size:.9rem; color:var(--muted); margin-top:8px }
@media(max-width:760px){ .stats{ grid-template-columns:repeat(2,1fr) } }

/* ---------- services ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; margin-top:42px }
.svc{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  overflow:hidden; box-shadow:var(--shadow-sm); display:flex; flex-direction:column;
  transition:transform .2s ease, box-shadow .2s ease;
}
.svc:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md) }
.svc-media{ aspect-ratio:16/10; overflow:hidden; position:relative }
.svc-media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease }
.svc:hover .svc-media img{ transform:scale(1.04) }
.svc-ico{
  position:absolute; left:16px; bottom:16px; width:46px; height:46px; border-radius:13px;
  background:var(--surface); display:grid; place-items:center; box-shadow:var(--shadow-sm); color:var(--teal-deep);
}
.svc-ico svg{ width:24px; height:24px }
.svc-body{ padding:24px 24px 26px }
.svc-body h3{ font-size:1.32rem }
.svc-body p{ color:var(--muted); margin-top:10px; font-size:1rem }
.svc-tags{ display:flex; flex-wrap:wrap; gap:7px; margin-top:16px }
.svc-tag{ font-size:.78rem; font-weight:500; color:var(--teal-deep); background:var(--teal-soft); padding:.35em .8em; border-radius:999px }
@media(max-width:720px){ .svc-grid{ grid-template-columns:1fr } }

/* ---------- brands ---------- */
.brands{ margin-top:46px; text-align:center }
.brands .bl{ font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); font-weight:600; font-family:var(--font-head) }
.brand-row{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin-top:18px }
.brand-chip{ font-family:var(--font-head); font-weight:600; font-size:.98rem; color:var(--muted); background:var(--surface); border:1px solid var(--line); padding:.5em 1.1em; border-radius:999px; box-shadow:var(--shadow-sm) }

/* ---------- reviews ---------- */
.reviews{ background:linear-gradient(180deg, var(--sky), var(--bg)) }
.rev-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:42px }
.rev{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:26px 26px 24px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:14px;
}
.rev .rstars{ color:var(--amber-deep); letter-spacing:.08em; font-size:.95rem }
.rev blockquote{ margin:0; font-size:1.02rem; color:var(--ink); line-height:1.6 }
.rev figcaption{ font-weight:600; color:var(--muted); font-size:.92rem; margin-top:auto }
.rev.feature{ grid-column:span 2; background:linear-gradient(160deg, var(--mint), var(--surface)) }
.rev.feature blockquote{ font-size:1.18rem }
@media(max-width:880px){ .rev-grid{ grid-template-columns:1fr } .rev.feature{ grid-column:auto } }

/* ---------- interlude band (light, airy — image at 100%) ---------- */
.band{ position:relative; padding:0 }
.band-inner{
  display:grid; grid-template-columns:1fr 1fr; align-items:stretch; gap:0;
  background:var(--surface); border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.band-photo{ overflow:hidden; min-height:340px }
.band-photo img{ width:100%; height:100%; object-fit:cover }
.band-copy{ padding:60px 54px; display:flex; flex-direction:column; justify-content:center }
.band-copy h2{ font-size:clamp(1.8rem,3.2vw,2.5rem) }
.band-copy p{ color:var(--muted); font-size:1.12rem; margin-top:16px }
.band-copy .checks{ list-style:none; margin:22px 0 0; padding:0; display:grid; gap:12px }
.band-copy .checks li{ display:flex; gap:.7em; align-items:flex-start; color:var(--ink) }
.band-copy .checks svg{ width:21px; height:21px; color:var(--teal); flex:0 0 auto; margin-top:2px }
@media(max-width:880px){ .band-inner{ grid-template-columns:1fr } .band-photo{ min-height:240px; order:-1 } .band-copy{ padding:42px 24px } }

/* ---------- service area ---------- */
.area-grid{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center }
.chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:26px }
.chips li{ list-style:none; font-family:var(--font-head); font-weight:600; font-size:.98rem; color:var(--ink); background:var(--surface); border:1px solid var(--line); padding:.6em 1.15em; border-radius:999px; box-shadow:var(--shadow-sm) }
.chips li.accent{ background:var(--teal); color:#fff; border-color:transparent }
.area-note{ margin-top:22px; color:var(--muted) }
@media(max-width:780px){ .area-grid{ grid-template-columns:1fr; gap:30px } }

/* ---------- CTA band ---------- */
.cta{ position:relative; overflow:hidden }
.cta-inner{
  background:linear-gradient(150deg, var(--teal), var(--teal-deep)); color:#fff;
  border-radius:var(--r-xl); padding:64px 48px; text-align:center; box-shadow:var(--shadow-lg);
  position:relative; overflow:hidden;
}
.cta-inner::before{ content:""; position:absolute; width:340px; height:340px; border-radius:50%;
  background:radial-gradient(circle, oklch(1 0 0 / .22), transparent 70%); top:-120px; right:-80px }
.cta-inner h2{ font-size:clamp(2rem,3.6vw,2.85rem); color:#fff; position:relative }
.cta-inner p{ color:oklch(1 0 0 / .9); font-size:1.15rem; margin-top:14px; position:relative }
.cta-actions{ display:flex; flex-wrap:wrap; justify-content:center; gap:14px; margin-top:30px; position:relative }
.cta-actions .num{ display:flex; flex-direction:column; align-items:center }
.cta-actions .num small{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; opacity:.85; margin-bottom:8px; font-family:var(--font-head) }
.cta-sub{ margin-top:22px; font-size:.92rem; color:oklch(1 0 0 / .85); position:relative }
.cta-sub a{ color:#fff; text-decoration:underline; text-underline-offset:3px }

/* ---------- footer ---------- */
.footer{ background:var(--surface); border-top:1px solid var(--line); padding:54px 0 30px; margin-top:0 }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px }
.footer .brand{ margin-bottom:14px }
.footer-blurb{ color:var(--muted); font-size:.95rem; max-width:26em }
.footer h4{ font-family:var(--font-head); font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); margin-bottom:14px }
.footer-col a, .footer-col p{ display:block; color:var(--muted); font-size:.96rem; margin-bottom:9px }
.footer-col a:hover{ color:var(--teal-deep) }
.footer-base{ display:flex; flex-wrap:wrap; gap:10px 24px; justify-content:space-between; align-items:center; margin-top:40px; padding-top:22px; border-top:1px solid var(--line); color:var(--faint); font-size:.84rem }
@media(max-width:780px){ .footer-grid{ grid-template-columns:1fr 1fr } .footer-brand-col{ grid-column:1 / -1 } }
@media(max-width:480px){ .footer-grid{ grid-template-columns:1fr } }

/* ---------- subpage hero (light) ---------- */
.page-hero{ padding:56px 0 10px }
.page-hero .eyebrow{ margin-bottom:18px }
.page-hero h1{ font-size:clamp(2.2rem,4.6vw,3.4rem); font-weight:800 }
.page-hero p{ color:var(--muted); font-size:1.18rem; margin-top:18px; max-width:38rem }

/* ---------- service detail rows ---------- */
.svc-detail{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; padding:48px 0; border-bottom:1px solid var(--line) }
.svc-detail:nth-child(even) .svc-detail-media{ order:2 }
.svc-detail-media{ border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-md); aspect-ratio:4/3 }
.svc-detail-media img{ width:100%; height:100%; object-fit:cover }
.svc-detail h2{ font-size:clamp(1.6rem,3vw,2.2rem) }
.svc-detail .num{ font-family:var(--font-head); font-weight:800; font-size:1rem; color:var(--teal); letter-spacing:.04em }
.svc-detail p{ color:var(--muted); margin-top:14px; font-size:1.06rem }
.svc-detail .checks{ list-style:none; margin:20px 0 0; padding:0; display:grid; gap:11px }
.svc-detail .checks li{ display:flex; gap:.7em; align-items:flex-start; color:var(--ink) }
.svc-detail .checks svg{ width:20px; height:20px; color:var(--teal); flex:0 0 auto; margin-top:3px }
@media(max-width:820px){ .svc-detail{ grid-template-columns:1fr; gap:28px } .svc-detail:nth-child(even) .svc-detail-media{ order:-1 } }

/* ---------- about ---------- */
.about-grid{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center }
.about-media{ border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:3/4 }
.about-media img{ width:100%; height:100%; object-fit:cover }
.about-copy p{ color:var(--muted); margin-top:16px; font-size:1.08rem }
.about-copy p.lede{ color:var(--ink); font-size:1.24rem; margin-top:0 }
.value-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:46px }
.value{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:24px; box-shadow:var(--shadow-sm) }
.value .vi{ width:44px; height:44px; border-radius:12px; background:var(--teal-soft); display:grid; place-items:center; color:var(--teal-deep); margin-bottom:14px }
.value .vi svg{ width:23px; height:23px }
.value h3{ font-size:1.16rem }
.value p{ color:var(--muted); margin-top:8px; font-size:.98rem }
@media(max-width:820px){ .about-grid{ grid-template-columns:1fr; gap:36px } .about-media{ max-width:380px; margin:0 auto } .value-grid{ grid-template-columns:1fr } }

/* ---------- reviews page wall ---------- */
.review-wall{ columns:3; column-gap:20px; margin-top:42px }
.review-wall .rev{ break-inside:avoid; margin-bottom:20px }
@media(max-width:980px){ .review-wall{ columns:2 } }
@media(max-width:640px){ .review-wall{ columns:1 } }

/* ---------- contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start }
.contact-cards{ display:grid; gap:16px }
.ccard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:26px 28px; box-shadow:var(--shadow-sm); display:flex; gap:18px; align-items:flex-start }
.ccard .ci{ width:48px; height:48px; border-radius:13px; background:var(--teal-soft); display:grid; place-items:center; color:var(--teal-deep); flex:0 0 auto }
.ccard .ci svg{ width:24px; height:24px }
.ccard h3{ font-size:1.1rem }
.ccard{ min-width:0 }
.ccard > div{ min-width:0; flex:1 1 auto }
.ccard .big{ font-family:var(--font-head); font-weight:800; font-size:1.5rem; color:var(--ink); margin-top:4px; display:inline-block; max-width:100%; overflow-wrap:anywhere; word-break:break-word }
.ccard .big:hover{ color:var(--teal-deep) }
.ccard p{ color:var(--muted); font-size:.95rem; margin-top:4px }
.form{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:30px; box-shadow:var(--shadow-sm) }
.form h3{ font-size:1.3rem }
.form .fnote-intro{ color:var(--muted); font-size:.95rem; margin:8px 0 22px }
.field{ margin-bottom:16px }
.field label{ display:block; font-family:var(--font-head); font-weight:600; font-size:.85rem; color:var(--ink); margin-bottom:7px }
.field input, .field textarea, .field select{
  width:100%; font-family:var(--font-body); font-size:1rem; color:var(--ink);
  padding:.8em 1em; border:1px solid var(--line); border-radius:var(--r-sm); background:var(--bg);
  transition:border-color .18s ease, box-shadow .18s ease;
}
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none; border-color:var(--teal); box-shadow:0 0 0 3px oklch(0.64 0.135 45 / .20); background:#fff;
}
.field textarea{ resize:vertical; min-height:120px }
.form-note{ display:none; margin-top:16px; padding:14px 16px; background:var(--mint); border-radius:var(--r-sm); color:var(--teal-deep); font-size:.95rem }
@media(max-width:820px){ .contact-grid{ grid-template-columns:1fr; gap:32px } }

/* focus visibility */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible{
  outline:2px solid var(--teal); outline-offset:2px; border-radius:6px;
}

/* ---------- ZV SAMPLE BADGE — temporary, REMOVABLE ---------- */
.zv-sample-badge{ display:none }
body[data-sample] .zv-sample-badge{
  display:flex; align-items:center; gap:.5ch; position:fixed; left:50%; bottom:16px; transform:translateX(-50%);
  z-index:999; padding:.5em .95em; border-radius:999px; font:600 .72rem/1 var(--font-body);
  letter-spacing:.02em; color:#fff; background:oklch(0.32 0.030 55 / 0.88); backdrop-filter:blur(8px);
  box-shadow:0 6px 20px rgba(70,40,20,.28); text-decoration:none; pointer-events:auto;
}
.zv-sample-badge b{ color:oklch(0.82 0.12 55) }
.zv-short{ display:none }
@media(max-width:640px){
  .zv-sample-badge{ font-size:.62rem; bottom:12px; left:auto; right:12px; transform:none; padding:.45em .85em; opacity:.94; white-space:nowrap }
  .zv-long{ display:none } .zv-short{ display:inline }
}
