/* Southern Yankee Pizza — Chicago deep dish, Powell TN
   Palette grounded in the product: charred oven, deep-dish sauce, golden crust, mozzarella, basil. */
:root{
  --char:#1E1411;       /* charred oven brown-black */
  --char-2:#2A1C17;     /* warm dark surface */
  --char-3:#382520;     /* raised dark */
  --brick:#B5331F;      /* deep-dish sauce red — PRIMARY accent */
  --brick-bright:#CB4329;/* hover red */
  --crust:#D08A36;      /* golden crust — warm accent (dark grounds only) */
  --crust-deep:#A96A22;
  --cream:#F4E7CC;      /* cornmeal cream — light paper bg */
  --cream-2:#EADCBE;
  --mozz:#FBF6EC;       /* mozzarella near-white */
  --basil:#5C7C45;      /* herb green — secondary accent */
  --basil-deep:#466134;
  --ink:#241712;        /* text on cream */
  --ink-soft:#5A4A40;   /* muted text on cream (AA: ~6:1) */
  --paper-mute:#7A6452;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:"Newsreader",Georgia,serif;
  background:var(--cream);
  color:var(--ink);
  font-size:18px;line-height:1.62;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,.disp,.eyebrow,.btn,.nav,label,input,textarea,select,button{
  font-family:"Bricolage Grotesque","Segoe UI",system-ui,sans-serif;
}
h1,h2,h3,h4{line-height:1.02;letter-spacing:-.015em;font-weight:800;color:var(--ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{
  font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brick);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--brick);display:inline-block}
.eyebrow.on-dark{color:var(--crust)}
.eyebrow.on-dark::before{background:var(--crust)}
.section{padding:clamp(64px,9vw,124px) 0}
.lead{font-size:clamp(19px,2.2vw,23px);color:var(--ink-soft);max-width:60ch}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-size:15px;font-weight:700;letter-spacing:.02em;
  padding:15px 26px;border:2px solid transparent;cursor:pointer;
  transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);
  text-transform:uppercase;
}
.btn-primary{background:var(--brick);color:var(--mozz);border-color:var(--brick)}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--brick-bright);border-color:var(--brick-bright)}
.btn-ghost{background:transparent;color:var(--mozz);border-color:rgba(251,246,236,.45)}
.btn-ghost:hover,.btn-ghost:focus-visible{border-color:var(--crust);color:var(--crust)}
.btn-dark{background:var(--char);color:var(--mozz);border-color:var(--char)}
.btn-dark:hover,.btn-dark:focus-visible{background:var(--brick);border-color:var(--brick)}
:focus-visible{outline:3px solid var(--crust);outline-offset:3px}

/* ---------- header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  padding:18px 0;transition:background .3s var(--ease),padding .3s var(--ease),box-shadow .3s var(--ease);
}
.site-header::before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(20,12,9,.55),transparent);pointer-events:none;opacity:1;transition:opacity .3s}
.site-header.solid{background:var(--char);padding:11px 0;box-shadow:0 1px 0 rgba(208,138,54,.25)}
.site-header.solid::before{opacity:0}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:20px;position:relative}
.brand{display:flex;align-items:center;gap:12px;color:var(--mozz)}
.brand svg{width:34px;height:34px;flex:none}
.brand .bt{display:flex;flex-direction:column;line-height:1}
.brand .bt b{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:18px;letter-spacing:.01em}
.brand .bt span{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--crust);margin-top:3px}
.nav{display:flex;align-items:center;gap:30px}
.nav a{color:var(--mozz);font-size:14.5px;font-weight:600;letter-spacing:.01em;position:relative;padding:4px 0}
.nav a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--crust);transition:width .28s var(--ease)}
.nav a:not(.btn):hover::after,.nav a:not(.btn):focus-visible::after{width:100%}
.nav a.btn{padding:11px 20px;text-transform:uppercase;font-size:13px}
.nav a.btn:hover::after{display:none}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;color:var(--mozz);padding:6px}
.menu-toggle svg{width:28px;height:28px}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--char);color:var(--mozz);overflow:hidden;
  padding:170px 0 96px;min-height:100vh;display:flex;align-items:center}
.hero-glow{position:absolute;inset:0;background:
   radial-gradient(120% 80% at 18% 88%, rgba(181,51,31,.34), transparent 55%),
   radial-gradient(90% 70% at 92% 8%, rgba(208,138,54,.18), transparent 60%);
  pointer-events:none}
.hero-grain{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.025) 1px,transparent 1px);background-size:4px 4px}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;width:100%}
.hero h1{font-size:clamp(48px,8.4vw,116px);color:var(--mozz);letter-spacing:-.025em}
.hero h1 .pz{color:var(--brick);display:block}
.hero .sub{font-size:clamp(18px,2.3vw,22px);color:var(--cream);max-width:46ch;margin:26px 0 34px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap}
.hero-art{position:relative;display:flex;justify-content:center;align-items:center}
.hero-art svg{width:min(100%,420px);height:auto;filter:drop-shadow(0 24px 50px rgba(0,0,0,.5))}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--crust);font-family:"Bricolage Grotesque",sans-serif;opacity:.85}

/* ---------- trust strip ---------- */
.trust{background:var(--char-2);color:var(--mozz);border-top:1px solid rgba(208,138,54,.22)}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.trust .ti{padding:30px 24px;border-right:1px solid rgba(208,138,54,.18);transition:background .25s var(--ease)}
.trust .ti:last-child{border-right:0}
.trust .ti:hover{background:var(--char-3)}
.trust .tn{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:30px;color:var(--crust);display:flex;align-items:center;gap:7px}
.trust .tl{font-size:13.5px;letter-spacing:.04em;color:var(--cream);margin-top:4px;font-family:"Bricolage Grotesque",sans-serif;font-weight:500}
.stars{color:var(--crust);letter-spacing:1px;font-size:18px}

