/* ============================================================
   ARKOS DATATEKS — design system v2
   Signature idea: messy records becoming structured tables.
   Vocabulary borrowed from the product itself (TABLE / FIELD /
   RECORD) drives structure instead of generic numbered markers.
   Palette: deep navy + warm gold — a nod to Ghana without
   leaning on literal cliché.
   ============================================================ */

:root{
  --ink:        #161B22;
  --ink-soft:   #4A5568;
  --navy-950:   #172F49;
  --navy-800:   #1F3F62;
  --navy-700:   #28517E;
  --navy-600:   #57779A;
  --gold-600:   #B9860F;
  --gold-500:   #D9A521;
  --gold-100:   #F7E9C2;
  --paper:      #F6F7F9;
  --panel:      #FFFFFF;
  --mist:       #EAEFF6;
  --mist-deep:  #DCE6F2;
  --line:       #DCE3ED;
  --line-deep:  #C3CEDD;
  --green:      #2F8A4B;
  --red:        #B23A3A;

  --f-display: "Space Grotesk", "Inter", sans-serif;
  --f-body:    "Inter", "Helvetica Neue", Arial, sans-serif;
  --f-mono:    "IBM Plex Mono", ui-monospace, monospace;

  --fs-900: clamp(2.6rem, 1.6rem + 3.6vw, 4.7rem);
  --fs-800: clamp(2.1rem, 1.5rem + 2.2vw, 3.2rem);
  --fs-700: clamp(1.6rem, 1.3rem + 1.1vw, 2.1rem);
  --fs-600: clamp(1.25rem, 1.1rem + 0.5vw, 1.5rem);
  --fs-500: 1.125rem;
  --fs-400: 1rem;
  --fs-300: 0.9rem;
  --fs-200: 0.78rem;

  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 22px;

  --shadow-sm: 0 8px 18px -14px rgba(23,47,73,0.25);
  --shadow-md: 0 18px 36px -20px rgba(23,47,73,0.28);
  --shadow-lg: 0 30px 60px -28px rgba(23,47,73,0.32);
  --shadow-gold: 0 16px 32px -14px rgba(217,165,33,0.45);

  --maxw: 1180px;
  --pad: clamp(20px, 4vw, 56px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:96px; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--f-body);
  font-size:var(--fs-400);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; }
h1,h2,h3,h4{ font-family:var(--f-display); margin:0; line-height:1.12; letter-spacing:-0.01em; }
p{ margin:0; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); position:relative; }
:focus-visible{ outline:3px solid var(--gold-500); outline-offset:2px; border-radius:4px; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

.dot-grid{ background-image:radial-gradient(circle, rgba(23,47,73,0.09) 1.3px, transparent 1.3px); background-size:24px 24px; }
.bg-navy.dot-grid{ background-image:radial-gradient(circle, rgba(255,255,255,0.10) 1.3px, transparent 1.3px); }

/* ---------- signature record tag ---------- */
.record-tag{ display:flex; align-items:center; gap:10px; font-family:var(--f-mono); font-size:var(--fs-200); letter-spacing:0.03em; color:var(--navy-600); margin-bottom:18px; }
.record-tag::before{ content:"▸"; color:var(--gold-500); font-size:0.9em; }
.record-tag .rule{ flex:1; height:1px; background:var(--line-deep); transform:scaleX(0); transform-origin:left; transition:transform .7s cubic-bezier(.4,0,.2,1) .15s; }
.reveal.is-visible .record-tag .rule{ transform:scaleX(1); }
.bg-navy .record-tag{ color:var(--gold-100); }
.bg-navy .record-tag .rule{ background:rgba(255,255,255,0.18); }

/* ---------- pattern strip (signature divider) ---------- */
.pattern-strip{ position:relative; height:1px; background:linear-gradient(90deg, transparent, var(--line-deep) 15%, var(--gold-500) 50%, var(--line-deep) 85%, transparent); }
.pattern-strip::before{ content:""; position:absolute; top:50%; left:50%; width:7px; height:7px; background:var(--gold-500); border-radius:50%; transform:translate(-50%,-50%); box-shadow:0 0 0 5px var(--paper); }

/* ---------- icon tiles ---------- */
.icon-tile{ width:50px; height:50px; flex:none; border-radius:14px; background:linear-gradient(150deg,var(--navy-800),var(--navy-950)); display:flex; align-items:center; justify-content:center; color:var(--gold-500); box-shadow:0 10px 22px -10px rgba(23,47,73,0.45), inset 0 1px 0 rgba(255,255,255,0.08); transition:transform .25s ease, box-shadow .25s ease; }
.icon-tile svg{ width:24px; height:24px; }
.icon-tile-sm{ width:34px; height:34px; border-radius:10px; }
.icon-tile-sm svg{ width:18px; height:18px; }
.icon-tile-ghost{ background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.16); box-shadow:none; }
.path-card:hover .icon-tile, .step:hover .icon-tile{ transform:translateY(-4px) rotate(-5deg); box-shadow:var(--shadow-gold); }

