/* GhrimPrints design system · dark default + light toggle */
:root{
  --void:#06050b; --void2:#0a0813; --panel:#100c1e; --panel2:#15102a;
  --purple:#bf00ff; --violet:#8b2bff; --glowpink:#e9a6ff; --indigo:#4b0082;
  --text:#EDEAF6; --muted:#9c95b8; --faint:#615a7e;
  --line:rgba(191,0,255,.18); --line2:rgba(255,255,255,.07);
  --header:rgba(6,5,11,.72);
  --live:#46e3a8; --soon:#f0b045;
}
[data-theme="light"]{
  --void:#f3effb; --void2:#ece6f7; --panel:#ffffff; --panel2:#f7f3fd;
  --purple:#8a00c2; --violet:#7a2bd6; --glowpink:#b46bff;
  --text:#160f2b; --muted:#574f70; --faint:#8d86a3;
  --line:rgba(138,0,194,.2); --line2:rgba(20,12,40,.08);
  --header:rgba(243,239,251,.82);
  --live:#0e9c6d; --soon:#b87514;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--void);color:var(--text);font-family:'Inter',sans-serif;font-weight:300;line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background .5s,color .5s}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--purple);color:#fff}
.wrap{position:relative;z-index:3;max-width:1240px;margin:0 auto;padding:0 clamp(20px,5vw,48px)}
h1,h2,h3,h4{font-family:'Syne',sans-serif;letter-spacing:-.01em;line-height:1.05}

/* ambient + grain */
.amb{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.5;transition:opacity .6s}
[data-theme="light"] .orb{opacity:.22}
.orb.a{width:640px;height:640px;background:radial-gradient(circle,rgba(191,0,255,.55),transparent 70%);top:-200px;right:-140px}
.orb.b{width:520px;height:520px;background:radial-gradient(circle,rgba(75,0,130,.75),transparent 70%);bottom:-160px;left:-120px}
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* header */
header{position:fixed;top:0;left:0;right:0;z-index:60;backdrop-filter:blur(16px);background:var(--header);border-bottom:1px solid var(--line2)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px;max-width:1240px;margin:0 auto;padding:0 clamp(20px,5vw,48px)}
.mark{font-family:'Syne';font-weight:800;font-size:19px;letter-spacing:.32em;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.mark b{color:var(--purple)}
.logo-img{height:34px;width:auto;display:block}
[data-theme="light"] .logo-img{filter:invert(1)}
.navlinks{display:flex;gap:26px;font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.navlinks a{transition:color .25s}.navlinks a:hover,.navlinks a.active{color:var(--purple)}
.nav-r{display:flex;align-items:center;gap:12px}
.icbtn{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--text);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:border-color .25s,transform .3s;position:relative;text-decoration:none}
.icbtn:hover{border-color:var(--purple)}
#themeBtn:hover{transform:rotate(18deg)}
.cart-count{position:absolute;top:-4px;right:-4px;min-width:17px;height:17px;border-radius:9px;background:var(--purple);color:#fff;font-family:'Space Mono';font-size:10px;display:none;align-items:center;justify-content:center;padding:0 4px}
.burger{display:none}
.menu{position:fixed;inset:0;z-index:70;background:var(--void2);backdrop-filter:blur(20px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;opacity:0;pointer-events:none;transition:opacity .4s}
.menu.open{opacity:1;pointer-events:auto}
.menu a{font-family:'Syne';font-weight:700;font-size:30px;color:var(--text);padding:7px 0}
.menu a:hover{color:var(--purple)}
.menu .close{position:absolute;top:22px;right:26px;font-size:22px}

/* buttons */
.btn{font-family:'Inter';font-weight:500;font-size:14px;border-radius:999px;padding:14px 28px;cursor:pointer;border:none;display:inline-flex;align-items:center;gap:9px;transition:transform .3s,box-shadow .3s;text-decoration:none}
.btn-primary{background:linear-gradient(95deg,var(--violet),var(--purple));color:#fff;box-shadow:0 14px 44px -12px rgba(191,0,255,.7)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 60px -12px rgba(191,0,255,.9)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--purple);transform:translateY(-3px)}
.btn-block{width:100%;justify-content:center;padding:16px}
.btn[disabled]{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none}

/* page scaffold */
main{position:relative;z-index:3;padding-top:70px}
.sec{padding:clamp(56px,9vw,110px) 0}
.sec-tight{padding:clamp(36px,6vw,70px) 0}
.idx{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--purple);margin-bottom:14px;display:flex;align-items:center;gap:12px}
.idx span{color:var(--faint)}
h2{font-weight:700;font-size:clamp(30px,5vw,56px)}
.lead{color:var(--muted);max-width:36rem;margin-top:14px;font-size:clamp(15px,1.4vw,17px)}
.crumb{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);padding:24px 0 0;display:flex;gap:8px;flex-wrap:wrap}
.crumb a:hover{color:var(--purple)}
.pagehead{padding:36px 0 8px}
.pagehead .eyebrow{font-family:'Space Mono';font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--purple);margin-bottom:14px}

/* badges */
.tag{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;padding:5px 11px;border-radius:999px;display:inline-block}
.tag.live{color:var(--live);background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.3)}
.tag.soon{color:var(--soon);background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.3)}
.tag.made{color:var(--glowpink);background:rgba(191,0,255,.1);border:1px solid var(--line)}

