/* ============================================================
   ANVAYA — Landing page (dark, cinematic, operational)
   Brand: Quicksand · Anvaya light-blue (cyan) accent · teal "active"
   ============================================================ */

@font-face{font-family:'Quicksand';src:url('fonts/Quicksand-Light.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap;}
@font-face{font-family:'Quicksand';src:url('fonts/Quicksand-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'Quicksand';src:url('fonts/Quicksand-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:'Quicksand';src:url('fonts/Quicksand-SemiBold.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:'Quicksand';src:url('fonts/Quicksand-Bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap;}

:root{
  --bg:#0B0707;
  --bg-1:#120C0B;
  --bg-2:#181010;
  --bg-3:#1F1614;
  --panel:rgba(28,19,18,0.74);
  --line:rgba(230,96,84,0.11);
  --line-2:rgba(230,96,84,0.20);

  --ink-0:#F7F2EE;
  --ink-1:#C2B4AD;
  --ink-2:#8C7E78;
  --ink-3:#5E5450;

  --red:#E6493D;        /* Anvaya red — primary accent */
  --red-bright:#F47567;
  --red-deep:#B22A1E;
  --gold:#E3A857;        /* warm gold — live / active */
  --gold-bright:#F2C57C;
  --blue:#7A3B33;        /* deep clay */
  --amber:#E3A857;

  --font:'Quicksand','ui-rounded',system-ui,sans-serif;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--ink-0);
  font-family:var(--font);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  line-height:1.5;
}
::selection{background:rgba(230,73,61,.32);color:#fff;}

a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
canvas{display:block;}

/* page-wide subtle vignette + grain feel */
.bg-field{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(150,42,32,.20), transparent 60%),
    radial-gradient(90% 60% at 85% 110%, rgba(227,168,87,.06), transparent 55%);
}
.grid-lines{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:84px 84px;mask-image:radial-gradient(120% 100% at 50% 0%,#000,transparent 75%);}
#contours{position:fixed;inset:0;z-index:0;pointer-events:none;
  mask-image:linear-gradient(180deg,transparent 0,#000 14%,#000 86%,transparent 100%);
  animation:contourDrift 34s ease-in-out infinite alternate;}
#contours svg{width:100%;height:100%;display:block;}
@keyframes contourDrift{0%{transform:translate3d(0,0,0) scale(1.02)}100%{transform:translate3d(-1.4%,-2%,0) scale(1.06)}}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}

/* ---------- eyebrow / labels ---------- */
.eyebrow{font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--red);
  display:inline-flex;align-items:center;gap:10px;}
.eyebrow::before{content:"";width:22px;height:1px;background:linear-gradient(90deg,var(--red),transparent);}
.eyebrow.center::before{display:none;}
.mono{font-variant-numeric:tabular-nums;letter-spacing:.04em;}

/* ============================================================
   NAV
   ============================================================ */
header.nav{position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 36px;transition:background .4s var(--ease),border-color .4s,padding .4s;
  border-bottom:1px solid transparent;}
header.nav.scrolled{background:rgba(6,8,11,.72);backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--line);padding:12px 36px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:var(--logo-h,42px);width:auto;transition:height .25s var(--ease);}
.brand .word{font-weight:700;font-size:23px;letter-spacing:-.01em;color:var(--word,#CBC3BD);}
.navlinks{display:flex;align-items:center;gap:34px;}
.navlinks a{font-size:14.5px;font-weight:500;color:var(--ink-1);transition:color .2s;position:relative;}
.navlinks a:hover{color:var(--ink-0);}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-6px;height:1.5px;width:0;background:var(--red);transition:width .3s var(--ease);}
.navlinks a:hover::after{width:100%;}
.nav-right{display:flex;align-items:center;gap:18px;}
.lang{display:flex;align-items:center;gap:7px;font-size:13.5px;font-weight:500;color:var(--ink-1);cursor:pointer;}
.lang .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold);}

.btn{font-family:var(--font);font-weight:600;font-size:14.5px;cursor:pointer;border:none;
  border-radius:999px;padding:11px 22px;transition:transform .18s var(--ease),background .25s,box-shadow .25s,color .25s;
  display:inline-flex;align-items:center;gap:9px;white-space:nowrap;}
.btn:active{transform:translateY(1px) scale(.99);}
.btn-primary{background:var(--red);color:#FBEDE9;box-shadow:0 0 0 1px rgba(230,96,84,.4),0 8px 30px -8px rgba(230,96,84,.5);}
.btn-primary:hover{background:var(--red-bright);box-shadow:0 0 0 1px rgba(244,117,103,.6),0 10px 38px -8px rgba(230,96,84,.7);}
.btn-ghost{background:rgba(230,96,84,.04);color:var(--ink-0);box-shadow:inset 0 0 0 1px var(--line-2);}
.btn-ghost:hover{background:rgba(230,96,84,.10);box-shadow:inset 0 0 0 1px var(--red);}
.btn .arrow{transition:transform .25s var(--ease);}
.btn:hover .arrow{transform:translateX(3px);}
@media(max-width:1080px){.navlinks{display:none;}}

/* ============================================================
   HERO — agent wall
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;
  padding-top:90px;}
#agent-wall{position:absolute;inset:0;z-index:1;}
.agent-card{position:absolute;width:248px;border-radius:16px;
  background:linear-gradient(180deg,rgba(34,43,57,.97),rgba(19,25,35,.97));
  border:1px solid rgba(230,96,84,.30);padding:15px 16px 14px;
  box-shadow:0 26px 60px -24px rgba(0,0,0,.95),0 0 28px -10px rgba(230,96,84,.18),inset 0 1px 0 rgba(255,255,255,.07);
  backdrop-filter:blur(3px);will-change:transform,opacity;}
.agent-card .ac-top{display:flex;align-items:center;gap:10px;margin-bottom:11px;}
.ac-ico{width:34px;height:34px;border-radius:10px;flex:none;display:grid;place-items:center;
  background:rgba(230,96,84,.08);box-shadow:inset 0 0 0 1px var(--line-2);}
.ac-ico svg{width:18px;height:18px;stroke:var(--red);}
.ac-name{font-weight:600;font-size:14px;color:var(--ink-0);line-height:1.2;}
.ac-domain{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);margin-top:2px;}
.ac-task{font-size:12.5px;color:var(--ink-1);font-weight:400;line-height:1.45;min-height:34px;}
.ac-task b{color:var(--red);font-weight:600;}
.ac-foot{display:flex;align-items:center;justify-content:space-between;margin-top:12px;
  padding-top:11px;border-top:1px solid var(--line);}
.ac-status{display:flex;align-items:center;gap:7px;font-size:11.5px;font-weight:600;color:var(--gold-bright);letter-spacing:.02em;}
.ac-pulse{width:7px;height:7px;border-radius:50%;background:var(--gold);position:relative;}
.ac-pulse::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1px solid var(--gold);
  animation:pulse 2.2s var(--ease) infinite;}
@keyframes pulse{0%{transform:scale(.6);opacity:.9}80%,100%{transform:scale(1.9);opacity:0}}
.ac-prog{font-size:11px;color:var(--ink-2);font-variant-numeric:tabular-nums;}
.agent-card.highlight{border-color:var(--red);box-shadow:0 0 0 1px var(--red),0 30px 70px -24px rgba(230,96,84,.4);}

.hero-inner{position:relative;z-index:5;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 32px;
  text-align:center;pointer-events:none;}
.hero-veil{position:absolute;inset:0;z-index:3;pointer-events:none;
  background:radial-gradient(58% 52% at 50% 50%, rgba(6,8,11,.82) 0%, rgba(6,8,11,.42) 42%, rgba(6,8,11,0) 72%);}
.hero h1{font-weight:700;letter-spacing:-.03em;line-height:.96;
  font-size:clamp(44px,8.2vw,118px);color:var(--ink-0);text-wrap:balance;
  text-shadow:0 4px 60px rgba(6,8,11,.8);}
.hero h1 .grad{background:linear-gradient(180deg,#fff,var(--red));-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero .sub{margin:26px auto 0;max-width:680px;font-size:clamp(16px,1.5vw,20px);font-weight:400;color:var(--ink-1);text-wrap:pretty;line-height:1.6;}
.hero .cta-row{margin-top:36px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;pointer-events:auto;}
.hero .support{margin-top:26px;font-size:13.5px;color:var(--ink-2);display:flex;gap:10px;justify-content:center;align-items:center;flex-wrap:wrap;}
.hero .support .sep{width:4px;height:4px;border-radius:50%;background:var(--ink-3);}

.scroll-cue{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:6;
  display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--ink-2);font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;}
.scroll-cue .rail{width:1px;height:46px;background:linear-gradient(var(--red),transparent);position:relative;overflow:hidden;}
.scroll-cue .rail::after{content:"";position:absolute;top:0;left:0;width:100%;height:14px;background:var(--red);animation:drop 1.8s var(--ease) infinite;}
@keyframes drop{0%{transform:translateY(-16px);opacity:0}40%{opacity:1}100%{transform:translateY(46px);opacity:0}}
@media(max-height:780px){.scroll-cue{display:none;}}

/* orchestrating cursor */
#orch-cursor{position:absolute;z-index:4;width:22px;height:22px;pointer-events:none;left:0;top:0;
  transition:transform .9s var(--ease),opacity .4s;will-change:transform;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6));}
