/* =====================================================
   LEWIS · v4 · clean modern · producer storefront
   dark-first · accent yellow · grid-driven
   ===================================================== */

:root{
  /* dark base */
  --bg:#0a0a0b;
  --bg-1:#101012;
  --bg-2:#15151a;
  --bg-3:#1d1d22;
  --bg-4:#26262e;
  --line:#1f1f25;
  --line-2:#2a2a32;
  --line-3:#3a3a44;
  --ink:#fafafa;
  --ink-2:#a8a8ad;
  --ink-3:#75757b;
  --ink-4:#52525a;

  --accent:#d4ff00;       /* electric lime */
  --accent-ink:#0a0a0b;
  --accent-soft:rgba(212,255,0,.12);

  --green:#22c55e;
  --red:#ef4444;

  --sans:'Geist','Inter',system-ui,-apple-system,sans-serif;
  --mono:'Geist Mono','JetBrains Mono',ui-monospace,monospace;

  --max:1320px;
  --pad-x:clamp(20px,4vw,56px);
  --pad-y:clamp(72px,11vw,160px);

  --r-sm:6px;
  --r:10px;
  --r-lg:16px;

  --t-fast:140ms cubic-bezier(0.16, 1, 0.3, 1);
  --t:260ms cubic-bezier(0.16, 1, 0.3, 1);
  --t-slow:520ms cubic-bezier(0.16, 1, 0.3, 1);

  --nav-h:64px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;color-scheme:dark}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);
  font-size:15.5px;line-height:1.55;letter-spacing:-.005em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body.is-locked{overflow:hidden}
img,svg,canvas{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;font-family:inherit}
input,select{font:inherit;color:inherit;font-family:inherit}
::selection{background:var(--accent);color:var(--accent-ink)}

.kicker{
  font-family:var(--mono);font-size:11.5px;font-weight:500;
  letter-spacing:.04em;color:var(--ink-3);margin:0 0 14px;
  text-transform:none;
}

