:root{
  --bg:#0b0c10;
  --panel:#12141b;
  --text:#e9e9ef;
  --muted:#a8a8b6;
  --line:rgba(255,255,255,.10);
  --accent:#7c5cff;
  --max:1080px;
  --radius:16px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}

body{
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,"Apple Color Emoji","Segoe UI Emoji";
  background:
    radial-gradient(1200px 800px at 15% 10%, rgba(124,92,255,.18), transparent 60%),
    radial-gradient(900px 700px at 85% 25%, rgba(255,255,255,.07), transparent 55%),
    var(--bg);
  color:var(--text);
  line-height:1.5;
  padding-top:68px;
}

a{color:inherit;text-decoration:none}
a:hover{opacity:.92}

.container{
  max-width:var(--max);
  margin:0 auto;
  padding:28px 18px;
}

/* Nav */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:9999;
  background:linear-gradient(
    to bottom,
    rgba(0,0,0,.72),
    rgba(0,0,0,.40),
    rgba(0,0,0,0)
  );
  backdrop-filter:blur(8px);
}

.navInner{
  max-width:var(--max);
  margin:0 auto;
  padding:14px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}

/* brand sits outside the capsule */
.brand{
  font-weight:750;
  letter-spacing:.3px;
  font-size:14px;
  color:rgba(255,255,255,.92);
  white-space:nowrap;
  flex:0 0 auto;
}

/* desktop tab capsule */
.navlinks{
  position:relative;
  display:flex;
  gap:10px;

  padding:4px;
  border-radius:999px;

  background:linear-gradient(
    180deg,
    rgba(255,255,255,.10),
    rgba(255,255,255,.04)
  );
  border:1px solid rgba(255,255,255,.16);

  overflow:hidden;
}

.navlinks a{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid transparent;
  color:rgba(255,255,255,.68);
  font-size:13px;
  line-height:1;
  transition:background .18s ease, color .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.navlinks a.active,
.navlinks a:hover{
  color:rgba(255,255,255,.95);
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.18);
  box-shadow: inset 0 -2px 0 rgba(255,255,255,.22);
}

/* optional scroll structure support */
.navlinks .navScroll{
  overflow-x:auto;
  overflow-y:hidden;
  white-space:nowrap;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  touch-action:pan-x;
}

.navlinks .navScroll::-webkit-scrollbar{display:none}

.navlinks .navRow{
  display:inline-flex;
  gap:10px;
  min-width:max-content;
}

/* scroll fades, monochrome */
.navlinks::before,
.navlinks::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:16px;
  pointer-events:none;
  z-index:2;
}

.navlinks::before{
  left:0;
  background:linear-gradient(to right, rgba(18,20,27,.95), rgba(18,20,27,0));
}

.navlinks::after{
  right:0;
  background:linear-gradient(to left, rgba(18,20,27,.95), rgba(18,20,27,0));
}

/* Hero */
.heroPoster{
  height:78vh;
  min-height:520px;
  background:url("../images/hero.jpg") center/cover no-repeat;
  position:relative;
}

.posterOverlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(rgba(0,0,0,.35), rgba(0,0,0,.35));
}

.posterTitle{
  font-size:clamp(48px,10vw,140px);
  letter-spacing:.08em;
  font-weight:700;
  color:#fff;
  text-shadow:0 12px 40px rgba(0,0,0,.55);
}

/* Page hero */
.hero{padding-top:32px}
.kicker{color:var(--muted);font-size:14px;letter-spacing:.12em;text-transform:uppercase}
.h1{font-size:clamp(32px,6vw,56px);font-weight:700;margin:8px 0 12px}
.lead{color:var(--muted);max-width:520px}

/* Plushie page hero overrides */
.plushiePage .heroPoster{
  min-height:40vh;
  background-image:url("../images/ozzieRen.png");
  background-size:cover;
  background-position:center;
  height:auto;
}

.plushiePage .posterOverlay{
  background:linear-gradient(rgba(0,0,0,.35), rgba(0,0,0,.65));
}

.plushiePage .posterTitle{
  font-size:clamp(36px,6vw,64px);
  letter-spacing:.04em;
}

/* Store page hero overrides */
.storePage .heroPoster{
  min-height:50vh;
  background-image:url("../images/store.png");
  background-size:cover;
  background-position:center;
  height:auto;
}

.storePage .posterOverlay{
  background:linear-gradient(rgba(0,0,0,.25), rgba(0,0,0,.6));
}

.storePage .posterTitle{
  font-size:clamp(40px,7vw,90px);
  letter-spacing:.06em;
}

/* Gallery */
.gallery{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:24px;
  margin-top:32px;
}

.tile{display:block;border-radius:var(--radius)}

.thumb{
  width:100%;
  aspect-ratio:1/1;
  background-size:cover;
  background-position:center;
  border-radius:var(--radius);
  border:1px solid var(--line);
  transition:transform .15s ease;
}

.tile:hover .thumb{transform:translateY(-2px)}

.meta{margin-top:8px}
.title{margin:0;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sub{margin:4px 0 0;font-size:.9rem;color:var(--muted)}

/* Footer */
.footer{color:var(--muted);font-size:14px;padding:26px 6px}

/* Plush archive layout */
.page-head{padding:24px 0 10px}
.page-head h1{margin:0 0 6px;font-size:clamp(22px,3vw,34px)}
.muted{color:var(--muted)}

/* Plush archive grid */
.sold-grid{
  display:grid;
  gap:12px;
  padding:16px 0 40px;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  grid-auto-flow:dense;
}

.sold-card{grid-column:span 1}
.sold-card.is-wide{grid-column:span 2}
.sold-card.is-tall{grid-row:span 2}

@media (max-width:900px){
  .sold-card.is-wide{grid-column:span 1}
}

/* Card */
.sold-card--bg{
  position:relative;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background-size:cover;
  background-position:center;
  aspect-ratio:16/9;
  display:block;
}

/* photo tint */
.sold-card--bg::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(
    to bottom,
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,.08) 60%,
    rgba(0,0,0,.22) 100%
  );
  z-index:0;
  pointer-events:none;
}

