:root{--bg:#0a0a0a;--panel:#121212;--muted:#9aa0a6;--text:#f5f5f5;--accent:#ffd400;--accent-ink:#111}
*{box-sizing:border-box}html,body{margin:0;background:var(--bg);color:var(--text);font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 20px}

/* Header */
.site-header{position:sticky;top:0;z-index:5;background:#0c0c0c;border-bottom:1px solid #111}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}
.logo{font-weight:800;text-decoration:none;color:var(--text)}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1rem;border-radius:10px;border:1px solid #2a2a2a;background:#1a1a1a;color:var(--text);text-decoration:none;cursor:pointer}
.btn-accent{background:var(--accent);color:var(--accent-ink);border-color:#eac500}
.btn-small{padding:.45rem .7rem;font-size:.9rem}
.btn-outline{background:transparent;border-color:#3a3a3a}

/* Hero */
.hero{padding:28px 0 12px}
.hero-grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:center;justify-items:center}
.hero-img{max-height:420px;object-fit:contain;border-radius:14px;border:1px solid #111;background:#000}
.hero-copy{text-align:center}
.hero-copy h1{font-size:clamp(1.8rem,3.5vw,3rem);margin:.25rem 0 .5rem}
.hero-copy h1 span{color:var(--accent)}
.hero-copy p{color:var(--muted);margin:0 0 .75rem}

/* Shop carousel */
.shop{padding:32px 0}
.shop h2{text-align:center;margin:0 0 12px}
.carousel{position:relative;overflow:hidden}
.track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:clamp(220px,24vw,280px);
  gap:1rem;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding:.5rem .75rem 1rem;
  -webkit-overflow-scrolling:touch;
  scroll-behavior:smooth;
  align-items:start;            /* align cards to the top */
}
.track::-webkit-scrollbar{height:8px}.track::-webkit-scrollbar-thumb{background:#2b2b2b;border-radius:4px}
.card{
  background:var(--panel);
  border:1px solid #1c1c1c;
  border-radius:16px;
  padding:.75rem;
  scroll-snap-align:center;
  display:flex;                 /* stack content */
  flex-direction:column;
}
.card h3{
  min-height:2.2em;             /* reserve space for two-line titles */
  line-height:1.1;
  margin:.6rem 0 .25rem;
}
.card h3 a{color:var(--text);text-decoration:none}
.card .meta{
  display:flex;align-items:center;justify-content:space-between;color:var(--muted);
  margin-top:auto;              /* pin to bottom */
}
.img-btn{border:0;background:none;padding:0;cursor:zoom-in;border-radius:12px;overflow:hidden}
.img-btn img{
  width:100%;
  height:240px;                 /* uniform thumb height */
  object-fit:cover;             /* normalize portrait/square */
  background:#000;
  border-radius:12px;
  border:1px solid #111;
}
.nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;background:#111;border:1px solid #222;color:#ddd;border-radius:999px;width:38px;height:38px;display:grid;place-items:center;cursor:pointer}
.nav:hover{background:#161616}.nav.prev{left:6px}.nav.next{right:6px}
.dots{display:flex;gap:.4rem;justify-content:center;margin-top:.25rem}
.dots button{width:9px;height:9px;border-radius:50%;border:0;background:#2f2f2f}
.dots button[aria-current=true]{background:var(--accent)}

/* Sayings & About */
.sayings{padding:32px 0;text-align:center}.about{padding:24px 0;text-align:center;color:var(--muted)}
blockquote{max-width:900px;margin:0 auto 1rem;padding:1rem 1.2rem;border-radius:12px;background:#111;border:1px solid #1e1e1e;color:#e9e9e9}

/* Modal */
.modal{position:fixed;inset:0;display:none}.modal.show{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.75)}
.modal-content{position:relative;z-index:2;max-width:min(92vw,1000px);margin:4vh auto;background:#0d0d0d;border:1px solid #222;border-radius:16px;padding:14px}
.modal-content img{width:100%;height:auto;background:#000;border-radius:12px}
.modal-close{position:absolute;top:6px;right:10px;border:0;background:#111;color:#eee;border-radius:10px;padding:.25rem .5rem;cursor:pointer}
.modal-actions{display:flex;justify-content:flex-end;margin-top:.5rem}

/* Desktop two-column hero */
@media (min-width: 980px){
  .hero-grid{grid-template-columns:1fr 1fr;justify-items:start}
  .hero-img{justify-self:start}
  .hero-copy{text-align:left}
}

/* Mobile tuning */
@media (max-width: 520px){
  .track{grid-auto-columns:80vw;padding:0 1rem 1rem}
  .img-btn img{height:190px}
}
