/*
Theme Name: Mooslover
Theme URI: https://mooslover.xyz
Author: Sofia Digital
Author URI: https://sofia.enterprises
Description: Premium custom theme for Mooslover — an artisan ice cream & dessert bar. Editorial, dark-moody, mobile-first. Built bespoke (no page builder) with full Customizer business settings, JSON-LD schema, and conversion-driven sections.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mooslover
*/

/* ============================================================
   DESIGN TOKENS  (colors are overridden inline from Customizer)
   ============================================================ */
:root{
  --base:#15100d;          /* warm espresso near-black */
  --base-2:#1f1813;        /* raised surface */
  --base-3:#2a201a;        /* card / border surface */
  --cream:#f7efe4;         /* primary light text / light bg */
  --cream-soft:#efe4d4;
  --muted:#b7a99a;         /* muted text on dark */
  --line:rgba(247,239,228,.12);
  --accent:#ff5d8a;        /* strawberry-cream */
  --accent-2:#e8b06a;      /* caramel gold */
  --accent-ink:#2a0f18;    /* readable text on accent */
  --maxw:1240px;
  --pad:clamp(20px,5vw,40px);
  --sec:clamp(64px,9vw,118px);
  --r:18px;
  --r-lg:26px;
  --shadow:0 24px 60px -24px rgba(0,0,0,.65);
  --t:.35s cubic-bezier(.2,.7,.2,1);
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}

/* ============================================================ RESET */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--base);color:var(--cream);font-family:var(--sans);
  font-size:17px;line-height:1.65;font-weight:400;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;padding-bottom:0}
body.has-mobilebar{padding-bottom:64px}
@media(min-width:861px){body.has-mobilebar{padding-bottom:0}}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--serif);font-weight:560;line-height:1.05;margin:0 0 .4em;
  letter-spacing:-.01em;font-optical-sizing:auto}
p{margin:0 0 1.1em}
ul{margin:0;padding:0}
::selection{background:var(--accent);color:var(--accent-ink)}

/* ============================================================ LAYOUT */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.section{padding-top:var(--sec);padding-bottom:var(--sec);position:relative}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:12.5px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--accent);margin:0 0 18px;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);display:inline-block;opacity:.7}
.h-xl{font-size:clamp(38px,7.2vw,86px)}
.h-lg{font-size:clamp(32px,5.2vw,60px)}
.h-md{font-size:clamp(25px,3.4vw,38px)}
.lede{font-size:clamp(17px,2.1vw,21px);color:var(--muted);max-width:62ch;line-height:1.7}
.center{text-align:center}
.center .eyebrow{justify-content:center}
.center .lede{margin-left:auto;margin-right:auto}

/* ============================================================ BUTTONS */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:600;
  font-size:15px;letter-spacing:.01em;padding:15px 30px;border-radius:100px;border:1px solid transparent;
  transition:transform var(--t),background var(--t),color var(--t),box-shadow var(--t);will-change:transform;line-height:1}
.btn svg{width:18px;height:18px}
.btn--primary{background:var(--accent);color:var(--accent-ink);box-shadow:0 14px 30px -12px rgba(255,93,138,.6)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 22px 42px -14px rgba(255,93,138,.75)}
.btn--ghost{background:transparent;color:var(--cream);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--cream);transform:translateY(-3px)}
.btn--dark{background:var(--base);color:var(--cream)}
.btn--dark:hover{transform:translateY(-3px)}
.btn--lg{padding:18px 38px;font-size:16px}

/* ============================================================ HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:90;transition:background var(--t),box-shadow var(--t),padding var(--t);
  padding:20px 0}
.site-header.scrolled{background:rgba(21,16,13,.86);backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line);padding:12px 0}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-weight:600;font-size:24px;letter-spacing:-.02em;color:var(--cream)}
.brand .dot{color:var(--accent)}
.brand img{max-height:46px;width:auto}
.nav-main{display:flex;align-items:center;gap:34px}
.nav-main a{font-size:15px;font-weight:500;color:var(--cream);opacity:.85;transition:opacity var(--t);position:relative}
.nav-main a:hover{opacity:1}
.nav-main a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--accent);transition:width var(--t)}
.nav-main a:hover::after{width:100%}
.hdr-cta{display:flex;align-items:center;gap:16px}
.hdr-phone{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;color:var(--cream)}
.hdr-phone svg{width:16px;height:16px;color:var(--accent)}
.burger{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:50%;background:transparent;
  align-items:center;justify-content:center;flex-direction:column;gap:5px}
.burger span{width:20px;height:2px;background:var(--cream);transition:var(--t)}

/* mobile nav overlay */
.mobile-nav{position:fixed;inset:0;z-index:200;background:rgba(18,13,10,.98);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;justify-content:center;padding:40px var(--pad);
  opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s ease}
