/* ============ RODS DESIGN SYSTEM ============ */
:root{
  --pine:#0E2018;
  --pine-2:#14291C;
  --bone:#F2EFE6;
  --bone-2:#E9E5D8;
  --ink:#122218;
  --signal:#43E08A;
  --signal-deep:#1B7A4B;
  --amber:#E8A33D;
  --line-dark:rgba(242,239,230,.12);
  --line-light:rgba(18,34,24,.14);
  --disp:'Bricolage Grotesque',sans-serif;
  --body:'Archivo',sans-serif;
  --mono:'JetBrains Mono',monospace;
  --gut:clamp(20px,5vw,72px);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--pine);color:var(--bone);-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--signal);color:var(--pine)}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--signal);outline-offset:3px;border-radius:2px}
img{max-width:100%}

/* ============ CURSOR ============ */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;transform:translate(-50%,-50%);display:none}
@media (pointer:fine){
  .cursor-dot,.cursor-ring{display:block}
  .cursor-dot{width:6px;height:6px;background:var(--signal)}
  .cursor-ring{width:34px;height:34px;border:1px solid rgba(67,224,138,.5);transition:width .25s,height .25s,border-color .25s,background .25s}
  body.cursor-hover .cursor-ring{width:64px;height:64px;border-color:rgba(67,224,138,.9);background:rgba(67,224,138,.08)}
}

/* ============ NAV ============ */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:18px var(--gut);transition:background .4s,backdrop-filter .4s}
nav.scrolled{background:rgba(14,32,24,.78);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-dark)}
.logo{font-family:var(--disp);font-weight:800;font-size:22px;letter-spacing:-.02em;display:flex;align-items:center;gap:10px;z-index:102}
.logo .dot{width:9px;height:9px;border-radius:50%;background:var(--signal);box-shadow:0 0 14px var(--signal);animation:blink 3.2s infinite}
@keyframes blink{0%,92%,100%{opacity:1}96%{opacity:.25}}
.nav-links{display:flex;gap:30px;font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.nav-links a{position:relative;padding:4px 0;opacity:.75;transition:opacity .25s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--signal);transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.65,0,.35,1)}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);transform-origin:left}
.nav-links a.active{opacity:1;color:var(--signal)}
.nav-cta{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--signal);color:var(--signal);padding:10px 18px;border-radius:999px;transition:background .3s,color .3s;z-index:102}
.nav-cta:hover{background:var(--signal);color:var(--pine)}
.burger{display:none;z-index:102;background:none;border:none;cursor:pointer;width:40px;height:40px;position:relative}
.burger span{position:absolute;left:8px;right:8px;height:2px;background:var(--bone);transition:transform .35s,opacity .25s,top .35s}
.burger span:nth-child(1){top:14px}
.burger span:nth-child(2){top:20px}
.burger span:nth-child(3){top:26px}
body.menu-open .burger span:nth-child(1){top:20px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){top:20px;transform:rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;background:var(--pine);z-index:101;display:flex;flex-direction:column;justify-content:center;padding:0 var(--gut);gap:8px;opacity:0;pointer-events:none;transition:opacity .35s}
body.menu-open .mobile-menu{opacity:1;pointer-events:auto}
.mobile-menu a{font-family:var(--disp);font-weight:700;font-size:clamp(30px,8vw,44px);letter-spacing:-.02em;padding:8px 0;border-bottom:1px solid var(--line-dark);display:flex;justify-content:space-between;align-items:center}
.mobile-menu a span{font-family:var(--mono);font-size:12px;color:var(--signal);font-weight:400}
.mobile-menu a.active{color:var(--signal)}
@media(max-width:960px){.nav-links,.nav-cta{display:none}.burger{display:block}}

