/* ============================================================
   TGK Consulting — shared stylesheet
   Aesthetic: dark editorial-tech · gold accent · serif + mono
   ============================================================ */

:root{
  --ink:        #0c0a08;
  --ink-2:      #15110d;
  --ink-3:      #1d1812;
  --ink-4:      #2a221a;
  --bone:       #f6efe3;
  --bone-mute:  #d6cdbf;
  --bone-dim:   #9a8f7d;
  --rule:       #2b231a;
  --gold:       #d4a017;
  --gold-2:     #e6c659;
  --gold-deep:  #8a6810;
  --sage:       #7ea88a;
  --signal:     #6ddc97;
  --rose:       #d97570;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--ink);color:var(--bone);font-family:'IBM Plex Sans',ui-sans-serif,system-ui,sans-serif;font-weight:400;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  background:
    radial-gradient(1200px 700px at 80% -10%, rgba(212,160,23,.10), transparent 60%),
    radial-gradient(900px 600px at -10% 30%, rgba(126,168,138,.05), transparent 60%),
    var(--ink);
  overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.045;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace;font-feature-settings:"calt" 0;letter-spacing:.02em}
.serif{font-family:'Fraunces',serif;font-optical-sizing:auto}
.ital{font-style:italic}
.container{max-width:1280px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--bone-dim)}
.gold{color:var(--gold)}
.gold-2{color:var(--gold-2)}

/* ====== top status bar ====== */
.topbar{
  border-bottom:1px solid var(--rule);
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;color:var(--bone-dim);
  background:rgba(12,10,8,.75);backdrop-filter:blur(8px);position:relative;z-index:5;
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;height:34px;gap:24px;flex-wrap:wrap}
.topbar-inner > div{display:flex;align-items:center;gap:18px}
.dot{width:7px;height:7px;border-radius:50%;background:var(--signal);box-shadow:0 0 0 0 rgba(109,220,151,.5);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(109,220,151,.55)}70%{box-shadow:0 0 0 9px rgba(109,220,151,0)}100%{box-shadow:0 0 0 0 rgba(109,220,151,0)}}
.topbar a:hover{color:var(--bone)}

/* ====== nav ====== */
nav.main{
  position:sticky;top:0;z-index:50;
  background:rgba(12,10,8,.78);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--rule);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:80px}
.brand{display:flex;align-items:center;gap:14px;font-weight:600;font-size:15px;letter-spacing:.04em}
.brand-mark{
  width:44px;height:44px;border-radius:50%;
  background:var(--ink);
  display:grid;place-items:center;overflow:hidden;
  box-shadow:0 0 0 1px var(--rule), 0 6px 18px -8px rgba(212,160,23,.4);
}
.brand-mark img{width:100%;height:100%;object-fit:cover;object-position:center}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text .b1{font-family:'Fraunces',serif;font-weight:500;font-size:18px;color:var(--bone);letter-spacing:.01em}
.brand-text .b2{font-family:'JetBrains Mono',monospace;font-size:9.5px;color:var(--bone-dim);letter-spacing:.18em;margin-top:5px;text-transform:uppercase}
.nav-links{display:flex;gap:30px;font-size:14px;color:var(--bone-mute)}
.nav-links a{position:relative;padding:6px 0;transition:color .2s}
.nav-links a:hover{color:var(--bone)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:width .25s ease}
.nav-links a:hover::after, .nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--gold)}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border:1px solid var(--rule);border-radius:999px;
  font-size:13px;color:var(--bone);transition:all .2s;background:var(--ink-2);
}
.nav-cta:hover{border-color:var(--gold);color:var(--gold)}
.nav-cta .arrow{display:inline-block;transition:transform .2s}
.nav-cta:hover .arrow{transform:translateX(3px)}
.hamburger{display:none}

/* ====== buttons (universal) ====== */
.btn{
  display:inline-flex;align-items:center;gap:10px;padding:15px 24px;border-radius:999px;
  font-size:14px;font-weight:500;letter-spacing:.01em;cursor:pointer;border:1px solid transparent;transition:all .25s;
}
.btn-primary{background:var(--gold);color:var(--ink);box-shadow:0 12px 30px -10px rgba(212,160,23,.45)}
.btn-primary:hover{background:var(--gold-2);transform:translateY(-1px);box-shadow:0 16px 36px -10px rgba(212,160,23,.6)}
.btn-ghost{color:var(--bone);border-color:var(--rule);background:transparent}
.btn-ghost:hover{border-color:var(--bone-mute);background:var(--ink-2)}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}
.ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* ====== hero (homepage) ====== */
.hero{padding:90px 0 60px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center}
.hero h1{
  font-family:'Fraunces',serif;font-weight:380;font-variation-settings:"opsz" 144;
  font-size:clamp(44px,6.4vw,92px);line-height:.98;letter-spacing:-.025em;margin:18px 0 28px;color:var(--bone);
}
.hero h1 em{font-style:italic;font-weight:300;color:var(--gold-2);font-variation-settings:"opsz" 144,"SOFT" 100}
.hero h1 .strike{position:relative;display:inline-block}
.hero h1 .strike::after{
  content:"";position:absolute;left:-4%;right:-4%;top:55%;height:6px;background:var(--gold);
  transform:rotate(-2deg);opacity:.85;
}
.hero-sub{font-size:18px;color:var(--bone-mute);max-width:560px;margin-bottom:36px;line-height:1.6}
.hero-sub strong{color:var(--bone);font-weight:500}
.hero-meta{display:flex;gap:32px;margin-top:48px;padding-top:28px;border-top:1px solid var(--rule);flex-wrap:wrap}
.hero-meta div{display:flex;flex-direction:column;gap:4px}
.hero-meta .label{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--bone-dim)}
.hero-meta .val{font-family:'Fraunces',serif;font-size:22px;color:var(--bone);font-variation-settings:"opsz" 36}

