/* ============ HOME — page-specific ============ */

/* hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.hero-bg{position:absolute;inset:-10% 0 0 0;height:120%;will-change:transform}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(3,33,26,.6) 0%,rgba(3,33,26,.3) 30%,rgba(3,33,26,.46) 62%,rgba(3,33,26,.92) 100%),radial-gradient(130% 85% at 12% 92%,rgba(3,33,26,.55),transparent 62%)}
.hero-in{position:relative;z-index:3;padding-bottom:clamp(56px,8vh,104px);max-width:1140px}
.hero .eyebrow{color:#bdeee3}
.hero .eyebrow::before{background:#bdeee3}
.hero-h1{font-size:clamp(44px,7.2vw,116px);line-height:.96;letter-spacing:-.025em;margin:26px 0 0;max-width:16ch;color:#fff}
.hero-h1 em{color:var(--sky);font-style:italic}
.hero-sub{font-family:var(--serif);font-style:italic;font-size:clamp(19px,2.3vw,30px);color:#eaf4f0;margin-top:28px;max-width:30ch;line-height:1.32}
.hero-cta{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}
.hero-scroll{position:absolute;left:50%;transform:translateX(-50%);bottom:26px;z-index:3;display:flex;flex-direction:column;align-items:center;gap:9px;font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.8)}
.hero-scroll i{width:1px;height:42px;background:linear-gradient(rgba(255,255,255,.7),transparent);position:relative;overflow:hidden}
.hero-scroll i::after{content:"";position:absolute;top:-50%;left:0;width:1px;height:50%;background:#fff;animation:scrolldot 2.2s var(--ease) infinite}
@keyframes scrolldot{to{top:100%}}
@media(max-width:680px){.hero-scroll{display:none}}
@media(max-height:760px){.hero-scroll{display:none}}

/* split-word headline */
.hero-h1 .w{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.04em}
.hero-h1 .w>i{display:inline-block;font-style:inherit;transform:translateY(112%);transition:transform 1s var(--ease)}
.hero-h1.in .w>i{transform:none}

/* intro */
.intro-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(34px,6vw,90px);align-items:start}
.intro-h{font-size:clamp(30px,4vw,52px);line-height:1.08;letter-spacing:-.02em}
.intro-h em{color:var(--teal)}
.intro-r .geo{margin-top:28px}

