/* ===========================================================
   PENANCE — shared styles
   Edit brand colors in :root. Everything else inherits from here.
   =========================================================== */
:root{
  --ink:#15110d;     /* warm washed near-black — background */
  --coal:#1e1813;    /* raised surfaces / cards */
  --ash:#39322a;     /* borders, dividers */
  --bone:#dcd3c4;    /* aged off-white — primary text */
  --smoke:#8f857a;   /* muted taupe — secondary text */
  --oxblood:#8a2018; /* the single accent */
  --rust:#a8794a;    /* vintage tan, used sparingly */
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink);color:var(--bone);
  font-family:"Archivo",system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative;min-height:100vh;
  display:flex;flex-direction:column;
}
body::before{
  content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.06;
  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='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
body::after{
  content:"";position:fixed;inset:0;z-index:9997;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 0%, transparent 55%, rgba(0,0,0,.55) 100%);
}
main{flex:1 0 auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--oxblood);color:var(--bone)}
:focus-visible{outline:2px solid var(--rust);outline-offset:3px}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}
.mono{font-family:"Courier Prime",monospace}
.display{font-family:"Pirata One",serif;font-weight:400}

/* ---------- ticker ---------- */
.topbar{
  background:var(--oxblood);color:var(--bone);overflow:hidden;white-space:nowrap;
  border-bottom:1px solid #000;position:relative;z-index:10;
  font-family:"Courier Prime",monospace;font-size:12px;letter-spacing:2px;text-transform:uppercase;
}
.ticker{display:inline-block;padding:7px 0;will-change:transform}
.ticker span{padding:0 26px}
@media (prefers-reduced-motion: no-preference){.ticker{animation:scroll 34s linear infinite}}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- nav ---------- */
nav{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;background:rgba(21,17,13,.86);backdrop-filter:blur(7px);
  border-bottom:1px solid var(--ash);
}
.brand{font-family:"Pirata One",serif;font-size:34px;letter-spacing:1px;line-height:1}
.navlinks{display:flex;gap:30px;align-items:center;
  font-family:"Courier Prime",monospace;font-size:12px;letter-spacing:2px;text-transform:uppercase}
.navlinks a{color:var(--smoke);transition:color .15s}
.navlinks a:hover,.navlinks a.active{color:var(--bone)}
.navlinks a.acc{color:var(--rust)}
.navtoggle{display:none;background:none;border:1px solid var(--ash);color:var(--bone);
  font-family:"Courier Prime",monospace;font-size:12px;letter-spacing:1px;text-transform:uppercase;
  padding:9px 13px;cursor:pointer}
@media(max-width:760px){
  .navtoggle{display:block}
  .navlinks{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:var(--coal);border-bottom:1px solid var(--ash);
    max-height:0;overflow:hidden;transition:max-height .25s ease}
  .navlinks a{padding:16px 24px;border-top:1px solid var(--ash);width:100%;font-size:13px}
  body.nav-open .navlinks{max-height:360px}
}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--bone);color:var(--ink);
  font-weight:700;text-transform:uppercase;letter-spacing:1.5px;font-size:13px;padding:15px 30px;
  border:none;cursor:pointer;transition:transform .14s,box-shadow .14s,background .15s}