/* ====== page hero (interior pages) ====== */
.page-hero{padding:90px 0 80px;position:relative;border-bottom:1px solid var(--rule)}
.page-hero .eyebrow{margin-bottom:18px}
.page-hero h1{
  font-family:'Fraunces',serif;font-weight:380;font-variation-settings:"opsz" 144;
  font-size:clamp(40px,5.5vw,80px);line-height:1.0;letter-spacing:-.025em;margin:0 0 28px;color:var(--bone);max-width:1000px;
}
.page-hero h1 em{font-style:italic;color:var(--gold-2);font-weight:300}
.page-hero .lede{font-size:19px;color:var(--bone-mute);max-width:680px;line-height:1.6}

/* ====== terminal mockup ====== */
.terminal{
  background:linear-gradient(180deg,var(--ink-2),var(--ink-3));
  border:1px solid var(--rule);border-radius:14px;overflow:hidden;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.6), 0 0 0 1px rgba(212,160,23,.04);
  position:relative;font-family:'JetBrains Mono',monospace;font-size:12.5px;line-height:1.65;
  transform:rotate(.5deg);
}
.terminal::before{
  content:"";position:absolute;inset:-1px;border-radius:14px;padding:1px;pointer-events:none;
  background:linear-gradient(180deg,rgba(212,160,23,.3),transparent 40%);
  -webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);-webkit-mask-composite:xor;mask-composite:exclude;
}
.term-bar{display:flex;align-items:center;gap:8px;padding:11px 14px;border-bottom:1px solid var(--rule);background:rgba(0,0,0,.25)}
.term-bar .b{width:11px;height:11px;border-radius:50%;background:#3a302a}
.term-bar .b:nth-child(1){background:#ff5f57}
.term-bar .b:nth-child(2){background:#febc2e}
.term-bar .b:nth-child(3){background:#28c840}
.term-bar .t{margin-left:12px;color:var(--bone-dim);font-size:11px;letter-spacing:.05em}
.term-body{padding:20px 22px 24px;min-height:360px}
.term-body .line{display:flex;gap:10px;margin-bottom:6px}
.term-body .prompt{color:var(--gold)}
.term-body .cmd{color:var(--bone)}
.term-body .out{color:var(--bone-mute);margin-left:22px;margin-bottom:8px}
.term-body .ok{color:var(--signal)}
.term-body .key{color:var(--gold-2)}
.term-body .dim{color:var(--bone-dim)}
.cursor{display:inline-block;width:7px;height:15px;background:var(--gold);vertical-align:-2px;animation:blink 1s steps(2) infinite;margin-left:4px}
@keyframes blink{50%{opacity:0}}

/* ====== marquee ====== */
.marquee{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:22px 0;overflow:hidden;background:var(--ink-2)}
.marquee-track{display:flex;gap:48px;white-space:nowrap;animation:scroll 38s linear infinite;font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--bone-dim);letter-spacing:.05em}
.marquee-track span{display:flex;align-items:center;gap:48px}
.marquee-track span::before{content:"◆";color:var(--gold);font-size:9px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ====== section base ====== */
section.s{padding:120px 0;position:relative}
.section-head{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;margin-bottom:72px;align-items:end}
.section-head h2{
  font-family:'Fraunces',serif;font-weight:400;font-variation-settings:"opsz" 144;
  font-size:clamp(36px,4.5vw,58px);line-height:1;letter-spacing:-.02em;margin:14px 0 0;color:var(--bone);
}
.section-head h2 em{font-style:italic;color:var(--gold-2);font-weight:300}
.section-head .lede{font-size:17px;color:var(--bone-mute);line-height:1.65;max-width:560px;justify-self:end}
.section-num{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--gold);letter-spacing:.2em}

/* ====== services grid (homepage) ====== */
.services{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border-top:1px solid var(--rule);border-left:1px solid var(--rule)}
.svc{
  grid-column:span 2;padding:38px 32px 42px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  position:relative;transition:background .25s;cursor:default;background:var(--ink);
}
.svc:nth-child(1),.svc:nth-child(2){grid-column:span 3}
.svc:nth-child(1){background:var(--ink-2)}
.svc:hover{background:var(--ink-2)}
.svc-num{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--gold);letter-spacing:.2em;margin-bottom:24px;display:flex;justify-content:space-between;align-items:center}
.svc-num .tag{padding:3px 8px;border:1px solid var(--rule);border-radius:999px;font-size:9px;color:var(--bone-dim);letter-spacing:.15em}
.svc-num .tag.flag{color:var(--gold);border-color:rgba(212,160,23,.4)}
.svc h3{font-family:'Fraunces',serif;font-weight:380;font-size:30px;line-height:1.1;margin:0 0 14px;letter-spacing:-.015em}
.svc h3 em{font-style:italic;color:var(--gold-2)}
.svc p{color:var(--bone-mute);font-size:14.5px;margin:0 0 22px;line-height:1.65}
.svc ul{list-style:none;padding:0;margin:0;font-size:13px;color:var(--bone-mute)}
.svc ul li{padding:7px 0;border-top:1px solid var(--rule);display:flex;gap:10px;align-items:baseline}
.svc ul li::before{content:"→";color:var(--gold);font-family:'JetBrains Mono',monospace;font-size:11px}
.svc-icon{
  position:absolute;top:32px;right:32px;width:42px;height:42px;border-radius:8px;border:1px solid var(--rule);
  display:grid;place-items:center;font-family:'Fraunces',serif;color:var(--gold);font-size:18px;background:var(--ink-3);
}

/* ====== offradar feature block ====== */
.offradar-block{
  background:linear-gradient(180deg,var(--ink),var(--ink-2));
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  padding:130px 0;position:relative;overflow:hidden;
}
.offradar-block::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(600px 400px at 85% 30%, rgba(212,160,23,.14), transparent 60%),
    radial-gradient(500px 300px at 15% 80%, rgba(126,168,138,.08), transparent 60%);
  pointer-events:none;
}
.offradar-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative}
.badge{
  display:inline-flex;align-items:center;gap:9px;padding:8px 14px;background:rgba(212,160,23,.08);
  border:1px solid rgba(212,160,23,.35);border-radius:999px;font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--gold);letter-spacing:.15em;margin-bottom:24px;
}
.offradar-block h2{font-family:'Fraunces',serif;font-weight:380;font-size:clamp(38px,4.8vw,64px);line-height:1.02;letter-spacing:-.02em;margin:0 0 24px;color:var(--bone)}
.offradar-block h2 em{font-style:italic;color:var(--gold-2);font-weight:300}
.offradar-block .lede{font-size:17px;color:var(--bone-mute);max-width:520px;margin-bottom:32px;line-height:1.7}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 24px;margin-bottom:36px}
.feat{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:var(--bone-mute);line-height:1.55}
.feat .ck{flex:none;width:18px;height:18px;border-radius:50%;background:rgba(212,160,23,.15);border:1px solid var(--gold);display:grid;place-items:center;color:var(--gold);font-size:10px;margin-top:2px}
.feat strong{color:var(--bone);font-weight:500}

