/* September Fair — Fall Festival theme */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700;9..144,900&display=swap');
:root{
  /* Sampled directly from the September Fair logo */
  --cream:#fef2e3; --cream2:#f7e6d0; --paper:#fffaf1;
  --olive:#554e21; --olive-dk:#403a18; --ink:#52492f;
  --marigold:#d26b1d; --marigold-dk:#a85614; --gold:#e09d6a;
  --line:#ecd9bf; --maxw:1100px;
  --serif:'Fraunces',Georgia,"Times New Roman",serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  line-height:1.65;font-size:17px;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--serif);color:var(--olive);line-height:1.12;font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,6vw,3.6rem);margin:0 0 .4em;font-weight:900} h2{font-size:clamp(1.7rem,4vw,2.4rem);margin:1.5em 0 .5em}
h3{font-size:1.3rem;margin:1.3em 0 .4em}
a{color:var(--marigold-dk)} a:hover{color:var(--olive)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.btn{display:inline-block;background:var(--marigold);color:#fff9ee;padding:14px 30px;border-radius:999px;
  text-decoration:none;font-weight:700;letter-spacing:.3px;box-shadow:0 8px 18px rgba(210,107,29,.28);
  transition:background .15s,transform .15s,box-shadow .15s}
.btn:hover{background:var(--marigold-dk);color:#fff9ee;transform:translateY(-2px);box-shadow:0 12px 24px rgba(210,107,29,.34)}
.btn.ghost{background:transparent;color:var(--olive);border:1.5px solid var(--olive);box-shadow:none}
.btn.ghost:hover{box-shadow:none}
.btn.ghost:hover{background:var(--cream2);color:var(--olive-dk)}

/* header */
header.site{background:rgba(251,245,233,.92);backdrop-filter:blur(6px);border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;max-width:var(--maxw);margin:0 auto;padding:14px 22px}
.brand{font-family:var(--serif);font-weight:900;font-size:1.45rem;color:var(--olive);text-decoration:none;letter-spacing:.2px}
.brand span{color:var(--marigold)}
.brand img{height:62px;width:auto;display:block}
@media(max-width:520px){.brand img{height:48px}}
.menu{display:flex;gap:26px;align-items:center;list-style:none;margin:0;padding:0}
.menu a{color:var(--olive);text-decoration:none;font-weight:600;font-size:.97rem}
.menu a:hover{color:var(--marigold-dk)}
.menu a.shop{background:var(--olive);color:var(--cream);padding:9px 18px;border-radius:10px}
.menu a.shop:hover{background:var(--olive-dk);color:var(--cream)}
.navtoggle{display:none}
@media(max-width:820px){
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;
    gap:0;border-bottom:1px solid var(--line);padding:8px 0}
  .menu li{width:100%} .menu a{display:block;padding:12px 22px}
  .navtoggle{display:block;background:none;border:0;font-size:1.6rem;color:var(--olive);cursor:pointer}
  #nav:checked ~ .menu{display:flex}
}
#nav{display:none}

/* hero */
.hero{position:relative;color:#fff9ee;text-align:center;padding:96px 22px 84px;
  background:var(--olive-dk)}
.hero h1{color:#fff9ee;font-size:3rem;text-shadow:0 2px 14px rgba(0,0,0,.25)}
.hero p{font-size:1.2rem;max-width:620px;margin:0 auto 26px;opacity:.95}
.hero .btn.ghost{color:#fff9ee;border-color:#fff9ee}
.hero .btn.ghost:hover{background:rgba(255,255,255,.12);color:#fff9ee}

/* logo hero (homepage) — warm festival scene, showcases the actual logo */
.hero--logo{position:relative;overflow:hidden;text-align:center;color:var(--ink);
  background:#fdf2e2;padding:28px 22px 70px}
.hero--logo .eyebrow{display:inline-block;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-weight:700;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--marigold-dk);
  background:#fff8ec;border:1px solid var(--line);padding:7px 16px;border-radius:999px;margin:6px 0 16px}
.hero--logo .herologo{max-width:600px;width:90%;height:auto;display:block;margin:0 auto 4px}
.hero--logo h1{margin:.1em auto .25em;max-width:14ch}
.hero--logo .hl{color:var(--marigold)}
.hero--logo .tag{color:var(--olive-dk);max-width:600px;margin:8px auto 24px;font-size:1.18rem}
.hero--logo p{color:var(--olive-dk);max-width:600px;margin:0 auto 28px;font-size:1.18rem}
.hero--logo .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero--logo .btn.ghost{color:var(--olive);border-color:var(--olive)}
.hero--logo .btn.ghost:hover{background:var(--cream2);color:var(--olive-dk)}
.vetbadge{display:inline-block;margin:24px auto 0;font-family:-apple-system,sans-serif;font-weight:700;
  font-size:.82rem;letter-spacing:.06em;color:var(--marigold-dk);background:#fff8ec;border:1px solid var(--line);
  padding:9px 20px;border-radius:999px}
.vetbadge .star{color:var(--marigold)}
/* string lights across the very top of the hero */
.lights{position:absolute;top:0;left:-2%;width:104%;height:46px;pointer-events:none;opacity:.9}

/* tent-title hero (homepage) — reconstructs the logo at scale */
.hero--tent{position:relative;overflow:hidden;text-align:center;padding:30px 22px 84px;
  background:
    radial-gradient(60% 50% at 18% 10%, rgba(210,107,29,.16), transparent 60%),
    radial-gradient(55% 45% at 85% 6%, rgba(224,157,106,.22), transparent 60%),
    linear-gradient(180deg,#fff7ea 0%,var(--cream) 55%,#fbe9d1 100%)}
.hero--tent .eyebrow{display:inline-block;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-weight:700;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--marigold-dk);
  background:rgba(255,255,255,.6);border:1px solid var(--line);padding:6px 15px;border-radius:999px;margin:8px 0 14px}
.tentart{display:block;max-width:520px;width:78%;height:auto;margin:2px auto -4px;mix-blend-mode:multiply}
.titlerow{display:flex;align-items:center;justify-content:center;gap:20px}
.titlerow h1{margin:0;font-size:clamp(2.3rem,7vw,3.7rem);color:var(--olive)}
.titlerow .sprig{height:78px;width:auto;flex:none;mix-blend-mode:multiply}
.titlerow .sprig.flip{transform:scaleX(-1)}
.hero--tent .tag{color:var(--olive-dk);max-width:600px;margin:14px auto 26px;font-size:1.18rem}
.hero--tent .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero--tent .btn.ghost{color:var(--olive);border-color:var(--olive)}
.hero--tent .btn.ghost:hover{background:var(--cream2);color:var(--olive-dk)}
@media(max-width:560px){.titlerow .sprig{height:52px}.titlerow{gap:10px}}
@media(max-width:400px){.titlerow .sprig{display:none}}

/* single centered stat */
.stats.one{display:flex;justify-content:center;margin:26px 0 2px}
.stats.one .stat{min-width:260px}
.stats.one .stat .n{color:var(--marigold)}

/* ── festival decorations ─────────────────────────────────────── */
/* pennant bunting strip (pure CSS triangles) */
.bunting{--w:34px;height:20px;border-top:2px solid rgba(85,78,33,.35);
  background:repeating-linear-gradient(90deg,
    var(--marigold) 0 var(--w),
    var(--olive) var(--w) calc(2*var(--w)),
    var(--gold) calc(2*var(--w)) calc(3*var(--w)),
    var(--marigold-dk) calc(3*var(--w)) calc(4*var(--w)));
  -webkit-mask:
    linear-gradient(-45deg,#000 50%,transparent 50%) 0 0/var(--w) 100% repeat-x,
    linear-gradient(45deg,#000 50%,transparent 50%) 0 0/var(--w) 100% repeat-x;
  -webkit-mask-composite:source-in;mask-composite:intersect}
.bunting.under-nav{margin:0}

/* orange striped tent canopy + scalloped valance — runs under the nav on every page */
.canopy{position:relative;height:26px;
  background:repeating-linear-gradient(90deg,var(--marigold) 0 26px,#f2d6ac 26px 52px)}
.canopy::after{content:"";position:absolute;left:0;right:0;top:100%;height:13px;
  background:radial-gradient(circle at 13px 0,var(--marigold) 11.5px,transparent 12.5px) repeat-x;
  background-size:26px 13px}

/* scalloped valance divider — echoes the tent edge in the logo */
.scallop{height:26px;line-height:0;margin:0}
.scallop svg{display:block;width:100%;height:100%}

/* ── marquee ticker ───────────────────────────────────────────── */
.ticker{background:var(--olive);color:var(--cream);overflow:hidden;white-space:nowrap;
  border-top:1px solid rgba(0,0,0,.12);border-bottom:1px solid rgba(0,0,0,.12)}
.ticker .track{display:inline-flex;gap:0;padding:11px 0;animation:tick 28s linear infinite;will-change:transform}
.ticker:hover .track{animation-play-state:paused}
.ticker span{font-family:var(--serif);font-weight:600;font-size:1.02rem;padding:0 26px;display:inline-flex;align-items:center}
.ticker .dot{color:var(--gold);padding:0 2px}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── section rhythm + bands ───────────────────────────────────── */
.band{padding:62px 0}
.band--paper{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band--night{position:relative;background:
    radial-gradient(80% 120% at 50% -10%, #5e5526 0%, transparent 60%),
    linear-gradient(180deg,var(--olive) 0%,var(--olive-dk) 100%);
  color:#f3ecd9;overflow:hidden}
.band--night::before{content:"";position:absolute;top:-1px;left:0;right:0;height:20px;
  background:radial-gradient(circle at 15px 0,var(--cream) 13px,transparent 14px) repeat-x;
  background-size:30px 20px}
.band--night h2,.band--night h3{color:#fff7ea}
.band--night .lead{color:#e8dec4}
.center{text-align:center}
.eyebrow2{font-family:-apple-system,sans-serif;font-weight:700;font-size:.74rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--marigold-dk);margin:0 0 8px}
.band--night .eyebrow2{color:var(--gold)}
.maxnarrow{max-width:720px;margin-left:auto;margin-right:auto}

/* feature stats row (bento-ish) */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin:26px 0 4px}
.stat{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:24px 20px;text-align:center;
  transition:transform .14s,box-shadow .14s}
.stat:hover{transform:translateY(-4px);box-shadow:0 14px 28px rgba(74,70,54,.10)}
.stat .n{font-family:var(--serif);font-weight:900;font-size:2.3rem;color:var(--marigold);line-height:1;display:block}
.stat .l{font-size:.92rem;color:var(--olive-dk);margin-top:8px;display:block}

/* brand showcase strip (homepage) */
.brandstrip{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:18px;margin:30px 0 6px}
.bchip{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;
  background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:26px 18px 22px;
  text-decoration:none;color:var(--ink);transition:transform .15s,box-shadow .15s,border-color .15s}
.bchip:hover{transform:translateY(-5px);box-shadow:0 16px 32px rgba(74,70,54,.12);border-color:var(--gold)}
.bchip .logowrap{width:96px;height:96px;border-radius:50%;background:#f1e9d6;display:flex;align-items:center;
  justify-content:center;overflow:hidden;margin-bottom:14px;border:1px solid var(--line)}
.bchip .logowrap img{width:82%;height:82%;object-fit:contain}
.bchip .mono{font-family:var(--serif);font-weight:700;font-size:1.3rem;color:var(--bt,var(--olive));opacity:.72}
.bchip .bn{font-family:var(--serif);font-weight:700;font-size:1.18rem;color:var(--olive);display:block}
.bchip .bd{font-size:.86rem;color:#8a7f64;margin-top:4px;display:block}
.bchip .tag{position:absolute;top:12px;right:12px;font-size:.62rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--marigold-dk);background:var(--cream2);border:1px solid var(--line);
  padding:3px 9px;border-radius:999px}

/* featured book (night band) */
.feature{display:grid;grid-template-columns:minmax(160px,230px) 1fr;gap:34px;align-items:center;
  max-width:860px;margin:28px auto 0}
.feature .cover{width:100%;border-radius:10px;display:block;box-shadow:0 18px 40px rgba(0,0,0,.4);
  transform:rotate(-2deg);transition:transform .2s}
.feature .cover:hover{transform:rotate(0) scale(1.02)}
@media(max-width:640px){.feature{grid-template-columns:1fr;text-align:center;max-width:340px}
  .feature .cover{max-width:200px;margin:0 auto}}

/* CTA band */
.ctaband{text-align:center;padding:58px 22px}
.ctaband h2{margin-top:0}

/* content is always visible; reveal is a no-op kept for class hooks */
@media(prefers-reduced-motion:reduce){.ticker .track{animation:none}}

/* sections */
section{padding:8px 0}
.lead{font-size:1.15rem;color:var(--olive-dk);max-width:760px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin:30px 0}
.card{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:30px 26px;text-decoration:none;
  color:var(--ink);display:block;overflow:hidden;transition:transform .14s,box-shadow .14s,border-color .14s}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;
  background:linear-gradient(90deg,var(--marigold),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .25s}
.card:hover{transform:translateY(-5px);box-shadow:0 16px 32px rgba(74,70,54,.12);border-color:var(--gold)}
.card:hover::before{transform:scaleX(1)}
.card h3{margin-top:0;color:var(--olive)}
.card .ic{font-size:1.5rem;color:var(--marigold);margin-bottom:6px;display:block}
.card .go{color:var(--marigold-dk);font-weight:700;margin-top:12px;display:inline-block}
.card:hover .go{text-decoration:underline}
.tile{border-radius:14px;padding:30px 26px;text-decoration:none;display:block;transition:transform .12s}
.tile:hover{transform:translateY(-3px)}
.tile .name{font-size:1.35rem;font-weight:700;font-family:Georgia,serif;display:block;margin-bottom:6px}
.tile .go{display:block;margin-top:14px;font-weight:600}
.note{background:var(--cream2);border-left:4px solid var(--gold);padding:16px 20px;border-radius:8px;margin:24px 0}

/* ad slot */
.ad{margin:34px auto;max-width:760px;text-align:center}
.ad small{display:block;color:#9a937e;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}
.adbox{min-height:90px;background:var(--cream2);border:1px dashed #d9ccad;border-radius:8px;
  display:flex;align-items:center;justify-content:center;color:#a99e82;font-size:.85rem}

/* footer */
footer.site{background:var(--olive-dk);color:#e9e2cf;margin-top:60px;padding:46px 22px 30px}
footer.site .cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:30px;max-width:var(--maxw);margin:0 auto}
footer.site h4{color:#fff9ee;margin:0 0 12px;font-size:1.05rem}
footer.site a{color:#e9e2cf;text-decoration:none;display:block;padding:3px 0;font-size:.95rem}
footer.site a:hover{color:var(--gold)}
footer.site .fine{max-width:var(--maxw);margin:28px auto 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.15);
  font-size:.85rem;color:#bdb49b}
.content{padding:40px 0}
.content ul{padding-left:20px} .content li{margin:6px 0}

/* footer social row */
.footsocial{display:flex;justify-content:center;gap:12px;max-width:var(--maxw);margin:26px auto 0;padding-top:22px;
  border-top:1px solid rgba(255,255,255,.15)}
.footsocial a.ico{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.08);color:#e9e2cf;font-size:1.05rem;text-decoration:none;transition:background .12s,color .12s}
.footsocial a.ico:hover{background:var(--gold);color:var(--olive-dk)}

/* 404 */
.notfound{text-align:center;padding:90px 22px 70px}
.notfound h1{font-size:3rem} .notfound p{font-size:1.15rem;color:var(--olive-dk);max-width:520px;margin:10px auto 26px}

/* shop — coming soon */
.soonbar{background:var(--olive);color:#fff9ee;text-align:center;padding:11px 18px;font-weight:600;font-size:.98rem;letter-spacing:.2px}
.shopgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,320px));gap:26px;margin:28px 0 36px}
.product{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.product .cover{position:relative;background:var(--cream2)}
.product .cover img{width:100%;display:block}
.product .ribbon{position:absolute;top:14px;left:-38px;transform:rotate(-45deg);background:var(--marigold);color:#fff9ee;
  font-weight:700;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;padding:6px 46px;box-shadow:0 2px 6px rgba(0,0,0,.18)}
.product .pinfo{padding:20px 22px 24px}
.product .pinfo h3{margin:0 0 4px}
.product .brandtag{color:#9a8f72;font-size:.85rem;margin-bottom:10px}
.product .price{font-family:Georgia,serif;font-size:1.4rem;color:var(--olive);margin-bottom:16px}
.product .btn{display:block;text-align:center;margin-bottom:10px}
.btn.disabled{background:#cbbfa3;color:#fff9ee;cursor:not-allowed;pointer-events:none}

/* brand tiles — logo (top) / name+desc (mid) / socials / merch (bottom) */
.brandgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin:30px 0}
.brandtile{position:relative;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--paper);
  display:flex;flex-direction:column;transition:box-shadow .14s,transform .14s}
.brandtile:hover{box-shadow:0 14px 30px rgba(74,70,54,.13);transform:translateY(-3px)}
.bt-logo{display:flex;align-items:center;justify-content:center;background:var(--paper);
  border-bottom:1px solid var(--line);padding:28px 22px;min-height:176px}
.bt-logo img{max-height:120px;max-width:82%;width:auto;height:auto;display:block}
.bt-body{padding:20px 24px 8px}
.bt-body .name{font-family:var(--serif);font-weight:700;font-size:1.4rem;color:var(--olive);display:block}
.bt-body .desc{display:block;color:var(--ink);margin:7px 0 12px;font-size:.95rem;line-height:1.5}
.bt-body a.go{font-weight:700;color:var(--marigold-dk);text-decoration:none;display:inline-block}
.bt-body a.go:hover{color:var(--olive);text-decoration:underline}
.bt-social{display:flex;flex-wrap:wrap;gap:9px;padding:12px 22px 16px;align-items:center}
.bt-social a.ico{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;
  background:var(--bt);color:#fff9ee;font-size:1.25rem;text-decoration:none;transition:transform .12s,filter .12s}
.bt-social a.ico:hover{filter:brightness(1.14);transform:translateY(-2px)}
.bt-social .soon{font-size:.82rem;color:#9a8f72;font-style:italic;margin-left:2px}
.bt-shop{display:block;text-align:center;padding:13px;background:var(--olive);color:var(--cream);
  text-decoration:none;font-weight:600;letter-spacing:.2px;margin-top:auto}
.bt-shop:hover{background:var(--olive-dk);color:var(--cream)}

/* coming-soon brand tiles */
.brandtile.is-soon{background:var(--cream)}
.brandtile.is-soon .bt-logo{background:var(--cream2)}
.bt-mark{font-family:var(--serif);font-size:1.9rem;font-weight:700;color:var(--bt);opacity:.7;
  letter-spacing:.02em;text-align:center;line-height:1.15}
.bt-foot{margin-top:auto;padding:14px 24px 20px;color:#9a8f72;font-size:.85rem;font-style:italic}
.soonflag{position:absolute;top:18px;right:-36px;transform:rotate(45deg);background:var(--marigold);
  color:#fff9ee;font-weight:700;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 44px;box-shadow:0 2px 6px rgba(0,0,0,.2);z-index:2}