/* ---------- section heads ---------- */
.shead{max-width:64ch;margin-bottom:clamp(34px,5vw,58px)}
.shead h2{font-size:clamp(34px,5.4vw,62px);margin:14px 0 16px}
.shead.center{margin-left:auto;margin-right:auto;text-align:center}
.shead.center .eyebrow{justify-content:center}

/* ---------- menu ---------- */
.menu{background:var(--cream)}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(28px,4vw,56px)}
.mcat{}
.mcat h3{font-size:24px;display:flex;align-items:baseline;gap:12px;color:var(--ink);
  padding-bottom:12px;border-bottom:2px solid var(--brick);margin-bottom:6px}
.mcat h3 .ci{font-family:"Newsreader",serif;font-style:italic;font-weight:400;font-size:15px;color:var(--paper-mute);letter-spacing:0;text-transform:none;margin-left:auto}
.mrow{display:flex;gap:14px;align-items:flex-start;padding:16px 12px 16px 0;border-bottom:1px solid rgba(36,23,18,.1);position:relative;transition:padding .25s var(--ease)}
.mrow::before{content:"";position:absolute;left:-14px;top:50%;transform:translateY(-50%) scaleY(0);
  width:4px;height:62%;background:var(--brick);transition:transform .25s var(--ease)}
.mrow:hover{padding-left:14px}
.mrow:hover::before{transform:translateY(-50%) scaleY(1)}
.mrow:hover .mh{color:var(--brick)}
.mrow .mh{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:17.5px;color:var(--ink);transition:color .25s var(--ease)}
.mrow .md{font-size:15px;color:var(--ink-soft);line-height:1.5;margin-top:3px}
.menu-note{margin-top:34px;font-size:15px;color:var(--paper-mute);font-style:italic;border-left:3px solid var(--crust);padding:6px 0 6px 16px}

/* ---------- about (dark band) ---------- */
.about{background:var(--char);color:var(--cream)}
.about .eyebrow{color:var(--crust)}.about .eyebrow::before{background:var(--crust)}
.about h2{color:var(--mozz)}
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,80px);align-items:center}
.about p{margin-bottom:18px;color:var(--cream)}
.about p strong{color:var(--mozz);font-weight:600}
.about-card{background:var(--char-2);border:1px solid rgba(208,138,54,.28);padding:38px 34px;position:relative}
.about-card .qmark{font-family:"Bricolage Grotesque",sans-serif;font-size:64px;color:var(--brick);line-height:.6}
.about-card blockquote{font-family:"Newsreader",serif;font-style:italic;font-size:21px;line-height:1.5;color:var(--mozz);margin:6px 0 20px}
.about-card .sig{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:14px;letter-spacing:.06em;color:var(--crust);text-transform:uppercase}
.about-card .sigsub{font-size:13px;color:var(--paper-mute);margin-top:2px;font-family:"Bricolage Grotesque",sans-serif}

