/* ============================================================
   emreyakut.com — kişi odaklı, dark+light, terminal + lüks
   ============================================================ */

/* ---------- THEME TOKENS ---------- */
:root[data-theme="dark"]{
  --bg:#0a0e14;
  --bg-2:#0c111a;
  --surface:#10161f;
  --surface-2:#141c27;
  --border:rgba(255,255,255,.09);
  --border-2:rgba(255,255,255,.14);
  --text:#e8eef6;
  --text-dim:#aeb9c8;
  --text-mute:#6b7889;
  --accent:#2fe0a8;          /* mint/teal */
  --accent-2:#7aa2ff;        /* cool blue */
  --accent-soft:rgba(47,224,168,.12);
  --accent-line:rgba(47,224,168,.35);
  --glow-1:rgba(47,224,168,.20);
  --glow-2:rgba(122,162,255,.18);
  --grid:rgba(255,255,255,.035);
  --shadow:0 30px 80px -30px rgba(0,0,0,.7);
  --shadow-sm:0 8px 30px -12px rgba(0,0,0,.6);
  --card-grad:linear-gradient(160deg,rgba(255,255,255,.04),rgba(255,255,255,0));
}
:root[data-theme="light"]{
  --bg:#f5f7fa;
  --bg-2:#eef1f6;
  --surface:#ffffff;
  --surface-2:#f4f7fb;
  --border:rgba(12,18,28,.10);
  --border-2:rgba(12,18,28,.16);
  --text:#0c1320;
  --text-dim:#3e4a5c;
  --text-mute:#76828f;
  --accent:#0a9d76;
  --accent-2:#2f63e6;
  --accent-soft:rgba(10,157,118,.10);
  --accent-line:rgba(10,157,118,.30);
  --glow-1:rgba(10,157,118,.16);
  --glow-2:rgba(47,99,230,.12);
  --grid:rgba(12,18,28,.05);
  --shadow:0 30px 70px -30px rgba(20,30,50,.30);
  --shadow-sm:0 10px 30px -14px rgba(20,30,50,.22);
  --card-grad:linear-gradient(160deg,rgba(12,18,28,.015),rgba(12,18,28,0));
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',-apple-system,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.62;font-size:17px;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
  transition:background .4s ease,color .4s ease;
}
h1,h2,h3,h4{font-family:'Space Grotesk','Inter',sans-serif;line-height:1.08;letter-spacing:-.02em;font-weight:700}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace}
.dim{color:var(--text-mute)}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
section{padding:110px 0;position:relative}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}

/* ---------- decorative grid + glow ---------- */
.grid-bg{position:absolute;inset:0;background-image:
  linear-gradient(var(--grid) 1px,transparent 1px),
  linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 30%,transparent 75%);
  pointer-events:none;z-index:0}
.grid-bg.sm{background-size:40px 40px;mask-image:radial-gradient(ellipse 70% 80% at 50% 40%,#000 20%,transparent 70%)}
.glow{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none;z-index:0;opacity:.9}
.g1{width:560px;height:560px;background:var(--glow-1);top:-160px;right:-120px}
.g2{width:480px;height:480px;background:var(--glow-2);bottom:-180px;left:-140px}
.g3{width:520px;height:520px;background:var(--glow-2);top:10%;right:-160px}
.g4{width:600px;height:380px;background:var(--glow-1);top:-60px;left:50%;transform:translateX(-50%)}

/* ---------- eyebrow / titles ---------- */
.eyebrow{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600;
  letter-spacing:.04em;color:var(--accent);margin-bottom:18px}
.eyebrow.light{color:var(--accent)}
h2.title{font-size:clamp(28px,4.3vw,46px);font-weight:700;letter-spacing:-.03em;max-width:18ch}
.center h2.title{margin:0 auto}
.sec-head{margin-bottom:54px;max-width:760px}
.sec-head.center{margin-left:auto;margin-right:auto}
.lead{font-size:18px;color:var(--text-dim);max-width:640px;margin-top:18px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15.5px;padding:14px 24px;
  border-radius:12px;border:1px solid transparent;cursor:pointer;transition:.22s ease;font-family:inherit}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--accent);color:#04140e}
:root[data-theme="light"] .btn-primary{color:#fff}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px var(--glow-1);filter:brightness(1.05)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--border-2)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

/* ---------- NAV ---------- */
header{position:sticky;top:0;z-index:80;background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:saturate(160%) blur(16px);border-bottom:1px solid var(--border);transition:.3s}
header.scrolled{box-shadow:0 10px 40px -24px rgba(0,0,0,.6)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:20px}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.brand-mark{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:15px;color:var(--accent);
  border:1.5px solid var(--accent-line);border-radius:9px;width:38px;height:38px;display:grid;place-items:center;
  background:var(--accent-soft)}
.brand-name{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:18px;letter-spacing:-.02em}
.menu{display:flex;gap:4px;align-items:center}
.menu a{font-size:14px;font-weight:500;color:var(--text-dim);padding:8px 13px;border-radius:9px;transition:.18s;
  display:flex;align-items:center;gap:7px}
.menu a .i{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-mute)}
.menu a:hover,.menu a.active{color:var(--text);background:var(--surface)}
.menu a:hover .i,.menu a.active .i{color:var(--accent)}
.nav-tools{display:flex;align-items:center;gap:10px;flex-shrink:0}
.toggle{font-family:'JetBrains Mono',monospace;background:var(--surface);border:1px solid var(--border);
  color:var(--text-dim);height:38px;border-radius:10px;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center}
.toggle:hover{border-color:var(--accent-line);color:var(--text)}
.toggle.lang{padding:0 12px;font-size:12.5px;font-weight:600;gap:3px}
.toggle.lang .on{color:var(--accent)}.toggle.lang .off{color:var(--text-mute)}.toggle.lang .sep{opacity:.5}
:root[data-lang="en"] .toggle.lang .on{color:var(--text-mute)}
:root[data-lang="en"] .toggle.lang .off{color:var(--accent)}
.toggle.theme{width:38px}
.toggle.theme svg{width:18px;height:18px}
.toggle.theme .ic-sun{display:none}.toggle.theme .ic-moon{display:block}
:root[data-theme="light"] .toggle.theme .ic-sun{display:block}
:root[data-theme="light"] .toggle.theme .ic-moon{display:none}
.burger{display:none;width:40px;height:38px;background:var(--surface);border:1px solid var(--border);border-radius:10px;
  cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.burger span{width:18px;height:2px;background:var(--text);border-radius:2px;transition:.25s}
.burger.open span:nth-child(1){transform:translateY(3.5px) rotate(45deg)}
.burger.open span:nth-child(2){transform:translateY(-3.5px) rotate(-45deg)}

/* ---------- TERMINAL component ---------- */
.term{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
.term-bar{display:flex;align-items:center;gap:8px;padding:11px 15px;background:var(--surface-2);border-bottom:1px solid var(--border)}
.term-bar i{width:11px;height:11px;border-radius:50%}
.term-bar i.r{background:#ff5f57}.term-bar i.y{background:#febc2e}.term-bar i.g{background:#28c840}
.term-title{margin-left:10px;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-mute)}
.term-body{padding:20px 20px 22px;font-family:'JetBrains Mono',monospace;font-size:14px;line-height:1.85}
.term-body .prompt{color:var(--accent)}
.term-body .cmd{color:var(--text)}
.term-body .out{color:var(--text-dim);white-space:pre-wrap;min-height:1.85em}
.blink{animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* ---------- HERO ---------- */
.hero{padding:70px 0 90px;overflow:hidden}
.hero-inner{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center;position:relative;z-index:2}
.hero-term{max-width:430px;margin-bottom:30px}
.hero-h{font-size:clamp(40px,6.4vw,76px);letter-spacing:-.04em;line-height:1.0}
.hero-h .hl{color:var(--accent)}
.hero-lead{font-size:clamp(16px,1.9vw,19px);color:var(--text-dim);max-width:540px;margin-top:24px}
.hero-role{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--text-dim);margin-top:22px;
  display:flex;align-items:center;gap:9px;flex-wrap:wrap;line-height:1.5}
.hero-role .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);flex-shrink:0}
.hero-role .at{color:var(--accent)}
.hero-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.tag{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-dim);background:var(--surface);
  border:1px solid var(--border);padding:6px 12px;border-radius:100px}