.btn:hover{background:var(--oxblood);color:var(--bone);transform:translateY(-2px);box-shadow:0 8px 0 #000}
.btn.ghost{background:transparent;color:var(--bone);border:1px solid var(--ash)}
.btn.ghost:hover{background:transparent;border-color:var(--rust);box-shadow:none;transform:translateY(-2px)}

/* ---------- hero ---------- */
.hero{max-width:var(--maxw);margin:0 auto;padding:78px 24px 64px;
  display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
@media(max-width:860px){.hero{grid-template-columns:1fr;gap:38px;padding-top:54px}}
.eyebrow{font-family:"Courier Prime",monospace;font-size:12px;letter-spacing:3px;
  color:var(--rust);text-transform:uppercase;margin-bottom:24px}
.hero h1{font-family:"Pirata One",serif;line-height:.92;
  font-size:clamp(60px,10vw,128px);letter-spacing:0;text-transform:uppercase}
.hero h1 em{font-style:normal;color:var(--oxblood)}
.hero p.sub{margin-top:26px;max-width:430px;color:var(--smoke);font-size:15px;line-height:1.7}
.hero p.sub b{color:var(--bone);font-weight:600}
.cta{display:inline-flex;align-items:center;gap:10px;margin-top:32px;background:var(--bone);color:var(--ink);
  font-weight:700;text-transform:uppercase;letter-spacing:1.5px;font-size:13px;padding:15px 30px;border:none;
  cursor:pointer;transition:transform .14s,box-shadow .14s,background .15s}
.cta:hover{background:var(--oxblood);color:var(--bone);transform:translateY(-2px);box-shadow:0 8px 0 #000}

.figure{position:relative;border:1px solid var(--ash);background:var(--coal);padding:12px}
.figure .frame{aspect-ratio:4/5;overflow:hidden;background:var(--ink)}
.figure img{width:100%;height:100%;object-fit:cover;object-position:center;
  filter:grayscale(30%) sepia(14%) contrast(.96) brightness(.92);transition:filter .5s,transform .7s}
.figure:hover img{filter:none;transform:scale(1.03)}
.figure .cap{display:flex;justify-content:space-between;font-family:"Courier Prime",monospace;
  font-size:11px;letter-spacing:1.5px;color:var(--smoke);text-transform:uppercase;margin-top:10px}

/* ---------- section heads ---------- */
.sect{max-width:var(--maxw);margin:0 auto;padding:34px 24px}
.shead{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;
  border-bottom:1px solid var(--ash);padding-bottom:18px;margin-bottom:44px}
.shead h2{font-family:"Pirata One",serif;text-transform:uppercase;font-size:clamp(34px,5vw,56px);line-height:1}
.shead .meta{font-family:"Courier Prime",monospace;font-size:12px;color:var(--smoke);
  text-align:right;line-height:1.7;text-transform:uppercase}
.shead .meta b{color:var(--rust)}

/* ---------- product grid + card ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:920px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid{grid-template-columns:1fr}}
.card{background:var(--coal);border:1px solid var(--ash);display:flex;flex-direction:column;
  position:relative;transition:transform .16s,border-color .16s}
.card:hover{transform:translateY(-4px);border-color:var(--rust)}
.card.sold{opacity:.62}
.thumb{aspect-ratio:4/5;overflow:hidden;position:relative;background:var(--ink);
  border-bottom:1px solid var(--ash);display:flex;align-items:center;justify-content:center}
.thumb img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;
  filter:grayscale(32%) sepia(14%) contrast(.95) brightness(.9);transition:filter .5s,transform .7s}
.card:hover .thumb img{filter:none;transform:scale(1.05)}
.thumb.noimg img{display:none}
.thumb.noimg::after{content:attr(data-label);font-family:"Pirata One",serif;
  font-size:22px;color:var(--ash);text-align:center;padding:20px;letter-spacing:1px}
.tag{position:absolute;top:11px;left:11px;z-index:2;font-family:"Courier Prime",monospace;
  font-size:10px;letter-spacing:1.5px;text-transform:uppercase;padding:4px 9px;
  background:var(--ink);border:1px solid var(--rust);color:var(--rust)}
.tag.hot{border-color:var(--oxblood);color:#d98a7e;background:#2a0f0b}
.tag.dead{border-color:var(--smoke);color:var(--smoke)}
.cbody{padding:17px 17px 19px;display:flex;flex-direction:column;gap:7px;flex:1}
.cname{font-family:"Pirata One",serif;font-size:24px;line-height:1.05;text-transform:uppercase;letter-spacing:.4px}
.cdesc{font-size:12.5px;color:var(--smoke);line-height:1.55;flex:1}
.crow{display:flex;align-items:center;justify-content:space-between;margin-top:9px}
.price{font-family:"Courier Prime",monospace;font-weight:700;font-size:16px;color:var(--bone)}
.sku{font-family:"Courier Prime",monospace;font-size:10px;color:var(--ash);letter-spacing:1.5px}
.buy{margin-top:13px;width:100%;text-align:center;border:none;cursor:pointer;
  font-family:"Courier Prime",monospace;font-weight:700;font-size:12px;letter-spacing:2px;
  text-transform:uppercase;padding:14px;display:flex;align-items:center;justify-content:center;gap:8px;
  transition:transform .1s,box-shadow .1s,background .15s,color .15s}
.buy.live{background:var(--oxblood);color:var(--bone)}
.buy.live:hover{transform:translateY(-2px);box-shadow:0 5px 0 #000;background:#9c2519}
.buy.pending{background:transparent;color:var(--smoke);border:1px solid var(--ash);cursor:not-allowed}
.buy.pending::before{content:"⌁ "}
.buy.gone{background:transparent;color:var(--smoke);border:1px solid var(--smoke);cursor:not-allowed}

/* ---------- category tiles (home) ---------- */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:760px){.tiles{grid-template-columns:1fr}}
.tile{position:relative;aspect-ratio:3/2;overflow:hidden;border:1px solid var(--ash);background:var(--coal);
  display:flex;align-items:flex-end;padding:20px}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(45%) sepia(18%) brightness(.55);transition:filter .5s,transform .7s;z-index:0}
.tile:hover img{filter:grayscale(10%) brightness(.7);transform:scale(1.05)}
.tile span{position:relative;z-index:1;font-family:"Pirata One",serif;font-size:30px;
  text-transform:uppercase;letter-spacing:1px}
.tile small{position:relative;z-index:1;font-family:"Courier Prime",monospace;font-size:11px;
  color:var(--rust);letter-spacing:2px;text-transform:uppercase;margin-left:auto}

/* ---------- brand ethos band ---------- */
.band{border-top:1px solid var(--ash);border-bottom:1px solid var(--ash);margin-top:80px}
.band .wrap{padding-top:64px;padding-bottom:64px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:760px){.band .wrap{grid-template-columns:1fr;gap:24px}}
.band h3{font-family:"Pirata One",serif;font-size:clamp(30px,4vw,46px);text-transform:uppercase;line-height:1.05}
.band p{color:var(--smoke);font-size:15px;line-height:1.8}
.band p+p{margin-top:14px}

/* ---------- shop filter ---------- */
.filterbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px}
.filterbar button{background:transparent;border:1px solid var(--ash);color:var(--smoke);
  font-family:"Courier Prime",monospace;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;
  padding:9px 16px;cursor:pointer;transition:color .15s,border-color .15s,background .15s}