.mobile-nav.open{opacity:1;visibility:visible}
.mobile-nav a{font-family:var(--serif);font-size:clamp(30px,9vw,46px);color:var(--cream);padding:10px 0;
  border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.mobile-nav a span{color:var(--accent);font-size:18px}
.mobile-nav .mn-foot{margin-top:34px;display:flex;flex-direction:column;gap:14px;font-family:var(--sans)}
.mn-close{position:absolute;top:24px;right:var(--pad);width:48px;height:48px;border-radius:50%;
  border:1px solid var(--line);background:transparent;color:var(--cream);font-size:24px}

/* ============================================================ HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding:120px 0 clamp(56px,8vw,96px);overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,11,9,.55) 0%,rgba(15,11,9,.35) 38%,rgba(15,11,9,.92) 100%),
  radial-gradient(120% 80% at 80% 20%,rgba(255,93,138,.18),transparent 60%)}
.hero__inner{position:relative;max-width:980px}
.hero h1{margin:.12em 0 .28em}
.hero .lede{color:var(--cream-soft);max-width:54ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero__meta{display:flex;flex-wrap:wrap;gap:22px 34px;margin-top:40px;padding-top:28px;border-top:1px solid var(--line)}
.hero__meta div{min-width:90px}
.hero__meta b{display:block;font-family:var(--serif);font-size:26px;line-height:1}
.hero__meta span{font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.scroll-hint{position:absolute;bottom:26px;right:var(--pad);writing-mode:vertical-rl;font-size:11px;
  letter-spacing:.3em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:12px}
.scroll-hint::after{content:"";width:1px;height:46px;background:linear-gradient(var(--accent),transparent)}

/* ============================================================ MARQUEE / PROOF STRIP */
.proof{background:var(--accent);color:var(--accent-ink);padding:18px 0;overflow:hidden}
.proof-track{display:flex;gap:48px;white-space:nowrap;width:max-content;animation:marq 32s linear infinite;font-family:var(--serif);
  font-size:20px;align-items:center}
.proof-track span{display:inline-flex;align-items:center;gap:48px;font-weight:500}
.proof-track i{font-style:normal;opacity:.6}
@keyframes marq{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.proof-track{animation:none}}

/* social-proof badges row */
.badges{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.badge{background:var(--base-2);border:1px solid var(--line);border-radius:var(--r);padding:26px 22px;text-align:center;transition:transform var(--t),border-color var(--t)}
.badge:hover{transform:translateY(-4px);border-color:rgba(255,93,138,.4)}
.badge b{display:block;font-family:var(--serif);font-size:34px;color:var(--cream);line-height:1}
.badge .stars{color:var(--accent-2);font-size:15px;letter-spacing:2px;margin:8px 0 4px}
.badge span{font-size:13px;color:var(--muted);letter-spacing:.04em}

/* ============================================================ MENU / CORE OFFERING */
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.mcard{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--base-2);border:1px solid var(--line);
  min-height:420px;display:flex;flex-direction:column;justify-content:flex-end;isolation:isolate;transition:transform var(--t)}
.mcard:hover{transform:translateY(-6px)}
.mcard__img{position:absolute;inset:0;z-index:-1}
.mcard__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.mcard:hover .mcard__img img{transform:scale(1.07)}
.mcard__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,11,9,0) 30%,rgba(15,11,9,.9) 100%)}
.mcard__body{padding:26px 26px 28px;position:relative}
.mcard__tag{position:absolute;top:-2px;right:26px;transform:translateY(-100%);background:var(--accent);color:var(--accent-ink);
  font-size:12px;font-weight:700;letter-spacing:.04em;padding:6px 12px;border-radius:100px}
.mcard h3{font-size:25px;margin:0 0 6px}
.mcard p{font-size:14.5px;color:var(--cream-soft);margin:0}
.mcard .price{font-family:var(--serif);color:var(--accent-2);font-size:18px;margin-top:12px;display:inline-block}

/* simple list menu (menu page) */
.menulist{display:grid;grid-template-columns:1fr 1fr;gap:14px 54px;margin-top:14px}
.menu-row{display:flex;align-items:baseline;gap:14px;padding:14px 0;border-bottom:1px dashed var(--line)}
.menu-row .nm{font-family:var(--serif);font-size:20px;color:var(--cream);white-space:nowrap}
.menu-row .ds{font-size:14px;color:var(--muted);flex:1}
.menu-row .pr{font-family:var(--serif);color:var(--accent-2);font-size:18px}
.menu-row .leader{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-4px)}

