/* ==========================================================================
   harry's websites — site stylesheet (forest glass / CRT / mono brutalist)
   shared across all pages
   ========================================================================== */
:root{
  --bg:#0a120c; --bg-2:#0d1a10; --forest-1:#1a3624; --forest-2:#2d5a3d; --forest-3:#4a8055;
  --phosphor:#7fc28f; --ink:#e8efe9; --muted:#8a9590; --rule:rgba(232,239,233,0.08);
  --glass-bg:rgba(45,90,61,0.10); --glass-bg-2:rgba(15,28,19,0.42);
  --glass-border:rgba(232,239,233,0.14); --glass-blur:40px; --amber:#e6a24a;
  --mono:'IBM Plex Mono','JetBrains Mono',ui-monospace,SFMono-Regular,'SF Mono',Menlo,Consolas,monospace;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--mono);font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision;overflow-x:hidden;}
body{position:relative;min-height:100vh;}
a{color:inherit;}

/* ---- background field ---- */
.bg-field{position:fixed;top:-20vh;left:-10vw;right:-10vw;bottom:-20vh;z-index:0;overflow:hidden;
  background:radial-gradient(ellipse at 20% 10%,#11231a 0%,transparent 55%),radial-gradient(ellipse at 90% 90%,#0e1f15 0%,transparent 55%),var(--bg);
  -webkit-mask-image:linear-gradient(180deg,transparent 0%,#000 14%,#000 86%,transparent 100%);mask-image:linear-gradient(180deg,transparent 0%,#000 14%,#000 86%,transparent 100%);}
.bg-field-inner{position:absolute;inset:0;transform:translate3d(0,var(--parallax-y,0px),0);will-change:transform;}
.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:0.55;mix-blend-mode:screen;}
.blob.b1{width:720px;height:720px;background:#1f4a30;left:-180px;top:-120px;animation:drift-a 24s ease-in-out infinite;}
.blob.b2{width:560px;height:560px;background:#2d5a3d;right:-160px;top:8vh;animation:drift-b 28s ease-in-out infinite;}
.blob.b3{width:600px;height:600px;background:#143824;left:30vw;top:46vh;animation:drift-c 32s ease-in-out infinite;}
.blob.b4{width:440px;height:440px;background:#36694a;right:14vw;top:74vh;animation:drift-a 26s ease-in-out infinite reverse;}
@keyframes drift-a{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(220px,260px) scale(1.12);}}
@keyframes drift-b{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(-220px,240px) scale(1.16);}}
@keyframes drift-c{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(180px,-220px) scale(0.9);}}
@media (prefers-reduced-motion:reduce){.blob{animation:none;}}

/* ---- CRT overlay ---- */
.crt-layer{position:fixed;inset:0;pointer-events:none;z-index:9000;}
.crt-layer .scanlines{position:absolute;inset:0;background-image:repeating-linear-gradient(to bottom,rgba(0,0,0,0) 0px,rgba(0,0,0,0) 2px,rgba(0,0,0,0.2) 3px);mix-blend-mode:multiply;opacity:0.22;}
.crt-layer .vignette{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 56%,rgba(0,0,0,0.42) 100%);opacity:0.5;}
.crt-layer .flicker{position:absolute;inset:0;background:rgba(127,194,143,0.012);animation:crt-flicker 7s steps(2,end) infinite;}
@keyframes crt-flicker{0%,7%,14%,22%,29%,36%,43%,50%,57%,64%,71%,78%,85%,92%,100%{opacity:1;}4%{opacity:0.93;}46%{opacity:0.9;}73%{opacity:0.94;}}
@media (prefers-reduced-motion:reduce){.crt-layer .flicker{animation:none;}}

/* ---- glass ---- */
.glass{position:relative;background:linear-gradient(180deg,var(--glass-bg) 0%,var(--glass-bg-2) 100%);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(160%);backdrop-filter:blur(var(--glass-blur)) saturate(160%);border:1px solid var(--glass-border);border-radius:14px;}
.glass::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(180deg,rgba(255,255,255,0.18) 0%,rgba(255,255,255,0.02) 35%,rgba(255,255,255,0) 100%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;}

/* ---- shell + topbar ---- */
.shell{position:relative;z-index:10;max-width:1240px;margin:0 auto;padding:24px 30px 110px;}
/* full-width flat top bar (demo look) */
.topbar{position:sticky;top:0;z-index:150;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 30px;background:rgba(10,18,12,0.72);-webkit-backdrop-filter:blur(12px) saturate(150%);backdrop-filter:blur(12px) saturate(150%);border-bottom:1px solid var(--rule);}
.topbar .mark{font-weight:700;font-size:13px;letter-spacing:-0.01em;display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);}
.topbar .mark .dot{width:8px;height:8px;background:var(--phosphor);border-radius:50%;}
.topbar nav{display:flex;gap:6px;flex-wrap:wrap;}
.topbar nav a{color:var(--muted);text-decoration:none;font-weight:700;font-size:10.5px;letter-spacing:0.08em;text-transform:uppercase;padding:7px 11px;border-radius:999px;transition:all .15s;}
.topbar nav a:hover{color:var(--phosphor);}
.topbar nav a.active{color:#0a120c;background:var(--phosphor);}
.topbar .tb-cta{padding:10px 16px;font-size:10px;}

/* ---- stage + browser-window frame (demo look, site-wide) ---- */
.stage{position:relative;z-index:10;max-width:1200px;margin:26px auto 0;padding:0 22px 90px;}
.frame{overflow:hidden;border-radius:14px;}
.frame-head{display:flex;align-items:center;gap:14px;padding:11px 16px;border-bottom:1px solid var(--rule);background:rgba(0,0,0,0.28);}
.frame-dots{display:flex;gap:6px;}
.frame-dots span{width:10px;height:10px;border-radius:50%;background:rgba(232,239,233,0.18);}
.frame-dots span:first-child{background:rgba(255,95,86,0.55);}
.frame-dots span:nth-child(2){background:rgba(255,189,46,0.55);}
.frame-dots span:nth-child(3){background:rgba(127,194,143,0.6);}
.frame-url{font-size:10px;font-weight:700;letter-spacing:0.12em;color:var(--muted);}
.frame-live{margin-left:auto;font-size:8px;font-weight:700;letter-spacing:0.16em;color:var(--phosphor);display:inline-flex;align-items:center;gap:6px;}
.frame-live .led{width:6px;height:6px;border-radius:50%;background:var(--phosphor);animation:pulse 1.8s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.3;}}
@media (prefers-reduced-motion:reduce){.frame-live .led{animation:none;}}
.frame-inner{padding:8px 32px 44px;background:linear-gradient(180deg,#0c1810 0%,#0a130d 100%);}
.stage .footer{margin-top:40px;}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(26px);filter:blur(6px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1),filter .7s ease;will-change:opacity,transform,filter;}
.reveal.in{opacity:1;transform:none;filter:blur(0);}
.reveal .stagger>*{opacity:0;transform:translateY(16px);transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1);}
.reveal.in .stagger>*{opacity:1;transform:none;}
.reveal.in .stagger>*:nth-child(1){transition-delay:.10s;}
.reveal.in .stagger>*:nth-child(2){transition-delay:.18s;}
.reveal.in .stagger>*:nth-child(3){transition-delay:.26s;}
.reveal.in .stagger>*:nth-child(4){transition-delay:.34s;}
.reveal.in .stagger>*:nth-child(5){transition-delay:.42s;}
.reveal.in .stagger>*:nth-child(6){transition-delay:.50s;}
@media (prefers-reduced-motion:reduce){.reveal,.reveal .stagger>*{opacity:1;transform:none;filter:none;transition:none;}}

/* ---- section bits ---- */
section{scroll-margin-top:100px;padding:56px 0 28px;}
.sec-tag{display:inline-flex;align-items:center;gap:10px;font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--phosphor);margin:0 0 16px;}
.sec-tag::before{content:"";width:36px;height:2px;background:var(--phosphor);display:inline-block;}
.sec-title{font-weight:700;font-size:clamp(32px,4.2vw,54px);letter-spacing:-0.035em;line-height:0.92;margin:0 0 16px;text-wrap:balance;}
.sec-title .accent{color:var(--phosphor);}
.sec-sub{font-size:14px;color:var(--muted);max-width:60ch;margin:0 0 34px;line-height:1.55;}

