/* ============================================================
   SPOT GROUP — rich components (shared across pages)
   ============================================================ */

/* ---------------- HERO ---------------- */
.hero{
  position:relative; min-height:100svh;
  display:flex; align-items:center;
  background:
    radial-gradient(120% 90% at 78% 18%, rgba(43,166,240,0.22), transparent 55%),
    radial-gradient(90% 80% at 12% 92%, rgba(0,114,181,0.20), transparent 60%),
    linear-gradient(160deg, #0A2038 0%, #07172A 60%, #04101E 100%);
  color:#fff; overflow:hidden;
}
.hero-canvas{ position:absolute; inset:0; z-index:1; opacity:0.9; }
.hero-grain{ position:absolute; inset:0; z-index:2; pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size:4px 4px; mix-blend-mode:overlay; }
.hero-inner{ position:relative; z-index:4; width:100%; padding-top:120px; padding-bottom:64px; }
.hero h1{ color:#fff; max-width:16ch; }
.hero .lead{ color:var(--tx-on-dark); max-width:46ch; margin-top:30px; }
.hero-cta{ display:flex; gap:16px; margin-top:42px; flex-wrap:wrap; }
.hero-meta{ position:absolute; bottom:38px; left:var(--gutter); right:var(--gutter); z-index:4;
  display:flex; justify-content:space-between; align-items:flex-end; gap:20px; }
.scroll-cue{ display:flex; flex-direction:column; align-items:center; gap:10px; color:var(--tx-on-dark-soft); font-family:var(--font-mono); font-size:0.66rem; letter-spacing:0.25em; }
.scroll-cue .bar{ width:1px; height:48px; background:linear-gradient(var(--blue-bright), transparent); position:relative; overflow:hidden; }
.scroll-cue .bar::after{ content:""; position:absolute; top:0; left:0; width:100%; height:40%; background:var(--blue-glow); animation:scrolldn 2s var(--ease) infinite; }
@keyframes scrolldn{ 0%{ transform:translateY(-100%);} 100%{ transform:translateY(300%);} }
.hero-badges{ display:flex; gap:34px; font-family:var(--font-mono); font-size:0.68rem; letter-spacing:0.18em; color:var(--tx-on-dark-soft); text-transform:uppercase; }

/* rotating compass mark behind hero */
.hero-compass{ position:absolute; z-index:2; right:-8vw; top:50%; transform:translateY(-50%);
  width:min(60vw,720px); aspect-ratio:1; pointer-events:none; opacity:0.5; }

/* ---------------- STAT BAND ---------------- */
.stat-band{ background:var(--white); border-top:1px solid var(--line); }
.stat-grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat-cell{ padding:clamp(36px,4vw,64px) clamp(20px,2.4vw,40px); border-right:1px solid var(--line); position:relative; }
.stat-cell:last-child{ border-right:0; }
.stat-num{ font-family:var(--font-display); font-weight:600; font-size:clamp(3rem,6vw,5.2rem); line-height:1; color:var(--navy); letter-spacing:-0.04em; display:flex; align-items:baseline; }
.stat-num .suf{ color:var(--blue); }
.stat-label{ margin-top:14px; font-size:0.9rem; color:var(--tx-mut); font-weight:500; letter-spacing:0.01em; }
@media(max-width:760px){ .stat-grid{ grid-template-columns:repeat(2,1fr);} .stat-cell:nth-child(2n){ border-right:0;} .stat-cell:nth-child(-n+2){ border-bottom:1px solid var(--line);} }

/* ---------------- SECTION HEADER ---------------- */
.sec-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:40px; flex-wrap:wrap; margin-bottom:clamp(40px,6vw,84px); }
.sec-head .left{ max-width:60ch; }
.sec-head h2{ margin-top:22px; }

/* ---------------- WHO WE ARE / split ---------------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,96px); align-items:center; }
.split-media{ position:relative; }
.media-frame{ position:relative; border-radius:0; overflow:hidden; aspect-ratio:4/5; background:var(--navy); }
.media-frame.wide{ aspect-ratio:4/3; }
.quote-card{ background:var(--navy); color:#fff; padding:clamp(28px,3vw,44px); position:relative; }
.quote-card .mk{ font-family:var(--font-display); font-size:5rem; line-height:0.6; color:var(--blue-bright); display:block; height:32px; }
.quote-card p{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.3rem,2vw,1.8rem); line-height:1.25; color:#fff; letter-spacing:-0.02em; }
@media(max-width:820px){ .split{ grid-template-columns:1fr; } }

/* ---------------- MISSION / VISION / AIM ---------------- */
.mvv{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--line-dark); }
.mvv-cell{ padding:clamp(34px,3.6vw,56px) clamp(24px,2.6vw,44px); border-right:1px solid var(--line-dark); position:relative; transition:background .5s var(--ease); }
.mvv-cell:last-child{ border-right:0; }
.mvv-cell:hover{ background:rgba(43,166,240,0.06); }
.mvv-num{ font-family:var(--font-mono); font-size:0.78rem; letter-spacing:0.2em; color:var(--blue-bright); }
.mvv-cell h3{ font-size:clamp(1.7rem,2.4vw,2.4rem); margin:26px 0 8px; color:#fff; }
.mvv-kicker{ font-size:0.82rem; text-transform:uppercase; letter-spacing:0.18em; color:var(--tx-on-dark-soft); font-family:var(--font-mono); }
.mvv-cell p{ margin-top:22px; color:var(--tx-on-dark-soft); }
@media(max-width:820px){ .mvv{ grid-template-columns:1fr; } .mvv-cell{ border-right:0; border-bottom:1px solid var(--line-dark); } }

/* ---------------- VALUE CARDS ---------------- */
.values-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.value-card{ background:var(--paper); padding:clamp(30px,3vw,48px); min-height:300px; display:flex; flex-direction:column; position:relative; overflow:hidden; transition:background .5s var(--ease); }
.value-card::before{ content:""; position:absolute; left:0; top:0; height:3px; width:0; background:var(--blue); transition:width .5s var(--ease); }
.value-card:hover{ background:var(--white); }
.value-card:hover::before{ width:100%; }
.value-card .vc-ico{ width:46px; height:46px; color:var(--blue); margin-bottom:auto; }
.value-card .vc-num{ position:absolute; top:clamp(30px,3vw,48px); right:clamp(30px,3vw,48px); font-family:var(--font-mono); font-size:0.8rem; color:var(--tx-mut); }
.value-card h3{ font-size:1.4rem; margin:28px 0 12px; }
.value-card p{ font-size:0.98rem; color:var(--tx); }
@media(max-width:900px){ .values-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:600px){ .values-grid{ grid-template-columns:1fr; } }

/* ---------------- TIMELINE ---------------- */
.timeline{ position:relative; }
.tl-line{ position:absolute; left:max(80px, 14%); top:6px; bottom:6px; width:1px; background:var(--line-strong); }
.tl-line .fill{ position:absolute; top:0; left:0; width:100%; height:0; background:var(--blue); transition:height 1.2s var(--ease); }
.timeline.in .tl-line .fill{ height:100%; }
.tl-row{ display:grid; grid-template-columns:max(80px,14%) 1fr; gap:clamp(30px,5vw,80px); padding-block:clamp(28px,3.4vw,52px); position:relative; }
.tl-year{ font-family:var(--font-display); font-weight:600; font-size:clamp(1.6rem,2.6vw,2.6rem); color:var(--navy); letter-spacing:-0.03em; }
.tl-dot{ position:absolute; left:max(80px,14%); top:calc(clamp(28px,3.4vw,52px) + 10px); width:13px; height:13px; border-radius:50%; background:var(--white); border:2px solid var(--blue); transform:translate(-50%,0); z-index:2; }
.tl-content h3{ font-size:clamp(1.3rem,2vw,1.7rem); margin-bottom:12px; }
.tl-content p{ color:var(--tx); max-width:54ch; }
.tl-kick{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue); display:block; margin-bottom:14px; }
@media(max-width:640px){
  .tl-line, .tl-dot{ left:6px; }
  .tl-row{ grid-template-columns:1fr; gap:8px; padding-left:34px; }
  .tl-dot{ left:6px; }
}