/* ============================================================ STORY / ABOUT */
.story{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,6vw,80px);align-items:center}
.story__media{position:relative}
.story__media img{border-radius:var(--r-lg);width:100%;aspect-ratio:3/4;object-fit:cover;box-shadow:var(--shadow)}
.story__media .chip{position:absolute;left:-22px;bottom:34px;background:var(--cream);color:var(--base);
  padding:20px 24px;border-radius:var(--r);max-width:230px;box-shadow:var(--shadow)}
.story__media .chip b{font-family:var(--serif);font-size:40px;display:block;line-height:1;color:var(--accent)}
.story__media .chip span{font-size:13.5px;font-weight:500}
.story blockquote{font-family:var(--serif);font-size:clamp(20px,2.4vw,26px);line-height:1.4;color:var(--cream);
  border-left:3px solid var(--accent);padding-left:22px;margin:26px 0}

/* ============================================================ PROCESS / USP */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px;counter-reset:s}
.step{background:linear-gradient(180deg,var(--base-2),var(--base));border:1px solid var(--line);border-radius:var(--r-lg);
  padding:38px 30px;transition:transform var(--t),border-color var(--t)}
.step:hover{transform:translateY(-6px);border-color:rgba(232,176,106,.45)}
.step .ic{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,93,138,.12);color:var(--accent);margin-bottom:20px}
.step .ic svg{width:28px;height:28px}
.step::before{counter-increment:s;content:"0" counter(s);font-family:var(--serif);font-size:15px;color:var(--accent-2);
  letter-spacing:.1em;display:block;margin-bottom:8px}
.step h3{font-size:22px}
.step p{font-size:15px;color:var(--muted);margin:0}

/* ============================================================ TESTIMONIALS */
.tcols{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.tcard{background:var(--base-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 30px;
  display:flex;flex-direction:column;gap:18px;transition:transform var(--t)}
.tcard:hover{transform:translateY(-6px)}
.tcard .stars{color:var(--accent-2);letter-spacing:3px;font-size:15px}
.tcard p{font-family:var(--serif);font-size:19px;line-height:1.5;color:var(--cream);margin:0}
.tcard .who{display:flex;align-items:center;gap:13px;margin-top:auto}
.tcard .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:600;color:var(--accent-ink);font-size:18px}
.tcard .who b{font-size:15px;display:block}
.tcard .who span{font-size:13px;color:var(--muted)}

/* ============================================================ GALLERY MASONRY */
.gallery{columns:3;column-gap:16px;margin-top:48px}
.gallery figure{margin:0 0 16px;break-inside:avoid;border-radius:var(--r);overflow:hidden;position:relative}
.gallery img{width:100%;display:block;transition:transform .6s ease,filter var(--t)}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figcaption{position:absolute;left:14px;bottom:12px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:#fff;opacity:0;transform:translateY(8px);transition:var(--t);z-index:2;text-shadow:0 2px 10px rgba(0,0,0,.6)}
.gallery figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.55));
  opacity:0;transition:var(--t)}
.gallery figure:hover::after{opacity:1}
.gallery figure:hover figcaption{opacity:1;transform:none}

/* ============================================================ FAQ ACCORDION */
.faq{max-width:860px;margin:48px auto 0}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{list-style:none;cursor:pointer;padding:22px 48px 22px 0;position:relative;font-family:var(--serif);
  font-size:clamp(18px,2.3vw,22px);color:var(--cream)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:var(--sans);
  font-size:26px;color:var(--accent);transition:var(--t)}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq .ans{padding:0 40px 22px 0;color:var(--muted);font-size:16px}