/* ---- hero ---- */
.hero{padding:24px 0 16px;}
.hero .tag{font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--phosphor);margin-bottom:26px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.hero .tag .sep{color:var(--muted);}
.hero h1{font-weight:700;font-size:clamp(52px,8.5vw,116px);letter-spacing:-0.055em;line-height:0.86;margin:0 0 30px;text-wrap:balance;}
.hero h1 .accent{color:var(--phosphor);}
.hero .sub{font-size:clamp(15px,1.4vw,17px);color:var(--muted);max-width:60ch;line-height:1.55;margin:0 0 40px;}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:56px;}
.stamp-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;}
.stamp-row .stamp{padding:20px 18px 20px 0;border-top:1px solid var(--rule);}
.stamp-row .stamp:not(:last-child){border-right:1px solid var(--rule);padding-right:18px;}
.stamp-row .stamp+.stamp{padding-left:18px;}
.stamp-row .k{font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:9px;}
.stamp-row .v{font-size:22px;font-weight:700;letter-spacing:-0.02em;color:var(--ink);}
.stamp-row .v .sm{font-size:13px;color:var(--muted);font-weight:500;}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:12px 22px;font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;text-decoration:none;color:var(--ink);background:rgba(45,90,61,0.18);-webkit-backdrop-filter:blur(20px) saturate(160%);backdrop-filter:blur(20px) saturate(160%);border:1px solid rgba(127,194,143,0.28);border-radius:999px;cursor:pointer;transition:background .16s,border-color .16s,transform .08s;position:relative;}
.btn::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(180deg,rgba(255,255,255,0.22),rgba(255,255,255,0));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;}
.btn:hover{background:rgba(74,128,85,0.32);border-color:rgba(127,194,143,0.55);}
.btn:active{transform:translateY(1px);}
.btn.primary{color:#0a120c;background:rgba(127,194,143,0.9);border-color:rgba(127,194,143,0.9);}
.btn.primary:hover{background:rgba(127,194,143,1);}
.btn .arr{font-weight:700;transition:transform .16s;}
.btn:hover .arr{transform:translateX(3px);}

/* ---- marquee ---- */
.marquee-wrap{padding:24px 0;}
.marquee{overflow:hidden;padding:16px 0;-webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);}
.marquee-track{display:inline-flex;align-items:center;gap:30px;white-space:nowrap;animation:mq 40s linear infinite;padding-left:30px;}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none;}}
.mq-item{font-size:17px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;display:inline-flex;align-items:center;gap:30px;}
.mq-item:nth-child(odd){color:var(--phosphor);}
.mq-b{color:var(--phosphor);}
@keyframes mq{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ---- generic card grids ---- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.svc-card{padding:28px 26px 24px;display:flex;flex-direction:column;gap:13px;min-height:198px;}
.svc-card .num{font-size:11px;font-weight:700;letter-spacing:0.14em;color:var(--phosphor);}
.svc-card .name{font-size:21px;font-weight:700;letter-spacing:-0.025em;line-height:1.02;}
.svc-card .desc{font-size:12.5px;line-height:1.5;color:var(--muted);flex:1;}
.svc-card .from{font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;display:flex;justify-content:space-between;align-items:baseline;padding-top:14px;border-top:1px solid var(--rule);}
.svc-card .from .k{color:var(--muted);}

/* ---- feature split + chat ---- */
.feat{display:grid;grid-template-columns:1fr 1.05fr;gap:16px;align-items:start;}
.feat-text{padding:32px 32px 28px;display:flex;flex-direction:column;gap:18px;}
.feat-text p{font-size:14px;line-height:1.6;color:var(--ink);opacity:0.9;margin:0;max-width:52ch;}
.feat-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px;}
.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--phosphor);background:rgba(127,194,143,0.08);border:1px solid rgba(127,194,143,0.28);}
.pill .dot{width:6px;height:6px;background:var(--phosphor);border-radius:50%;}
.pill.muted{color:var(--muted);background:rgba(232,239,233,0.04);border-color:var(--rule);}
.pill.muted .dot{background:var(--muted);}
.chat{padding:0;overflow:hidden;display:flex;flex-direction:column;min-height:340px;}
.chat-head{display:flex;align-items:center;gap:14px;padding:12px 16px;border-bottom:1px solid var(--rule);background:rgba(0,0,0,0.25);}
.chat-dots{display:flex;gap:6px;}
.chat-dots span{width:10px;height:10px;border-radius:50%;background:rgba(232,239,233,0.18);}
.chat-dots span:first-child{background:rgba(255,95,86,0.55);}
.chat-dots span:nth-child(2){background:rgba(255,189,46,0.55);}
.chat-dots span:nth-child(3){background:rgba(127,194,143,0.6);}
.chat-url{font-size:10px;font-weight:700;letter-spacing:0.13em;color:var(--muted);}
.chat-body{flex:1;padding:20px 22px;display:flex;flex-direction:column;gap:13px;font-size:13px;line-height:1.5;}
.chat-line{display:grid;grid-template-columns:64px 1fr;gap:12px;align-items:baseline;}
.chat-line .prefix{font-weight:700;font-size:10px;text-transform:uppercase;}
.chat-line.you .prefix{color:var(--muted);}
.chat-line.assistant .prefix{color:var(--phosphor);}
.chat-line.small .msg{font-size:11px;color:var(--muted);}
.chat-line .cursor{display:inline-block;color:var(--phosphor);font-weight:700;animation:blink 1.1s steps(2,end) infinite;}
@keyframes blink{0%,49%{opacity:1;}50%,100%{opacity:0;}}
.chat-foot{padding:12px 22px;border-top:1px solid var(--rule);background:rgba(0,0,0,0.18);font-size:9px;font-weight:700;letter-spacing:0.15em;color:var(--muted);text-align:center;}