#orch-cursor .label{position:absolute;left:24px;top:8px;white-space:nowrap;font-size:11px;font-weight:600;
  background:var(--red);color:#FBEDE9;padding:3px 9px;border-radius:999px;letter-spacing:.02em;
  opacity:0;transition:opacity .3s;}
#orch-cursor.acting .label{opacity:1;}

/* ============================================================
   SECTION scaffolding
   ============================================================ */
section.block{position:relative;z-index:5;padding:140px 0;}
.section-head{max-width:780px;margin:0 auto 64px;text-align:center;}
.section-head.left{margin-left:0;text-align:left;}
.section-head h2{margin-top:20px;font-weight:700;letter-spacing:-.025em;line-height:1.04;
  font-size:clamp(34px,4.6vw,62px);color:var(--ink-0);text-wrap:balance;}
.section-head p{margin-top:22px;font-size:clamp(16px,1.4vw,19px);color:var(--ink-1);line-height:1.65;text-wrap:pretty;}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ============================================================
   NUSANTARA / GLOBE
   ============================================================ */
.nusantara{padding-top:60px;padding-bottom:60px;}
.globe-stage{position:relative;min-height:780px;display:flex;align-items:center;justify-content:center;}
#globe-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;}
.globe-stage .section-head{position:relative;z-index:4;pointer-events:none;}
.globe-stage .section-head h2{text-shadow:0 4px 50px rgba(6,8,11,.9);}