/* product grid (fixed-ratio media · never skews) */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:20px;margin-top:36px}
.pcard{border-radius:14px;overflow:hidden;border:1px solid var(--line);background:var(--panel);transition:transform .4s,border-color .4s;display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-7px);border-color:rgba(191,0,255,.5)}
.pcard .ph{aspect-ratio:4/3;overflow:hidden;position:relative;background:#0c0917}
.pcard .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.pcard:hover .ph img{transform:scale(1.06)}
.pcard .ph .tag{position:absolute;top:12px;left:12px}
.pcard .m{padding:16px 18px;display:flex;flex-direction:column;flex:1}
.pcard .m .t{font-family:'Syne';font-weight:600;font-size:17px;margin-bottom:4px}
.pcard .m .d{color:var(--muted);font-size:13px;margin-bottom:14px;flex:1}
.pcard .m .r{display:flex;align-items:center;justify-content:space-between;gap:8px}
.price{font-family:'Space Mono',monospace;color:var(--purple);font-size:14px}
.mini{font-size:12px;border:1px solid var(--line);border-radius:999px;padding:8px 15px;background:transparent;color:var(--text);cursor:pointer;white-space:nowrap;transition:border-color .25s,background .25s;text-decoration:none;display:inline-block}
.mini:hover{border-color:var(--purple);background:rgba(191,0,255,.08)}
.mini.soon{color:var(--soon);border-color:rgba(245,158,11,.4)}

/* category tiles (shop) */
.cats{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:40px}
.cat{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line);min-height:340px;display:flex;align-items:flex-end;transition:transform .4s}
.cat:hover{transform:translateY(-8px)}
.cat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .6s}
.cat:hover img{transform:scale(1.06)}
.cat .veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(6,5,11,.1),rgba(6,5,11,.88))}
.cat .ci{position:relative;z-index:2;padding:28px}
.cat .ci h3{font-size:26px;font-weight:700;color:#fff;margin-bottom:6px}
.cat .ci p{color:rgba(255,255,255,.8);font-size:14px;margin-bottom:14px;max-width:24rem}
.cat .ci .go{font-family:'Space Mono';font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--glowpink);display:inline-flex;gap:8px;transition:gap .3s}
.cat:hover .ci .go{gap:15px}

/* category hero banner */
.cat-hero{position:relative;border-radius:18px;overflow:hidden;margin-top:24px;border:1px solid var(--line);min-height:300px;display:flex;align-items:center}
.cat-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.cat-hero .veil{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(6,5,11,.92),rgba(6,5,11,.45))}
.cat-hero .ch{position:relative;z-index:2;padding:clamp(28px,5vw,56px);max-width:40rem}