.scanner{
  background:var(--ink-3);border:1px solid var(--rule);border-radius:16px;padding:22px;
  font-family:'JetBrains Mono',monospace;font-size:12px;
  box-shadow:0 40px 100px -30px rgba(0,0,0,.7), 0 0 0 1px rgba(212,160,23,.06);
  position:relative;
}
.scanner-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--rule)}
.scanner-h .title{display:flex;gap:10px;align-items:center;color:var(--bone)}
.scanner-h .title::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--signal);box-shadow:0 0 12px var(--signal);animation:pulse 2s infinite}
.scanner-h .now{color:var(--bone-dim);font-size:11px}
.lead{
  border:1px solid var(--rule);border-radius:10px;padding:14px;margin-bottom:10px;background:rgba(0,0,0,.2);
  display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;transition:border-color .3s;
}
.lead:hover{border-color:rgba(212,160,23,.4)}
.lead .src{color:var(--bone-dim);font-size:10.5px;letter-spacing:.1em}
.lead .ttl{color:var(--bone);font-family:'IBM Plex Sans',sans-serif;font-size:13.5px;font-weight:500;letter-spacing:-.005em;margin:4px 0 6px;line-height:1.35}
.lead .meta{color:var(--bone-dim);font-size:10.5px}
.stars{color:var(--gold);font-size:13px;letter-spacing:.08em;line-height:1}
.stars .o{color:#3a2f24}
.scanner-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--rule);color:var(--bone-dim);font-size:10.5px}
.scanner-foot .pushed{color:var(--signal)}