/* floating insight cards over globe */
.insight{position:absolute;z-index:3;border-radius:14px;padding:13px 15px;min-width:200px;
  background:var(--panel);border:1px solid var(--line-2);backdrop-filter:blur(8px);
  box-shadow:0 20px 50px -22px rgba(0,0,0,.85);will-change:transform;}
.insight .ins-top{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);}
.insight .ins-top .d{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold);}
.insight .ins-main{margin-top:7px;font-size:14.5px;font-weight:600;color:var(--ink-0);}
.insight .ins-sub{margin-top:3px;font-size:12px;color:var(--ink-1);}

.callouts{max-width:1080px;margin:54px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:18px;overflow:hidden;}
.callouts .co{background:var(--bg-1);padding:26px 26px;display:flex;align-items:flex-start;gap:14px;transition:background .3s;}
.callouts .co:hover{background:var(--bg-2);}
.co .co-ico{width:38px;height:38px;flex:none;border-radius:11px;display:grid;place-items:center;
  background:rgba(230,96,84,.07);box-shadow:inset 0 0 0 1px var(--line-2);}
.co .co-ico svg{width:20px;height:20px;stroke:var(--red);}
.co .co-t{font-weight:600;font-size:15.5px;color:var(--ink-0);line-height:1.3;}
.co .co-d{font-size:13px;color:var(--ink-2);margin-top:4px;line-height:1.45;}
@media(max-width:880px){.callouts{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.callouts{grid-template-columns:1fr;}}

/* ============================================================
   FLOW — scattered systems to work done
   ============================================================ */
.flow{display:grid;grid-template-columns:1fr auto 1.05fr auto 1fr;gap:0;align-items:stretch;margin-top:20px;}
.flow-col{display:flex;flex-direction:column;gap:12px;}
.flow-col .fc-label{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);margin-bottom:6px;}
.chip{border-radius:11px;padding:12px 15px;font-size:14px;font-weight:500;color:var(--ink-1);
  background:var(--bg-1);border:1px solid var(--line);display:flex;align-items:center;gap:10px;transition:.3s;}