/* ---------- find us ---------- */
.find{background:var(--cream-2)}
.find-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,52px);align-items:start}
.hours{border:2px solid var(--ink);background:var(--cream)}
.hours .hh{background:var(--char);color:var(--mozz);padding:16px 22px;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;letter-spacing:.04em;display:flex;justify-content:space-between;align-items:center}
.hours .hh .pin{color:var(--crust);font-size:13px}
.hrow{display:flex;justify-content:space-between;padding:13px 22px;border-bottom:1px solid rgba(36,23,18,.1);transition:background .2s var(--ease)}
.hrow:last-child{border-bottom:0}
.hrow:hover{background:var(--cream-2)}
.hrow .d{font-family:"Bricolage Grotesque",sans-serif;font-weight:600;font-size:15px}
.hrow .t{font-size:15.5px;color:var(--ink-soft)}
.hrow.closed .t{color:var(--brick);font-weight:600;font-family:"Bricolage Grotesque",sans-serif;font-size:14px}
.find-copy h3{font-size:28px;margin-bottom:14px}
.find-copy p{color:var(--ink-soft);margin-bottom:18px;max-width:46ch}
.find-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.social-line{display:flex;gap:18px;margin-top:24px}
.social-line a{display:inline-flex;align-items:center;gap:8px;font-family:"Bricolage Grotesque",sans-serif;font-weight:600;font-size:14px;color:var(--ink);transition:color .2s var(--ease)}
.social-line a svg{width:20px;height:20px}
.social-line a:hover{color:var(--brick)}

/* ---------- reviews band ---------- */
.rev{background:var(--brick);color:var(--mozz);text-align:center}
.rev .big{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:clamp(40px,7vw,76px);line-height:1}
.rev .stars{color:var(--crust);font-size:clamp(26px,4vw,38px);margin:10px 0 6px;letter-spacing:3px}
.rev p{color:var(--cream);max-width:48ch;margin:8px auto 0}

/* ---------- faq ---------- */
.faq{background:var(--cream)}
.faq-list{max-width:820px;margin:0 auto;border-top:1px solid rgba(36,23,18,.15)}
.faq-item{border-bottom:1px solid rgba(36,23,18,.15)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;
  padding:22px 44px 22px 0;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:18.5px;color:var(--ink);
  position:relative;transition:color .2s var(--ease)}
.faq-q:hover{color:var(--brick)}
.faq-q .pm{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:18px;height:18px}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--brick);transition:transform .25s var(--ease)}
.faq-q .pm::before{left:0;top:8px;width:18px;height:2px}
.faq-q .pm::after{left:8px;top:0;width:2px;height:18px}
.faq-item.open .pm::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-a p{padding:0 0 22px;color:var(--ink-soft);font-size:16.5px;max-width:64ch}

/* ---------- order form ---------- */
.order{background:var(--char);color:var(--cream)}
.order .eyebrow{color:var(--crust)}.order .eyebrow::before{background:var(--crust)}
.order h2{color:var(--mozz)}
.order-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,6vw,72px);align-items:start}
.order-copy p{color:var(--cream);margin-bottom:18px}
.order-copy .callbig{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:clamp(26px,3.4vw,38px);color:var(--crust);display:inline-block;margin:6px 0 8px}
.order-copy .callbig:hover{color:var(--mozz)}
form{display:grid;gap:16px}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-size:12.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--crust);margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;background:var(--char-2);border:1.5px solid rgba(208,138,54,.3);color:var(--mozz);
  padding:13px 15px;font-size:16px;font-family:"Newsreader",serif;transition:border-color .2s var(--ease),background .2s}