/* ====== stack/infra ====== */
.stack{padding:120px 0;background:var(--ink-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.stack-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.stat{background:var(--ink-2);padding:36px 28px;position:relative}
.stat .num{font-family:'Fraunces',serif;font-weight:300;font-variation-settings:"opsz" 144;font-size:64px;line-height:1;color:var(--gold);letter-spacing:-.04em;margin-bottom:12px}
.stat .num small{font-size:24px;color:var(--bone-mute);margin-left:4px}
.stat .lbl{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--bone-dim);letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}
.stat p{font-size:13px;color:var(--bone-mute);margin:0;line-height:1.55}

.infra{margin-top:80px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.infra h3{font-family:'Fraunces',serif;font-weight:400;font-size:38px;line-height:1.05;letter-spacing:-.02em;margin:0 0 20px}
.infra h3 em{font-style:italic;color:var(--gold-2)}
.infra p{color:var(--bone-mute);font-size:15px;line-height:1.7;margin:0 0 14px}
.rack{
  background:var(--ink-3);border:1px solid var(--rule);border-radius:14px;padding:24px;font-family:'JetBrains Mono',monospace;font-size:12px;
}
.rack-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:14px;align-items:center;padding:12px 0;border-bottom:1px solid var(--rule)}
.rack-row:last-child{border-bottom:none}
.rack-row .ic{width:30px;height:30px;border-radius:6px;background:var(--ink-4);display:grid;place-items:center;color:var(--gold);font-family:'Fraunces',serif;font-size:13px}
.rack-row .name{color:var(--bone);font-size:12.5px}
.rack-row .name small{display:block;color:var(--bone-dim);font-size:10.5px;margin-top:2px}
.rack-row .ip{color:var(--bone-dim);font-size:10.5px}
.rack-row .status{display:flex;align-items:center;gap:6px;color:var(--signal);font-size:10.5px}
.rack-row .status::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--signal);box-shadow:0 0 8px var(--signal)}

/* ====== pricing ====== */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.plan{
  background:var(--ink-2);border:1px solid var(--rule);border-radius:18px;padding:38px 32px;position:relative;
  display:flex;flex-direction:column;transition:transform .3s,border-color .3s;
}
.plan:hover{transform:translateY(-4px);border-color:var(--bone-dim)}
.plan.featured{border-color:var(--gold);background:linear-gradient(180deg,rgba(212,160,23,.07),var(--ink-2) 30%)}
.plan.featured::before{
  content:"Most chosen";position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--ink);padding:5px 14px;border-radius:999px;font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:.15em;text-transform:uppercase;font-weight:600;
}
.plan .pname{font-family:'Fraunces',serif;font-weight:400;font-size:28px;letter-spacing:-.015em;margin:0 0 8px}
.plan .ptag{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--bone-dim);letter-spacing:.12em;text-transform:uppercase;margin-bottom:24px}
.plan .price{font-family:'Fraunces',serif;font-weight:300;font-variation-settings:"opsz" 144;font-size:64px;line-height:1;letter-spacing:-.03em;color:var(--bone);margin-bottom:4px}
.plan .price small{font-size:18px;color:var(--bone-dim);font-family:'IBM Plex Sans';font-weight:400}
.plan .pinfo{font-size:13px;color:var(--bone-dim);margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid var(--rule)}
.plan ul{list-style:none;padding:0;margin:0 0 32px;flex:1}
.plan ul li{padding:10px 0;font-size:14px;color:var(--bone-mute);display:flex;gap:12px;align-items:flex-start;line-height:1.45;position:relative}
.plan ul li::before{content:"";flex:none;width:14px;height:14px;border-radius:50%;background:rgba(212,160,23,.12);border:1px solid var(--gold);margin-top:3px}
.plan ul li::after{content:"✓";position:absolute;color:var(--gold);font-size:9px;left:3px;top:6px}
.plan .pbtn{
  display:flex;justify-content:center;align-items:center;gap:8px;padding:14px;border-radius:10px;
  font-size:14px;font-weight:500;cursor:pointer;transition:all .25s;
}
.plan .pbtn-gold{background:var(--gold);color:var(--ink)}
.plan .pbtn-gold:hover{background:var(--gold-2)}
.plan .pbtn-ghost{background:transparent;color:var(--bone);border:1px solid var(--rule)}
.plan .pbtn-ghost:hover{border-color:var(--bone-mute)}
.pricing-note{margin-top:36px;text-align:center;color:var(--bone-dim);font-size:13.5px;font-family:'JetBrains Mono',monospace;letter-spacing:.04em}
.pricing-note span{color:var(--gold)}

/* ====== process ====== */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--rule)}
.step{padding:42px 28px 36px;border-right:1px solid var(--rule);position:relative}
.step:last-child{border-right:none}
.step .sn{font-family:'Fraunces',serif;font-weight:300;font-variation-settings:"opsz" 144;font-size:78px;line-height:1;color:var(--gold);letter-spacing:-.04em;margin-bottom:18px;opacity:.95}
.step h4{font-family:'Fraunces',serif;font-weight:400;font-size:22px;letter-spacing:-.01em;margin:0 0 10px}
.step p{font-size:14px;color:var(--bone-mute);margin:0;line-height:1.6}

