:root{
  --bg:#0f1110;           /* deep forest */
  --bg-soft:#151816;      /* panel */
  --ink:#e9efe7;          /* parchment */
  --ink-dim:#c6d0c4;      /* muted text */
  --bone:#c6a567;         /* brass — Bone accent */
  --brine:#44c0b0;        /* aqua — Brine accent */
  --moss:#6aa174;         /* secondary green */
  --shadow: 0 10px 30px rgba(0,0,0,.45);
  --radius: 16px;
}
*{box-sizing:border-box}
html,body{height:100%}
body.bb-dark{margin:0; background:radial-gradient(1200px 700px at 70% -20%, rgba(68,192,176,.08), transparent 60%), var(--bg); color:var(--ink); font-family:Quicksand, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;}

/* Layout helpers */
.container{width:min(1100px, 92vw); margin-inline:auto}
.noscript{background:#300; color:#fff; padding:.75rem; text-align:center}

/* Header */
.bb-header{position:sticky; top:0; z-index:20; backdrop-filter:saturate(140%) blur(6px); background:linear-gradient(180deg, rgba(10,12,10,.9), rgba(10,12,10,.6) 70%, transparent); border-bottom:1px solid rgba(255,255,255,.06)}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.7rem 0}
.brand{display:flex; align-items:center; gap:.8rem; text-decoration:none; color:var(--ink)}
.brand img{border-radius:12px; box-shadow:var(--shadow)}
.brand-text h1{font-family:Marcellus, serif; font-size:1.35rem; line-height:1.1; margin:0}
.brand-text h1 span{color:var(--brine)}
.brand-text .tag{margin:.1rem 0 0; opacity:.8}

/* Primary Navigation */
.main-nav{position:relative}
.nav-toggle{display:none; background:transparent; border:1px solid rgba(255,255,255,.15); color:var(--ink); padding:.45rem .65rem; border-radius:10px}
.nav-links{list-style:none; display:flex; gap:.4rem; margin:0; padding:0}
.nav-links > li{position:relative}
.nav-links a{color:var(--ink); text-decoration:none; padding:.55rem .7rem; border-radius:10px; display:inline-block}
.nav-links a:hover{background:rgba(255,255,255,.06)}

/* Dropdowns */
.has-children > a::after{content:"▾"; font-size:.8em; margin-left:.35rem; opacity:.8}
.has-children .sub{display:none; position:absolute; top:100%; left:0; background:var(--bg-soft); border:1px solid rgba(255,255,255,.08); padding:.45rem; border-radius:12px; box-shadow:var(--shadow); min-width:190px}
.has-children .sub a{display:block; padding:.5rem .7rem}
.has-children:hover .sub{display:block}

/* Mobile nav */
@media (max-width: 820px){
  .nav-toggle{display:inline-flex; align-items:center; gap:.35rem}
  .nav-links{display:none; position:absolute; right:0; top:120%; flex-direction:column; background:var(--bg-soft); padding:.6rem; border-radius:12px; border:1px solid rgba(255,255,255,.08); min-width:230px}
  .nav-links.open{display:flex}
  .has-children .sub{position:static; display:none; margin:.2rem 0 .2rem .6rem}
  .has-children.open .sub{display:block}
}