/* ============ BUTTONS ============ */
.btn{font-family:var(--mono);font-size:13px;letter-spacing:.1em;text-transform:uppercase;padding:16px 30px;border-radius:999px;display:inline-flex;align-items:center;gap:10px;position:relative;overflow:hidden;transition:color .35s;will-change:transform;cursor:pointer;border:none;background:none}
.btn span{position:relative;z-index:1}
.btn-solid{background:var(--signal);color:var(--pine)}
.btn-solid::before{content:'';position:absolute;inset:0;background:var(--bone);transform:translateY(101%);transition:transform .4s cubic-bezier(.65,0,.35,1);border-radius:inherit}
.btn-solid:hover::before{transform:translateY(0)}
.btn-ghost{border:1px solid var(--line-dark);color:var(--bone)}
.btn-ghost:hover{border-color:var(--signal);color:var(--signal)}
.btn-dark{background:var(--pine);color:var(--bone)}
.btn-dark::before{content:'';position:absolute;inset:0;background:var(--signal);transform:translateY(101%);transition:transform .4s cubic-bezier(.65,0,.35,1);border-radius:inherit}
.btn-dark:hover::before{transform:translateY(0)}
.btn-dark:hover{color:var(--pine)}
.btn-outline{border:1px solid var(--line-light);color:var(--ink)}
.btn-outline:hover{border-color:var(--signal-deep);color:var(--signal-deep)}
.btn-amber{border:1px solid var(--amber);color:var(--amber)}
.btn-amber:hover{background:var(--amber);color:var(--pine)}

/* ============ HERO (home) ============ */
header.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
#field{position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse at 50% 70%,#14291C,#0E2018)}
.hero-grad{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(14,32,24,.25) 0%,rgba(14,32,24,0) 35%,rgba(14,32,24,.88) 100%);pointer-events:none}
.hero-inner{position:relative;z-index:2;width:100%;padding:0 var(--gut) clamp(48px,9vh,110px)}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--signal);display:flex;align-items:center;gap:14px;margin-bottom:26px}
.eyebrow::before{content:'';width:36px;height:1px;background:var(--signal);flex-shrink:0}
h1{font-family:var(--disp);font-weight:800;font-size:clamp(42px,8.2vw,118px);line-height:.96;letter-spacing:-.03em;max-width:13ch}
h1 .accent{color:var(--signal);font-style:normal}
h1 .word{display:inline-block;overflow:hidden;vertical-align:bottom}
h1 .word>span{display:inline-block;transform:translateY(110%)}
.hero-sub{margin-top:30px;max-width:48ch;font-size:clamp(15px,1.5vw,18px);line-height:1.65;color:rgba(242,239,230,.78)}
.hero-ctas{display:flex;gap:16px;margin-top:40px;flex-wrap:wrap}
.scroll-cue{position:absolute;right:var(--gut);bottom:clamp(48px,9vh,110px);z-index:2;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(242,239,230,.5);writing-mode:vertical-rl;display:flex;align-items:center;gap:12px}
.scroll-cue::after{content:'';width:1px;height:54px;background:linear-gradient(var(--signal),transparent);animation:drip 2s infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}55%{transform:scaleY(1);transform-origin:top}56%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media(max-width:700px){.scroll-cue{display:none}}

/* ============ PAGE HERO (subpages) ============ */
.page-hero{position:relative;padding:clamp(140px,22vh,220px) var(--gut) clamp(50px,8vh,90px);overflow:hidden}
.page-hero h1{font-size:clamp(40px,6.6vw,92px);max-width:16ch}
.page-hero .hero-sub{max-width:56ch}
.page-hero .rings{position:absolute;top:-120px;right:-120px;width:480px;height:480px;opacity:.5;pointer-events:none}
.page-hero .rings circle{fill:none;stroke:var(--signal);stroke-width:1;opacity:.16;transform-origin:center;animation:ringpulse 4.5s ease-out infinite}
.page-hero .rings circle:nth-child(2){animation-delay:1.1s}
.page-hero .rings circle:nth-child(3){animation-delay:2.2s}
.page-hero .rings circle:nth-child(4){animation-delay:3.3s}
@keyframes ringpulse{0%{transform:scale(.4);opacity:.35}100%{transform:scale(1.15);opacity:0}}
.crumb{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(242,239,230,.5);margin-bottom:22px;display:block}
.crumb a:hover{color:var(--signal)}

/* ============ MARQUEE ============ */
.marquee{border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark);overflow:hidden;padding:20px 0;background:var(--pine-2)}
.marquee-track{display:flex;width:max-content;animation:scrollX 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--disp);font-weight:600;font-size:clamp(16px,2vw,22px);letter-spacing:-.01em;white-space:nowrap;padding:0 18px;color:rgba(242,239,230,.85)}
.marquee-track i{font-style:normal;color:var(--signal)}
@keyframes scrollX{to{transform:translateX(-50%)}}