/* ============================================================ LOCATION / MAP */
.loc{display:grid;grid-template-columns:.9fr 1.1fr;gap:0;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);margin-top:48px}
.loc__info{background:var(--base-2);padding:clamp(32px,4vw,52px)}
.loc__info h3{font-size:28px}
.loc__row{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.loc__row svg{width:20px;height:20px;color:var(--accent);flex:none;margin-top:3px}
.loc__row b{display:block;font-size:14px;letter-spacing:.04em}
.loc__row span{font-size:14.5px;color:var(--muted)}
.loc__map{min-height:380px}
.loc__map iframe{width:100%;height:100%;min-height:380px;border:0;filter:grayscale(.3) contrast(1.05)}

.hours-table{width:100%;border-collapse:collapse;margin-top:6px}
.hours-table td{padding:9px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.hours-table td:last-child{text-align:right;color:var(--cream-soft)}
.hours-table tr.today td{color:var(--accent)}
.hours-table tr.today td:first-child::after{content:" • Today";font-size:11px;letter-spacing:.1em}

/* ============================================================ FINAL CTA */
.finalcta{position:relative;text-align:center;border-radius:var(--r-lg);overflow:hidden;
  padding:clamp(56px,9vw,108px) var(--pad);margin:0 auto;max-width:var(--maxw)}
.finalcta::before{content:"";position:absolute;inset:0;background:
  radial-gradient(80% 120% at 50% 0%,rgba(255,93,138,.35),transparent 60%),var(--base-2);z-index:-1}
.finalcta .btn-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:30px}

/* ============================================================ FOOTER */
.site-footer{background:#100c09;border-top:1px solid var(--line);padding:72px 0 0}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px}
.foot-grid h4{font-family:var(--sans);font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:18px}
.foot-brand .brand{margin-bottom:16px}
.foot-brand p{color:var(--muted);font-size:14.5px;max-width:34ch}
.foot-links a{display:block;color:var(--cream);opacity:.8;padding:7px 0;font-size:14.5px;transition:opacity var(--t),padding-left var(--t)}
.foot-links a:hover{opacity:1;padding-left:6px;color:var(--accent)}
.foot-social{display:flex;gap:12px;margin-top:8px}
.foot-social a{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--t)}
.foot-social a:hover{background:var(--accent);color:var(--accent-ink);border-color:var(--accent);transform:translateY(-3px)}
.foot-social svg{width:18px;height:18px}
.foot-bottom{border-top:1px solid var(--line);margin-top:56px;padding:24px 0;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:12px;font-size:13px;color:var(--muted)}
.foot-bottom a:hover{color:var(--accent)}

/* ============================================================ MOBILE BOTTOM BAR */
.mobilebar{position:fixed;left:0;right:0;bottom:0;z-index:120;height:64px;display:none;
  grid-template-columns:1fr 1fr 1.3fr;background:var(--accent);box-shadow:0 -8px 24px -10px rgba(0,0,0,.5)}
.mobilebar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:var(--accent-ink);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.mobilebar a svg{width:22px;height:22px}
.mobilebar a+a{border-left:1px solid rgba(42,15,24,.18)}
.mobilebar a.cta{background:var(--accent-ink);color:var(--cream)}

/* ============================================================ PAGE HERO (interior pages) */
.page-hero{padding:160px 0 64px;position:relative;text-align:center;border-bottom:1px solid var(--line)}
.page-hero .crumb{font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.page-hero .crumb a:hover{color:var(--accent)}
.entry{max-width:820px;margin:0 auto}
.entry h2{margin-top:1.4em}
.entry img{border-radius:var(--r);margin:1.4em 0}
.entry ul{padding-left:1.2em;margin:0 0 1.2em;list-style:disc}
.entry li{margin:.4em 0}

/* contact form */
.cform{display:grid;gap:16px}
.cform .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cform input,.cform textarea{width:100%;background:var(--base-2);border:1px solid var(--line);border-radius:12px;
  padding:15px 16px;color:var(--cream);font-family:inherit;font-size:15px;transition:border-color var(--t)}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--accent)}
.cform label{font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;display:block}

/* utility reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============================================================ RESPONSIVE */
@media(max-width:1024px){
  .menu-grid,.steps,.tcols{grid-template-columns:repeat(2,1fr)}
  .gallery{columns:2}
  .foot-grid{grid-template-columns:1fr 1fr}
  .loc{grid-template-columns:1fr}
  .story{grid-template-columns:1fr;gap:40px}
  .story__media img{aspect-ratio:16/11;max-width:560px}
  .menulist{grid-template-columns:1fr}
}
@media(max-width:860px){
  .nav-main,.hdr-phone{display:none}
  .burger{display:flex}
  .mobilebar{display:grid}
  .badges{grid-template-columns:repeat(2,1fr)}
  .hero{min-height:92svh}
}
@media(max-width:560px){
  .menu-grid,.steps,.tcols{grid-template-columns:1fr}
  .gallery{columns:1}
  .foot-grid{grid-template-columns:1fr}
  .cform .row{grid-template-columns:1fr}
  .hero__meta div{min-width:72px}
  .story__media .chip{left:0}
  .foot-bottom{justify-content:center;text-align:center}
}