/* ---------- announce bar ---------- */
.bar{
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:var(--bg-1);
  padding:9px var(--pad-x);
  font-family:var(--mono);font-size:12px;color:var(--ink-2);
  border-bottom:1px solid var(--line);
  position:relative;z-index:60;
}
.bar a{color:var(--accent);font-weight:500}
.bar a:hover{text-decoration:underline;text-underline-offset:3px}
.bar__dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 var(--accent);animation:p 2s ease-out infinite}
@keyframes p{0%{box-shadow:0 0 0 0 rgba(212,255,0,.5)}100%{box-shadow:0 0 0 9px rgba(212,255,0,0)}}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;gap:18px;
  height:var(--nav-h);padding:0 var(--pad-x);
  background:rgba(10,10,11,.72);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color var(--t),background var(--t);
}
.nav.is-scrolled{border-bottom-color:var(--line);background:rgba(10,10,11,.92)}
.brand{display:inline-flex;align-items:center;gap:9px;font-weight:600;letter-spacing:-.01em}
.brand__mark{
  width:26px;height:26px;border-radius:7px;background:var(--accent);
  display:grid;place-items:center;color:var(--accent-ink);
  font-family:var(--mono);font-weight:600;font-size:13px;line-height:1;
}
.brand__name{font-size:15px}
.nav__links{display:flex;gap:6px;margin-left:18px}
.nav__links a{
  font-size:13.5px;color:var(--ink-2);
  padding:8px 12px;border-radius:var(--r-sm);
  transition:color var(--t-fast),background var(--t-fast);
}
.nav__links a:hover{color:var(--ink);background:var(--bg-2)}
.nav__actions{margin-left:auto;display:flex;gap:6px;align-items:center}
.iconlink{
  width:36px;height:36px;border-radius:var(--r-sm);
  display:grid;place-items:center;color:var(--ink-2);
  transition:color var(--t-fast),background var(--t-fast);
  position:relative;
}
.iconlink:hover{color:var(--ink);background:var(--bg-2)}
.iconlink--cart span{
  position:absolute;top:2px;right:2px;
  background:var(--accent);color:var(--accent-ink);
  font-family:var(--mono);font-size:9.5px;font-weight:600;line-height:1;
  min-width:14px;height:14px;border-radius:7px;padding:0 3px;
  display:grid;place-items:center;
  transform:scale(0);transition:transform var(--t);
}
.iconlink--cart.has-items span{transform:scale(1)}
.iconlink--burger{display:none}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  height:38px;padding:0 16px;border-radius:var(--r-sm);
  font-size:13.5px;font-weight:500;letter-spacing:-.005em;
  transition:transform var(--t-fast),background var(--t-fast),color var(--t-fast),border-color var(--t-fast);
  white-space:nowrap;
  border:1px solid transparent;
}
.btn--accent{background:var(--accent);color:var(--accent-ink)}
.btn--accent:hover{background:#e2ff33;transform:translateY(-1px)}
.btn--ghost{border-color:var(--line-2);color:var(--ink);background:transparent}
.btn--ghost:hover{border-color:var(--ink-3);background:var(--bg-2)}
.btn--lg{height:46px;padding:0 22px;font-size:14.5px}
.btn--ink{background:var(--ink);color:var(--bg)}
.btn--ink:hover{background:#e9e9e9;transform:translateY(-1px)}

/* ---------- pills ---------- */
.pill{
  display:inline-flex;align-items:center;gap:8px;
  height:32px;padding:0 12px;border-radius:999px;
  font-size:12.5px;color:var(--ink-2);
  background:var(--bg-2);border:1px solid var(--line);
  transition:all var(--t-fast);
}
.pill:hover{color:var(--ink);border-color:var(--line-2)}
.pill.is-active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.pill__c{
  font-family:var(--mono);font-size:10.5px;
  background:var(--bg-3);color:var(--ink-3);
  padding:1px 6px;border-radius:5px;line-height:1.5;
}
.pill.is-active .pill__c{background:var(--bg-4);color:var(--ink-2)}

/* ---------- hero ---------- */
.hero{
  display:grid;grid-template-columns:1.1fr 1fr;gap:72px;align-items:center;
  max-width:var(--max);margin:0 auto;
  padding:80px var(--pad-x) 96px;
}
.tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:12px;color:var(--ink-2);
  padding:7px 12px;border-radius:999px;
  background:var(--bg-2);border:1px solid var(--line);
  margin:0 0 24px;
}
.tag__pulse{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 var(--accent);animation:p 2s ease-out infinite}
.hero__title{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(40px,5.6vw,72px);
  line-height:1.02;letter-spacing:-.035em;
  margin:0 0 24px;
}
.hero__lede{
  font-size:clamp(15px,1.3vw,17px);
  color:var(--ink-2);max-width:50ch;margin:0 0 28px;
  line-height:1.55;
}
.hero__ctas{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.hero__ctas .btn{height:46px;padding:0 22px;font-size:14.5px}
.hero__stats{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-family:var(--mono);font-size:12.5px;color:var(--ink-3);
  padding-top:24px;border-top:1px solid var(--line);
}
.hero__stats strong{color:var(--ink);font-weight:500;font-family:var(--sans);font-size:14px;letter-spacing:-.01em;margin-right:2px}
.hero__stats .dot{color:var(--ink-4)}

.hero__visual{
  position:relative;background:var(--bg-1);
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:24px;aspect-ratio:5/4;
  display:flex;flex-direction:column;justify-content:space-between;
  overflow:hidden;
}
.hero__visual::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 70% 0%,rgba(212,255,0,.08),transparent 50%);
  pointer-events:none;
}
.hero__visual canvas{
  width:100%;flex:1;
  position:relative;z-index:1;
}
.hero__visual-meta{
  position:absolute;top:16px;left:20px;right:20px;z-index:2;
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.04em;
}
.hero__playpill{
  position:relative;z-index:2;display:flex;align-items:center;gap:14px;
  background:var(--bg-2);border:1px solid var(--line-2);
  border-radius:var(--r);padding:12px 14px;text-align:left;
  transition:border-color var(--t-fast),background var(--t-fast);
  margin-top:14px;
}
.hero__playpill:hover{border-color:var(--ink-4);background:var(--bg-3)}
.hero__playicon{
  width:36px;height:36px;border-radius:50%;background:var(--accent);color:var(--accent-ink);
  display:grid;place-items:center;font-size:13px;line-height:1;flex-shrink:0;
  transition:background var(--t-fast);
}
.hero__visual.is-playing .hero__playicon{background:var(--accent)}
.hero__playmeta{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.hero__playmeta span:first-child{font-size:13.5px;color:var(--ink);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hero__playmeta span:last-child{font-family:var(--mono);font-size:11px;color:var(--ink-3)}

/* ---------- credits strip ---------- */
.creds{
  border-top:1px solid var(--line);
  padding:28px var(--pad-x);
  display:flex;align-items:center;gap:28px;
  max-width:var(--max);margin:0 auto;
  flex-wrap:wrap;
}
.creds__label{
  font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.04em;
  margin:0;flex-shrink:0;
}
.creds__list{
  list-style:none;margin:0;padding:0;display:flex;gap:28px;flex-wrap:wrap;align-items:center;
  font-size:14.5px;color:var(--ink);font-weight:600;letter-spacing:-.01em;
}
.creds__list li{transition:opacity var(--t-fast)}
.creds__list li:hover{opacity:.7}
.creds__list li > span{color:var(--ink-4);font-weight:400;letter-spacing:.04em}
.creds__hit{
  font-family:var(--mono);font-size:12px;font-weight:500;color:var(--ink-2);letter-spacing:.02em;
  display:inline-flex;align-items:baseline;gap:8px;
}
.creds__hit em{color:var(--accent);font-style:normal;font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:-.01em}

/* ---------- daws strip ---------- */
.daws{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:22px var(--pad-x);
  display:flex;align-items:center;gap:32px;
  max-width:var(--max);margin:0 auto;
  flex-wrap:wrap;
  opacity:.85;
}
.daws__label{
  font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.04em;
  margin:0;flex-shrink:0;
}
.daws__list{
  list-style:none;margin:0;padding:0;display:flex;gap:32px;flex-wrap:wrap;
  font-size:13.5px;color:var(--ink-2);font-weight:500;
}
.daws__list li{transition:color var(--t-fast)}
.daws__list li:hover{color:var(--ink)}

/* ---------- catalog ---------- */
.cat{padding:var(--pad-y) var(--pad-x);max-width:var(--max);margin:0 auto}
.cat__head{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:end;margin-bottom:36px}
.cat__head h2{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(36px,4.4vw,56px);
  letter-spacing:-.03em;line-height:1;margin:0;
}
.cat__sub{color:var(--ink-2);max-width:54ch;margin:0;font-size:15px;line-height:1.6}

/* filters */
.filters{
  display:grid;grid-template-columns:1.1fr 2fr 1fr;gap:14px;align-items:center;
  background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:10px;margin-bottom:24px;
}
.filters__search{display:flex;align-items:center;gap:10px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 12px}
.filters__search svg{color:var(--ink-3);flex-shrink:0}
.filters__search input{flex:1;background:none;border:0;outline:none;font-size:13.5px;color:var(--ink)}
.filters__search input::placeholder{color:var(--ink-4)}
.filters__chips{display:flex;gap:6px;flex-wrap:wrap}
.filters__bpm{
  display:grid;grid-template-columns:auto 1fr;gap:6px 10px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:9px 12px;align-items:center;
}
.filters__bpm > span:first-child{font-family:var(--mono);font-size:11px;color:var(--ink-3)}
.filters__bpmval{font-family:var(--mono);font-size:11px;color:var(--ink);text-align:right}
.dual{position:relative;height:18px;grid-column:1/3}
.dual input[type="range"]{
  -webkit-appearance:none;appearance:none;
  position:absolute;left:0;right:0;width:100%;height:2px;background:var(--line-2);
  pointer-events:none;outline:none;margin:0;top:8px;border-radius:1px;
}
.dual input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:14px;height:14px;border-radius:50%;background:var(--accent);
  pointer-events:auto;cursor:pointer;border:2px solid var(--bg-2);
}
.dual input[type="range"]::-moz-range-thumb{
  width:14px;height:14px;border-radius:50%;background:var(--accent);
  pointer-events:auto;cursor:pointer;border:2px solid var(--bg-2);
}

/* kit grid · 4 cols clean */
.cat__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.kit{
  background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;cursor:pointer;
  transition:transform var(--t-fast),border-color var(--t-fast);
  display:flex;flex-direction:column;
}
.kit:hover{transform:translateY(-2px);border-color:var(--line-3)}
.kit__cover{aspect-ratio:1/1;position:relative;overflow:hidden;background:var(--bg-3)}
.kit__cover-bg{position:absolute;inset:0;transition:transform var(--t)}
.kit:hover .kit__cover-bg{transform:scale(1.04)}
.kit__cover-meta{
  position:absolute;top:12px;left:12px;right:12px;z-index:2;
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:10.5px;color:rgba(255,255,255,.85);letter-spacing:.04em;
}
.kit__cover-meta span:last-child{
  background:rgba(0,0,0,.35);backdrop-filter:blur(6px);
  padding:3px 8px;border-radius:5px;
}
.kit__play{
  position:absolute;left:50%;bottom:14px;transform:translate(-50%,4px);z-index:3;
  width:42px;height:42px;border-radius:50%;
  background:var(--accent);color:var(--accent-ink);
  display:grid;place-items:center;
  opacity:0;transition:opacity var(--t),transform var(--t);
}
.kit:hover .kit__play{opacity:1;transform:translate(-50%,0)}
.kit.is-playing .kit__play{opacity:1;transform:translate(-50%,0)}
.kit__minwave{
  position:absolute;left:14px;right:14px;bottom:14px;height:32px;z-index:2;
  display:flex;align-items:flex-end;gap:1.5px;
  opacity:0;transition:opacity var(--t);
}
.kit.is-playing .kit__minwave{opacity:.85}
.kit__minwave span{flex:1;height:20%;background:rgba(255,255,255,.95);border-radius:1px}
.kit.is-playing .kit__minwave span{animation:bar 700ms ease-in-out infinite alternate}
@keyframes bar{from{height:18%}to{height:90%}}

.kit__body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:10px;flex:1}
.kit__title{font-size:15px;font-weight:500;letter-spacing:-.01em;margin:0;line-height:1.25}
.kit__row{display:flex;justify-content:space-between;align-items:center;gap:8px}
.kit__meta{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.02em}
.kit__price{font-size:18px;font-weight:600;letter-spacing:-.01em;line-height:1;color:var(--ink)}
.kit__price s{color:var(--ink-3);font-size:12px;font-weight:400;margin-right:4px}
.kit__buy{
  width:32px;height:32px;border-radius:var(--r-sm);
  background:var(--bg-3);color:var(--ink);
  display:grid;place-items:center;font-size:18px;line-height:1;
  transition:background var(--t-fast),color var(--t-fast);
}
.kit__buy:hover{background:var(--accent);color:var(--accent-ink)}
.kit__buy.is-added{background:var(--green);color:var(--accent-ink);font-size:13px;pointer-events:none}