/* ====== local ====== */
.local{padding:120px 0;background:var(--ink-2);border-top:1px solid var(--rule)}
.local-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:80px;align-items:center}
.local h2{font-family:'Fraunces',serif;font-weight:380;font-size:clamp(36px,4.5vw,58px);line-height:1.02;letter-spacing:-.02em;margin:0 0 24px}
.local h2 em{font-style:italic;color:var(--gold-2)}
.local p{color:var(--bone-mute);font-size:16px;line-height:1.7;margin:0 0 16px}
.towns{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}
.towns span{padding:8px 14px;border:1px solid var(--rule);border-radius:999px;font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--bone-mute);letter-spacing:.04em;background:var(--ink-3);transition:all .2s}
.towns span:hover{border-color:var(--gold);color:var(--gold)}

/* ====== cta ====== */
.cta-block{padding:140px 0;text-align:center;position:relative;overflow:hidden;border-top:1px solid var(--rule)}
.cta-block::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(800px 400px at 50% 30%, rgba(212,160,23,.18), transparent 60%);
  pointer-events:none;
}
.cta-block h2{font-family:'Fraunces',serif;font-weight:380;font-size:clamp(44px,6vw,84px);line-height:1;letter-spacing:-.025em;margin:0 0 28px;color:var(--bone)}
.cta-block h2 em{font-style:italic;color:var(--gold-2);font-weight:300}
.cta-block p{font-size:18px;color:var(--bone-mute);max-width:560px;margin:0 auto 40px;line-height:1.6}
.cta-block .ctas{justify-content:center}

/* ====== footer ====== */
footer{border-top:1px solid var(--rule);padding:60px 0 30px;font-size:13px;color:var(--bone-dim)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:50px;margin-bottom:60px}
.foot-grid h5{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--bone);letter-spacing:.18em;text-transform:uppercase;margin:0 0 18px;font-weight:500}
.foot-grid ul{list-style:none;padding:0;margin:0}
.foot-grid ul li{padding:5px 0}
.foot-grid ul li a:hover{color:var(--gold)}
.foot-brand p{margin:14px 0 0;line-height:1.65;max-width:340px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid var(--rule);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;flex-wrap:wrap;gap:14px}
.foot-bottom .sig{display:flex;align-items:center;gap:10px}
.foot-bottom .sig .dot{width:6px;height:6px}

/* ====== reveal animations ====== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.05s}
.reveal[data-d="2"]{transition-delay:.12s}
.reveal[data-d="3"]{transition-delay:.2s}
.reveal[data-d="4"]{transition-delay:.3s}
.reveal[data-d="5"]{transition-delay:.4s}

/* ============================================================
   SERVICES PAGE
   ============================================================ */
.svc-detail{padding:100px 0;border-bottom:1px solid var(--rule);position:relative}
.svc-detail:nth-child(even){background:var(--ink-2)}
.svc-detail-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:80px;align-items:start}
.svc-detail .num{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--gold);letter-spacing:.2em;margin-bottom:18px}
.svc-detail h2{font-family:'Fraunces',serif;font-weight:380;font-size:clamp(36px,4.2vw,54px);line-height:1.02;letter-spacing:-.02em;margin:0 0 20px;color:var(--bone)}
.svc-detail h2 em{font-style:italic;color:var(--gold-2);font-weight:300}
.svc-detail .lede{color:var(--bone-mute);font-size:16px;line-height:1.7;margin:0 0 18px;max-width:460px}
.svc-detail .tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:24px}
.svc-detail .tags span{padding:5px 11px;border:1px solid var(--rule);border-radius:999px;font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--bone-dim);letter-spacing:.06em}

.svc-block{background:var(--ink-3);border:1px solid var(--rule);border-radius:14px;padding:32px 34px;margin-bottom:18px}
.svc-block h4{font-family:'Fraunces',serif;font-weight:400;font-size:22px;letter-spacing:-.01em;margin:0 0 8px;color:var(--bone)}
.svc-block h4 em{font-style:italic;color:var(--gold-2)}
.svc-block .desc{color:var(--bone-mute);font-size:14.5px;line-height:1.65;margin:0 0 20px}
.svc-block ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:6px 24px}
.svc-block ul li{padding:6px 0;font-size:13.5px;color:var(--bone-mute);display:flex;gap:10px;align-items:baseline;line-height:1.4}
.svc-block ul li::before{content:"→";color:var(--gold);font-family:'JetBrains Mono',monospace;font-size:11px;flex:none}

/* ============================================================
   OFFRADAR PAGE
   ============================================================ */
.or-hero{padding:90px 0 70px;border-bottom:1px solid var(--rule);position:relative;overflow:hidden}
.or-hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(700px 500px at 90% 20%, rgba(212,160,23,.16), transparent 60%),
    radial-gradient(500px 400px at 10% 80%, rgba(126,168,138,.06), transparent 60%);
  pointer-events:none;
}
.or-hero h1{font-family:'Fraunces',serif;font-weight:380;font-size:clamp(48px,6.8vw,100px);line-height:.96;letter-spacing:-.03em;margin:0 0 30px;color:var(--bone);max-width:1100px}
.or-hero h1 em{font-style:italic;color:var(--gold-2);font-weight:300}
.or-hero .lede{font-size:19px;color:var(--bone-mute);max-width:680px;line-height:1.65;margin:0 0 36px}