.hero-actions{display:flex;gap:13px;margin-top:32px;flex-wrap:wrap}

.hero-right{position:relative}
.portrait{position:relative;width:100%;max-width:380px;margin-left:auto;aspect-ratio:4/5;border-radius:22px;overflow:visible}
.portrait img{width:100%;height:100%;object-fit:cover;border-radius:22px;border:1px solid var(--border-2);
  box-shadow:var(--shadow);position:relative;z-index:1}
.portrait-ring{position:absolute;inset:-10px;border-radius:28px;
  background:conic-gradient(from 180deg,var(--accent),var(--accent-2),var(--accent));
  opacity:.5;filter:blur(14px);z-index:0;animation:spin 14s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.float-chip{position:absolute;z-index:3;background:color-mix(in srgb,var(--surface) 88%,transparent);
  backdrop-filter:blur(10px);border:1px solid var(--border-2);border-radius:10px;padding:8px 12px;
  font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-dim);box-shadow:var(--shadow-sm);
  display:flex;align-items:center;gap:7px}
.float-chip code{font-size:12px;color:var(--text-dim)}
.float-chip .dotc{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.fc1{top:18px;left:-26px;animation:bob 4s ease-in-out infinite}
.fc2{bottom:64px;right:-30px;animation:bob 5s ease-in-out infinite .5s}
.fc3{bottom:14px;left:6px;animation:bob 4.6s ease-in-out infinite .2s}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.scrollcue{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);width:40px;height:40px;
  border:1px solid var(--border-2);border-radius:50%;display:grid;place-items:center;color:var(--text-mute);
  z-index:3;animation:bob 2.4s ease-in-out infinite}
.scrollcue:hover{color:var(--accent);border-color:var(--accent-line)}
.scrollcue svg{width:18px;height:18px}

/* ---------- WHO / MANIFESTO ---------- */
.manifesto{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:start}
.who-values{list-style:none;display:flex;flex-direction:column;gap:0}
.who-values li{position:relative;padding:20px 0 20px 28px;border-bottom:1px solid var(--border)}
.who-values li:last-child{border-bottom:none}
.who-values li::before{content:"";position:absolute;left:2px;top:27px;width:9px;height:9px;border-radius:2px;
  background:var(--accent);transform:rotate(45deg);transition:.2s}
.who-values li:hover::before{box-shadow:0 0 0 5px var(--accent-soft)}
.who-values .vh{display:block;font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:600;
  letter-spacing:-.01em;color:var(--text);margin-bottom:5px}
.who-values .vd{display:block;font-size:14.5px;color:var(--text-dim);line-height:1.55}
.who-aside{background:var(--card-grad);border:1px solid var(--border);border-radius:18px;padding:34px;position:relative;overflow:hidden}
.who-aside::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));opacity:.7}
.who-quote{font-family:'Space Grotesk',sans-serif;font-size:21px;font-weight:600;line-height:1.4;color:var(--text);margin-bottom:18px}
.who-body{font-size:15.5px;color:var(--text-dim);margin-bottom:24px}
.who-meta{display:flex;flex-direction:column;gap:9px;font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--text-dim)}
.who-meta .k{color:var(--accent);display:inline-block;width:16px}

/* ---------- NOW ---------- */
.now-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.now-text h3{font-size:24px;margin-bottom:14px}
.now-text p{color:var(--text-dim);font-size:16px;margin-bottom:22px}
.check{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:24px}
.check li{position:relative;padding-left:30px;font-size:15px;color:var(--text-dim)}
.check li::before{content:"";position:absolute;left:4px;top:9px;width:9px;height:9px;border-radius:2px;
  background:var(--accent);transform:rotate(45deg)}
.now-foot{font-family:'JetBrains Mono',monospace;font-size:13.5px;color:var(--text-dim)}
.now-foot .k{color:var(--accent)}
.now-foot a{color:var(--text);border-bottom:1px solid var(--accent-line)}
.now-foot a:hover{color:var(--accent)}

/* mac browser mockup */
.mac{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.mac-bar{display:flex;align-items:center;gap:8px;padding:11px 14px;background:var(--surface-2);border-bottom:1px solid var(--border)}
.mac-bar i{width:11px;height:11px;border-radius:50%}
.mac-bar i.r{background:#ff5f57}.mac-bar i.y{background:#febc2e}.mac-bar i.g{background:#28c840}
.mac-url{margin-left:12px;flex:1;background:var(--bg);border:1px solid var(--border);border-radius:7px;
  padding:5px 12px;font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--text-mute);
  display:flex;align-items:center;gap:7px}
.mac-url svg{width:12px;height:12px;color:var(--accent)}
.mac-body{padding:0;background:var(--bg-2)}
.dash{display:grid;grid-template-columns:140px 1fr;min-height:300px}
.dash-side{background:var(--surface);border-right:1px solid var(--border);padding:16px 12px;display:flex;flex-direction:column;gap:3px}
.ds-logo{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--accent);font-weight:600;margin-bottom:10px;padding:0 8px}
.ds-i{display:block;width:100%;text-align:left;font-family:inherit;font-size:12.5px;color:var(--text-mute);
  padding:7px 9px;border-radius:7px;cursor:pointer;background:none;border:none;transition:.15s}