/* ---- pricing ---- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:stretch;}
.price-card{padding:28px 26px 26px;display:flex;flex-direction:column;gap:18px;min-height:430px;}
.price-card.featured{background:linear-gradient(180deg,rgba(127,194,143,0.18) 0%,rgba(15,28,19,0.42) 100%);border-color:rgba(127,194,143,0.4);}
.price-card .name{font-size:21px;font-weight:700;letter-spacing:-0.025em;}
.price-card .price{display:flex;align-items:baseline;gap:8px;border-bottom:1px solid var(--rule);padding-bottom:16px;flex-wrap:wrap;}
.price-card .price .ccy{font-size:14px;font-weight:600;color:var(--muted);}
.price-card .price .amt{font-size:38px;font-weight:700;letter-spacing:-0.03em;}
.price-card .price .unit{font-size:11px;font-weight:600;letter-spacing:0.05em;color:var(--muted);text-transform:uppercase;}
.price-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;flex:1;}
.price-card ul li{font-size:12px;line-height:1.45;opacity:0.86;display:flex;gap:10px;align-items:flex-start;}
.price-card ul li::before{content:"+";color:var(--phosphor);font-weight:700;flex-shrink:0;}
.price-card ul li b{font-weight:700;opacity:1;}
.price-card ul li.absent{opacity:0.4;}
.price-card ul li.absent::before{content:"-";color:var(--muted);}

/* ---- process ---- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.step{padding:24px 22px 22px;display:flex;flex-direction:column;gap:14px;min-height:218px;}
.step .num{font-size:42px;font-weight:700;letter-spacing:-0.04em;line-height:0.9;color:var(--phosphor);}
.step .name{font-size:18px;font-weight:700;letter-spacing:-0.02em;}
.step .desc{font-size:12px;line-height:1.5;color:var(--muted);flex:1;}
.step .when{font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;padding-top:14px;border-top:1px solid var(--rule);}

/* ---- work grid ---- */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.work-card{padding:0;overflow:hidden;}
.work-shot{aspect-ratio:16/10;position:relative;border-bottom:1px solid var(--rule);}
.work-shot.s1{background:linear-gradient(135deg,#1f4a30,#0e1f15);}
.work-shot.s2{background:linear-gradient(135deg,#36694a,#143824);}
.work-shot.s3{background:linear-gradient(135deg,#2a5a3a,#0c1810);}
.work-shot.s4{background:linear-gradient(135deg,#4a8055,#1a3624);}
.work-shot .ph{position:absolute;left:18px;bottom:16px;font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--phosphor);background:rgba(10,18,12,0.7);border:1px solid rgba(127,194,143,0.3);padding:5px 10px;border-radius:999px;}
.work-meta{padding:20px 22px 22px;}
.work-meta .nm{font-size:19px;font-weight:700;letter-spacing:-0.025em;}
.work-meta .cl{font-size:11px;color:var(--muted);font-weight:600;margin-top:4px;}
.work-meta .ds{font-size:12.5px;line-height:1.55;color:var(--muted);margin:14px 0 0;}

/* ---- about ---- */
.about{padding:36px 40px 32px;}
.about p{font-size:15px;line-height:1.65;opacity:0.92;margin:0 0 16px;max-width:64ch;}
.about p:last-child{margin-bottom:0;}
.about p .accent{color:var(--phosphor);}

/* ---- cta strip ---- */
.cta-strip{padding:60px 52px 52px;display:flex;flex-direction:column;align-items:flex-start;gap:22px;}
.cta-strip h2{font-weight:700;font-size:clamp(38px,6vw,82px);letter-spacing:-0.045em;line-height:0.9;margin:0;text-wrap:balance;}
.cta-strip h2 .accent{color:var(--phosphor);}
.cta-tags{display:flex;flex-wrap:wrap;gap:10px;font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);}
.cta-tags .sep{color:var(--phosphor);}

/* ---- contact ---- */
.contact{padding:48px 48px 44px;display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start;}
.contact h2{font-weight:700;font-size:clamp(34px,5vw,58px);letter-spacing:-0.04em;line-height:0.9;margin:0 0 20px;}
.contact h2 .accent{color:var(--phosphor);}
.contact .p{font-size:14px;line-height:1.55;color:var(--muted);max-width:44ch;margin:0 0 28px;}
.channels{display:flex;flex-direction:column;gap:12px;}
.ch{display:grid;grid-template-columns:110px 1fr;gap:14px;padding:9px 0;border-bottom:1px solid var(--rule);}
.ch:last-child{border-bottom:0;}
.ch .k{font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);padding-top:3px;}
.ch .v{font-size:13.5px;font-weight:600;}
.ch .v a{color:var(--ink);text-decoration:none;border-bottom:1px solid rgba(127,194,143,0.35);}
.ch .v a:hover{color:var(--phosphor);}
.cform{display:flex;flex-direction:column;gap:12px;}
.cform .field{display:flex;flex-direction:column;gap:6px;}
.cform label{font-size:9px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);}
.cform input,.cform textarea{font-family:var(--mono);font-size:13.5px;font-weight:500;background:rgba(15,28,19,0.35);color:var(--ink);border:1px solid var(--rule);border-radius:8px;padding:13px 15px;outline:none;transition:border-color .12s,background .12s;}
.cform input::placeholder,.cform textarea::placeholder{color:var(--muted);opacity:0.55;}
.cform input:focus,.cform textarea:focus{border-color:rgba(127,194,143,0.5);background:rgba(15,28,19,0.55);}
.cform textarea{min-height:120px;resize:vertical;}
.cf-send{align-self:flex-start;margin-top:6px;}
.cf-note{font-size:10px;letter-spacing:0.04em;color:var(--muted);}

/* ---- footer ---- */
.footer{margin-top:80px;padding-top:26px;border-top:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center;font-size:10px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);flex-wrap:wrap;gap:14px;}
.footer .stamp{display:inline-flex;align-items:center;gap:8px;}
.footer .stamp .dot{width:6px;height:6px;border-radius:50%;background:var(--phosphor);}
.footer .f-links{display:flex;gap:18px;}
.footer .f-links a{color:var(--muted);text-decoration:none;font-weight:700;letter-spacing:0.12em;}
.footer .f-links a:hover{color:var(--phosphor);}

/* ---- responsive ---- */
@media (max-width:1000px){
  .svc-grid,.process{grid-template-columns:1fr 1fr;}
  .price-grid,.feat,.contact,.work-grid{grid-template-columns:1fr;}
  .stamp-row{grid-template-columns:1fr 1fr;}
}
@media (max-width:600px){
  .shell{padding:18px 16px 70px;}
  .svc-grid,.process{grid-template-columns:1fr;}
  /* hero stamps as a 2x2 grid, not 4 stacked tiles */
  .stamp-row{grid-template-columns:1fr 1fr;gap:0;}
  .stamp-row .stamp{padding:14px 12px 14px 0 !important;border-right:0 !important;}
  .stamp-row .stamp + .stamp{padding-left:12px !important;}
  .stamp-row .v{font-size:18px;}
  .hero h1{font-size:clamp(34px,10vw,52px);}
  .contact,.cta-strip,.about{padding:24px 18px;}
  .footer{flex-direction:column;align-items:flex-start;gap:10px;}
}

/* ---- mobile nav (hamburger) + compaction ---- */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:36px;background:none;border:0;cursor:pointer;padding:7px;border-radius:8px;}
.hamburger span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .2s,opacity .2s;}
.topbar nav.open ~ .hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.topbar nav.open ~ .hamburger span:nth-child(2){opacity:0;}
.topbar nav.open ~ .hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
@media (max-width:760px){
  /* clean one-row top bar: logo + hamburger only */
  .topbar{flex-wrap:nowrap;padding:10px 16px;justify-content:space-between;}
  .topbar .tb-cta{display:none !important;}
  .hamburger{display:flex;}
  /* nav drops as an absolutely-positioned panel below the bar (doesn't push the bar layout around) */
  .topbar nav{display:none;position:absolute;top:100%;left:0;right:0;width:auto;flex-direction:column;gap:2px;padding:6px 12px 14px;background:rgba(10,18,12,0.96);-webkit-backdrop-filter:blur(12px) saturate(150%);backdrop-filter:blur(12px) saturate(150%);border-bottom:1px solid var(--rule);}
  .topbar nav.open{display:flex;}
  .topbar nav a{padding:13px 12px;font-size:13px;border-radius:8px;width:auto;text-align:left;letter-spacing:0.08em;}
  .topbar nav a.active{color:var(--phosphor);background:rgba(127,194,143,0.12);}
  /* compaction — less scrolling */
  section{padding:30px 0 14px;}
  .frame-inner{padding:4px 16px 30px;}
  .stage{padding:0 12px 64px;margin-top:16px;}
  .sec-title{font-size:clamp(26px,7vw,38px);}
  .sec-sub{margin-bottom:24px;}
  .hero{padding:12px 0 6px;}
  .hero h1{font-size:clamp(38px,11.5vw,58px);margin-bottom:18px;}
  .hero .tag{margin-bottom:18px;}
  .hero .sub{margin-bottom:26px;}
  .hero .cta-row{margin-bottom:30px;}
  .svc-card,.step,.price-card{min-height:auto;}
  .marquee-wrap{padding:12px 0;}
  .cta-strip h2,.contact h2{font-size:clamp(34px,9vw,52px);}
}