/* product detail + configurator */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);margin-top:30px;align-items:start}
.pd-media{border-radius:16px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;position:relative;background:#0c0917}
.pd-media img{width:100%;height:100%;object-fit:cover}
.pd h1{font-size:clamp(30px,4vw,46px);font-weight:800;margin-bottom:8px}
.pd .sub{color:var(--muted);margin-bottom:22px}
.pd .pdrice{font-family:'Space Mono';color:var(--purple);font-size:28px;margin-bottom:24px}
.cfg{display:flex;flex-direction:column;gap:22px}
.cfg .grp .lab{font-family:'Space Mono';font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;display:block}
.opts{display:flex;flex-wrap:wrap;gap:10px}
.opt{border:1px solid var(--line);border-radius:10px;padding:11px 16px;background:transparent;color:var(--text);cursor:pointer;font-size:14px;transition:border-color .25s,background .25s;font-family:'Inter'}
.opt small{display:block;color:var(--faint);font-size:11px}
.opt.sel{border-color:var(--purple);background:rgba(191,0,255,.1);color:var(--purple)}
.swatch{width:42px;height:42px;border-radius:10px;border:2px solid var(--line);cursor:pointer;transition:transform .2s,border-color .2s}
.swatch.sel{border-color:var(--purple);transform:scale(1.08)}
select.opt,.cfg select{appearance:none;width:100%}
.upload{border:1.5px dashed var(--line);border-radius:12px;padding:22px;text-align:center;color:var(--muted);cursor:pointer;font-size:13px;transition:border-color .25s,background .25s}
.upload:hover{border-color:var(--purple);background:rgba(191,0,255,.05)}
.qtyrow{display:flex;align-items:center;gap:14px}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:10px}
.qty button{width:38px;height:42px;background:transparent;border:none;color:var(--text);font-size:18px;cursor:pointer}
.qty span{min-width:34px;text-align:center;font-family:'Space Mono'}
.note{font-size:12px;color:var(--faint);margin-top:6px}

/* steps grid (process / how) */
.steps4{display:grid;grid-template-columns:repeat(4,1fr);margin-top:40px;border-top:1px solid var(--line2)}
.steps4 .st{padding:28px 22px 28px 0;border-right:1px solid var(--line2)}
.steps4 .st:last-child{border-right:none;padding-right:0}
.steps4 .n{font-family:'Syne';font-weight:800;font-size:38px;color:transparent;-webkit-text-stroke:1.4px var(--purple);margin-bottom:12px}
.steps4 .st h4{font-size:17px;font-weight:600;margin-bottom:6px}
.steps4 .st p{color:var(--muted);font-size:14px}

/* multi-step custom form */
.wizard{max-width:780px;margin:34px auto 0;border:1px solid var(--line);border-radius:20px;background:var(--panel);padding:clamp(24px,4vw,40px)}
.progress{display:flex;gap:8px;margin-bottom:28px}
.progress .p{flex:1;height:4px;border-radius:2px;background:var(--line2)}
.progress .p.on{background:var(--purple)}
.stepwrap .step{display:none}
.stepwrap .step.active{display:block;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1}}
.step h3{font-size:22px;font-weight:700;margin-bottom:18px}
.field{margin-bottom:18px}
.field label{display:block;font-family:'Space Mono';font-size:11px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;color:var(--muted)}
.field input,.field select,.field textarea{width:100%;background:transparent;border:1px solid var(--line);border-radius:11px;padding:14px 16px;color:var(--text);font-family:'Inter';font-size:15px;outline:none;transition:border-color .25s}
.field input::placeholder,.field textarea::placeholder{color:var(--faint)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--purple)}
.field select{appearance:none}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.wizard .nav2{display:flex;justify-content:space-between;gap:12px;margin-top:24px}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{border:1px solid var(--line);border-radius:999px;padding:10px 18px;cursor:pointer;font-size:14px;transition:border-color .25s,background .25s}
.chip.sel{border-color:var(--purple);background:rgba(191,0,255,.1);color:var(--purple)}
.okpanel{text-align:center;padding:20px}
.okpanel .ring{width:64px;height:64px;border-radius:50%;background:rgba(16,185,129,.15);color:var(--live);display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 16px}

/* cart */
.cartline{display:grid;grid-template-columns:84px 1fr auto;gap:16px;align-items:center;padding:18px 0;border-bottom:1px solid var(--line2)}
.cartline .thumb{width:84px;height:64px;border-radius:10px;object-fit:cover;border:1px solid var(--line)}
.cartline .cn{font-family:'Syne';font-weight:600}
.cartline .cv{color:var(--muted);font-size:13px}
.cartline .cp{font-family:'Space Mono';color:var(--purple)}
.cartline .rm{background:none;border:none;color:var(--faint);cursor:pointer;font-size:13px;text-decoration:underline}
.carttotal{display:flex;justify-content:space-between;align-items:center;padding:22px 0;font-family:'Syne';font-weight:700;font-size:22px}
.empty{text-align:center;padding:60px 0;color:var(--muted)}