/* per-kit cover gradients (dark-aware) */
.cv-1 .kit__cover-bg{background:linear-gradient(135deg,#3a1006,#0a0a0b 80%)}
.cv-2 .kit__cover-bg{background:linear-gradient(135deg,#3d2c00,#0a0a0b 80%)}
.cv-3 .kit__cover-bg{background:linear-gradient(135deg,#0a1f3a,#0a0a0b 80%)}
.cv-4 .kit__cover-bg{background:linear-gradient(135deg,#0e2912,#0a0a0b 80%)}
.cv-5 .kit__cover-bg{background:linear-gradient(135deg,#3a0e25,#0a0a0b 80%)}
.cv-6 .kit__cover-bg{background:linear-gradient(135deg,#1f1239,#0a0a0b 80%)}
.cv-7 .kit__cover-bg{background:linear-gradient(135deg,#063038,#0a0a0b 80%)}
.cv-8 .kit__cover-bg{background:linear-gradient(135deg,#3d0a05,#0a0a0b 80%)}
.cv-9 .kit__cover-bg{background:linear-gradient(135deg,#3a1d05,#0a0a0b 80%)}
.cv-10 .kit__cover-bg{background:linear-gradient(135deg,#053024,#0a0a0b 80%)}
.cv-11 .kit__cover-bg{background:linear-gradient(135deg,#3a3009,#0a0a0b 80%)}
.cv-12 .kit__cover-bg{background:linear-gradient(135deg,#241039,#0a0a0b 80%)}

.cat__empty{text-align:center;padding:64px 20px;color:var(--ink-2);border:1px dashed var(--line-2);border-radius:var(--r-lg);margin-top:18px}
.cat__empty p{margin:0 0 16px}
.cat__bundle{
  margin-top:24px;padding:20px 24px;
  background:linear-gradient(90deg,rgba(212,255,0,.08),rgba(212,255,0,.02));
  border:1px solid rgba(212,255,0,.2);border-radius:var(--r-lg);
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
}
.cat__bundle .kicker{color:var(--accent);margin:0 0 4px}
.cat__bundle strong{color:var(--accent)}
.cat__bundle div span{font-size:14px;color:var(--ink-2)}

/* ---------- process ---------- */
.process{padding:var(--pad-y) var(--pad-x);max-width:var(--max);margin:0 auto;border-top:1px solid var(--line)}
.process__head{margin-bottom:48px;max-width:680px}
.process__head h2{font-family:var(--sans);font-weight:600;font-size:clamp(36px,4.6vw,60px);letter-spacing:-.03em;line-height:1;margin:0 0 16px}
.process__head p{color:var(--ink-2);margin:0;font-size:16px}
.process__list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.process__list li{padding:32px 28px;background:var(--bg-1);display:flex;flex-direction:column;gap:12px}
.process__num{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.04em;margin-bottom:8px}
.process__list h3{font-size:20px;font-weight:600;letter-spacing:-.02em;margin:0 0 4px}
.process__list p{color:var(--ink-2);margin:0 0 8px;font-size:14.5px;line-height:1.55;flex:1}
.process__gear{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
.process__gear span{
  font-family:var(--mono);font-size:10.5px;color:var(--ink-3);
  background:var(--bg-2);padding:4px 8px;border-radius:5px;
}

/* ---------- showcase / playlist ---------- */
.show{padding:var(--pad-y) var(--pad-x);max-width:var(--max);margin:0 auto;border-top:1px solid var(--line)}
.show__head{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:end;margin-bottom:36px}
.show__head h2{font-family:var(--sans);font-weight:600;font-size:clamp(36px,4.4vw,56px);letter-spacing:-.03em;line-height:1;margin:0}
.show__head p{color:var(--ink-2);max-width:54ch;margin:0;font-size:15px;line-height:1.6}

.show__list{list-style:none;padding:0;margin:0;background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.show-row{
  display:grid;grid-template-columns:auto 48px 1fr 2fr auto auto;gap:16px;align-items:center;
  padding:14px 18px;border-bottom:1px solid var(--line);cursor:pointer;
  transition:background var(--t-fast);
}
.show-row:last-child{border-bottom:0}
.show-row:hover{background:var(--bg-2)}
.show-row__n{font-family:var(--mono);font-size:12.5px;color:var(--ink-3);width:24px;text-align:center}
.show-row:hover .show-row__n{color:var(--ink)}
.show-row.is-playing .show-row__n{color:var(--accent)}
.show-row__cv{
  width:48px;height:48px;border-radius:var(--r-sm);overflow:hidden;flex-shrink:0;
  position:relative;
}
.show-row__cv-bg{position:absolute;inset:0}
.show-row__title{font-size:14.5px;font-weight:500;letter-spacing:-.005em}
.show-row__sub{font-family:var(--mono);font-size:11.5px;color:var(--ink-3);margin-top:2px}
.show-row__wave{display:flex;align-items:center;gap:2px;height:24px;opacity:.45;transition:opacity var(--t)}
.show-row.is-playing .show-row__wave,.show-row:hover .show-row__wave{opacity:1}
.show-row__wave span{width:2px;background:var(--ink-3);height:30%;border-radius:1px}
.show-row.is-playing .show-row__wave span{background:var(--accent);animation:bar 700ms ease-in-out infinite alternate}
.show-row__time{font-family:var(--mono);font-size:11.5px;color:var(--ink-3);min-width:42px;text-align:right}
.show-row__btn{
  width:36px;height:36px;border-radius:50%;background:var(--bg-3);color:var(--ink);
  display:grid;place-items:center;font-size:11px;
  transition:background var(--t-fast),color var(--t-fast);
}
.show-row:hover .show-row__btn{background:var(--accent);color:var(--accent-ink)}
.show-row.is-playing .show-row__btn{background:var(--accent);color:var(--accent-ink)}

/* ---------- about ---------- */
.about{padding:var(--pad-y) var(--pad-x);max-width:var(--max);margin:0 auto;border-top:1px solid var(--line);display:grid;grid-template-columns:1fr 1.3fr;gap:64px;align-items:center}
.about__col--portrait{display:flex;flex-direction:column;gap:14px}
.portrait{
  aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;
  background:var(--bg-3);position:relative;
  border:1px solid var(--line);
}
.portrait__inner{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 30%,rgba(212,255,0,.18),transparent 55%),
    radial-gradient(circle at 70% 80%,rgba(255,255,255,.05),transparent 60%),
    var(--bg-2);
}
.portrait__caption{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11.5px;color:var(--ink-3)}
.portrait__caption span:first-child{color:var(--ink)}

.about h2{font-family:var(--sans);font-weight:600;font-size:clamp(30px,4vw,46px);letter-spacing:-.025em;line-height:1.05;margin:0 0 20px}
.about p{color:var(--ink-2);max-width:54ch;font-size:16px;line-height:1.65;margin:0}
.about__cred{
  list-style:none;padding:0;margin:32px 0 0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
}
.about__cred li{display:flex;flex-direction:column;gap:6px;padding:18px;background:var(--bg-1)}
.about__cred-n{font-size:24px;font-weight:600;letter-spacing:-.02em;color:var(--ink)}
.about__cred-l{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.02em}

/* ---------- testimonials ---------- */
.testi{padding:var(--pad-y) var(--pad-x);max-width:var(--max);margin:0 auto;border-top:1px solid var(--line)}
.testi__head{margin-bottom:36px;max-width:600px}
.testi__head h2{font-family:var(--sans);font-weight:600;font-size:clamp(32px,4vw,52px);letter-spacing:-.025em;line-height:1.05;margin:0}
.testi__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.testi__card{
  background:var(--bg-1);padding:28px 26px;display:flex;flex-direction:column;gap:18px;
}
.testi__stars{color:var(--accent);font-size:13px;letter-spacing:2px;font-family:var(--mono)}
.testi__quote{font-size:15.5px;line-height:1.55;letter-spacing:-.005em;margin:0;flex:1;color:var(--ink)}
.testi__person{display:flex;align-items:center;gap:12px;padding-top:18px;border-top:1px solid var(--line)}
.testi__avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;background:var(--bg-3);overflow:hidden;position:relative}
.testi__avatar::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.18),transparent 60%)}
.testi__name{font-size:13.5px;font-weight:500;line-height:1.2}
.testi__role{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin-top:3px}

/* ---------- loyalty ---------- */
.loyalty{padding:var(--pad-y) var(--pad-x);max-width:var(--max);margin:0 auto;border-top:1px solid var(--line)}
.loyalty__head{margin-bottom:36px;max-width:600px}
.loyalty__head h2{font-family:var(--sans);font-weight:600;font-size:clamp(32px,4vw,52px);letter-spacing:-.025em;line-height:1.05;margin:0}
.loyalty__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.loyalty__grid > div{background:var(--bg-1);padding:32px 28px;display:flex;flex-direction:column;gap:10px}
.loyalty__icon{
  width:44px;height:44px;border-radius:var(--r-sm);
  background:var(--accent-soft);color:var(--accent);
  display:grid;place-items:center;font-family:var(--mono);font-size:14px;font-weight:500;
  margin-bottom:8px;
}
.loyalty__grid h3{font-size:18px;font-weight:600;letter-spacing:-.015em;margin:0}
.loyalty__grid p{color:var(--ink-2);margin:0;font-size:14.5px;line-height:1.55}

/* ---------- FAQ ---------- */
.faq{padding:var(--pad-y) var(--pad-x);max-width:980px;margin:0 auto;border-top:1px solid var(--line)}
.faq__head{margin-bottom:32px}
.faq__head h2{font-family:var(--sans);font-weight:600;font-size:clamp(30px,4vw,48px);letter-spacing:-.025em;line-height:1;margin:0}
.faq__list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{
  width:100%;text-align:left;padding:22px 4px;font-size:16px;font-weight:500;
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  transition:color var(--t-fast);
}
.faq__q:hover{color:var(--accent)}
.faq__plus{
  width:22px;height:22px;border-radius:50%;flex-shrink:0;
  display:grid;place-items:center;font-size:14px;color:var(--ink-3);
  border:1px solid var(--line-2);
  transition:transform var(--t),background var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
.faq__item.is-open .faq__plus{transform:rotate(45deg);background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.faq__a{
  max-height:0;overflow:hidden;transition:max-height var(--t),padding var(--t);
  padding:0 4px;color:var(--ink-2);font-size:15px;line-height:1.65;
}
.faq__a p{margin:0}
.faq__item.is-open .faq__a{max-height:340px;padding:0 4px 22px}

/* ---------- newsletter ---------- */
.news{padding:var(--pad-y) var(--pad-x);border-top:1px solid var(--line)}
.news__inner{max-width:680px;margin:0 auto;text-align:center}
.news h2{font-family:var(--sans);font-weight:600;font-size:clamp(28px,3.6vw,42px);letter-spacing:-.025em;line-height:1.05;margin:0 0 12px}
.news > .news__inner > p{color:var(--ink-2);margin:0 0 24px}
.news__form{
  display:flex;gap:8px;max-width:480px;margin:0 auto;flex-wrap:wrap;
  background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r);
  padding:6px;
}
.news__form input{
  flex:1;background:transparent;border:0;outline:none;
  padding:10px 12px;font-size:14px;color:var(--ink);min-width:200px;
}
.news__form input::placeholder{color:var(--ink-4)}
.news__msg{margin-top:14px;font-size:13px;color:var(--green);min-height:1.4em;font-family:var(--mono)}
.news__msg.is-error{color:var(--red)}

/* ---------- footer ---------- */
.foot{padding:60px var(--pad-x) 28px;border-top:1px solid var(--line);background:var(--bg-1)}
.foot__top{display:grid;grid-template-columns:1fr 2fr;gap:48px;margin-bottom:40px}
.foot__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.foot__heading{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.04em;margin:0 0 14px}
.foot__cols div a{display:block;font-size:13.5px;color:var(--ink-2);padding:5px 0;transition:color var(--t-fast)}
.foot__cols div a:hover{color:var(--ink)}
.foot__bot{
  border-top:1px solid var(--line);padding-top:22px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-family:var(--mono);font-size:11.5px;color:var(--ink-4);
}

/* ---------- mini player ---------- */
.mini{
  position:fixed;bottom:16px;left:50%;transform:translate(-50%,30px);z-index:70;
  display:grid;grid-template-columns:auto auto 1fr auto auto;gap:14px;align-items:center;
  background:var(--bg-1);border:1px solid var(--line-2);border-radius:var(--r);
  padding:10px 14px 10px 10px;width:min(560px,calc(100vw - 32px));
  opacity:0;pointer-events:none;
  transition:opacity var(--t),transform var(--t);
  box-shadow:0 18px 50px -10px rgba(0,0,0,.6);
}
.mini.is-open{opacity:1;transform:translate(-50%,0);pointer-events:auto}
.mini__cover{width:40px;height:40px;border-radius:var(--r-sm);background:var(--bg-3);overflow:hidden}
.mini__info{min-width:0}
.mini__title{font-size:13px;font-weight:500;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini__sub{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin-top:2px}
.mini__wave{display:flex;align-items:center;gap:1.5px;height:22px;width:80px}
.mini__wave span{width:1.5px;background:var(--ink-3);height:30%;border-radius:1px}
.mini.is-playing .mini__wave span{background:var(--accent);animation:bar 600ms ease-in-out infinite alternate}
.mini__play{
  width:32px;height:32px;border-radius:50%;background:var(--accent);color:var(--accent-ink);
  display:grid;place-items:center;
  transition:background var(--t-fast);
}
.mini__play:hover{background:#e2ff33}
.mini__close{width:30px;height:30px;border-radius:var(--r-sm);color:var(--ink-3);font-size:18px;line-height:1;transition:color var(--t-fast),background var(--t-fast)}
.mini__close:hover{color:var(--ink);background:var(--bg-3)}

/* ---------- drawers ---------- */
.drawer{
  position:fixed;inset:0;z-index:80;
  background:rgba(0,0,0,.6);
  opacity:0;pointer-events:none;transition:opacity var(--t);
  display:flex;
}
.drawer.is-open{opacity:1;pointer-events:auto}
.drawer__panel{
  position:relative;background:var(--bg-1);border-left:1px solid var(--line-2);
  width:min(440px,90vw);height:100%;margin-left:auto;
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform var(--t);
}
.drawer.is-open .drawer__panel{transform:translateX(0)}
.drawer--menu .drawer__panel{margin-left:0;border-left:0;border-right:1px solid var(--line-2);transform:translateX(-100%)}
.drawer--menu.is-open .drawer__panel{transform:translateX(0)}
.drawer__panel header{
  padding:18px 22px;border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
  font-size:16px;font-weight:500;
}
.drawer__close{width:32px;height:32px;border-radius:var(--r-sm);font-size:20px;color:var(--ink-3);transition:color var(--t-fast),background var(--t-fast)}
.drawer__close:hover{color:var(--ink);background:var(--bg-3)}

.drawer--menu nav{display:flex;flex-direction:column;padding:14px 12px;gap:2px}
.drawer--menu nav a{padding:14px 12px;border-radius:var(--r-sm);font-size:18px;font-weight:500;transition:background var(--t-fast)}
.drawer--menu nav a:hover{background:var(--bg-3)}
.drawer--menu .btn{margin:14px 22px 22px}

.drawer__searchbox{display:flex;align-items:center;gap:10px;margin:14px 22px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 14px}
.drawer__searchbox svg{color:var(--ink-3)}
.drawer__searchbox input{flex:1;background:none;border:0;outline:none;font-size:14.5px}
.drawer__results{flex:1;overflow:auto;padding:0 22px 22px;display:flex;flex-direction:column;gap:6px}
.search-item{display:flex;align-items:center;gap:12px;padding:10px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);cursor:pointer;transition:border-color var(--t-fast)}
.search-item:hover{border-color:var(--line-3)}
.search-item__cv{width:40px;height:40px;border-radius:var(--r-sm);flex-shrink:0;background:var(--bg-3);overflow:hidden;position:relative}
.search-item__cv > div{position:absolute;inset:0}
.search-item__t{font-weight:500;font-size:13.5px}
.search-item__m{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin-top:2px}
.search-empty{color:var(--ink-3);text-align:center;padding:40px 20px;font-size:13.5px}

.cart__list{flex:1;overflow:auto;padding:14px 22px;display:flex;flex-direction:column;gap:10px}
.cart-item{display:grid;grid-template-columns:auto 1fr auto auto;gap:14px;padding:10px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);align-items:center}
.cart-item__cv{width:48px;height:48px;border-radius:var(--r-sm);flex-shrink:0;background:var(--bg-3);overflow:hidden;position:relative}
.cart-item__cv > div{position:absolute;inset:0}
.cart-item__t{font-weight:500;font-size:13.5px;line-height:1.2}
.cart-item__m{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin-top:2px}
.cart-item__p{font-size:16px;font-weight:600;letter-spacing:-.01em}
.cart-item__rm{color:var(--ink-3);width:28px;height:28px;border-radius:var(--r-sm);display:grid;place-items:center;font-size:18px}
.cart-item__rm:hover{background:var(--bg-3);color:var(--red)}
.cart__totals{padding:18px 22px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:9px}
.cart__row{display:flex;justify-content:space-between;font-size:13.5px;color:var(--ink-2)}
.cart__row strong{color:var(--ink);font-weight:600}
.cart__row--save strong{color:var(--accent)}
.cart__row--total{font-size:15.5px;color:var(--ink);padding-top:9px;border-top:1px solid var(--line)}
.cart__row--total strong{font-size:20px}
.cart__totals .btn{margin-top:6px;width:100%;justify-content:center}
.cart__note{font-size:11px;color:var(--ink-4);text-align:center;margin:0;font-family:var(--mono)}
.cart__empty{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:14px;color:var(--ink-3);padding:40px 22px}

/* ---------- modals ---------- */
.modal{
  position:fixed;inset:0;z-index:90;
  background:rgba(0,0,0,.7);backdrop-filter:blur(4px);
  opacity:0;pointer-events:none;transition:opacity var(--t);
  display:flex;align-items:center;justify-content:center;padding:20px;
}
.modal.is-open{opacity:1;pointer-events:auto}
.modal__panel{
  position:relative;background:var(--bg-1);border:1px solid var(--line-2);border-radius:var(--r-lg);
  width:min(960px,100%);max-height:90vh;overflow:auto;
  transform:scale(.98) translateY(8px);transition:transform var(--t);
}
.modal.is-open .modal__panel{transform:none}
.modal__panel--narrow{max-width:480px}
.modal__close{
  position:absolute;top:14px;right:14px;z-index:2;
  width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.4);color:var(--ink);
  font-size:18px;line-height:1;display:grid;place-items:center;
  transition:background var(--t-fast);
}
.modal__close:hover{background:var(--accent);color:var(--accent-ink)}

/* quickview */
.qv{display:grid;grid-template-columns:1fr 1.1fr;gap:0}
.qv__cover{
  aspect-ratio:1/1;position:relative;overflow:hidden;
  background:var(--bg-3);border-right:1px solid var(--line);
  border-radius:var(--r-lg) 0 0 var(--r-lg);
  display:grid;place-items:center;
}
.qv__cover-bg{position:absolute;inset:0}
.qv__cover-meta{
  position:absolute;top:16px;left:18px;right:18px;z-index:2;
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.85);
}
.qv__cover-meta span:last-child{
  background:rgba(0,0,0,.35);backdrop-filter:blur(8px);
  padding:3px 8px;border-radius:5px;
}
.qv__cover-title{
  position:absolute;left:18px;right:18px;bottom:18px;z-index:2;
  font-size:22px;font-weight:600;letter-spacing:-.02em;color:#fff;line-height:1.1;
}
.qv__play{
  position:relative;z-index:3;
  width:64px;height:64px;border-radius:50%;background:var(--accent);color:var(--accent-ink);
  display:grid;place-items:center;
  transition:transform var(--t-fast),background var(--t-fast);
}
.qv__play:hover{transform:scale(1.06);background:#e2ff33}
.qv__cover.is-playing .qv__play{background:#e2ff33}

.qv__info{padding:36px 32px;display:flex;flex-direction:column;gap:14px}
.qv__updated{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin:0}
.qv__info h3{font-size:30px;font-weight:600;letter-spacing:-.025em;margin:0;line-height:1.05}
.qv__desc{color:var(--ink-2);margin:0;font-size:15px;line-height:1.6}
.qv__specsrow{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;margin:6px 0 4px}
.qv__specsrow > div{background:var(--bg-2);padding:10px 12px;display:flex;flex-direction:column;gap:2px}
.qv__specsrow span{font-family:var(--mono);font-size:10.5px;color:var(--ink-3)}
.qv__specsrow strong{font-size:14px;font-weight:500;letter-spacing:-.005em}
.qv__info h4{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.04em;margin:8px 0 6px;font-weight:500}
.qv__contents{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:4px;font-size:13px;color:var(--ink-2)}
.qv__contents li{padding:7px 12px;background:var(--bg-2);border-radius:var(--r-sm);display:flex;align-items:center;gap:8px}
.qv__contents li::before{content:"•";color:var(--accent);font-size:14px}
.qv__license{font-size:13px;color:var(--ink-3);margin:0;line-height:1.55}
.qv__foot{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;padding-top:18px;border-top:1px solid var(--line)}
.qv__price{font-size:30px;font-weight:600;letter-spacing:-.025em;line-height:1}
.qv__price s{color:var(--ink-3);font-size:14px;font-weight:400;margin-right:6px}
.qv__foot .btn{height:46px;padding:0 22px;font-size:14.5px}

/* lead */
.lead{padding:36px 32px;display:flex;flex-direction:column;gap:14px}
.lead h3{font-size:28px;font-weight:600;letter-spacing:-.025em;margin:0;line-height:1.05}
.lead p{color:var(--ink-2);margin:0 0 8px;font-size:14.5px}
.lead form{display:flex;flex-direction:column;gap:10px}
.lead input{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:12px 14px;font-size:14.5px;color:var(--ink);outline:none;
  transition:border-color var(--t-fast);
}
.lead input:focus{border-color:var(--accent)}
.lead .btn{justify-content:center;width:100%}
.lead__msg{margin:0;font-size:13px;color:var(--green);min-height:1.4em;font-family:var(--mono)}
.lead__msg.is-error{color:var(--red)}

/* ---------- toast ---------- */
.toast{
  position:fixed;bottom:90px;left:50%;transform:translate(-50%,30px);
  background:var(--bg-3);border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:12px 18px;font-size:13.5px;
  z-index:100;opacity:0;pointer-events:none;
  transition:opacity var(--t),transform var(--t);
  box-shadow:0 14px 40px -10px rgba(0,0,0,.6);
}
.toast.is-shown{opacity:1;transform:translate(-50%,0)}

/* ---------- reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(14px);transition:opacity 600ms ease,transform 600ms cubic-bezier(0.16,1,0.3,1)}
[data-reveal].is-visible{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width:1180px){
  .hero{grid-template-columns:1fr;gap:48px}
  .hero__visual{aspect-ratio:16/10}
  .cat__grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:980px){
  .nav__links{display:none}
  .iconlink--burger{display:grid}
  .nav__actions .btn{display:none}
  .cat__head,.show__head{grid-template-columns:1fr;gap:18px}
  .cat__grid{grid-template-columns:repeat(2,1fr)}
  .process__list,.testi__grid,.loyalty__grid{grid-template-columns:1fr}
  .about{grid-template-columns:1fr;gap:32px}
  .filters{grid-template-columns:1fr}
  .qv{grid-template-columns:1fr}
  .qv__cover{border-right:0;border-bottom:1px solid var(--line);border-radius:var(--r-lg) var(--r-lg) 0 0;aspect-ratio:16/10}
  .qv__contents{grid-template-columns:1fr}
  .qv__specsrow{grid-template-columns:repeat(2,1fr)}
  .show-row{grid-template-columns:auto 40px 1fr auto auto;gap:12px}
  .show-row__sub-cell,.show-row__wave{display:none}
  .foot__top{grid-template-columns:1fr}
}
@media (max-width:620px){
  .cat__grid{grid-template-columns:1fr}
  .hero__title{font-size:40px}
  .hero__stats{font-size:11.5px;gap:8px}
  .foot__cols{grid-template-columns:1fr 1fr}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0!important;transition-duration:0!important}
}
