/* ============================================================
   PLOTFLOW · STYLES (base + components). Tokens live in tokens.css
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--white);background:var(--con2);line-height:1.5;overflow-x:hidden}
a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
select{font-family:inherit}
.jp{font-family:var(--jp)}
.num{font-variant-numeric:tabular-nums;letter-spacing:.02em}
.tiny{font-weight:700;font-size:8.5px;letter-spacing:.16em;text-transform:uppercase;line-height:1.4}
.wrap{max-width:1240px;margin:0 auto;padding:0 26px}

/* textures */
.grain{position:absolute;inset:0;pointer-events:none;opacity:.5;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.scan{position:absolute;inset:0;pointer-events:none;opacity:.4;background-image:repeating-linear-gradient(0deg,rgba(0,0,0,.10) 0 1px,transparent 1px 3px)}
.halftone{position:absolute;pointer-events:none;background-image:radial-gradient(var(--white) 32%,transparent 33%);background-size:7px 7px;-webkit-mask-image:radial-gradient(circle at 50% 50%,#000 38%,transparent 70%);mask-image:radial-gradient(circle at 50% 50%,#000 38%,transparent 70%);opacity:.7}
.ast{display:inline-block}.ast svg{display:block;width:100%;height:100%}.ast line{stroke:currentColor;stroke-width:10}

/* asterisk bug shorthand */
.star{color:var(--red)}

/* NAV */
nav{position:sticky;top:0;z-index:60;background:rgba(31,33,28,.72);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-in{max-width:1240px;margin:0 auto;padding:12px 26px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{font-weight:900;font-size:1.45rem;letter-spacing:-.01em;text-transform:uppercase}
.brand i{font-style:normal;color:var(--red)}
.nav-links{display:flex;gap:24px}
.nav-links a{font-weight:700;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}
.nav-links a:hover{color:var(--white)}
@media(max-width:720px){.nav-links{display:none}}
.cart{font-weight:800;font-size:10px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--line);padding:8px 13px}
.cart:hover{background:var(--white);color:var(--ink)}

/* HERO */
.hero{position:relative;min-height:92vh;display:flex;flex-direction:column;overflow:hidden;
  background:linear-gradient(180deg,rgba(40,43,36,.35),rgba(30,32,27,.78)),
             radial-gradient(120% 90% at 70% 10%,#6a6d62 0%,var(--con1) 45%,var(--con2) 100%)}
.hero .grain,.hero .scan{z-index:1}
.hero-head{position:relative;z-index:5;padding:34px 26px 0;max-width:1240px;margin:0 auto;width:100%}
.hero-head h1{font-weight:900;font-size:clamp(3rem,11vw,8rem);line-height:.84;letter-spacing:-.02em;text-transform:uppercase}
.hero-head h1 .s{color:var(--red)}
.hero-head .sub{font-weight:600;font-size:clamp(.7rem,1.6vw,1rem);letter-spacing:.02em;color:var(--mute);margin-top:8px;border-top:1px solid var(--line);padding-top:8px;max-width:760px}
.hero-head .sub b{color:var(--white);font-weight:700}

.stage-area{position:relative;z-index:5;flex:1;display:flex;align-items:center;justify-content:center;padding:18px 26px;min-height:0}
.bed{position:relative;background:var(--paper);box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 0 1px rgba(0,0,0,.3);width:min(62%,640px);max-height:64vh;aspect-ratio:4/3}
.bed .corner{position:absolute;width:15px;height:15px;border:1.5px solid #b7ab8a;z-index:3}
.bed .c-tl{top:8px;left:8px;border-right:none;border-bottom:none}.bed .c-tr{top:8px;right:8px;border-left:none;border-bottom:none}
.bed .c-bl{bottom:8px;left:8px;border-right:none;border-top:none}.bed .c-br{bottom:8px;right:8px;border-left:none;border-top:none}
.bed .bl{position:absolute;top:8px;left:50%;transform:translateX(-50%);font-weight:700;font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:#a99a76;z-index:3}
#pcanvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
#stage{position:absolute;inset:0;width:100%;height:100%;z-index:2}
#ppath{fill:none;stroke:none}
.replay{position:absolute;inset:0;z-index:6;display:none;align-items:center;justify-content:center;background:rgba(20,18,12,.12);cursor:pointer}
.replay.show{display:flex}
.replay span{font-family:var(--sans);font-weight:800;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#15160f;background:var(--paper);border:1px solid #15160f;padding:10px 18px}

/* big jp lockup lower-left like the reference */
.hero-jp{position:absolute;z-index:5;left:26px;bottom:96px;pointer-events:none}
.hero-jp .k{font-family:var(--jp);font-weight:900;font-size:clamp(2.4rem,7vw,5rem);line-height:.9;letter-spacing:.02em}
.hero-jp .e{font-weight:800;font-size:clamp(1rem,2.6vw,1.8rem);letter-spacing:.04em;text-transform:uppercase;margin-top:2px}
.hero-collab{position:absolute;z-index:5;left:26px;bottom:42px;font-weight:800;font-size:1rem;letter-spacing:.1em;text-transform:uppercase}
.hero-collab .star{color:var(--red)}
.hero .ht1{width:180px;height:180px;right:8%;top:40%;z-index:4}
.hero .ast-bug{position:absolute;z-index:5;width:54px;height:54px;color:var(--white);right:6%;bottom:8%}

/* plotter HUD + controls */
.hud{position:absolute;z-index:7;right:26px;top:120px;text-align:right;pointer-events:none}
.hud .k{color:var(--mute);font-weight:700;font-size:9px;letter-spacing:.18em;text-transform:uppercase}
.hud .row{font-weight:800;font-size:.95rem;margin-top:3px}
.hud .row small{color:var(--mute);font-weight:700;font-size:.62em;margin-left:3px}
@media(max-width:820px){.hud{display:none}.hero-jp{bottom:120px}}

.dock{position:relative;z-index:8;display:flex;align-items:center;gap:9px;flex-wrap:wrap;justify-content:center;padding:12px 26px 16px;background:rgba(20,21,16,.5);border-top:1px solid var(--line)}
.selwrap{position:relative}
select{appearance:none;background:rgba(245,244,239,.06);color:var(--white);border:1px solid var(--line);padding:9px 30px 9px 12px;font-weight:800;font-size:10px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}
.selwrap::after{content:"▾";position:absolute;right:11px;top:50%;transform:translateY(-50%);color:var(--red);pointer-events:none;font-size:10px}
.btn{font-weight:800;font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:9px 15px;border:1px solid var(--line);background:rgba(245,244,239,.06)}
.btn:hover{background:var(--white);color:var(--ink)}
.btn.pri{background:var(--white);color:var(--ink)}
.seg{display:flex;border:1px solid var(--line)}
.seg button{padding:8px 10px;font-weight:800;font-size:10px;color:var(--mute);border-right:1px solid var(--line)}
.seg button:last-child{border-right:none}.seg button.on{background:var(--white);color:var(--ink)}
.pbar{position:relative;z-index:8;height:3px;background:rgba(0,0,0,.25)}
.pbar b{position:absolute;left:0;top:0;bottom:0;width:0;background:var(--red)}

/* ---- mobile hero: taller plot + clean stack (plot › controls › lockup) ---- */
@media(max-width:720px){
  .hero{min-height:auto;padding-bottom:6px}
  .hero-head{padding:22px 18px 0}
  .stage-area{order:1;flex:none;padding:18px 16px 14px}
  .bed{width:90vw;max-width:520px;max-height:none;aspect-ratio:3/4}
  .pbar{order:2}
  .dock{order:3;padding:14px 16px;gap:8px}
  .selwrap{flex-basis:100%}
  .selwrap select{width:100%}
  .hero-jp{order:4;position:static;left:auto;bottom:auto;margin:20px 18px 0}
  .hero-collab{order:5;position:static;left:auto;bottom:auto;margin:8px 18px 16px;font-size:.85rem}
  .hero .ast-bug{display:none}
}

/* MANIFESTO strip */
.mani{position:relative;background:var(--ink);padding:46px 0;overflow:hidden;border-bottom:1px solid #2a2b24}
.mani .grain{opacity:.35}
.mani-in{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.mani h2{font-weight:900;font-size:clamp(1.8rem,5vw,3.4rem);text-transform:uppercase;letter-spacing:-.01em;line-height:.9}
.mani h2 .star{color:var(--red)}
.mani p{color:var(--mute);font-weight:500;font-size:13px;max-width:46ch;line-height:1.6}
.mani .jp{color:var(--dim);font-weight:700;font-size:11px;letter-spacing:.1em;margin-top:6px}

/* SHOP */
.shop{background:var(--con2);padding:54px 0 64px;position:relative}
.shop .grain{opacity:.4}
.shop-head{position:relative;z-index:2;display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:26px}
.shop-head h2{font-weight:900;font-size:clamp(2rem,6vw,3.4rem);text-transform:uppercase;letter-spacing:-.01em;line-height:.85}
.shop-head h2 .star{color:var(--red)}
.shop-head .jp{font-family:var(--jp);font-weight:700;color:var(--mute);font-size:1rem;align-self:center}
.shop-head .meta{margin-left:auto;color:var(--mute);max-width:34ch;text-align:right}
.grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.grid{grid-template-columns:1fr}}

.card .cover{position:relative;aspect-ratio:3/4;overflow:hidden;
  background:linear-gradient(180deg,rgba(40,43,36,.25),rgba(22,23,18,.7)),radial-gradient(120% 90% at 60% 15%,#63665b,#33352e);
  border:1px solid var(--line);display:flex;flex-direction:column}
.card .cover .art{position:absolute;inset:8% 6% 9% 6%;z-index:2;color:var(--white)}
.card .cover .art svg{width:100%;height:100%}
.card .cover .art path{stroke-width:.7px}
.card .cover .grain{opacity:.4;z-index:3}
.card .cover .ht{position:absolute;width:120px;height:120px;right:-10px;top:34%;z-index:3;background-image:radial-gradient(var(--white) 32%,transparent 33%);background-size:6px 6px;-webkit-mask-image:radial-gradient(circle,#000 36%,transparent 70%);mask-image:radial-gradient(circle,#000 36%,transparent 70%);opacity:.55}
.card .cover .top{position:relative;z-index:5;display:flex;justify-content:space-between;gap:6px;padding:9px 10px}
.card .cover .name{position:relative;z-index:5;padding:0 10px;font-weight:900;font-size:1.5rem;line-height:.92;text-transform:uppercase;letter-spacing:-.01em}
.card .cover .jp{position:absolute;z-index:5;right:10px;top:42px;font-family:var(--jp);font-weight:700;font-size:11px;color:var(--mute);writing-mode:vertical-rl}
.card .cover .ast{position:absolute;z-index:5;width:26px;height:26px;color:var(--red);left:10px;top:40%}
.card .cover .foot{position:relative;z-index:5;margin-top:auto;display:flex;justify-content:space-between;align-items:flex-end;padding:9px 10px}
.card .cover .plotbtn{position:absolute;z-index:6;right:10px;bottom:10px;font-family:var(--sans);font-weight:800;font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--white);padding:5px 8px;background:rgba(20,21,16,.4)}
.card .cover .plotbtn:hover{background:var(--white);color:var(--ink)}
.card .buy{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:12px 2px 0}
.card .buy .t{font-weight:800;font-size:1.05rem;line-height:1}
.card .buy .ed{font-weight:700;font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-bottom:3px}
.card .buy .pr{font-weight:800}
.card .buy .acq{font-weight:800;font-size:9px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--line);padding:8px 11px;margin-left:10px}
.card .buy .acq:hover{background:var(--red);border-color:var(--red);color:var(--white)}

/* PROCESS */
.proc{background:var(--con2);padding:8px 0 60px;position:relative}
.proc-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line)}
@media(max-width:720px){.proc-grid{grid-template-columns:1fr}}
.ps{padding:22px 20px;border-right:1px solid var(--line)}.ps:last-child{border-right:none}
@media(max-width:720px){.ps{border-right:none;border-bottom:1px solid var(--line)}.ps:last-child{border-bottom:none}}
.ps .n{font-weight:900;font-size:2rem;color:var(--red);line-height:.8}
.ps .jp{font-family:var(--jp);font-weight:700;font-size:11px;color:var(--mute);margin-top:4px}
.ps h4{font-weight:800;font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin:12px 0 7px}
.ps p{color:var(--mute);font-weight:500;font-size:12px;line-height:1.55}

/* FOOTER */
footer{background:var(--ink);padding:48px 0 56px;position:relative;overflow:hidden}
footer .grain{opacity:.3}
.foot-mast{position:relative;z-index:2;font-weight:900;font-size:clamp(3rem,13vw,9rem);line-height:.8;letter-spacing:-.02em;text-transform:uppercase;border-bottom:1px solid var(--line);padding-bottom:16px}
.foot-mast .s{color:var(--red)}
.foot-cols{position:relative;z-index:2;display:flex;justify-content:space-between;flex-wrap:wrap;gap:28px;padding:24px 0}
.fc h5{font-weight:800;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:11px}
.fc a{display:block;font-weight:500;font-size:13px;color:var(--mute);margin-bottom:7px}.fc a:hover{color:var(--white)}
.fc .est{display:block;font-weight:500;font-size:13px;color:var(--dim);margin-bottom:7px}
.foot-bot{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;border-top:1px solid var(--line);padding-top:18px;color:var(--dim)}

/* INTERIOR PAGES */
.page{background:var(--con2);padding:64px 0 80px;position:relative;min-height:60vh}
.page-head{border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:36px}
.page-head h1{font-weight:900;font-size:clamp(2.4rem,7vw,4.5rem);text-transform:uppercase;letter-spacing:-.01em;line-height:.85}
.page-head h1 .star{color:var(--red)}
.page-head .jp{font-family:var(--jp);font-weight:700;font-size:1rem;color:var(--mute);margin-top:6px}
.page-body{max-width:680px}
.page-body h3{font-weight:800;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--white);margin:32px 0 10px;padding-top:16px;border-top:1px solid var(--line)}
.page-body h3:first-child{margin-top:0;padding-top:0;border-top:none}
.page-body p{color:var(--mute);font-weight:500;font-size:14px;line-height:1.7;margin-bottom:12px}
.page-body ul,.page-body ol{color:var(--mute);font-weight:500;font-size:14px;line-height:1.7;margin:0 0 16px 20px}
.page-body li{margin-bottom:6px}
.page-body li strong{color:var(--white);font-weight:700}
.page-body a{color:var(--red)}
.page-body a:hover{text-decoration:underline}
.page-body blockquote{border-left:3px solid var(--red);padding:12px 0 12px 20px;margin:28px 0}
.page-body blockquote p{color:var(--white);font-weight:700;font-size:1.1rem;line-height:1.5}
.page-body blockquote em{color:var(--mute);font-weight:500;font-size:14px}
.faq .qa{padding:20px 0;border-bottom:1px solid var(--line)}
.faq .qa:first-child{padding-top:0}
.faq .qa h3{border-top:none;padding-top:0;margin-top:0;margin-bottom:8px}
.contact-block{display:flex;gap:40px;flex-wrap:wrap;margin:20px 0 28px}
.contact-item{display:flex;flex-direction:column;gap:6px}
.contact-link{font-weight:800;font-size:1.2rem;color:var(--white)}
.contact-link:hover{color:var(--red)}

/* CART DRAWER */
.cart-overlay{position:fixed;inset:0;z-index:90;background:rgba(10,11,8,.55);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:opacity .25s}
.cart-overlay.show{opacity:1;visibility:visible}
.cart-drawer{position:fixed;top:0;right:0;z-index:91;height:100%;width:min(420px,92vw);background:var(--con2);border-left:1px solid var(--line);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .28s ease;box-shadow:-30px 0 80px rgba(0,0,0,.45)}
.cart-drawer.open{transform:translateX(0)}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--line)}
.cart-title{font-weight:900;font-size:1.5rem;text-transform:uppercase;letter-spacing:-.01em}
.cart-ast{color:var(--red);font-weight:900;font-size:1.5rem}
.cart-jp{font-family:var(--jp);font-weight:700;font-size:11px;color:var(--mute);margin-left:10px}
.cart-close{font-size:1.7rem;line-height:1;color:var(--mute);padding:0 4px}
.cart-close:hover{color:var(--white)}
.cart-items{flex:1;overflow-y:auto;padding:8px 22px}
.cart-empty{color:var(--dim);padding:40px 0;text-align:center}
.ci{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:12px;padding:16px 0;border-bottom:1px solid var(--line)}
.ci-name{font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.01em;line-height:1.2}
.ci-ed{color:var(--dim);margin-top:4px}
.ci-qty{display:flex;align-items:center;border:1px solid var(--line)}
.ci-qty button{width:26px;height:26px;font-size:14px;font-weight:800;color:var(--mute)}
.ci-qty button:hover{background:var(--white);color:var(--ink)}
.ci-qty span{min-width:24px;text-align:center;font-weight:800;font-size:12px;font-variant-numeric:tabular-nums}
.ci-price{font-weight:800;font-size:13px;font-variant-numeric:tabular-nums;min-width:54px;text-align:right}
.ci-rm{color:var(--dim);font-size:1.1rem;line-height:1;padding:0 2px}
.ci-rm:hover{color:var(--red)}
.cart-foot{border-top:1px solid var(--line);padding:18px 22px 22px}
.cart-sub{display:flex;justify-content:space-between;align-items:baseline}
.cart-sub .tiny{color:var(--mute)}
.cart-sub-val{font-weight:900;font-size:1.3rem;font-variant-numeric:tabular-nums}
.cart-note{color:var(--dim);margin:8px 0 14px;letter-spacing:.04em;line-height:1.5;text-transform:none}
.cart-checkout{width:100%;background:var(--red);color:var(--white);font-weight:800;font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:14px;border:1px solid var(--red)}
.cart-checkout:hover{background:var(--white);color:var(--ink);border-color:var(--white)}
.cart-checkout:disabled{opacity:.45;cursor:not-allowed}
<<<<<<< HEAD
=======
.cart-toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);z-index:95;background:var(--ink);color:var(--white);border:1px solid var(--line);padding:12px 18px;font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none}
.cart-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
>>>>>>> a4f47b5b80479b6bdd236703ae93d873d3c42872