.filterbar button:hover{color:var(--bone)}
.filterbar button.on{background:var(--bone);color:var(--ink);border-color:var(--bone)}

/* ---------- product detail (PDP) ---------- */
.pdp{max-width:var(--maxw);margin:0 auto;padding:40px 24px 90px;
  display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
@media(max-width:860px){.pdp{grid-template-columns:1fr;gap:32px}}
.pdp .gallery{border:1px solid var(--ash);background:var(--coal);padding:12px;position:sticky;top:90px}
@media(max-width:860px){.pdp .gallery{position:static}}
.pdp .gallery .frame{aspect-ratio:4/5;overflow:hidden;background:var(--ink)}
.pdp .gallery img{width:100%;height:100%;object-fit:cover;
  filter:grayscale(20%) sepia(10%) contrast(.97) brightness(.95)}
#pdp-main{transition:opacity .4s ease}
.gallery .thumbs{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.gthumb{width:62px;height:78px;border:1px solid var(--ash);background:var(--ink);padding:0;
  cursor:pointer;overflow:hidden;transition:border-color .15s}
.gthumb:hover{border-color:var(--smoke)}
.gthumb.on{border-color:var(--rust)}
.gthumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%) sepia(10%) brightness(.95)}
.crumbs{font-family:"Courier Prime",monospace;font-size:11px;letter-spacing:1.5px;
  color:var(--smoke);text-transform:uppercase;margin-bottom:18px}
.crumbs a:hover{color:var(--bone)}
.pdp h1{font-family:"Pirata One",serif;font-size:clamp(40px,6vw,64px);line-height:.98;
  text-transform:uppercase;margin-bottom:14px}
.pdp .pprice{font-family:"Courier Prime",monospace;font-weight:700;font-size:22px;margin-bottom:22px}
.pdp .pdesc{color:var(--smoke);font-size:15px;line-height:1.8;margin-bottom:26px;max-width:46ch}
.lbl{font-family:"Courier Prime",monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--rust);margin-bottom:11px}
.sizes{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:26px}
.sizes button{min-width:50px;background:transparent;border:1px solid var(--ash);color:var(--bone);
  font-family:"Courier Prime",monospace;font-size:13px;padding:11px 8px;cursor:pointer;
  transition:border-color .15s,background .15s,color .15s}
.sizes button:hover{border-color:var(--rust)}
.sizes button.on{background:var(--bone);color:var(--ink);border-color:var(--bone)}
.pdp .buy{max-width:320px}
.specs{margin-top:34px;border-top:1px solid var(--ash);padding-top:22px}
.specs div{display:flex;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--ash);
  font-size:13px}
.specs div span:first-child{color:var(--smoke);font-family:"Courier Prime",monospace;
  font-size:11px;letter-spacing:1px;text-transform:uppercase}
.note{font-family:"Courier Prime",monospace;font-size:11px;color:var(--smoke);
  letter-spacing:.5px;margin-top:14px;line-height:1.6}

/* ---------- info / prose pages ---------- */
.page{max-width:780px;margin:0 auto;padding:64px 24px 90px}
.page .kicker{font-family:"Courier Prime",monospace;font-size:12px;letter-spacing:3px;
  color:var(--rust);text-transform:uppercase;margin-bottom:18px}
.page h1{font-family:"Pirata One",serif;font-size:clamp(46px,8vw,84px);text-transform:uppercase;
  line-height:.95;margin-bottom:30px}
.page h2{font-family:"Pirata One",serif;font-size:30px;text-transform:uppercase;
  margin:42px 0 14px;letter-spacing:.5px}
.page p{color:var(--smoke);font-size:15.5px;line-height:1.85;margin-bottom:16px}
.page p b{color:var(--bone);font-weight:600}
.page ul{color:var(--smoke);font-size:15.5px;line-height:1.85;margin:0 0 16px 20px}
.page li{margin-bottom:8px}
.page a.inline{color:var(--rust);text-decoration:underline;text-underline-offset:3px}

/* FAQ accordion */
.faq details{border-bottom:1px solid var(--ash);padding:6px 0}
.faq summary{cursor:pointer;list-style:none;padding:18px 0;font-family:"Pirata One",serif;
  font-size:22px;text-transform:uppercase;letter-spacing:.5px;display:flex;justify-content:space-between;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--rust);font-family:"Courier Prime",monospace}
.faq details[open] summary::after{content:"–"}
.faq details p{padding:0 0 18px}

/* size table */
.sztable{width:100%;border-collapse:collapse;margin:8px 0 22px;font-size:13px}
.sztable th,.sztable td{border:1px solid var(--ash);padding:10px 12px;text-align:center}
.sztable th{font-family:"Courier Prime",monospace;font-size:11px;letter-spacing:1px;
  text-transform:uppercase;color:var(--rust);background:var(--coal)}
.sztable td{color:var(--bone)}

/* ---------- forms ---------- */
.formwrap{max-width:560px}
.field{margin-bottom:18px}
.field label{display:block;font-family:"Courier Prime",monospace;font-size:11px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--rust);margin-bottom:8px}
.field input,.field textarea,.field select{width:100%;background:var(--coal);border:1px solid var(--ash);
  color:var(--bone);font-family:"Archivo",sans-serif;font-size:15px;padding:13px 14px;transition:border-color .15s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--rust)}
.field textarea{min-height:140px;resize:vertical}
.hp{position:absolute;left:-9999px}
.newsletter{display:flex;gap:10px;max-width:440px;flex-wrap:wrap}
.newsletter input{flex:1;min-width:200px;background:var(--coal);border:1px solid var(--ash);color:var(--bone);
  font-family:"Archivo",sans-serif;font-size:15px;padding:14px 15px}
.newsletter input:focus{outline:none;border-color:var(--rust)}

/* ---------- 404 ---------- */
.lost{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:100px 24px}
.lost h1{font-family:"Pirata One",serif;font-size:clamp(90px,22vw,220px);line-height:.9;color:var(--oxblood)}
.lost p{font-family:"Courier Prime",monospace;letter-spacing:1px;color:var(--smoke);
  text-transform:uppercase;margin:14px 0 30px}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--ash);padding:56px 24px;flex-shrink:0}
.fwrap{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;gap:34px;flex-wrap:wrap}
.fbrand{font-family:"Pirata One",serif;font-size:52px;line-height:1}
.ftag{font-family:"Courier Prime",monospace;font-size:13px;color:var(--rust);
  letter-spacing:2px;text-transform:uppercase;margin-top:8px}
.fcols{display:flex;gap:58px;flex-wrap:wrap}
.fcol h4{font-family:"Courier Prime",monospace;font-size:11px;letter-spacing:2px;
  color:var(--rust);text-transform:uppercase;margin-bottom:15px}
.fcol a{display:block;color:var(--smoke);font-size:13px;margin-bottom:10px;transition:color .15s}
.fcol a:hover{color:var(--bone)}
.legal{max-width:var(--maxw);margin:48px auto 0;font-family:"Courier Prime",monospace;
  font-size:11px;color:var(--ash);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  letter-spacing:1px;text-transform:uppercase}