/* ============ SECTIONS ============ */
section{position:relative}
.sec-light{background:var(--bone);color:var(--ink)}
.sec-light .label{color:var(--signal-deep)}
.sec-dark{background:var(--pine);color:var(--bone)}
.sec-dark2{background:var(--pine-2);color:var(--bone)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;padding:clamp(70px,11vh,130px) var(--gut) clamp(36px,6vh,64px);flex-wrap:wrap}
.sec-head h2,.h2{font-family:var(--disp);font-weight:800;font-size:clamp(34px,5.4vw,72px);letter-spacing:-.03em;line-height:1.02;max-width:16ch}
.sec-head p{max-width:38ch;font-size:15px;line-height:1.7;opacity:.72}
.label{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--signal);display:block;margin-bottom:18px}
.pad{padding:0 var(--gut) clamp(80px,12vh,140px)}

/* ============ CARD GRID ============ */
.grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line-light);border-left:1px solid var(--line-light)}
.grid.g3{grid-template-columns:repeat(3,1fr)}
@media(max-width:1100px){.grid,.grid.g3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid,.grid.g3{grid-template-columns:1fr}}
.card{position:relative;border-right:1px solid var(--line-light);border-bottom:1px solid var(--line-light);padding:34px 28px 30px;min-height:290px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;color:var(--ink)}
a.card{cursor:pointer}
.card::before{content:'';position:absolute;inset:0;background:var(--pine);transform:translateY(101%);transition:transform .45s cubic-bezier(.65,0,.35,1)}
.card:hover::before{transform:translateY(0)}
.card>*{position:relative;z-index:1;transition:color .35s}
.card svg{width:42px;height:42px;stroke:var(--signal-deep);fill:none;stroke-width:1.4;transition:stroke .35s,transform .45s cubic-bezier(.34,1.56,.64,1)}
.card:hover svg{stroke:var(--signal);transform:translateY(-4px) rotate(-4deg)}
.card h3{font-family:var(--disp);font-weight:700;font-size:21px;letter-spacing:-.01em;margin:20px 0 10px}
.card p{font-size:14px;line-height:1.65;opacity:.72}
.card:hover h3,.card:hover p{color:var(--bone)}
.card:hover p{opacity:.8}
.card .arrow{position:absolute;top:26px;right:24px;font-family:var(--mono);font-size:13px;color:var(--signal-deep);opacity:0;transform:translate(-8px,8px);transition:all .35s .08s;z-index:1}
.card:hover .arrow{opacity:1;transform:translate(0,0);color:var(--signal)}
.card .tag{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin-top:14px;display:inline-block}

/* dark variant cards */
.sec-dark .grid,.sec-dark2 .grid{border-color:var(--line-dark)}
.sec-dark .card,.sec-dark2 .card{border-color:var(--line-dark);color:var(--bone)}
.sec-dark .card::before,.sec-dark2 .card::before{background:var(--signal)}
.sec-dark .card:hover h3,.sec-dark .card:hover p,.sec-dark2 .card:hover h3,.sec-dark2 .card:hover p{color:var(--pine)}
.sec-dark .card svg,.sec-dark2 .card svg{stroke:var(--signal)}
.sec-dark .card:hover svg,.sec-dark2 .card:hover svg{stroke:var(--pine)}
.sec-dark .card .arrow,.sec-dark2 .card .arrow{color:var(--signal)}
.sec-dark .card:hover .arrow,.sec-dark2 .card:hover .arrow{color:var(--pine)}

/* ============ SIGNAAL ============ */
.signal-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,90px);align-items:center;padding:clamp(80px,13vh,150px) var(--gut)}
@media(max-width:900px){.signal-wrap{grid-template-columns:1fr}}
.signal-art{position:relative;aspect-ratio:1;max-width:520px;margin:0 auto;width:100%}
.signal-art svg{width:100%;height:100%;overflow:visible}
.signal-art .ring{fill:none;stroke:var(--signal);stroke-width:1.2;opacity:.18;transform-origin:center}
.signal-art .core{fill:var(--signal);filter:drop-shadow(0 0 18px var(--signal))}
.signal-copy h2{font-family:var(--disp);font-weight:800;font-size:clamp(34px,4.8vw,62px);letter-spacing:-.03em;line-height:1.04;margin-bottom:24px}
.signal-copy p{font-size:16px;line-height:1.75;color:rgba(242,239,230,.78);margin-bottom:18px;max-width:52ch}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-dark);border:1px solid var(--line-dark);margin-top:40px}
.stat{background:var(--pine);padding:26px 20px}
.stat b{display:block;font-family:var(--disp);font-weight:800;font-size:clamp(30px,3.4vw,46px);letter-spacing:-.02em;color:var(--signal)}
.stat span{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.6;display:block;margin-top:8px;line-height:1.5}
@media(max-width:560px){.stats{grid-template-columns:1fr}}