/* Buttons (Bone × Brine) */
.btn{appearance:none; border:1px solid rgba(255,255,255,.14); background:transparent; color:var(--ink); padding:.65rem 1rem; border-radius:12px; cursor:pointer; text-decoration:none; display:inline-block; transition:transform .08s ease, box-shadow .15s ease, opacity .15s}
.btn:active{transform:translateY(1px)}
.btn-bone{background:linear-gradient(180deg, var(--bone), #8f6e3e); border:none; color:#1a140c}
.btn-bone:hover{box-shadow:0 0 0 3px rgba(198,165,103,.22)}
.btn-brine{background:linear-gradient(180deg, var(--brine), #2a9185); border:none; color:#061411}
.btn-brine:hover{box-shadow:0 0 0 3px rgba(68,192,176,.22)}
.btn-ghost:hover{background:rgba(255,255,255,.06)}

/* Hero */
.hero{position:relative; padding:3.2rem 0 2rem}
.hero .container{display:grid; grid-template-columns: 1.1fr 1fr; gap:2rem; align-items:center}
.hero-copy h2{font-family:Marcellus, serif; font-size:2.2rem; margin:0 0 .6rem}
.hero-copy p{color:var(--ink-dim)}
.cta-row{display:flex; gap:.7rem; margin-top:1rem}
.hero-media img{display:block; width:100%; max-width:380px; border-radius:16px; border:1px solid rgba(255,255,255,.08); box-shadow:var(--shadow)}

/* Section baseline */
.section-title{font-family:Marcellus, serif; font-size:1.6rem; margin:0 0 .8rem; position:relative}
.section-title::after{content:""; display:block; height:3px; width:120px; margin-top:.4rem; background:linear-gradient(90deg, var(--bone), var(--brine))}
.section-blurb{color:var(--ink-dim); margin:-.2rem 0 1.2rem}

/* Grids & cards */
.grid{display:grid; gap:1rem}
.products-grid{grid-template-columns: repeat(3, 1fr)}
.media-grid{grid-template-columns: repeat(3, 1fr)}
.card{display:block; text-decoration:none; color:var(--ink); border-radius:16px; overflow:hidden; border:1px solid rgba(255,255,255,.08); background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015)); box-shadow:var(--shadow)}
.card-media img{display:block; width:100%; height:auto}
.card-body{padding:.95rem}
.card h4{font-family:Marcellus, serif; margin:.1rem 0 .25rem}
.card p{color:var(--ink-dim); margin:0}

/* Media items */
.media-item{border-radius:14px; overflow:hidden; border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.03)}
.media-item img{display:block; width:100%; height:auto}
.media-item figcaption{padding:.55rem .7rem; color:var(--ink-dim)}

/* Footer */
.bb-footer{padding:1.2rem 0; border-top:1px solid rgba(255,255,255,.08); background:rgba(0,0,0,.25)}
.footer-inner{display:flex; align-items:center; justify-content:space-between; gap:1rem}
.footer-nav a{color:var(--ink-dim); text-decoration:none; margin-left:.8rem}
.footer-nav a:hover{color:var(--ink)}

/* Responsive tweaks */
@media (max-width: 920px){
  .hero .container{grid-template-columns:1fr}
  .products-grid{grid-template-columns:1fr}
  .media-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 560px){
  .media-grid{grid-template-columns:1fr}
}

/* Rotator: stack frames and cross-fade */
.rotator{ position:relative; overflow:hidden; }
.rotator img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;        /* keep composition tight */
  opacity:0; transition:opacity 1s ease; /* smooth fade */
  pointer-events:none;     /* clicks go through */
}
.rotator img.is-active{ opacity:1; }

/* Suggested aspect ratios so the wrapper has height (no reflow) */
.card .card-media.rotator{ aspect-ratio: 4 / 3; }   /* product cards */
.media-item .rotator{ aspect-ratio: 16 / 9; }       /* 'Where They Roam' */

.logo {
    width: 100px;
    height: auto;
}

/* === Modal (Hauntling Lookup, Care, etc.) === */
.modal.closeableModal {
  position: fixed;
  inset: 0;
  display: none;               /* hidden by default */
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.65); /* dark backdrop */
  z-index: 1000;
  padding: 1rem;
}

.modal.closeableModal.open {
  display: flex;
}

.modal-content {
  background: var(--bg-soft);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  box-shadow: var(--shadow);
  width: min(720px, 92vw);
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: modalFade .25s ease;
}

@keyframes modalFade {
  from { opacity:0; transform: scale(.96); }
  to   { opacity:1; transform: scale(1); }
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .9rem 1rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
}

.modal-header h2 {
  margin: 0;
  font-family: Marcellus, serif;
  font-size: 1.25rem;
  color: var(--ink);
}

.modal-close {
  cursor: pointer;
  font-size: 1.5rem;
  line-height: 1;
  padding: .2rem .5rem;
  border-radius: 8px;
  transition: background .15s;
}
.modal-close:hover {
  background: rgba(255,255,255,.08);
}

.modal-body {
  padding: 1rem 1.1rem;
  overflow-y: auto;
  color: var(--ink);
}
.modal-body img {
  border-radius: 12px;
  display: block;
  width: 100%;
  height: auto;
  margin-bottom: 1rem;
  border: 1px solid rgba(255,255,255,.08);
}

/* ---- Audio Popup (bottom-right) ---- */
.bb-audio-pop {
  position: fixed;
  right: 16px;
  bottom: -1000px;             /* hidden off-screen initially */
  z-index: 1500;              /* above modal backdrop */
  width: min(280px, 42vw);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: var(--bg-soft);
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: bottom .25s ease;
  will-change: bottom;
}
.bb-audio-pop.open { bottom: 16px; }

.bb-audio-pop img {
  display: block;
  width: 100%;
  height: auto;
}

.bb-audio-pop .bb-audio-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  padding: .5rem .65rem;
  border-top: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  color: var(--ink);
  font-size: .9rem;
}

.bb-audio-pop .bb-audio-title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  opacity: .9;
}

.bb-audio-pop .bb-audio-close {
  cursor: pointer;
  border: 0;
  background: transparent;
  color: var(--ink);
  font-size: 1.1rem;
  line-height: 1;
  padding: .2rem .4rem;
  border-radius: 8px;
}
.bb-audio-pop .bb-audio-close:hover { background: rgba(255,255,255,.08); }

@media (max-width: 520px){
  .bb-audio-pop { right: 10px; width: min(220px, 60vw); }
}

.spinner {
  display:inline-block;
  width:1em; height:1em;
  border:2px solid #999;
  border-right-color:transparent;
  border-radius:50%;
  animation:spin 0.8s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }
