:root{
  --green-950:#000905;
  --green-900:#071D0E;
  --green-800:#004927;
  --green-700:#025D30;

  --olive-500:#809c13;
  --olive-800:#333300;
  --olive-600:#565620;

  --sand-200:#d9c096;
  --brown-700:#3d302d;
  --moss-700:#4c5a2d;
  --teal-700:#2d4440;
  --slate-800:#2d3037;

  --bg:var(--green-950);
  --text:#fafafa;
  --muted:rgba(255,255,255,.65);
  --card: #1a1d1a;         /* darker neutral */
  --accent:var(--olive-500);

  --glow-outer: 0 3px 8px rgba(0,0,0,.2);
  --glow-ring:  0 0 12px var(--accent);
  --glow-spread:0 0 24px rgba(128,156,19,.6); /* accent-ish */
}

/* ========== Base ========== */
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.container{width:min(1100px,92vw);margin-inline:auto}
.section{padding:64px 0}

h1,h2,h3,.nav a{font-family:var(--heading-font);text-transform:uppercase;letter-spacing:.02em}
body{font-family:var(--body-font)}

.card{background:var(--slate-800);border:1px solid rgba(255,255,255,.08);border-radius:18px}

.btn{
  display:inline-block;border-radius:999px;padding:.7rem 1.1rem;font-weight:800;
  background:linear-gradient(135deg,var(--olive-500),var(--moss-700));
  color:#0c0c0c;border:1px solid rgba(255,255,255,.1);transition:.2s;
}
.btn:hover{transform:translateY(-1px);
  background:linear-gradient(135deg,var(--olive-800),var(--green-700));}