.chip .cdot{width:7px;height:7px;border-radius:2px;background:var(--ink-3);flex:none;}
.flow-col.inputs .chip:hover{border-color:var(--line-2);color:var(--ink-0);}

.flow-core{border-radius:18px;padding:26px 24px;text-align:center;align-self:center;
  background:linear-gradient(180deg,rgba(150,42,32,.28),rgba(14,18,26,.9));
  border:1px solid var(--red);box-shadow:0 0 0 1px rgba(230,96,84,.15),0 30px 80px -30px rgba(230,96,84,.35),inset 0 1px 0 rgba(255,255,255,.05);}
.flow-core .fc-ico{width:48px;height:48px;margin:0 auto 14px;border-radius:14px;display:grid;place-items:center;
  background:rgba(230,96,84,.12);box-shadow:inset 0 0 0 1px var(--red);}
.flow-core .fc-ico svg{width:26px;height:26px;stroke:var(--red);}
.flow-core h3{font-size:18px;font-weight:700;letter-spacing:-.01em;}
.flow-core p{font-size:12.5px;color:var(--ink-1);margin-top:8px;line-height:1.5;}
.flow-core .tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:14px;}
.flow-core .tags span{font-size:11px;font-weight:600;color:var(--red);background:rgba(230,96,84,.08);
  border:1px solid var(--line-2);border-radius:999px;padding:4px 11px;letter-spacing:.02em;}
.flow-out .chip{background:linear-gradient(180deg,rgba(227,168,87,.10),rgba(14,18,26,.6));border-color:rgba(227,168,87,.25);color:var(--ink-0);}
.flow-out .chip .cdot{background:var(--gold);box-shadow:0 0 8px var(--gold);border-radius:50%;}

.flow-arrow{display:flex;align-items:center;justify-content:center;padding:0 18px;color:var(--red);opacity:.8;}
.flow-arrow svg{width:34px;height:34px;}
.flow-arrow .ln{stroke-dasharray:4 5;animation:dash 1.1s linear infinite;}
@keyframes dash{to{stroke-dashoffset:-18;}}
@media(max-width:980px){
  .flow{grid-template-columns:1fr;gap:14px;}
  .flow-arrow{transform:rotate(90deg);padding:4px 0;}
  .flow-core{margin:4px 0;}
}

/* ============================================================
   PLATFORM — AIN products
   ============================================================ */
.platform-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.prod{position:relative;border-radius:20px;padding:30px 30px 28px;overflow:hidden;
  background:linear-gradient(180deg,var(--bg-2),var(--bg-1));border:1px solid var(--line);
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;}
.prod::before{content:"";position:absolute;inset:0;opacity:0;transition:opacity .4s;
  background:radial-gradient(80% 120% at 0% 0%,rgba(230,96,84,.12),transparent 60%);}
.prod:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 40px 90px -40px rgba(0,0,0,.9);}
.prod:hover::before{opacity:1;}
.prod .p-head{display:flex;align-items:center;gap:13px;margin-bottom:16px;position:relative;}
.prod .p-ico{width:46px;height:46px;border-radius:13px;flex:none;display:grid;place-items:center;
  background:rgba(230,96,84,.08);box-shadow:inset 0 0 0 1px var(--line-2);}