/* ---------- header / nav ---------- */
.site-header{ position:sticky; top:0; z-index:50; }
.site-header-bg{ position:absolute; inset:0; z-index:0; background:rgba(246,247,249,0.92); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); }
.nav{ position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; padding-top:18px; padding-bottom:18px; transition:padding .25s ease; }
.site-header.scrolled .nav{ padding-top:11px; padding-bottom:11px; }
.site-header.scrolled{ box-shadow:0 8px 24px -18px rgba(23,47,73,0.35); }
.brand{ display:flex; align-items:center; gap:10px; font-family:var(--f-display); font-weight:600; font-size:1.05rem; color:var(--navy-950); }
.brand .mark-img{ width:32px; height:32px; object-fit:contain; }
.nav-links{ display:flex; align-items:center; gap:8px; }
.nav-link{ position:relative; font-size:0.92rem; color:var(--ink-soft); font-weight:500; padding:8px 10px; transition:color .15s ease; }
.nav-link::after{ content:""; position:absolute; left:10px; right:10px; bottom:3px; height:2px; background:var(--gold-500); transform:scaleX(0); transform-origin:left; transition:transform .25s ease; }
.nav-link:hover{ color:var(--navy-950); }
.nav-link:hover::after{ transform:scaleX(1); }
.nav-portal{ display:inline-flex; align-items:center; gap:6px; font-size:0.88rem; font-weight:600; color:var(--navy-700); padding:9px 14px; border:1px solid var(--line-deep); border-radius:999px; margin-left:6px; transition:background .15s ease, color .15s ease, border-color .15s ease; }
.nav-portal:hover{ background:var(--mist); border-color:var(--navy-600); color:var(--navy-950); }
.nav-portal svg{ width:14px; height:14px; }
.nav-cta{ background:var(--navy-950); color:#fff !important; padding:10px 20px; border-radius:999px; font-size:0.88rem; font-weight:600; display:inline-flex; align-items:center; gap:8px; margin-left:10px; transition:background .15s ease, transform .15s ease; }
.nav-cta:hover{ background:var(--navy-800); transform:translateY(-1px); }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; padding:6px; }
.nav-toggle svg{ width:24px; height:24px; }

@media (max-width:940px){
  .nav-links{ position:fixed; inset:64px 0 0 0; background:var(--paper); flex-direction:column; align-items:flex-start; gap:0; padding:8px var(--pad) 24px; border-top:1px solid var(--line); transform:translateY(-8px); opacity:0; pointer-events:none; transition:opacity .18s ease, transform .18s ease; overflow-y:auto; }
  .nav-links.open{ opacity:1; transform:translateY(0); pointer-events:auto; }
  .nav-link{ width:100%; padding:14px 0; border-bottom:1px solid var(--line); font-size:1rem; }
  .nav-link::after{ display:none; }
  .nav-portal, .nav-cta{ margin-top:14px; margin-left:0; width:100%; justify-content:center; }
  .nav-toggle{ display:block; }
}