/* ======= Search & Cart ======= */ 
.icon-btn{ background:transparent;border:1px solid rgba(255,255,255,.25);
  color:#fff;border-radius:999px;padding:.35rem .6rem;cursor:pointer }
.icon-btn:hover{ filter:brightness(1.1) }
.cart-badge{ font-weight:900; margin-left:.2rem }

/* Drawer */
.drawer{ position:fixed; top:0; right:-420px; width:min(420px,92vw); height:100%;
  background:#0c0c0c; border-left:1px solid rgba(255,255,255,.1);
  display:flex; flex-direction:column; transition:right .25s ease; z-index:9999 }
.drawer.open{ right:0 }
.backdrop{ position:fixed; inset:0; background:rgba(0,0,0,.5); display:none; z-index:9998 }
.backdrop.show{ display:block }
.drawer-head{ display:flex; justify-content:space-between; align-items:center;
  padding:14px 16px; border-bottom:1px solid rgba(255,255,255,.1) }
.drawer-list { display: grid; gap: 8px; }
.drawer-item  { display:grid; grid-template-columns:56px 1fr auto; gap:10px; align-items:center; padding:8px 0; border-bottom:1px solid rgba(255,255,255,.08); }
.drawer-item:last-child { border-bottom:none; }
.drawer-item img { width:56px; height:56px; object-fit:contain; background:linear-gradient(#2b341d,#374824); border-radius:8px; padding:6px; }
.drawer-item .title{ font-weight:700 }
.drawer-item .meta{ font-size:.9rem;opacity:.8 }
.drawer-item .qty{ width:68px;padding:.35rem .5rem;border-radius:8px;border:1px solid rgba(255,255,255,.18);background:#0f0f0f;color:#fff }
.drawer-foot{ border-top:1px solid rgba(255,255,255,.1); padding:12px 16px; display:grid; gap:10px }
.drawer-foot .row{ display:flex; justify-content:space-between }
.drawer-checkout{ text-align:center; padding:.7rem 1rem; border-radius:10px; font-weight:900; background:#fff; color:#000; text-decoration:none }

/* Search dialog */
.searchdlg{
  width:min(760px,92vw);
  border:none; border-radius:14px; padding:0;
  background:#0f0f0f;   /* NEW */
  color:#fff;           /* NEW */
}
.searchbox{ display:flex; gap:8px; padding:12px; border-bottom:1px solid rgba(255,255,255,.12); background:#101010 }
.searchbox input{ flex:1; padding:.75rem .85rem; border-radius:10px; border:1px solid rgba(255,255,255,.18); background:#0f0f0f; color:#fff }
.search-results{ padding:12px; max-height:60vh; overflow:auto; display:grid; gap:10px }
.search-results a{
  display:flex; align-items:center; gap:12px;
  color:#fff;                           /* NEW (was white-on-white before) */
  background:#121212;                   /* NEW */
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px; padding:10px 12px;
}
.search-results a:hover{ background:#181818 }
.search-results img{
  width:40px;height:40px; object-fit:contain;
  background:linear-gradient(#2b341d,#374824); border-radius:6px; padding:4px
}
/* ========== Topbar ========== */
.topbar{
  background:#e3dabe;color:#0b0b0b;border-bottom:1px solid rgba(0,0,0,.08);
  position:sticky;top:0;z-index:50;backdrop-filter:blur(6px);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.nav .brand{display:flex;gap:.7rem;align-items:center}
.nav .brand img{width:42px;height:42px;filter:grayscale(1) contrast(1.1)}
.nav a{padding:.3rem .5rem;opacity:.9}
.nav a:hover{opacity:1;color:var(--accent)}
.topbar .brand span{font-weight:800;letter-spacing:.06em}
.topbar .menu a{
  font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  color:#0b0b0b;opacity:1;padding:.4rem .6rem;
}
.topbar .menu a:hover{color:#333}
.topbar .join{
  background:#0b0b0b;color:#fff;border-radius:999px;padding:.55rem 1rem;
  font-weight:800;text-transform:uppercase;letter-spacing:.04em;border:none;
}

/* ========== Hero ========== */
.hero-wide{position:relative}
.hero-wide img{width:100%;height:80vh;min-height:520px;object-fit:cover;display:block}

/* Social badges */
.social-badges{position:absolute;left:24px;top:90px;display:flex;gap:14px;align-items:center;z-index:2}
.badge{
  width:44px;height:44px;border-radius:50%;background:#fff;border:1px solid rgba(0,0,0,.12);
  background-repeat:no-repeat;background-position:center;background-size:110%;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.badge:hover{transform:translateY(-2px) scale(1.05);border-color:var(--olive-500);
  box-shadow:0 3px 8px rgba(0,0,0,.2),0 0 12px var(--olive-500),0 0 24px rgba(128,156,19,.6)}
.badge:active{transform:scale(.97)}
.badge.ig{background-image:url("../skellhouse-assets/icons/instagram.png")}
.badge.tt{background-image:url("../skellhouse-assets/icons/tiktok.png")}
.badge.yt{background-image:url("../skellhouse-assets/icons/youtube.png")}

/* ========== Section headings (centered) ========== */
.section-head{display:grid;place-items:center;margin-bottom:18px}
.section-head h2{
  font-family:var(--heading-font);text-transform:uppercase;letter-spacing:.04em;
  font-size:clamp(28px,3.4vw,56px);margin:0;text-align:center
}
.section-head.light h2{color:#0b0b0b}

/* ========== TOUR (beige card) ========== */
.tour-wrap{
  background:#1d271e;color:#0b0b0b;border-radius:16px;padding:14px;border:1px solid rgba(255, 255, 255, 0);
}
.tour-filters{display:flex;gap:8px;margin:0 0 14px}
.tour-table{border-top:none}
.tour-row{
  display:grid;grid-template-columns:180px 1fr 1fr 220px;gap:16px;align-items:center;
  padding:18px 12px;border-bottom:1px solid rgba(0,0,0,.08);background:rgba(0,0,0,.06);
}
.tour-row:nth-child(2n){background:rgba(0, 0, 0, 0.1)}
.tour-date{font-weight:800;color:#ffffff}
.tour-city{text-transform:uppercase;letter-spacing:.03em;font-weight:800;color:#618e6d}
.tour-venue{text-transform:uppercase;color:rgba(253, 253, 253, 0.7)}
.tour-actions{display:flex;gap:10px;justify-self:end}

/* Tour buttons */
.btn-outline{
  display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;line-height:1;
  border:none;border-radius:999px;padding:.55rem 1rem;font-weight:800;letter-spacing:.04em;
  background:var(--accent);color:#0b0b0b;
}
.btn-outline:hover{filter:brightness(.95)}
.ticket{
  display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;line-height:1;
  border:none;border-radius:999px;padding:.6rem 1rem;font-weight:800;letter-spacing:.04em;
  background:#0b0b0b;color:#fff;
}
.ticket:hover{filter:brightness(1.08)}

/* ========== MUSIC (one-at-a-time, square art) ========== */
.music-carousel{ width:min(90vw,700px); margin:0 auto; position:relative; }
.mc-stage{overflow:hidden;border-radius:16px;border:1px solid rgba(0, 0, 0, 0.08);background:var(--card);padding:0}
.mc-track{ display:flex; flex-wrap:nowrap; transition:transform .35s ease; }
.mc-card{  flex:0 0 100%; display:grid; place-items:center; gap:10px; padding:22px; }
.mc-art{width:min(75vw,420px);aspect-ratio:1/1;object-fit:cover;border-radius:14px;box-shadow:0 6px 20px rgba(0,0,0,.28)}
.mc-title{font-family:var(--heading-font);font-size:clamp(20px,2.4vw,34px);text-align:center;margin-top:6px}
.mc-meta-row{display:flex;justify-content:center;margin-top:4px}
.mc-link{display:inline-flex;align-items:center;gap:6px;text-decoration:underline}
.mc-meta-row .mc-link span{margin-left:2px}

/* Music arrows */
.mc-arrow{
  position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:999px;
  border:2px solid #fff;background:rgba(0,0,0,.25);color:#fff;font-weight:800;display:grid;place-items:center;cursor:pointer;
}
#mcPrev{left:-26px} #mcNext{right:-26px}

/* See-all button (green, centered under title/listen) */
.seeall{
  display:block;width:fit-content;margin:10px auto 0;background:var(--accent);color:#0b0b0b;
  padding:.6rem 1.05rem;border-radius:999px;font-weight:800;border:1px solid rgba(0,0,0,.12);
}
.seeall:hover{filter:brightness(.95);transform:translateY(-1px)}

/* ========== VIDEOS (one-at-a-time) ========== */
.video-carousel{ width:min(90vw,700px); margin:0 auto; position:relative; }
.vc-stage{overflow:hidden;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:var(--card);padding:0;position: relative;}
.vc-track{ display:flex; flex-wrap:nowrap; transition:transform .35s ease; }
.vc-card{  flex:0 0 100%; display:grid; place-items:center; gap:10px; padding:22px; }
.video{width:100%;max-width:720px;aspect-ratio:16/9;border:0;border-radius:12px}
.vc-title{font-family:var(--heading-font);font-size:clamp(20px,2.4vw,34px);text-align:center;margin-top:6px}

/* Video arrows */
.vc-arrow{
  position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:999px;
  border:2px solid #fff;background:rgba(0,0,0,.25);color:#fff;font-weight:800;display:grid;place-items:center;cursor:pointer;
  z-index: 5; pointer-events: auto;
}
#vcPrev{left:-26px} #vcNext{right:-26px}


/* ========== Newsletter ========== */
.signup{background:#f2f2f2;color:#0b0b0b}
.nl-form{display:grid;gap:12px;max-width:700px;margin:0 auto}
.nl-form label{display:block;font-weight:700;margin:12px 2px 6px}
.nl-form label.req::after{content:" *";color:#e53935}
.nl-form input[type="email"], .nl-form select{
  padding:.85rem 1rem;border-radius:10px;border:1px solid #d3d3d3;background:#fff;font-size:1rem;
}
.nl-check{display:flex;gap:10px;align-items:center;font-weight:600;margin-top:6px}
.nl-check input{width:18px;height:18px}

/* Button: black by default; turns green when .ready (JS toggles) */
#signup .btn.glow{
  background:#0b0b0b;color:#fff;box-shadow:none;
  transition:background .2s ease,color .2s ease,box-shadow .25s ease;
}
#signup .btn.glow.ready{
  background:var(--accent);color:#0b0b0b;
  box-shadow:0 0 18px rgba(128,156,19,.7),0 0 34px rgba(76,90,45,.35);
}

/* ========== Footer nicety ========== */
.booking{margin-bottom:14px}

/* smooth transitions for these UI bits */
.btn, .btn-outline, .ticket, .seeall,
.mc-arrow, .vc-arrow,
.topbar .menu a, .nav a {
  transition:
    color .2s ease,
    background .2s ease,
    border-color .25s ease,
    box-shadow .25s ease,
    transform .25s ease,
    filter .25s ease;
}

/* keyboard focus glow */
.btn:focus-visible, .btn-outline:focus-visible, .ticket:focus-visible, .seeall:focus-visible {
  outline: 0;
  box-shadow: var(--glow-outer), var(--glow-ring), var(--glow-spread);
  border-color: var(--accent);
  transform: translateY(-1px);
}

/* Tickets + Remind Me glow */
.btn-outline:hover,
.ticket:hover{
  filter: none; /* override earlier brightness() tweaks */
  box-shadow: var(--glow-outer), var(--glow-ring), var(--glow-spread);
  border-color: var(--accent);
  transform: translateY(-1px);
}

/* See all music glow */
.seeall:hover{
  filter: none; /* override earlier .seeall:hover */
  box-shadow: var(--glow-outer), var(--glow-ring), var(--glow-spread);
  border-color: var(--accent);
  transform: translateY(-1px);
}

/* Optional: also let the generic .btn get a glow on hover */
.btn:hover{
  box-shadow: var(--glow-outer), var(--glow-ring), var(--glow-spread);
  border-color: var(--accent);
}

/* ============================================================
   (3) CAROUSEL ARROWS: same glow + tiny scale on hover/focus
   ============================================================ */

.mc-arrow:hover, .vc-arrow:hover{
  box-shadow: var(--glow-outer), var(--glow-ring), var(--glow-spread);
  border-color: var(--accent);
  transform: translateY(-50%) scale(1.05); /* keep vertical centering */
}

.mc-arrow:focus-visible, .vc-arrow:focus-visible{
  outline: 0;
  box-shadow: var(--glow-outer), var(--glow-ring), var(--glow-spread);
  border-color: var(--accent);
  transform: translateY(-50%) scale(1.03);
}

/* ============================================================
   (4) TOP NAV LINKS: turn accent green on hover like brand
   Note: this overrides the earlier .topbar .menu a:hover {color:#333}
   because it appears later (same specificity).
   ============================================================ */

.topbar .menu a{ color:#0b0b0b; }
.topbar .menu a:hover{
  color: var(--accent);
  transform: translateY(-1px);
}

/* also give them a focus ring */
.topbar .menu a:focus-visible{
  outline: 0;
  box-shadow: var(--glow-outer), var(--glow-ring);
  border-radius: 6px; /* subtle */
}

/* ========== ABOUT section styles ========== */
.about-wrap{
  background: var(--card);                       /* same dark card color */
  border: 1px solid rgba(255,255,255,.08);       /* subtle border like .mc-stage/.vc-stage */
  border-radius: 16px;
  padding: 24px 28px;
  max-width: 900px;
  margin: 0 auto;
  box-shadow: 0 6px 20px rgba(0,0,0,.28);        /* soft shadow for depth */
}
.about-text{
  color: var(--muted);                           /* slightly lighter than pure white */
  font-size: clamp(16px,1.1vw,18px);
  line-height: 1.7;
  letter-spacing: .01em;
}
.about-text strong{
  color: var(--text);
  font-weight: 800;
}

/* ========== MERCH GRID ========== */
.merch-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px
}
.product-card{
  background: var(--moss-700);              /* shared olive/green backdrop */
  border: 1px solid rgba(0,0,0,.25);
  border-radius: 14px; padding: 14px;
  display:grid; gap:10px; place-items:center;
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.product-card:hover{
  transform: translateY(-2px);
  filter: brightness(1.02);
  box-shadow: 0 10px 30px rgba(0,0,0,.28);
}
.card-frame{
  width:100%; aspect-ratio: 1/1.05;        /* tall-ish like PTV */
  display:grid; place-items:center;
  background: linear-gradient(#2b341d,#374824);  /* subtle depth behind PNGs */
  border-radius: 10px; overflow:hidden;
  position: relative;
}
.card-frame img{
  width:min(90%, 420px); height:auto; display:block;
  transition: opacity .2s ease, transform .2s ease;
}
.card-frame img.back{ position:absolute; inset:0; margin:auto; opacity:0 }
.product-card:hover .card-frame img.front{ opacity:0 }
.product-card:hover .card-frame img.back{ opacity:1 }

/* name + price similar hierarchy */
.p-title{
  font-family: var(--heading-font);
  text-transform: uppercase; letter-spacing:.04em;
  font-size: clamp(15px,1.3vw,18px);
}
.p-price{ color: rgba(255,255,255,.85); font-weight:700 }

/* ========== PRODUCT PAGE ========== */
/* Layout: fixed-ish left column so it doesn’t drift */
.product-page{
  display:grid;
  grid-template-columns: minmax(340px, 560px) 1fr;  /* NEW: stable gallery width */
  gap: 28px;                                        /* slightly tighter than 34px */
  align-items:start;
}

/* Gallery card spacing tightened */
.p-hero{
  background: var(--moss-700);
  border: 1px solid rgba(0,0,0,.25);
  border-radius:14px;
  padding:14px;                                     /* NEW (down from 18px) */
  display:grid; grid-template-columns: 82px 1fr; gap:12px; /* NEW (gap down) */
  justify-self:start;                               /* NEW: keep on the left */
}

.p-thumbs{ display:grid; gap:8px }                  /* NEW (down from 10px) */
.p-thumbs button{
  background:#223016;border:1px solid rgba(0,0,0,.35);
  border-radius:10px;padding:4px; cursor:pointer    /* NEW (down from 6px) */
}

.p-main{ display:grid; place-items:center; background:linear-gradient(#2b341d,#374824); border-radius:12px }
.p-main img{
  width:min(92%,520px); height:auto;                /* NEW: hard cap so it doesn’t look oversized */
}

/* Size/qty spacing polish */
.size-row{ gap:8px; margin:.25rem 0 .9rem }         /* NEW, slightly tighter */
.qty-row{ gap:8px; margin:0 0 12px }                /* NEW */

/* Product page: make the Back row span both columns */
.product-page > div:first-child{
  grid-column: 1 / -1;
  margin-bottom: 8px;
}

/* (Optional) keep right panel tight at top */
.p-meta{ align-self: start; }

/* ---------- PRODUCT CONTROLS (size, qty, buttons) ---------- */

/* size chips */
.size-row{
  display:flex; flex-wrap:wrap; gap:8px;
  margin:.25rem 0 .9rem;
}
.size-pill{
  background:#0f0f0f;
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  padding:.45rem .7rem;
  font-weight:800;
  cursor:pointer;
  transition:box-shadow .2s ease, transform .15s ease, border-color .2s ease;
}
.size-pill:hover{ transform:translateY(-1px) }
.size-pill[aria-pressed="true"]{
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent) inset, 0 0 14px rgba(128,156,19,.55);
  color:#eaffd5;
}

/* qty */
.qty-row{
  display:flex; align-items:center; gap:8px;
  margin:0 0 12px;
}
.qty-row input{
  width:72px;
  padding:.5rem .6rem;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.18);
  background:#0f0f0f; color:#fff;
}

/* add / size-guide buttons */
.p-actions{ display:flex; gap:10px }
.p-actions .add{
  background: var(--accent);
  color:#0b0b0b;
  font-weight:900;
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px;
  padding:.7rem 1rem;
  cursor:pointer;
  transition: transform .15s ease, box-shadow .2s ease;
}
.p-actions .add:hover{
  transform:translateY(-1px);
  box-shadow: 0 0 14px rgba(128,156,19,.55);
}

.p-actions .guide{
  background:transparent;
  color:#fff;
  border:1px solid rgba(255,255,255,.28);
  border-radius:10px;
  padding:.7rem 1rem;
  font-weight:800;
  cursor:pointer;
  transition: transform .15s ease, border-color .2s ease;
}
.p-actions .guide:hover{
  transform:translateY(-1px);
  border-color:#fff;
}

/* keep title/price spacing tidy on the right */
.p-meta h1{ margin:0 0 8px }
.p-price-lg{ font-weight:900; margin:0 0 10px }


/* ========== DIALOG (Size Guide) ========== */
dialog.size-guide{
  width:min(720px,92vw); border:none; border-radius:14px; padding:0; overflow:hidden;
}
.size-wrap{background:#101010; color:#fff; padding:18px}
.size-head{display:flex; justify-content:space-between; align-items:center}
.size-body{display:grid; gap:10px; padding-top:10px}
.size-close{background:#fff;border:none;border-radius:10px;padding:.4rem .7rem;font-weight:800;cursor:pointer}
dialog::backdrop{ background: rgba(0,0,0,.6) }

/* ========== CHECKOUT ========== */
.checkout{
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 28px;
  margin-top: 8px;
}

/* Cards */
.order-card, .pay-card{
  background: var(--slate-800);            /* matches site theme */
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding: 16px;
}

/* Headings */
.order-card h2, .pay-card h2{
  font-family: var(--heading-font);
  letter-spacing: .03em;
  margin: 0 0 10px;
}

/* Order rows */
.order-row{
  display:grid;
  grid-template-columns: 72px 1fr auto;
  gap:12px;
  align-items:center;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.order-row:last-child{ border-bottom:none; }

/* Thumbnail tile */
.order-row img{
  width:64px; height:64px; object-fit:contain;
  background: linear-gradient(#2b341d,#374824);
  border-radius:8px; padding:6px;
}

/* Form fields in right panel */
.pay-card input, .pay-card select{
  width:100%;
  padding:.75rem .85rem;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.18);
  background:#0f0f0f; color:#fff;
  margin-bottom:10px;
}

.pay-btn{
  background:var(--accent); color:#0b0b0b;
  font-weight:900; border:none;
  border-radius:10px; padding:.8rem 1rem; width:100%;
}

/* Stack on mobile */
@media (max-width: 900px){
  .checkout{ grid-template-columns: 1fr; }
  .order-card, .pay-card{ padding:14px; }
}

/* Cart Count badge */
nav.menu a .cart-badge{
  font-weight: 800;
  opacity:.85;
}

.inline-check{
  display:flex; align-items:center; gap:8px;
  padding:.6rem .7rem; border:1px solid rgba(255,255,255,.18);
  border-radius:10px; background:#0f0f0f; color:#ddd; margin-bottom:12px;
}
.inline-check input{ width:18px; height:18px; }

