/* ===================================================================
   DPP Bangladesh — index.html stylesheet
   Editorial dark + gold aesthetic (matches news.html design system)
   Fonts: Cormorant Garamond (display) · Jost (body) · DM Mono (mono)
   =================================================================== */

:root{
  --bk:#091628;--bk1:#0b1a30;--bk2:#0e2038;--bk3:#122844;--bk4:#16304f;
  --wh:#ffffff;--wh1:#fafaf8;--wh2:#f5f2ec;--wh3:#ede9e0;--wh4:#e0dbd0;
  --g1:#5c3d10;--g2:#8a6820;--g3:#c9a84c;--g4:#e8c97a;--g5:#f5e4b3;
  --gb:rgba(201,168,76,.08);--gb2:rgba(201,168,76,.14);
  --gb3:rgba(201,168,76,.22);--gb4:rgba(201,168,76,.40);
  --cr:#eef3fb;--cr2:#bdc8da;--cr3:#8794a8;--cr4:#586778;
  --ink:#0f2540;--ink2:#27395a;--ink3:#465674;--ink4:#6a7891;
  --paper:#f5f8fc;--paper2:#e9eff7;--line:#d6deea;
  --gold:linear-gradient(135deg,#6b4f1a 0%,#c9a84c 38%,#e8c97a 62%,#f5e4b3 78%,#c9a84c 100%);
  --gold-t:linear-gradient(135deg,#c9a84c 0%,#e8c97a 35%,#f5e4b3 55%,#e8c97a 72%,#c9a84c 100%);
  --fh:'Cormorant Garamond',Georgia,serif;
  --fb:'Jost',system-ui,sans-serif;
  --fm:'DM Mono','JetBrains Mono',monospace;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--bk);color:var(--cr2);overflow-x:hidden;line-height:1.7;-webkit-font-smoothing:antialiased}
body::after{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px 180px}
a{color:inherit}
img,svg{display:block}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bk)}::-webkit-scrollbar-thumb{background:var(--g2)}

/* Gold gradient text */
.gt,.gline{background:var(--gold-t);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:gsh 6s ease infinite}
@keyframes gsh{0%,100%{background-position:0 50%}50%{background-position:100% 50%}}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.reveal.vis{opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}.gt,.gline{animation:none}}

/* Rules / dividers */
.rule{height:1px;background:linear-gradient(90deg,transparent,var(--gb4),transparent)}
.rule-white{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent)}
.rgold{height:2px;width:54px;background:var(--gold)}

/* ============ NAV ============ */
#nav{position:fixed;top:0;left:0;right:0;z-index:500;height:68px;display:flex;align-items:center;gap:24px;padding:0 48px;background:rgba(9,22,40,.92);backdrop-filter:blur(28px);border-bottom:1px solid var(--gb)}
.nlogo{display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0}
.logo-svg{width:34px;height:34px}
.nbrand{font-family:var(--fh);font-size:17px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--cr)}
.nbrand em{font-style:normal;background:var(--gold-t);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nlinks{display:flex;gap:6px;list-style:none;margin-left:auto;align-items:center}
.nlinks a{font-family:var(--fb);font-size:11px;font-weight:400;letter-spacing:1.2px;text-transform:uppercase;color:var(--cr3);text-decoration:none;padding:8px 12px;transition:color .25s;white-space:nowrap}
.nlinks a:hover{color:var(--g3)}
.nact{display:flex;gap:10px;align-items:center;flex-shrink:0}
.btn-gs{padding:9px 20px;border:1px solid var(--gb3);background:transparent;font-family:var(--fb);font-size:9px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--g3);cursor:pointer;transition:all .3s}
.btn-gs:hover{border-color:var(--gb4);color:var(--g4);background:var(--gb)}
.btn-gd{padding:10px 24px;border:none;background:var(--gold);font-family:var(--fb);font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--bk);cursor:pointer;transition:all .3s}
.btn-gd:hover{box-shadow:0 0 22px rgba(201,168,76,.4)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:7px;border:1px solid var(--gb3);background:transparent;margin-left:auto}
.hamburger span{display:block;width:20px;height:1.5px;background:var(--g3);transition:.3s}

/* ============ HERO ============ */
.hero{position:relative;overflow:hidden;background:var(--bk);padding:150px 48px 90px;border-bottom:1px solid var(--gb)}
.hbg{position:absolute;inset:0;background:radial-gradient(ellipse 70% 55% at 50% 0%,rgba(138,104,32,.16) 0%,transparent 62%);pointer-events:none}
.hr1,.hr2,.hr3{position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,var(--gb2),transparent);pointer-events:none}
.hr1{left:18%}.hr2{left:50%}.hr3{left:82%}
.hi{max-width:1000px;margin:0 auto;position:relative;z-index:2;text-align:center}
.hover{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:22px;animation:rise .8s ease both}
.hl{width:40px;height:1px;background:var(--gold)}
.ht{font-family:var(--fb);font-size:14px;font-weight:600;letter-spacing:2.2px;text-transform:uppercase;text-align:center;background:var(--gold-t);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:gsh 6s ease infinite}
@media(max-width:560px){.ht{font-size:11.5px;letter-spacing:1.5px}}
.hero-it{font-family:var(--fh);font-style:italic;font-size:18px;font-weight:400;color:var(--cr3);margin-bottom:14px;letter-spacing:.3px;animation:rise .8s .05s ease both}
.hero-h{font-family:var(--fh);font-size:clamp(40px,6vw,76px);font-weight:300;line-height:1.04;letter-spacing:-1.5px;color:var(--cr);margin-bottom:22px;animation:rise .8s .1s ease both}
.hero-lead{font-size:14px;font-weight:300;color:var(--cr3);line-height:1.9;max-width:640px;margin:0 auto 32px;animation:rise .8s .18s ease both}
.hero-lead strong{color:var(--g4);font-weight:400}
.hbtns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:56px;animation:rise .8s .26s ease both}
.btn-p{padding:16px 38px;border:none;background:var(--gold);font-family:var(--fb);font-size:10px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--bk);cursor:pointer;transition:all .3s}
.btn-p:hover{box-shadow:0 6px 28px rgba(201,168,76,.4);transform:translateY(-1px)}
.btn-s{padding:16px 38px;border:1px solid var(--gb3);background:transparent;font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--g3);cursor:pointer;transition:all .3s}
.btn-s:hover{border-color:var(--gb4);color:var(--g4);background:var(--gb)}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}