.prod .p-ico svg{width:24px;height:24px;stroke:var(--red);}
.prod .p-name{font-size:21px;font-weight:700;letter-spacing:-.01em;}
.prod .p-name span{color:var(--red);}
.prod .p-tag{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);margin-top:2px;}
.prod .p-desc{font-size:14.5px;color:var(--ink-1);line-height:1.6;position:relative;}
.prod .p-list{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px;position:relative;}
.prod .p-list span{font-size:12.5px;font-weight:500;color:var(--ink-1);background:rgba(255,255,255,.025);
  border:1px solid var(--line);border-radius:999px;padding:6px 13px;}
.prod.consulting{border-color:rgba(227,168,87,.22);}
.prod.consulting .p-ico{background:rgba(227,168,87,.10);box-shadow:inset 0 0 0 1px rgba(227,168,87,.3);}
.prod.consulting .p-ico svg{stroke:var(--gold-bright);}
.prod.consulting .p-name span{color:var(--gold-bright);}
.platform-foot{margin-top:26px;text-align:center;font-size:13.5px;color:var(--ink-2);
  display:flex;align-items:center;gap:10px;justify-content:center;}
.platform-foot .d{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold);}
@media(max-width:820px){.platform-grid{grid-template-columns:1fr;}}

/* ============================================================
   WHY — list
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:20px;overflow:hidden;}
.why{background:var(--bg-1);padding:30px 24px 34px;transition:background .3s;}
.why:hover{background:var(--bg-2);}
.why .wn{font-size:12px;font-weight:600;letter-spacing:.1em;color:var(--red);font-variant-numeric:tabular-nums;}
.why .wt{margin-top:18px;font-size:17px;font-weight:600;line-height:1.25;color:var(--ink-0);text-wrap:balance;}
.why .wd{margin-top:10px;font-size:13px;color:var(--ink-2);line-height:1.5;}
@media(max-width:980px){.why-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.why-grid{grid-template-columns:1fr;}}

/* ============================================================
   CTA + FOOTER
   ============================================================ */
.cta{position:relative;overflow:hidden;border-radius:32px;margin:0 32px;padding:90px 40px 96px;text-align:center;
  background:linear-gradient(160deg,rgba(150,42,32,.4),rgba(10,13,18,.6));border:1px solid var(--line-2);}
.cta::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 90% at 50% 0%,rgba(230,96,84,.18),transparent 60%);}
.cta .cta-mark{width:62px;height:62px;margin:0 auto 26px;opacity:.9;position:relative;}
.cta h2{position:relative;font-size:clamp(34px,5vw,68px);font-weight:700;letter-spacing:-.025em;line-height:1.02;text-wrap:balance;}
.cta p{position:relative;max-width:580px;margin:22px auto 0;font-size:18px;color:var(--ink-1);line-height:1.6;}
.cta .cta-row{position:relative;margin-top:36px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

footer{position:relative;z-index:5;border-top:1px solid var(--line);margin-top:130px;padding:60px 0 50px;}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.foot-brand{max-width:320px;}
.foot-brand .fb-row{display:flex;align-items:center;gap:11px;margin-bottom:16px;}
.foot-brand img{height:30px;}
.foot-brand .word{font-weight:700;font-size:20px;color:var(--word,#CBC3BD);}
.foot-brand p{font-size:13.5px;color:var(--ink-2);line-height:1.6;}
.foot-cols{display:flex;gap:64px;flex-wrap:wrap;}
.foot-col h4{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);margin-bottom:16px;}
.foot-col a{display:block;font-size:14px;color:var(--ink-1);margin-bottom:11px;transition:color .2s;}
.foot-col a:hover{color:var(--red);}
.foot-bot{margin-top:48px;padding-top:26px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12.5px;color:var(--ink-3);}
.foot-bot .legal{letter-spacing:.02em;}

/* ---------- tweaks panel ---------- */
#tweaks{position:fixed;right:18px;bottom:18px;z-index:200;width:268px;
  background:var(--panel);backdrop-filter:blur(16px);border:1px solid var(--line-2);
  border-radius:16px;padding:16px 16px 18px;box-shadow:0 30px 70px -24px rgba(0,0,0,.9);
  font-size:13px;display:none;}
#tweaks.show{display:block;}
#tweaks h5{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:14px;display:flex;justify-content:space-between;}
#tweaks .tw-row{margin-bottom:14px;}
#tweaks label{display:block;font-size:11.5px;color:var(--ink-2);margin-bottom:7px;font-weight:500;}
#tweaks .swatches{display:flex;gap:8px;}
#tweaks .sw{width:30px;height:30px;border-radius:9px;cursor:pointer;border:2px solid transparent;transition:.2s;}
#tweaks .sw.active{border-color:#fff;transform:scale(1.06);}
#tweaks input[type=range]{width:100%;accent-color:var(--red);}
#tweaks .seg{display:flex;background:var(--bg-1);border:1px solid var(--line);border-radius:9px;padding:3px;gap:3px;}
#tweaks .seg button{flex:1;font-family:var(--font);font-size:12px;font-weight:600;color:var(--ink-2);
  background:transparent;border:none;border-radius:7px;padding:6px 4px;cursor:pointer;transition:.2s;}