.verticals{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--rule);border-left:1px solid var(--rule)}
.vert{padding:28px 24px 30px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);transition:background .25s;position:relative}
.vert:hover{background:var(--ink-2)}
.vert .vn{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--gold);letter-spacing:.18em;margin-bottom:12px}
.vert h4{font-family:'Fraunces',serif;font-weight:400;font-size:20px;letter-spacing:-.01em;margin:0 0 8px;color:var(--bone)}
.vert p{font-size:13px;color:var(--bone-mute);margin:0;line-height:1.55}
.vert .sources{margin-top:12px;font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--bone-dim);letter-spacing:.04em}

/* how it works */
.how{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--rule);border-left:1px solid var(--rule)}
.how-step{padding:36px 28px 40px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);position:relative}
.how-step .icon{
  width:48px;height:48px;border-radius:10px;background:var(--ink-3);border:1px solid var(--rule);
  display:grid;place-items:center;color:var(--gold);font-family:'Fraunces',serif;font-size:22px;margin-bottom:22px;
}
.how-step .icon::after{content:"";position:absolute;top:48px;right:-2px;width:30%;height:1px;background:linear-gradient(90deg,var(--gold),transparent);display:none}
.how-step .label{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--gold);letter-spacing:.18em;margin-bottom:8px}
.how-step h4{font-family:'Fraunces',serif;font-weight:400;font-size:22px;letter-spacing:-.01em;margin:0 0 12px}
.how-step p{font-size:14px;color:var(--bone-mute);margin:0;line-height:1.6}

/* offradar tiers */
.or-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.or-tier{
  background:var(--ink-2);border:1px solid var(--rule);border-radius:18px;padding:38px 32px;position:relative;
  display:flex;flex-direction:column;transition:all .3s;
}
.or-tier:hover{transform:translateY(-4px);border-color:var(--bone-dim)}
.or-tier.featured{border-color:var(--gold);background:linear-gradient(180deg,rgba(212,160,23,.08),var(--ink-2) 30%)}
.or-tier.featured::before{
  content:"Recommended";position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--ink);padding:5px 14px;border-radius:999px;font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:.15em;text-transform:uppercase;font-weight:600;
}
.or-tier .tn{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--gold);letter-spacing:.18em;margin-bottom:14px}
.or-tier .pname{font-family:'Fraunces',serif;font-weight:400;font-size:34px;letter-spacing:-.015em;margin:0 0 10px}
.or-tier .ptag{font-size:13px;color:var(--bone-mute);margin-bottom:24px;line-height:1.5}
.or-tier .price-row{display:flex;align-items:baseline;gap:8px;margin-bottom:6px}
.or-tier .price{font-family:'Fraunces',serif;font-weight:300;font-variation-settings:"opsz" 144;font-size:64px;line-height:1;letter-spacing:-.03em;color:var(--bone)}
.or-tier .price small{font-size:18px;color:var(--bone-dim);font-family:'IBM Plex Sans';font-weight:400}
.or-tier .pinfo{font-size:12.5px;color:var(--bone-dim);margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid var(--rule);font-family:'JetBrains Mono',monospace;letter-spacing:.05em}
.or-tier ul{list-style:none;padding:0;margin:0 0 32px;flex:1}
.or-tier ul li{padding:9px 0;font-size:13.5px;color:var(--bone-mute);display:flex;gap:12px;align-items:flex-start;line-height:1.5;position:relative}
.or-tier ul li::before{content:"";flex:none;width:14px;height:14px;border-radius:50%;background:rgba(212,160,23,.12);border:1px solid var(--gold);margin-top:2px}
.or-tier ul li::after{content:"✓";position:absolute;color:var(--gold);font-size:9px;left:3px;top:5px}

/* faq */
.faq{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule);border:1px solid var(--rule)}
.q{background:var(--ink);padding:32px 30px}
.q h4{font-family:'Fraunces',serif;font-weight:400;font-size:20px;letter-spacing:-.01em;margin:0 0 12px;color:var(--bone)}
.q h4 em{font-style:italic;color:var(--gold-2)}
.q p{font-size:14.5px;color:var(--bone-mute);margin:0;line-height:1.65}

/* ============================================================
   PRICING PAGE — comparison table
   ============================================================ */