/* ---------------- DIVISIONS ---------------- */
.div-split{ display:grid; grid-template-columns:1fr 1fr; min-height:78vh; }
.div-panel{ position:relative; overflow:hidden; padding:clamp(40px,5vw,80px); display:flex; flex-direction:column; justify-content:flex-end; color:#fff; min-height:480px; isolation:isolate; }
.div-panel .bg{ position:absolute; inset:0; z-index:-2; transition:transform 1s var(--ease); }
.div-panel:hover .bg{ transform:scale(1.06); }
.div-panel::after{ content:""; position:absolute; inset:0; z-index:-1; transition:opacity .5s; }
.div-media{ background:linear-gradient(150deg,#0A2038,#07172A); }
.div-media::after{ background:linear-gradient(180deg, rgba(7,23,42,0.1), rgba(7,23,42,0.55)); }
.div-signs{ background:linear-gradient(150deg,#0A86D6,#0072B5); }
.div-signs::after{ background:linear-gradient(180deg, rgba(16,47,79,0.05), rgba(16,47,79,0.45)); }
.div-panel .d-eye{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.22em; text-transform:uppercase; color:rgba(255,255,255,0.7); }
.div-panel h3{ color:#fff; font-size:clamp(2.2rem,3.4vw,3.4rem); margin:18px 0 16px; letter-spacing:-0.03em; }
.div-panel p{ color:rgba(255,255,255,0.85); max-width:42ch; margin-bottom:30px; }
.div-tag{ position:absolute; top:clamp(40px,5vw,80px); left:clamp(40px,5vw,80px); font-family:var(--font-display); font-weight:500; font-size:clamp(2.6rem,5vw,5rem); color:rgba(255,255,255,0.10); letter-spacing:-0.04em; }
@media(max-width:820px){ .div-split{ grid-template-columns:1fr; } }

/* ---------------- WHY (numbered) ---------------- */
.why-row{ display:grid; grid-template-columns:90px 1fr; gap:clamp(24px,4vw,60px); padding-block:clamp(28px,3vw,44px); border-top:1px solid var(--line-dark); align-items:start; transition:padding-left .5s var(--ease); }
.why-row:hover{ padding-left:14px; }
.why-row .w-num{ font-family:var(--font-mono); font-size:0.9rem; color:var(--blue-bright); padding-top:8px; }
.why-row h3{ font-size:clamp(1.4rem,2.4vw,2.1rem); color:#fff; margin-bottom:10px; }
.why-row p{ color:var(--tx-on-dark-soft); max-width:60ch; }
@media(max-width:600px){ .why-row{ grid-template-columns:1fr; gap:8px; } }

/* ---------------- PAGE HERO (inner pages) ---------------- */
.page-hero{ position:relative; padding-top:clamp(150px,18vh,230px); padding-bottom:clamp(60px,8vw,110px); overflow:hidden;
  background:linear-gradient(160deg,#0A2038,#07172A 70%,#04101E); color:#fff; }
.page-hero canvas{ position:absolute; inset:0; z-index:1; opacity:0.85; }
.page-hero .ph-inner{ position:relative; z-index:3; }
.page-hero h1{ color:#fff; max-width:18ch; }
.page-hero .lead{ color:var(--tx-on-dark); max-width:52ch; margin-top:26px; }
.breadcrumb{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--tx-on-dark-soft); margin-bottom:30px; display:flex; gap:10px; align-items:center; }
.breadcrumb a:hover{ color:#fff; }
.breadcrumb .sep{ color:var(--blue-bright); }

/* ---------------- SERVICE ROWS ---------------- */
.svc-row{ display:grid; grid-template-columns:0.8fr 1.4fr; gap:clamp(30px,5vw,80px); padding-block:clamp(40px,5vw,80px); border-top:1px solid var(--line); align-items:start; }
.svc-row .s-left{ position:sticky; top:120px; }
.svc-num{ font-family:var(--font-mono); color:var(--blue); font-size:0.85rem; letter-spacing:0.1em; }
.svc-row h3{ font-size:clamp(1.8rem,3vw,2.8rem); margin:18px 0; }
.svc-list{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line); }
.svc-item{ background:var(--paper); padding:clamp(24px,2.6vw,38px); transition:background .4s; }
.svc-item:hover{ background:#fff; }
.svc-item .si-ico{ width:34px; height:34px; color:var(--blue); margin-bottom:18px; }
.svc-item h4{ font-size:1.18rem; margin-bottom:8px; }
.svc-item p{ font-size:0.94rem; color:var(--tx-mut); }
@media(max-width:820px){ .svc-row{ grid-template-columns:1fr; } .svc-row .s-left{ position:static; } .svc-list{ grid-template-columns:1fr; } }

/* ---------------- FEATURE STRIP ---------------- */
.feat-strip{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,48px); }
.feat-card{ padding:clamp(28px,3vw,44px); background:var(--white); border:1px solid var(--line); position:relative; transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.feat-card:hover{ transform:translateY(-6px); box-shadow:var(--sh-2); }
.feat-card .fc-ico{ width:42px; height:42px; color:var(--blue); margin-bottom:24px; }
.feat-card h4{ font-size:1.3rem; margin-bottom:10px; }
.feat-card p{ font-size:0.98rem; color:var(--tx-mut); }
@media(max-width:820px){ .feat-strip{ grid-template-columns:1fr; } }

/* ---------------- CTA BAND ---------------- */
.cta-band{ position:relative; overflow:hidden; background:linear-gradient(150deg,#0072B5,#0A2038 90%); color:#fff; padding-block:clamp(70px,9vw,130px); }
.cta-band h2{ color:#fff; max-width:18ch; }
.cta-orbit{ position:absolute; right:-6vw; top:50%; transform:translateY(-50%); width:min(46vw,560px); aspect-ratio:1; opacity:0.5; pointer-events:none; }

/* ---------------- CONTACT ---------------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,90px); }
.field{ margin-bottom:24px; }
.field label{ display:block; font-family:var(--font-mono); font-size:0.7rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--tx-mut); margin-bottom:10px; }
.field input, .field textarea, .field select{
  width:100%; font-family:var(--font-body); font-size:1.05rem; color:var(--tx-strong);
  background:var(--white); border:1px solid var(--line-strong); border-radius:0;
  padding:16px 18px; transition:border-color .3s, box-shadow .3s; }
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(0,114,181,0.12); }
.field textarea{ resize:vertical; min-height:140px; }
.info-item{ padding-block:26px; border-top:1px solid var(--line); }
.info-item .il{ font-family:var(--font-mono); font-size:0.7rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--blue); margin-bottom:10px; }
.info-item .iv{ font-size:1.15rem; color:var(--tx-strong); font-weight:500; }
@media(max-width:820px){ .contact-grid{ grid-template-columns:1fr; } }