/* ============ TIJDLIJN / STAPPEN ============ */
.timeline{position:relative;margin:0 var(--gut) clamp(90px,13vh,160px);padding-left:clamp(28px,4vw,48px)}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--line-light)}
.sec-dark .timeline::before,.sec-dark2 .timeline::before{background:var(--line-dark)}
.timeline .progress{position:absolute;left:0;top:0;width:2px;height:100%;background:var(--signal);transform:scaleY(0);transform-origin:top}
.t-item{position:relative;padding:clamp(24px,3.6vh,40px) 0;max-width:680px}
.t-item::before{content:'';position:absolute;left:calc(-1*clamp(28px,4vw,48px) - 6px);top:calc(clamp(24px,3.6vh,40px) + 10px);width:14px;height:14px;border-radius:50%;background:var(--bone);border:2px solid var(--signal-deep);transition:background .3s,box-shadow .3s}
.sec-dark .t-item::before,.sec-dark2 .t-item::before{background:var(--pine);border-color:var(--signal)}
.t-item.active::before{background:var(--signal);border-color:var(--signal);box-shadow:0 0 16px rgba(67,224,138,.7)}
.t-item .year{font-family:var(--mono);font-size:13px;letter-spacing:.18em;color:var(--signal-deep)}
.sec-dark .t-item .year,.sec-dark2 .t-item .year{color:var(--signal)}
.t-item h3{font-family:var(--disp);font-weight:700;font-size:clamp(22px,2.8vw,34px);letter-spacing:-.02em;margin:10px 0 12px}
.t-item p,.t-item ul{font-size:15px;line-height:1.7;opacity:.78;max-width:54ch}
.t-item ul{padding-left:20px;margin-top:8px}
.t-item li{margin-bottom:6px}

/* ============ RON ============ */
.ron-wrap{padding:clamp(90px,14vh,170px) var(--gut);display:grid;grid-template-columns:auto 1fr;gap:clamp(36px,6vw,80px);align-items:center;max-width:1200px;margin:0 auto}
@media(max-width:800px){.ron-wrap{grid-template-columns:1fr}}
.ron-mark{width:clamp(120px,16vw,190px);height:clamp(120px,16vw,190px);border-radius:50%;border:1.5px solid var(--amber);display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.ron-mark::before{content:'';position:absolute;inset:-16px;border-radius:50%;border:1px dashed rgba(232,163,61,.4);animation:spin 26s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ron-mark b{font-family:var(--disp);font-weight:800;font-size:clamp(34px,5vw,56px);color:var(--amber);letter-spacing:-.02em}
.ron-quote blockquote{font-family:var(--disp);font-weight:600;font-size:clamp(22px,3.1vw,38px);line-height:1.3;letter-spacing:-.015em}
.ron-quote blockquote em{font-style:normal;color:var(--amber)}
.ron-quote figcaption{margin-top:26px;font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(242,239,230,.6)}
.ron-quote figcaption b{color:var(--amber);font-weight:500}

/* ============ AI BRIDGE ============ */
.ai-bridge{background:linear-gradient(135deg,var(--pine) 0%,#0F2A1E 60%,#142E14 100%);border-top:1px solid var(--line-dark);overflow:hidden;position:relative}
.ai-bridge::after{content:'';position:absolute;right:-180px;top:50%;transform:translateY(-50%);width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(67,224,138,.12),transparent 65%);pointer-events:none}
.ai-wrap{padding:clamp(80px,13vh,150px) var(--gut);display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center;position:relative;z-index:1}
@media(max-width:900px){.ai-wrap{grid-template-columns:1fr}}
.ai-wrap h2{font-family:var(--disp);font-weight:800;font-size:clamp(32px,4.6vw,58px);letter-spacing:-.03em;line-height:1.05;margin-bottom:22px}
.ai-wrap h2 .x{color:var(--signal)}
.ai-wrap p{font-size:16px;line-height:1.75;color:rgba(242,239,230,.78);margin-bottom:16px;max-width:50ch}
.ai-list{list-style:none;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line-dark)}
.ai-list li{display:flex;align-items:baseline;gap:18px;padding:20px 4px;border-bottom:1px solid var(--line-dark);transition:padding-left .3s,background .3s}
.ai-list li:hover{padding-left:16px;background:rgba(67,224,138,.05)}
.ai-list .k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--signal);flex-shrink:0;width:120px;text-transform:uppercase}
.ai-list .v{font-size:15px;line-height:1.6;opacity:.85}