#tweaks .seg button.active{background:var(--red);color:#FBEDE9;}

/* ---------- IoT + Consulting cards ---------- */
.prod.iot{border-color:rgba(230,96,84,.20);}
.prod.full{margin-top:18px;}
.prod.full .p-desc{max-width:780px;}

/* ---------- Indonesia network map ---------- */
.idmap{border:1px solid var(--line);border-radius:24px;background:linear-gradient(180deg,var(--bg-1),var(--bg));
  padding:30px 30px 24px;box-shadow:0 40px 90px -50px rgba(0,0,0,.9);}
.idmap-bar{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:14px;}
.idmap-title{font-size:clamp(21px,2.3vw,30px);font-weight:700;letter-spacing:-.02em;margin-top:12px;color:var(--ink-0);text-wrap:balance;}
.idmap-legend{display:flex;gap:22px;font-size:12.5px;color:var(--ink-2);font-weight:500;}
.idmap-legend span{display:flex;align-items:center;gap:8px;}
.idmap-legend .lg{flex:none;display:inline-block;}
.idmap-legend .lg.node{width:13px;height:13px;border-radius:50%;background:radial-gradient(circle,#fff 25%,var(--red) 70%);box-shadow:0 0 10px var(--red);}
.idmap-legend .lg.link{width:20px;height:2px;border-radius:2px;background:var(--gold);box-shadow:0 0 8px var(--gold);}
#id-map{width:100%;}
#id-map svg{width:100%;height:auto;display:block;}
#id-map .id-label{fill:var(--ink-1);font:600 11px var(--font);letter-spacing:.02em;}
#id-map .id-link{stroke-dasharray:3 6;animation:idflow 1.5s linear infinite;}
@keyframes idflow{to{stroke-dashoffset:-27;}}
#id-map .id-pulse{transform-box:fill-box;transform-origin:center;animation:idping 2.6s var(--ease) infinite;}
@keyframes idping{0%{transform:scale(.5);opacity:.85}80%,100%{transform:scale(2.5);opacity:0}}
.idmap-foot{margin-top:14px;font-size:13px;color:var(--ink-2);text-align:center;}

/* ---------- Flow ("scattered systems to work done") motion ---------- */
#flow{position:relative;overflow:hidden;}
#flow > .wrap{position:relative;z-index:2;}
.flow-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
.flow-bg .core-glow{position:absolute;left:50%;top:64%;width:660px;height:660px;max-width:82vw;
  transform:translate(-50%,-50%);border-radius:50%;filter:blur(8px);
  background:radial-gradient(circle,rgba(230,73,61,.18),rgba(227,168,87,.06) 46%,transparent 66%);
  animation:flowPulse 5.5s var(--ease) infinite;}
@keyframes flowPulse{0%,100%{opacity:.55;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}}
.flow-bg .stream{position:absolute;left:0;height:2px;width:220px;border-radius:99px;opacity:0;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  animation:streamFlow linear infinite;}
.flow-bg .stream.alt{height:1.5px;width:150px;background:linear-gradient(90deg,transparent,var(--red-bright),transparent);}
@keyframes streamFlow{0%{transform:translateX(-240px);opacity:0}10%{opacity:.5}50%{opacity:.85}90%{opacity:.5}100%{transform:translateX(calc(100vw + 240px));opacity:0}}
.flow-bg .s1{top:57%;animation-duration:6.8s;animation-delay:0s}
.flow-bg .s2{top:65%;animation-duration:8.2s;animation-delay:1.5s}
.flow-bg .s3{top:72%;animation-duration:7.4s;animation-delay:.7s}
.flow-bg .s4{top:80%;animation-duration:9.1s;animation-delay:2.3s}
.flow-bg .s5{top:61%;animation-duration:8.7s;animation-delay:3.4s}
.flow-bg .s6{top:87%;animation-duration:7.9s;animation-delay:1.1s}
.flow-col,.flow-core{transition:transform .3s linear;}
.flow .chip{opacity:0;transition:opacity .6s var(--ease),transform .6s var(--ease),border-color .35s,box-shadow .35s,color .35s;}
.flow-col.inputs .chip{transform:translateX(-22px);}
.flow-out .chip{transform:translateX(22px);}
.flow.in .chip{opacity:1;transform:none;}
.chip.flowing{border-color:var(--gold)!important;color:var(--ink-0)!important;box-shadow:0 0 0 1px rgba(227,168,87,.45),0 0 26px -6px rgba(227,168,87,.55)!important;}
.chip.flowing .cdot{background:var(--gold)!important;box-shadow:0 0 8px var(--gold)!important;}
.flow-core.flowing{box-shadow:0 0 0 1px rgba(172,219,227,.3),0 0 70px -14px rgba(230,73,61,.7),inset 0 1px 0 rgba(255,255,255,.06)!important;}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;}
  html{scroll-behavior:auto;}
}