/* tiers (faq/rights) */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.tier{border:1px solid var(--line);border-radius:16px;padding:30px 26px;background:var(--panel);transition:transform .4s}
.tier:hover{transform:translateY(-6px)}
.tier.feat{border-color:rgba(191,0,255,.6);box-shadow:0 30px 70px -34px rgba(191,0,255,.6)}
.tier .tg{font-family:'Space Mono';font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--purple);margin-bottom:14px}
.tier h4{font-size:21px;font-weight:700;margin-bottom:6px}
.tier .fee{font-family:'Space Mono';color:var(--muted);font-size:13px;margin-bottom:18px}
.tier ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.tier li{color:var(--muted);font-size:14px;padding-left:20px;position:relative}
.tier li::before{content:'';position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:var(--purple)}
.acc{border-top:1px solid var(--line2);margin-top:30px}
.acc details{border-bottom:1px solid var(--line2)}
.acc summary{padding:20px 0;cursor:pointer;font-family:'Syne';font-weight:600;font-size:17px;list-style:none;display:flex;justify-content:space-between}
.acc summary::-webkit-details-marker{display:none}
.acc summary::after{content:'+';color:var(--purple)}
.acc details[open] summary::after{content:'−'}
.acc p{color:var(--muted);padding:0 0 20px;max-width:48rem}

/* gallery masonry (intrinsic ratio · never skews) */
.gal{columns:3;column-gap:16px;margin-top:34px}
.gal figure{break-inside:avoid;margin-bottom:16px;border-radius:14px;overflow:hidden;border:1px solid var(--line);position:relative}
.gal img{width:100%;height:auto;transition:transform .6s}
.gal figure:hover img{transform:scale(1.05)}
.gal figcaption{position:absolute;left:0;right:0;bottom:0;padding:16px;font-family:'Space Mono';font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.78));opacity:0;transition:opacity .4s}
.gal figure:hover figcaption{opacity:1}

/* vision */
.vision{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(28px,5vw,60px);align-items:center;margin-top:30px}
.vision .big{font-family:'Syne';font-weight:600;font-size:clamp(23px,3vw,36px);line-height:1.3}
.vision .big em{font-style:normal;color:var(--purple)}
.vision .who p{color:var(--muted);margin-bottom:14px}
.vision .who{border-left:1px solid var(--line);padding-left:28px}

/* footer */
footer{border-top:1px solid var(--line2);padding:64px 0 40px;position:relative;z-index:3;margin-top:48px}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:44px}
.fbrand .mark{margin-bottom:16px}
footer .fp{color:var(--muted);font-size:15px;max-width:26rem;margin-top:6px}
footer .fmail{font-family:'Space Mono',monospace;color:var(--purple);font-size:13px;margin-top:12px}
footer h5{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:14px}
footer .col a{display:block;color:var(--muted);font-size:14px;margin-bottom:11px;transition:color .25s}
footer .col a:hover{color:var(--purple)}
.copy{border-top:1px solid var(--line2);padding-top:24px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--faint);font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase}

/* reveal · only hides when JS present */
.js .rv{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.js .rv.in{opacity:1;transform:none}

/* legal prose */
.legal{max-width:46rem}
.legal h3{font-family:'Syne',sans-serif;font-size:20px;font-weight:600;margin:30px 0 10px}
.legal p,.legal li{color:var(--muted);margin-bottom:12px}
.legal ul{margin:0 0 16px 20px}
.legal a{color:var(--purple)}

/* responsive */
@media(max-width:920px){
  .navlinks{display:none}.burger{display:flex}#headcta{display:none}
  .pd{grid-template-columns:1fr;gap:24px}
  .steps4{grid-template-columns:1fr 1fr}.steps4 .st{border-right:none;border-bottom:1px solid var(--line2);padding:22px 0}
  .tiers{grid-template-columns:1fr}
  .gal{columns:2}
  .vision{grid-template-columns:1fr}.vision .who{border-left:none;padding-left:0;border-top:1px solid var(--line);padding-top:20px}
  .frow{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr;gap:30px 24px}.fbrand{grid-column:1/-1}
}
@media(max-width:460px){
  .gal{columns:1}.pgrid{grid-template-columns:1fr}
  .mark span{display:none}.logo-img{height:34px}
  .fgrid{grid-template-columns:1fr;gap:26px}
}