.compare{border:1px solid var(--rule);border-radius:14px;overflow:hidden;background:var(--ink-2)}
.compare table{width:100%;border-collapse:collapse}
.compare th, .compare td{padding:18px 22px;text-align:left;border-bottom:1px solid var(--rule);font-size:14px}
.compare th{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--bone-dim);font-weight:500;background:var(--ink-3)}
.compare th.tier{color:var(--bone);font-family:'Fraunces',serif;font-size:18px;letter-spacing:-.01em;text-transform:none}
.compare th.tier.featured{color:var(--gold)}
.compare td{color:var(--bone-mute)}
.compare td.feat-name{color:var(--bone);font-weight:500}
.compare td.check{text-align:center;color:var(--gold);font-size:16px}
.compare td.cross{text-align:center;color:#3a2f24;font-size:14px}
.compare tr:last-child td{border-bottom:none}
.compare tr:hover td{background:rgba(212,160,23,.03)}

/* addons */
.addons{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.addon{background:var(--ink-2);border:1px solid var(--rule);border-radius:14px;padding:28px 30px;transition:border-color .25s}
.addon:hover{border-color:var(--bone-dim)}
.addon .label{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--gold);letter-spacing:.18em;margin-bottom:10px}
.addon h4{font-family:'Fraunces',serif;font-weight:400;font-size:22px;letter-spacing:-.01em;margin:0 0 8px;color:var(--bone);display:flex;justify-content:space-between;align-items:baseline;gap:14px}
.addon h4 .p{font-family:'IBM Plex Sans',sans-serif;font-size:18px;color:var(--gold);font-weight:500}
.addon p{font-size:14px;color:var(--bone-mute);margin:0;line-height:1.6}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-hero{display:grid;grid-template-columns:1.2fr .8fr;gap:80px;align-items:center;padding:60px 0 90px;border-bottom:1px solid var(--rule)}
.about-hero h1{font-family:'Fraunces',serif;font-weight:380;font-size:clamp(44px,6vw,84px);line-height:.98;letter-spacing:-.025em;margin:18px 0 28px;color:var(--bone)}
.about-hero h1 em{font-style:italic;color:var(--gold-2);font-weight:300}
.about-hero .lede{font-size:18px;color:var(--bone-mute);line-height:1.65;max-width:560px}
.logo-frame{
  aspect-ratio:1/1;background:var(--ink-2);border:1px solid var(--rule);border-radius:20px;display:grid;place-items:center;
  position:relative;overflow:hidden;
  box-shadow:0 40px 100px -30px rgba(0,0,0,.6);
}
.logo-frame::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(400px 300px at 50% 50%, rgba(212,160,23,.15), transparent 60%);
}
.logo-frame img{width:80%;height:auto;position:relative;z-index:1}

.story{padding:100px 0;border-bottom:1px solid var(--rule)}
.story-grid{display:grid;grid-template-columns:.7fr 1.3fr;gap:80px}
.story h2{font-family:'Fraunces',serif;font-weight:400;font-size:42px;line-height:1.02;letter-spacing:-.02em;margin:0;color:var(--bone)}
.story h2 em{font-style:italic;color:var(--gold-2)}
.story .num{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--gold);letter-spacing:.2em;margin-bottom:14px}
.story p{font-size:16px;color:var(--bone-mute);line-height:1.75;margin:0 0 18px}
.story p strong{color:var(--bone);font-weight:500}
.story p:last-child{margin-bottom:0}

.principles{padding:100px 0;background:var(--ink-2);border-bottom:1px solid var(--rule)}
.prin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);margin-top:60px}
.prin{background:var(--ink-2);padding:38px 32px}
.prin .n{font-family:'Fraunces',serif;font-weight:300;font-variation-settings:"opsz" 144;font-size:42px;color:var(--gold);line-height:1;margin-bottom:18px}
.prin h4{font-family:'Fraunces',serif;font-weight:400;font-size:22px;letter-spacing:-.01em;margin:0 0 10px}
.prin h4 em{font-style:italic;color:var(--gold-2)}
.prin p{font-size:14px;color:var(--bone-mute);line-height:1.65;margin:0}

.ventures{padding:100px 0;border-bottom:1px solid var(--rule)}
.vent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.vent{background:var(--ink-2);border:1px solid var(--rule);border-radius:14px;padding:30px 28px;position:relative}
.vent .label{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--gold);letter-spacing:.18em;margin-bottom:14px}
.vent h4{font-family:'Fraunces',serif;font-weight:400;font-size:24px;letter-spacing:-.01em;margin:0 0 10px}
.vent h4 em{font-style:italic;color:var(--gold-2)}
.vent p{font-size:13.5px;color:var(--bone-mute);line-height:1.6;margin:0 0 14px}
.vent .meta{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--bone-dim);letter-spacing:.06em;padding-top:14px;border-top:1px solid var(--rule)}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;padding:80px 0 100px;align-items:start}
.contact-info h2{font-family:'Fraunces',serif;font-weight:400;font-size:32px;letter-spacing:-.015em;margin:0 0 22px;color:var(--bone)}
.contact-info h2 em{font-style:italic;color:var(--gold-2)}
.info-block{margin-bottom:36px;padding-bottom:36px;border-bottom:1px solid var(--rule)}
.info-block:last-child{border-bottom:none}
.info-block .label{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--gold);letter-spacing:.18em;margin-bottom:12px}
.info-block .val{font-family:'Fraunces',serif;font-weight:400;font-size:26px;letter-spacing:-.01em;color:var(--bone);margin-bottom:6px;line-height:1.2}
.info-block .val a:hover{color:var(--gold)}
.info-block p{font-size:14px;color:var(--bone-mute);margin:0;line-height:1.65}