/* ============ TOOLS ============ */
.tools{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding:0 var(--gut) clamp(80px,12vh,140px)}
@media(max-width:900px){.tools{grid-template-columns:1fr}}
.tool{border:1px solid var(--line-light);border-radius:18px;padding:30px 28px;position:relative;overflow:hidden;transition:transform .35s cubic-bezier(.34,1.4,.64,1),box-shadow .35s,border-color .35s;background:var(--bone)}
.sec-dark .tool,.sec-dark2 .tool{border-color:var(--line-dark);background:var(--pine-2)}
.tool:hover{transform:translateY(-6px);border-color:var(--signal-deep);box-shadow:0 18px 44px -18px rgba(18,34,24,.35)}
.tool .free{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--pine);background:var(--signal);padding:5px 12px;border-radius:999px;display:inline-block;margin-bottom:18px}
.tool h3{font-family:var(--disp);font-weight:700;font-size:20px;margin-bottom:10px}
.tool p{font-size:14px;line-height:1.65;opacity:.72;margin-bottom:20px}
.tool .go{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--signal-deep);display:inline-flex;gap:8px;align-items:center}
.tool:hover .go{color:var(--signal-deep)}
.tool .go::after{content:'→';transition:transform .3s}
.tool:hover .go::after{transform:translateX(5px)}

