/* ============================================================
   home.css — homepage cinematic sections + inner page-hero
   ============================================================ */

/* ---------- HERO (homepage) ---------- */
.hero{ position:relative; isolation:isolate; min-height:clamp(560px,86vh,820px); display:flex; align-items:center; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__media img, .hero__media canvas{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero__media canvas{ z-index:1; opacity:.9; mix-blend-mode:screen; }
.hero__scrim{ position:absolute; inset:0; z-index:-1;
  background:linear-gradient(100deg, rgba(7,63,70,.92) 0%, rgba(10,90,98,.74) 42%, rgba(8,47,54,.32) 100%); }
.hero__scrim::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(7,63,70,.55), transparent 45%); }
.hero__inner{ position:relative; z-index:2; padding-block:clamp(3rem,8vh,6rem); color:#eafafa; max-width:760px; }
.hero .pill{ background:rgba(255,255,255,.14); color:#eafafa; border:1px solid rgba(255,255,255,.25); margin-bottom:1.4rem; }
.hero .pill b{ color:#fff; }
.hero h1{ color:#fff; font-size:clamp(2.5rem,6vw,4.4rem); letter-spacing:-.02em; margin-bottom:1.1rem; }
.hero h1 .ital{ font-style:italic; font-weight:500; color:var(--teal-soft); }
.hero__sub{ font-size:clamp(1.1rem,1.9vw,1.32rem); color:#d4eceb; max-width:48ch; margin-bottom:1.8rem; }
.hero .btn-row{ margin-bottom:2rem; }
.hero__ticks{ display:flex; flex-wrap:wrap; gap:.5rem 1.4rem; padding-top:1.5rem; border-top:1px solid rgba(255,255,255,.18); }
.hero__ticks span{ display:inline-flex; align-items:center; gap:.5rem; font-family:var(--sans); font-weight:600; font-size:.9rem; color:#cfeceb; }
.hero__ticks svg{ width:17px; height:17px; color:var(--teal-soft); flex:none; }
@media (prefers-reduced-motion:reduce){ .hero__media canvas{ display:none; } }

/* trust strip */
.trust-strip{ background:var(--paper); border-bottom:1px solid var(--line); }
.trust-strip .container{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; padding-block:1.1rem; }
.trust-strip p{ margin:0; font-family:var(--sans); font-weight:700; color:var(--ink); font-size:.92rem; }
.trust-strip .badges{ display:flex; gap:1.4rem; align-items:center; flex-wrap:wrap; }
.trust-strip .badges img{ height:42px; width:auto; filter:grayscale(.2); opacity:.95; }

/* ---------- INTRO split ---------- */
.intro{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.intro__media{ position:relative; }
.intro__media img{ border-radius:var(--radius-lg); box-shadow:var(--shadow); width:100%; aspect-ratio:4/3.2; object-fit:cover; }
.intro__media .float-card{ position:absolute; bottom:-22px; left:-22px; background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:1rem 1.2rem; box-shadow:var(--shadow); display:flex; align-items:center; gap:.8rem; max-width:240px; }
.intro__media .float-card img{ width:46px; height:46px; border-radius:0; box-shadow:none; aspect-ratio:auto; }
.intro__media .float-card b{ font-family:var(--serif); color:var(--teal-deep); display:block; }
.intro__media .float-card span{ font-size:.8rem; color:var(--ink-mute); }

/* ---------- SERVICES grid (homepage) ---------- */
.svc-card{ display:flex; flex-direction:column; }
.svc-card .card__media{ aspect-ratio:16/10; border-radius:var(--radius-sm); overflow:hidden; margin-bottom:1.1rem; }
.svc-card .card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.svc-card:hover .card__media img{ transform:scale(1.06); }

/* ---------- CDCP feature ---------- */
.cdcp-feature{ background:linear-gradient(135deg,var(--mint),#fff); border:1px solid var(--mint-2); border-radius:var(--radius-lg); padding:clamp(2rem,4vw,3.2rem); display:grid; grid-template-columns:1.2fr 1fr; gap:2.5rem; align-items:center; position:relative; overflow:hidden; }
.cdcp-feature .pill--cdcp{ margin-bottom:1rem; }
.cdcp-feature ul{ list-style:none; padding:0; margin:1.2rem 0 0; display:grid; gap:.7rem; }
.cdcp-feature li{ display:flex; gap:.6rem; align-items:flex-start; font-family:var(--sans); color:var(--ink); }
.cdcp-feature li svg{ width:20px; height:20px; color:var(--teal); flex:none; margin-top:2px; }
.cdcp-tiers{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:1.5rem; box-shadow:var(--shadow-sm); }
.cdcp-tiers .tier{ display:flex; justify-content:space-between; align-items:center; padding:.8rem 0; border-bottom:1px solid var(--line-soft); }
.cdcp-tiers .tier:last-child{ border-bottom:none; }
.cdcp-tiers .tier b{ font-family:var(--serif); font-size:1.6rem; color:var(--teal-deep); }
.cdcp-tiers .tier span{ font-size:.85rem; color:var(--ink-mute); }

/* ---------- first visit / process ---------- */
.process{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.1rem; counter-reset:step; }
.process .step{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:1.5rem; position:relative; }
.process .step b{ display:block; font-family:var(--serif); color:var(--teal); font-size:1.1rem; margin-bottom:.4rem; }
.process .step .num{ position:absolute; top:1.1rem; right:1.2rem; font-family:var(--serif); font-size:2.6rem; color:var(--mint-2); line-height:1; }
.process .step p{ font-size:.92rem; margin:0; }

/* ---------- INNER PAGE HERO ---------- */
.page-hero{ position:relative; isolation:isolate; overflow:hidden; padding:clamp(2.6rem,7vw,5rem) 0 clamp(2.2rem,5vw,3.4rem); color:#eafafa; }
.page-hero::before{ content:""; position:absolute; inset:0; z-index:-2; background:linear-gradient(135deg,var(--teal-deep),var(--teal-darker)); }
.page-hero::after{ content:""; position:absolute; inset:0; z-index:-1; opacity:.4; background:
  radial-gradient(60% 80% at 85% 10%, rgba(127,201,206,.4), transparent 60%),
  radial-gradient(50% 60% at 10% 100%, rgba(224,138,114,.28), transparent 60%); }
.page-hero__bg{ position:absolute; inset:0; z-index:-3; width:100%; height:100%; object-fit:cover; opacity:.22; }
.page-hero .breadcrumb, .page-hero .breadcrumb a, .page-hero .breadcrumb li{ color:#bfe0df; }
.page-hero .breadcrumb a:hover{ color:#fff; }
.page-hero h1{ color:#fff; margin:.9rem 0 .6rem; max-width:18ch; }
.page-hero .eyebrow{ color:var(--teal-soft); }
.page-hero .eyebrow::before{ background:var(--coral); }
.page-hero__sub{ color:#d4eceb; font-size:clamp(1.05rem,1.7vw,1.25rem); max-width:60ch; }

/* ---------- generic content prose ---------- */
.prose{ max-width:none; }
.prose h2{ margin-top:2.4rem; }
.prose h3{ margin-top:1.8rem; color:var(--teal-deep); }
.prose ul{ padding-left:0; list-style:none; display:grid; gap:.6rem; margin:1.2rem 0; }
.prose ul li{ position:relative; padding-left:1.8rem; color:var(--ink-soft); }
.prose ul li::before{ content:""; position:absolute; left:0; top:.5em; width:9px; height:9px; border-radius:50%; background:var(--teal); box-shadow:0 0 0 4px var(--mint); }
.content-split{ display:grid; grid-template-columns:1fr 340px; gap:clamp(2rem,4vw,3.5rem); align-items:start; }
.content-split__aside{ position:sticky; top:120px; display:grid; gap:1.2rem; }
.aside-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:1.5rem; box-shadow:var(--shadow-sm); }
.aside-card h3{ margin-top:0; font-size:1.15rem; }
.aside-card.teal{ background:linear-gradient(140deg,var(--teal-deep),var(--teal-darker)); color:#eafafa; border:none; }
.aside-card.teal h3{ color:#fff; }
.aside-card.teal p{ color:#cfeceb; }
.service-figure{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); margin:1.8rem 0; }
.service-figure img{ width:100%; aspect-ratio:16/9; object-fit:cover; }

/* service list cards inside content */
.svc-list{ display:grid; gap:1rem; margin:1.5rem 0; }
.svc-list .row{ display:flex; gap:1rem; padding:1.2rem 1.3rem; background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-sm); transition:border-color .25s, transform .25s; }
.svc-list .row:hover{ border-color:var(--teal-soft); transform:translateX(4px); }
.svc-list .row .ico{ width:44px; height:44px; flex:none; border-radius:12px; background:var(--mint); color:var(--teal-deep); display:grid; place-items:center; }
.svc-list .row .ico svg{ width:22px; height:22px; }
.svc-list .row h3{ margin:0 0 .25rem; font-size:1.12rem; }
.svc-list .row p{ margin:0; font-size:.94rem; }

/* about: bios + gallery */
.bio{ display:grid; grid-template-columns:auto 1fr; gap:1.6rem; background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:1.8rem; box-shadow:var(--shadow-sm); }
.bio__photo{ width:130px; height:130px; border-radius:20px; background:var(--mint); display:grid; place-items:center; flex:none; overflow:hidden; }
.bio__photo svg{ width:62px; height:62px; color:var(--teal-soft); }
.bio h3{ margin:0 0 .2rem; }
.bio .cred{ font-family:var(--sans); font-weight:700; color:var(--teal); font-size:.85rem; letter-spacing:.03em; margin-bottom:.8rem; display:block; }
.bio p{ font-size:.96rem; }
.bio__tags{ display:flex; gap:.5rem; flex-wrap:wrap; margin-top:.6rem; }
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:.8rem; }
.gallery img{ width:100%; aspect-ratio:1; object-fit:cover; border-radius:var(--radius-sm); }
.gallery img:nth-child(1){ grid-column:span 2; grid-row:span 2; aspect-ratio:auto; height:100%; }

/* contact */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; align-items:start; }
.contact-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:1.6rem; box-shadow:var(--shadow-sm); }
.contact-card .row{ display:flex; gap:.9rem; padding:.9rem 0; border-bottom:1px solid var(--line-soft); align-items:flex-start; }
.contact-card .row:last-child{ border-bottom:none; }
.contact-card .ico{ width:42px; height:42px; flex:none; border-radius:12px; background:var(--mint); color:var(--teal-deep); display:grid; place-items:center; }
.contact-card .ico svg{ width:20px; height:20px; }
.contact-card b{ font-family:var(--sans); display:block; font-size:.95rem; }
.map-embed{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-sm); }
.map-embed iframe{ width:100%; height:420px; border:0; display:block; }

@media (max-width:980px){
  .intro, .cdcp-feature, .contact-grid{ grid-template-columns:1fr; }
  .content-split{ grid-template-columns:1fr; }
  .content-split__aside{ position:static; }
  .process{ grid-template-columns:repeat(2,1fr); }
  .gallery{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:600px){
  .bio{ grid-template-columns:1fr; }
  .bio__photo{ width:96px; height:96px; }
  .process{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); }
  .gallery img:nth-child(1){ grid-column:span 2; }
  .intro__media .float-card{ left:0; }
}