.ds-i:hover{color:var(--text-dim);background:color-mix(in srgb,var(--accent) 7%,transparent)}
.ds-i.active{background:var(--accent-soft);color:var(--accent)}
.dash-view{display:none;flex-direction:column;gap:12px}
.dash-view.on{display:flex;animation:dashFade .25s ease}
@keyframes dashFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.dlist{display:flex;flex-direction:column;gap:8px}
.dli{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface);
  border:1px solid var(--border);border-radius:10px;padding:11px 13px;font-size:12.5px;color:var(--text-dim)}
.pill{font-family:'JetBrains Mono',monospace;font-size:10.5px;padding:3px 9px;border-radius:100px;white-space:nowrap}
.pill.ok{color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-line)}
.pill.warn{color:#febc2e;background:rgba(254,188,46,.12);border:1px solid rgba(254,188,46,.3)}
.pill.mut{color:var(--text-mute);background:color-mix(in srgb,var(--text-mute) 10%,transparent);border:1px solid var(--border)}
.spark.tall{height:48px}
.dash-main{padding:16px;display:flex;flex-direction:column;gap:12px}
.dash-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.dcard{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:14px;display:flex;flex-direction:column;gap:7px}
.dcard.wide{gap:11px}.dcard.sm{padding:11px 13px;gap:5px}
.dcard .dl{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-mute)}
.dcard .dv{font-family:'JetBrains Mono',monospace;font-size:14px;color:var(--text);font-weight:500}
.dcard .dv.ok{color:var(--accent)}
.spark{display:flex;align-items:flex-end;gap:3px;height:26px}
.spark b{flex:1;background:var(--accent);border-radius:2px;opacity:.85;animation:grow 1.4s ease-out backwards}
.spark.s2 b{background:var(--accent-2)}
.spark b:nth-child(1){height:40%;animation-delay:.0s}.spark b:nth-child(2){height:65%;animation-delay:.07s}
.spark b:nth-child(3){height:48%;animation-delay:.14s}.spark b:nth-child(4){height:80%;animation-delay:.21s}
.spark b:nth-child(5){height:58%;animation-delay:.28s}.spark b:nth-child(6){height:92%;animation-delay:.35s}
.spark b:nth-child(7){height:70%;animation-delay:.42s}.spark b:nth-child(8){height:100%;animation-delay:.49s}
.spark b:nth-child(9){height:54%;animation-delay:.56s}.spark b:nth-child(10){height:86%;animation-delay:.63s}
.spark b:nth-child(11){height:64%;animation-delay:.70s}.spark b:nth-child(12){height:96%;animation-delay:.77s}
@keyframes grow{from{transform:scaleY(0);transform-origin:bottom}}
.pipe{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-dim)}
.pipe span{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:5px 9px}
.pipe i{color:var(--accent);font-style:normal}

/* metering deep-dive */
.now-detail{margin-top:64px;padding-top:54px;border-top:1px solid var(--border)}
.nd-head{max-width:720px;margin-bottom:36px}
.nd-title{font-size:clamp(22px,3vw,32px);margin-bottom:14px}
.nd-lead{color:var(--text-dim);font-size:16px}
.md-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.mdcard{background:var(--card-grad);border:1px solid var(--border);border-radius:14px;padding:24px;transition:.25s;position:relative}
.mdcard:hover{border-color:var(--accent-line);transform:translateY(-4px)}
.mdcard .mdi{font-size:12px;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-line);
  border-radius:7px;padding:3px 9px;display:inline-block;margin-bottom:14px}
.mdcard h4{font-size:16.5px;margin-bottom:8px}
.mdcard p{font-size:13.5px;color:var(--text-dim);line-height:1.5}
.music-modular{color:var(--text-dim);font-size:16px;margin-top:16px}
.music-modular b{color:var(--accent);font-weight:600}

/* ---------- GARAGE / STACK ---------- */
.stack-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.scard{background:var(--card-grad);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:.25s}
.scard:hover{border-color:var(--accent-line);transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.scard.accent{border-color:var(--accent-line)}
.scard-head{padding:13px 18px;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--surface) 60%,transparent)}
.scard-head .path{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--accent)}
.scard ul{list-style:none;padding:16px 18px 20px;display:flex;flex-direction:column;gap:10px}
.scard li{font-size:14px;color:var(--text-dim);line-height:1.45}
.scard li b{font-family:'JetBrains Mono',monospace;color:var(--text);font-weight:600;font-size:13.5px}

/* ---------- PHILOSOPHY ---------- */
.philo{background:var(--bg-2);overflow:hidden}
.philo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;position:relative;z-index:2}
.pcard{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:28px;transition:.25s}
.pcard:hover{border-color:var(--accent-line);transform:translateY(-4px)}
.pcard .pn{font-family:'JetBrains Mono',monospace;font-size:14px;color:var(--accent);font-weight:600;display:block;margin-bottom:14px}
.pcard p{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:500;line-height:1.4;color:var(--text)}

/* ---------- LAB ---------- */
.lab-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.labcard{position:relative;background:var(--card-grad);border:1px solid var(--border);border-radius:16px;padding:30px;transition:.25s;overflow:hidden}
.labcard::before{content:"";position:absolute;inset:0;background:radial-gradient(400px 200px at 100% 0%,var(--accent-soft),transparent 60%);opacity:0;transition:.3s}
.labcard:hover{border-color:var(--accent-line);transform:translateY(-4px)}
.labcard:hover::before{opacity:1}
.lab-tag{position:relative;z-index:1;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--accent);
  background:var(--accent-soft);border:1px solid var(--accent-line);padding:4px 11px;border-radius:100px;display:inline-block;margin-bottom:16px}
.labcard h3{position:relative;z-index:1;font-size:20px;margin-bottom:10px}
.labcard p{position:relative;z-index:1;font-size:15px;color:var(--text-dim)}

/* ---------- MUSIC ---------- */
.music{background:var(--bg-2);overflow:hidden}
.music-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center;position:relative;z-index:2}
.music-text h2.title{margin-bottom:18px}
.music-text p{color:var(--text-dim);font-size:16px}
.genre-chips{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0}
.genre-chips span{font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--text-dim);
  border:1px solid var(--border);border-radius:100px;padding:6px 13px;transition:.2s}
.genre-chips span:hover{border-color:var(--accent-line);color:var(--accent)}
.music-ai{font-size:15px;color:var(--text-dim);border-left:2px solid var(--accent-line);padding-left:16px}