/* Hero DPP preview card */
.dpreview{max-width:680px;margin:0 auto;background:var(--bk2);border:1px solid var(--gb3);text-align:left;box-shadow:0 30px 80px rgba(0,0,0,.6);animation:rise .8s .34s ease both;position:relative}
.dpreview::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold)}
.dbar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--gb);background:var(--bk3)}
.ddot{width:9px;height:9px;border-radius:50%;background:var(--cr4)}
.ddot:first-child{background:#c9544c}.ddot:nth-child(2){background:#c9a84c}.ddot:nth-child(3){background:#5aa86a}
.durl{margin-left:10px;font-family:var(--fm);font-size:10px;color:var(--cr3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dbody{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:28px 26px}
.dqr,.dp-qr-sm{display:grid;gap:2px;flex-shrink:0}
.dqr{grid-template-columns:repeat(5,1fr);width:104px;height:104px}
.dp-qr-sm{grid-template-columns:repeat(4,1fr);width:60px;height:60px}
.qc,.qcs{background:var(--g3);border-radius:1px}
.qc.w,.qcs.w{background:transparent}
.dlbl{font-family:var(--fm);font-size:9px;letter-spacing:1px;color:var(--g3);text-transform:uppercase;margin-bottom:8px}
.dname{font-family:var(--fh);font-size:22px;font-weight:500;color:var(--cr);margin-bottom:14px}
.dfs{display:flex;flex-wrap:wrap;gap:6px}
.df{font-size:10px;font-weight:300;color:var(--cr2);padding:4px 9px;border:1px solid var(--gb);background:var(--bk3)}
.df.g{color:#7fd0a3;border-color:rgba(90,168,106,.3);background:rgba(90,168,106,.08)}

/* ============ SECTIONS ============ */
.sec{padding:92px 48px;position:relative}
.sec.wh{background:var(--paper)}
.sec.wh2{background:var(--paper2)}
.sec.dk{background:var(--bk1)}
.sec.dk2{background:var(--bk)}
.sec.wh,.sec.wh2{color:var(--ink3)}
.sec-wrap{max-width:1200px;margin:0 auto}
.sec-top{text-align:center;max-width:760px;margin:0 auto 48px}
.orn{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:18px}
.ol{width:34px;height:1px;background:var(--gold)}
.od{width:5px;height:5px;transform:rotate(45deg);background:var(--g3)}
.sec-lbl{font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--g3);display:block;margin-bottom:14px}
.sec-h{font-family:var(--fh);font-size:clamp(30px,4vw,50px);font-weight:300;line-height:1.1;letter-spacing:-.5px;color:var(--cr)}
.sec.wh .sec-h,.sec.wh2 .sec-h{color:var(--ink)}
.sec-sub{font-size:14px;font-weight:300;color:var(--cr3);line-height:1.85;margin-top:16px}
.sec.wh .sec-sub,.sec.wh2 .sec-sub{color:var(--ink3)}

/* ============ LIVE DEMO ============ */
.demo-wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:32px;max-width:1040px;margin:0 auto;align-items:start}
.demo-controls{background:#fff;border:1px solid var(--line);padding:30px}
.demo-title{font-family:var(--fh);font-size:20px;font-weight:500;color:var(--ink);margin-bottom:20px}
.demo-field{margin-bottom:16px}
.demo-lbl{font-family:var(--fm);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink4);margin-bottom:6px}
.demo-input,.demo-select{width:100%;padding:11px 13px;border:1px solid var(--line);background:var(--paper);font-family:var(--fb);font-size:13px;color:var(--ink);outline:none;transition:border-color .25s}
.demo-input:focus,.demo-select:focus{border-color:var(--g3)}
.demo-btn{width:100%;margin-top:8px;padding:14px;border:none;background:var(--ink);font-family:var(--fb);font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--g4);cursor:pointer;transition:all .3s}
.demo-btn:hover{background:#000}
.demo-preview{background:var(--bk2);border:1px solid var(--gb3);position:relative}
.demo-preview::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold)}
.dp-header{display:flex;gap:16px;align-items:center;padding:24px 24px 18px;border-bottom:1px solid var(--gb)}
.dp-hn{font-family:var(--fh);font-size:18px;font-weight:500;color:var(--cr);margin-bottom:4px}
.dp-hs{font-family:var(--fm);font-size:9px;letter-spacing:.5px;color:var(--g3);text-transform:uppercase}
.dp-body{padding:18px 24px}
.dp-row{display:flex;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--gb);font-size:12px}
.dp-row:last-child{border-bottom:none}
.dp-k{color:var(--cr3);font-weight:300;flex-shrink:0}
.dp-v{color:var(--cr);font-weight:300;text-align:right}
.dp-v.ok{color:#7fd0a3}
.dp-footer{display:flex;gap:10px;padding:16px 24px;border-top:1px solid var(--gb)}
.dp-btn-sm{flex:1;padding:10px;border:1px solid var(--gb3);background:transparent;font-family:var(--fb);font-size:9px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--g3);cursor:pointer;transition:all .3s}
.dp-btn-sm:hover{border-color:var(--gb4);color:var(--g4);background:var(--gb)}
.dp-dl{background:var(--gold);color:var(--bk);border:none;font-weight:600}

/* ============ CARD GRIDS ============ */
.wgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;max-width:1100px;margin:0 auto}
.wgrid2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:1000px;margin:0 auto}
.wcard{background:#fff;border:1px solid var(--line);padding:30px 28px;transition:border-color .3s,box-shadow .3s}
.wcard:hover{border-color:var(--gb4);box-shadow:0 14px 40px rgba(90,61,16,.08)}
.wcard-num{font-family:var(--fm);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--g2);margin-bottom:12px}
.wcard-title{font-family:var(--fh);font-size:21px;font-weight:500;color:var(--ink);margin-bottom:12px;line-height:1.25}
.wcard-body{font-size:13px;font-weight:300;color:var(--ink3);line-height:1.8}
.wcard-body strong{color:var(--ink);font-weight:500}
.wcard-tag{margin-top:16px;display:inline-block;font-family:var(--fm);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--g2);padding:4px 10px;border:1px solid var(--gb3);background:var(--gb)}

/* ============ PROCESS ============ */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);max-width:1100px;margin:0 auto}
.proc{background:var(--paper);padding:34px 26px;text-align:center}
.proc-n{font-family:var(--fh);font-size:34px;font-weight:300;background:var(--gold-t);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:12px}
.proc-t{font-family:var(--fh);font-size:19px;font-weight:500;color:var(--ink);margin-bottom:10px}
.proc-d{font-size:12px;font-weight:300;color:var(--ink3);line-height:1.75}