/* ---------- explorer ---------- */
.explorer{position:relative;border-radius:var(--rad-lg);overflow:hidden;background:#0b3a31;box-shadow:var(--shadow);aspect-ratio:16/9}
.ex-stage{position:absolute;inset:0}
.explorer .ex-img{position:absolute;inset:0}
.explorer .ex-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease),filter .6s}
.explorer.zoom .ex-img img{transform:scale(1.06)}
.ex-shade{position:absolute;inset:0;background:radial-gradient(circle at var(--hx,50%) var(--hy,50%),transparent 8%,rgba(4,30,24,.30) 30%,rgba(4,30,24,.72) 78%);transition:background .6s var(--ease),opacity .5s;opacity:0}
.explorer.active .ex-shade{opacity:1}
/* hotspots */
.hot{position:absolute;transform:translate(-50%,-50%);width:34px;height:34px;border-radius:50%;cursor:pointer;z-index:6;background:none;border:none;padding:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.hot .pulse{position:absolute;inset:0;border-radius:50%;background:rgba(255,255,255,.9);box-shadow:0 0 0 0 rgba(255,255,255,.6)}
.hot .core{position:absolute;inset:9px;border-radius:50%;background:var(--teal);border:2px solid #fff;transition:.3s}
.hot::after{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid rgba(255,255,255,.55);animation:hotring 2.6s ease-out infinite;animation-delay:var(--d,0s)}
@keyframes hotring{0%{transform:scale(1);opacity:.7}100%{transform:scale(2.4);opacity:0}}
.hot:hover .core,.hot.on .core{background:#fff;transform:scale(1.25)}
.hot.on{z-index:7}
.hot .tag{position:absolute;left:50%;bottom:calc(100% + 12px);transform:translateX(-50%) translateY(6px);background:#fff;color:var(--ink);font-family:var(--sans);font-weight:600;font-size:12.5px;white-space:nowrap;padding:6px 12px;border-radius:999px;opacity:0;pointer-events:none;transition:.25s;box-shadow:var(--shadow-sm)}
.hot:hover .tag,.hot.on .tag{opacity:1;transform:translateX(-50%) translateY(0)}
@media(prefers-reduced-motion:reduce){.hot::after{animation:none}}
/* info card */
.ex-card{position:absolute;left:30px;bottom:30px;width:min(380px,calc(100% - 60px));background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-radius:20px;padding:26px 26px 24px;z-index:5;box-shadow:var(--shadow);transition:.5s var(--ease)}
.ex-card .ec-ic{width:46px;height:46px;border-radius:13px;background:var(--teal-50);color:var(--teal);display:grid;place-items:center;margin-bottom:16px;transition:.3s}
.ex-card .ec-ic svg{width:24px;height:24px}
.ex-card h3{font-size:27px;line-height:1.05}
.ex-card p{font-size:14.5px;color:var(--ink-soft);margin-top:9px;line-height:1.5}
.ex-card .ec-link{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-family:var(--sans);font-weight:600;font-size:13.5px;color:var(--teal)}
.ex-card .ec-link .arr{transition:transform .3s var(--ease)}
.ex-card .ec-link:hover .arr{transform:translateX(4px)}
.ex-count{position:absolute;top:26px;right:28px;z-index:5;font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:rgba(255,255,255,.85)}
.ex-count b{font-size:15px;color:#fff}
.ex-hint{position:absolute;top:24px;left:28px;z-index:5;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.8);display:flex;align-items:center;gap:9px;transition:.4s}
.explorer.active .ex-hint{opacity:0}
.ex-hint .blink{width:7px;height:7px;border-radius:50%;background:var(--aqua);animation:blink 1.4s infinite}
@keyframes blink{50%{opacity:.25}}
@media(max-width:900px){
  .intro-grid{grid-template-columns:1fr;gap:22px}
}
@media(max-width:760px){
  /* card moves below the image so the photo and every hotspot stay usable */
  .explorer{aspect-ratio:auto;overflow:visible;background:none;box-shadow:none;border-radius:0}
  .ex-stage{position:relative;inset:auto;aspect-ratio:4/5;border-radius:var(--rad-lg);overflow:hidden;background:#0b3a31;box-shadow:var(--shadow)}
  .ex-card{position:static;width:100%;margin-top:14px;padding:22px;box-shadow:var(--shadow)}
  .ex-card h3{font-size:23px}
  .ex-hint,.ex-count{font-size:10px}
  .hot{width:44px;height:44px}
  .hot .core{inset:13px}
  .hot .tag{display:none}

  /* the idea — tighter, with a serif pull-line instead of one long block */
  .intro-h{font-size:clamp(32px,8.6vw,42px)}
  .intro-r .lead-body{font-size:16.5px;line-height:1.68}
  .intro-r .lead-body strong{display:block;margin-top:20px;font-family:var(--serif);font-style:italic;font-weight:500;font-size:23px;line-height:1.32;letter-spacing:-.01em;color:var(--teal-ink,#063b31)}
  .intro-r .geo{font-size:13px;line-height:1.6;border-left:0;padding:16px 0 0;margin-top:26px;border-top:1px solid var(--line-2,rgba(0,0,0,.08));opacity:.75}
}
@media(hover:none){.ex-hint{display:none}}

/* services grid */
.svc-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.svc-card{position:relative;border-radius:var(--rad);overflow:hidden;background:#0b3a31;min-height:300px;display:flex;align-items:flex-end;grid-column:span 4;isolation:isolate}
.svc-card.lg{grid-column:span 6}
.svc-card .sc-img{position:absolute;inset:0;z-index:-1}
.svc-card .sc-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.svc-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(4,33,26,.05) 0%,rgba(4,33,26,.35) 48%,rgba(4,33,26,.9) 100%)}
.svc-card:hover .sc-img img{transform:scale(1.07)}
.svc-card .sc-body{padding:26px;color:#fff;position:relative;width:100%}
.svc-card .sc-ic{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);display:grid;place-items:center;margin-bottom:14px;transition:.3s}
.svc-card .sc-ic svg{width:21px;height:21px;color:#fff}
.svc-card:hover .sc-ic{background:var(--teal);transform:translateY(-2px)}
.svc-card h3{font-size:24px;line-height:1.14}
.svc-card .sc-d{font-size:13.5px;color:rgba(255,255,255,.82);margin-top:10px;max-width:32ch}
.svc-card .sc-go{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--sky);transition:.3s}
.svc-card:hover .sc-go{gap:13px;color:#fff}
@media(max-width:980px){.svc-card,.svc-card.lg{grid-column:span 6}}
@media(max-width:600px){.svc-card,.svc-card.lg{grid-column:span 12;min-height:260px}}

/* why band */
.band{display:grid;grid-template-columns:1fr 1.05fr;background:var(--teal-ink);color:#dcebe6;overflow:hidden}
.band-media{position:relative;min-height:560px}
.band-media img{position:absolute;inset:0}
.band-txt{padding:clamp(56px,7vw,104px) clamp(34px,5vw,84px)}
.band-txt h2{color:#fff;font-size:clamp(30px,3.6vw,50px);margin-top:18px;letter-spacing:-.02em;max-width:18ch;line-height:1.08}
.band-txt h2 em{color:var(--sky)}
.band-lead{color:#a8c8c0;margin-top:30px;font-size:18px;line-height:1.6;max-width:46ch}
.feats{margin-top:38px}
.feat{display:flex;gap:18px;padding:22px 0;border-top:1px solid rgba(255,255,255,.13)}
.feat:last-child{border-bottom:1px solid rgba(255,255,255,.13)}
.feat .fd{flex:none;width:10px;height:10px;border-radius:50%;background:var(--aqua);margin-top:8px;box-shadow:0 0 0 4px rgba(70,194,180,.18)}
.feat b{color:#fff;font-weight:600;font-size:16.5px;display:block;font-family:var(--sans)}
.feat p{color:#9fc1b9;font-size:14.5px;margin-top:4px;line-height:1.5}
@media(max-width:900px){.band{grid-template-columns:1fr}.band-media{min-height:340px}}

/* where */
.where-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(34px,6vw,80px);align-items:center}
.where-l h2{font-size:clamp(30px,4vw,52px);margin-top:18px;letter-spacing:-.02em;max-width:14ch;line-height:1.1}
.where-l .lead-body{margin-top:24px}
.where-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:34px}
.where-cols h5{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);margin-bottom:9px}
.where-cols p{font-size:14.5px;color:var(--ink-soft);line-height:1.7}
.where-r{position:relative;border-radius:var(--rad-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow)}
.where-badge{position:absolute;left:22px;bottom:22px;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-radius:16px;padding:16px 22px;display:flex;flex-direction:column;line-height:1}
.where-badge b{font-family:var(--serif);font-size:38px;color:var(--teal)}
.where-badge span{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px}
@media(max-width:900px){.where-grid{grid-template-columns:1fr}.where-cols{grid-template-columns:1fr 1fr}.where-r{aspect-ratio:16/11;max-height:420px}}