/* ============================================================
   MOBILE / SMALL SCREENS
   ============================================================ */
@media(max-width:768px){
  /* tighter gutters */
  .wrap{padding:0 20px;}
  .hero-inner{padding:0 20px;}
  section.block{padding:88px 0;}
  .section-head{margin-bottom:44px;}

  /* nav: compact, no collisions */
  header.nav,header.nav.scrolled{padding-left:18px;padding-right:18px;}
  .nav-right{gap:12px;}
  .nav-right .lang{display:none;}            /* EN/ID drops on small screens */
  .nav-right .btn{padding:9px 16px;font-size:13.5px;}
  .brand img{height:32px;}
  .brand .word{font-size:20px;}

  /* hero: drop the scattered agent wall (it's decorative) for a clean, readable hero */
  #agent-wall{display:none;}
  .hero{padding-top:120px;min-height:auto;padding-bottom:80px;}
  .hero-veil{background:radial-gradient(70% 60% at 50% 42%, rgba(230,73,61,.10) 0%, rgba(6,8,11,0) 70%);}
  .hero h1{font-size:clamp(40px,12vw,72px);}
  .scroll-cue{display:none;}

  /* globe: drop the floating insight cards (they overlap on narrow widths) */
  .globe-stage{min-height:520px;}
  .insight{display:none;}

  /* CTA panel */
  .cta{margin:0 18px;padding:60px 24px 66px;border-radius:26px;}
  .cta p{font-size:16px;}

  /* footer stacks naturally; tighten the columns */
  .foot-cols{gap:36px 48px;}

  /* tweaks panel: fit narrow screens */
  #tweaks{right:12px;left:12px;bottom:12px;width:auto;}
}

@media(max-width:560px){
  .hero .cta-row .btn,.cta .cta-row .btn{width:100%;justify-content:center;}
  .hero .cta-row,.cta .cta-row{width:100%;}
}