/* panel */
.sold-card--bg .sold-panel{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  z-index:5;
  padding:10px 12px;
  pointer-events:auto;
}

/* details wrapper */
.sold-details{
  margin:0;
}

/* summary becomes minimal UI */
.sold-summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:10px;
  width:fit-content;
  padding:0;
  color:var(--muted);
}

.sold-summary::-webkit-details-marker{display:none}

/* plush name pill */
.sold-pill{
  display:inline-flex;
  align-items:center;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(10,10,15,.55);
  backdrop-filter:blur(10px);
  color:var(--text);
  font-weight:600;
  font-size:14px;
  line-height:1;
}

/* desktop hint text */
.sold-hint{
  font-size:12px;
  color:var(--muted);
  opacity:.9;
}

/* drawer */
.sold-drawer{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(10,10,15,.62);
  backdrop-filter:blur(10px);

  opacity:0;
  transform:translateY(6px);
  max-height:0;
  overflow:hidden;
  transition:opacity .18s ease, transform .18s ease, max-height .18s ease;
}

.sold-details[open] .sold-drawer{
  opacity:1;
  transform:translateY(0);
  max-height:min(60vh, 520px);
  overflow:auto;
}

/* rows inside drawer */
.sold-row{
  display:grid;
  grid-template-columns:86px 1fr;
  gap:8px;
  align-items:baseline;
  margin:0;
  padding:0;
}

.sold-row + .sold-row{margin-top:8px}

.sold-label{
  font-size:12px;
  color:var(--muted);
}

.sold-value{
  font-size:14px;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* message wraps */
.sold-messageText{
  white-space:normal;
  display:-webkit-box;
  -webkit-line-clamp:4;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.sold-details[open] .sold-messageText{
  display:block;
  overflow:visible;
}

/* mobile */
@media (max-width:600px){
  .sold-card--bg{aspect-ratio:4/3}
  .sold-row{grid-template-columns:78px 1fr}
  .sold-card--bg .sold-panel{padding:10px}
}

/* mobile only: show tap hint */
@media (hover:none) and (pointer:coarse){
  .sold-hint{display:none}

  .sold-summary{
    position:relative;
    padding-right:86px;
  }

  .sold-summary::after{
    content:"Tap for details";
    position:absolute;
    right:0;
    top:0;
    font-size:11px;
    color:var(--muted);
    opacity:.9;
  }

  .sold-details[open] .sold-summary::after{
    content:"Tap to close";
  }

  .sold-summary::before{
    content:"▾";
    position:absolute;
    right:74px;
    top:0;
    opacity:.8;
  }

  .sold-details[open] .sold-summary::before{
    content:"▴";
  }
}

/* desktop hint copy */
@media (hover:hover){
  .sold-hint{display:inline}

  .sold-details:not([open]):hover .sold-drawer{
    opacity:1;
    transform:translateY(0);
    max-height:220px;
    overflow:hidden;
  }
}

/* allow full text when opened */
.sold-details[open] .sold-row .sold-value{
  white-space:normal;
  overflow:visible;
  text-overflow:clip;
}

/* Nav mobile */
@media (max-width: 640px){
  body{padding-top:60px}

  .navInner{
    padding:10px 12px;
    gap:10px;
    min-width:0;
    justify-content:flex-start;
  }

  .brand{
    font-size:13px;
  }

  .navlinks{
    flex:1 1 auto;
    min-width:0;
    width:100%;
    max-width:calc(100vw - 132px);
    padding:4px;
    border-radius:999px;
  }

  .navlinks a{
    font-size:12.5px;
    padding:8px 10px;
  }

  .navlinks::before,
  .navlinks::after{
    width:14px;
  }
}

/* Homepage animations */
.reveal{
  opacity:0;
  transform:translateY(12px);
  transition:opacity .45s ease, transform .45s ease;
  will-change:opacity, transform;
}

.reveal.in{
  opacity:1;
  transform:translateY(0);
}

.homeHero,
.card,
.preview{
  position:relative;
  transform:translateZ(0);
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}

.homeHero:hover,
.card:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.18);
}

.preview:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.18);
}

.preview::before{
  transition:transform .6s ease, filter .25s ease;
}

.preview:hover::before{
  transform:scale(1.12);
  filter:saturate(1.08) contrast(1.03);
}

.homeHero::after,
.card::after{
  content:"";
  position:absolute;
  inset:-40%;
  background:linear-gradient(
    120deg,
    rgba(255,255,255,0),
    rgba(255,255,255,.06),
    rgba(255,255,255,0)
  );
  transform:translateX(-30%) rotate(12deg);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease, transform .6s ease;
}

.homeHero:hover::after,
.card:hover::after{
  opacity:1;
  transform:translateX(30%) rotate(12deg);
}

@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .homeHero,
  .card,
  .preview{transition:none}
  .homeHero::after,
  .card::after{display:none}
}

/* =====================
   Archive controls
===================== */
.archiveControls{
  display:grid;
  grid-template-columns:1.2fr .8fr .6fr .6fr;
  gap:12px;
  margin:8px 0 16px;
}

.archiveControls .input{
  width:100%;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(10,10,15,.55);
  color:var(--text);
  padding:10px 12px;
  font:inherit;
}

@media (max-width:720px){
  .archiveControls{
    grid-template-columns:1fr 1fr;
  }
}