/* iphone mockup */
.phone-wrap{display:flex;justify-content:center}
.phone{width:280px;aspect-ratio:9/19;background:#070a0f;border-radius:42px;padding:11px;position:relative;
  border:1px solid var(--border-2);box-shadow:var(--shadow);}
.notch{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:120px;height:26px;background:#070a0f;border-radius:0 0 16px 16px;z-index:3}
.phone-screen{width:100%;height:100%;border-radius:32px;background:
  radial-gradient(120% 80% at 50% 0%,color-mix(in srgb,var(--accent) 22%,#0a0e14),#0a0e14 70%);
  padding:46px 22px 26px;display:flex;flex-direction:column;align-items:center;overflow:hidden;color:#e8eef6}
.np-art{width:150px;height:150px;border-radius:18px;margin-bottom:22px;
  background:linear-gradient(150deg,var(--accent),var(--accent-2));display:grid;place-items:center;box-shadow:0 16px 40px -14px var(--glow-1)}
.eq{display:flex;align-items:flex-end;gap:5px;height:54px}
.eq b{width:7px;background:rgba(4,20,14,.85);border-radius:3px;animation:eq 1s ease-in-out infinite}
.eq b:nth-child(1){height:30%;animation-delay:0s}.eq b:nth-child(2){height:70%;animation-delay:.2s}
.eq b:nth-child(3){height:100%;animation-delay:.4s}.eq b:nth-child(4){height:55%;animation-delay:.1s}
.eq b:nth-child(5){height:80%;animation-delay:.3s}
@keyframes eq{0%,100%{transform:scaleY(.4)}50%{transform:scaleY(1)}}
.np-label{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:rgba(232,238,246,.6);margin-bottom:8px}
.np-track{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:600}
.np-artist{font-size:13px;color:rgba(232,238,246,.6);margin-bottom:18px}
.np-bar{width:100%;height:4px;border-radius:3px;background:rgba(255,255,255,.14);margin-bottom:18px;overflow:hidden}
.np-bar span{display:block;height:100%;width:38%;background:var(--accent);border-radius:3px;animation:seek 6s ease-in-out infinite}
@keyframes seek{0%{width:8%}50%{width:62%}100%{width:8%}}
.np-ctrl{display:flex;align-items:center;gap:24px;color:#e8eef6;margin-bottom:auto}
.np-ctrl svg{width:22px;height:22px;opacity:.85}
.np-ctrl .play{width:40px;height:40px;background:var(--accent);color:#04140e;border-radius:50%;padding:9px;opacity:1}
.np-gear{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-top:18px}
.np-gear span{font-family:'JetBrains Mono',monospace;font-size:9.5px;color:rgba(232,238,246,.55);
  border:1px solid rgba(255,255,255,.14);border-radius:100px;padding:3px 8px}

/* ---------- STUDIO PHOTO (parallax banner) ---------- */
.studio-photo{position:relative;height:clamp(260px,42vw,460px);border-radius:18px;overflow:hidden;margin-bottom:54px;
  border:1px solid var(--border-2);box-shadow:var(--shadow);
  background-image:url(img/studio.jpg);background-size:cover;background-position:center 40%;background-attachment:fixed}
.studio-photo::before{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(5,7,11,.72),rgba(5,7,11,.18) 45%,rgba(5,7,11,.05) 70%),
  linear-gradient(0deg,rgba(5,7,11,.85),rgba(5,7,11,0) 55%)}
.sp-cap{position:absolute;left:0;bottom:0;padding:26px 30px;z-index:1;color:#eef2f7}
.sp-cap .mono{font-size:12px;color:var(--accent);letter-spacing:.06em}
.sp-cap p{font-family:'Space Grotesk',sans-serif;font-size:clamp(17px,2.3vw,24px);font-weight:600;margin-top:8px;max-width:22ch;line-height:1.25}
@media(max-width:760px){.studio-photo{background-attachment:scroll}}

/* ---------- LIVE MACHINE (studio) ---------- */
.studio-head{max-width:720px;margin:0 auto 34px;text-align:center}
.studio-head .eyebrow{margin-bottom:14px}
.studio{max-width:980px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:16px;
  overflow:hidden;box-shadow:var(--shadow);user-select:none;-webkit-user-select:none}
.studio input,.studio textarea,.studio select,.studio-code{user-select:text;-webkit-user-select:text}
.studio-bar{display:flex;align-items:center;gap:8px;padding:11px 15px;background:var(--surface-2);border-bottom:1px solid var(--border)}
.studio-bar i{width:11px;height:11px;border-radius:50%}
.studio-bar i.r{background:#ff5f57}.studio-bar i.y{background:#febc2e}.studio-bar i.g{background:#28c840}
.studio-title{margin-left:10px;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-mute);flex:1}
.studio-stamp{font-size:11.5px;color:var(--accent)}
.studio-body{padding:20px}
.studio-transport{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:20px}
.st-play{display:inline-flex;align-items:center;gap:8px;font-family:inherit;font-weight:600;font-size:14px;
  background:var(--accent);color:#04140e;border:none;border-radius:10px;padding:10px 18px;cursor:pointer;transition:.2s}
:root[data-theme="light"] .st-play{color:#fff}
.st-play:hover{filter:brightness(1.06);transform:translateY(-1px)}
.st-play.on{background:#ff5f57;color:#fff}
.st-play .ico{font-size:12px}
.st-ctl{display:flex;align-items:center;gap:8px}
.st-ctl label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.04em;color:var(--text-mute)}
.st-ctl input[type=range]{width:84px;accent-color:var(--accent);cursor:pointer}
.st-ctl b{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-dim);min-width:24px}
.st-preset{margin-left:auto;font-family:'JetBrains Mono',monospace;font-size:12.5px;background:var(--bg);
  color:var(--text);border:1px solid var(--border);border-radius:9px;padding:8px 12px;cursor:pointer}
.studio-grid{display:flex;flex-direction:column;gap:7px;overflow-x:auto;padding-bottom:4px}
.st-row{display:flex;align-items:center;gap:10px;min-width:880px;--tc:var(--accent);border-radius:9px;padding:3px;transition:background .15s}
.knob.kdisabled .knob-dial{pointer-events:none;opacity:.32}
.st-row.selrow{background:color-mix(in srgb,var(--tc) 9%,transparent)}
/* channel strip knobs */
.st-strip{display:flex;gap:7px;flex-shrink:0}
.knob{display:flex;flex-direction:column;align-items:center;gap:2px;width:38px}
.knob-dial{width:30px;height:30px;border-radius:50%;background:radial-gradient(circle at 50% 38%,var(--surface-2),var(--bg));
  border:1px solid var(--border-2);cursor:ns-resize;position:relative;touch-action:none;--ang:0deg}
.knob-dial::after{content:"";position:absolute;left:50%;top:3px;width:2px;height:9px;background:var(--tc,var(--accent));
  border-radius:2px;transform-origin:50% 12px;transform:translateX(-50%) rotate(var(--ang))}
.knob-dial:hover{border-color:var(--tc,var(--accent-line))}
.knob-lab{font-family:'JetBrains Mono',monospace;font-size:8.5px;letter-spacing:.04em;color:var(--text-mute)}
.knob-val{font-size:8.5px;color:var(--text-dim)}
.mst-knobs .knob{width:62px;gap:5px}.mst-knobs .knob-dial{width:54px;height:54px}
.mst-knobs .knob-dial::after{top:5px;height:15px;transform-origin:50% 22px;width:3px}
.mst-knobs .knob-lab{font-size:10px}.mst-knobs .knob-val{font-size:11px;color:var(--text);font-weight:600}
.mst-out{display:flex;align-items:center;gap:12px;margin-left:auto}
.grid-top{display:flex;justify-content:flex-end;margin-bottom:9px}
.grid-top-r{display:flex;align-items:center;gap:7px}
.gt-lab{font-size:11px;letter-spacing:.1em;color:var(--text-mute)}
.st-lock{background:none;border:1px solid var(--border);border-radius:7px;width:30px;height:30px;cursor:pointer;font-size:12px;transition:.15s;padding:0}
.st-lock:hover{border-color:var(--accent-line)}
.st-lock.on{background:var(--accent-soft);border-color:var(--accent-line)}
.st-head{flex-shrink:0;width:152px;display:flex;align-items:center;gap:4px}
.st-gear{width:24px;height:34px;border-radius:7px;border:1px solid var(--border);background:var(--bg);color:var(--text-mute);cursor:pointer;font-size:13px;transition:.15s;flex-shrink:0}
.st-gear:hover{border-color:var(--tc,var(--accent-line));color:var(--tc,var(--accent))}
.st-sm{width:22px;height:34px;border-radius:7px;border:1px solid var(--border);background:var(--bg);
  color:var(--text-mute);font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;cursor:pointer;transition:.15s;flex-shrink:0}
.st-sm:hover{border-color:var(--border-2);color:var(--text-dim)}
.st-sm.s.on{background:#ffd166;color:#1a1206;border-color:#ffd166}
.st-sm.m.on{background:#ff5f57;color:#fff;border-color:#ff5f57}
.st-name{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:1px;text-align:left;
  background:var(--bg);border:1px solid var(--border);border-left:3px solid var(--tc);border-radius:8px;
  padding:6px 9px;cursor:pointer;transition:.15s;overflow:hidden}
.st-name:hover{border-color:var(--tc)}
.st-name b{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700;color:var(--text);white-space:nowrap}
.st-name .st-eng{font-size:9.5px;color:var(--text-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.st-steps{display:flex;gap:5px;flex:1}
.st-cell{flex:1;min-width:20px;height:34px;border-radius:6px;border:1px solid var(--border);background:var(--bg);
  cursor:pointer;transition:background .12s,border-color .12s,transform .06s,box-shadow .12s;padding:0;position:relative}
.st-cell.beat{border-color:var(--border-2)}
.st-cell.grp{margin-left:15px}
.st-cell:hover{border-color:var(--tc)}
.st-cell.on{background:var(--tc);border-color:transparent;box-shadow:inset 0 0 0 1px rgba(255,255,255,.22),inset 0 -7px 9px -7px rgba(0,0,0,.5),0 0 12px -2px var(--tc)}
.st-cell.acc::after{content:"";position:absolute;top:3px;right:3px;width:5px;height:5px;border-radius:50%;background:#ff4d62;box-shadow:0 0 6px #ff4d62}
.st-cell .cn{position:absolute;left:0;right:0;bottom:2px;text-align:center;font-family:'JetBrains Mono',monospace;font-size:7px;color:#04140e;font-weight:700;pointer-events:none}
.st-cell.selcell{outline:2px solid var(--tc);outline-offset:1px}
.st-cell.cue{transform:translateY(-1px)}
.st-cell.cue:not(.on){box-shadow:inset 0 0 0 2px var(--accent-2)}
.st-cell.on.cue{box-shadow:0 0 0 2px #fff,0 0 12px -1px var(--tc)}
.st-addrow{display:flex;min-width:880px;padding-top:4px;padding-left:236px}
/* per-row step lane */
.st-lane{display:flex;gap:10px;min-width:880px;background:color-mix(in srgb,var(--tc) 7%,transparent);border:1px solid color-mix(in srgb,var(--tc) 28%,transparent);border-radius:9px;padding:8px 3px;margin-top:-2px;--tc:var(--accent)}
.st-lane-pad{flex-shrink:0}
.st-lane-steps{display:flex;gap:5px;flex:1}
.lane-col{flex:1;min-width:20px;display:flex;flex-direction:column;align-items:center;gap:3px;border-radius:6px;padding:3px 0;transition:background .12s}
.lane-col.grp{margin-left:15px}
.lane-col.cue{background:color-mix(in srgb,var(--tc) 16%,transparent)}
.lane-num{font-size:8px;color:var(--text-mute)}
.lane-knob{width:auto}
.lane-knob .knob-dial{width:24px;height:24px}
.lane-knob .knob-lab{display:none}
.lane-knob .knob-val{font-size:8px}
.lane-acc{width:14px;height:14px;border-radius:50%;border:1px solid var(--border-2);background:var(--bg);cursor:pointer;transition:.12s;padding:0}
.lane-acc.on{background:#ff4d62;border-color:#ff4d62;box-shadow:0 0 8px #ff4d62}

/* top spectrum */
.studio-topeq{display:flex;align-items:center;gap:10px;margin-bottom:16px;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:6px 12px}
.te-lab{font-size:9.5px;letter-spacing:.1em;color:var(--text-mute);flex-shrink:0}
.topviz{flex:1;width:100%;height:46px;display:block}

/* design: function gen + scope + rec */
.pnl-knobs{display:flex;flex-wrap:wrap;gap:20px 26px;margin-bottom:6px}
.pnl-knobs .knob{width:64px;gap:5px}
.pnl-knobs .knob-dial{width:54px;height:54px}
.pnl-knobs .knob-dial::after{top:5px;height:15px;transform-origin:50% 22px;width:3px}
.pnl-knobs .knob-lab{font-size:10px}
.pnl-knobs .knob-val{font-size:11px;color:var(--text);font-weight:600}
.pnl-seg{display:flex;gap:6px}
.segb{width:38px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-size:15px;cursor:pointer;transition:.15s}
.segb:hover{border-color:var(--accent-line)}
.segb.on{background:var(--accent);color:#04140e;border-color:transparent}
:root[data-theme="light"] .segb.on{color:#fff}
.pnl-scope{width:100%;height:50px;background:#05070b;border:1px solid var(--border);border-radius:8px;margin-bottom:12px;display:block}
:root[data-theme="light"] .pnl-scope{background:#0a0e14}
.pnl-rec{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.rec-btn{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:12px;background:var(--surface);border:1px solid var(--border-2);border-radius:9px;padding:9px 15px;color:var(--text-dim);cursor:pointer;transition:.15s}
.rec-btn:hover{border-color:#ff4d62;color:#ff4d62}
.rec-btn .rec-led{width:9px;height:9px;border-radius:50%;background:#ff4d62;transition:.15s}
.rec-btn.on{border-color:#ff4d62;color:#ff4d62}
.rec-btn.on .rec-led{animation:recblink .8s steps(1) infinite;box-shadow:0 0 8px #ff4d62}
@keyframes recblink{50%{opacity:.25}}
.rec-stat{font-size:11.5px;font-family:'JetBrains Mono',monospace}
.st-metro{display:inline-flex;align-items:center;gap:6px;font-family:'JetBrains Mono',monospace;font-size:12.5px;
  background:var(--surface);border:1px solid var(--border);color:var(--text-dim);border-radius:9px;padding:9px 13px;cursor:pointer;transition:.15s}
.st-metro:hover{border-color:var(--accent-line);color:var(--text)}
.st-metro.on{background:var(--accent);color:#04140e;border-color:transparent}
:root[data-theme="light"] .st-metro.on{color:#fff}
.st-mini{font-family:'JetBrains Mono',monospace;font-size:11.5px;background:var(--surface);border:1px solid var(--border);color:var(--text-dim);border-radius:9px;padding:8px 11px;cursor:pointer;transition:.15s}
.st-mini:hover{border-color:var(--accent-line);color:var(--text)}
.master-out{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:10px;padding:12px 18px;
  background:var(--bg);border:1px solid var(--border);border-left:3px solid #ff4d62;border-radius:13px}
.mo-label{font-size:11px;letter-spacing:.12em;color:var(--text);font-weight:700;padding-right:6px;border-right:1px solid var(--border)}
.mo-stat{font-size:12px;color:var(--text-dim);margin-left:auto}
.st-live{display:inline-flex;align-items:center;gap:6px;font-family:'JetBrains Mono',monospace;font-size:12.5px;font-weight:600;
  background:var(--surface);border:1px solid #ff4d62;color:#ff4d62;border-radius:9px;padding:9px 14px;cursor:pointer;transition:.15s}
.st-live:hover{background:rgba(255,77,98,.1)}
.st-live.on{background:#ff4d62;color:#fff}
.st-live.on{animation:liveblink 1.1s steps(1) infinite}
@keyframes liveblink{50%{background:#c8313f}}
/* context menu */
.st-ctx{position:fixed;z-index:400;min-width:170px;background:var(--surface);border:1px solid var(--border-2);border-radius:11px;box-shadow:var(--shadow);padding:6px;overflow:hidden}
.ctx-item{display:block;width:100%;text-align:left;font-family:inherit;font-size:13px;color:var(--text-dim);background:none;border:none;border-radius:7px;padding:9px 12px;cursor:pointer;transition:.12s}
.ctx-item:hover{background:var(--accent-soft);color:var(--accent)}
.ctx-item.danger:hover{background:rgba(255,77,98,.12);color:#ff4d62}
.ctx-sep{height:1px;background:var(--border);margin:5px 4px}
.vu{flex:1;min-width:80px;max-width:200px;height:9px;background:var(--bg);border:1px solid var(--border);border-radius:100px;overflow:hidden}
.vu-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),#ffd166 70%,#ff4d62);transition:width .05s linear}
.sed{margin-top:6px}
.sed-info{font-size:10.5px;color:var(--text-mute);margin-bottom:7px}
.sed-wave{width:100%;height:96px;display:block;border:1px solid var(--border);border-radius:8px;cursor:ew-resize;touch-action:none}
.sed-act{display:flex;gap:9px;flex-wrap:wrap;margin-top:12px}
.sed-btn{font-family:'JetBrains Mono',monospace;font-size:12px;background:var(--surface);color:var(--text-dim);border:1px solid var(--border);border-radius:9px;padding:9px 14px;cursor:pointer;transition:.15s}
.sed-btn:hover{border-color:var(--accent-line);color:var(--text)}
.sed-btn.on{background:#ff4d62;color:#fff;border-color:transparent}
.sed-btn.primary{background:var(--accent);color:#04140e;border-color:transparent}
:root[data-theme="light"] .sed-btn.primary{color:#fff}

/* master scope + kit badge */
.mst-scope{width:200px;height:48px;background:#05070b;border:1px solid var(--border);border-radius:8px}
:root[data-theme="light"] .mst-scope{background:#0a0e14}
.rc-kit{font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:700;color:#04140e;background:var(--cc);border-radius:4px;padding:1px 5px}
.st-add{width:128px;font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--text-mute);
  background:var(--bg);border:1px dashed var(--border-2);border-radius:8px;padding:8px;cursor:pointer;transition:.15s;display:flex;align-items:center;justify-content:center;gap:6px}
.st-add span{color:var(--accent);font-weight:700}
.st-add:hover{border-color:var(--accent-line);color:var(--text-dim)}

/* master mixer */
.studio-master{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-top:16px;padding:14px 18px;
  background:var(--bg);border:1px solid var(--border);border-radius:13px}
.mst-label{font-size:11px;letter-spacing:.12em;color:var(--text);font-weight:700;padding-right:6px;border-right:1px solid var(--border)}
.mst-knobs{display:flex;gap:14px}
.mst-loop{display:flex;align-items:center;gap:8px;margin-left:auto}
.mst-llab{font-size:11px;color:var(--text-mute);letter-spacing:.08em}
.mst-step{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600;color:var(--text-dim);
  background:var(--surface);border:1px solid var(--border);border-radius:8px;width:42px;height:34px;cursor:pointer;transition:.15s}
.mst-step:hover{border-color:var(--accent-line)}
.mst-step.on{background:var(--accent);color:#04140e;border-color:transparent}
:root[data-theme="light"] .mst-step.on{color:#fff}

/* preview area in design panel */
.pnl-preview{background:color-mix(in srgb,var(--accent) 5%,transparent);border:1px solid var(--border);border-radius:11px;padding:13px;margin-bottom:16px}
.pnl-pvhead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.pnl-pvlab{font-size:9.5px;letter-spacing:.08em;color:var(--accent)}
.pnl-arm{font-family:'JetBrains Mono',monospace;font-size:11px;background:var(--surface);border:1px solid #ff4d62;color:#ff4d62;border-radius:8px;padding:6px 11px;cursor:pointer;transition:.15s}
.pnl-arm:hover{background:rgba(255,77,98,.1)}
.pnl-arm.on{background:#ff4d62;color:#fff;animation:liveblink 1.1s steps(1) infinite}
.pnl-kbd{display:flex;gap:3px}
.pkey{flex:1;height:48px;border-radius:0 0 5px 5px;border:1px solid var(--border-2);background:#f2f5f9;color:#0c1320;
  font-family:'JetBrains Mono',monospace;font-size:9px;cursor:pointer;display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px;transition:.08s}
.pkey.blk{background:#11161f;color:#aeb9c8;height:40px;margin:0 -7px;z-index:2}
.pkey:active{background:var(--accent);color:#04140e}
.pnl-pads{display:flex;gap:10px}
.ppad{flex:1;height:46px;border-radius:9px;border:1px solid var(--border-2);background:var(--surface);color:var(--text-dim);
  font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;cursor:pointer;transition:.08s}
.ppad:hover{border-color:var(--accent-line);color:var(--text)}
.ppad:active{background:var(--accent);color:#04140e;border-color:transparent}
.pnl-note{font-size:11.5px;margin-top:12px;font-family:'JetBrains Mono',monospace}

/* console: design + cell panels */
.studio-console{margin-top:16px;background:var(--bg);border:1px solid var(--accent-line);border-radius:14px;overflow:hidden;animation:dashFade .2s ease}
.pnl-bar{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;background:color-mix(in srgb,var(--accent) 7%,transparent);border-bottom:1px solid var(--border)}
.pnl-title{font-size:12.5px;color:var(--text);letter-spacing:.04em}
.pnl-title .dim{color:var(--text-mute)}
.pnl-x{width:26px;height:26px;border-radius:7px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;font-size:12px}
.pnl-x:hover{border-color:#ff5f57;color:#ff5f57}
.pnl-body{padding:16px}
.pnl-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.pnl-lab{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-mute);width:64px}
.pnl-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 22px}
.pnl-sub{font-size:10.5px;letter-spacing:.1em;color:var(--accent);margin:18px 0 12px;text-transform:uppercase}
.pnl-grid .st-ctl{justify-content:space-between}
.pnl-grid .st-ctl input[type=range]{flex:1;width:auto}
.pnl-act{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.pnl-btn{font-family:'JetBrains Mono',monospace;font-size:12px;background:var(--surface);color:var(--text-dim);
  border:1px solid var(--border);border-radius:9px;padding:9px 15px;cursor:pointer;transition:.15s}
.pnl-btn:hover{border-color:var(--accent-line);color:var(--text)}
.pnl-btn.primary{background:var(--accent);color:#04140e;border-color:transparent}
:root[data-theme="light"] .pnl-btn.primary{color:#fff}
.pnl-btn.danger:hover{border-color:#ff5f57;color:#ff5f57}

/* saved sound rack */
.studio-rackwrap{margin-top:18px}
.rack-label{display:block;font-size:11px;letter-spacing:.06em;color:var(--text-dim);margin-bottom:9px}
.rack-label .dim{color:var(--text-mute);font-weight:400}
.studio-rack{display:block;min-height:38px;max-height:280px;overflow-y:auto;padding:2px}
.rack-group{margin-bottom:12px}
.rack-gh{display:block;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mute);margin:0 0 7px}
.rack-row{display:flex;gap:9px;flex-wrap:wrap}
.rack-empty{font-size:12px;font-family:'JetBrains Mono',monospace}
.rack-chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);
  border-radius:100px;padding:7px 13px;cursor:pointer;transition:.15s;font-size:12px}
.rack-chip:hover{border-color:var(--accent-line);transform:translateY(-2px)}
.rack-chip{--cc:var(--accent)}
.rack-chip.user{border-style:dashed}
.rack-chip .rc-dot{width:8px;height:8px;border-radius:50%;background:var(--cc);box-shadow:0 0 6px var(--cc)}
.rack-chip b{font-family:'JetBrains Mono',monospace;font-weight:600;color:var(--text)}
.rack-chip .rc-eng{font-size:10px;color:var(--text-mute)}
.rack-chip .rc-x{color:var(--text-mute);font-size:11px;padding-left:2px}
.rack-chip .rc-x:hover{color:#ff5f57}

.studio-viz{width:100%;height:96px;background:var(--bg);border:1px solid var(--border);border-radius:12px;display:block;margin-top:18px}
.studio-code{width:100%;margin-top:16px;min-height:150px;resize:vertical;background:#05070b;color:#cdd6e0;
  border:1px solid var(--border);border-radius:12px;padding:16px;font-family:'JetBrains Mono',monospace;
  font-size:13px;line-height:1.7;letter-spacing:.04em;white-space:pre}
:root[data-theme="light"] .studio-code{background:#0a0e14}
.studio-code:focus{outline:none;border-color:var(--accent-line);box-shadow:0 0 0 3px var(--accent-soft)}

/* ---------- IDEAS / RANGE ---------- */
.range-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px;font-family:'Space Grotesk',sans-serif;
  font-size:clamp(16px,2.1vw,22px);font-weight:600;margin-bottom:46px}
.range-row span{color:var(--text)}
.range-row i{color:var(--accent);font-style:normal;font-size:.8em}
.todo{background:var(--card-grad);border:1px solid var(--border);border-radius:14px;padding:26px 30px}
.todo-head{font-size:14px;color:var(--accent);margin-bottom:16px}
.todo ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.todo li{position:relative;padding-left:30px;font-size:15.5px;color:var(--text-dim)}
.todo li::before{content:"[ ]";position:absolute;left:0;top:0;font-family:'JetBrains Mono',monospace;color:var(--accent);font-size:13px}

/* ---------- CONTACT ---------- */
.contact{overflow:hidden}
.contact-term{max-width:620px;margin:0 auto}
.contact-term .term-body{font-size:14.5px;line-height:2.1}
.cc{display:flex;flex-direction:column;gap:6px;margin:6px 0}
.cc a,.cc-line{color:var(--text-dim);transition:.18s;white-space:pre}
.cc a:hover{color:var(--accent)}
.cc .ck{color:var(--accent-2);display:inline-block;width:84px}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--border);padding:38px 0;background:var(--bg-2)}
.foot{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.foot-brand{display:flex;align-items:center;gap:13px}
.foot-brand b{display:block;font-family:'Space Grotesk',sans-serif;font-size:15px}
.foot-brand .dim{font-size:12.5px;font-family:'JetBrains Mono',monospace}
.foot-note{font-size:12.5px;color:var(--text-mute)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.r-right{transform:translateX(30px)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .portrait-ring,.spark b,.eq b,.np-bar span,.float-chip,.scrollcue{animation:none!important}
}

/* ---------- scroll progress + to-top ---------- */
.progress{position:fixed;top:0;left:0;height:2px;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));z-index:100;transition:width .1s linear}
.to-top{position:fixed;right:22px;bottom:22px;width:44px;height:44px;border-radius:12px;background:var(--surface);
  border:1px solid var(--border-2);color:var(--text);display:grid;place-items:center;cursor:pointer;z-index:70;
  opacity:0;visibility:hidden;transform:translateY(10px);transition:.25s;box-shadow:var(--shadow-sm)}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{border-color:var(--accent-line);color:var(--accent)}
.to-top svg{width:19px;height:19px}

/* ---------- window controls (mac + studio) ---------- */
.mac-bar i,.studio-bar i{cursor:pointer;transition:transform .12s,filter .12s}
.mac-bar i:hover,.studio-bar i:hover{transform:scale(1.18);filter:brightness(1.15)}
body.win-fulling{overflow:hidden}
.mac.wfull,.studio.wfull{position:fixed;inset:3vh 3vw;width:auto!important;max-width:none!important;height:94vh!important;
  z-index:300;margin:0;display:flex;flex-direction:column;box-shadow:0 0 0 100vmax rgba(2,4,8,.74),var(--shadow)}
.mac.wfull .mac-body,.studio.wfull .studio-body{flex:1;overflow:auto}
.mac.wfull .dash{min-height:100%}
.mac.wmin .mac-body,.studio.wmin .studio-body{display:none}
.win-reopen{display:inline-flex;align-items:center;gap:7px;margin-top:14px;font-family:'JetBrains Mono',monospace;
  font-size:12px;background:var(--surface);border:1px solid var(--border-2);border-radius:9px;padding:9px 15px;color:var(--text-dim);cursor:pointer;transition:.15s}
.win-reopen span{color:var(--accent)}
.win-reopen:hover{border-color:var(--accent-line);color:var(--text)}

/* ---------- GHOST SHELL (easter egg) ---------- */
.ghost{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;
  background:rgba(2,4,8,.72);backdrop-filter:blur(6px);padding:24px}
.ghost.on{display:flex;animation:ghostIn .25s ease}
@keyframes ghostIn{from{opacity:0}to{opacity:1}}
body.ghost-open{overflow:hidden}
.ghost-win{width:min(920px,96vw);height:min(620px,88vh);display:flex;flex-direction:column;
  background:#05070b;border:1px solid #1b2531;border-radius:12px;overflow:hidden;
  box-shadow:0 40px 120px -30px rgba(0,0,0,.9),0 0 0 1px rgba(47,224,168,.08);
  font-family:'JetBrains Mono',ui-monospace,monospace}
.ghost-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#0a0e14;border-bottom:1px solid #1b2531}
.ghost-bar i{width:12px;height:12px;border-radius:50%;cursor:pointer}
.ghost-bar i.r{background:#ff5f57}.ghost-bar i.y{background:#febc2e}.ghost-bar i.g{background:#28c840}
.ghost-title{margin-left:10px;font-size:12px;color:#5b6675;flex:1}
.ghost-x{font-size:11px;color:#5b6675;border:1px solid #1b2531;border-radius:6px;padding:2px 8px;cursor:pointer}
.ghost-x:hover{color:#9fb0c0;border-color:#2c3a4a}
.ghost-body{flex:1;overflow-y:auto;padding:16px 18px 26px;font-size:13.5px;line-height:1.7;color:#cdd6e0;
  white-space:pre-wrap;word-break:break-word}
.ghost-body::-webkit-scrollbar{width:9px}.ghost-body::-webkit-scrollbar-thumb{background:#1b2531;border-radius:6px}
.ghost-body .gl{white-space:pre-wrap}
.ghost-body .gp{white-space:pre-wrap;word-break:break-word}
.ghost-body .cmd{color:#cdd6e0}
.ghost-body .ok{color:#2fe0a8}
.ghost-body .dim{color:#5b6675}
.ghost-body .gu{color:#2fe0a8}
.ghost-body .gc{color:#7aa2ff}
.ghost-body .gd{color:#7aa2ff}
.ghost-body .hp-warn{color:#ff7a90}
.ghost-body .gin{white-space:pre-wrap}
.gcur{display:inline-block;width:8px;height:15px;background:#2fe0a8;vertical-align:-2px;animation:blink 1.05s steps(1) infinite}
.ghost-hint{position:fixed;right:16px;bottom:74px;z-index:60;font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--text-mute);background:var(--surface);border:1px dashed var(--border-2);border-radius:8px;
  padding:6px 10px;cursor:pointer;opacity:.55;transition:.2s}
.ghost-hint:hover{opacity:1;color:var(--accent);border-color:var(--accent-line)}
@media(max-width:560px){.ghost-hint{display:none}.ghost-win{height:92vh}}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1080px){
  .menu{display:none}
}
@media(max-width:920px){
  section{padding:84px 0}
  .hero-inner,.manifesto,.now-grid,.music-inner{grid-template-columns:1fr;gap:40px}
  .hero-right{order:-1}
  .portrait{max-width:300px;margin:0 auto}
  .stack-grid,.philo-grid,.md-grid{grid-template-columns:repeat(2,1fr)}
  .lab-grid{grid-template-columns:1fr}
  .menu.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;gap:2px;
    background:var(--bg);border-bottom:1px solid var(--border);padding:14px 20px 22px}
  .menu.open a{padding:11px 12px}
  .burger{display:flex}
  .now-grid{direction:ltr}
  .mac-wrap{order:1}
}
@media(max-width:560px){
  body{font-size:16px}
  .wrap{padding:0 18px}
  section{padding:68px 0}
  .stack-grid,.philo-grid,.md-grid{grid-template-columns:1fr}
  .hero-term{max-width:100%}
  .dash{grid-template-columns:1fr}
  .dash-side{flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid var(--border)}
  .ds-logo{width:100%}
  .float-chip{display:none}
  .fc3{display:flex}
  .foot{flex-direction:column;align-items:flex-start}
  .studio-foot{grid-template-columns:1fr}
  .studio-transport{gap:12px}
  .st-preset{margin-left:0;width:100%}
}