.form{background:var(--ink-2);border:1px solid var(--rule);border-radius:18px;padding:40px 38px;position:relative}
.form::before{
  content:"";position:absolute;inset:-1px;border-radius:18px;padding:1px;pointer-events:none;
  background:linear-gradient(180deg,rgba(212,160,23,.25),transparent 30%);
  -webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);-webkit-mask-composite:xor;mask-composite:exclude;
}
.form h3{font-family:'Fraunces',serif;font-weight:400;font-size:26px;letter-spacing:-.01em;margin:0 0 8px;color:var(--bone)}
.form h3 em{font-style:italic;color:var(--gold-2)}
.form .desc{font-size:14px;color:var(--bone-mute);margin:0 0 28px;line-height:1.6}
.field{margin-bottom:18px}
.field label{display:block;font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--bone-dim);letter-spacing:.15em;text-transform:uppercase;margin-bottom:8px}
.field input, .field select, .field textarea{
  width:100%;padding:13px 16px;background:var(--ink-3);border:1px solid var(--rule);border-radius:10px;
  color:var(--bone);font-family:'IBM Plex Sans',sans-serif;font-size:14.5px;transition:border-color .2s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none;border-color:var(--gold);background:var(--ink-3);
}
.field textarea{resize:vertical;min-height:120px;line-height:1.55}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-btn{
  width:100%;padding:16px;border-radius:10px;border:none;cursor:pointer;
  background:var(--gold);color:var(--ink);font-family:'IBM Plex Sans',sans-serif;font-size:15px;font-weight:500;letter-spacing:.01em;
  transition:all .2s;margin-top:8px;display:flex;justify-content:center;align-items:center;gap:8px;
}
.form-btn:hover{background:var(--gold-2);transform:translateY(-1px)}
.form-fine{margin-top:18px;font-size:11.5px;color:var(--bone-dim);font-family:'JetBrains Mono',monospace;letter-spacing:.05em;line-height:1.65;text-align:center}

.contact-extras{padding:100px 0;background:var(--ink-2);border-top:1px solid var(--rule)}
.extras-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.extra{background:var(--ink-2);padding:36px 32px;text-align:center}
.extra .icon{
  width:48px;height:48px;border-radius:50%;background:rgba(212,160,23,.1);border:1px solid var(--gold);
  display:grid;place-items:center;color:var(--gold);font-family:'Fraunces',serif;font-size:22px;margin:0 auto 18px;
}
.extra h4{font-family:'Fraunces',serif;font-weight:400;font-size:20px;letter-spacing:-.01em;margin:0 0 10px}
.extra p{font-size:13.5px;color:var(--bone-mute);line-height:1.6;margin:0 0 8px}
.extra .v{color:var(--gold);font-family:'JetBrains Mono',monospace;font-size:13px;letter-spacing:.04em}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;gap:50px}
  .section-head{grid-template-columns:1fr;gap:20px}
  .section-head .lede{justify-self:start}
  .services{grid-template-columns:1fr}
  .svc, .svc:nth-child(1), .svc:nth-child(2){grid-column:span 1}
  .offradar-grid{grid-template-columns:1fr;gap:60px}
  .feat-grid{grid-template-columns:1fr}
  .stack-grid{grid-template-columns:repeat(2,1fr)}
  .infra{grid-template-columns:1fr;gap:40px}
  .pricing, .or-tiers{grid-template-columns:1fr;gap:18px}
  .process, .how{grid-template-columns:1fr}
  .step{border-right:none;border-bottom:1px solid var(--rule)}
  .local-grid{grid-template-columns:1fr;gap:50px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:40px}
  .nav-links{display:none}
  .hamburger{display:flex;flex-direction:column;gap:4px;cursor:pointer}
  .hamburger span{width:22px;height:1.5px;background:var(--bone)}
  .topbar-inner > div:nth-child(2){display:none}
  .svc-detail-grid{grid-template-columns:1fr;gap:40px}
  .svc-block ul{grid-template-columns:1fr}
  .verticals{grid-template-columns:repeat(2,1fr)}
  .faq{grid-template-columns:1fr}
  .compare{overflow-x:auto}
  .compare table{min-width:680px}
  .addons{grid-template-columns:1fr}
  .about-hero{grid-template-columns:1fr;gap:40px}
  .story-grid{grid-template-columns:1fr;gap:30px}
  .prin-grid, .vent-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:50px;padding:60px 0 80px}
  .extras-grid{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .container{padding:0 20px}
  section.s{padding:80px 0}
  .hero{padding:60px 0 40px}
  .hero-meta{gap:24px}
  .ctas{flex-direction:column;align-items:stretch}
  .ctas .btn{justify-content:center}
  .terminal{transform:none}
  .stack-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;align-items:flex-start}
  .verticals{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
}