/* ============ TIMELINE ============ */
.tl-wrap{display:grid;grid-template-columns:1.5fr 1fr;gap:40px;max-width:1140px;margin:0 auto;align-items:start}
.tl-left{position:relative;padding-left:6px}
.tli{display:grid;grid-template-columns:auto 1fr;gap:20px;padding-bottom:30px;position:relative}
.tli::before{content:'';position:absolute;left:13px;top:28px;bottom:0;width:1px;background:var(--gb3)}
.tli:last-child::before{display:none}
.tld{width:28px;height:28px;border-radius:50%;border:1px solid var(--gb3);background:var(--bk2);color:var(--cr3);display:flex;align-items:center;justify-content:center;font-size:12px;font-family:var(--fm);flex-shrink:0;position:relative;z-index:1}
.tld.done{background:rgba(90,168,106,.14);border-color:rgba(90,168,106,.4);color:#7fd0a3}
.tld.hot{background:rgba(201,84,76,.16);border-color:rgba(201,84,76,.45);color:#e88a82}
.tl-dt{font-family:var(--fm);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--g3);margin-bottom:5px}
.tl-ti{font-family:var(--fh);font-size:19px;font-weight:500;color:var(--cr);margin-bottom:7px;line-height:1.2}
.tl-p{font-size:12px;font-weight:300;color:var(--cr3);line-height:1.8}
.tl-p strong{color:var(--g4);font-weight:400}
.tlbadge{display:inline-block;margin-top:10px;font-family:var(--fm);font-size:8px;letter-spacing:1.5px;text-transform:uppercase;padding:3px 9px;border:1px solid var(--gb3);color:var(--g3)}
.tlbadge.done{color:#7fd0a3;border-color:rgba(90,168,106,.35)}
.tlbadge.hot{color:#e88a82;border-color:rgba(201,84,76,.4);background:rgba(201,84,76,.08)}
.tl-rcard{background:var(--bk2);border:1px solid var(--gb3);padding:34px 30px;position:sticky;top:90px;position:relative}
.tl-rcard::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold)}
.tlr-icon{font-size:32px;margin-bottom:14px}
.tlr-title{font-family:var(--fh);font-size:22px;font-weight:500;color:var(--g4);margin-bottom:14px;line-height:1.25}
.tlr-body{font-size:12px;font-weight:300;color:var(--cr3);line-height:1.85}
.tlr-body em{color:var(--cr2);font-style:italic}

/* ============ FAQ ============ */
.faq-list{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-item{border:1px solid var(--line);background:#fff;transition:border-color .3s}
.faq-item:hover{border-color:var(--gb4)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;cursor:pointer}
.faq-qt{font-family:var(--fh);font-size:18px;font-weight:500;color:var(--ink);line-height:1.3}
.faq-ico{font-size:20px;color:var(--g3);flex-shrink:0;transition:transform .3s;font-weight:300}
.faq-item.open .faq-ico{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;padding:0 24px;font-size:13px;font-weight:300;color:var(--ink3);line-height:1.85;transition:max-height .4s ease,padding .4s ease}
.faq-item.open .faq-a{max-height:600px;padding:0 24px 22px}
.faq-a strong{color:var(--ink);font-weight:500}
.faq-a code{font-family:var(--fm);font-size:12px;background:var(--paper2);padding:1px 5px;color:var(--g2)}

/* ============ RESEARCH / TRUST inline cards handled inline ============ */

/* ============ PRICING ============ */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1080px;margin:0 auto;align-items:start}
.pc{background:#fff;border:1px solid var(--line);padding:36px 30px;position:relative;transition:transform .3s,box-shadow .3s}
.pc:hover{transform:translateY(-3px);box-shadow:0 20px 50px rgba(90,61,16,.1)}
.pc.feat{border-color:var(--gb4);box-shadow:0 20px 60px rgba(90,61,16,.14)}
.pc.feat::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold)}
.pc-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--bk);font-family:var(--fb);font-size:8px;font-weight:600;letter-spacing:2px;text-transform:uppercase;padding:5px 16px;white-space:nowrap}
.pc-tier{font-family:var(--fm);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--g2);margin-bottom:14px}
.pc-price{font-family:var(--fh);font-size:54px;font-weight:300;color:var(--ink);line-height:1;letter-spacing:-1px}
.pc-price sup{font-size:24px;font-weight:400;color:var(--ink4);vertical-align:super}
.pc-period{font-size:12px;font-weight:300;color:var(--ink4);margin:6px 0 16px}
.pc-desc{font-size:13px;font-weight:300;color:var(--ink3);line-height:1.7;min-height:42px}
.pc-line{height:1px;background:var(--line);margin:20px 0}
.pcf{display:flex;flex-direction:column;gap:11px;margin-bottom:26px}
.pfi{display:flex;align-items:flex-start;gap:10px;font-size:12.5px;font-weight:300;color:var(--ink2)}
.pfi.dim{color:#b3a99d}
.pfic{color:var(--g3);font-size:11px;flex-shrink:0;margin-top:2px}
.pfi.dim .pfic{color:#c8bfb2}
.pc-btn{width:100%;padding:14px;font-family:var(--fb);font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .3s}
.pc-btn-o{border:1px solid var(--ink);background:transparent;color:var(--ink)}
.pc-btn-o:hover{background:var(--ink);color:var(--g4)}
.pc-btn-g{border:none;background:var(--gold);color:var(--bk)}
.pc-btn-g:hover{box-shadow:0 6px 24px rgba(201,168,76,.4)}

/* ============ NEWS GRID ============ */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);max-width:1140px;margin:0 auto}
.news-card{background:#fff;padding:30px 26px;position:relative;overflow:hidden;transition:background .3s}
.news-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold);opacity:0;transition:opacity .3s}
.news-card:hover{background:var(--paper)}
.news-card:hover::before{opacity:1}
.news-badge{display:inline-block;font-family:var(--fm);font-size:8px;font-weight:500;letter-spacing:2px;text-transform:uppercase;padding:3px 9px;border:1px solid var(--gb3);color:var(--g2);margin-bottom:14px}
.news-badge.new{background:var(--gb);color:var(--g2);border-color:var(--gb4)}
.news-date{font-family:var(--fm);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink4);margin-bottom:10px}
.news-title{font-family:var(--fh);font-size:19px;font-weight:500;color:var(--ink);line-height:1.25;margin-bottom:10px}
.news-body{font-size:12px;font-weight:300;color:var(--ink3);line-height:1.8;margin-bottom:16px}
.news-link{font-family:var(--fb);font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--g2);text-decoration:none}
.news-card:hover .news-link{color:var(--g3)}

/* ============ PLATFORM (dark) ============ */
.dgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--gb);border:1px solid var(--gb);max-width:1140px;margin:0 auto}
.dcard{background:var(--bk2);padding:32px 28px;transition:background .3s;position:relative;overflow:hidden}
.dcard::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold);opacity:0;transition:opacity .3s}
.dcard:hover{background:var(--bk3)}
.dcard:hover::before{opacity:1}
.dc-num{font-family:var(--fm);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--g2);margin-bottom:14px}
.dc-title{font-family:var(--fh);font-size:21px;font-weight:500;color:var(--cr);margin-bottom:10px}
.dc-body{font-size:12.5px;font-weight:300;color:var(--cr3);line-height:1.8}
.dc-tag{margin-top:16px;display:inline-block;font-family:var(--fm);font-size:8px;letter-spacing:1.5px;text-transform:uppercase;color:var(--g3);padding:4px 10px;border:1px solid var(--gb3)}

/* ============ GLOSSARY (dark accordion) ============ */
.glos-acc{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:8px}
.ga-item{border:1px solid var(--gb);background:var(--bk2);transition:border-color .3s}
.ga-item:hover{border-color:var(--gb3)}
.ga-term{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:17px 22px;cursor:pointer}
.ga-term-txt{font-family:var(--fh);font-size:17px;font-weight:500;color:var(--cr);letter-spacing:.2px}
.ga-icon{font-size:18px;color:var(--g3);flex-shrink:0;transition:transform .3s;font-weight:300}
.ga-item.open .ga-icon{transform:rotate(45deg)}
.ga-def{max-height:0;overflow:hidden;padding:0 22px;font-size:13px;font-weight:300;color:var(--cr3);line-height:1.85;transition:max-height .4s ease,padding .4s ease}
.ga-item.open .ga-def{max-height:500px;padding:0 22px 20px}
.ga-def strong{color:var(--g4);font-weight:400}
.ga-def code{font-family:var(--fm);font-size:12px;color:var(--g4)}

/* ============ CONTACT (dark) ============ */
.contact-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:44px;max-width:1080px;margin:0 auto;align-items:start}
.ci-item{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px}
.ci-ico{font-size:22px;flex-shrink:0}
.ci-t{font-family:var(--fm);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--g3);margin-bottom:5px}
.ci-v{font-size:13px;font-weight:300;color:var(--cr2);line-height:1.7}
.cform{background:var(--bk2);border:1px solid var(--gb3);padding:34px 32px;position:relative}
.cform::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold)}
.cf-title{font-family:var(--fh);font-size:24px;font-weight:500;color:var(--cr);margin-bottom:22px}
.cf-row{margin-bottom:15px;display:flex;flex-direction:column;gap:6px}
.cf-lbl{font-family:var(--fm);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cr3)}
.cf-input,.cf-select,.cf-ta{width:100%;padding:12px 14px;background:var(--bk3);border:1px solid var(--gb);font-family:var(--fb);font-size:13px;color:var(--cr);outline:none;transition:border-color .25s}
.cf-input:focus,.cf-select:focus,.cf-ta:focus{border-color:var(--gb4)}
.cf-input::placeholder,.cf-ta::placeholder{color:var(--cr4)}
.cf-ta{min-height:100px;resize:vertical}
.cf-submit{width:100%;margin-top:8px;padding:15px;border:none;background:var(--gold);font-family:var(--fb);font-size:10px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--bk);cursor:pointer;transition:all .3s}
.cf-submit:hover{box-shadow:0 6px 26px rgba(201,168,76,.4)}