/* ---------- buttons ---------- */
.btn{ position:relative; overflow:hidden; display:inline-flex; align-items:center; gap:8px; font-family:var(--f-body); font-weight:600; font-size:0.95rem; padding:13px 25px; border-radius:999px; cursor:pointer; border:1px solid transparent; transition:transform 0.18s ease, background 0.18s ease, box-shadow .18s ease; }
.btn:hover{ transform:translateY(-2px); }
.btn-gold{ background:linear-gradient(165deg,var(--gold-500) 0%,var(--gold-600) 100%); color:var(--navy-950); box-shadow:0 10px 22px -14px rgba(217,165,33,0.55); }
.btn-gold:hover{ background:var(--gold-600); box-shadow:var(--shadow-gold); }
.btn-navy{ background:linear-gradient(165deg,var(--navy-800) 0%,var(--navy-950) 100%); color:#fff; box-shadow:0 10px 22px -14px rgba(23,47,73,0.55); }
.btn-navy:hover{ background:var(--navy-800); box-shadow:0 14px 30px -12px rgba(23,47,73,0.5); }
.btn-ghost{ background:transparent; color:var(--navy-950); border-color:var(--line-deep); }
.btn-ghost:hover{ background:var(--mist); }
.btn-onlight{ background:rgba(255,255,255,0.1); color:#fff; border:1px solid rgba(255,255,255,0.25); }
.btn-onlight:hover{ background:rgba(255,255,255,0.18); }
.btn-block{ width:100%; justify-content:center; }
.btn-gold::before, .btn-navy::before{ content:""; position:absolute; top:0; left:-75%; width:50%; height:100%; background:linear-gradient(120deg, transparent, rgba(255,255,255,0.5), transparent); transform:skewX(-20deg); transition:left .6s ease; }
.btn-gold:hover::before, .btn-navy:hover::before{ left:130%; }

/* ---------- hero ---------- */
.hero{ padding:68px 0 50px; position:relative; }
.hero::before{ content:""; position:absolute; top:-80px; left:-120px; width:560px; height:560px; background:radial-gradient(circle, rgba(217,165,33,0.10), transparent 70%); pointer-events:none; z-index:0; }
.hero .wrap{ position:relative; z-index:1; }
.eyebrow{ font-family:var(--f-mono); font-size:var(--fs-200); letter-spacing:0.08em; color:var(--navy-600); text-transform:uppercase; margin-bottom:16px; display:inline-block; background:var(--mist); border:1px solid var(--mist-deep); padding:5px 12px; border-radius:999px; }
.hero h1{ font-size:var(--fs-900); color:var(--navy-950); letter-spacing:-0.015em; }
.hero h1 em{ font-style:normal; color:var(--gold-600); }
.hero-sub{ font-size:var(--fs-500); color:var(--ink-soft); max-width:46ch; margin-top:20px; }
.hero-actions{ display:flex; gap:14px; margin-top:30px; flex-wrap:wrap; }

/* trust strip pills */
.trust-strip{ display:flex; gap:12px; flex-wrap:wrap; margin-top:36px; }
.trust-item{ display:flex; align-items:center; gap:10px; background:var(--panel); border:1px solid var(--line); border-radius:999px; padding:8px 16px 8px 8px; font-size:0.83rem; font-weight:600; color:var(--navy-950); box-shadow:var(--shadow-sm); }
.trust-item .icon-tile-sm{ width:28px; height:28px; border-radius:8px; }
.trust-item .icon-tile-sm svg{ width:15px; height:15px; }

/* ---------- hero grid (text + product screenshot) ---------- */
.hero-grid{ display:grid; grid-template-columns:0.92fr 1.32fr; gap:40px; align-items:center; }
.hero-text{ max-width:560px; }
.hero-shot{ margin-right:-64px; }
@media (max-width:1180px){ .hero-shot{ margin-right:0; } }
@media (max-width:960px){ .hero-grid{ grid-template-columns:1fr; } .hero-shot{ margin-top:8px; margin-right:0; } }

/* ---------- product screenshot frame ---------- */
.screenshot-frame{ background:var(--panel); border:1px solid var(--line); border-radius:16px; overflow:hidden; box-shadow:var(--shadow-lg); }
.sf-bar{ display:flex; align-items:center; gap:7px; padding:10px 14px; background:var(--mist); border-bottom:1px solid var(--line); }
.sf-dot{ width:9px; height:9px; border-radius:50%; flex:none; }
.sf-dot.r{ background:#E2675B; } .sf-dot.y{ background:#E8B84B; } .sf-dot.g{ background:#5BAE71; }
.sf-url{ margin-left:8px; font-family:var(--f-mono); font-size:0.7rem; color:var(--ink-soft); background:#fff; border:1px solid var(--line); border-radius:6px; padding:3px 12px; }
.sf-imgwrap{ position:relative; width:100%; aspect-ratio:1904/907; background:#fff; }
.sf-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:top center; opacity:0; transition:opacity 1s ease; }
.sf-img.is-active{ opacity:1; }

/* desktop-window variant (for the offline Access product — honest about being a native app, not a website) */
.desktop-frame{ background:var(--panel); border:1px solid var(--line); border-radius:12px; overflow:hidden; box-shadow:var(--shadow-lg); }
.df-bar{ display:flex; align-items:center; gap:8px; padding:9px 12px; background:#F0F1F3; border-bottom:1px solid var(--line); }
.df-icon{ width:16px; height:16px; border-radius:4px; background:linear-gradient(150deg,var(--navy-800),var(--navy-950)); flex:none; }
.df-title{ font-size:0.78rem; color:var(--ink-soft); font-weight:600; }
.df-close{ margin-left:auto; width:18px; height:18px; border-radius:4px; display:flex; align-items:center; justify-content:center; color:var(--ink-soft); }
.df-close svg{ width:11px; height:11px; }
.desktop-frame img{ width:100%; display:block; }

.shot-dots{ display:flex; gap:8px; justify-content:center; margin-top:18px; }
.shot-dot{ width:7px; height:7px; border-radius:50%; background:var(--line-deep); border:none; cursor:pointer; padding:0; transition:background .2s ease, transform .2s ease; }
.shot-dot.is-active{ background:var(--navy-700); transform:scale(1.3); }
.shot-caption{ text-align:center; margin-top:14px; font-size:0.84rem; color:var(--ink-soft); }

/* ---------- watch-demo play overlay on screenshot ---------- */
.sf-play{ position:absolute; inset:0; z-index:3; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; background:none; border:none; padding:0; cursor:pointer; }
.sf-play-circle{ width:60px; height:60px; border-radius:50%; background:var(--navy-950); color:#fff; display:flex; align-items:center; justify-content:center; box-shadow:0 0 0 9px rgba(255,255,255,0.55), 0 16px 30px -10px rgba(11,22,35,0.55); transition:transform .2s ease, background .2s ease; }
.sf-play-circle svg{ width:20px; height:20px; margin-left:2px; }
.sf-play:hover .sf-play-circle{ transform:scale(1.08); background:var(--gold-600); }
.sf-play-label{ background:rgba(11,22,35,0.72); color:#fff; font-weight:700; font-size:0.8rem; padding:7px 16px; border-radius:999px; }

.video-modal{ position:fixed; inset:0; z-index:300; display:none; align-items:center; justify-content:center; padding:24px; }
.video-modal.is-open{ display:flex; }
.video-modal-backdrop{ position:absolute; inset:0; background:rgba(23,47,73,0.86); }
.video-modal-panel{ position:relative; z-index:1; width:min(480px,92vw); max-height:90vh; background:#0B1620; border-radius:18px; overflow:hidden; box-shadow:0 40px 90px -24px rgba(0,0,0,0.65); }
.video-modal-panel video{ width:100%; aspect-ratio:1/1; max-height:90vh; display:block; background:#000; object-fit:contain; }
.video-modal-close{ position:absolute; top:12px; right:12px; z-index:2; width:34px; height:34px; border-radius:50%; background:rgba(8,16,24,0.6); color:#fff; border:none; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .2s ease; }
.video-modal-close:hover{ background:rgba(8,16,24,0.85); }
.video-modal-close svg{ width:15px; height:15px; }

/* ---------- sections ---------- */
section{ padding:64px 0; }
.section-head{ max-width:62ch; margin-bottom:40px; }
.section-head h2{ font-size:var(--fs-800); color:var(--navy-950); letter-spacing:-0.01em; }
.section-head p{ color:var(--ink-soft); font-size:var(--fs-500); margin-top:14px; }
.bg-mist{ background:var(--mist); }
.bg-navy{ background:var(--navy-950); color:#fff; }
.bg-navy .section-head h2{ color:#fff; }
.bg-navy .section-head p{ color:#B8C6DC; }

/* ---------- path cards (home) ---------- */
.path-grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.path-card{ position:relative; background:var(--panel); border:1px solid var(--line); border-radius:var(--radius-lg); padding:36px; display:flex; flex-direction:column; gap:18px; box-shadow:var(--shadow-sm); overflow:hidden; transition:transform 0.22s ease, box-shadow 0.22s ease, border-color .22s ease; }
.path-card::before{ content:""; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--gold-500),var(--navy-700)); transform:scaleX(0); transform-origin:left; transition:transform .3s ease; }
.path-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--line-deep); }
.path-card:hover::before{ transform:scaleX(1); }
.path-card h3{ font-size:var(--fs-700); color:var(--navy-950); }
.path-card p{ color:var(--ink-soft); }
.path-card .pc-from{ font-family:var(--f-mono); font-size:0.85rem; color:var(--navy-700); margin-top:auto; }
.path-card .pc-from b{ font-size:1.15rem; }
.path-card .pc-go{ display:inline-flex; align-items:center; gap:6px; font-weight:600; color:var(--navy-950); font-size:0.9rem; }
.path-card .pc-go svg{ width:15px; height:15px; transition:transform .22s ease; }
.path-card:hover .pc-go svg{ transform:translateX(4px); }
@media (max-width:780px){ .path-grid{ grid-template-columns:1fr; } }

/* ---------- comparison table ---------- */
.compare{ width:100%; border-collapse:collapse; background:var(--panel); border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line); }
.compare thead th{ background:var(--navy-950); color:#fff; font-family:var(--f-display); font-weight:600; border-bottom:3px solid var(--gold-500); }
.compare th,.compare td{ padding:16px 20px; text-align:left; border-bottom:1px solid var(--line); font-size:0.95rem; }
.compare thead th .th-ic{ display:inline-flex; align-items:center; gap:8px; }
.compare thead th .th-ic svg{ width:16px; height:16px; color:var(--gold-500); }
.compare tbody tr{ transition:background .15s ease; }
.compare tbody tr:hover{ background:var(--mist); }
.compare tbody tr:last-child td{ border-bottom:none; }
.compare td:first-child{ color:var(--ink-soft); font-size:0.88rem; }
.table-scroll{ overflow-x:auto; -webkit-overflow-scrolling:touch; }

/* ---------- steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }
.step{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius-md); padding:24px 20px; box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease; }
.step:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.step .icon-tile{ width:42px; height:42px; border-radius:11px; margin-bottom:14px; }
.step .icon-tile svg{ width:20px; height:20px; }
.step .step-id{ font-family:var(--f-mono); font-size:0.7rem; color:var(--gold-600); margin-bottom:8px; }
.step h4{ font-size:1.02rem; color:var(--navy-950); margin-bottom:8px; }
.step p{ font-size:0.86rem; color:var(--ink-soft); }
@media (max-width:980px){ .steps{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .steps{ grid-template-columns:1fr; } }

/* ---------- package cards ---------- */
.pkg-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; align-items:stretch; }
.pkg{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius-lg); padding:28px 24px; display:flex; flex-direction:column; gap:16px; position:relative; box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.pkg:hover{ transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--line-deep); }
.pkg.featured{ border-color:var(--gold-500); box-shadow:var(--shadow-gold); }
.pkg.featured::before{ content:"MOST CHOSEN"; position:absolute; top:-12px; left:24px; background:var(--gold-500); color:var(--navy-950); font-family:var(--f-mono); font-size:0.65rem; letter-spacing:0.05em; padding:4px 10px; border-radius:999px; font-weight:700; }
.pkg h3{ font-size:1.2rem; color:var(--navy-950); }
.pkg .price{ font-family:var(--f-mono); }
.pkg .price .impl{ font-size:1.7rem; font-weight:700; color:var(--navy-950); }
.pkg .price .ann{ display:block; font-size:0.8rem; color:var(--ink-soft); margin-top:4px; font-family:var(--f-body); }
.pkg ul{ display:flex; flex-direction:column; gap:10px; margin:6px 0; }
.pkg li{ font-size:0.86rem; color:var(--ink-soft); padding-left:24px; position:relative; }
.pkg li::before{ content:"✓"; position:absolute; left:0; top:0.5px; width:16px; height:16px; border-radius:50%; background:var(--gold-500); color:var(--navy-950); font-size:0.62rem; font-weight:700; display:flex; align-items:center; justify-content:center; }
.pkg .btn{ margin-top:auto; }
@media (max-width:1040px){ .pkg-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .pkg-grid{ grid-template-columns:1fr; } }
.pkg-grid-3{ grid-template-columns:repeat(3,1fr); }
@media (max-width:880px){ .pkg-grid-3{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .pkg-grid-3{ grid-template-columns:1fr; } }

/* ---------- module price tables ---------- */
.module-table{ width:100%; border-collapse:collapse; }
.module-table th,.module-table td{ padding:13px 18px; border-bottom:1px solid var(--line); font-size:0.92rem; text-align:left; }
.module-table thead th{ font-family:var(--f-mono); font-size:0.72rem; letter-spacing:0.05em; text-transform:uppercase; color:var(--navy-600); background:var(--mist); border-bottom:2px solid var(--gold-500); }
.module-table td:last-child,.module-table th:last-child{ text-align:right; font-family:var(--f-mono); white-space:nowrap; font-weight:600; color:var(--navy-800); }
.module-table tbody tr{ transition:background .15s ease; }
.module-table tbody tr:hover{ background:var(--mist); }
.module-card{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-sm); }
.module-card .accordion-trigger{ padding:18px 24px; }
.module-card .accordion-inner{ padding:0 0 6px; max-width:none; }

/* ---------- accordions (faq + module tables) ---------- */
.accordion{ border-bottom:1px solid var(--line); }
.accordion:last-child{ border-bottom:none; }
.accordion-trigger{ width:100%; background:none; border:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; padding:20px 4px; font:inherit; font-weight:600; font-size:1.02rem; color:var(--navy-950); text-align:left; }
.accordion-trigger .chev{ flex:none; width:18px; height:18px; color:var(--gold-600); transition:transform .3s ease; }
.accordion.is-open .accordion-trigger .chev{ transform:rotate(180deg); }
.accordion-panel{ max-height:0; overflow:hidden; transition:max-height .4s cubic-bezier(.4,0,.2,1); }
.accordion-inner{ padding:0 4px 20px; color:var(--ink-soft); max-width:70ch; }

/* ---------- two-col include/exclude ---------- */
.inc-grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.inc-card{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius-md); padding:28px; transition:transform .2s ease, box-shadow .2s ease; }
.inc-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); }
.inc-card h4{ display:flex; align-items:center; gap:10px; font-size:1rem; color:var(--navy-950); margin-bottom:16px; }
.inc-card ul{ display:flex; flex-direction:column; gap:11px; }
.inc-card li{ font-size:0.9rem; color:var(--ink-soft); padding-left:24px; position:relative; }
.inc-card.yes li::before{ content:"✓"; position:absolute; left:0; color:var(--green); font-weight:700; }
.inc-card.no li::before{ content:"–"; position:absolute; left:0; color:var(--red); font-weight:700; }

/* ---------- banner ---------- */
.banner{ background:var(--navy-950); color:#fff; border-radius:var(--radius-lg); padding:40px var(--pad); text-align:center; background-image:radial-gradient(circle at 18% 20%, rgba(217,165,33,0.22), transparent 50%), radial-gradient(circle, rgba(255,255,255,0.10) 1.3px, transparent 1.3px); background-size:auto, 24px 24px; }
.banner .label{ font-family:var(--f-mono); font-size:0.75rem; letter-spacing:0.08em; color:var(--gold-100); text-transform:uppercase; }
.banner .amount{ font-size:var(--fs-800); font-family:var(--f-display); margin:8px 0; }
.banner p{ color:#B8C6DC; max-width:48ch; margin:0 auto; }

/* ---------- payment terms ---------- */
.terms-grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.term-card{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius-md); padding:26px; }
.term-card h4{ color:var(--navy-950); margin-bottom:14px; }
.term-card .seg{ display:flex; align-items:center; gap:12px; padding:9px 0; border-bottom:1px dashed var(--line); }
.term-card .seg:last-child{ border-bottom:none; }
.term-card .seg .pct{ font-family:var(--f-mono); font-weight:700; color:var(--navy-700); width:48px; }
@media (max-width:760px){ .terms-grid{ grid-template-columns:1fr; } .inc-grid{ grid-template-columns:1fr; } }

/* ---------- footer ---------- */
footer{ background:var(--navy-950); color:#B8C6DC; padding:56px 0 28px; position:relative; }
footer::before{ content:""; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg, transparent, var(--gold-500), transparent); }
.foot-grid{ display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:40px; margin-bottom:40px; }
.foot-brand{ display:flex; align-items:center; gap:10px; color:#fff; font-family:var(--f-display); font-size:1.1rem; margin-bottom:12px; }
.foot-brand .mark-img{ width:28px; height:28px; object-fit:contain; }
.foot-col h5{ color:#fff; font-size:0.85rem; letter-spacing:0.05em; text-transform:uppercase; margin-bottom:16px; font-family:var(--f-mono); }
.foot-col ul{ display:flex; flex-direction:column; gap:14px; }
.foot-col li{ display:flex; align-items:center; gap:10px; }
.foot-col a:hover{ color:#fff; }
.foot-bottom{ border-top:1px solid rgba(255,255,255,0.12); padding-top:22px; font-size:0.82rem; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; }
@media (max-width:780px){ .foot-grid{ grid-template-columns:1fr; gap:28px; } }

/* ---------- whatsapp floating cta ---------- */
.wa-float{ position:fixed; bottom:22px; right:22px; z-index:60; background:var(--gold-500); color:var(--navy-950); border-radius:999px; padding:13px 20px; display:flex; align-items:center; gap:9px; font-weight:700; font-size:0.88rem; box-shadow:0 14px 30px -10px rgba(0,0,0,0.4); transition:transform .2s ease, background .2s ease; }
.wa-float:hover{ background:var(--gold-600); transform:translateY(-2px); }

/* ---------- breadcrumb (sub-pages) ---------- */
.crumb{ font-family:var(--f-mono); font-size:0.8rem; color:var(--navy-600); display:flex; gap:8px; align-items:center; margin-bottom:20px; }
.crumb a:hover{ color:var(--navy-950); }

/* ---------- reveal-on-scroll ---------- */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity 0.6s cubic-bezier(.4,0,.2,1), transform 0.6s cubic-bezier(.4,0,.2,1); }
.reveal.is-visible{ opacity:1; transform:translateY(0); }

/* ---------- generic helpers ---------- */
.mt-8{ margin-top:8px;} .mt-16{ margin-top:16px;} .mt-24{margin-top:24px;} .mt-40{margin-top:40px;}
.center{ text-align:center; }
.muted{ color:var(--ink-soft); }