/* ============ PRICING ============ */
.pricing{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:0 var(--gut) 30px}
@media(max-width:1100px){.pricing{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.pricing{grid-template-columns:1fr}}
.price-card{border:1px solid var(--line-light);border-radius:18px;padding:32px 28px;display:flex;flex-direction:column;transition:transform .35s,border-color .35s,box-shadow .35s;background:#fff;position:relative}
.price-card:hover{transform:translateY(-6px);border-color:var(--signal-deep);box-shadow:0 18px 44px -18px rgba(18,34,24,.3)}
.price-card.featured{border-color:var(--signal-deep);background:var(--pine);color:var(--bone)}
.price-card.featured .price-list li{border-color:var(--line-dark)}
.price-card .pname{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--signal-deep);margin-bottom:14px}
.price-card.featured .pname{color:var(--signal)}
.price-card .pprice{font-family:var(--disp);font-weight:800;font-size:40px;letter-spacing:-.02em}
.price-card .pprice small{font-size:14px;font-weight:400;opacity:.6;font-family:var(--body)}
.price-list{list-style:none;margin:24px 0 28px;flex:1}
.price-list li{font-size:13.5px;line-height:1.5;padding:9px 0 9px 24px;border-bottom:1px solid var(--line-light);position:relative;opacity:.85}
.price-list li::before{content:'✓';position:absolute;left:0;color:var(--signal-deep);font-weight:700}
.price-card.featured .price-list li::before{color:var(--signal)}
.fyne{font-family:var(--mono);font-size:11px;opacity:.55;padding:14px var(--gut) clamp(70px,10vh,120px);letter-spacing:.06em}

/* ============ PROSE / CONTENT PAGES ============ */
.prose{max-width:760px;margin:0 auto;padding:0 var(--gut) clamp(80px,12vh,150px)}
.prose-wide{max-width:980px}
.prose h2{font-family:var(--disp);font-weight:700;font-size:clamp(24px,3vw,34px);letter-spacing:-.02em;margin:48px 0 16px}
.prose h3{font-family:var(--disp);font-weight:600;font-size:19px;margin:32px 0 10px}
.prose p,.prose li{font-size:15.5px;line-height:1.8;opacity:.85;margin-bottom:14px}
.prose ul,.prose ol{padding-left:22px;margin-bottom:16px}
.prose li{margin-bottom:6px}
.prose a{color:var(--signal);border-bottom:1px solid rgba(67,224,138,.35);transition:border-color .25s}
.prose a:hover{border-color:var(--signal)}
.sec-light .prose a{color:var(--signal-deep);border-color:rgba(27,122,75,.35)}
.sec-light .prose a:hover{border-color:var(--signal-deep)}
.prose .meta{font-family:var(--mono);font-size:12px;letter-spacing:.12em;opacity:.55;margin-bottom:30px}

/* ============ INFO PANELS / TABLES ============ */
.panel{border:1px solid var(--line-dark);border-radius:18px;padding:30px;background:var(--pine-2);margin:26px 0}
.sec-light .panel{border-color:var(--line-light);background:#fff}
.panel h3{font-family:var(--disp);font-weight:700;font-size:19px;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.panel h3::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--signal);box-shadow:0 0 10px var(--signal)}
.kv{display:grid;grid-template-columns:auto 1fr;gap:10px 24px;font-size:14.5px;line-height:1.6}
.kv dt{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--signal);padding-top:2px;white-space:nowrap}
.sec-light .kv dt{color:var(--signal-deep)}
.kv dd{opacity:.85}
@media(max-width:560px){.kv{grid-template-columns:1fr}.kv dd{margin-bottom:8px}}
table.ports{width:100%;border-collapse:collapse;margin:18px 0;font-size:14px}
table.ports th{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;text-align:left;padding:12px 14px;border-bottom:2px solid var(--signal-deep);color:var(--signal-deep)}
table.ports td{padding:12px 14px;border-bottom:1px solid var(--line-light);line-height:1.5;vertical-align:top}
table.ports .ok{color:var(--signal-deep);font-weight:600}
table.ports .no{color:#B4543A;font-weight:600}
.sec-dark table.ports td,.sec-dark2 table.ports td{border-color:var(--line-dark)}
.sec-dark table.ports th{color:var(--signal);border-color:var(--signal)}
.sec-dark table.ports .ok{color:var(--signal)}

/* split two-col feature list */
.feature-cols{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(30px,5vw,70px);padding:0 var(--gut) clamp(80px,12vh,140px);max-width:1200px}
@media(max-width:760px){.feature-cols{grid-template-columns:1fr}}
.feature{display:flex;gap:18px;padding:24px 0;border-bottom:1px solid var(--line-light)}
.sec-dark .feature,.sec-dark2 .feature{border-color:var(--line-dark)}
.feature .ico{width:38px;height:38px;flex-shrink:0;border-radius:10px;background:var(--signal-deep);color:var(--bone);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:14px}
.sec-dark .feature .ico,.sec-dark2 .feature .ico{background:rgba(67,224,138,.14);color:var(--signal)}
.feature h3{font-family:var(--disp);font-weight:700;font-size:17px;margin-bottom:6px}
.feature p{font-size:14px;line-height:1.65;opacity:.72}

/* domain price chips */
.domains{display:flex;flex-wrap:wrap;gap:12px;padding:0 var(--gut) clamp(70px,10vh,120px)}
.domain{font-family:var(--mono);font-size:13px;border:1px solid var(--line-light);border-radius:999px;padding:12px 20px;transition:border-color .3s,transform .3s;background:#fff}
.domain b{color:var(--signal-deep);margin-right:8px}
.domain:hover{border-color:var(--signal-deep);transform:translateY(-3px)}

/* ============ CONTACT ============ */
.contact-wrap{padding:clamp(100px,15vh,180px) var(--gut) clamp(70px,10vh,120px);text-align:center}
.contact-wrap h2{font-family:var(--disp);font-weight:800;font-size:clamp(44px,9vw,130px);letter-spacing:-.035em;line-height:.98}
.contact-wrap h2 a{position:relative;display:inline-block;transition:color .3s}
.contact-wrap h2 a:hover{color:var(--signal-deep)}
.contact-sub{margin:30px auto 46px;max-width:46ch;font-size:16px;line-height:1.7;opacity:.75}
.contact-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.contact-details{display:flex;justify-content:center;gap:clamp(28px,5vw,70px);flex-wrap:wrap;margin-top:clamp(60px,9vh,100px);padding-top:44px;border-top:1px solid var(--line-light);font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;line-height:2;opacity:.85;text-align:left}
.contact-details b{display:block;letter-spacing:.2em;text-transform:uppercase;font-size:11px;color:var(--signal-deep);margin-bottom:6px;font-weight:500}

/* ============ PARTNERS ============ */
.partners{background:var(--pine);border-top:1px solid var(--line-dark);padding:54px 0;overflow:hidden}
.partners .p-label{text-align:center;font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;opacity:.45;margin-bottom:28px}
.p-track{display:flex;width:max-content;animation:scrollX 36s linear infinite}
.p-track span{font-family:var(--disp);font-weight:600;font-size:18px;color:rgba(242,239,230,.4);padding:0 34px;white-space:nowrap;transition:color .3s}
.p-track span:hover{color:var(--signal)}

/* ============ FOOTER ============ */
footer{background:var(--pine);border-top:1px solid var(--line-dark);padding:clamp(50px,8vh,80px) var(--gut) 30px}
.f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(28px,4vw,60px);padding-bottom:46px}
@media(max-width:900px){.f-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.f-grid{grid-template-columns:1fr}}
.f-grid h4{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--signal);margin-bottom:18px;font-weight:500}
.f-grid a,.f-grid p{display:block;font-size:14px;line-height:1.6;opacity:.65;margin-bottom:10px;transition:opacity .25s,color .25s}
.f-grid a:hover{opacity:1;color:var(--signal)}
.f-brand{font-family:var(--disp);font-weight:800;font-size:24px;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.f-bottom{border-top:1px solid var(--line-dark);padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;color:rgba(242,239,230,.45)}
.f-bottom a:hover{color:var(--signal)}

/* ============ CTA BAND ============ */
.cta-band{background:var(--bone);color:var(--ink);text-align:center;padding:clamp(80px,12vh,140px) var(--gut)}
.cta-band .label{color:var(--signal-deep)}
.cta-band h2{font-family:var(--disp);font-weight:800;font-size:clamp(36px,6.5vw,84px);letter-spacing:-.03em;line-height:1;margin-bottom:26px}
.cta-band p{max-width:46ch;margin:0 auto 36px;font-size:16px;line-height:1.7;opacity:.75}
.cta-band .contact-ctas{justify-content:center}

/* ============ REVEALS ============ */
.rv{opacity:0;transform:translateY(36px)}
.no-js .rv{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important}
  .rv{opacity:1;transform:none}
  h1 .word>span{transform:none}
}

