/* ============================================================
   The Jolly Elf Holiday Popup — stylesheet
   Brand: Work Sans • Burgundy #aa1e21 / Red #ed1c26 / Teals
   ============================================================ */

/* ---------- Fonts (self-hosted, OFL) ---------- */
@font-face{font-family:'Work Sans';font-style:normal;font-weight:400;font-display:swap;
  src:url('../assets/fonts/work-sans-latin-400-normal.woff2') format('woff2'),
      url('../assets/fonts/work-sans-latin-400-normal.woff') format('woff');}
@font-face{font-family:'Work Sans';font-style:normal;font-weight:500;font-display:swap;
  src:url('../assets/fonts/work-sans-latin-500-normal.woff2') format('woff2'),
      url('../assets/fonts/work-sans-latin-500-normal.woff') format('woff');}
@font-face{font-family:'Work Sans';font-style:normal;font-weight:600;font-display:swap;
  src:url('../assets/fonts/work-sans-latin-600-normal.woff2') format('woff2'),
      url('../assets/fonts/work-sans-latin-600-normal.woff') format('woff');}
@font-face{font-family:'Work Sans';font-style:normal;font-weight:700;font-display:swap;
  src:url('../assets/fonts/work-sans-latin-700-normal.woff2') format('woff2'),
      url('../assets/fonts/work-sans-latin-700-normal.woff') format('woff');}
@font-face{font-family:'Work Sans';font-style:normal;font-weight:800;font-display:swap;
  src:url('../assets/fonts/work-sans-latin-800-normal.woff2') format('woff2'),
      url('../assets/fonts/work-sans-latin-800-normal.woff') format('woff');}