/* ============ PORTAL ============ */
.port-sec{padding:92px 48px;background:var(--bk1)}
.pgrid2{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1080px;margin:0 auto;align-items:start}
.pcard{background:var(--bk2);border:1px solid var(--gb3);padding:32px 28px;transition:border-color .3s,transform .3s;cursor:pointer}
.pcard:hover{border-color:var(--gb4);transform:translateY(-3px)}
.pico{font-size:32px;margin-bottom:14px}
.pt{font-family:var(--fh);font-size:23px;font-weight:500;color:var(--cr);margin-bottom:8px}
.pd{font-size:12.5px;font-weight:300;color:var(--cr3);line-height:1.75;margin-bottom:18px}
.lform{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.lf{width:100%;padding:11px 13px;background:var(--bk3);border:1px solid var(--gb);font-family:var(--fb);font-size:12px;color:var(--cr);outline:none;transition:border-color .25s}
.lf:focus{border-color:var(--gb4)}
.lf::placeholder{color:var(--cr4)}
.ls{width:100%;padding:12px;border:none;background:var(--gold);font-family:var(--fb);font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--bk);cursor:pointer;transition:all .3s}
.ls:hover{box-shadow:0 4px 20px rgba(201,168,76,.35)}
.pl{display:inline-block;font-family:var(--fb);font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--g3);text-decoration:none;cursor:pointer;padding:11px 0}
.pl:hover{color:var(--g4)}
.pn{font-size:11px;font-weight:300;color:var(--cr4);line-height:1.6}
.pn span{color:var(--g3);cursor:pointer}
.pn span:hover{color:var(--g4)}

/* ============ FOOTER ============ */
footer{background:var(--bk);border-top:1px solid var(--gb);padding:60px 48px 30px}
.fw{max-width:1200px;margin:0 auto}
.fc-brand{font-family:var(--fh);font-size:26px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--cr)}
.fc-tag{font-family:var(--fm);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--g3);margin-top:6px}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px}
.fdesc{font-size:12.5px;font-weight:300;color:var(--cr3);line-height:1.85;max-width:320px}
.fch{font-family:var(--fm);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--g3);margin-bottom:16px}
.flinks{list-style:none;display:flex;flex-direction:column;gap:10px}
.flinks a{font-size:12.5px;font-weight:300;color:var(--cr3);text-decoration:none;transition:color .25s}
.flinks a:hover{color:var(--g4)}
.fbot{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:36px;padding-top:24px;border-top:1px solid var(--gb);flex-wrap:wrap}
.fcopy{font-size:11px;font-weight:300;color:var(--cr4)}
.faddr{font-style:normal;font-size:12.5px;font-weight:300;color:var(--cr3);line-height:1.85;margin-top:16px}
.faddr a{color:var(--g4);text-decoration:none}
.faddr a:hover{text-decoration:underline}
.flegal{display:flex;flex-wrap:wrap;gap:18px}
.flegal a{font-size:11.5px;letter-spacing:.5px;color:var(--cr3);text-decoration:none;transition:color .25s}
.flegal a:hover{color:var(--g4)}

/* ============ MODAL ============ */
.mover{position:fixed;inset:0;z-index:1000;background:rgba(5,5,5,.9);backdrop-filter:blur(12px);display:none;align-items:flex-start;justify-content:center;overflow-y:auto;padding:60px 22px}
.mover.show{display:flex}
.mbox{background:var(--bk2);border:1px solid var(--gb3);width:100%;max-width:440px;margin:auto;padding:40px 38px;position:relative;box-shadow:0 40px 100px rgba(0,0,0,.85)}
.mbox::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold)}
.mclose{position:absolute;top:16px;right:16px;width:32px;height:32px;border:1px solid var(--gb3);background:transparent;color:var(--cr3);font-size:13px;cursor:pointer;transition:all .3s}
.mclose:hover{border-color:var(--gb4);color:var(--g4)}
.mlbl{font-family:var(--fm);font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--g3);margin-bottom:10px}
.mtit{font-family:var(--fh);font-size:30px;font-weight:500;color:var(--cr);margin-bottom:6px}
.msub{font-size:12px;font-weight:300;color:var(--cr3);margin-bottom:22px}
.mtabs{display:flex;gap:0;margin-bottom:22px;border:1px solid var(--gb3)}
.mtab{flex:1;padding:11px;background:transparent;border:none;font-family:var(--fb);font-size:10px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--cr3);cursor:pointer;transition:all .3s}
.mtab.on{background:var(--gb);color:var(--g4)}
.mi{width:100%;padding:13px 14px;margin-bottom:11px;background:var(--bk3);border:1px solid var(--gb);border-radius:7px;font-family:var(--fb);font-size:13px;color:var(--cr);outline:none;transition:border-color .25s}
.mi:focus{border-color:var(--gb4)}
.mi::placeholder{color:var(--cr4)}
.msbmt{width:100%;padding:14px;border:none;background:var(--gold);font-family:var(--fb);font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--bk);cursor:pointer;transition:all .3s;margin-top:4px}
.msbmt:hover{box-shadow:0 6px 24px rgba(201,168,76,.4)}
.mnote{font-size:11px;font-weight:300;color:var(--cr4);line-height:1.7;margin-top:14px;text-align:center}
.mnote a{color:var(--g3)}
.mnote strong{color:var(--cr2);font-weight:400}

/* ============ MOBILE MENU ============ */
#mob-menu{display:none;position:fixed;inset:0;z-index:900;background:rgba(7,7,7,.97);backdrop-filter:blur(14px);flex-direction:column;align-items:center;justify-content:center;gap:0}
#mob-menu.open{display:flex}
#mob-menu::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gold)}
#mob-menu a{font-family:var(--fh);font-size:26px;font-weight:400;color:var(--cr);letter-spacing:.5px;text-decoration:none;padding:13px 40px;transition:color .2s;width:100%;text-align:center;border-bottom:1px solid var(--gb)}
#mob-menu a:hover{color:var(--g4)}
.mob-close{position:absolute;top:20px;right:20px;width:38px;height:38px;border:1px solid var(--gb3);background:transparent;color:var(--g3);font-size:18px;cursor:pointer}

/* ============ TOAST ============ */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(90px);background:var(--bk2);border:1px solid var(--gb3);padding:14px 30px;font-family:var(--fb);font-size:12px;font-weight:300;color:var(--g4);letter-spacing:.4px;box-shadow:0 14px 40px rgba(0,0,0,.7);z-index:1100;transition:transform .4s;white-space:nowrap;max-width:90vw}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ============ RESPONSIVE ============ */
@media(max-width:960px){
  .nlinks{display:none}
  .nact .btn-gs{display:none}
  .hamburger{display:flex}
  #nav{padding:0 22px}
  .sec,.hero,.port-sec,footer{padding-left:22px;padding-right:22px}
  .demo-wrap,.tl-wrap,.contact-wrap,.wgrid2{grid-template-columns:1fr}
  .proc-grid,.pgrid,.news-grid,.dgrid,.pgrid2{grid-template-columns:1fr}
  .tl-rcard{position:static}
  .fgrid{grid-template-columns:1fr 1fr;gap:28px}
  .hero{padding-top:120px}
}
@media(max-width:560px){
  .dbody{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .fbot{flex-direction:column;align-items:flex-start}
  .sec{padding:64px 20px}
}


/* ===== Ported passport+verifier section layout ===== */
.ppx-sec{background:var(--bk);padding:34px 48px 86px;border-bottom:1px solid var(--gb)}
.ppx-head{text-align:center;max-width:680px;margin:0 auto 38px}
.ppx{max-width:1120px;margin:0 auto;font-family:'Inter','Jost',system-ui,sans-serif}
.ppx-stage{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;margin-bottom:50px}
.ppx-verify{max-width:600px;margin:0 auto}
@media(max-width:900px){.ppx-stage{grid-template-columns:1fr;gap:34px}.ppx-sec{padding:24px 20px 64px}}


/* ===== Hero 2-column: headline left, live passport right ===== */
.hi-split{display:grid;grid-template-columns:1.04fr .96fr;gap:48px;align-items:center;text-align:left;max-width:1240px}
.hi-left .hover{justify-content:flex-start}
.hi-left .hero-lead{margin:0 0 30px;max-width:560px}
.hi-left .hbtns{justify-content:flex-start;margin-bottom:0}
.hi-right{position:relative;min-width:0;display:flex;flex-direction:column;align-items:center;gap:16px}
.hi-right .tag-demo{max-width:100%}
.hero:has(.hi-split){padding-top:120px;padding-bottom:64px}
@media(max-width:960px){
  .hi-split{grid-template-columns:1fr;text-align:center;gap:34px}
  .hi-left .hover{justify-content:center}
  .hi-left .hero-lead{margin:0 auto 30px}
  .hi-left .hbtns{justify-content:center}
}


/* lead + CTAs moved below the hero split (full width, centered) */
.hi-below{grid-column:1 / -1;text-align:center;margin-top:26px}
.hi-below .hero-lead{margin:0 auto 24px;max-width:760px}
.hi-below .hbtns{justify-content:center;margin-bottom:0}

/* Hero: centered single column — eyebrow on top, passport centered, lead+CTAs below */
.hi-split{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;max-width:920px}
.hi-left{display:flex;flex-direction:column;align-items:center;width:100%}
.hi-left .hover{justify-content:center}
.hi-right{width:100%;align-items:center}
.hi-below{margin-top:10px}


/* === Hero FINAL: desktop = text left / passport right · mobile = stacked === */
.hi-split{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;text-align:left;max-width:1200px}
.hi-left{display:flex;flex-direction:column;align-items:flex-start}
.hi-left .hover{justify-content:flex-start}
.hi-left .hero-lead{margin:24px 0 28px;max-width:520px}
.hi-left .hbtns{justify-content:flex-start;margin-bottom:0}
.hi-right{width:auto;align-items:center;justify-self:center}
@media(max-width:900px){
  .hi-split{grid-template-columns:1fr;text-align:center;gap:32px;max-width:600px}
  .hi-left{align-items:center;order:2}
  .hi-left .hover{justify-content:center}
  .hi-left .hero-lead{margin:18px auto 26px}
  .hi-left .hbtns{justify-content:center}
  .hi-right{order:1}
}


/* === Hero ONE-SCREEN flow: cloth (left) · tap (mid) · passport (right), text below === */
.hero:has(.hero-flow){padding-top:100px;padding-bottom:46px}
.hero-flow{display:flex;flex-direction:column;align-items:center;text-align:center;gap:20px;max-width:1200px;margin:0 auto}
.hero-flow .hover{justify-content:center;margin-bottom:0}
.flow-row{display:flex;align-items:center;justify-content:center;gap:26px;width:100%;flex-wrap:nowrap}
.flow-row .tag-demo{flex:0 1 440px;max-width:440px}
.flow-below{max-width:760px}
.flow-below .hero-lead{margin:0 auto 20px;max-width:680px}
.flow-below .hbtns{justify-content:center;margin-bottom:0}
@media(max-width:900px){
  .hero:has(.hero-flow){padding-top:96px}
  .flow-row{flex-direction:column;gap:18px}
  .flow-row .tag-demo{flex:0 1 auto;max-width:100%}
}

/* Hero height -10% (passport row scaled + tighter padding/gaps) */
.hero:has(.hero-flow){padding-top:86px;padding-bottom:38px}
.hero-flow{gap:16px}
.flow-row{zoom:.9}
@media(max-width:900px){.hero:has(.hero-flow){padding-top:84px}.flow-row{zoom:1}}

/* Hide the outer box around cloth + tap (.tag-demo) — keep contents */
.flow-row.ppx .tag-demo,
.flow-row.ppx .tag-demo:hover{border-color:transparent;background:transparent;box-shadow:none;transform:none}
.flow-row.ppx .tag-demo::before{display:none}

/* Garment (cloth) box +20% */
.flow-row.ppx .tag-photo{width:454px;height:335px}
@media(max-width:560px){.flow-row.ppx .tag-photo{width:min(454px,86vw);height:auto;aspect-ratio:454 / 335}}

/* Separate "Tap here to scan" from the passport (keep it centered, not merged) */
.flow-row{gap:64px}
.flow-row .tag-demo{margin-right:8px}
@media(max-width:900px){.flow-row{gap:24px}.flow-row .tag-demo{margin-right:0}}

/* Keep the trailing arrow to the RIGHT of the tap circle (not below) */
.flow-row.ppx .tag-demo{flex-wrap:nowrap}
.flow-row.ppx .tag-cta{flex:0 0 auto}
.flow-row.ppx .tag-arrow-end{flex:none;align-self:center}

/* Hero height -20% more */
.flow-row{zoom:.72}
@media(max-width:900px){.flow-row{zoom:1}}
.hero:has(.hero-flow){padding-top:68px;padding-bottom:30px}

/* First screen fills exactly the device viewport (100%) */
.hero:has(.hero-flow){
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  align-items:center;
  padding-top:84px;
  padding-bottom:36px;
}

/* ===== Every section fills the device viewport (same ratio as hero) ===== */
html{scroll-snap-type:y proximity;scroll-padding-top:68px}
.hero{scroll-snap-align:start}
.sec,.ppx-sec,.port-sec{
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  scroll-snap-align:start;
}
@media(max-width:560px){
  .sec,.ppx-sec,.port-sec{min-height:100svh}
}


/* DPP Live ported pages (timeline, how-it-works) — full viewport */
.ppx-page{min-height:100dvh;display:flex;flex-direction:column;scroll-snap-align:start}
.ppx-page > section{flex:1 0 auto;width:100%}

/* Hide the faint golden boundary on the first page (hero) */
.hero:has(.hero-flow){border-bottom:none}

/* Remove the box/border framing cloth + tap + passport */
.hero-flow .flow-row{border:0!important;outline:0!important;box-shadow:none!important;background:transparent!important}
.flow-row.ppx .tag-demo,
.flow-row.ppx .tag-demo:hover,
.flow-row.ppx .tag-demo:focus,
.flow-row.ppx .tag-demo:focus-visible{border:0!important;outline:0!important;box-shadow:none!important;background:transparent!important}

/* Remove hero vertical gold lines */
.hr1,.hr2,.hr3{display:none!important}

/* ===== Add depth & subtle colour variety (less flat navy) ===== */
/* Hero: dual glow — warm gold + soft EU blue */
.hbg{background:
  radial-gradient(ellipse 60% 55% at 28% 6%, rgba(201,168,76,.15), transparent 60%),
  radial-gradient(ellipse 62% 58% at 84% 96%, rgba(56,104,196,.16), transparent 62%) !important}

/* Dark sections: faint top sheen, alternating cool/warm for rhythm */
.sec.dk{background:var(--bk1) radial-gradient(120% 65% at 50% 0%, rgba(120,160,230,.06), transparent 58%)}
.sec.dk2{background:var(--bk) radial-gradient(120% 65% at 50% 0%, rgba(201,168,76,.05), transparent 58%)}
.port-sec{background:var(--bk1) radial-gradient(120% 60% at 50% 100%, rgba(56,104,196,.07), transparent 60%)}
.ppx-sec{background:var(--bk) radial-gradient(110% 60% at 50% 0%, rgba(201,168,76,.05), transparent 55%)}

/* Body underlay so any gaps read as depth, not flat */
body{background:
  radial-gradient(130% 90% at 50% -8%, #0e2748 0%, transparent 52%),
  #081323}

/* ===== Premium white + navy refinement ===== */
:root{
  --paper:#ffffff;          /* crisp white */
  --paper2:#eef3fb;         /* soft cool white */
  --line:#dbe3ee;           /* clean navy-tint hairline */
}
/* Light sections: airy white, navy text, premium card polish */
.sec.wh{background:#ffffff}
.sec.wh2{background:#eef3fb}
.wcard,.faq-item,.pc,.news-card,.demo-controls{
  background:#fff;
  border:1px solid #e4eaf3;
  box-shadow:0 1px 2px rgba(15,37,64,.04), 0 14px 38px -22px rgba(15,37,64,.22);
}
.wcard:hover,.pc:hover{box-shadow:0 2px 4px rgba(15,37,64,.05),0 22px 50px -24px rgba(15,37,64,.30)}

/* Dark sections: restrained, classy sheen (less coloured/muddy) */
.sec.dk{background:var(--bk1) radial-gradient(120% 60% at 50% 0%, rgba(255,255,255,.035), transparent 60%)}
.sec.dk2{background:var(--bk) radial-gradient(120% 60% at 50% 0%, rgba(255,255,255,.028), transparent 60%)}
.ppx-sec{background:var(--bk) radial-gradient(110% 55% at 50% 0%, rgba(255,255,255,.03), transparent 58%)}
.port-sec{background:var(--bk1)}
.hbg{background:
  radial-gradient(ellipse 58% 52% at 30% 6%, rgba(201,168,76,.10), transparent 60%),
  radial-gradient(ellipse 64% 58% at 82% 96%, rgba(70,120,210,.12), transparent 62%) !important}
body{background:radial-gradient(130% 90% at 50% -10%, #0c2240 0%, transparent 55%), #081222}
/* ===== How-it-works Step 1: big holographic supply-chain → next-step QR flow ===== */
.ppx .hiw-flow{position:relative}
.fviz{position:absolute;top:0;left:0;right:auto;bottom:auto;width:53%;height:100%;
  pointer-events:none;opacity:0;transition:opacity .45s ease;z-index:8}
.hiw-flow.fv-on .fviz{opacity:1}
.fviz-svg{width:100%;height:100%;overflow:visible}

/* flow lines (4 stacked boxes -> next step QR) */
.fv-path{fill:none;stroke:rgba(0,196,140,.16);stroke-width:1.6}
.fv-flow{fill:none;stroke:#00C48C;stroke-width:2.6;stroke-dasharray:5 16;stroke-linecap:round;opacity:0;
  filter:drop-shadow(0 0 5px rgba(0,196,140,.6))}
.hiw-flow.fv-on .fv-flow{opacity:.92;animation:fvDash 1.05s linear infinite}
@keyframes fvDash{to{stroke-dashoffset:-42}}
.fv-dot{fill:#bff8e3;filter:drop-shadow(0 0 6px rgba(0,196,140,.9))}

/* 4 equal stacked source boxes — Iron-Man staggered slide-in */
.fv-box{opacity:0;transform:translateX(-26px) scale(.92);transform-origin:left center;transform-box:fill-box}
.hiw-flow.fv-on .fv-box{animation:fvBoxIn .5s cubic-bezier(.2,.9,.2,1) forwards}
.hiw-flow.fv-on .fv-box.b2{animation-delay:.1s}
.hiw-flow.fv-on .fv-box.b3{animation-delay:.2s}
.hiw-flow.fv-on .fv-box.b4{animation-delay:.3s}
@keyframes fvBoxIn{0%{opacity:0;transform:translateX(-26px) scale(.92)}60%{opacity:1;transform:translateX(0) scale(1.03)}100%{opacity:1;transform:translateX(0) scale(1)}}
.fv-rect{fill:rgba(8,24,42,.94);stroke:rgba(0,196,140,.55);stroke-width:1.6}
.hiw-flow.fv-on .fv-rect{animation:fvRing 2.4s ease-in-out infinite}
@keyframes fvRing{0%,100%{stroke:rgba(0,196,140,.5)}50%{stroke:rgba(0,196,140,.95)}}
.fv-bico{font-size:26px;text-anchor:middle}
.fv-bt{fill:#eafff7;font:600 15px 'Jost',sans-serif;letter-spacing:.02em}
.fv-bs{fill:rgba(180,232,212,.78);font:400 11px 'JetBrains Mono',monospace}

/* next-step QR target */
.fv-qr{fill:rgba(0,196,140,.10);stroke:#00C48C;stroke-width:1.8}
.hiw-flow.fv-on .fv-qr{animation:fvGlow 1.6s ease-in-out infinite}
@keyframes fvGlow{0%,100%{filter:drop-shadow(0 0 3px rgba(0,196,140,.45))}50%{filter:drop-shadow(0 0 16px rgba(0,196,140,.85))}}
.fv-qrpix{fill:#7df1c4;opacity:0}
.hiw-flow.fv-on .fv-qrpix{animation:fvFade .4s .55s forwards}
@keyframes fvFade{to{opacity:.92}}
.fv-qrlbl{text-anchor:middle;fill:#bff8e3;font:600 11px 'JetBrains Mono',monospace;letter-spacing:.14em}
@media(prefers-reduced-motion:reduce){.fv-flow,.fv-rect,.fv-qr{animation:none}}
@media(max-width:900px){.fviz{width:100%}}

/* On hover, slide Step 1's form box aside so the 4 source boxes are visible */
.fviz{width:62%}
.hiw-flow .fv-s1 .hiw-vis{transition:transform .45s ease,opacity .45s ease,filter .45s ease}

.hiw-flow.fv-on .fv-s1 .hiw-steplabel,.hiw-flow.fv-on .fv-s1 h3,.hiw-flow.fv-on .fv-s1 p{opacity:.25;transition:opacity .4s ease}

/* CSS-only fallback trigger (works even if JS is blocked) */
.hiw-flow:has(.fv-s1:hover) .fviz{opacity:1}
.hiw-flow:has(.fv-s1:hover) .fv-flow{opacity:.92;animation:fvDash 1.05s linear infinite}
.hiw-flow:has(.fv-s1:hover) .fv-box{animation:fvBoxIn .5s cubic-bezier(.2,.9,.2,1) forwards}
.hiw-flow:has(.fv-s1:hover) .fv-box.b2{animation-delay:.1s}
.hiw-flow:has(.fv-s1:hover) .fv-box.b3{animation-delay:.2s}
.hiw-flow:has(.fv-s1:hover) .fv-box.b4{animation-delay:.3s}
.hiw-flow:has(.fv-s1:hover) .fv-rect{animation:fvRing 2.4s ease-in-out infinite}
.hiw-flow:has(.fv-s1:hover) .fv-qr{animation:fvGlow 1.6s ease-in-out infinite}
.hiw-flow:has(.fv-s1:hover) .fv-qrpix{animation:fvFade .4s .55s forwards}


/* full-width overlay so the wide flow-viz renders big */
.fviz{width:100%}


/* Step 1 shrinks + slides left so the 4 boxes are the focus; flow enters Step 2's real QR */
.hiw-flow .fv-s1 .hiw-vis{transition:transform .55s cubic-bezier(.2,.8,.2,1),opacity .5s ease,filter .5s ease}
.hiw-flow.fv-on .fv-s1 .hiw-vis,
.hiw-flow:has(.fv-s1:hover) .fv-s1 .hiw-vis{transform:scale(.46) translateX(-46%);transform-origin:left top;opacity:.16;filter:blur(1px)}
/* glow target where flow enters Step 2's QR */
.fv-target{opacity:0}
.hiw-flow.fv-on .fv-target,.hiw-flow:has(.fv-s1:hover) .fv-target{opacity:1}
.fv-tring{fill:none;stroke:#00C48C;stroke-width:2.2}
.hiw-flow.fv-on .fv-tring,.hiw-flow:has(.fv-s1:hover) .fv-tring{animation:fvT 1.5s ease-out infinite}
@keyframes fvT{0%{r:8;opacity:.9}100%{r:30;opacity:0}}
.fv-tdot{fill:#aef7dd;filter:drop-shadow(0 0 8px rgba(0,196,140,.9))}

/* ===== Flow-viz v2: real HTML boxes (no SVG clipping) ===== */
.fviz{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:0;transition:opacity .45s ease;z-index:8}
.hiw-flow.fv-on .fviz,.hiw-flow:has(.fv-s1:hover) .fviz{opacity:1}
.fv-lines{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.fv-path{fill:none;stroke:rgba(0,196,140,.18);stroke-width:1.6;vector-effect:non-scaling-stroke}
.fv-flow{fill:none;stroke:#00C48C;stroke-width:2.4;stroke-dasharray:5 13;stroke-linecap:round;vector-effect:non-scaling-stroke;opacity:0;filter:drop-shadow(0 0 4px rgba(0,196,140,.6))}
.hiw-flow.fv-on .fv-flow,.hiw-flow:has(.fv-s1:hover) .fv-flow{opacity:.9;animation:fvDash 1s linear infinite}
@keyframes fvDash{to{stroke-dashoffset:-36}}
.fv-tring{fill:none;stroke:#00C48C;stroke-width:2;vector-effect:non-scaling-stroke}
.hiw-flow.fv-on .fv-tring,.hiw-flow:has(.fv-s1:hover) .fv-tring{animation:fvT 1.5s ease-out infinite}
@keyframes fvT{0%{r:1.2;opacity:.9}100%{r:5;opacity:0}}
.fv-tdot{fill:#aef7dd;filter:drop-shadow(0 0 6px rgba(0,196,140,.9))}

/* Supply chain shown as ONE box (V3 stacked) — rows inside a single container */
.fv-col{position:absolute;left:1%;top:50%;transform:translateY(-50%);width:23%;display:flex;flex-direction:column;gap:0;
  background:rgba(8,24,42,.97);border:1.5px solid rgba(0,196,140,.55);border-radius:16px;
  padding:9px 12px 10px;box-shadow:0 18px 40px -16px rgba(0,0,0,.7);overflow:hidden}
.fv-col::before{content:"YOUR SUPPLY CHAIN";display:block;font:700 9px 'JetBrains Mono',monospace;
  letter-spacing:.14em;color:rgba(95,233,192,.95);padding:1px 2px 8px}
.fv-bx{display:flex;align-items:center;gap:11px;padding:7px 2px;border-radius:0;
  background:transparent;border:0;border-bottom:1px solid rgba(0,196,140,.16);
  box-shadow:none;opacity:0;transform:translateX(-20px) scale(.92)}
.fv-bx:last-child{border-bottom:0}
.hiw-flow.fv-on .fv-bx,.hiw-flow:has(.fv-s1:hover) .fv-bx{animation:fvBxIn .5s cubic-bezier(.2,.9,.2,1) forwards}
.hiw-flow.fv-on .fv-bx.b2,.hiw-flow:has(.fv-s1:hover) .fv-bx.b2{animation-delay:.1s}
.hiw-flow.fv-on .fv-bx.b3,.hiw-flow:has(.fv-s1:hover) .fv-bx.b3{animation-delay:.2s}
.hiw-flow.fv-on .fv-bx.b4,.hiw-flow:has(.fv-s1:hover) .fv-bx.b4{animation-delay:.3s}
@keyframes fvBxIn{0%{opacity:0;transform:translateX(-26px) scale(.92)}60%{opacity:1;transform:translateX(0) scale(1.03)}100%{opacity:1;transform:translateX(0) scale(1)}}
.hiw-flow.fv-on .fv-bx,.hiw-flow:has(.fv-s1:hover) .fv-bx{animation-fill-mode:forwards}
.fv-i{font-size:18px;line-height:1;flex-shrink:0}
.fv-tx{display:flex;flex-direction:row;align-items:center;flex:1;gap:8px;line-height:1.2}
.fv-tx b{font:600 13px 'Jost',sans-serif;color:#eafff7}
.fv-tx i{font:400 9.5px 'JetBrains Mono',monospace;color:rgba(180,232,212,.78);font-style:normal;margin-left:auto;white-space:nowrap}
@media(max-width:900px){.fv-col{width:60%;left:6%}}

/* Step 1's visual IS the supply-chain box (in-flow). Form kept as a hidden driver. */
/* supply-chain box → step 2 flow lines re-aimed; fviz overlay visible again */
.hiw-flow.fv-on .fv-s1 .hiw-vis,
.hiw-flow:has(.fv-s1:hover) .fv-s1 .hiw-vis{opacity:1;transform:none;filter:none}
.hiw-vis-supply{padding:9px;overflow:hidden;display:flex;align-items:stretch;gap:8px;background:none;border:none;box-shadow:none}
.hiw-vis-supply .fv-col{position:relative;left:auto;top:auto;transform:none;flex:1;width:auto;max-width:none;margin:0;z-index:2}
.fv-s1 .hiw-vis-supply .hiw-driver{position:absolute;inset:0;width:auto;height:auto;opacity:0;pointer-events:none}
/* left data panel — surfaces the hovered/cycled stage's data in the small space */
.s1-data{flex:0 0 43%;min-width:0;display:flex;flex-direction:column;background:rgba(8,24,42,.55);border:1px solid rgba(0,196,140,.25);border-radius:10px;padding:8px 9px;overflow:hidden}
.s1-data-h{font:700 8px 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:#5fe9c0;margin-bottom:7px}
.s1-line{display:flex;flex-direction:column;padding:3px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.s1-line .k{font:400 8px 'JetBrains Mono',monospace;color:rgba(180,232,212,.65);letter-spacing:.04em}
.s1-line .v{font:600 10.5px 'Inter',sans-serif;color:#eafff7}
.s1-line .v.cur::after{content:"\25AE";color:#00C48C;animation:s1blink 1s step-end infinite;margin-left:1px}
@keyframes s1blink{50%{opacity:0}}
.fv-s1 .fv-bx{cursor:pointer;padding:5px 7px}
.fv-s1 .fv-bx.on{background:rgba(0,196,140,.12)}
.fv-s1 .fv-i{font-size:15px}
.fv-s1 .fv-tx{flex-direction:column;align-items:flex-start;gap:0}
.fv-s1 .fv-tx b{font-size:11px}
.fv-s1 .fv-tx i{font-size:8px;margin:0}
.hiw-flow.fv-on .fv-s1 .hiw-steplabel,
.hiw-flow.fv-on .fv-s1 .hiw-eyebrow,
.hiw-flow.fv-on .fv-s1 .hiw-node,
.hiw-flow.fv-on .fv-s1 h3,
.hiw-flow.fv-on .fv-s1 p{opacity:1}

/* ===== Step 1 wide featured: 4 supply-chain stages → passport ===== */
.hiw-flow .fviz{display:none}
.hiw-flow .fv-s1{display:block;text-align:left;background:linear-gradient(180deg,rgba(0,196,140,.05),rgba(8,24,42,0));border:1px solid rgba(0,196,140,.2);border-radius:20px;padding:20px 26px}
.fv-s1 .s1-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.fv-s1 .s1-head .hiw-node{margin:0;flex:none}
.fv-s1 .s1-head-tx{display:flex;flex-direction:column;align-items:flex-start}
.fv-s1 .s1-head h3{margin:2px 0 0}
.fv-s1 .hiw-eyebrow{margin:0}
.fv-s1 > p{margin:16px 0 0;max-width:none}
.s1-diagram{position:relative;width:680px;max-width:100%;height:300px;margin:0 auto}
.s1-conn{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}
.s1-cline{fill:none;stroke:rgba(0,196,140,.18);stroke-width:1.6;vector-effect:non-scaling-stroke}
.s1-cflow{fill:none;stroke:#00C48C;stroke-width:2.4;stroke-dasharray:4 10;opacity:0;vector-effect:non-scaling-stroke;filter:drop-shadow(0 0 4px rgba(0,196,140,.6));transition:opacity .2s}
.s1-cflow.on{opacity:.95;animation:s1dash .7s linear infinite}
@keyframes s1dash{to{stroke-dashoffset:28}}
.s1-cdot{r:4.5;fill:#aef7dd;opacity:0;filter:drop-shadow(0 0 6px rgba(0,196,140,1))}
.s1-cdot.on{opacity:1}
.s1-stage{position:absolute;left:0;width:170px;height:60px;display:flex;align-items:center;gap:10px;padding:0 13px;box-sizing:border-box;border:1px solid rgba(0,196,140,.3);border-radius:12px;background:rgba(8,24,42,.96);cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s;z-index:2}
.s1-stage.on{border-color:var(--green);transform:translateX(4px);box-shadow:0 8px 20px -8px rgba(0,196,140,.5)}
.s1-stage .ic{font-size:19px;flex:none}
.s1-stage .tx{display:flex;flex-direction:column;line-height:1.25;min-width:0}
.s1-stage .tx b{font:600 13.5px 'Jost',sans-serif;color:#eafff7}
.s1-stage .tx i{font:400 10px 'JetBrains Mono',monospace;font-style:normal;color:rgba(180,232,212,.7);margin-top:1px}
.s1-pass{position:absolute;right:0;top:0;width:280px;height:300px;border:1.5px solid rgba(0,196,140,.3);border-radius:16px;background:rgba(8,24,42,.6);box-sizing:border-box;z-index:1}
.s1-pass-h{position:absolute;top:0;left:0;right:0;height:30px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-bottom:1px solid rgba(0,196,140,.2);font:700 9px 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:#5fe9c0}
.s1-pass-f{position:absolute;bottom:0;left:0;right:0;height:26px;display:flex;align-items:center;justify-content:center;gap:6px;font:700 9px 'JetBrains Mono',monospace;letter-spacing:.08em;color:#5fe9c0;border-top:1px solid rgba(0,196,140,.2)}
.s1-pin{position:absolute;right:16px;width:248px;height:56px;display:flex;flex-direction:column;justify-content:center;gap:2px;padding:0 13px;box-sizing:border-box;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:rgba(8,24,42,.85);transition:border-color .2s,transform .2s;z-index:2}
.s1-pin.on{border-color:var(--green);transform:translateX(-4px)}
.s1-pin .hd{font:700 8px 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:#5fe9c0;margin-bottom:1px}
.s1-pin .row{display:flex;justify-content:space-between;gap:10px}
.s1-pin .row .k{font:400 10px 'Inter',sans-serif;color:rgba(180,232,212,.7)}
.s1-pin .row .v{font:600 11.5px 'JetBrains Mono',monospace;color:#eafff7}
.fv-s1 .stage-inner.hiw-driver{position:absolute !important;inset:0;width:auto;height:auto;opacity:0;pointer-events:none;overflow:hidden}
@media(max-width:760px){.s1-diagram{transform:scale(.62);transform-origin:top center;margin-bottom:-110px}}

/* ===== Under-hero bands: EU requirements checklist + Trusted-by ===== */
.eureq{background:var(--bk1);padding:56px 48px;border-top:1px solid var(--gb);border-bottom:1px solid var(--gb)}
.band-wrap{max-width:1120px;margin:0 auto}
.band-lbl{display:block;text-align:center;font-family:var(--fm);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--g3);margin-bottom:26px}
.eureq-list{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:12px 14px;padding:0}
.eureq-list li{display:inline-flex;align-items:center;gap:9px;font-size:13.5px;font-weight:300;color:var(--cr2);padding:9px 16px;border:1px solid var(--gb);border-radius:99px;background:rgba(255,255,255,.02)}
.eureq-list .chk{width:19px;height:19px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(0,196,140,.15);color:#5fe9c0;font-size:11px;flex-shrink:0}

.trusted{background:var(--bk);padding:42px 48px 52px}
.trusted-lbl{text-align:center;font-family:var(--fm);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--cr4);margin-bottom:24px}
.trusted-logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:18px 42px}
.trusted-logos span{font-family:var(--fh);font-size:25px;font-weight:600;letter-spacing:1px;color:var(--cr3);opacity:.55;transition:opacity .3s,color .3s}
.trusted-logos span:hover{opacity:1;color:var(--cr)}
@media(max-width:560px){.eureq,.trusted{padding-left:20px;padding-right:20px}.trusted-logos{gap:14px 26px}.trusted-logos span{font-size:18px}}

/* ===== Compact under-hero strips (inside hero, fits in 100vh) ===== */
.hero-foot{max-width:1080px;margin:26px auto 0;padding:0 12px}
.hero-foot .eureq-list{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:7px 8px;padding:0;margin:0 0 16px}
.hero-foot .eureq-list li{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:300;color:var(--cr2);padding:5px 11px;border:1px solid var(--gb);border-radius:99px;background:rgba(255,255,255,.02);white-space:nowrap}
.hero-foot .eureq-list .chk{width:14px;height:14px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(0,196,140,.15);color:#5fe9c0;font-size:9px;flex-shrink:0}
.hero-foot .trusted-row{text-align:center;border-top:1px solid var(--gb);padding-top:14px}
.hero-foot .trusted-lbl{display:block;font-family:var(--fm);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--cr4);margin-bottom:9px}
.hero-foot .trusted-logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:9px 24px}
.hero-foot .trusted-logos span{font-family:var(--fh);font-size:17px;font-weight:600;letter-spacing:.5px;color:var(--cr3);opacity:.5;transition:opacity .3s,color .3s}
.hero-foot .trusted-logos span:hover{opacity:1;color:var(--cr)}
@media(max-width:560px){.hero-foot{margin-top:18px}.hero-foot .eureq-list li{font-size:10px;padding:4px 9px}.hero-foot .trusted-logos span{font-size:14px}.hero-foot .trusted-logos{gap:7px 15px}}

/* ===== Widen hero content left→right (reduce side gutters) ===== */
.hero:has(.hero-flow){padding-left:26px;padding-right:26px}
.hero-flow{max-width:1380px}
.flow-row{gap:128px}                 /* spread cloth · tap · passport wider */
.flow-below{max-width:1100px}
.flow-below .hero-lead{max-width:780px}
.hero-foot{max-width:1320px}
.hero-foot .eureq-list{gap:8px 10px}
@media(max-width:1100px){.hero-flow{max-width:96vw}}
@media(max-width:900px){.flow-row{gap:24px}.hero:has(.hero-flow){padding-left:18px;padding-right:18px}}

/* ===== Compress hero so Trusted-by fits inside 100vh ===== */
.hero:has(.hero-flow){padding-top:82px;padding-bottom:18px}
.hero-flow{gap:8px}
.flow-row{zoom:.6}                    /* shrink passport row to free vertical space */
.hero-foot{margin-top:8px}
.hero-foot .eureq-list{margin-bottom:9px;gap:6px 9px}
.hero-foot .eureq-list li{padding:4px 10px;font-size:10.5px}
.hero-foot .trusted-row{padding-top:9px}
.hero-foot .trusted-lbl{margin-bottom:7px}
.hero-foot .trusted-logos{gap:8px 22px}
.hero-foot .trusted-logos span{font-size:16px}
@media(max-width:900px){.flow-row{zoom:1}}

/* ===== hero-foot text bigger · passport row bigger · footer lower ===== */
.flow-row{zoom:.80}
@media(max-width:900px){.flow-row{zoom:1}}
.hero-foot{margin-top:22px}
.hero-foot .eureq-list li{font-size:11px;padding:5px 12px;gap:6px}
.hero-foot .eureq-list .chk{width:13px;height:13px;font-size:9px}
.hero-foot .eureq-list{gap:6px 9px;margin-bottom:10px}
.hero-foot .trusted-lbl{font-size:9px;letter-spacing:1.8px;margin-bottom:8px}
.hero-foot .trusted-logos{gap:8px 20px}
.hero-foot .trusted-logos span{font-size:15px}
@media(max-width:560px){.hero-foot .eureq-list li{font-size:10px}.hero-foot .trusted-logos span{font-size:12px}}
 