/* ============ MOBILE POLISH ============ */
@media(max-width:700px){
  nav{padding:14px 20px}
  nav.scrolled,body.menu-open nav{background:rgba(14,32,24,.92);backdrop-filter:blur(14px)}
  header.hero{min-height:100svh}
  .hero-inner{padding-top:118px;padding-bottom:54px}
  .eyebrow{font-size:10px;letter-spacing:.12em;line-height:1.8;margin-bottom:18px;flex-wrap:wrap}
  .eyebrow::before{width:24px}
  h1{font-size:clamp(38px,11.5vw,52px);letter-spacing:-.025em}
  .hero-sub{margin-top:22px;font-size:15px}
  .hero-ctas{flex-direction:column;align-items:stretch;margin-top:30px}
  .hero-ctas .btn,.contact-ctas .btn{justify-content:center;text-align:center}
  .contact-ctas{flex-direction:column;align-items:stretch}
  .page-hero{padding-top:118px;padding-bottom:44px}
  .page-hero .rings{width:300px;height:300px;top:-90px;right:-90px;opacity:.35}
  .sec-head{padding-top:54px;padding-bottom:28px;gap:18px}
  .sec-head p{max-width:none}
  .card{min-height:0;padding:26px 22px 24px}
  .card h3{font-size:19px}
  .feature{padding:20px 0}
  .signal-wrap{padding-top:64px;padding-bottom:64px;gap:34px}
  .signal-art{max-width:300px}
  .stat{padding:20px 18px}
  .timeline{padding-left:26px}
  .t-item::before{left:-32px}
  .ron-wrap{padding-top:70px;padding-bottom:70px;gap:30px;justify-items:start}
  .contact-wrap{padding-top:80px}
  .contact-details{flex-direction:column;gap:24px;align-items:flex-start}
  .pricing{gap:14px}
  .price-card{padding:26px 22px}
  .panel{padding:24px 20px}
  .prose{padding-left:20px;padding-right:20px}
  table.ports{font-size:13px}
  table.ports th,table.ports td{padding:10px 8px}
  .tools{gap:14px}
  .f-grid{gap:26px}
  .marquee-track span{font-size:15px}
  .mobile-menu{padding-top:90px;justify-content:flex-start;gap:4px}
  .mobile-menu a{font-size:clamp(26px,7.5vw,36px);padding:14px 0}
  .mobile-menu .mm-cta{margin-top:28px;border-bottom:none;font-family:var(--mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;background:var(--signal);color:var(--pine);border-radius:999px;padding:18px 26px;justify-content:center}
}
@media(max-width:380px){
  h1{font-size:34px}
  .logo{font-size:19px}
}

/* ============ TRUST STRIP ============ */
.trust-strip{background:var(--pine-2);border-bottom:1px solid var(--line-dark)}
.trust-inner{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-dark)}
.trust-item{background:var(--pine-2);padding:22px var(--gut);font-family:var(--mono);font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:rgba(242,239,230,.65);display:flex;align-items:center;gap:10px;line-height:1.4}
.trust-item b{color:var(--signal);font-weight:600;font-family:var(--disp);font-size:18px;letter-spacing:-.01em;text-transform:none}
.trust-item::before{content:'✓';color:var(--signal-deep);font-weight:700;flex-shrink:0}
@media(max-width:900px){.trust-inner{grid-template-columns:1fr 1fr}.trust-item{padding:18px 22px}}
@media(max-width:480px){.trust-inner{grid-template-columns:1fr}}