/* ---------- Tokens ---------- */
:root{
  --burgundy:#aa1e21; --red:#ed1c26; --teal-dark:#34b3bd; --teal:#87d1d1;
  --night:#1a0405;            /* rich near-black for the deepest sections */
  --burgundy-deep:#7e1518;    /* darker burgundy for depth/gradients */
  --teal-deep:#0f6b73;        /* accessible dark-teal bg for white text */
  --cream:#fff7f0; --mint:#eaf7f7;
  --ink:#2b1416;              /* body text on light */
  --ink-soft:#5c4548;
  --white:#ffffff;
  --maxw:1200px;
  --r:18px; --r-lg:26px;
  --shadow:0 14px 40px rgba(26,4,5,.16);
  --shadow-sm:0 6px 18px rgba(26,4,5,.12);
  --ease:cubic-bezier(.2,.7,.2,1);
  --display:'Work Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{font-family:var(--display);font-weight:400;color:var(--ink);background:var(--cream);
  line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
:focus-visible{outline:3px solid var(--teal-dark);outline-offset:3px;border-radius:6px}

/* candy-cane accent used as a top hairline + dividers */
.candy{height:6px;width:100%;
  background:repeating-linear-gradient(45deg,var(--red) 0 14px,#fff 14px 28px);}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,40px)}
.section{padding:clamp(56px,8vw,108px) 0;position:relative}
.section.tight{padding:clamp(40px,5vw,64px) 0}
.eyebrow{font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  font-size:.78rem;color:var(--teal-dark)}
.center{text-align:center}
h1,h2,h3{font-weight:800;line-height:1.04;letter-spacing:-.015em}
h1{font-size:clamp(2.3rem,6vw,4.4rem)}
h2{font-size:clamp(1.9rem,4.4vw,3.1rem)}
h3{font-size:clamp(1.25rem,2.2vw,1.6rem);letter-spacing:-.01em}
.lead{font-size:clamp(1.05rem,1.7vw,1.3rem);font-weight:500}
p{max-width:62ch}
.center p{margin-left:auto;margin-right:auto}

/* ---------- Section themes ---------- */
.dark{background:linear-gradient(160deg,var(--burgundy) 0%,var(--burgundy-deep) 100%);color:#fff}
.night{background:radial-gradient(120% 130% at 80% -10%,#3a0a0c 0%,var(--night) 60%);color:#fff}
.teal{background:linear-gradient(155deg,var(--teal-deep) 0%,#0b525a 100%);color:#fff}
.light{background:var(--cream)}
.mint{background:linear-gradient(180deg,var(--mint),#f3fbfb)}
.dark .eyebrow,.night .eyebrow,.teal .eyebrow{color:var(--teal)}
.dark h2,.night h2,.teal h2,.dark h3,.night h3,.teal h3{color:#fff}
.dark p,.night p,.teal p{color:rgba(255,255,255,.9)}

/* snow-dot texture overlay for dark sections */
.night::before,.dark::before,.teal::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.5) 1.1px,transparent 1.2px);
  background-size:46px 46px;opacity:.10;mix-blend-mode:screen}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:600;letter-spacing:.02em;
  padding:.92em 1.5em;border-radius:999px;font-size:1rem;line-height:1;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s;
  will-change:transform}
.btn:hover{transform:translateY(-3px)}
.btn:active{transform:translateY(-1px)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 24px rgba(237,28,38,.36)}
.btn-red:hover{box-shadow:0 16px 32px rgba(237,28,38,.46)}
.btn-burgundy{background:var(--burgundy);color:#fff;box-shadow:0 10px 24px rgba(170,30,33,.32)}
.btn-teal{background:var(--teal-dark);color:#06363b;box-shadow:0 10px 24px rgba(52,179,189,.32)}
.btn-cream{background:var(--cream);color:var(--burgundy)}
.btn-outline{background:transparent;color:#fff;box-shadow:inset 0 0 0 2px rgba(255,255,255,.85)}
.btn-outline:hover{background:#fff;color:var(--burgundy)}
.btn-lg{font-size:1.08rem;padding:1.05em 1.8em}
.btn .arr{transition:transform .25s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

.btn-row{display:flex;flex-wrap:wrap;gap:14px}
.section.center .btn-row{justify-content:center}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{position:sticky;top:0;z-index:60;transition:background .3s,box-shadow .3s,padding .3s}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;
  padding:14px clamp(18px,4vw,40px);gap:16px}
.site-header{background:rgba(26,4,5,.0)}
.site-header.scrolled{background:rgba(26,4,5,.96);box-shadow:0 6px 24px rgba(0,0,0,.28);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
/* on interior pages the header always sits over a dark band, so it starts solid-ish */
body.solid-header .site-header{background:rgba(26,4,5,.96);box-shadow:0 6px 24px rgba(0,0,0,.22)}
.brand-logo{height:46px;width:auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.45))}
.nav{display:flex;align-items:center;gap:26px}
.nav a.navlink{color:#fff;font-weight:600;font-size:.98rem;letter-spacing:.01em;position:relative;padding:6px 2px}
.nav a.navlink::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:var(--teal-dark);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.nav a.navlink:hover::after,.nav a.navlink[aria-current="page"]::after{transform:scaleX(1)}
.nav a.navlink[aria-current="page"]{color:var(--teal)}
.nav .btn{padding:.7em 1.25em;font-size:.95rem}
.hamburger{display:none;flex-direction:column;gap:5px;padding:10px;border-radius:10px}
.hamburger span{width:26px;height:3px;background:#fff;border-radius:3px;transition:.3s}

/* mobile overlay */
.mobile-nav{position:fixed;inset:0;z-index:70;background:linear-gradient(160deg,var(--burgundy),var(--night));
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  transform:translateY(-100%);transition:transform .42s var(--ease);visibility:hidden}
.mobile-nav.open{transform:translateY(0);visibility:visible}
.mobile-nav a{color:#fff;font-weight:800;font-size:1.7rem;padding:12px}
.mobile-nav .btn{margin-top:18px;font-size:1.15rem}
.mobile-nav .close{position:absolute;top:20px;right:22px;color:#fff;font-size:2.2rem;line-height:1}
body.menu-open{overflow:hidden}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:min(92vh,820px);display:flex;align-items:center;
  margin-top:-82px;padding-top:82px;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:-2}
.hero-scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(26,4,5,.62) 0%,rgba(26,4,5,.35) 38%,rgba(26,4,5,.78) 100%)}
.hero-inner{max-width:880px;padding:48px 0}
.hero .logo-hero{width:clamp(220px,30vw,360px);margin-bottom:22px;
  filter:drop-shadow(0 6px 22px rgba(0,0,0,.55))}
.hero h1{font-size:clamp(2.1rem,5vw,3.7rem);text-shadow:0 4px 26px rgba(0,0,0,.5)}
.hero .lead{margin:18px 0 30px;max-width:42ch;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.5)}
.scroll-cue{position:absolute;bottom:22px;right:34px;color:rgba(255,255,255,.85);
  font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
@media (max-width:760px){ .scroll-cue{display:none} }
.scroll-cue .dot{width:24px;height:38px;border:2px solid rgba(255,255,255,.7);border-radius:14px;position:relative}
.scroll-cue .dot::after{content:"";position:absolute;left:50%;top:8px;width:4px;height:8px;background:#fff;border-radius:3px;
  transform:translateX(-50%);animation:scrolldot 1.6s var(--ease) infinite}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,12px)}}

/* falling snow (hero only, lightweight) */
.snow{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.snow i{position:absolute;top:-10px;color:#fff;opacity:.0;border-radius:50%;background:#fff;width:6px;height:6px;
  animation:fall linear infinite}
@keyframes fall{0%{transform:translateY(-10px) translateX(0);opacity:0}
  10%{opacity:.8}90%{opacity:.8}100%{transform:translateY(102vh) translateX(30px);opacity:0}}
@media (prefers-reduced-motion:reduce){.snow{display:none}.scroll-cue .dot::after{animation:none}}

/* small page hero (interior pages) */
.page-hero{position:relative;color:#fff;display:flex;align-items:center;min-height:clamp(320px,46vh,440px);
  margin-top:-82px;padding:104px 0 40px;overflow:hidden}
.page-hero .hero-bg{filter:saturate(1.02)}
.page-hero .hero-scrim{background:linear-gradient(180deg,rgba(26,4,5,.7),rgba(26,4,5,.55) 50%,rgba(26,4,5,.82))}
.page-hero .inner{max-width:760px}
.page-hero h1{text-shadow:0 4px 24px rgba(0,0,0,.5)}
.page-hero p{color:#fff;margin-top:14px;text-shadow:0 2px 12px rgba(0,0,0,.5)}

/* ============================================================
   FEATURE / EXPLAINER COLUMNS
   ============================================================ */
.cols{display:grid;gap:clamp(22px,3vw,40px);margin-top:clamp(34px,4vw,52px)}
.cols.three{grid-template-columns:repeat(3,1fr)}
.feature{text-align:center}
.feature .ic{width:74px;height:74px;margin:0 auto 18px;display:grid;place-items:center;border-radius:50%;
  background:rgba(135,209,209,.16)}
.feature .ic svg{width:38px;height:38px}
.dark .feature .ic,.night .feature .ic{background:rgba(135,209,209,.14)}
.light .feature .ic{background:rgba(15,107,115,.10)}
.feature h3{margin-bottom:8px}
.feature p{margin:0 auto;max-width:34ch;font-size:1.02rem}

/* icon stroke colors */
.ic-teal{stroke:var(--teal-dark)} .ic-teal2{stroke:var(--teal)}

/* ============================================================
   SHOWCASE MOSAIC
   ============================================================ */
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:160px;gap:14px;margin-top:38px}
.mosaic figure{overflow:hidden;border-radius:var(--r);position:relative;box-shadow:var(--shadow-sm)}
.mosaic img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.mosaic figure:hover img{transform:scale(1.06)}
.mosaic .big{grid-column:span 2;grid-row:span 2}
.mosaic .wide{grid-column:span 2}
.mosaic .tall{grid-row:span 2}

/* ============================================================
   LOCATIONS
   ============================================================ */
.loc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,2.6vw,30px);margin-top:42px}
.loc-card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden;
  display:flex;flex-direction:column;border:1px solid rgba(15,107,115,.14);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.loc-card:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(26,4,5,.22)}
.loc-logo{display:block;background:var(--night);padding:26px;position:relative}
.loc-logo img{width:100%;max-width:340px;margin:0 auto;height:auto}
.loc-logo .tag{position:absolute;top:14px;left:14px;background:var(--red);color:#fff;font-weight:700;
  font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;padding:5px 11px;border-radius:999px}
.loc-body{padding:24px clamp(20px,3vw,30px) 28px;display:flex;flex-direction:column;gap:8px;flex:1}
.loc-body h3{color:var(--burgundy)}
.loc-city{font-weight:700;color:var(--teal-deep);letter-spacing:.02em}
.loc-meta{display:flex;align-items:flex-start;gap:9px;color:var(--ink-soft);font-size:.97rem;font-weight:500}
.loc-meta svg{flex:none;width:18px;height:18px;margin-top:2px;stroke:var(--teal-dark)}
.loc-dates{font-weight:700;color:var(--ink)}
.loc-give{font-size:.9rem;color:var(--ink-soft);font-weight:500;border-top:1px dashed rgba(15,107,115,.3);padding-top:12px;margin-top:4px}
.loc-give b{color:var(--burgundy)}
.loc-actions{margin-top:auto;padding-top:16px;display:flex;gap:10px;flex-wrap:wrap}
.loc-actions .btn{font-size:.92rem;padding:.78em 1.25em}

.coming{margin-top:36px;text-align:center;border:2px dashed rgba(255,255,255,.35);border-radius:var(--r-lg);
  padding:clamp(26px,4vw,40px)}
.coming h3{font-size:clamp(1.4rem,2.6vw,2rem);margin-bottom:8px}

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,34px);margin-top:44px;counter-reset:step}
.step{position:relative;padding-left:8px}
.step .num{font-size:3.2rem;font-weight:800;color:var(--teal-dark);line-height:1;opacity:.9}
.step h3{margin:10px 0 6px}
.step p{font-size:1.02rem}

/* ============================================================
   GIVING BACK / CHARITIES
   ============================================================ */
.charities{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(22px,4vw,54px);margin-top:38px}
.charity{display:flex;flex-direction:column;align-items:center;gap:12px;max-width:230px;text-align:center}
.charity .chip{background:#fff;border-radius:18px;padding:18px 22px;width:200px;height:120px;display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.charity .chip img{max-height:84px;max-width:100%;width:auto;object-fit:contain}
.charity small{color:rgba(255,255,255,.85);font-weight:600;letter-spacing:.02em}

/* ============================================================
   SPLIT (image + text) used on Experience
   ============================================================ */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.split.rev{grid-template-columns:1fr 1.05fr}
.split .media{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.split .media img{width:100%;height:100%;object-fit:cover}
.split.rev .media{order:2}
.checklist{list-style:none;display:grid;gap:14px;margin-top:22px}
.checklist li{display:flex;gap:12px;align-items:flex-start;font-weight:500;font-size:1.05rem}
.checklist svg{flex:none;width:24px;height:24px;margin-top:2px}

/* values grid */
.values{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:40px}
.value{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:var(--r);
  padding:22px 18px;text-align:center}
.value .v{font-weight:800;letter-spacing:.06em;color:var(--teal);font-size:1.05rem;margin-bottom:6px}
.value p{font-size:.92rem;color:rgba(255,255,255,.85);margin:0 auto}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:820px;margin:38px auto 0;display:grid;gap:12px}
.faq details{background:#fff;border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid rgba(15,107,115,.12)}
.faq summary{list-style:none;cursor:pointer;padding:20px 24px;font-weight:700;color:var(--burgundy);
  display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:1.05rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex:none;width:26px;height:26px;border-radius:50%;background:var(--mint);display:grid;place-items:center;
  color:var(--teal-deep);font-weight:800;transition:transform .3s var(--ease)}
.faq details[open] summary .pm{transform:rotate(45deg);background:var(--teal-dark);color:#fff}
.faq .ans{padding:0 24px 22px;color:var(--ink-soft);font-weight:500}
.faq .ans a{color:var(--red);font-weight:700;text-decoration:underline}

/* ============================================================
   GALLERY
   ============================================================ */
.masonry{columns:4;column-gap:14px;margin-top:8px}
.masonry button{display:block;width:100%;padding:0;margin:0 0 14px;border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-sm);background:#eee;line-height:0;break-inside:avoid;transition:transform .3s var(--ease)}
.masonry img{width:100%;height:auto;transition:transform .6s var(--ease)}
.masonry button:hover{transform:translateY(-3px)}
.masonry button:hover img{transform:scale(1.05)}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:90;background:rgba(8,2,3,.92);display:none;align-items:center;justify-content:center;padding:24px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox .lb-btn{position:absolute;background:rgba(255,255,255,.12);color:#fff;width:54px;height:54px;border-radius:50%;
  font-size:1.6rem;display:grid;place-items:center;transition:background .2s}
.lightbox .lb-btn:hover{background:rgba(255,255,255,.25)}
.lb-close{top:22px;right:22px}
.lb-prev{left:18px;top:50%;transform:translateY(-50%)}
.lb-next{right:18px;top:50%;transform:translateY(-50%)}

/* social UGC strip */
.ugc{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:30px}
.ugc a{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--burgundy);font-weight:700;
  padding:.85em 1.4em;border-radius:999px;box-shadow:var(--shadow-sm)}
.ugc a svg{width:22px;height:22px}

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-band{text-align:center}
.cta-band h2{max-width:18ch;margin:0 auto}
.cta-band p{max-width:54ch;margin:14px auto 26px}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr;gap:40px;max-width:760px;margin:0 auto}
.form-card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow);padding:clamp(24px,4vw,44px);border:1px solid rgba(15,107,115,.12)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:700;color:var(--burgundy);margin-bottom:7px;font-size:.95rem}
.field .opt{color:var(--ink-soft);font-weight:500;font-size:.82rem}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:1rem;color:var(--ink);
  padding:.85em 1em;border:2px solid #e7d9d6;border-radius:12px;background:#fffdfc;transition:border .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal-dark);
  box-shadow:0 0 0 4px rgba(52,179,189,.18)}
.field textarea{min-height:130px;resize:vertical}
.field.row2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:0}
.check{display:flex;gap:12px;align-items:flex-start;background:var(--mint);border-radius:12px;padding:14px 16px;margin-bottom:20px}
.check input{width:20px;height:20px;margin-top:2px;flex:none;accent-color:var(--red)}
.check label{font-weight:600;color:var(--ink);font-size:.95rem;margin:0}
.partner-only{display:none}
.form-note{font-size:.85rem;color:var(--ink-soft);margin-top:14px}
.form-msg{display:none;border-radius:14px;padding:18px 20px;font-weight:600;margin-bottom:18px}
.form-msg.ok{background:#e7f7ec;color:#176c3a;border:1px solid #b6e2c4}
.form-msg.err{background:#fdeaea;color:#a3201f;border:1px solid #f3c0c0}
.contact-info{text-align:center}
.contact-info a{color:var(--red);font-weight:700}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--night);color:#fff;position:relative}
.site-footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;padding-block:clamp(48px,6vw,72px) 40px}
.site-footer .flogo{width:170px;margin-bottom:16px}
.site-footer .tagline{color:rgba(255,255,255,.82);font-weight:600;max-width:30ch}
.site-footer h4{font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);margin-bottom:14px}
.site-footer ul{list-style:none;display:grid;gap:9px}
.site-footer ul a{color:rgba(255,255,255,.85);font-weight:500}
.site-footer ul a:hover{color:#fff}
.socials{display:flex;gap:12px;margin-top:6px}
.socials a{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.1);display:grid;place-items:center;transition:background .2s,transform .2s}
.socials a:hover{background:var(--red);transform:translateY(-3px)}
.socials svg{width:20px;height:20px;fill:#fff}
.site-footer .bottom{border-top:1px solid rgba(255,255,255,.12);padding-block:20px;
  display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;color:rgba(255,255,255,.7);font-size:.85rem}
.site-footer .bottom a{color:rgba(255,255,255,.7)}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:960px){
  .nav .navlink{display:none}
  .nav .btn{display:none}
  .hamburger{display:flex}
  .cols.three{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr}
  .values{grid-template-columns:repeat(2,1fr)}
  .split,.split.rev{grid-template-columns:1fr}
  .split.rev .media{order:0}
  .site-footer .top{grid-template-columns:1fr 1fr}
  .masonry{columns:3}
  .mosaic{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  .cols.three{grid-template-columns:1fr}
  .loc-grid{grid-template-columns:1fr}
  .values{grid-template-columns:1fr}
  .field.row2{grid-template-columns:1fr;gap:0}
  .masonry{columns:2;column-gap:10px}
  .site-footer .top{grid-template-columns:1fr}
  .mosaic{grid-auto-rows:130px}
  .hero{min-height:88vh}
}

/* ============================================================
   BRIGHT THEME — merry & bright overrides + festive decor
   (placed last so it wins the cascade)
   ============================================================ */
:root{ --blush:#fbecec; --teal-bg:#9bdada; --teal-bg2:#7fcccd; --gold:#e6b54a; --green:#2e8b57; }

/* ---- Section themes: light & cheerful ---- */
.white{background:#ffffff}
.blush{background:var(--blush)}
.light{background:var(--cream)}
.mint{background:linear-gradient(180deg,#e7f6f6,#f6fbfb)}
.teal{background:linear-gradient(165deg,var(--teal-bg) 0%,var(--teal-bg2) 100%);color:var(--ink)}
/* neutralize any leftover ultra-dark theme to a bright cream */
.night{background:var(--cream);color:var(--ink)}
/* keep ONE rich accent for pop: .dark stays burgundy w/ white text */
.dark{background:linear-gradient(155deg,var(--red) 0%,var(--burgundy) 70%,var(--burgundy-deep) 100%);color:#fff}

/* text colors on the bright sections */
.light .eyebrow,.white .eyebrow,.blush .eyebrow,.mint .eyebrow,.teal .eyebrow,.night .eyebrow{color:var(--teal-dark)}
.teal .eyebrow{color:var(--burgundy)}
.light h2,.white h2,.blush h2,.mint h2,.teal h2,.night h2,
.light h3,.white h3,.blush h3,.mint h3,.teal h3,.night h3{color:var(--burgundy)}
.light p,.white p,.blush p,.mint p,.teal p,.night p{color:var(--ink-soft)}
.teal .lead,.blush .lead,.mint .lead,.light .lead,.white .lead{color:var(--ink)}
.dark .eyebrow{color:#ffe6c7}
.dark h2,.dark h3{color:#fff}
.dark p,.dark .lead{color:rgba(255,255,255,.95)}

/* feature icon circles on bright bg */
.feature .ic{background:rgba(52,179,189,.16)}
.teal .feature .ic{background:rgba(255,255,255,.45)}
.dark .feature .ic{background:rgba(255,255,255,.18)}
.teal .ic-teal,.light .ic-teal,.white .ic-teal,.blush .ic-teal{stroke:var(--teal-dark)}
.teal .ic-teal{stroke:var(--burgundy)}

/* turn off the dark snow-dot overlay on now-bright sections */
.night::before,.teal::before{display:none}
/* keep a soft sparkle only on the .dark accent */
.dark::before{opacity:.12}

/* ---- Header: light & airy ---- */
.site-header.scrolled{background:rgba(255,255,255,.97);box-shadow:0 6px 22px rgba(170,30,33,.12);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
body.solid-header .site-header{background:rgba(255,255,255,.98);box-shadow:0 4px 18px rgba(170,30,33,.10)}
.site-header.scrolled .nav a.navlink,body.solid-header .nav a.navlink{color:var(--burgundy)}
.site-header.scrolled .nav a.navlink[aria-current="page"],
body.solid-header .nav a.navlink[aria-current="page"]{color:var(--teal-dark)}
.site-header.scrolled .hamburger span,body.solid-header .hamburger span{background:var(--burgundy)}
.brand-logo{height:50px;filter:drop-shadow(0 2px 5px rgba(0,0,0,.18))}
body.solid-header .brand-logo,.site-header.scrolled .brand-logo{filter:none}

/* ---- Hero: lighten the scrim so photos feel brighter ---- */
.hero-scrim{background:linear-gradient(180deg,rgba(26,4,5,.52) 0%,rgba(26,4,5,.22) 40%,rgba(26,4,5,.66) 100%)}
.page-hero .hero-scrim{background:linear-gradient(180deg,rgba(26,4,5,.6),rgba(26,4,5,.42) 50%,rgba(26,4,5,.72))}

/* ---- Restaurant logo tiles stay dark (white-on-dark signs) ---- */
.loc-logo{background:linear-gradient(160deg,#241016,#140609)}

/* ---- "more coming" box on bright bg ---- */
.coming{border-color:rgba(170,30,33,.32);background:rgba(255,255,255,.55)}
.coming h3{color:var(--burgundy)}
.coming p{color:var(--ink-soft)}

/* ---- charity caption on bright bg ---- */
.charity small{color:var(--ink-soft)}
.charity .chip{box-shadow:var(--shadow-sm);border:1px solid rgba(170,30,33,.08)}

/* ---- values grid on bright bg ---- */
.value{background:#fff;border:1px solid rgba(52,179,189,.22);box-shadow:var(--shadow-sm)}
.value .v{color:var(--burgundy)}
.value p{color:var(--ink-soft)}

/* ---- footer: warm burgundy instead of near-black ---- */
.site-footer{background:linear-gradient(160deg,var(--burgundy) 0%,var(--burgundy-deep) 100%)}

/* ============================================================
   FESTIVE DECORATIONS
   ============================================================ */
/* candy-cane dividers */
.candy{height:8px;background:repeating-linear-gradient(45deg,var(--red) 0 16px,#fff 16px 32px)}
.candy-lg{height:13px;width:100%;background:repeating-linear-gradient(45deg,var(--red) 0 20px,#fff 20px 40px)}

/* hanging-ornament garland strip (drop at top of a section) */
.garland{height:62px;background:url(/assets/deco/garland.svg) repeat-x center top/auto 62px;
  margin-bottom:6px;pointer-events:none}

/* subtle snowflake texture layer for a section */
.snowy{position:relative;isolation:isolate}
.snowy::after{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:url(/assets/deco/snowflakes.svg) repeat;background-size:280px 280px;opacity:.55}

/* absolutely-placed corner vector accents */
.sec{position:relative;overflow:hidden}
.deco{position:absolute;pointer-events:none;z-index:0;user-select:none}
.deco img{width:100%;height:auto;display:block}
.section>.wrap{position:relative;z-index:1}
.deco-cane{width:64px;top:26px;right:30px;transform:rotate(12deg);opacity:.9}
.deco-cane.left{right:auto;left:30px;transform:rotate(-14deg)}
.deco-holly{width:104px;top:-8px;left:18px;transform:rotate(-8deg)}
.deco-tree{width:78px;bottom:18px;right:34px;opacity:.9}
.deco-gift{width:84px;bottom:20px;left:30px}
@media (max-width:680px){ .deco-cane,.deco-tree,.deco-gift,.deco-holly{display:none} }

/* elf mascot accent (peeking / standing) */
.elf-peek{position:absolute;z-index:1;pointer-events:none;bottom:0;right:6%;width:clamp(120px,16vw,210px);
  filter:drop-shadow(0 10px 20px rgba(26,4,5,.25))}
@media (max-width:860px){ .elf-peek{display:none} }

/* little inline ornament bullet for lists/eyebrows */
.spark{display:inline-block;width:.7em;height:.7em;vertical-align:baseline;margin:0 .15em}

/* feature icon strokes readable on bright sections */
.light .ic-teal2,.white .ic-teal2,.blush .ic-teal2,.mint .ic-teal2{stroke:var(--teal-dark)}
.teal .ic-teal2{stroke:var(--burgundy)}

/* ============================================================
   ROUND 3 — header, hero, tiles, CTA, footer, showcase
   ============================================================ */
/* 1. Header always white, nav + logo always visible */
.site-header{background:#ffffff;box-shadow:0 2px 14px rgba(170,30,33,.10)}
.site-header.scrolled{background:#ffffff;box-shadow:0 6px 22px rgba(170,30,33,.14)}
.site-header .nav a.navlink{color:var(--burgundy)}
.site-header .nav a.navlink[aria-current="page"]{color:var(--teal-dark)}
.site-header .hamburger span{background:var(--burgundy)}
.brand-logo{filter:none}
/* hero no longer slides under the header */
.hero{margin-top:0;padding-top:0}
.page-hero{margin-top:0;padding:clamp(48px,6vw,72px) 0 40px}

/* 2. Location logo tiles: deep teal (logos pop, brand color) */
.loc-logo{background:#104e54}

/* 3. "For Restaurants" accent band -> deep teal so the elf mascot reads */
.dark{background:linear-gradient(150deg,#0f6b73 0%,#0a464c 100%);color:#fff}
.dark .eyebrow{color:#bdeef0}
.dark::before{opacity:.10}

/* 4. Footer -> near-black so the red wordmark pops (it's built for dark) */
.site-footer{background:radial-gradient(120% 130% at 80% -10%,#34121a 0%,#150406 65%)}

/* 6 & locations: truly center a centered paragraph block */
p.center{margin-left:auto;margin-right:auto}

/* 9. charity boxes top-aligned so the first lines up with the others */
.charities{align-items:flex-start}

/* ---- Showcase: masonry (handles every aspect ratio, no cropping) ---- */
.showcase{columns:4;column-gap:14px;margin-top:38px}
.showcase figure{break-inside:avoid;margin:0 0 14px;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-sm);line-height:0;background:#eadfdf}
.showcase img{width:100%;height:auto;transition:transform .6s var(--ease)}
.showcase figure:hover img{transform:scale(1.05)}
@media (max-width:960px){ .showcase{columns:3} }
@media (max-width:680px){ .showcase{columns:2;column-gap:10px} }

/* hero circle logo sizing */
.logo-hero.circle{width:clamp(170px,22vw,260px);margin-bottom:22px;
  filter:drop-shadow(0 8px 22px rgba(0,0,0,.45))}

/* clickable charity logos */
a.chip{cursor:pointer;text-decoration:none;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
a.chip:hover{transform:translateY(-4px);box-shadow:0 12px 26px rgba(170,30,33,.18)}
a.chip:focus-visible{outline:3px solid var(--teal-dark);outline-offset:3px}

/* ============================================================
   TWINKLE / GOOD TIDINGS LLC (Twinkle logo is the only
   permitted brand-color exception; all design stays Jolly Elf)
   ============================================================ */
.section.brands{background:#f0fafa}
.twinkle-logo{display:block;width:clamp(168px,24vw,216px);height:auto;margin:32px auto 22px;
  filter:drop-shadow(0 8px 20px rgba(15,75,82,.16))}
.twinkle-link{display:inline-block;color:var(--teal-dark);font-weight:700;text-decoration:none;
  border-bottom:2px solid currentColor;padding-bottom:2px;transition:color .2s var(--ease),transform .2s var(--ease)}
.twinkle-link:hover{color:var(--teal-deep);transform:translateY(-1px)}
.twinkle-link .arr{transition:transform .2s var(--ease)}
.twinkle-link:hover .arr{transform:translateX(4px)}

/* location-card Twinkle treatment (Barley's + Blue Moose / KC Hopps) */
.loc-twinkle{display:flex;flex-direction:column;align-items:center;gap:10px;margin:4px 0 14px}
.loc-twinkle img{height:88px;width:auto}
.loc-disclosure{font-size:13px;line-height:1.4;color:var(--teal-dark);font-weight:500;max-width:34ch;margin:0 auto}
.loc-disclosure b{font-weight:800}
.loc-twinkle-link{display:inline-block;margin-top:12px;color:var(--teal-dark);font-weight:700;font-size:14px;
  text-decoration:underline;text-underline-offset:3px}
.loc-twinkle-link:hover{color:var(--teal-deep)}

/* ---- Differentiators: keep headline clear of the corner candy canes ---- */
.diff h2{max-width:560px;margin-inline:auto}
@media (max-width:860px){ .deco-cane{display:none} }
