  :root{
    --bg:#08060f; --bg-2:#100d1c; --surface:rgba(255,255,255,0.04); --border:rgba(255,255,255,0.10);
    --text:#f2f0f8; --muted:#aaa3c2; --accent:#a78bfa; --accent-2:#7c5cff; --accent-3:#22d3ee; --accent-rgb:167,139,250; --accent2-rgb:124,92,255; --accent3-rgb:34,211,238;
    --ok:var(--ok); --ok-rgb:58,211,122; --warn:var(--warn); --danger:#ff5470;
    --glow:0 0 55px rgba(var(--accent-rgb),0.5); --radius:18px; --ease:cubic-bezier(0.16,1,0.3,1); --mono:'Space Mono',ui-monospace,monospace; --display:'Bricolage Grotesque','Sora',system-ui,sans-serif;
    --maxw:1180px; /* content column width — scales up on large screens (media queries below) so the site fills big displays */
  }
  *{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
  html{scroll-behavior:smooth;color-scheme:dark;scrollbar-color:var(--accent-2) rgba(255,255,255,.04);scrollbar-width:thin}
  body{background:var(--bg);color:var(--text);font-family:'Space Grotesk',system-ui,sans-serif;line-height:1.6;overflow-x:hidden}
  ::-webkit-scrollbar{width:11px;height:11px}
  ::-webkit-scrollbar-track{background:rgba(255,255,255,.03)}
  ::-webkit-scrollbar-thumb{background:linear-gradient(var(--accent-2),var(--accent));border-radius:10px;border:2px solid var(--bg)}
  ::-webkit-scrollbar-thumb:hover{background:var(--accent)}
  body.has-cursor,body.has-cursor a,body.has-cursor button,body.has-cursor input,body.has-cursor summary{cursor:none}
  body.loading.has-cursor,body.loading.has-cursor *{cursor:auto} /* keep the real pointer visible during the preloader (custom cursor sits behind it) */
  a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,summary:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
  .palette input:focus-visible,.cform input:focus-visible,.cform textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
  body.loading{overflow:hidden;height:100vh;height:100svh}
  @media (pointer:coarse){body{cursor:auto}}
  ::selection{background:var(--accent-2);color:#fff}
  a{color:inherit}

  /* Preloader */
  #preloader{position:fixed;inset:0;z-index:10000;background:var(--bg);display:grid;place-items:center;overflow:hidden;transition:transform .9s var(--ease)}
  #preloader.done{transform:translateY(-100%);pointer-events:none}
  #preloader::before{content:'';position:absolute;inset:-20%;background:radial-gradient(40% 40% at 50% 38%,rgba(var(--accent2-rgb),.22),transparent 70%);filter:blur(30px)}
  #preloader::after{content:'';position:absolute;inset:0;opacity:.5;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(circle at 50% 40%,#000,transparent 75%);mask-image:radial-gradient(circle at 50% 40%,#000,transparent 75%)}
  .pre-ocean{position:absolute;inset:0;z-index:0;background:#04060c url('assets/intro/ocean.jpg') center/cover no-repeat;opacity:.5;filter:saturate(.72) hue-rotate(-26deg) brightness(.92);-webkit-mask-image:radial-gradient(120% 100% at 50% 30%,#000 55%,transparent 100%);mask-image:radial-gradient(120% 100% at 50% 30%,#000 55%,transparent 100%)}
  .pre-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.9}
  .pre-inner{position:relative;z-index:1;text-align:center;width:min(460px,84vw)}
  .pre-mark{width:74px;height:74px;margin:0 auto 26px;border-radius:20px;display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:1.7rem;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:var(--glow);position:relative;animation:preMark .8s var(--ease) both}
  .pre-mark::before{content:'';position:absolute;inset:-11px;border-radius:50%;border:1.5px solid transparent;border-top-color:var(--accent);border-right-color:var(--accent-2);animation:preSpin 1s linear infinite}
  @keyframes preMark{from{opacity:0;transform:scale(.6) rotate(-12deg)}to{opacity:1;transform:none}}
  @keyframes preSpin{to{transform:rotate(360deg)}}
  .pre-name{font-family:var(--display);font-weight:800;font-size:clamp(1.4rem,5vw,2.2rem);letter-spacing:-.02em;line-height:1;background:linear-gradient(180deg,#fff,var(--accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;clip-path:inset(0 100% 0 0);animation:preName 1s .15s var(--ease) forwards}
  @keyframes preName{to{clip-path:inset(0 0 0 0)}}
  .pre-role{font-family:var(--mono);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-top:14px;opacity:0;animation:preFade .6s .4s forwards}
  @keyframes preFade{to{opacity:1}}
  /* the download counter is the intro's hero — big, glowing, gently pulsing */
  .pre-count{font-family:var(--display);font-weight:800;font-size:clamp(4.6rem,19vw,8.5rem);line-height:.9;margin:22px 0 16px;background:linear-gradient(120deg,#fff,var(--accent) 55%,var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 30px rgba(var(--accent2-rgb),.55));animation:preCountPulse 2.2s ease-in-out infinite}
  @keyframes preCountPulse{50%{transform:scale(1.035)}}
  .pre-count i{font-style:normal;font-size:.34em;color:var(--muted);-webkit-text-fill-color:var(--muted);margin-left:6px;filter:none}
  .pre-bar{width:100%;height:5px;background:rgba(255,255,255,.07);border-radius:4px;overflow:hidden;box-shadow:0 0 0 1px rgba(var(--accent-rgb),.12)}
  .pre-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));box-shadow:0 0 18px var(--accent);transition:width .14s linear}
  .pre-status{font-family:var(--mono);color:var(--muted);margin-top:14px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase}
  .pre-status::before{content:'● ';color:var(--ok)}

  /* Cursor */
  .cur-blob{position:fixed;top:0;left:0;width:300px;height:300px;border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(var(--accent2-rgb),0.22),transparent 60%);filter:blur(10px)}
  .cur-dot{position:fixed;top:0;left:0;width:10px;height:10px;border-radius:50%;border:1.5px solid #fff;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);display:grid;place-items:center;transition:width .28s var(--ease),height .28s var(--ease),background .25s,box-shadow .28s var(--ease),border-color .25s}
  .cur-dot.label{width:46px;height:46px;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:rgba(255,255,255,.9);box-shadow:0 0 0 4px rgba(var(--accent2-rgb),.16),0 10px 26px rgba(var(--accent2-rgb),.5)}
  .cur-dot .t{font-family:var(--mono);font-size:8px;font-weight:700;letter-spacing:.1em;color:#fff;opacity:0;transform:scale(.7);transition:opacity .2s var(--ease),transform .2s var(--ease);white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.35)}
  .cur-dot.label .t{transform:scale(1)}
  .cur-dot.label .t{opacity:1}
  @media (pointer:coarse){.cur-blob,.cur-dot{display:none}}

  /* Background */
  .aurora{position:fixed;inset:-25%;z-index:-2;background:
    radial-gradient(38% 38% at 80% 18%,rgba(var(--accent2-rgb),0.22),transparent 70%),
    radial-gradient(34% 34% at 12% 32%,rgba(var(--accent3-rgb),0.10),transparent 70%),
    radial-gradient(45% 45% at 55% 96%,rgba(var(--accent2-rgb),0.12),transparent 70%);
    filter:blur(30px)}
  .gridbg{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
    background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
    background-size:64px 64px;-webkit-mask-image:radial-gradient(circle at 50% 30%,#000,transparent 80%);mask-image:radial-gradient(circle at 50% 30%,#000,transparent 80%)}
  .grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.045;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

  /* Social rail + resume */
  .social-rail{position:fixed;left:26px;top:50%;transform:translateY(-50%);z-index:90;display:flex;flex-direction:column;gap:18px}
  .social-rail a{color:var(--muted);font-size:.8rem;font-family:var(--mono);text-decoration:none;writing-mode:vertical-rl;transition:color .25s,transform .25s}
  .social-rail a:hover{color:var(--accent);transform:translateY(-3px)}
  .social-rail::after{content:'';width:1px;height:70px;background:linear-gradient(var(--border),transparent);margin:6px auto 0}
  @media (max-width:980px){.social-rail{display:none}}
  .resume-fixed{position:fixed;right:24px;bottom:22px;z-index:90;font-family:var(--mono);color:var(--muted);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;transition:color .25s}
  .resume-fixed:hover{color:var(--accent)}
  @media (max-width:980px){.resume-fixed{display:none}}

  .wrap{position:relative;z-index:2}
  section{max-width:var(--maxw);margin:0 auto;padding:140px 28px;scroll-margin-top:80px}

  /* Nav */
  #nav{position:fixed;top:0;left:0;right:0;z-index:100;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:22px clamp(20px,2.4vw,44px);transition:padding .4s var(--ease),background .4s var(--ease)}
  #nav>.logo{justify-self:start}
  #nav>.nav-email{justify-self:center}
  #nav>.nav-right{justify-self:end}
  #nav.scrolled{padding:13px clamp(20px,2.4vw,44px);background:rgba(8,6,15,0.72);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
  .skip{position:fixed;left:12px;top:-60px;z-index:300;background:var(--accent-2);color:#fff;padding:10px 16px;border-radius:10px;font-weight:700;text-decoration:none;transition:top .2s}
  .skip:focus{top:12px}
  .logo{font-family:'Sora',system-ui,sans-serif;font-weight:800;font-size:1.45rem;letter-spacing:.03em;text-decoration:none}
  .nav-email{color:var(--muted);text-decoration:none;font-family:var(--mono);font-size:.82rem;transition:color .25s}
  .nav-email:hover{color:var(--text);text-decoration:underline;text-underline-offset:4px}
  .nav-right{display:flex;gap:22px;align-items:center}
  .nav-links{display:flex;gap:22px;align-items:center}
  .nav-links a{color:var(--text);text-decoration:none;font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;transition:color .3s var(--ease)}
  .nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--accent)}
  .kbtn{font-family:var(--mono);font-size:.72rem;color:var(--muted);border:1px solid var(--border);border-radius:8px;padding:6px 9px;background:var(--surface);cursor:pointer}
  .kbtn:hover{color:var(--text);border-color:var(--accent)}
  @media (max-width:880px){.nav-email,.nav-links{display:none}#nav{display:flex;justify-content:space-between;padding:18px 20px}.kbtn{padding:10px 14px;font-size:.8rem}}

  /* Section label */
  .slabel{font-family:var(--mono);font-size:.78rem;color:var(--accent);letter-spacing:.2em;text-transform:uppercase;display:flex;align-items:center;gap:12px;margin-bottom:18px}
  .slabel::before{content:attr(data-n);color:var(--muted);font-weight:700}
  .slabel.center{justify-content:center}
  .stitle{font-family:var(--display);font-weight:800;font-size:clamp(2.4rem,6.5vw,4.6rem);letter-spacing:-.03em;line-height:.98}
  .stitle .hl{background:linear-gradient(110deg,var(--accent) 0%,#fff 50%,var(--accent-2) 100%);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:hlShimmer 8s linear infinite}
  @keyframes hlShimmer{to{background-position:-220% center}}
  .head-center{text-align:center;margin-bottom:72px}
  .ssub{color:var(--muted);max-width:600px;margin:18px auto 0}

  /* (unused split-text styles removed) */

  .reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
  .reveal.in{opacity:1;transform:none}
  .reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}

  /* Hero */
  .hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;padding:120px 28px 80px;max-width:var(--maxw);margin:0 auto}
  .hero-grid{position:relative;z-index:3;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;width:100%;align-items:center}
  @media (max-width:920px){.hero-grid{grid-template-columns:1fr;gap:46px}.hero-art{order:-1;min-height:auto}.hero-art .blender-avatar{width:min(360px,78%)}}
  .hero-wm{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);z-index:0;font-family:var(--display);font-weight:800;font-size:clamp(5rem,19vw,17rem);letter-spacing:-.04em;line-height:1;color:rgba(255,255,255,.022);white-space:nowrap;text-align:center;pointer-events:none}
  .status{display:inline-flex;align-items:center;gap:9px;padding:8px 15px;border:1px solid var(--border);border-radius:100px;background:rgba(16,13,28,.5);font-family:var(--mono);font-size:.74rem;color:var(--muted);margin-bottom:24px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
  .status .dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok);animation:pulse 2s infinite}
  @keyframes pulse{50%{opacity:.4}}
  .hello{font-size:clamp(1rem,2.2vw,1.3rem);color:var(--muted);margin-bottom:4px}
  .name{font-family:var(--display);font-weight:800;font-size:clamp(2.8rem,8.4vw,6.8rem);line-height:.86;letter-spacing:-.04em;margin-bottom:20px}
  .name .nm{display:block;overflow:hidden}
  .name .nm i{display:block;font-style:normal;background:linear-gradient(180deg,#fff 0%,#d8c9ff 45%,var(--accent) 110%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;transform:translateY(110%);transition:transform 1s var(--ease)}
  .name.in .nm i{transform:none}.name .nm:nth-child(2) i{transition-delay:.1s}
  .roles{font-family:'Sora',system-ui,sans-serif;font-weight:700;font-size:clamp(1.15rem,3.2vw,1.9rem);color:var(--text);min-height:1.5em;margin-bottom:22px}
  .roles .swap{color:var(--accent)}.roles .swap::after{content:'|';color:var(--accent);animation:blink 1s step-end infinite;margin-left:3px;font-weight:400}
  @keyframes blink{50%{opacity:0}}
  .lead{font-size:clamp(1rem,2vw,1.18rem);color:var(--muted);max-width:480px;margin-bottom:30px}.lead strong{color:var(--text);font-weight:600}
  .cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
  .btn{position:relative;display:inline-flex;align-items:center;gap:9px;padding:16px 30px;border-radius:12px;font-family:inherit;font-weight:600;font-size:.95rem;text-decoration:none;border:1px solid transparent;-webkit-appearance:none;appearance:none;cursor:pointer;transition:transform .2s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
  .btn:active{transform:translateY(1px) scale(.985)}
  .pos-tab:active,.socials a:active,.add-deal:active,.kbtn:active,.copy-email:active,.theme-dots button:active{transform:scale(.95)}
  @media (pointer:coarse){ .pos-line .q button{width:30px;height:30px} .pos-line .rm{padding:6px} .pos-mute{width:40px;height:40px} .to-top{width:46px;height:46px} }
  .btn-primary{color:#fff;background:linear-gradient(110deg,var(--accent-2),var(--accent));box-shadow:var(--glow)}
  .btn-primary:hover{box-shadow:0 0 75px rgba(var(--accent2-rgb),.75)}
  .btn-ghost{color:var(--text);border-color:var(--border);background:rgba(16,13,28,.4)}
  .btn-ghost:hover{border-color:var(--accent)}
  .hero-mini{display:flex;gap:30px;margin-top:36px;flex-wrap:wrap}
  .hero-mini .m b{font-family:'Sora',system-ui,sans-serif;font-size:1.8rem;font-variant-numeric:tabular-nums;display:block;background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
  .hero-mini .m span{color:var(--muted);font-size:.78rem;font-family:var(--mono)}
  .hero-art{position:relative;display:flex;align-items:center;justify-content:center;min-height:520px}
  .hero-art .blender-avatar{position:relative;right:auto;bottom:auto;transform:none;width:min(560px,100%);z-index:1;opacity:1}
  /* (unused legacy portrait/4D-layer styles removed) */
  .scroll-hint{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-family:var(--mono);color:var(--muted);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;text-decoration:none;z-index:4}

  /* Marquee */
  .marquee{overflow:hidden;padding:26px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);-webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
  .mq-track{display:flex;gap:46px;width:max-content;animation:scrollx 28s linear infinite;will-change:transform}
  .mq-track span{font-family:'Sora',system-ui,sans-serif;font-size:clamp(1.2rem,2.4vw,1.9rem);font-weight:700;color:#8f89aa;white-space:nowrap}
  .mq-track span::after{content:'✦';margin-left:46px;color:var(--accent)}
  .marquee:hover .mq-track{animation-play-state:paused}
  @keyframes scrollx{to{transform:translateX(-50%)}}

  /* About */
  .about-wrap{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
  @media (max-width:920px){.about-wrap{grid-template-columns:1fr;gap:34px}}
  .about-text h2{font-family:'Sora',system-ui,sans-serif;font-weight:700;font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:18px;letter-spacing:-.02em}
  .about-text p{color:var(--muted);font-size:1.08rem;margin-bottom:16px}.about-text strong{color:var(--text)}
  .tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
  .tag-row span{font-size:.8rem;color:var(--text);background:var(--surface);border:1px solid var(--border);padding:7px 14px;border-radius:100px}
  /* Terminal card */
  .term{border:1px solid rgba(var(--accent-rgb),.28);border-radius:18px;background:rgba(8,6,15,.7);box-shadow:var(--glow);overflow:hidden;font-family:var(--mono)}
  .term-bar{display:flex;align-items:center;gap:7px;padding:12px 16px;border-bottom:1px solid var(--border);color:var(--muted);font-size:.72rem}
  .term-bar i{width:10px;height:10px;border-radius:50%;background:#ff5f57}.term-bar i:nth-child(2){background:var(--warn)}.term-bar i:nth-child(3){background:#28c840}
  .term-bar span{margin-left:auto}
  .term-body{padding:18px 16px;display:grid;gap:12px;font-size:.86rem}
  .term-body .ln{display:flex;justify-content:space-between;gap:16px;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:11px}
  .term-body .ln:last-child{border-bottom:0;padding-bottom:0}
  .term-body .k{color:var(--accent)}.term-body .v{color:#fff;text-align:right}

  /* HUD cards */
  .do-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}@media (max-width:820px){.do-grid{grid-template-columns:1fr}}
  .hud{position:relative;padding:40px;border:1px dashed rgba(var(--accent-rgb),.28);border-radius:6px;background:rgba(16,13,28,.4);overflow:hidden;transition:border-color .3s,transform .3s}
  .hud:hover{border-color:rgba(var(--accent-rgb),.6);transform:translateY(-5px)}
  .hud::before,.hud::after,.hud .cn::before,.hud .cn::after{content:'';position:absolute;width:20px;height:20px;border:2px solid var(--accent)}
  .hud::before{top:6px;left:6px;border-right:0;border-bottom:0}.hud::after{bottom:6px;right:6px;border-left:0;border-top:0}
  .hud .cn::before{top:6px;right:6px;border-left:0;border-bottom:0}.hud .cn::after{bottom:6px;left:6px;border-right:0;border-top:0}
  .hud .glow{position:absolute;inset:0;opacity:0;transition:opacity .4s;background:radial-gradient(380px circle at var(--mx,50%) var(--my,50%),rgba(var(--accent2-rgb),.14),transparent 45%)}
  .hud:hover .glow{opacity:1}
  .hud h3{font-family:'Sora',system-ui,sans-serif;font-weight:800;font-size:1.7rem;text-transform:uppercase;margin-bottom:8px}
  .hud .tg{color:var(--accent);font-size:.9rem;margin-bottom:18px}
  .hud p{color:var(--muted);margin-bottom:22px}
  .hud .lbl{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:12px}

  /* Timeline — premium career rail */
  .tline{position:relative;max-width:780px;margin:0 auto;padding-left:6px}
  .tline-line{position:absolute;left:26px;top:12px;bottom:14px;width:3px;background:linear-gradient(rgba(var(--accent-rgb),.2),rgba(var(--accent-rgb),.05));overflow:hidden;border-radius:3px}
  .tline-line i{display:block;width:100%;height:100%;background:linear-gradient(var(--accent),var(--accent-2));transform:scaleY(var(--p,0));transform-origin:top;box-shadow:0 0 16px rgba(var(--accent2-rgb),.75)}
  .tl-row{position:relative;padding:0 0 30px 72px;opacity:0;transform:translateX(-26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
  .tl-row.in{opacity:1;transform:none}
  .tl-row:nth-child(3){transition-delay:.09s}.tl-row:nth-child(4){transition-delay:.18s}.tl-row:nth-child(5){transition-delay:.27s}
  .tl-row:last-child{padding-bottom:0}
  .tl-node{position:absolute;left:8px;top:0;width:40px;height:40px;border-radius:13px;display:grid;place-items:center;font-size:1.1rem;background:rgba(16,13,28,.9);border:1px solid rgba(var(--accent-rgb),.4);box-shadow:0 0 0 5px var(--bg),0 6px 20px rgba(0,0,0,.5);z-index:2;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
  .tl-row:hover .tl-node{transform:scale(1.1) rotate(-4deg);border-color:var(--accent);box-shadow:0 0 0 5px var(--bg),0 0 28px rgba(var(--accent2-rgb),.6)}
  .tl-row.now .tl-node{border-color:var(--accent)}
  .tl-row.now .tl-node::after{content:'';position:absolute;inset:-1px;border-radius:13px;border:1.5px solid var(--accent);animation:tlPulse 2.2s ease-out infinite;pointer-events:none}
  @keyframes tlPulse{0%{transform:scale(1);opacity:.85}100%{transform:scale(1.55);opacity:0}}
  .tl-row .inner{position:relative;border:1px solid var(--border);border-radius:18px;padding:18px 22px;background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.01));overflow:hidden;transition:border-color .3s var(--ease),transform .3s var(--ease),box-shadow .3s var(--ease)}
  .tl-row .inner::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(var(--accent),var(--accent-2));opacity:.55;transition:opacity .3s}
  .tl-row .inner::after{content:'';position:absolute;left:-22px;top:21px;width:22px;height:2px;background:linear-gradient(90deg,transparent,rgba(var(--accent-rgb),.55))}
  .tl-row:hover .inner{border-color:rgba(var(--accent-rgb),.5);transform:translateX(5px);box-shadow:0 18px 50px rgba(0,0,0,.4)}
  .tl-row:hover .inner::before{opacity:1}
  .tl-row .yr{display:inline-block;font-family:var(--mono);font-size:.7rem;color:var(--accent);border:1px solid rgba(var(--accent-rgb),.3);background:rgba(var(--accent2-rgb),.08);padding:4px 12px;border-radius:100px;margin-bottom:10px;letter-spacing:.08em}
  .tl-row .yr.now{color:#fff;background:linear-gradient(110deg,var(--accent-2),var(--accent));border-color:transparent;box-shadow:var(--glow)}
  .tl-row h3{font-family:'Sora',system-ui,sans-serif;font-weight:700;font-size:1.22rem;line-height:1.18}
  .tl-row .sub{color:var(--accent);font-size:.88rem;margin-top:4px}
  .tl-row .desc{color:var(--muted);font-size:.94rem;margin-top:10px;max-width:600px}
  .tl-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
  .tl-tags span{font-family:var(--mono);font-size:.66rem;color:var(--muted);border:1px solid var(--border);background:rgba(255,255,255,.02);padding:4px 10px;border-radius:7px;transition:color .25s,border-color .25s,background .25s}
  .tl-row:hover .tl-tags span{color:var(--accent);border-color:rgba(var(--accent-rgb),.35);background:rgba(var(--accent2-rgb),.06)}
  @media(max-width:560px){.tl-row{padding-left:60px}.tl-node{width:34px;height:34px;font-size:1rem}.tline-line{left:22px}.tl-row .inner::after{left:-20px;width:20px}}

  /* Work — pinned horizontal */
  #work{max-width:100%;padding:0}
  .work-pin{position:relative;display:flex;align-items:center;padding:76px 0;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;cursor:grab}
  .work-pin.grabbing{scroll-snap-type:none;cursor:grabbing}/* don't fight the drag with snap; snap re-engages on release */
  .work-pin.grabbing{cursor:grabbing}
  .work-pin.grabbing .wcard{pointer-events:none}
  /* desktop scroll-driven sticky horizontal pan (enabled by JS via #work.sticky-mode; min-height set inline) */
  #work.sticky-mode{padding:0}
  #work.sticky-mode .work-pin{position:sticky;top:0;height:100vh;height:100svh;padding:0;overflow:hidden;scroll-snap-type:none;cursor:default}
  #work.sticky-mode .work-track{padding:0 7vw;will-change:transform}
  #work.sticky-mode .wcard,#work.sticky-mode .work-intro{scroll-snap-align:none}
  .work-track{display:flex;gap:30px;padding:0 28px}
  body.pinned .work-pin{height:100vh;height:100svh;padding:0;overflow:hidden}
  body.pinned .work-track{padding:0 7vw;will-change:transform}
  .work-intro{flex:0 0 min(420px,80vw);display:flex;flex-direction:column;justify-content:center;scroll-snap-align:center}
  .wcard{flex:0 0 min(380px,80vw);min-height:62vh;border:1px solid var(--border);border-radius:24px;background:var(--bg-2);overflow:hidden;text-decoration:none;color:inherit;display:flex;flex-direction:column;transition:transform .35s var(--ease),border-color .35s;scroll-snap-align:center}
  .wcard:hover{transform:translateY(-8px);border-color:rgba(var(--accent-rgb),.55)}
  .wcard .thumb{height:46%;display:grid;place-items:center;font-size:3.4rem;position:relative;overflow:hidden;background:#0d0a18}
  .wcard .thumb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .5s var(--ease)}
  .wcard:hover .thumb-img{transform:scale(1.04)}
  .wcard .thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,15,.1),rgba(8,6,15,.5));z-index:1;pointer-events:none}
  .wcard .thumb .no{position:absolute;top:18px;left:22px;z-index:2;font-family:'Sora',system-ui,sans-serif;font-weight:800;font-size:1.3rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.75)}
  .wcard .body{padding:26px;display:flex;flex-direction:column;flex:1}
  .wcard .cat{font-family:var(--mono);color:var(--accent);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:8px}
  .wcard h3{font-family:'Sora',system-ui,sans-serif;font-weight:700;font-size:1.5rem;margin-bottom:10px}
  .wcard .tools{color:var(--muted);font-size:.9rem}
  .wcard .go{margin-top:auto;padding-top:18px;color:var(--accent);font-family:var(--mono);font-size:.82rem}
  /* Mobile: proper swipe carousel — heading slide + peeking cards, one-per-swipe snap */
  @media(max-width:820px){
    #work{padding:60px 0 32px}
    .work-pin{align-items:stretch;padding:8px 0 18px;scroll-snap-type:x mandatory;scroll-padding-left:18px}
    .work-track{gap:14px;padding:0 18px}
    .work-intro{flex:0 0 min(80vw,420px);justify-content:center;scroll-snap-align:center;scroll-snap-stop:always}
    .wcard{flex:0 0 min(80vw,420px);min-height:auto;scroll-snap-align:center;scroll-snap-stop:always}
    .wcard .thumb{height:172px}
    .wcard .body{padding:22px}
    .ssub .cue-d{display:none}.ssub .cue-m{display:inline}
  }
  .cue-m{display:none}/* desktop shows "Scroll →", mobile (more specific rule above) shows "Swipe →" */

  /* ===== Mobile polish pass (phone-only; desktop untouched) ===== */
  /* fix horizontal overflow: flex/grid children with nowrap text must be allowed to shrink (min-width:0) */
  @media(max-width:900px){
    .net-wrap>*,.net-hud,.net-stage,.net-stats,.net-stat,.net-feed,.net-feed-h,.net-feed-list,.net-feed-row,.net-feed-row .ms{min-width:0}
    section{padding-top:104px;padding-bottom:104px}/* smoother vertical rhythm across the tablet range */
  }
  @media(max-width:680px){
    /* tighter, more intentional vertical rhythm on phones */
    section{padding:80px 22px}
    .hero{padding:96px 22px 64px}
    #stack{padding-top:76px;padding-bottom:88px}
    #network{padding-top:80px;padding-bottom:38px}
    /* Network: the corner scan label has no room — the LIVE badge is enough */
    .net-scan{display:none}
    .net-stat b{font-size:1.5rem}
    .net-stat span{font-size:.64rem}
    /* POS "Today's Special": let the description wrap to its own line instead of being crushed to nothing */
    .pos-deal{flex-wrap:wrap;row-gap:8px}
    .pos-deal .txt{flex-basis:100%;order:3;white-space:normal;overflow:visible;text-overflow:clip}
    .pos-deal .add-deal{margin-left:auto}
    .pos-deal .was{display:inline}
  }

  /* Tech grid */
  #stack{position:relative;overflow:hidden;width:100%;max-width:none;padding:120px max(28px,calc((100% - var(--maxw))/2)) 160px}/* full-bleed so the bg spans edge-to-edge; horizontal padding re-centers a 1180px content column (same trick as #nav) */
  #stack::before{content:'';position:absolute;left:50%;top:58%;transform:translate(-50%,-50%);width:min(780px,82vw);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(var(--accent2-rgb),.22),rgba(var(--accent2-rgb),.06) 45%,transparent 66%);filter:blur(50px);z-index:0;pointer-events:none;animation:corePulse 6s ease-in-out infinite}
  @keyframes corePulse{50%{opacity:.6;transform:translate(-50%,-50%) scale(1.09)}}
  #stackbg{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;opacity:.5}/* calmed from .9 → .5 so the globe recedes and makes room for the crystal + godray layers */
  /* Generated crystalline video backdrop — sits UNDER the wireframe globe as an ambient base coat.
     The wrapper is `isolate`d so its tint blends ONLY onto the video, not the rest of the section.
     A radial mask softens the rectangular edges; the near-black video matches the section bg so the
     glass reads as floating depth. Desktop + motion only. */
  /* base scale(1.08) = headroom so the parallax drift never reveals the masked edges */
  .stack-bg-wrap{position:absolute;inset:0;z-index:0;pointer-events:none;isolation:isolate;opacity:0;transform:scale(1.08);will-change:transform;transition:opacity 1.4s var(--ease),transform .12s var(--ease);-webkit-mask-image:radial-gradient(135% 130% at 50% 42%,#000 56%,transparent 100%);mask-image:radial-gradient(135% 130% at 50% 42%,#000 56%,transparent 100%)}
  .stack-bg-wrap.in{opacity:.62}
  .stack-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:blur(1.2px) saturate(1.15)}
  /* `color` blend keeps the crystal's luminance/refraction but swaps its hue to the live accent → recolors with the theme switcher */
  .stack-tint{position:absolute;inset:0;background:var(--accent);mix-blend-mode:color;opacity:.55}
  /* brand-color spotlight: a soft bloom of the hovered tile's real brand color, behind the tiles */
  .stack-spot{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:0;transition:opacity .45s var(--ease);mix-blend-mode:screen;background:radial-gradient(280px circle at var(--sx,50%) var(--sy,50%),color-mix(in srgb,var(--sc,var(--accent)) 60%,transparent),transparent 72%)}
  .stack-spot.on{opacity:.85}
  @media (pointer:coarse){.stack-spot{display:none}}
  /* generated godray top-light — masked to the upper area so it fades out before the tile grid; screen blend so only the light reads */
  .stack-rays{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;pointer-events:none;opacity:0;transition:opacity 1.6s var(--ease);mix-blend-mode:screen;-webkit-mask-image:linear-gradient(#000 0%,#000 28%,transparent 62%);mask-image:linear-gradient(#000 0%,#000 28%,transparent 62%)}
  .stack-rays.in{opacity:.32}
  @media (max-width:760px){.stack-rays{display:none}}
  @media (prefers-reduced-motion:reduce){.stack-rays{display:none}}
  @media (max-width:760px){.stack-bg-wrap{display:none}}
  @media (prefers-reduced-motion:reduce){.stack-bg-wrap{display:none}}
  #stack>.head-center,#stack>.tech-grid{position:relative;z-index:2}
  .tech-grid{display:flex;flex-direction:column;align-items:center;gap:26px;max-width:var(--maxw);margin:0 auto}
  .tech-row{display:flex;gap:26px;justify-content:center;flex-wrap:wrap}
  .tech-item{width:112px}
  @media (max-width:1120px){.tech-row{gap:16px}.tech-item{width:96px}}
  @media (max-width:760px){.tech-grid{gap:14px}.tech-row{gap:10px}.tech-item{width:76px;padding:18px 8px}.tech-item i{font-size:2rem}}
  .tech-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 10px;border:1px solid var(--border);border-radius:16px;background:rgba(16,13,28,.42);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);text-decoration:none;overflow:hidden;transition:transform .25s var(--ease),border-color .25s,box-shadow .25s,background .25s}
  .tech-item:hover{background:rgba(16,13,28,.66)}
  .tech-item::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .25s var(--ease);background:radial-gradient(120% 80% at 50% 0,rgba(var(--accent2-rgb),.18),transparent 70%);background:radial-gradient(120% 80% at 50% 0,color-mix(in srgb,var(--bc,var(--accent)) 22%,transparent),transparent 70%)}
  .tech-item::after{content:'↗';position:absolute;top:8px;right:8px;width:21px;height:21px;display:grid;place-items:center;border-radius:7px;font-family:var(--mono);font-size:.72rem;font-weight:700;color:var(--bc,var(--accent));background:rgba(var(--accent2-rgb),.16);background:color-mix(in srgb,var(--bc,var(--accent)) 18%,transparent);opacity:0;transform:translateY(-4px) scale(.7);transition:opacity .25s var(--ease),transform .25s var(--ease)}
  .tech-item:hover{transform:translateY(-8px);border-color:var(--bc,var(--accent));box-shadow:0 16px 50px rgba(var(--accent2-rgb),.28);box-shadow:0 16px 50px color-mix(in srgb,var(--bc,var(--accent)) 30%,transparent)}
  .tech-item:hover::before{opacity:1}.tech-item:hover::after{opacity:1;transform:none}
  .tech-item i{position:relative;font-size:2.4rem;color:#fff;transition:transform .3s var(--ease),filter .3s var(--ease)}
  .tech-item:hover i{transform:scale(1.16) translateY(-3px);filter:drop-shadow(0 8px 16px rgba(var(--accent2-rgb),.5));filter:drop-shadow(0 8px 16px color-mix(in srgb,var(--bc,var(--accent)) 55%,transparent))}
  .tech-item .nm{transition:color .25s}.tech-item:hover .nm{color:var(--bc,var(--accent))}
  .tech-item .nm{position:relative;font-size:.78rem;color:var(--muted);font-family:var(--mono)}

  /* Certificates */
  .cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
  @media (min-width:680px){.cert-grid{grid-template-columns:1fr 1fr;max-width:840px;margin:0 auto}}
  .cert{border:1px solid var(--border);border-radius:18px;padding:24px;background:var(--surface);transition:transform .3s var(--ease),border-color .3s var(--ease)}
  .cert:hover{transform:translateY(-6px);border-color:rgba(var(--accent-rgb),.5)}
  .cert .org{font-family:var(--mono);font-size:.72rem;color:var(--accent);text-transform:uppercase;letter-spacing:.14em;margin-bottom:10px}
  .cert h3{font-family:'Sora',system-ui,sans-serif;font-weight:700;font-size:1.12rem;line-height:1.2}.cert p{color:var(--muted);font-size:.88rem;margin-top:8px}

  /* What I Bring */
  .value-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
  @media(max-width:920px){.value-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:540px){.value-grid{grid-template-columns:1fr}}
  .value-card{border:1px solid var(--border);border-radius:18px;padding:28px;background:var(--bg-2);transition:transform .3s var(--ease),border-color .3s}
  .value-card:hover{transform:translateY(-6px);border-color:rgba(var(--accent-rgb),.5)}
  .value-card .ic{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;font-size:1.4rem;margin-bottom:16px;background:linear-gradient(135deg,rgba(var(--accent-rgb),.25),rgba(var(--accent2-rgb),.1));border:1px solid var(--border);transition:transform .3s var(--ease)}
  .value-card:hover .ic{transform:scale(1.06)}
  .value-card h3{font-family:'Sora',system-ui,sans-serif;font-size:1.15rem;margin-bottom:8px}
  .value-card p{color:var(--muted);font-size:.92rem}

  /* Featured spotlight */
  .spotlight{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;max-width:1100px;margin:0 auto}
  @media(max-width:900px){.spotlight{grid-template-columns:1fr;gap:32px}}
  .spot-tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);border:1px solid rgba(var(--accent-rgb),.3);background:rgba(var(--accent2-rgb),.08);padding:6px 12px;border-radius:100px;margin-bottom:16px}
  .spot-copy h3{font-family:'Sora',system-ui,sans-serif;font-weight:700;font-size:clamp(1.4rem,3vw,2rem);margin-bottom:16px;letter-spacing:-.02em}
  .spot-copy p{color:var(--muted);margin-bottom:12px}.spot-copy p b{color:var(--text);font-weight:600}
  .spot-metrics{display:flex;gap:26px;flex-wrap:wrap;margin:22px 0}
  .spot-metrics .sm b{font-family:'Sora',system-ui,sans-serif;font-weight:800;font-size:1.6rem;font-variant-numeric:tabular-nums;display:block;background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
  .spot-metrics .sm span{color:var(--muted);font-size:.74rem;font-family:var(--mono)}
  .mock{border:1px solid var(--border);border-radius:16px;overflow:hidden;background:#0c0a17;box-shadow:0 40px 90px rgba(0,0,0,.5),var(--glow)}
  .mock-bar{display:flex;align-items:center;gap:7px;padding:12px 14px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}
  .mock-bar i{width:10px;height:10px;border-radius:50%;background:#ff5f57}.mock-bar i:nth-child(2){background:var(--warn)}.mock-bar i:nth-child(3){background:#28c840}
  .mock-bar span{margin-left:10px;font-family:var(--mono);font-size:.7rem;color:var(--muted)}
  .mock-body{padding:18px;display:grid;gap:12px}
  .mock-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
  .mock-stat{border:1px solid var(--border);border-radius:10px;padding:12px;background:rgba(255,255,255,.02)}
  .mock-stat b{font-family:'Sora',system-ui,sans-serif;font-weight:800;font-size:1.3rem;color:var(--accent)}
  .mock-stat span{display:block;color:var(--muted);font-size:.66rem;font-family:var(--mono);margin-top:2px}
  .mock-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.02);font-size:.8rem}
  .mock-row .dev{display:flex;align-items:center;gap:10px;color:var(--text)}
  .mock-row .d{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok);flex:none}
  .mock-row .d.warn{background:var(--warn);box-shadow:0 0 8px var(--warn)}
  .mock-row .who{color:var(--muted);font-family:var(--mono);font-size:.72rem}
  .mock-row .tg{font-family:var(--mono);font-size:.64rem;color:var(--accent);border:1px solid rgba(var(--accent-rgb),.3);border-radius:6px;padding:2px 7px;flex:none}

  /* FAQ */
  .faq-grid{max-width:820px;margin:0 auto;display:grid;gap:12px}
  .faq{border:1px solid var(--border);border-radius:14px;background:var(--bg-2);overflow:hidden;transition:border-color .25s}
  .faq:hover{border-color:rgba(var(--accent-rgb),.4)}
  .faq summary{list-style:none;cursor:pointer;padding:20px 24px;font-family:var(--display);font-weight:700;font-size:1.05rem;display:flex;justify-content:space-between;align-items:center;gap:16px}
  .faq summary::-webkit-details-marker{display:none}
  .faq summary::after{content:'+';color:var(--accent);font-size:1.5rem;line-height:1;transition:transform .25s;flex:none}
  .faq[open] summary::after{transform:rotate(45deg)}
  .faq p{padding:0 24px 22px;color:var(--muted);font-size:.95rem;margin:0}
  .faq[open] p{animation:faqIn .28s var(--ease)}
  @keyframes faqIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
  /* ⌘K scroll-progress ring */
  .kbtn{position:relative}
  .kbtn::before{content:'';position:absolute;inset:-3px;border-radius:11px;padding:2px;background:conic-gradient(var(--accent) calc(var(--p,0)*360deg),rgba(255,255,255,.08) 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}

  /* How I Work — process */
  .proc{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;counter-reset:step;max-width:1000px;margin:0 auto}
  @media(max-width:780px){.proc{grid-template-columns:1fr}}
  .proc .step{position:relative;border:1px solid var(--border);border-radius:18px;padding:30px 26px;background:var(--bg-2);transition:transform .3s var(--ease),border-color .3s}
  .proc .step:hover{transform:translateY(-6px);border-color:rgba(var(--accent-rgb),.5)}
  .proc .step::before{counter-increment:step;content:'0' counter(step);display:block;font-family:var(--display);font-weight:800;font-size:2.2rem;line-height:1;margin-bottom:14px;background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
  .proc .step h3{font-family:'Sora',system-ui,sans-serif;font-weight:700;font-size:1.2rem;margin-bottom:8px}
  .proc .step p{color:var(--muted);font-size:.92rem}

  /* Contact */
  .contact{text-align:center}
  .contact .big{font-family:var(--display);font-weight:800;font-size:clamp(2.6rem,9vw,6.5rem);letter-spacing:-.03em;line-height:1;margin:18px 0 26px}
  .contact .big a{background:linear-gradient(110deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-decoration:none}
  .socials{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:34px}
  .socials a{padding:14px 26px;border:1px solid var(--border);border-radius:12px;color:var(--text);text-decoration:none;background:var(--surface);font-family:var(--mono);font-size:.85rem;transition:transform .3s var(--ease),border-color .3s var(--ease),color .3s var(--ease)}
  .socials a:hover{transform:translateY(-3px);border-color:var(--accent);color:var(--accent)}
  footer{text-align:center;padding:44px;color:var(--muted);font-size:.85rem;border-top:1px solid var(--border);font-family:var(--mono)}

  /* Command palette */
  .palette{position:fixed;inset:0;z-index:120;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:none;place-items:start center;padding-top:14vh}
  .palette.open{display:grid}
  .palette-box{width:min(560px,calc(100% - 32px));max-height:80vh;overflow:auto;overscroll-behavior:contain;border:1px solid rgba(var(--accent-rgb),.28);background:#0b0816;border-radius:20px;padding:10px;box-shadow:0 40px 130px rgba(0,0,0,.8)}
  .palette input{width:100%;border:0;outline:0;background:rgba(255,255,255,.06);color:#fff;border-radius:12px;padding:16px 18px;font-size:1rem;font-family:var(--mono)}
  .palette a{display:flex;justify-content:space-between;padding:13px 16px;border-radius:12px;color:var(--muted);text-decoration:none;font-weight:600;margin-top:4px}
  .palette a:hover,.palette a.sel{background:rgba(var(--accent2-rgb),.16);color:#fff}
  .palette a .h{font-family:var(--mono);font-size:.7rem;opacity:.5}
  .pal-empty{padding:14px 16px;color:var(--muted);font-family:var(--mono);font-size:.85rem}
  @media (forced-colors: active){
    .stitle .hl,.name .nm i,.hero-mini .m b,.contact .big a,.pre-name,.tl-row .yr.now,.logo{-webkit-text-fill-color:currentColor!important;color:CanvasText!important;background:none!important}
  }

  #progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:110;background:linear-gradient(90deg,var(--accent),var(--accent-2))}

  /* ===== Wave 1 enhancements ===== */
  .aurora{animation:auroraHue 18s ease-in-out infinite alternate}
  @keyframes auroraHue{from{filter:blur(30px) hue-rotate(-10deg)}to{filter:blur(30px) hue-rotate(14deg)}}
  .grain{animation:grainMove 1.1s steps(6) infinite}
  @keyframes grainMove{0%{background-position:0 0}100%{background-position:180px 180px}}
  .btn{overflow:hidden}
  .btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 35%,rgba(255,255,255,.28) 50%,transparent 65%);transform:translateX(-130%);transition:transform .6s var(--ease);pointer-events:none}
  .btn-primary:hover::before{transform:translateX(130%)}
  .nav-links a{position:relative}
  .nav-links a::after{content:'';position:absolute;left:0;right:0;bottom:-5px;height:2px;border-radius:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
  .nav-links a:hover::after,.nav-links a[aria-current="page"]::after{transform:scaleX(1)}
  .to-top{position:fixed;right:24px;bottom:64px;z-index:95;width:44px;height:44px;border-radius:12px;border:1px solid var(--border);background:rgba(16,13,28,.7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text);font-size:1.1rem;cursor:pointer;opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .3s,transform .3s,border-color .3s,color .3s}
  .to-top.show{opacity:1;transform:none;pointer-events:auto}
  .to-top:hover{border-color:var(--accent);color:var(--accent)}
  @media(max-width:980px){.to-top{right:16px;bottom:max(16px,env(safe-area-inset-bottom))}}
  .toast{position:fixed;left:50%;bottom:32px;transform:translate(-50%,20px);z-index:400;background:var(--accent-2);color:#fff;font-family:var(--mono);font-size:.82rem;padding:12px 20px;border-radius:12px;box-shadow:var(--glow);opacity:0;pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease)}
  .toast.show{opacity:1;transform:translate(-50%,0)}
  .copy-email{margin-top:18px;background:none;border:1px dashed var(--border);color:var(--muted);font-family:var(--mono);font-size:.82rem;padding:10px 16px;border-radius:10px;cursor:pointer;transition:color .2s,border-color .2s}
  .copy-email:hover{color:var(--accent);border-color:var(--accent)}
  .cform{max-width:520px;margin:38px auto 8px;display:grid;gap:14px;text-align:left}
  .cform .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  @media(max-width:560px){.cform .row{grid-template-columns:1fr}}
  .cform label{font-family:var(--mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:6px;display:block}
  .cform input,.cform textarea{width:100%;background:rgba(16,13,28,.5);border:1px solid var(--border);border-radius:12px;padding:13px 15px;color:var(--text);font-family:inherit;font-size:16px;-webkit-appearance:none;appearance:none;transition:border-color .2s}
  .cform input:focus,.cform textarea:focus{outline:none;border-color:var(--accent)}
  .cform input::placeholder,.cform textarea::placeholder,.palette input::placeholder{color:var(--muted);opacity:.7}
  .cform textarea{min-height:120px;resize:vertical}
  .cform .send{justify-self:center}
  .wstatus{position:absolute;top:16px;right:16px;font-family:var(--mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ok);border:1px solid rgba(var(--ok-rgb),.4);background:rgba(var(--ok-rgb),.12);border-radius:100px;padding:3px 9px}
  .learning{text-align:center;margin-top:36px;font-family:var(--mono);font-size:.82rem;color:var(--muted)}
  .learning b{color:var(--accent);font-weight:400}
  .tilt3d{transform-style:preserve-3d}/* will-change toggled in JS on hover so 8 cards don't hold GPU layers for the whole page life */
  /* accent switcher */
  .theme-dots{position:fixed;left:20px;bottom:20px;z-index:96;display:flex;gap:8px;background:rgba(16,13,28,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:100px;padding:8px}
  .theme-dots button{width:18px;height:18px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:transform .2s,border-color .2s}
  .theme-dots button:hover{transform:scale(1.15)}
  .theme-dots button[aria-pressed="true"]{border-color:#fff}
  @media(max-width:980px){.theme-dots{left:12px;bottom:max(12px,env(safe-area-inset-bottom))}}
  /* shimmering logo monogram */
  .logo{background:linear-gradient(90deg,#fff,var(--accent),#fff);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:logoSh 6s linear infinite}
  @keyframes logoSh{to{background-position:200% center}}

  @media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation:none!important;transition:none!important}.reveal,.name .nm i{opacity:1!important;transform:none!important}#preloader{display:none}}
  @media print{
    *{cursor:auto!important;box-shadow:none!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
    body{background:#fff;color:#000}
    .aurora,.gridbg,.grain,.cur-blob,.cur-dot,#progress,#stackbg,.stack-bg-wrap,.stack-rays,.stack-spot,#preloader,.social-rail,.resume-fixed,.scroll-hint,.marquee,.kbtn,.hero-wm,.palette,#network,#pos,#stack,.to-top,.theme-dots,.toast,#ctxMenu,#shortcuts,.cta-row,.hero-art{display:none!important}
    .reveal,.name .nm i{opacity:1!important;transform:none!important}
    a{color:#000;text-decoration:underline}
    .socials a[href^="http"]::after,.contact .big a[href^="mailto"]::after{content:" (" attr(href) ")";font-family:monospace;font-size:.82em;color:#444;text-decoration:none}
    .stitle .hl,.name .nm i,.hero-mini .m b,.contact .big a,.tl-row .yr.now,.pre-name{-webkit-text-fill-color:#000!important;color:#000!important;background:none!important}
    section,.hero{padding:24px 0;min-height:0;page-break-inside:avoid}
    .tech-item,.hud,.cert,.wcard{border-color:#ccc!important;background:#fff!important}
  }

  /* ===== cool features ===== */
  /* FX confetti canvas */
  #fx{position:fixed;inset:0;width:100%;height:100%;z-index:9997;pointer-events:none}
  /* live GitHub stats */
  .gh-stats{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;min-height:30px}
  .gh-stats .gs{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:.74rem;color:var(--muted);border:1px solid var(--border);background:rgba(255,255,255,.02);padding:6px 12px;border-radius:100px;opacity:0;transform:translateY(6px);transition:opacity .5s var(--ease),transform .5s var(--ease),color .25s,border-color .25s}
  .gh-stats .gs.in{opacity:1;transform:none}
  .gh-stats .gs b{color:var(--accent);font-weight:700}
  .gh-stats .gs:hover{border-color:rgba(var(--accent-rgb),.4);color:var(--text)}
  /* branded context menu */
  .ctx{position:fixed;z-index:9990;min-width:210px;padding:7px;border-radius:14px;background:rgba(13,10,24,.92);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(var(--accent-rgb),.28);box-shadow:0 24px 70px rgba(0,0,0,.6);opacity:0;transform:scale(.96);transform-origin:top left;pointer-events:none;visibility:hidden;transition:opacity .14s var(--ease),transform .14s var(--ease)}
  .ctx.open{opacity:1;transform:none;pointer-events:auto;visibility:visible}
  .ctx button,.ctx a{display:flex;width:100%;align-items:center;gap:10px;padding:9px 12px;border:0;background:none;border-radius:9px;color:var(--text);font:inherit;font-size:.85rem;text-align:left;text-decoration:none;cursor:pointer}
  .ctx button:hover,.ctx a:hover{background:rgba(var(--accent2-rgb),.18);color:#fff}
  /* shortcuts cheatsheet */
  .sheet{position:fixed;inset:0;z-index:130;display:grid;place-items:center;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;transition:opacity .2s}
  .sheet.open{opacity:1}
  .sheet[hidden]{display:none}
  .sheet-box{width:min(420px,calc(100% - 32px));background:#0b0816;border:1px solid rgba(var(--accent-rgb),.28);border-radius:20px;padding:26px 28px;box-shadow:0 40px 130px rgba(0,0,0,.8);transform:translateY(10px) scale(.98);transition:transform .25s var(--ease)}
  .sheet.open .sheet-box{transform:none}
  .sheet-box h3{font-family:var(--display);font-size:1.3rem;margin-bottom:18px}
  .sheet-box ul{list-style:none;display:grid;gap:11px}
  .sheet-box li{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--muted);font-size:.92rem}
  .sheet-box kbd{font-family:var(--mono);font-size:.72rem;color:var(--text);background:rgba(255,255,255,.06);border:1px solid var(--border);border-bottom-width:2px;border-radius:7px;padding:3px 8px;margin-left:5px}
  .sheet-hint{margin-top:18px;font-family:var(--mono);font-size:.72rem;color:var(--muted);opacity:.8}
  /* idle nudge on ⌘K */
  @keyframes kbPulse{0%,100%{box-shadow:0 0 0 0 rgba(var(--accent2-rgb),.5)}50%{box-shadow:0 0 0 7px rgba(var(--accent2-rgb),0)}}
  .kbtn.nudge{animation:kbPulse 1.4s ease-out 3;border-color:var(--accent)}
  @media (prefers-reduced-motion:reduce){.kbtn.nudge{animation:none}}

  /* ===== Store Network — live fleet map (canvas) ===== */
  .slabel .gly{font-family:var(--mono);color:var(--accent)}
  #network{max-width:calc(var(--maxw) + 160px)}
  .net-wrap{display:grid;grid-template-columns:1.5fr .9fr;gap:24px;max-width:calc(var(--maxw) + 100px);margin:0 auto;align-items:stretch}
  @media(max-width:900px){.net-wrap{grid-template-columns:1fr}}
  .net-stage{position:relative;border:1px solid var(--border);border-radius:20px;overflow:hidden;background:linear-gradient(180deg,rgba(10,8,20,.7),rgba(8,6,15,.85));min-height:540px;box-shadow:inset 0 0 80px rgba(0,0,0,.5),var(--glow)}
  @media(max-width:900px){.net-stage{min-height:420px}}
  @media(max-width:480px){.net-stage{min-height:330px}.net-tip{white-space:normal;max-width:min(220px,72vw)}}
  @media(max-width:400px){.hero{padding-left:16px;padding-right:16px}section{padding-left:16px;padding-right:16px}.hero-mini{gap:18px}.spot-metrics{gap:16px}}
  .net-stage canvas{display:block;width:100%;height:100%;position:absolute;inset:0}
  .net-live{position:absolute;top:14px;left:16px;z-index:2;font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:#bdf5d0;display:flex;align-items:center;gap:7px;background:rgba(8,6,15,.55);border:1px solid rgba(var(--ok-rgb),.32);padding:5px 11px;border-radius:100px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
  .net-live i{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok);animation:pulse 2s infinite}
  .net-scan{position:absolute;top:14px;right:16px;z-index:2;font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
  .net-tip{position:absolute;z-index:3;pointer-events:none;opacity:0;transform:translate(-50%,-118%);transition:opacity .18s var(--ease);font-family:var(--mono);font-size:.66rem;line-height:1.5;color:var(--text);background:rgba(13,10,24,.94);border:1px solid rgba(var(--accent-rgb),.3);border-radius:9px;padding:7px 10px;white-space:nowrap;box-shadow:0 12px 34px rgba(0,0,0,.6)}
  .net-tip.on{opacity:1}
  .net-tip b{color:var(--accent);font-weight:700}
  .net-tip .st{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px;vertical-align:middle}
  .net-hud{display:flex;flex-direction:column;gap:14px}
  .net-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .net-stat{position:relative;border:1px solid var(--border);border-radius:18px;padding:16px 18px;background:rgba(16,13,28,.42);overflow:hidden;transition:border-color .3s var(--ease),transform .3s var(--ease)}
  .net-stat:hover{border-color:rgba(var(--accent-rgb),.5);transform:translateY(-5px)}
  .net-stat::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(var(--accent),var(--accent-2));opacity:.7}
  .net-stat b{display:block;font-family:'Sora',system-ui,sans-serif;font-weight:800;font-size:1.7rem;line-height:1;background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-variant-numeric:tabular-nums}
  .net-stat span{display:block;margin-top:6px;color:var(--muted);font-family:var(--mono);font-size:.68rem;letter-spacing:.04em}
  /* live ops activity feed — store-tech events streaming in */
  .net-feed{flex:1;min-height:150px;border:1px solid var(--border);border-radius:16px;background:rgba(16,13,28,.42);overflow:hidden;display:flex;flex-direction:column}
  .net-feed-h{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:11px 14px 9px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
  .net-feed-h .dot{width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok);animation:pulse 2s infinite;display:inline-block;margin-right:6px}
  .net-feed-list{flex:1;overflow:hidden;padding:5px 0;-webkit-mask-image:linear-gradient(#000 84%,transparent);mask-image:linear-gradient(#000 84%,transparent)}
  .net-feed-row{display:flex;gap:8px;align-items:baseline;padding:5px 14px;font-family:var(--mono);font-size:.64rem;line-height:1.4;animation:feedIn .35s var(--ease)}
  @keyframes feedIn{from{opacity:0;transform:translateY(-7px)}to{opacity:1;transform:none}}
  .net-feed-row .tm{color:var(--accent);flex:none;opacity:.8}
  .net-feed-row .ic{flex:none;width:11px;text-align:center}
  .net-feed-row.ok .ic{color:var(--ok)}.net-feed-row.warn .ic{color:var(--warn)}.net-feed-row.up .ic{color:var(--accent)}
  .net-feed-row,.net-feed-row .ms{min-width:0}/* allow the nowrap message to shrink+ellipsis on desktop too (was only ≤900px) */
  .net-feed-row .ms{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .net-feed-row .ms b{color:var(--muted);font-weight:400}
  .net-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:2px;padding:14px 20px;border:1px solid var(--border);border-radius:16px;background:rgba(16,13,28,.42)}
  .net-legend i{font-family:var(--mono);font-size:.68rem;color:var(--muted);display:inline-flex;align-items:center;gap:7px;font-style:normal}
  .net-legend i::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--c,var(--ok));box-shadow:0 0 8px var(--c,var(--ok))}

  /* ===== Playable POS — "ring me up" interactive register ===== */
  #pos{max-width:calc(var(--maxw) + 140px)}
  .pos{display:flex;flex-direction:column;max-width:calc(var(--maxw) + 60px);margin:0 auto;border:1px solid rgba(var(--accent-rgb),.28);border-radius:24px;overflow:hidden;background:linear-gradient(180deg,rgba(14,11,26,.9),rgba(8,6,15,.95));box-shadow:0 44px 120px rgba(0,0,0,.6),var(--glow)}
  .pos-top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(var(--accent2-rgb),.12),transparent)}
  .pos-brand{font-family:'Sora',system-ui,sans-serif;font-weight:800;font-size:.95rem;letter-spacing:.01em;display:flex;align-items:center;gap:9px}
  .pos-led{width:9px;height:9px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok);animation:pulse 2s infinite;flex:none}
  .pos-top-r{display:flex;align-items:center;gap:10px;min-width:0}
  .pos-disp{font-family:var(--mono);font-size:.7rem;color:var(--accent);background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:8px;padding:5px 11px;max-width:46vw;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
  @media(max-width:560px){.pos-disp{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}}/* visually hidden but still announced to screen readers */
  .pos-disp.flash{animation:dispFlash .55s var(--ease)}
  @keyframes dispFlash{0%{background:rgba(var(--accent2-rgb),.45);color:#fff;border-color:var(--accent)}100%{background:rgba(0,0,0,.4)}}
  .pos-mute{width:32px;height:32px;border:1px solid var(--border);background:rgba(255,255,255,.03);border-radius:9px;cursor:pointer;font-size:.92rem;color:var(--text);flex:none;transition:border-color .2s,opacity .2s}
  .pos-mute:hover{border-color:var(--accent)}.pos-mute.off{opacity:.45}
  .pos-main{display:grid;grid-template-columns:1.25fr .9fr}
  @media(max-width:820px){.pos-main{grid-template-columns:1fr}}
  .pos-item .ic{height:66px;display:flex;align-items:center;justify-content:center}
  .pos-item .ic img{height:88px;width:88px;object-fit:contain;mix-blend-mode:screen;filter:drop-shadow(0 6px 16px rgba(var(--accent2-rgb),.5));transition:transform .25s var(--ease)}
  .pos-item .desc{font-family:var(--mono);font-size:.7rem;color:var(--muted);line-height:1.35;margin-top:-2px}
  .pos-item:hover .ic img{transform:scale(1.12) translateY(-2px)}
  .pos-item.pulse{animation:posPulse .45s var(--ease)}
  @keyframes posPulse{0%{box-shadow:0 0 0 0 rgba(var(--accent2-rgb),.55)}100%{box-shadow:0 0 0 16px rgba(var(--accent2-rgb),0)}}
  .pos-fly{position:absolute;left:50%;top:12px;transform:translateX(-50%);font-family:var(--mono);font-weight:700;font-size:.8rem;color:var(--accent);pointer-events:none;text-shadow:0 0 12px rgba(var(--accent2-rgb),.6);animation:flyUp .85s var(--ease) forwards}
  @keyframes flyUp{0%{opacity:0;transform:translate(-50%,8px)}22%{opacity:1}100%{opacity:0;transform:translate(-50%,-30px)}}
  /* card-reader payment overlay */
  .pos-pay-ov{position:absolute;inset:0;z-index:6;display:grid;place-items:center;padding:20px;text-align:center;background:rgba(6,5,12,.9);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .3s var(--ease)}
  .pos-pay-ov.on{opacity:1;pointer-events:auto}
  .pay-card{width:100%;max-width:280px;margin:0 auto;display:flex;flex-direction:column;align-items:center;text-align:center}
  .pay-reader{width:120px;height:80px;margin:0 auto 18px;border:1px solid var(--border);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.01));position:relative;display:grid;place-items:center;transition:border-color .3s,box-shadow .3s}
  .pay-card.proc .pay-reader,.pay-card.ok .pay-reader{border-color:var(--accent);box-shadow:0 0 30px rgba(var(--accent2-rgb),.4)}
  .pay-chip{width:30px;height:22px;border-radius:5px;background:linear-gradient(135deg,#e7d79a,#b9962f);box-shadow:0 0 16px rgba(216,201,138,.45);position:relative;z-index:1}
  .pay-wave{position:absolute;top:50%;right:18px;width:14px;height:14px;border:2px solid var(--accent);border-left-color:transparent;border-bottom-color:transparent;border-radius:50%;transform:translateY(-50%) rotate(-45deg);opacity:.5;animation:payWave 1.4s ease-out infinite}
  .pay-wave.w2{width:22px;height:22px;right:12px;animation-delay:.25s}
  @keyframes payWave{0%{opacity:0;transform:translateY(-50%) rotate(-45deg) scale(.7)}40%{opacity:.7}100%{opacity:0;transform:translateY(-50%) rotate(-45deg) scale(1.2)}}
  .pay-slot{position:absolute;bottom:11px;left:16px;right:16px;height:6px;border-radius:3px;background:#05040a;box-shadow:inset 0 1px 3px rgba(0,0,0,.9)}
  .pay-spin{width:34px;height:34px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;margin:0 auto;animation:spin .7s linear infinite}
  @keyframes spin{to{transform:rotate(360deg)}}
  .pay-ok{font-size:2.1rem;line-height:1;color:var(--ok);animation:stampIn .4s var(--ease)}
  .pay-msg{font-family:var(--mono);font-size:.82rem;color:var(--text);min-height:1.4em;margin-bottom:6px}
  .pay-amt{font-family:'Sora',system-ui,sans-serif;font-weight:800;font-size:clamp(1.4rem,4.6vw,1.9rem);line-height:1;white-space:nowrap;max-width:100%;background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:18px;font-variant-numeric:tabular-nums}
  .pay-actions{display:flex;gap:10px;justify-content:center}
  .pay-actions .btn{padding:11px 18px}
  /* --- strategic extras: OPEN badge, deal strip, tabs, scroll, ticker, screen sheen --- */
  .pos-open{flex:none;font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;color:var(--ok);border:1px solid rgba(var(--ok-rgb),.4);background:rgba(var(--ok-rgb),.1);border-radius:100px;padding:2px 8px;margin-left:4px}
  .pos-deal{display:flex;align-items:center;gap:12px;padding:11px 18px;border-bottom:1px solid var(--border);background:linear-gradient(90deg,rgba(var(--accent2-rgb),.2),rgba(var(--accent2-rgb),.03));font-family:var(--mono);font-size:.74rem;position:relative;overflow:hidden}
  .pos-deal::before{content:'';position:absolute;inset:0;background:linear-gradient(110deg,transparent 42%,rgba(255,255,255,.13) 50%,transparent 58%);transform:translateX(-120%);animation:dealSh 5s var(--ease) infinite}
  @keyframes dealSh{0%,100%{transform:translateX(-120%)}55%,82%{transform:translateX(120%)}}
  .pos-deal>*{position:relative}
  .pos-deal .tag{flex:none;font-weight:700;color:#fff;background:var(--accent-2);padding:3px 9px;border-radius:6px;letter-spacing:.06em;white-space:nowrap}
  .pos-deal .txt{color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .pos-deal .txt b{color:var(--accent)}
  .pos-deal .was{color:var(--muted);text-decoration:line-through;margin:0 3px;font-size:.85em}
  .pos-deal .add-deal{flex:none;margin-left:auto;border:1px solid var(--accent);color:var(--accent);background:rgba(var(--accent2-rgb),.12);font-family:var(--mono);font-size:.72rem;padding:6px 13px;border-radius:8px;cursor:pointer;white-space:nowrap;transition:background .2s,color .2s,border-color .2s}
  .pos-deal .add-deal:hover{background:var(--accent-2);color:#fff;border-color:transparent}
  @media(max-width:600px){.pos-deal .was{display:none}}
  .pos-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
  .pos-tab{font-family:var(--mono);font-size:.72rem;color:var(--muted);border:1px solid var(--border);background:rgba(255,255,255,.02);padding:7px 14px;border-radius:100px;cursor:pointer;transition:color .2s,border-color .2s,background .2s}
  .pos-tab:hover{color:var(--text);border-color:rgba(var(--accent-rgb),.4)}
  .pos-tab[aria-selected="true"]{color:#fff;background:linear-gradient(110deg,var(--accent-2),var(--accent));border-color:transparent}
  .pos-tab .n{opacity:.55;margin-left:6px}
  .pos-scroll{max-height:432px;overflow-y:auto;overscroll-behavior:contain;padding-right:6px;scrollbar-width:thin;scrollbar-color:var(--accent-2) transparent}
  .pos-scroll::-webkit-scrollbar{width:7px}
  .pos-scroll::-webkit-scrollbar-thumb{background:linear-gradient(var(--accent-2),var(--accent));border-radius:8px}
  .pos-scroll::-webkit-scrollbar-track{background:transparent}
  .pos-cat-foot{margin-top:12px;text-align:center;font-family:var(--mono);font-size:.66rem;color:var(--muted);opacity:.7}
  .pos-item .kbd{position:absolute;bottom:12px;right:12px;font-family:var(--mono);font-size:.58rem;color:var(--muted);border:1px solid var(--border);border-radius:5px;padding:1px 5px;opacity:0;transition:opacity .2s}
  .pos-cat:hover .pos-item .kbd{opacity:.65}
  .pos-item.is-pop{border-color:rgba(var(--accent-rgb),.4)}
  .pos-item .pop{position:absolute;top:0;left:0;font-family:var(--mono);font-weight:700;font-size:.54rem;letter-spacing:.08em;color:#fff;background:linear-gradient(110deg,var(--accent-2),var(--accent));padding:3px 9px;border-bottom-right-radius:10px}
  .pos-item .pr .was{color:var(--muted);text-decoration:line-through;font-size:.82em;margin-left:6px}
  .pos-ticker{display:flex;align-items:center;gap:8px;padding:10px 18px;border-top:1px solid var(--border);font-family:var(--mono);font-size:.68rem;color:var(--muted);background:rgba(0,0,0,.28)}
  .pos-ticker .fire{filter:drop-shadow(0 0 6px rgba(255,140,66,.6))}
  .pos-ticker b{color:var(--text)}
  .pos-side::after{content:'';position:absolute;inset:0;z-index:4;pointer-events:none;background:linear-gradient(125deg,transparent 43%,rgba(var(--accent-rgb),.07) 50%,transparent 57%);transform:translateX(-100%);animation:screenSheen 7.5s ease-in-out infinite}
  @keyframes screenSheen{0%,55%{transform:translateX(-100%)}90%,100%{transform:translateX(100%)}}
  @media (prefers-reduced-motion:reduce){.pos-deal::before,.pos-side::after{animation:none;opacity:0}}
  .pos-cat{padding:22px;border-right:1px solid var(--border)}
  @media(max-width:820px){.pos-cat{border-right:0;border-bottom:1px solid var(--border)}}
  .pos-cat-h{font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;display:flex;justify-content:space-between}
  .pos-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  @media(max-width:540px){.pos-grid{grid-template-columns:1fr}}
  .pos-item{position:relative;display:flex;flex-direction:column;gap:9px;text-align:left;padding:22px 18px 20px;border:1px solid var(--border);border-radius:16px;background:rgba(255,255,255,.02);color:var(--text);font:inherit;cursor:pointer;overflow:hidden;transition:transform .25s var(--ease),border-color .25s var(--ease),background .25s var(--ease)}
  .pos-item:hover{transform:translateY(-3px);border-color:rgba(var(--accent-rgb),.5);background:rgba(255,255,255,.04)}
  .pos-item:active{transform:translateY(0) scale(.98)}
  .pos-item .ic{font-size:1.5rem;line-height:1}
  .pos-item .nm{font-family:'Sora',system-ui,sans-serif;font-weight:700;font-size:1.05rem}
  .pos-item .pr{font-family:var(--mono);font-size:.92rem;color:var(--accent)}
  .pos-item .add{position:absolute;top:10px;right:10px;width:22px;height:22px;display:grid;place-items:center;border-radius:7px;background:rgba(var(--accent2-rgb),.16);color:var(--accent);font-family:var(--mono);font-weight:700;font-size:.9rem;opacity:0;transform:scale(.7);transition:opacity .2s var(--ease),transform .2s var(--ease)}
  .pos-item:hover .add{opacity:1;transform:none}
  .pos-side{position:relative;display:flex;flex-direction:column;background:rgba(6,5,12,.6);overflow:hidden}
  .pos-screen-h{display:flex;align-items:center;gap:8px;padding:14px 18px;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:.7rem;color:var(--muted)}
  .pos-screen-h .d{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok);animation:pulse 2s infinite}
  .pos-screen-h b{margin-left:auto;color:var(--text)}
  .pos-order{flex:1;min-height:240px;max-height:380px;overflow-y:auto;padding:10px 16px;display:flex;flex-direction:column;gap:2px;scrollbar-width:thin;scrollbar-color:var(--accent-2) transparent}
  .pos-order::-webkit-scrollbar{width:7px}
  .pos-order::-webkit-scrollbar-thumb{background:linear-gradient(var(--accent-2),var(--accent));border-radius:8px}
  .pos-order::-webkit-scrollbar-track{background:transparent}
  .pos-empty{margin:auto;text-align:center;color:var(--muted);font-family:var(--mono);font-size:.74rem;padding:24px 12px;line-height:1.7}
  .pos-empty b{display:block;color:var(--text);font-family:'Sora',system-ui,sans-serif;font-weight:700;font-size:1.05rem;margin-bottom:6px;letter-spacing:.01em}
  .pe-scan{display:block;width:118px;height:118px;margin:0 auto 18px;border:1px dashed rgba(var(--accent-rgb),.32);border-radius:14px;position:relative;overflow:hidden;background:rgba(var(--accent2-rgb),.04)}
  .pe-scan::before{content:'';position:absolute;left:8%;right:8%;height:2px;top:8%;background:linear-gradient(90deg,transparent,var(--accent),transparent);box-shadow:0 0 12px var(--accent);animation:peScan 2.6s ease-in-out infinite}
  .pe-scan::after{content:'';position:absolute;inset:34px;border:2px solid rgba(var(--accent-rgb),.22);border-radius:8px}
  @keyframes peScan{0%,100%{top:10%}50%{top:86%}}
  @media (prefers-reduced-motion:reduce){.pe-scan::before{animation:none}}
  .pos-line{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;padding:9px 4px;border-bottom:1px solid rgba(255,255,255,.05);font-size:.86rem;animation:posIn .25s var(--ease)}
  @keyframes posIn{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:none}}
  .pos-line .q{display:flex;align-items:center;gap:6px;font-family:var(--mono)}
  .pos-line .q button{width:20px;height:20px;border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text);border-radius:6px;cursor:pointer;font-family:var(--mono);line-height:1;display:grid;place-items:center}
  .pos-line .q button:hover{border-color:var(--accent);color:var(--accent)}
  .pos-line .q b{min-width:16px;text-align:center;color:var(--accent)}
  .pos-line .ln{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .pos-line .lp{font-family:var(--mono);color:var(--muted)}
  .pos-line .rm{border:0;background:none;color:var(--muted);cursor:pointer;font-size:1rem;line-height:1;padding:2px;border-radius:5px}
  .pos-line .rm:hover{color:var(--danger)}
  .pos-tot{padding:14px 18px;border-top:1px solid var(--border);font-family:var(--mono);font-size:.82rem;display:grid;gap:6px}
  .pos-tot .r{display:flex;justify-content:space-between;color:var(--muted)}
  .pos-tot .r.big{color:var(--text);font-size:1.15rem;font-weight:700;margin-top:4px}
  .pos-tot .r.big b{font-variant-numeric:tabular-nums;background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
  .pos-actions{display:flex;gap:10px;padding:0 18px 18px}
  .pos-actions .btn{flex:1;justify-content:center;padding:14px 18px}
  .pos-actions .ghost{flex:0 0 auto;padding:14px 16px}
  .pos-pay{position:relative;overflow:hidden}
  .pos-pay[disabled]{opacity:.5;cursor:not-allowed;filter:grayscale(.4)}
  /* thermal receipt */
  .pos-receipt-wrap{max-width:1080px;margin:22px auto 0;display:flex;justify-content:center;perspective:1000px}
  .pos-receipt{width:min(360px,92vw);background:#f7f5ef;color:#16131f;font-family:var(--mono);font-size:.74rem;line-height:1.6;padding:22px 22px 16px;border-radius:4px;box-shadow:0 30px 70px rgba(0,0,0,.6);transform-origin:top center;max-height:0;opacity:0;overflow:hidden;transition:max-height .7s var(--ease),opacity .4s;-webkit-mask-image:linear-gradient(#000 calc(100% - 14px),transparent);mask-image:linear-gradient(#000 calc(100% - 14px),transparent)}
  .pos-receipt.show{max-height:4000px;opacity:1}/* generous cap so a large order's total/footer is never clipped (content height < cap = fully shown) */
  .pos-receipt *{font-family:var(--mono)}
  .rc-c{text-align:center}
  .rc-logo{font-family:'Sora',system-ui,sans-serif;font-weight:800;font-size:1.15rem;letter-spacing:.02em}
  .rc-sub{font-size:.64rem;text-transform:uppercase;letter-spacing:.14em;color:#6a6478}
  .rc-rule{border:0;border-top:1px dashed #9b95a6;margin:11px 0}
  .rc-line{display:flex;justify-content:space-between;gap:10px}
  .rc-line .muted{color:#6a6478}
  .rc-big{display:flex;justify-content:space-between;font-weight:700;font-size:.92rem}
  .rc-stamp{display:inline-block;margin:10px 0 4px;border:2.5px solid #c0392b;color:#c0392b;font-family:'Sora',system-ui,sans-serif;font-weight:800;font-size:1.1rem;letter-spacing:.08em;padding:3px 14px;border-radius:6px;transform:rotate(-8deg);opacity:0}
  .pos-receipt.show .rc-stamp{animation:stampIn .4s .55s var(--ease) forwards}
  @keyframes stampIn{0%{opacity:0;transform:rotate(-8deg) scale(2.4)}70%{opacity:1}100%{opacity:1;transform:rotate(-8deg) scale(1)}}
  .rc-barcode{height:42px;margin:10px 0 6px;background:repeating-linear-gradient(90deg,#16131f 0 2px,transparent 2px 4px,#16131f 4px 5px,transparent 5px 9px,#16131f 9px 12px,transparent 12px 14px)}
  .rc-cta a{color:#16131f;font-weight:700;text-decoration:underline;text-underline-offset:2px}
  @media (prefers-reduced-motion:reduce){.pos-receipt{transition:opacity .3s}.pos-receipt.show .rc-stamp{animation:none;opacity:1}}
  /* ===== Large-screen scaling — fill big displays proportionally, keep text readable ===== */
  @media(min-width:1600px){ :root{--maxw:1340px} html{font-size:16.5px} }
  @media(min-width:2000px){ :root{--maxw:1480px} html{font-size:17px} .hero-art .blender-avatar{width:min(640px,100%)} }
  @media(min-width:2560px){ :root{--maxw:1660px} html{font-size:18.5px} .hero-art .blender-avatar{width:min(720px,100%)}
    .tline{max-width:980px} .proc{max-width:1280px} .spotlight{max-width:1400px} .faq-grid{max-width:980px} .ssub{max-width:720px} .tech-item{width:128px} }
  @media(min-width:3200px){ :root{--maxw:2000px} html{font-size:20px} .spotlight{max-width:1560px} .proc{max-width:1440px} }
