:root{
  --bg:#05080F;--bg2:#0A1322;--panel:rgba(255,255,255,0.035);--panel-solid:#0C1626;
  --line:rgba(120,170,255,0.13);--line-strong:rgba(120,170,255,0.28);
  --cyan:#34D7FF;--blue:#2B8FFF;--blue-deep:#1668E0;--gold:#FFC83D;--gold-deep:#F0A91B;
  --text:#EAF2FF;--muted:#93A6C4;--muted-dim:#5E708C;--good:#3DE3A8;--radius:16px;--maxw:1280px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;font-weight:700;line-height:1.05;margin:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.mono{font-family:'JetBrains Mono',monospace}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);font-weight:500}

.bg-fx{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bg-fx .glow{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}
.bg-fx .g1{width:560px;height:560px;left:-120px;top:-80px;background:radial-gradient(circle,#114a8f55,transparent 70%)}
.bg-fx .g2{width:680px;height:680px;right:-180px;top:160px;background:radial-gradient(circle,#0e6fb544,transparent 70%)}
.bg-fx .grid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 80% 55% at 50% 0%,#000 30%,transparent 80%);opacity:.4}
main,header,footer{position:relative;z-index:1}

/* util */
.util{border-bottom:1px solid var(--line);font-size:12.5px;background:rgba(5,8,15,.6)}
.util .wrap{display:flex;align-items:center;justify-content:space-between;height:38px;gap:18px}
.util-left{display:flex;gap:22px;color:var(--muted);flex-wrap:wrap}
.util-left span{display:flex;align-items:center;gap:7px;white-space:nowrap}
.util-left svg{width:14px;height:14px;stroke:var(--cyan)}
.util-right{display:flex;gap:18px;align-items:center;color:var(--muted);white-space:nowrap}
.util-right a:hover{color:var(--text)}
.lang{display:flex;align-items:center;gap:6px;border:1px solid var(--line);padding:3px 9px;border-radius:6px}
@media(max-width:920px){.util-left span:nth-child(n+3){display:none}}

/* nav */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);background:rgba(5,8,15,.72);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;gap:24px;height:72px}
.logo{display:flex;align-items:center;gap:11px;font-family:'Space Grotesk';font-weight:700;font-size:22px;letter-spacing:.05em}
.logo .mark{width:38px;height:38px;display:grid;place-items:center;border-radius:9px;background:linear-gradient(135deg,#0d2a4d,#08182f);border:1px solid var(--line-strong)}
.logo .mark svg{width:22px;height:22px}
.logo small{display:block;font-family:'JetBrains Mono';font-size:8px;letter-spacing:.32em;color:var(--cyan);font-weight:500;margin-top:1px}
.logo-dark,
.logo-light{
    height:48px;
    width:auto;
}

[data-theme="dark"] .logo-light{
    display:none;
}

[data-theme="light"] .logo-dark{
    display:none;
}
.menu{display:flex;gap:22px;margin-left:6px;font-size:14px;font-weight:500}
.menu a{color:var(--muted);position:relative;padding:4px 0}
.menu a:hover,.menu a.active{color:var(--text)}
.menu a.active::after{content:"";position:absolute;left:0;right:0;bottom:-25px;height:2px;background:var(--cyan)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:13px}
.cart{display:flex;align-items:center;gap:9px;border:1px solid var(--line-strong);padding:9px 14px;border-radius:10px;font-weight:600;font-size:13.5px;cursor:pointer;transition:.2s}
.cart:hover{border-color:var(--cyan);background:var(--panel)}
.cart .badge{background:var(--cyan);color:#03121f;font-family:'JetBrains Mono';font-weight:700;font-size:11px;min-width:19px;height:19px;border-radius:50%;display:grid;place-items:center;padding:0 5px}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;border-radius:11px;padding:13px 22px;font-size:15px;cursor:pointer;border:1px solid transparent;transition:.2s;font-family:'Inter'}
.btn-gold{background:linear-gradient(180deg,var(--gold),var(--gold-deep));color:#1a1200;box-shadow:0 6px 24px -8px var(--gold)}
.btn-gold:hover{transform:translateY(-1px);box-shadow:0 10px 30px -8px var(--gold)}
.btn-ghost{border-color:var(--line-strong);color:var(--text);background:var(--panel)}
.btn-ghost:hover{border-color:var(--cyan)}
.btn-blue{background:linear-gradient(180deg,var(--blue),var(--blue-deep));color:#fff;box-shadow:0 6px 24px -8px var(--blue)}
.btn-blue:hover{transform:translateY(-1px)}
.reseller-link{font-size:13.5px;color:var(--cyan);font-weight:500;display:inline-flex;align-items:center;gap:6px}
.reseller-link:hover{text-decoration:underline}
@media(max-width:1100px){.menu{display:none}}

/* ===== HERO (dense) ===== */
.hero{padding:40px 0 30px}
.hero .wrap{display:grid;grid-template-columns:1fr 1.15fr 0.95fr;gap:26px;align-items:center}
.hero-eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 10px var(--good)}
.kicker-big{font-family:'Space Grotesk';font-weight:600;font-size:15px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.hero h1{font-size:clamp(30px,3.2vw,40px);letter-spacing:-.01em;line-height:1.04}
.hero h1 .mhz{color:var(--cyan)}
.wordmark{font-family:'Space Grotesk';font-weight:700;font-size:clamp(40px,5vw,62px);letter-spacing:-.02em;margin:12px 0 12px;line-height:.95}
.wordmark .n{color:var(--cyan)}
.hero p.lead{color:var(--muted);font-size:15.5px;max-width:440px;margin:0 0 20px}
.usp{display:grid;grid-template-columns:1fr 1fr;gap:10px 20px;margin:0 0 24px;padding:0;list-style:none}
.usp li{display:flex;align-items:center;gap:9px;font-size:13.5px;color:#cdddf2}
.usp li svg{width:18px;height:18px;flex:0 0 18px;stroke:var(--cyan)}
.hero-cta{display:flex;gap:11px;flex-wrap:wrap;align-items:stretch}
.cta-stack{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1}
.cta-stack small{font-size:11px;opacity:.85;font-weight:500}
.btn.sm{padding:11px 16px;font-size:13.5px}

/* constellation */
.stage{position:relative;height:460px}
.const-lines{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.const-lines line{stroke:var(--line-strong);stroke-width:1;stroke-dasharray:3 4;opacity:.7}
.cdevice{position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);width:180px;height:120px;z-index:4;
  background:linear-gradient(145deg,#1b2c44,#0c1726);border:1px solid var(--line-strong);border-radius:16px;
  box-shadow:0 30px 60px -20px #000,inset 0 1px 0 rgba(255,255,255,.06);display:grid;place-items:center}
.cdevice::after{content:"";position:absolute;left:14px;right:14px;bottom:8px;height:3px;border-radius:3px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);box-shadow:0 0 16px var(--cyan);animation:glowbar 2.6s ease-in-out infinite}
@keyframes glowbar{0%,100%{opacity:.55}50%{opacity:1}}
.cdevice .brand{font-family:'Space Grotesk';font-weight:700;font-size:15px;letter-spacing:.16em;color:#aebfd6;display:flex;align-items:center;gap:6px}
.cdevice .brand svg{width:16px;height:16px}
.cantenna{position:absolute;left:50%;top:52%;transform:translate(40px,-148px);width:5px;height:92px;border-radius:4px;background:linear-gradient(180deg,#2b3b54,#16243a);z-index:3}
.cantenna::before{content:"";position:absolute;top:-7px;left:-3px;width:11px;height:11px;border-radius:50%;background:var(--cyan);box-shadow:0 0 14px var(--cyan)}
.cring{position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);border:1px solid var(--line);border-radius:50%;z-index:2}
.cring.a{width:210px;height:210px;opacity:.7}
.cring.b{width:300px;height:300px;border-style:dashed;opacity:.4}
.orb{position:absolute;z-index:5;display:flex;flex-direction:column;align-items:center;gap:6px;width:96px;text-align:center;animation:floaty 6s ease-in-out infinite}
.orb .circle{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 30% 30%,#11314f,#0a1828);border:1px solid var(--line-strong);box-shadow:0 8px 22px -10px #000,inset 0 0 14px rgba(52,215,255,.12)}
.orb .circle svg{width:24px;height:24px;stroke:var(--cyan)}
.orb .lab{font-size:11px;line-height:1.25;color:#b6c7df;font-weight:500}
.orb.mqtt .circle{font-family:'Space Grotesk';font-weight:700;font-size:13px;color:var(--cyan);letter-spacing:.06em}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.orb.o1{left:8%;top:14%}.orb.o2{left:42%;top:2%;animation-delay:.5s}.orb.o3{right:10%;top:12%;animation-delay:1s}
.orb.o4{right:-1%;top:40%;animation-delay:1.5s}.orb.o5{right:6%;top:66%;animation-delay:.8s}
.orb.o6{right:30%;bottom:0;animation-delay:1.2s}.orb.o7{left:0;top:46%;animation-delay:.3s}

/* werkt met panel */
.works-panel{border:1px solid var(--line-strong);background:linear-gradient(160deg,rgba(14,30,52,.7),rgba(8,16,30,.6));border-radius:var(--radius);padding:20px}
.works-panel .lbl{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.2em;color:var(--cyan);text-transform:uppercase;margin-bottom:16px}
.brandgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.brandgrid .b{font-family:'Space Grotesk';font-weight:600;font-size:13px;color:#9fb3cf;text-align:center;padding:12px 4px;border:1px solid var(--line);border-radius:10px;transition:.2s}
.brandgrid .b:hover{color:#fff;border-color:var(--line-strong);background:rgba(255,255,255,.03)}
.works-panel .all{display:block;text-align:center;margin-top:16px;font-size:13px;color:var(--cyan);font-weight:600}
@media(max-width:1100px){
  .hero .wrap{grid-template-columns:1fr}
  .stage{order:-1;height:420px;max-width:520px;margin:0 auto;width:100%}
  .usp{max-width:520px}
}

/* trust */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:30px}
.trust .wrap{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;padding:24px 22px}
.trust-item{display:flex;gap:12px;align-items:flex-start}
.trust-item svg{width:24px;height:24px;stroke:var(--cyan);flex:0 0 24px;margin-top:2px}
.trust-item b{display:block;font-size:14px;font-family:'Space Grotesk'}
.trust-item span{font-size:12px;color:var(--muted)}
@media(max-width:900px){.trust .wrap{grid-template-columns:repeat(2,1fr)}.trust-item:last-child{display:none}}

/* ===== 5-up strip ===== */
.strip-sec{padding:40px 0 10px}
.strip{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.scol{border:1px solid var(--line);background:var(--panel);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column}
.scol .sh{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.scol .sh h3{font-size:14px;letter-spacing:.02em}
.scol .sh a{font-size:11.5px;color:var(--cyan);font-weight:600}
.minilist{list-style:none;padding:0;margin:0;display:grid;gap:9px}
.minilist li{display:flex;gap:10px;align-items:center;font-size:13px;color:#c4d4ea;padding:7px;border-radius:9px;transition:.2s;cursor:pointer}
.minilist li:hover{background:rgba(255,255,255,.03)}
.minilist .thumb{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,#11304f,#0a1a30);border:1px solid var(--line);display:grid;place-items:center;flex:0 0 34px}
.minilist .thumb svg{width:17px;height:17px;stroke:var(--cyan)}
.minilist .arr{margin-left:auto;color:var(--muted-dim)}
.feat-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.feat-list li{display:flex;gap:9px;align-items:flex-start;font-size:12.5px;color:#c4d4ea}
.feat-list svg{width:16px;height:16px;stroke:var(--cyan);flex:0 0 16px;margin-top:2px}
.tablet{border:1px solid var(--line-strong);border-radius:12px;background:#0a1424;padding:10px;margin-bottom:14px}
.tablet .tb{display:flex;gap:6px;margin-bottom:8px}.tablet .tb i{width:6px;height:6px;border-radius:50%;background:#243a57}
.tablet .tg{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.tablet .tile{background:linear-gradient(150deg,#0e1d33,#0a1626);border:1px solid var(--line);border-radius:7px;padding:8px}
.tablet .tile .v{font-family:'Space Grotesk';font-weight:700;font-size:15px}
.tablet .tile .l{font-size:9px;color:var(--muted)}
.tablet .tile.wide{grid-column:1/-1}
.spark{display:flex;gap:2px;align-items:flex-end;height:22px;margin-top:4px}
.spark i{flex:1;background:linear-gradient(180deg,var(--cyan),transparent);border-radius:2px;opacity:.8}
.scol .cta-bottom{margin-top:auto;padding-top:14px}
.scol .cta-bottom a{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--cyan);font-weight:600}
.reseller-vis{height:74px;border-radius:11px;border:1px solid var(--line);background:linear-gradient(135deg,#0c2745,#0a1830);display:grid;place-items:center;margin-bottom:12px}
.reseller-vis svg{width:36px;height:36px;stroke:var(--cyan)}
.scol p.small{font-size:12px;color:var(--muted);margin:0 0 12px}
@media(max-width:1100px){.strip{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.strip{grid-template-columns:1fr}}

/* section base */
section.block{padding:74px 0}
.shead{max-width:680px;margin-bottom:42px}
.shead h2{font-size:clamp(28px,3.2vw,40px);margin:14px 0 12px;letter-spacing:-.01em}
.shead p{color:var(--muted);font-size:16px;margin:0}

/* connect grid */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{border:1px solid var(--line);background:var(--panel);border-radius:var(--radius);padding:24px;transition:.25s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;inset:0;background:radial-gradient(400px circle at var(--mx,50%) var(--my,0%),rgba(52,215,255,.08),transparent 60%);opacity:0;transition:.3s;pointer-events:none}
.card:hover{border-color:var(--line-strong);transform:translateY(-4px)}
.card:hover::before{opacity:1}
.card .ico{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;margin-bottom:16px;background:linear-gradient(135deg,#0e2b4d,#0a1c34);border:1px solid var(--line-strong)}
.card .ico svg{width:25px;height:25px;stroke:var(--cyan)}
.card h3{font-size:17px;margin-bottom:8px}
.card p{color:var(--muted);font-size:13.5px;margin:0}
.card .tags{margin-top:13px;font-family:'JetBrains Mono';font-size:11px;color:var(--muted-dim)}
@media(max-width:880px){.cards{grid-template-columns:1fr}}

/* wizard */
.wizard{background:linear-gradient(135deg,#091a30,#060d18);border:1px solid var(--line-strong);border-radius:22px;padding:44px;position:relative;overflow:hidden}
.wizard::after{content:"";position:absolute;right:-60px;top:-60px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(52,215,255,.13),transparent 70%)}
.wizard .inner{position:relative;z-index:1;max-width:760px}
.wizard h2{font-size:clamp(26px,3vw,36px);margin-bottom:8px}
.wizard p.sub{color:var(--muted);margin:0 0 24px}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}
.chip{font-size:14px;font-weight:600;padding:11px 18px;border-radius:30px;border:1px solid var(--line-strong);background:var(--panel);cursor:pointer;transition:.2s;color:var(--text)}
.chip:hover{border-color:var(--cyan)}
.chip.sel{background:var(--cyan);color:#03121f;border-color:var(--cyan)}
.wiz-result{min-height:60px;border-left:3px solid var(--cyan);padding:14px 0 14px 20px;font-size:16px;color:#dceaff;background:linear-gradient(90deg,rgba(52,215,255,.06),transparent)}
.wiz-result b{color:var(--cyan)}
.wiz-result.empty{color:var(--muted-dim);border-color:var(--line)}

/* why split */
.why{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.why-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.why-list li{display:flex;gap:14px;padding:17px 19px;border:1px solid var(--line);border-radius:14px;background:var(--panel)}
.why-list .num{font-family:'JetBrains Mono';color:var(--cyan);font-weight:700;font-size:13px}
.why-list b{font-family:'Space Grotesk';font-size:15.5px;display:block;margin-bottom:3px}
.why-list span{color:var(--muted);font-size:13px}
.ha-mock{border:1px solid var(--line-strong);border-radius:18px;background:#0a1424;padding:16px;box-shadow:0 40px 80px -30px #000}
.ha-bar{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.ha-bar .dotk{width:8px;height:8px;border-radius:50%;background:#243a57}
.ha-bar .t{margin-left:8px;font-family:'JetBrains Mono';font-size:11px;color:var(--muted)}
.ha-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ha-tile{background:linear-gradient(150deg,#0e1d33,#0a1626);border:1px solid var(--line);border-radius:11px;padding:13px}
.ha-tile .top{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:12px}
.ha-tile .val{font-family:'Space Grotesk';font-weight:700;font-size:22px;margin-top:7px}
.ha-tile .val .u{font-size:12px;color:var(--muted)}
.ha-tile.full{grid-column:1/-1}
.toggle{width:40px;height:22px;border-radius:20px;background:var(--cyan);position:relative}
.toggle::after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:#03121f;top:3px;right:3px}
.toggle.off{background:#243a57}.toggle.off::after{right:auto;left:3px;background:#7c91ad}
.ha-tile .spark{height:30px}
@media(max-width:900px){.why{grid-template-columns:1fr}}

/* examples */
.ex-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.ex{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--panel);transition:.25s;display:flex;flex-direction:column}
.ex:hover{border-color:var(--line-strong);transform:translateY(-4px)}
.ex .cap{height:140px;position:relative;overflow:hidden;background:linear-gradient(135deg,#102744,#081424);display:grid;place-items:center}
.ex .cap svg{width:54px;height:54px;stroke:var(--cyan);opacity:.85}
.ex .cap .scan{position:absolute;inset:0;background:linear-gradient(transparent 50%,rgba(52,215,255,.05) 50%);background-size:100% 6px}
.ex .body{padding:20px}
.ex .kicker{font-family:'JetBrains Mono';font-size:11px;color:var(--cyan);letter-spacing:.16em;text-transform:uppercase}
.ex h3{font-size:17px;margin:8px 0 7px}
.ex p{color:var(--muted);font-size:13.5px;margin:0 0 12px}
.ex a.more{font-size:13px;color:var(--cyan);font-weight:600;display:inline-flex;gap:6px;align-items:center}
@media(max-width:760px){.ex-grid{grid-template-columns:1fr}}

/* product band */
.product{background:linear-gradient(135deg,#0a1830,#060c17);border:1px solid var(--line-strong);border-radius:24px;padding:44px;display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;position:relative;overflow:hidden}
.product::before{content:"";position:absolute;left:-80px;bottom:-80px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(43,143,255,.16),transparent 70%)}
.prod-visual{position:relative;z-index:1;display:grid;place-items:center;height:280px}
.prod-visual .ringp{position:absolute;border:1px solid var(--line-strong);border-radius:50%}
.prod-device{width:200px;height:132px;background:linear-gradient(145deg,#1d3050,#0c1828);border:1px solid var(--line-strong);border-radius:18px;position:relative;display:grid;place-items:center;box-shadow:0 30px 60px -20px #000}
.prod-device .brand{font-family:'Space Grotesk';font-weight:700;letter-spacing:.18em;color:#aebfd6}
.prod-device::after{content:"";position:absolute;left:16px;right:16px;bottom:9px;height:3px;border-radius:3px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);box-shadow:0 0 14px var(--cyan)}
.prod-info{position:relative;z-index:1}
.prod-info .rate{display:flex;align-items:center;gap:8px;color:var(--gold);font-size:14px;margin-bottom:10px}
.prod-info h2{font-size:32px}
.prod-info .price{display:flex;align-items:baseline;gap:12px;margin:16px 0}
.prod-info .price .now{font-family:'Space Grotesk';font-weight:700;font-size:40px}
.prod-info .price .vat{color:var(--muted);font-size:13px}
.prod-info .stock{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--good);margin-bottom:16px;font-family:'JetBrains Mono'}
.prod-info .stock .d{width:8px;height:8px;border-radius:50%;background:var(--good);box-shadow:0 0 8px var(--good)}
.qty{display:flex;align-items:center;border:1px solid var(--line-strong);border-radius:10px;overflow:hidden;width:fit-content}
.qty button{background:var(--panel);border:none;color:var(--text);width:42px;height:46px;font-size:20px;cursor:pointer}
.qty span{width:50px;text-align:center;font-family:'JetBrains Mono';font-weight:700}
.buy-row{display:flex;gap:12px;align-items:center;margin-top:16px;flex-wrap:wrap}
.prod-meta{margin-top:20px;display:flex;gap:20px;flex-wrap:wrap;font-size:12.5px;color:var(--muted)}
.prod-meta span{display:flex;align-items:center;gap:7px}
.prod-meta svg{width:15px;height:15px;stroke:var(--cyan)}
@media(max-width:880px){.product{grid-template-columns:1fr;padding:30px}}

/* reseller band */
.reseller{background:linear-gradient(120deg,#06243f,#0a1424);border:1px solid var(--line-strong);border-radius:22px;padding:44px;display:grid;grid-template-columns:1.3fr 1fr;gap:38px;align-items:center}
.reseller h2{font-size:clamp(26px,3vw,34px);margin-bottom:12px}
.reseller p{color:var(--muted);margin:0 0 20px;max-width:520px}
.reseller .perks{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:22px;list-style:none;padding:0}
.reseller .perks li{display:flex;gap:10px;font-size:13.5px;align-items:center}
.reseller .perks svg{width:18px;height:18px;stroke:var(--good)}
.tiers{border:1px solid var(--line-strong);border-radius:16px;overflow:hidden;background:rgba(5,12,22,.6)}
.tiers .row{display:grid;grid-template-columns:1fr 1fr;padding:14px 20px;border-bottom:1px solid var(--line);font-size:14px}
.tiers .row:last-child{border-bottom:none}
.tiers .row.head{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);background:rgba(52,215,255,.05)}
.tiers .row .disc{color:var(--good);font-weight:700;font-family:'JetBrains Mono';text-align:right}
.tiers .row .q{font-family:'JetBrains Mono'}
@media(max-width:880px){.reseller{grid-template-columns:1fr;padding:30px}.reseller .perks{grid-template-columns:1fr}}

/* downloads + radar */
.dual{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.dl-card,.radar-card{border:1px solid var(--line);background:var(--panel);border-radius:18px;padding:30px}
.dl-card h3,.radar-card h3{font-size:21px;margin-bottom:6px}
.dl-card .sub,.radar-card .sub{color:var(--muted);font-size:14px;margin-bottom:20px}
.dl-list{list-style:none;padding:0;margin:0;display:grid;gap:2px}
.dl-list li{display:flex;align-items:center;gap:13px;padding:12px 13px;border-radius:11px;transition:.2s;cursor:pointer}
.dl-list li:hover{background:rgba(255,255,255,.03)}
.dl-list .fi{width:34px;height:34px;border-radius:9px;background:rgba(52,215,255,.08);display:grid;place-items:center;flex:0 0 34px}
.dl-list .fi svg{width:17px;height:17px;stroke:var(--cyan)}
.dl-list .name{font-size:14px;font-weight:500;flex:1}
.dl-list .ext{font-family:'JetBrains Mono';font-size:11px;color:var(--muted-dim)}
.dl-list .dlico{width:16px;height:16px;stroke:var(--muted)}
.radar-card{background:linear-gradient(150deg,#091a30,#070e1b);position:relative;overflow:hidden}
.radar-card .live{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono';font-size:11px;color:var(--good);letter-spacing:.14em;text-transform:uppercase;margin-bottom:12px}
.radar-card .live .d{width:8px;height:8px;border-radius:50%;background:var(--good);box-shadow:0 0 10px var(--good);animation:blink 1.6s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}
.post{border:1px solid var(--line);border-radius:14px;padding:18px;background:rgba(5,12,22,.5);margin-top:4px}
.post .date{font-family:'JetBrains Mono';font-size:11px;color:var(--cyan);margin-bottom:8px}
.post h4{font-family:'Space Grotesk';font-size:16px;margin:0 0 8px}
.post p{color:var(--muted);font-size:13.5px;margin:0 0 12px}
.post .by{font-family:'JetBrains Mono';font-size:11px;color:var(--muted-dim);display:flex;align-items:center;gap:7px}
.post .by .sq{width:14px;height:14px;border-radius:4px;background:linear-gradient(135deg,var(--cyan),var(--blue))}
@media(max-width:880px){.dual{grid-template-columns:1fr}}

/* protocols */
.protocols{border-top:1px solid var(--line);padding:50px 0}
.protocols .lbl{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.2em;color:var(--cyan);text-transform:uppercase;text-align:center;margin-bottom:24px}
.cloud{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:960px;margin:0 auto}
.cloud span{font-family:'Space Grotesk';font-weight:600;font-size:15px;color:#8497b3;padding:9px 16px;border:1px solid var(--line);border-radius:30px;transition:.2s}
.cloud span:hover{color:#fff;border-color:var(--cyan)}

/* footer */
footer{border-top:1px solid var(--line);background:#040710;padding:54px 0 28px;margin-top:8px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:38px;margin-bottom:38px}
.foot-grid h5{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);margin:0 0 16px}
.foot-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.foot-grid a{color:var(--muted);font-size:14px}.foot-grid a:hover{color:#fff}
.foot-about p{color:var(--muted);font-size:14px;max-width:320px;margin:16px 0}
.pay{display:flex;gap:8px;margin-top:6px;flex-wrap:wrap}
.pay span{font-family:'JetBrains Mono';font-size:11px;font-weight:700;padding:6px 10px;border:1px solid var(--line-strong);border-radius:7px;color:#aebfd6}
.foot-bottom{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;align-items:center;color:var(--muted-dim);font-size:12.5px;flex-wrap:wrap;gap:12px}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}}

.reveal{opacity:0;transform:translateY(22px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}

/* ===== Logo image + hero photo (toegevoegd) ===== */
.logo img{height:46px;width:auto;display:block}
.foot-about .logo img{height:52px}
.hero-photo{display:flex;align-items:center;justify-content:center;overflow:visible}
.hero-photo img{width:100%;max-width:560px;height:auto;filter:drop-shadow(0 30px 60px rgba(0,0,0,.6))}
@media(max-width:1100px){.hero-photo{height:auto;max-width:560px}.hero-photo img{max-width:100%}}
/* product page gallery image */
.prod-photo{border:1px solid var(--line-strong);border-radius:20px;overflow:hidden;background:linear-gradient(160deg,#0a1626,#060c17);display:flex;align-items:center;justify-content:center;padding:10px}
.prod-photo img{width:100%;height:auto;border-radius:12px}

/* ===== Formulieren (checkout, reseller, admin) ===== */
label{display:block;font-size:13px;color:var(--muted);font-weight:500}
.fld{width:100%;margin-top:7px;background:rgba(5,12,22,.6);border:1px solid var(--line-strong);border-radius:10px;
  padding:12px 14px;color:var(--text);font-family:'Inter';font-size:15px;outline:none;transition:.2s}
.fld:focus{border-color:var(--cyan);background:rgba(5,12,22,.9)}
select.fld{appearance:none;cursor:pointer}
.auth-wrap{max-width:440px;margin:0 auto}
.auth-card{border:1px solid var(--line-strong);background:linear-gradient(160deg,rgba(14,30,52,.6),rgba(8,16,30,.6));border-radius:20px;padding:36px}
.auth-card h2{font-size:26px;margin-bottom:6px}
.auth-card .sub{color:var(--muted);font-size:14px;margin-bottom:22px}
.notice{border:1px solid var(--line-strong);border-radius:12px;padding:14px 18px;margin-bottom:20px;font-size:14px}
.notice.ok{border-color:var(--good);background:rgba(61,227,168,.08);color:var(--good)}
.notice.err{border-color:var(--gold);background:rgba(255,200,61,.08);color:var(--gold)}
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;font-family:'JetBrains Mono';font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);padding:12px 14px;border-bottom:1px solid var(--line-strong)}
.table td{padding:12px 14px;border-bottom:1px solid var(--line);color:#090909}
.table tr:hover td{background:rgba(255,255,255,.02)}
.badge-status{font-family:'JetBrains Mono';font-size:11px;padding:4px 9px;border-radius:20px;border:1px solid var(--line-strong)}
.badge-status.paid{color:var(--good);border-color:var(--good)}
.badge-status.pending{color:var(--gold);border-color:var(--gold)}
.badge-status.failed{color:#ff7a7a;border-color:#ff7a7a}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.kpi{border:1px solid var(--line);background:var(--panel);border-radius:14px;padding:20px}
.kpi .n{font-family:'Space Grotesk';font-weight:700;font-size:28px}
.kpi .l{font-size:12.5px;color:var(--muted);margin-top:4px}
@media(max-width:880px){.kpis{grid-template-columns:1fr 1fr}}
.admin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:980px){.admin-grid{grid-template-columns:1fr}}
.lang-switch{display:inline-flex;gap:6px;align-items:center}
.lang-switch .lang{padding:2px 6px;border-radius:999px;text-decoration:none;opacity:.75}
.lang-switch .lang.active{opacity:1;background:rgba(255,255,255,.08);color:var(--gold)}


/* =========================================================
   Mobile responsive polish
   Toegevoegd: maakt publieke pagina's goed bruikbaar op mobiel.
   Admin/beheer is bewust niet uitgebreid aangepast.
   ========================================================= */

.mobile-menu-toggle{display:none}

@media(max-width:1100px){
  .nav .wrap{height:auto;min-height:68px;position:relative;gap:12px;flex-wrap:wrap;padding-top:10px;padding-bottom:10px}
  .logo{min-width:0}
  .logo img{height:40px}
  .mobile-menu-toggle{
    display:inline-flex;
    flex-direction:column;
    justify-content:center;
    gap:5px;
    width:42px;
    height:42px;
    margin-left:auto;
    border:1px solid var(--line-strong);
    border-radius:11px;
    background:rgba(255,255,255,.035);
    color:var(--text);
    cursor:pointer;
  }
  .mobile-menu-toggle span{
    width:18px;
    height:2px;
    border-radius:2px;
    background:var(--text);
    display:block;
    margin:0 auto;
    transition:.2s;
  }
  body.menu-open .mobile-menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.menu-open .mobile-menu-toggle span:nth-child(2){opacity:0}
  body.menu-open .mobile-menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  .menu{
    display:none;
    order:10;
    width:100%;
    margin:8px 0 0;
    padding:10px;
    border:1px solid var(--line);
    border-radius:16px;
    background:rgba(5,12,22,.96);
    box-shadow:0 22px 50px rgba(0,0,0,.35);
    grid-template-columns:1fr 1fr;
    gap:6px;
  }
  body.menu-open .menu{display:grid}
  .menu a{
    padding:12px 13px;
    border-radius:11px;
    background:rgba(255,255,255,.025);
    color:var(--text);
  }
  .menu a.active{background:rgba(52,215,255,.10);color:var(--cyan)}
  .menu a.active::after{display:none}

  .nav-right{margin-left:0}
  .cart{padding:9px 11px;font-size:0}
  .cart svg{width:19px;height:19px}
  .cart .badge{font-size:11px}
}

@media(max-width:760px){
  html{font-size:16px}
  .wrap{padding:0 16px}
  .util .wrap{height:auto;min-height:36px;padding-top:7px;padding-bottom:7px}
  .util-left{gap:12px}
  .util-left span:nth-child(n+2){display:none}
  .util-right{margin-left:auto;gap:9px;font-size:12px}
  .util-right>a:not(.reseller-link){display:none}
  .lang-switch{gap:4px}
  .lang-switch .lang{font-size:11px;padding:2px 6px}
  .logo img{height:36px}
  .menu{grid-template-columns:1fr}
}

/* Algemene mobiele spacing */
@media(max-width:880px){
  section.block{padding:48px 0}
  section.block[style]{padding-top:42px!important}
  .shead{margin-bottom:26px}
  .shead h2{font-size:clamp(25px,8vw,34px);line-height:1.1}
  .shead p{font-size:15px}
  .btn{width:100%;justify-content:center}
  .hero-cta{width:100%;display:grid;grid-template-columns:1fr;gap:10px}
}

/* Homepage hero */
@media(max-width:1100px){
  .hero{padding:24px 0 26px}
  .hero .wrap{grid-template-columns:1fr;gap:18px}
  .hero-photo{order:-1;max-width:520px;width:100%;margin:0 auto}
  .works-panel{max-width:720px;width:100%;margin:0 auto}
}

@media(max-width:680px){
  .hero{padding-top:18px}
  .hero h1{font-size:clamp(30px,10vw,40px)}
  .wordmark{font-size:clamp(38px,13vw,58px);word-break:break-word}
  .hero p.lead{font-size:15px;max-width:none}
  .usp{grid-template-columns:1fr;gap:9px}
  .stage{height:auto;min-height:0}
  .hero-photo img{max-width:100%;filter:drop-shadow(0 20px 38px rgba(0,0,0,.5))}
  .brandgrid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* Trust, strips en grids */
@media(max-width:760px){
  .trust{margin-top:18px}
  .trust .wrap{grid-template-columns:1fr;gap:14px;padding:18px 16px}
  .trust-item:last-child{display:flex}
  .strip-sec{padding:28px 0 6px}
  .strip{grid-template-columns:1fr}
  .scol{padding:18px}
  .cards{grid-template-columns:1fr}
  .card{padding:20px}
}

/* Wizard */
@media(max-width:760px){
  .wizard{padding:26px 18px;border-radius:18px}
  .wizard .inner{max-width:none}
  .chips{display:grid;grid-template-columns:1fr;gap:9px}
  .chip{width:100%;text-align:left;border-radius:13px;padding:13px 14px}
  .wiz-result{font-size:14px;line-height:1.65}
}

/* Waarom / HA mockup */
@media(max-width:760px){
  .why{grid-template-columns:1fr;gap:24px}
  .why-list li{gap:12px}
  .ha-mock{padding:16px;border-radius:18px}
  .ha-grid{grid-template-columns:1fr}
  .ha-tile.full{grid-column:auto}
}

/* Productblokken */
@media(max-width:760px){
  .product{grid-template-columns:1fr;padding:22px;border-radius:18px;gap:22px}
  .prod-photo{padding:8px}
  .prod-info h2{font-size:26px}
  .price{display:grid;gap:3px}
  .buy-row{display:grid!important;grid-template-columns:1fr!important;gap:10px!important}
  .qty{width:100%;justify-content:space-between}
  .prod-meta{display:grid;grid-template-columns:1fr;gap:8px}
}

/* Reseller */
@media(max-width:760px){
  .reseller{padding:24px 18px;border-radius:18px;grid-template-columns:1fr;gap:24px}
  .reseller .perks{grid-template-columns:1fr}
  .tiers .row{padding:12px 14px}
}

/* Downloads, lijsten, support */
@media(max-width:760px){
  .dual{grid-template-columns:1fr}
  .dl-card,.radar-card{padding:20px;border-radius:16px}
  .dl-list li,
  .dl-row-link{
    align-items:flex-start;
    gap:10px;
  }
  .dl-list li{padding:11px 8px}
  .dl-list .name{min-width:0;line-height:1.35}
  .dl-list .ext{
    display:inline-flex;
    align-items:center;
    align-self:flex-start;
    white-space:normal;
    text-align:right;
    max-width:42%;
    overflow-wrap:anywhere;
  }
  .dlico{display:none}
  .type-grid{grid-template-columns:1fr!important}
  .type-card{padding:14px}
  .downloads-stack{gap:16px}
  .download-note{padding:14px}
  .choice-list div{padding:13px}
  .company-meta{grid-template-columns:1fr!important}
}

/* Voorbeelden en content cards */
@media(max-width:760px){
  .ex-grid{grid-template-columns:1fr}
  .ex .cap{height:110px}
  .ex .body{padding:17px}
  .protocols{padding:34px 0}
  .cloud{justify-content:flex-start;gap:8px}
  .cloud span{font-size:13px;padding:8px 12px}
}

/* Tabellen en brede content veilig laten scrollen */
.table-wrap,
.admin-table,
.orders-table,
.compat-table,
.responsive-table{
  max-width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
table{max-width:100%}
@media(max-width:760px){
  table{font-size:13px}
  th,td{padding:10px 8px}
  pre,code{white-space:pre-wrap;overflow-wrap:anywhere}
}

/* Footer */
@media(max-width:760px){
  footer{padding:36px 0 22px}
  .foot-grid{grid-template-columns:1fr;gap:24px}
  .foot-about .logo img{height:44px}
}

/* Kleine schermen: minder hover-animatie en geen horizontale uitloop */
@media(max-width:560px){
  body{overflow-x:hidden}
  .bg-fx .grid{background-size:42px 42px}
  .card:hover,.ex:hover{transform:none}
  .btn{padding:12px 15px}
  .dl-card h3,.radar-card h3{font-size:19px}
  .auth-card{padding:22px}
}

/* Formulieren: prettig op mobiel */
@media(max-width:760px){
  .fld{font-size:16px}
  .auth-wrap{max-width:100%}
  .auth-card{border-radius:18px}
  label{font-size:13px}
}

/* Sticky nav mag niet over ankers vallen */
section[id]{scroll-margin-top:96px}


/* Cart & checkout responsive polish */
.cart-head{margin-bottom:28px}.empty-cart-card{grid-template-columns:1fr;text-align:center}.empty-cart-card p{color:var(--muted);margin:0 0 22px}.cart-layout,.checkout-layout{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(320px,1fr);gap:28px;align-items:start}.checkout-layout{grid-template-columns:minmax(0,1.4fr) minmax(320px,1fr)}.cart-items-card{padding:14px 20px}.cart-line{display:grid;grid-template-columns:54px minmax(0,1fr) auto 96px 34px;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}.cart-line:last-of-type{border-bottom:0}.cart-product-icon{width:54px;height:54px;border:1px solid var(--line);border-radius:12px;background:rgba(79,209,255,.08);display:grid;place-items:center;color:var(--cyan);flex:0 0 auto}.cart-product-icon svg{width:24px;height:24px;stroke:currentColor}.cart-product-name{font-family:'Space Grotesk',sans-serif;font-weight:700}.cart-product-meta{font-size:12.5px;color:var(--muted);margin-top:3px}.cart-qty{height:42px}.cart-line-total{text-align:right;font-family:'Space Grotesk',sans-serif;font-weight:700;white-space:nowrap}.cart-remove-form{margin:0}.cart-remove{background:none;border:none;color:var(--muted);cursor:pointer;font-size:22px;line-height:1;padding:4px}.cart-remove:hover{color:var(--gold)}.cart-continue{padding-top:16px}.summary-lines,.checkout-lines{margin-top:16px;display:grid;gap:12px;font-size:15px}.summary-lines>div,.checkout-line{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.summary-lines span,.checkout-line span{color:var(--muted)}.summary-lines em{color:var(--good);font-style:normal;text-align:right}.summary-total,.checkout-line.total{border-top:1px solid var(--line);padding-top:12px;font-size:18px}.summary-lines p,.checkout-lines p{font-size:12px;color:var(--muted-dim);margin:0;line-height:1.55}.summary-btn{width:100%;justify-content:center;margin-top:20px}.cart-pay{margin-top:16px;justify-content:center}.checkout-alert{border:1px solid var(--gold);background:rgba(255,200,61,.08);border-radius:12px;padding:14px 18px;margin-bottom:22px;color:var(--gold)}.checkout-fields{display:grid;gap:14px;margin-top:18px}.checkout-address-row{display:grid;grid-template-columns:1fr 1.4fr;gap:14px}.checkout-line.divider{border-top:1px solid var(--line);padding-top:10px}.secure-note{font-size:11.5px;color:var(--muted-dim);text-align:center;margin-top:12px}
@media(max-width:900px){.cart-layout,.checkout-layout{grid-template-columns:1fr}.cart-summary,.checkout-summary{position:static;order:2}.cart-items-card,.checkout-form-card{order:1}.cart-line{grid-template-columns:50px minmax(0,1fr) auto;gap:12px}.cart-product-icon{width:50px;height:50px}.cart-qty{grid-column:2/3;width:100%;max-width:170px}.cart-line-total{grid-column:3/4;grid-row:2/3;align-self:center}.cart-remove-form{grid-column:3/4;grid-row:1/2;justify-self:end;align-self:start}.cart-continue{padding-top:18px}.checkout-address-row{grid-template-columns:1fr 1.25fr}}
@media(max-width:620px){.checkout-cart-page .wrap{padding-left:14px;padding-right:14px}.cart-head{margin-bottom:20px}.cart-items-card,.cart-summary,.checkout-form-card,.checkout-summary{padding:18px;border-radius:16px}.cart-line{grid-template-columns:44px minmax(0,1fr) 32px;padding:16px 0}.cart-product-icon{width:44px;height:44px;border-radius:11px}.cart-product-name{font-size:15px;line-height:1.25}.cart-product-meta{font-size:12px}.cart-qty{grid-column:1/3;grid-row:2/3;max-width:none;height:40px;margin-top:2px}.cart-line-total{grid-column:3/4;grid-row:2/3;font-size:14px;align-self:center}.cart-remove-form{grid-column:3/4;grid-row:1/2}.summary-lines>div,.checkout-line{font-size:14px}.summary-total,.checkout-line.total{font-size:17px}.checkout-address-row{grid-template-columns:1fr}.checkout-line{display:grid;grid-template-columns:minmax(0,1fr) auto}.checkout-line span{line-height:1.4}.cart-pay{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.cart-pay span{text-align:center}.checkout-fields{gap:12px}.fld{min-height:46px}}
@media(max-width:420px){.cart-line{grid-template-columns:1fr auto}.cart-product-icon{display:none}.cart-product-info{grid-column:1/2}.cart-remove-form{grid-column:2/3}.cart-qty{grid-column:1/2}.cart-line-total{grid-column:2/3}.summary-btn{font-size:15px}}


/* ===== Licht/donker thema switch ===== */
.theme-toggle{
  display:inline-flex;align-items:center;gap:7px;height:40px;padding:0 12px;border-radius:11px;
  border:1px solid var(--line-strong);background:var(--panel);color:var(--text);cursor:pointer;
  font-family:'Inter',system-ui,sans-serif;font-weight:700;font-size:13px;transition:.2s;white-space:nowrap
}
.theme-toggle:hover{border-color:var(--cyan);transform:translateY(-1px)}
.theme-ico{line-height:1;font-size:14px}.theme-sun{display:none}.theme-moon{display:inline-block}
:root[data-theme="light"] .theme-sun{display:inline-block}
:root[data-theme="light"] .theme-moon{display:none}
@media(max-width:720px){.theme-label{display:none}.theme-toggle{width:40px;justify-content:center;padding:0}}

:root[data-theme="light"]{
  --bg:#F4F8FC;--bg2:#EAF1F8;--panel:rgba(255,255,255,.72);--panel-solid:#FFFFFF;
  --line:rgba(18,55,90,.13);--line-strong:rgba(18,55,90,.25);
  --cyan:#047FB3;--blue:#176FE5;--blue-deep:#0F55C4;--gold:#F3B61A;--gold-deep:#D49500;
  --text:#102033;--muted:#53677F;--muted-dim:#7E8FA2;--good:#0AA875;
}
:root[data-theme="light"] body{background:linear-gradient(180deg,#F7FAFD,#EDF3F9);color:var(--text)}
:root[data-theme="light"] .bg-fx .g1{background:radial-gradient(circle,rgba(27,143,215,.18),transparent 70%);opacity:.75}
:root[data-theme="light"] .bg-fx .g2{background:radial-gradient(circle,rgba(12,104,224,.13),transparent 70%);opacity:.65}
:root[data-theme="light"] .bg-fx .grid{opacity:.32;mask-image:radial-gradient(ellipse 85% 60% at 50% 0%,#000 35%,transparent 82%)}
:root[data-theme="light"] .util{background:rgba(255,255,255,.78)}
:root[data-theme="light"] .nav{background:rgba(255,255,255,.82);box-shadow:0 12px 30px rgba(18,55,90,.08)}
:root[data-theme="light"] .logo .mark{background:linear-gradient(135deg,#EAF4FF,#FFFFFF)}
:root[data-theme="light"] .menu a{color:#52677F}
:root[data-theme="light"] .menu a:hover,:root[data-theme="light"] .menu a.active{color:var(--text)}
:root[data-theme="light"] .btn-ghost,:root[data-theme="light"] .cart,:root[data-theme="light"] .theme-toggle{background:rgba(255,255,255,.72)}
:root[data-theme="light"] .works-panel,
:root[data-theme="light"] .wizard,
:root[data-theme="light"] .reseller,
:root[data-theme="light"] .product,
:root[data-theme="light"] .dl-card,
:root[data-theme="light"] .radar-card,
:root[data-theme="light"] .scol,
:root[data-theme="light"] .card,
:root[data-theme="light"] .ex,
:root[data-theme="light"] .ha-mock,
:root[data-theme="light"] .type-card,
:root[data-theme="light"] .choice-list div,
:root[data-theme="light"] .faq,
:root[data-theme="light"] .support-box,
:root[data-theme="light"] .company-box,
:root[data-theme="light"] .checkout-card,
:root[data-theme="light"] .cart-items-card,
:root[data-theme="light"] .empty-cart-card{
  background:rgba(255,255,255,.76);box-shadow:0 18px 45px rgba(18,55,90,.08);border-color:var(--line)
}
:root[data-theme="light"] .cdevice,
:root[data-theme="light"] .orb .circle,
:root[data-theme="light"] .card .ico,
:root[data-theme="light"] .minilist .thumb,
:root[data-theme="light"] .reseller-vis,
:root[data-theme="light"] .tablet,
:root[data-theme="light"] .tablet .tile,
:root[data-theme="light"] .ha-tile,
:root[data-theme="light"] .company-meta div,
:root[data-theme="light"] .cart-product-img,
:root[data-theme="light"] .product-thumb{
  background:linear-gradient(145deg,#FFFFFF,#EEF5FB);border-color:var(--line-strong);box-shadow:0 10px 28px rgba(18,55,90,.07)
}
:root[data-theme="light"] .cdevice .brand,:root[data-theme="light"] .orb .lab,:root[data-theme="light"] .usp li,:root[data-theme="light"] .minilist li,:root[data-theme="light"] .feat-list li{color:#2A3C52}
:root[data-theme="light"] .brandgrid .b{background:rgba(255,255,255,.58);color:#40556E}
:root[data-theme="light"] .brandgrid .b:hover{color:var(--text);background:#fff}
:root[data-theme="light"] .download-note{background:rgba(4,127,179,.08);border-color:rgba(4,127,179,.22)}
:root[data-theme="light"] .chip{background:#fff;color:var(--text)}
:root[data-theme="light"] .chip.sel{background:var(--cyan);color:#fff}
:root[data-theme="light"] .wiz-result{color:#203246;background:linear-gradient(90deg,rgba(4,127,179,.08),transparent)}
:root[data-theme="light"] .ha-bar .dotk{background:#B8C8D8}
:root[data-theme="light"] .toggle::after{background:#fff}
:root[data-theme="light"] .fld,
:root[data-theme="light"] input,
:root[data-theme="light"] textarea,
:root[data-theme="light"] select{
  background:#fff;color:var(--text);border-color:var(--line-strong)
}
:root[data-theme="light"] .footer,
:root[data-theme="light"] footer{background:rgba(255,255,255,.55)}
:root[data-theme="light"] .btn-gold{color:#211600;box-shadow:0 8px 24px rgba(212,149,0,.22)}
:root[data-theme="light"] .btn-blue{box-shadow:0 8px 24px rgba(23,111,229,.18)}
:root[data-theme="light"] .scan{opacity:.28}
:root[data-theme="light"] .ex .cap{background:linear-gradient(135deg,#EAF4FF,#FFFFFF)}
:root[data-theme="light"] table,
:root[data-theme="light"] .admin-table{background:#fff;color:var(--text)}

@media(max-width:1100px){
  :root[data-theme="light"] body.menu-open .menu{background:rgba(255,255,255,.97);box-shadow:0 25px 60px rgba(18,55,90,.18)}
}

/* ===== Fixes reseller/admin light theme + clickable dashboard elements ===== */
:root[data-theme="light"] .auth-card{
  background:rgba(255,255,255,.88);
  border-color:rgba(18,55,90,.18);
  box-shadow:0 22px 70px rgba(18,55,90,.14);
}
:root[data-theme="light"] .auth-card h2,
:root[data-theme="light"] .auth-card label,
:root[data-theme="light"] .auth-card p,
:root[data-theme="light"] .auth-card .sub{color:#102033!important}
:root[data-theme="light"] .auth-card .sub{color:#52677F!important}
:root[data-theme="light"] .auth-card .fld,
:root[data-theme="light"] .fld{
  background:#fff;
  color:#102033;
  border-color:rgba(18,55,90,.24);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.7);
}
:root[data-theme="light"] .auth-card .fld:focus,
:root[data-theme="light"] .fld:focus{
  background:#fff;
  border-color:var(--cyan);
  box-shadow:0 0 0 3px rgba(4,127,179,.13);
}
:root[data-theme="light"] .notice.ok{
  color:#057A55;
  background:rgba(10,168,117,.10);
  border-color:rgba(10,168,117,.42);
}
:root[data-theme="light"] .notice.err{
  color:#9A6400;
  background:rgba(243,182,26,.13);
  border-color:rgba(243,182,26,.44);
}
.kpi-link{display:block;text-decoration:none;color:inherit;cursor:pointer;transition:.18s ease}
.kpi-link:hover{border-color:var(--cyan);transform:translateY(-2px);box-shadow:0 14px 34px rgba(0,184,255,.12)}
.kpi-hint{margin-top:7px;font-size:11px;color:var(--cyan);font-weight:700}
.order-success{margin-bottom:22px;font-size:15px;line-height:1.5}
.dl-list li{padding:0!important}
.dl-download{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;width:100%;padding:11px 0;color:inherit;text-decoration:none}
.dl-download:hover .name{color:var(--cyan)}
.dl-download .ext{font-family:'JetBrains Mono',monospace;color:var(--cyan);font-size:11px}
button:disabled{cursor:wait;filter:saturate(.85)}
:root[data-theme="light"] .table td{color:#102033}
:root[data-theme="dark"] .table td{color:var(--text)}


/* Fix: interactieve knoppen/links binnen kaarten moeten altijd klikbaar blijven.
   De hover-glow van .card::before lag visueel over de inhoud heen. */
.card > *{position:relative;z-index:1}
.card::before{pointer-events:none!important}
.product-card a,.product-card button,.product-card form{position:relative;z-index:3;pointer-events:auto}
.product-cards{align-items:stretch}
.product-card{display:flex;flex-direction:column;min-height:100%}
.product-card .product-actions{margin-top:auto;display:flex;gap:10px;flex-wrap:wrap;padding-top:16px}
.product-card form{margin:0}


/* ===== Cookie consent ===== */
.cookie-consent{position:fixed;inset:auto 18px 18px 18px;z-index:9999;display:flex;justify-content:center;pointer-events:none}
.cookie-consent[hidden]{display:none!important}.cookie-card{width:min(980px,100%);pointer-events:auto;border:1px solid var(--line-strong);border-radius:22px;background:rgba(5,12,22,.96);box-shadow:0 24px 90px rgba(0,0,0,.42);padding:20px;display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;backdrop-filter:blur(18px)}
.cookie-main h2{font-size:19px;margin:0 0 8px}.cookie-main p{margin:0 0 8px;color:var(--muted);line-height:1.55;font-size:14px}.cookie-main a{color:var(--cyan);font-size:13px;text-decoration:none}.cookie-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap}.cookie-settings{grid-column:1/-1;border-top:1px solid var(--line);padding-top:14px;display:grid;gap:12px}.cookie-settings[hidden]{display:none!important}.cookie-row{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;border:1px solid var(--line);border-radius:14px;padding:12px;background:rgba(255,255,255,.025);cursor:pointer}.cookie-row.disabled{opacity:.8;cursor:not-allowed}.cookie-row input{margin-top:3px;inline-size:18px;block-size:18px}.cookie-row b{display:block;margin-bottom:3px}.cookie-row small{display:block;color:var(--muted);line-height:1.45}.cookie-open{position:fixed;left:16px;bottom:16px;z-index:9998;border:1px solid var(--line-strong);border-radius:999px;background:rgba(5,12,22,.9);color:var(--text);padding:9px 12px;font-size:12px;cursor:pointer;box-shadow:0 10px 30px rgba(0,0,0,.25)}.cookie-open[hidden]{display:none!important}:root[data-theme="light"] .cookie-card{background:rgba(255,255,255,.97);box-shadow:0 24px 80px rgba(18,55,90,.18)}:root[data-theme="light"] .cookie-row{background:rgba(4,127,179,.035)}:root[data-theme="light"] .cookie-open{background:rgba(255,255,255,.94);color:#102033}
@media(max-width:820px){.cookie-card{grid-template-columns:1fr}.cookie-actions{justify-content:stretch}.cookie-actions .btn{flex:1 1 150px;text-align:center}.cookie-consent{inset:auto 10px 10px 10px}.cookie-open{left:10px;bottom:10px}}

/* ===== Legal content pages ===== */
.legal-page{padding:70px 0}.legal-card{max-width:920px;margin:0 auto;border:1px solid var(--line);border-radius:24px;background:rgba(5,12,22,.45);padding:clamp(22px,4vw,44px);line-height:1.7}.legal-card h1{margin-top:0}.legal-card h2{margin-top:28px}.legal-card p,.legal-card li{color:var(--muted)}.legal-card a{color:var(--cyan)}:root[data-theme="light"] .legal-card{background:rgba(255,255,255,.72)}