.field textarea{resize:vertical;min-height:120px}
.field input::placeholder,.field textarea::placeholder{color:#9a8576}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--crust);background:var(--char-3)}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--brick-bright)}
.field .err{display:none;color:#F0A58E;font-family:"Bricolage Grotesque",sans-serif;font-size:12.5px;margin-top:6px}
.field.invalid .err{display:block}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-success{display:none;background:var(--char-2);border:1px solid var(--basil);padding:40px 34px;text-align:center}
.form-success.show{display:block}
.form-success svg{width:46px;height:46px;margin:0 auto 14px}
.form-success h3{color:var(--mozz);font-size:24px;margin-bottom:10px}
.form-success p{color:var(--cream);max-width:44ch;margin:0 auto}
select option{color:#fff;background:var(--char-2)}

/* ---------- location panel ---------- */
.loc{background:var(--char-2);color:var(--cream)}
.loc-panel{position:relative;border:1px solid rgba(208,138,54,.3);background:
   radial-gradient(120% 120% at 80% 10%, rgba(181,51,31,.16), transparent 60%),var(--char);
  overflow:hidden;display:grid;grid-template-columns:1fr 1fr;min-height:340px}
.loc-map{position:relative;overflow:hidden;border-right:1px solid rgba(208,138,54,.25)}
.loc-map svg{position:absolute;inset:0;width:100%;height:100%}
.loc-pin{position:absolute;left:50%;top:50%;transform:translate(-50%,-100%);z-index:2;text-align:center}
.loc-pin .pinmark{width:46px;height:46px;margin:0 auto}
.loc-pin .pinlbl{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:13px;letter-spacing:.06em;color:var(--mozz);margin-top:6px;text-transform:uppercase}
.loc-info{padding:clamp(30px,4vw,48px);display:flex;flex-direction:column;justify-content:center}
.loc-info h3{color:var(--mozz);font-size:28px;margin-bottom:8px}
.loc-info .addr{color:var(--cream);font-size:17px;margin-bottom:6px}
.loc-info .muted{color:var(--paper-mute);font-size:15px;margin-bottom:22px}

/* ---------- footer ---------- */
.site-footer{background:var(--char);color:var(--cream);padding:64px 0 30px;border-top:3px solid var(--brick)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(208,138,54,.2)}
.foot-brand{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.foot-brand svg{width:54px;height:54px}
.foot-brand .bt b{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:24px;color:var(--mozz);display:block;line-height:1}
.foot-brand .bt span{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--crust)}
.foot-col h4{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--crust);margin-bottom:16px}
.foot-col a,.foot-col p{display:block;color:var(--cream);font-size:15px;margin-bottom:10px;font-family:"Bricolage Grotesque",sans-serif;font-weight:500;transition:color .2s var(--ease)}
.foot-col a:hover{color:var(--crust)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:24px;flex-wrap:wrap}
.foot-bottom p{font-size:13px;color:var(--paper-mute);font-family:"Bricolage Grotesque",sans-serif}
.foot-bottom .disc{max-width:60ch}

/* ---------- reveal ---------- */
.js-ready .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js-ready .reveal.in{opacity:1;transform:none}
.js-ready .stagger>*{opacity:0;transform:translateY(18px)}
.js-ready .stagger.in>*{opacity:1;transform:none;transition:opacity .6s var(--ease),transform .6s var(--ease)}
@media (prefers-reduced-motion:reduce){
  .js-ready .reveal,.js-ready .stagger>*{opacity:1!important;transform:none!important;transition:none!important}
}

/* ---------- hero entrance ---------- */
.js-ready .hero .anim{opacity:0;transform:translateY(26px)}
.hero.entered .anim{opacity:1;transform:none;transition:opacity .8s var(--ease),transform .8s var(--ease)}
.hero.entered .anim.d1{transition-delay:.08s}
.hero.entered .anim.d2{transition-delay:.18s}
.hero.entered .anim.d3{transition-delay:.30s}
.hero.entered .anim.d4{transition-delay:.42s}
.hero-art .draw{stroke-dasharray:var(--len);stroke-dashoffset:var(--len)}
.hero.entered .hero-art .draw{animation:draw 1.6s var(--ease) .4s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@media (prefers-reduced-motion:reduce){
  .js-ready .hero .anim{opacity:1;transform:none}
  .hero-art .draw{stroke-dashoffset:0}
}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:30px}
  .hero-art{order:-1;max-width:300px;margin:0 auto}
  .hero-art svg{width:240px}
  .about-grid,.find-grid,.order-grid,.menu-grid{grid-template-columns:1fr}
  .trust .wrap{grid-template-columns:1fr 1fr}
  .trust .ti:nth-child(2){border-right:0}
  .trust .ti:nth-child(1),.trust .ti:nth-child(2){border-bottom:1px solid rgba(208,138,54,.18)}
  .foot-top{grid-template-columns:1fr 1fr}
  .loc-panel{grid-template-columns:1fr}
  .loc-map{min-height:240px;border-right:0;border-bottom:1px solid rgba(208,138,54,.25)}
}
@media (max-width:640px){
  body{font-size:17px}
  .nav{display:none;position:absolute;top:calc(100% + 8px);right:0;left:0;
    flex-direction:column;align-items:stretch;gap:0;background:var(--char);border:1px solid rgba(208,138,54,.3);padding:8px}
  .nav.open{display:flex}
  .nav a{padding:14px 12px;border-bottom:1px solid rgba(208,138,54,.14)}
  .nav a:not(.btn)::after{display:none}
  .nav a.btn{margin:8px;text-align:center;justify-content:center}
  .menu-toggle{display:block}
  .hero{min-height:auto;padding:140px 0 72px}
  .section{padding:58px 0}
  .f2{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;align-items:flex-start}
  .scroll-cue{display:none}
}