/* ============ RON INTRO ============ */
.ron-intro{max-width:1200px;margin:0 auto;padding:clamp(80px,13vh,150px) var(--gut);display:grid;grid-template-columns:auto 1fr;gap:clamp(40px,6vw,80px);align-items:center}
@media(max-width:820px){.ron-intro{grid-template-columns:1fr;gap:36px}}
.ron-photo{position:relative;width:clamp(180px,24vw,280px);aspect-ratio:1;flex-shrink:0}
.ron-photo img{width:100%;height:100%;object-fit:cover;border-radius:24px;position:relative;z-index:1}
.ron-photo-ph{width:100%;height:100%;border-radius:24px;background:linear-gradient(140deg,var(--pine),#0c1a13);border:1px solid var(--line-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;position:relative;z-index:1}
.ron-photo-ph b{font-family:var(--disp);font-weight:800;font-size:clamp(48px,7vw,76px);color:var(--amber);letter-spacing:-.03em;line-height:1}
.ron-photo-ph span{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(242,239,230,.4)}
.ron-photo-ring{position:absolute;inset:-14px;border:1px dashed rgba(232,163,61,.4);border-radius:32px;animation:spin 30s linear infinite;z-index:0}
.ron-text .label{color:var(--amber)}
.ron-text h2{font-family:var(--disp);font-weight:800;font-size:clamp(34px,5vw,62px);letter-spacing:-.03em;line-height:1.02;margin-bottom:22px}
.ron-text>p{font-size:16px;line-height:1.75;color:rgba(242,239,230,.82);margin-bottom:20px;max-width:56ch}
.ron-quote-inline{font-family:var(--disp);font-weight:600;font-size:clamp(19px,2.4vw,26px);line-height:1.4;letter-spacing:-.01em;border-left:2px solid var(--amber);padding-left:22px;margin:26px 0;color:var(--bone)}
.ron-quote-inline em{font-style:normal;color:var(--amber)}
.ron-region{font-size:14.5px;line-height:1.7;color:rgba(242,239,230,.7)!important;max-width:56ch}
.ron-region b{color:var(--signal);font-weight:600;letter-spacing:.04em}

/* trust-strip klikbaar item */
a.trust-link{transition:background .3s,color .3s}
a.trust-link:hover{background:var(--pine);color:var(--signal)}
a.trust-link:hover b{color:var(--signal)}
