/*
Theme Name: Marhaba Grill
Theme URI: https://marhabagrill.com
Author: Marhaba Grill
Description: Custom Mediterranean fine-casual theme for Marhaba Grill — buffet, by-the-pound takeout, and à la carte ordering. Built to match the approved 2026 redesign.
Version: 1.0
Requires at least: 5.8
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: marhaba-grill
*/

:root{
  --ink:#17110a;--ink-2:#241a10;--cream:#f7f0e2;--cream-2:#efe5d2;--paper:#fbf6ec;
  --gold:#c4953f;--gold-lt:#ddb360;--terra:#b1542c;--muted:#8a7a63;--line:rgba(138,122,99,.28);
  --serif:'Cormorant Garamond',Georgia,serif;--sans:'Jost',-apple-system,Segoe UI,sans-serif;--script:'Great Vibes',cursive;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.65;font-weight:300;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.08}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1220px;margin:0 auto;padding:0 30px}
.eyebrow{font-family:var(--sans);font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:500}
.script{font-family:var(--script);color:var(--gold-lt);font-weight:400}
.btn{display:inline-block;font-family:var(--sans);font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;padding:16px 36px;border-radius:1px;transition:.3s;cursor:pointer;font-weight:500}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-lt)}
.btn-out{border:1px solid rgba(247,240,226,.6);color:var(--cream)}
.btn-out:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn-dark{border:1px solid var(--ink);color:var(--ink)}
.btn-dark:hover{background:var(--ink);color:var(--cream)}

.topbar{background:var(--ink);color:var(--cream);text-align:center;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;padding:8px 16px}
.topbar b{color:var(--gold-lt);font-weight:500}

header.site{position:sticky;top:0;z-index:100;background:rgba(23,17,10,0);transition:.4s}
header.site.solid{background:rgba(23,17,10,.97);box-shadow:0 8px 34px rgba(0,0,0,.28)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;transition:.4s}
header.site.solid .nav{padding:9px 0}
.brand{display:flex;align-items:center}
.brand img{height:64px;width:auto;transition:.4s;filter:drop-shadow(0 2px 7px rgba(0,0,0,.45))}
header.site.solid .brand img{height:50px}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{color:var(--cream);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:400;position:relative;transition:.25s}
.nav-links a:hover{color:var(--gold-lt)}
.nav-links a:not(.nav-cta)::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:.3s}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{background:var(--gold);color:var(--ink)!important;padding:11px 22px}
.nav-cta:hover{background:var(--gold-lt)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;z-index:120}
.burger span{width:26px;height:2px;background:var(--cream);transition:.3s}

.hero{position:relative;min-height:94vh;margin-top:-92px;display:flex;align-items:center;color:var(--cream);overflow:hidden}
.hero-bg{position:absolute;inset:0;background-position:center;background-size:cover;transform:scale(1.06)}
.hero-ov{position:absolute;inset:0;background:linear-gradient(105deg,rgba(15,11,6,.86) 0%,rgba(15,11,6,.6) 45%,rgba(15,11,6,.32) 100%)}
.hero-inner{position:relative;z-index:2;max-width:760px;padding:120px 0}
.hero .script{font-size:2.6rem;display:block;margin-bottom:6px}
.hero h1{font-size:clamp(2.9rem,6.6vw,5.4rem);color:var(--cream);margin-bottom:22px}
.hero h1 em{font-style:italic;color:var(--gold-lt);font-weight:500}
.hero p.lede{font-size:1.18rem;font-weight:300;color:#e9dec9;max-width:560px;margin-bottom:34px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{position:absolute;bottom:26px;right:30px;z-index:2;text-align:right;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#d9ccb2}
.hero-meta b{color:var(--gold-lt)}

.awards{background:var(--ink);color:var(--cream);padding:30px 0;border-top:1px solid rgba(196,149,63,.25);border-bottom:1px solid rgba(196,149,63,.25)}
.awards-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;align-items:center}
.aw{display:flex;align-items:center;gap:14px;justify-content:center}
.aw .ic{font-size:1.9rem;line-height:1}
.aw .t{font-family:var(--serif);font-size:1.35rem;font-weight:600;color:var(--cream)}
.aw .s{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.aw.new .t{color:var(--gold-lt)}
.aw.new .tag{display:inline-block;font-size:.54rem;background:var(--terra);color:#fff;padding:2px 7px;border-radius:10px;letter-spacing:.14em;margin-left:6px;vertical-align:middle}

section.blk{padding:108px 0}
.head{text-align:center;max-width:660px;margin:0 auto 64px}
.head .script{font-size:2rem;display:block;margin-bottom:2px}
.head h2{font-size:clamp(2.2rem,4.8vw,3.5rem);font-weight:600}
.head h2 em{font-style:italic;color:var(--terra)}
.head p{color:var(--muted);font-size:1.06rem;margin-top:14px}
.divider{width:54px;height:2px;background:var(--gold);margin:18px auto 0}

.ways{background:var(--paper)}
.ways-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.way{background:#fff;border:1px solid var(--line);padding:46px 32px;text-align:center;transition:.35s}
.way:hover{transform:translateY(-7px);box-shadow:0 28px 56px rgba(23,17,10,.13);border-color:var(--gold)}
.way .n{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--gold);margin-bottom:8px}
.way h3{font-size:1.7rem;margin-bottom:12px}
.way p{color:var(--muted);font-size:.97rem;margin-bottom:18px}
.way .tag{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terra);border:1px solid rgba(177,84,44,.35);padding:7px 15px;border-radius:20px;display:inline-block}

.split{display:grid;grid-template-columns:1.05fr 1fr;gap:74px;align-items:center}
.split .ph{position:relative}
.split .ph img{width:100%;height:560px;object-fit:cover}
.split .ph::after{content:'';position:absolute;inset:14px;border:1px solid rgba(196,149,63,.55);pointer-events:none}
.split h2{font-size:clamp(2rem,4.4vw,3.1rem);margin:8px 0 20px}
.split p{color:#5d5042;margin-bottom:17px;font-size:1.06rem}
.sign{font-family:var(--script);font-size:2.3rem;color:var(--terra);margin-top:6px}
.sign small{display:block;font-family:var(--sans);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:2px}

.band{position:relative;min-height:62vh;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--cream);background-position:center;background-size:cover;background-attachment:fixed}
.band .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,11,6,.55),rgba(15,11,6,.7))}
.band-in{position:relative;z-index:2;max-width:720px;padding:60px 30px}
.band .script{font-size:2.2rem;display:block;margin-bottom:8px}
.band h2{font-size:clamp(2.1rem,4.6vw,3.3rem);color:var(--cream);margin-bottom:16px}
.band p{color:#e6d9c2;font-size:1.1rem;font-weight:300}

.menu{background:var(--cream)}
.tabs{display:none;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:48px;overflow-x:auto;-webkit-overflow-scrolling:touch}
body.js .tabs{display:flex}
.tab{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;padding:11px 22px;border:1px solid var(--line);background:transparent;cursor:pointer;color:var(--ink);transition:.25s;font-family:var(--sans)}
.tab:hover{border-color:var(--gold)}
.tab.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.card{background:#fff;border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;transition:.35s}
.card:hover{transform:translateY(-6px);box-shadow:0 26px 50px rgba(23,17,10,.14)}
.card .img{height:220px;overflow:hidden;background:#efe7d8}
.card .img img{width:100%;height:100%;object-fit:cover;transition:.6s}
.card:hover .img img{transform:scale(1.07)}
.card .body{padding:24px 24px 26px;flex:1;display:flex;flex-direction:column}
.card .tt{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px}
.card h4{font-size:1.4rem;font-weight:600;line-height:1.1}
.card .pr{font-family:var(--serif);font-weight:600;font-size:1.3rem;color:var(--terra);white-space:nowrap}
.card p{color:var(--muted);font-size:.9rem;line-height:1.55}
.grp{display:grid;margin-bottom:46px}
.cat-label{font-family:var(--serif);font-style:italic;font-size:1.95rem;color:var(--terra);text-align:center;margin:0 0 24px}
body.js .cat-label{display:none}
body.js .grp{display:none;margin-bottom:0}
body.js .grp.show{display:grid}
.menu-note{text-align:center;margin-top:46px}
.menu-note .btn{margin:0 6px 10px}

.cater{background:var(--ink);color:var(--cream)}
.cater .split h2{color:var(--cream)}
.cater .split p{color:#c9bba2}
.cater .ph img{height:520px}
.cater ul{list-style:none;margin:6px 0 26px}
.cater li{padding:9px 0;border-bottom:1px solid rgba(196,149,63,.18);font-size:1rem;color:#e7dcc8;display:flex;align-items:center;gap:12px}
.cater li::before{content:'\2756';color:var(--gold);font-size:.8rem}

.order{background:var(--paper)}
.order-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.ocard{background:#fff;border:1px solid var(--line);padding:38px 24px;text-align:center;transition:.32s}
.ocard:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(23,17,10,.12);border-color:var(--gold)}
.ocard .ic{font-size:2.3rem;margin-bottom:12px}
.ocard h4{font-size:1.45rem;margin-bottom:7px}
.ocard p{color:var(--muted);font-size:.86rem;margin-bottom:18px;min-height:38px}
.ocard a.go{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terra);border-bottom:1px solid var(--gold);padding-bottom:3px}

.visit{position:relative;color:var(--cream);background-position:center;background-size:cover}
.visit .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,11,6,.82),rgba(15,11,6,.9))}
.visit .wrap{position:relative;z-index:2}
.visit .head h2{color:var(--cream)}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.vrow{display:flex;gap:18px;padding:20px 0;border-bottom:1px solid rgba(196,149,63,.22)}
.vrow .ic{font-size:1.4rem;color:var(--gold-lt);width:30px}
.vrow h4{font-size:1.35rem;color:var(--cream);margin-bottom:2px}
.vrow a,.vrow p{color:#ddd0ba;font-size:1rem}
.hours{background:rgba(23,17,10,.6);border:1px solid rgba(196,149,63,.3);padding:42px}
.hours h3{font-size:1.9rem;color:var(--gold-lt);margin-bottom:4px}
.hours .o365{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.hrow{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.hrow span:first-child{color:#e7dcc8}.hrow span:last-child{color:var(--gold-lt)}

/* generic page (about, catering, contact, ordering pages) */
.page-hero{background:var(--ink);color:var(--cream);text-align:center;padding:150px 0 70px;margin-top:-92px}
.page-hero h1{font-size:clamp(2.4rem,5vw,3.6rem);color:var(--cream)}
.page-hero .script{font-size:1.8rem;display:block;margin-bottom:4px}
.page-body{max-width:1100px;margin:0 auto;padding:70px 30px 100px}
.page-body h2{font-size:2rem;color:var(--terra);margin:30px 0 14px;font-style:italic}
.page-body p{margin-bottom:16px;color:#4f4438}
.page-body a{color:var(--terra)}

footer.site{background:#0f0b06;color:var(--cream);padding:64px 0 32px;text-align:center}
footer.site .flogo{height:auto;width:250px;max-width:80%;margin:0 auto 14px;display:block;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
footer.site .script{font-size:1.7rem;display:block;margin:6px 0 18px}
.socials{display:flex;gap:18px;justify-content:center;margin:22px 0}
.socials a{width:44px;height:44px;border:1px solid rgba(196,149,63,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold-lt);transition:.3s}
.socials a:hover{background:var(--gold);color:var(--ink)}
.fcopy{color:var(--muted);font-size:.76rem;letter-spacing:.08em;margin-top:18px}

@media(max-width:980px){
  .split,.visit-grid{grid-template-columns:1fr;gap:38px}
  .awards-row{grid-template-columns:1fr 1fr;gap:18px}
  .ways-grid{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:1fr 1fr}
  .order-grid{grid-template-columns:1fr 1fr}
  .band{background-attachment:scroll}
  .split .ph img,.cater .ph img{height:420px}
}
@media(max-width:680px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:80%;max-width:320px;background:var(--ink);flex-direction:column;justify-content:center;gap:30px;transform:translateX(100%);transition:.4s}
  .nav-links.open{transform:translateX(0)}
  .burger{display:flex}
  header.site{background:rgba(23,17,10,.97)}
  .hero{margin-top:-74px}
  .page-hero{margin-top:-74px}
  .menu-grid,.order-grid{grid-template-columns:1fr}
  .hero-meta{display:none}
  section.blk{padding:74px 0}
  .hero-btns .btn{flex:1;text-align:center}
}

/* ===== awards: 3 across ===== */
.awards-row{grid-template-columns:repeat(3,1fr)}

/* ===== Order Now dropdown ===== */
.has-drop{position:relative}
.has-drop .caret{font-size:.7em;opacity:.85;margin-left:3px;display:inline-block;transition:.3s}
.drop{position:absolute;top:calc(100% + 12px);right:0;min-width:256px;background:var(--ink);border:1px solid rgba(196,149,63,.35);box-shadow:0 18px 50px rgba(0,0,0,.45);list-style:none;padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.28s;z-index:130}
.has-drop:hover .drop,.has-drop.open .drop{opacity:1;visibility:visible;transform:none}
.has-drop:hover .caret,.has-drop.open .caret{transform:rotate(180deg)}
.drop a{display:block;color:var(--cream)!important;padding:13px 16px;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;border-radius:2px;transition:.2s;text-align:left}
.drop a::after{display:none!important}
.drop a:hover{background:rgba(196,149,63,.16);color:var(--gold-lt)!important}
.drop .d-skip{display:block;font-family:var(--script);text-transform:none;letter-spacing:0;font-size:1.2rem;color:var(--gold-lt);line-height:1;margin-bottom:2px}
.drop .d-sub{display:block;text-transform:none;letter-spacing:.03em;font-size:.6rem;color:var(--muted);margin-top:4px}

/* ===== menu bar + skip-the-line pill ===== */
.menu-bar{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;margin-bottom:48px}
.skip-pill{display:inline-flex;align-items:center;gap:9px;background:#b1241c;color:#fff;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;padding:11px 20px;border-radius:30px;font-weight:500;box-shadow:0 8px 22px rgba(177,36,28,.32);transition:.25s}
.skip-pill:hover{background:#c62b22;transform:translateY(-2px)}
.skip-pill .dot{width:8px;height:8px;border-radius:50%;background:#fff;animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.6)}70%{box-shadow:0 0 0 9px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}

/* ===== order: pickup feature + delivery ===== */
.order-wrap{display:grid;grid-template-columns:1.15fr 1fr;gap:30px;align-items:stretch}
.pickup-feature{position:relative;background:linear-gradient(150deg,#1d140c,#2c1f12);color:var(--cream);border:1px solid rgba(196,149,63,.3);padding:54px 46px;overflow:hidden;display:flex;flex-direction:column;align-items:flex-start}
.pickup-feature .pf-ic{font-size:2.8rem;margin-bottom:14px}
.pickup-feature h3{font-size:2.3rem;color:var(--cream);margin-bottom:12px}
.pickup-feature p{color:#cbbba0;font-size:1.02rem;margin-bottom:26px;max-width:470px}
.pickup-feature .pf-foot{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:16px}
.ribbon{position:absolute;top:26px;right:-48px;background:#b1241c;color:#fff;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:9px 56px;transform:rotate(45deg);box-shadow:0 6px 16px rgba(0,0,0,.3)}
.delivery-block{background:#fff;border:1px solid var(--line);padding:46px 40px;display:flex;flex-direction:column;justify-content:center}
.delivery-block h3{font-size:1.9rem;margin:6px 0 10px}
.delivery-block p{color:var(--muted);margin-bottom:24px}
.partners{display:flex;flex-direction:column;gap:14px}
.partner{display:flex;align-items:center;justify-content:center;height:72px;border:1px solid var(--line);border-radius:6px;background:#fff;transition:.25s;overflow:hidden}
.partner img{max-height:60px;width:auto;object-fit:contain}
.partner:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 14px 30px rgba(23,17,10,.12)}

/* ===== MOTION ===== */
@media (prefers-reduced-motion:no-preference){
  .hero-bg{animation:kenburns 20s ease-out forwards}
  @keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.16)}}
  .hero-a1,.hero-a2,.hero-a3,.hero-a4{opacity:0;transform:translateY(22px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
  .hero-a1{animation-delay:.15s}.hero-a2{animation-delay:.32s}.hero-a3{animation-delay:.5s}.hero-a4{animation-delay:.66s}
  @keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
  .reveal.in{animation:rise .85s cubic-bezier(.2,.7,.2,1) both}
  
  
  
  
  .btn-gold{position:relative;overflow:hidden}
  .btn-gold::after{content:'';position:absolute;top:0;left:-130%;width:60%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-20deg)}
  .btn-gold:hover::after{animation:shine .85s}
  @keyframes shine{to{left:150%}}
  .divider{transform-origin:center}
  .head.in .divider{animation:grow .9s .2s both}
  @keyframes grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
}

/* ===== responsive add-ons ===== */
@media(max-width:980px){
  .order-wrap{grid-template-columns:1fr}
  .awards-row{grid-template-columns:1fr;gap:14px}
  .pickup-feature{padding:44px 30px}
}
@media(max-width:680px){
  .menu-bar{flex-direction:column}
  .drop{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;background:transparent;padding:6px 0 0;min-width:0;display:none}
  .has-drop.open .drop{display:block}
  .drop a{text-align:center}
  .ribbon{right:-50px;top:22px;padding:8px 54px}
}

/* ===== delivery buttons (clear, tappable) ===== */
.partners{display:flex;flex-direction:column;gap:12px}
.partner-btn{display:flex;align-items:center;gap:16px;padding:15px 22px;border:1px solid var(--line);border-radius:8px;background:#fff;transition:.25s;text-align:left;cursor:pointer}
.partner-btn .picon{width:56px;height:56px;flex:0 0 auto;background-repeat:no-repeat;background-position:center;background-size:275%;border-radius:24%}
.partner-btn .pname{font-family:var(--sans);font-size:.96rem;font-weight:500;color:var(--ink);letter-spacing:.02em;flex:1}
.partner-btn .pgo{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--terra);font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:.25s;white-space:nowrap}
.partner-btn:hover{border-color:var(--gold);background:#fbf6ec;transform:translateY(-2px);box-shadow:0 12px 28px rgba(23,17,10,.12)}
.partner-btn:hover .pgo{color:var(--gold);transform:translateX(4px)}

/* ===== mobile: center logo ===== */
@media(max-width:680px){
  .nav{position:relative;justify-content:center}
  .brand{margin:0 auto}
  .brand img{height:54px}
  header.site.solid .brand img{height:46px}
  .burger{position:absolute;right:0;top:50%;transform:translateY(-50%)}
}

/* ===== awards: center the trio as a group ===== */
.awards-row{display:flex;justify-content:center;align-items:center;gap:56px;flex-wrap:wrap}
.awards-row .aw{flex:0 1 auto}
@media(max-width:680px){ .awards-row{gap:22px;flex-direction:column} }

/* ===== hero order dropdown + menu delivery pill + pickup icon ===== */
.hero-drop{position:relative;display:inline-block}
.hero-drop .drop{right:auto;left:0;top:calc(100% + 10px)}
.deliver-pill{display:inline-flex;align-items:center;gap:9px;background:transparent;color:var(--ink);border:1px solid var(--gold);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;padding:11px 20px;border-radius:30px;font-weight:600;transition:.25s}
.deliver-pill:hover{background:var(--gold);color:var(--ink);transform:translateY(-2px)}
.deliver-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--gold)}
.deliver-pill:hover .dot{background:var(--ink)}
.pf-ic{line-height:0}
.pf-ic svg{width:56px;height:56px;display:block}

/* ===== nav: logo left at top, center on scroll ===== */
.nav{position:relative}
.brand{transition:margin .35s ease}
@media(min-width:681px){
  header.site.solid .nav-links{position:absolute;right:0;top:50%;transform:translateY(-50%)}
  header.site.solid .brand{margin:0 auto}
}
@media(max-width:680px){
  .nav{justify-content:flex-start}
  .brand{margin:0}
  header.site.solid .nav{justify-content:center}
  header.site.solid .brand{margin:0 auto}
}

/* ===== panning backgrounds (left<->right) ===== */
.band{position:relative;overflow:hidden}
.band-bg{position:absolute;inset:-4% -8%;background-size:cover;background-position:center;z-index:0}
.band .ov{z-index:1}
.band-in{position:relative;z-index:2}
.visit{overflow:hidden}
.visit-bg{position:absolute;inset:-4% -8%;background-size:cover;background-position:center;z-index:0}
.visit .ov{z-index:1}
@media (prefers-reduced-motion:no-preference){
  .hero-bg{transform:scale(1.12);animation:heropan 32s ease-in-out infinite alternate !important}
  @keyframes heropan{from{transform:scale(1.12) translateX(-3%)}to{transform:scale(1.12) translateX(3%)}}
  .band-bg{animation:panx 36s ease-in-out infinite alternate}
  .visit-bg{animation:panx 30s ease-in-out infinite alternate}
  @keyframes panx{from{transform:translateX(-3.5%)}to{transform:translateX(3.5%)}}
}

/* ===== dropdown polish + menu delivery dropdown ===== */
.hero-btns{align-items:center}
.hero-drop{display:inline-flex}
.caret{font-size:.82em;margin-left:5px;display:inline-block}
.deliver-drop{position:relative}
.deliver-drop .drop{left:50%;right:auto;margin-left:-108px;min-width:216px}
.drop-deliver a{text-align:center;letter-spacing:.14em}

/* ===== mobile: hero & menu dropdowns float (don't push siblings) ===== */
@media(max-width:680px){
  .hero-drop .drop,.deliver-drop .drop{position:absolute;display:block;opacity:0;visibility:hidden;transform:translateY(8px);background:var(--ink);border:1px solid rgba(196,149,63,.35);box-shadow:0 18px 50px rgba(0,0,0,.45);padding:8px;min-width:220px;z-index:130}
  .hero-drop.open .drop,.deliver-drop.open .drop{opacity:1;visibility:visible;transform:none}
  .hero-drop .drop{left:0;right:auto;top:calc(100% + 8px)}
  .deliver-drop .drop{left:50%;right:auto;margin-left:-110px;top:calc(100% + 8px)}
  .hero-drop .drop a,.deliver-drop .drop a{text-align:left}
  .deliver-drop .drop a{text-align:center}
}

/* ===== Online ordering (Zaytech/Clover) — themed to match site ===== */
.moo-choose-category{font-family:var(--serif)!important;color:var(--ink)!important;font-weight:600!important}
ul.moo-nav-menu,.moo-nav-menu.moo-bg-dark,.moo-bg-dark{background:var(--ink)!important;border:1px solid rgba(196,149,63,.25)!important;border-radius:4px;overflow:hidden}
.moo-nav-menu li,.moo-nav-menu li a{font-family:var(--sans)!important;letter-spacing:.1em!important;text-transform:uppercase!important;font-size:.74rem!important;color:var(--cream)!important;transition:.2s!important;border-color:rgba(196,149,63,.12)!important}
.moo-nav-menu li:hover,.moo-nav-menu li a:hover{background:rgba(196,149,63,.16)!important;color:var(--gold-lt)!important}
.moo-nav-menu li.moo-active,.moo-nav-menu li.active,.moo-nav-menu .moo-active a,.moo-nav-menu li.moo-active a,.moo-nav-menu a.active{background:var(--gold)!important;color:var(--ink)!important}
.moo-menu-category-title{background:linear-gradient(135deg,#1d140c,#2c1f12)!important;color:var(--cream)!important;font-family:var(--serif)!important;font-weight:600!important;letter-spacing:.02em!important;border:1px solid rgba(196,149,63,.3)!important;border-radius:4px}
.moo-item-name,.moo-item-name-bold{font-family:var(--serif)!important;font-size:1.25rem!important;font-weight:600!important;color:var(--ink)!important}
.moo-item-description{font-family:var(--sans)!important;color:var(--muted)!important}
.moo-price{font-family:var(--serif)!important;color:var(--terra)!important;font-weight:600!important;font-size:1.18rem!important}
.moo-btn,.moo-btn-sm,.moo-btn-lg,button.moo-btn-sm,.moo-add-to-cart,.moo-checkout-btn{background:var(--gold)!important;color:var(--ink)!important;border:1px solid var(--gold)!important;font-family:var(--sans)!important;letter-spacing:.1em!important;text-transform:uppercase!important;border-radius:2px!important;transition:.25s!important;box-shadow:none!important}
.moo-btn:hover,.moo-btn-sm:hover,.moo-btn-lg:hover,button.moo-btn-sm:hover,.moo-add-to-cart:hover,.moo-checkout-btn:hover{background:var(--gold-lt)!important;border-color:var(--gold-lt)!important;color:var(--ink)!important}
.moo-text-primary,.moo-link,.moo a{color:var(--terra)!important}
.moo-card,.moo-item,.moo-menu-item{border-color:var(--line)!important}

/* ===== FIXES (round 2) ===== */
/* pickup banner: compact, centered, no clipped text */
.moo-menu-category-title{height:auto!important;min-height:60px!important;padding:22px 24px!important;display:flex!important;align-items:center!important;justify-content:center!important;font-size:1.9rem!important;line-height:1.3!important;overflow:visible!important}
/* leave the cart button to the plugin's own styling (revert) */

/* logo: LEFT on desktop always; smooth slide to center on scroll only on mobile */
@media(min-width:681px){
  header.site.solid .nav-links{position:static;transform:none}
  header.site.solid .brand{margin:0}
}
@media(max-width:680px){
  .nav{position:relative;justify-content:flex-start;min-height:60px}
  .brand{position:absolute;left:0;top:50%;margin:0;transform:translate(0,-50%);transition:left .45s ease, transform .45s ease}
  header.site.solid .nav{justify-content:flex-start}
  header.site.solid .brand{left:50%;margin:0;transform:translate(-50%,-50%)}
  .brand img{height:52px}
  header.site.solid .brand img{height:46px}
  .burger{position:absolute;right:0;top:50%;transform:translateY(-50%)}
}

/* menu dropdown must sit ABOVE the dish cards */
.menu-bar{position:relative;z-index:60}
.deliver-drop .drop,.hero-drop .drop{z-index:400!important}

/* dropdowns: partner logos + Skip-the-Line badge */
.drop a{display:flex!important;align-items:center;gap:11px}
.drop a .pl{width:46px;height:46px;flex:0 0 auto;background-repeat:no-repeat;background-position:center;background-size:275%;border-radius:22%}
.drop-order .drop-pickup a{flex-direction:column;align-items:flex-start;gap:6px}
.skip-badge{display:inline-block;background:#b1241c;color:#fff;font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;padding:3px 10px;border-radius:20px;font-weight:600;line-height:1.4}
.drop-main{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cream)}
.drop-sec{font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);padding:9px 16px 4px;border-top:1px solid rgba(196,149,63,.16);margin-top:4px}
.drop-order a,.drop-deliver a{color:var(--cream)!important;font-size:.76rem}

/* ===== Ordering pages: stop theme from hijacking the widget's scroll ===== */
html:has(body.ordering-page){scroll-behavior:auto!important}
body.ordering-page{scroll-behavior:auto!important;overflow-anchor:none}
.ordering-page header.site{position:relative!important}
.ordering-page .page-hero{margin-top:0!important;padding:120px 0 60px}
.ordering-page .page-body{padding-top:34px}
/* checkout / cart theming */
.moo-checkout-btn,.moo-place-order,.moo-update-cart,button[class*="moo"]{background:var(--gold)!important;color:var(--ink)!important;border:1px solid var(--gold)!important;border-radius:2px!important}
.moo-checkout-btn:hover,.moo-place-order:hover,button[class*="moo"]:hover{background:var(--gold-lt)!important}
.moo-form-control,.moo input[type=text],.moo input[type=email],.moo input[type=tel],.moo textarea,.moo select,[class*="moo"] input,[class*="moo"] select,[class*="moo"] textarea{border:1px solid var(--line)!important;border-radius:3px!important;font-family:var(--sans)!important}
.moo-total,.moo-grand-total,.moo-order-total,[class*="moo-total"],[class*="moo-summary"] [class*="total"]{font-family:var(--serif)!important;color:var(--terra)!important;font-weight:600!important}
.moo-cart-title,.moo-checkout-title,[class*="moo"] h1,[class*="moo"] h2,[class*="moo"] h3{font-family:var(--serif)!important}

/* ===== ROUND 3 FIXES ===== */
/* hero dropdown opens UPWARD on mobile (was hidden under awards) */
@media(max-width:680px){
  .hero-drop .drop{top:auto!important;bottom:calc(100% + 10px)!important}
}
/* Skip-the-Line as a diagonal corner ribbon inside the pickup dropdown item */
.drop-order .drop-pickup a{position:relative;overflow:hidden;flex-direction:row;align-items:center;min-height:48px}
.drop-order .skip-badge{position:absolute;top:9px;right:-33px;transform:rotate(45deg);background:#b1241c;color:#fff;font-size:.46rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:3px 34px;border-radius:0;line-height:1.5;box-shadow:0 3px 8px rgba(0,0,0,.3)}
.drop-order .drop-pickup .drop-main{font-size:.84rem}
/* faster + more noticeable background panning on mobile */
@keyframes panxFast{from{transform:translateX(-6%)}to{transform:translateX(6%)}}
@keyframes heropanFast{from{transform:scale(1.16) translateX(-5%)}to{transform:scale(1.16) translateX(5%)}}
@media(max-width:680px) and (prefers-reduced-motion:no-preference){
  .band-bg,.visit-bg{inset:-6% -14%}
  .band-bg{animation:panxFast 15s ease-in-out infinite alternate}
  .visit-bg{animation:panxFast 14s ease-in-out infinite alternate}
  .hero-bg{animation:heropanFast 13s ease-in-out infinite alternate!important}
}

/* ===== ROUND 4: category title descenders + checkout ===== */
/* the actual title element clips 'pp' tails — let it breathe */
.moo-title{overflow:visible!important;line-height:1.3!important;height:auto!important;min-height:0!important;max-height:none!important;padding:6px 10px!important;font-family:var(--serif)!important;color:var(--cream)!important;font-weight:600!important;white-space:normal!important}
.moo-menu-category-title{padding:20px 24px!important}
.moo-menu-category-title .moo-bg-image{opacity:.18!important}
/* checkout / cart broader theming */
.moo-btn-default,a.moo-btn-default,button.moo-btn-default{background:var(--gold)!important;color:var(--ink)!important;border:1px solid var(--gold)!important;border-radius:2px!important;font-family:var(--sans)!important;letter-spacing:.1em;text-transform:uppercase}
.moo-btn-default:hover{background:var(--gold-lt)!important}
.ordering-page .page-body label,.ordering-page .page-body legend{font-family:var(--sans)!important;color:var(--ink)!important;letter-spacing:.04em}
.ordering-page .page-body table,.ordering-page .page-body th,.ordering-page .page-body td,[class*="moo"] table,[class*="moo"] th,[class*="moo"] td{border-color:var(--line)!important}
.ordering-page .page-body h1,.ordering-page .page-body h2,.ordering-page .page-body h3,.ordering-page .page-body h4{font-family:var(--serif)!important;color:var(--ink)!important}

/* ===== ROUND 5: cart modal (SweetAlert2) + skip ribbon fit ===== */
/* SweetAlert2 cart/confirm popups themed */
.swal2-popup{font-family:var(--sans)!important;border-radius:8px!important;border:1px solid rgba(196,149,63,.3)!important}
.swal2-title,.swal2-popup h1,.swal2-popup h2,.swal2-popup h3{font-family:var(--serif)!important;color:var(--ink)!important}
.swal2-styled.swal2-confirm{background:var(--gold)!important;background-color:var(--gold)!important;color:var(--ink)!important;border:1px solid var(--gold)!important;border-radius:2px!important;box-shadow:none!important;text-transform:uppercase;letter-spacing:.1em;font-family:var(--sans)!important}
.swal2-styled.swal2-confirm:hover{background:var(--gold-lt)!important;background-color:var(--gold-lt)!important}
.swal2-styled.swal2-cancel{background:transparent!important;background-color:transparent!important;color:var(--ink)!important;border:1px solid var(--line)!important;border-radius:2px!important;box-shadow:none!important;text-transform:uppercase;letter-spacing:.1em}
.swal2-styled.swal2-cancel:hover{background:var(--ink)!important;color:var(--cream)!important}
.swal2-popup thead,.swal2-popup th,.swal2-popup .moo-bg-dark{background:var(--ink)!important;color:var(--cream)!important}
.swal2-popup [style*="color: red"],.swal2-popup [style*="color:red"],.swal2-popup [style*="rgb(255, 0, 0)"]{color:var(--terra)!important}

/* Skip-the-Line corner ribbon — size it so the text fits (no clipping) */
.drop-order .drop-pickup a{position:relative;overflow:hidden;min-height:62px;display:flex;align-items:center;padding:20px 18px}
.drop-order .skip-badge{position:absolute;top:14px;right:-44px;width:156px;text-align:center;transform:rotate(45deg);transform-origin:center;background:#b1241c;color:#fff;font-size:.5rem;letter-spacing:.05em;text-transform:uppercase;font-weight:700;padding:4px 0;line-height:1.4;box-shadow:0 3px 8px rgba(0,0,0,.3)}
.drop-order .drop-pickup .drop-main{font-size:.86rem}

/* ===== ROUND 6: mobile polish + ordering pages ===== */
/* hero text was glued to the edges — shorthand padding had zeroed the sides */
.hero-inner{padding:120px 30px}
/* touch devices: sticky :hover was holding dropdowns open -> only .open controls them (fixes 2nd-tap close) */
@media(hover:none),(pointer:coarse){
  .has-drop:hover .drop{opacity:0;visibility:hidden}
  .has-drop.open .drop{opacity:1;visibility:visible}
  .has-drop:hover .caret{transform:none}
  .has-drop.open .caret{transform:rotate(180deg)}
}
/* nudge skip-the-line ribbon to sit centered on the corner */
.drop-order .skip-badge{right:-38px;width:148px;top:13px}
@media(max-width:680px){
  .hero{margin-top:0}                    /* removes the weird dark gap under the header */
  .hero-inner{padding:80px 24px}
  .topbar{padding:9px 20px}
  .wrap{padding:0 22px}
  section.blk{padding:62px 0}
  /* ordering (pickup/checkout/cart) pages breathe + no edge-stick on mobile */
  .ordering-page .page-hero{padding:84px 0 42px!important}
  .ordering-page .page-body{padding:22px 14px 64px!important}
  .page-body{padding:46px 16px 64px}
  .menu-bar{gap:10px}
}

/* ===== ROUND 7: kill the white header band on ordering pages ===== */
.ordering-page header.site{background:rgba(23,17,10,.98)!important;box-shadow:0 4px 24px rgba(0,0,0,.25)}

/* ===== ROUND 8: center skip-the-line ribbon + theme ordering-hours notice ===== */
/* proper symmetric corner ribbon (was sitting left of corner) */
.drop-order .drop-pickup a{position:relative;overflow:hidden;min-height:60px}
.drop-order .skip-badge{position:absolute;top:18px;right:-50px;left:auto;width:160px;text-align:center;padding:4px 0;transform:rotate(45deg);transform-origin:center center;background:#b1241c;color:#fff;font-size:.5rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700;line-height:1.4;box-shadow:0 3px 8px rgba(0,0,0,.3)}
/* the big Order-Your-Way ribbon centered on its corner too */
.ribbon{top:22px;right:-52px;width:170px;text-align:center;padding:8px 0}
/* theme the plugin's "ordering hours / closed" notice (was pink) */
.moo-alert,.moo-notice,[class*="moo-alert"],[class*="moo-message"],[class*="moo-notification"],[class*="moo-hours"]{background:var(--paper)!important;border:1px solid rgba(196,149,63,.3)!important;border-radius:6px!important;color:var(--ink)!important;font-family:var(--sans)!important}

/* ===== ROUND 9: keep dropdowns BELOW the sticky header (no riding over Order Now) ===== */
header.site{z-index:300}
.hero-drop .drop,.deliver-drop .drop{z-index:120}
@media(max-width:680px){
  .hero-drop .drop,.deliver-drop .drop{z-index:120}
}

/* ===== ROUND 10: mobile edges + tel links + palm sway ===== */
/* absolutely-positioned header items ignore container padding -> inset them so nothing is cut at the edge */
@media(max-width:680px){
  .brand{left:18px}
  header.site.solid .brand{left:50%}
  .burger{right:18px}
}
.topbar a{color:inherit;text-decoration:none}
/* footer logo: gentle palm-sway, pivoting from the bottom so the leaves sway and the text stays still */
@media (prefers-reduced-motion:no-preference){
  footer.site .flogo{transform-origin:center;animation:logozoom 6.5s ease-in-out infinite}
  @keyframes logozoom{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}
}

/* ===== ROUND 11: bulletproof corner ribbons (fixed clip box, never overflows) ===== */
.corner{position:absolute;top:0;right:0;width:94px;height:94px;overflow:hidden;pointer-events:none;z-index:3}
.corner .skip-badge{position:absolute;top:16px;right:-26px;left:auto;width:132px;text-align:center;transform:rotate(45deg);transform-origin:center;background:#b1241c;color:#fff;font-size:.46rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700;padding:4px 0;line-height:1.4;box-shadow:0 2px 7px rgba(0,0,0,.35)}
.drop-order .drop-pickup a{position:relative;overflow:hidden;min-height:56px;flex-direction:row;align-items:center}
.corner-lg{width:150px!important;height:150px!important}
.corner-lg .ribbon{position:absolute;top:36px;right:-55px;left:auto;width:210px;text-align:center;transform:rotate(45deg);transform-origin:center;background:#b1241c;color:#fff;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:8px 0;box-shadow:0 4px 10px rgba(0,0,0,.3)}
.pickup-feature{overflow:hidden}

/* ===== ROUND 12: ribbon gutter (no text overlap) + checkout cohesion ===== */
/* reserve a clean gutter on the right so the corner ribbon never overlaps "Order Pickup" */
.drop-order .drop-pickup a{position:relative!important;overflow:hidden!important;padding-right:82px!important;min-height:60px}
.corner{overflow:hidden!important;width:90px;height:90px;z-index:4}
/* center the text on the corner diagonal: element center (60,30) sits on the corner bisector of the 90x90 clip box */
.corner .skip-badge{top:21px;right:-33px;left:auto;width:126px;font-size:.45rem;padding:4px 0;letter-spacing:.05em;text-align:center}
/* hamburger slide menu: center the pickup label with symmetric clearance from the ribbon */
@media(max-width:680px){
  #orderdrop .drop-pickup a{padding-left:82px!important;padding-right:82px!important;min-height:64px}
  #orderdrop .drop-pickup .drop-main{width:100%;text-align:center}
  #orderdrop .drop{margin-top:6px}
}

/* ===== checkout / cart / account pages: carry the theme like the ordering page ===== */
body.ordering-page .page-body,body.ordering-page .page-body p,body.ordering-page .page-body span,
body.ordering-page .page-body label,body.ordering-page .page-body li,body.ordering-page .page-body a,
body.ordering-page .page-body button,body.ordering-page .page-body input,body.ordering-page .page-body select{font-family:var(--sans)}
body.ordering-page .page-body h1,body.ordering-page .page-body h2,body.ordering-page .page-body h3,
body.ordering-page .page-body h4,body.ordering-page .page-body legend{font-family:var(--serif)!important;color:var(--ink)!important}
/* menu category banners keep their own cream-on-dark styling (don't force ink, it goes invisible) */
body.ordering-page .page-body .moo-title,body.ordering-page .page-body .moo-menu-category-title{color:var(--cream)!important}
body.ordering-page .page-body input[type=text],body.ordering-page .page-body input[type=email],
body.ordering-page .page-body input[type=tel],body.ordering-page .page-body input[type=password],
body.ordering-page .page-body input[type=number],body.ordering-page .page-body textarea{border:1px solid var(--line)!important;border-radius:5px!important;background:#fff!important;padding:12px 14px!important}
/* selects: dont clip the chosen value — let height grow and leave room for the arrow */
body.ordering-page .page-body select{border:1px solid var(--line)!important;border-radius:5px!important;background:#fff!important;height:auto!important;min-height:48px!important;line-height:1.5!important;padding:10px 34px 10px 14px!important}
body.ordering-page .page-body input:focus,body.ordering-page .page-body select:focus,body.ordering-page .page-body textarea:focus{border-color:var(--gold)!important;outline:none!important;box-shadow:0 0 0 2px rgba(196,149,63,.15)!important}
/* section panels feel like the theme */
body.ordering-page .page-body .moo-row > div,body.ordering-page .page-body [class*="panel"],body.ordering-page .page-body [class*="card"]{border-color:var(--line)!important}

/* ===== ordering page: kill the plugins dark-green category panel & keep the sticky category bar legible ===== */
.moo-menu-category{background:transparent!important}
.moo-menu-category-title,.moo-menu-category-title *{color:var(--cream)!important}
.moo-menu-category-title{background:linear-gradient(135deg,#1d140c,#2c1f12)!important;border:1px solid rgba(196,149,63,.3)!important}
.moo-stick-to-content,nav.moo-fixed,.moo-stick-to-content.moo-fixed{background:var(--ink)!important}
.moo-stick-to-content .moo-choose-category,.moo-choose-category{color:var(--cream)!important}

/* ===== smooth first paint: hold a beat for webfonts, then fade in settled (no FOUT jitter) ===== */
html.pre body{opacity:0}
html.pre.ready body{opacity:1;transition:opacity .45s ease}

/* ===== catering: elegant auto-advancing slideshow (entree/platter dishes) ===== */
.cater-slides{position:relative;height:560px;overflow:hidden}
.cater-slides .cslide{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;object-fit:cover!important;object-position:50% 50%!important;transform-origin:50% 50%;opacity:0;transition:opacity 1.5s ease;z-index:1}
.cater-slides .cslide.on{opacity:1;z-index:2;animation:caterzoom 8s ease-in-out both}
@keyframes caterzoom{from{transform:scale(1)}to{transform:scale(1.34)}}
.cater-dots{position:absolute;left:0;right:0;bottom:18px;display:flex;justify-content:center;gap:8px;z-index:5}
.cater-dots .cd{width:8px;height:8px;border-radius:50%;background:rgba(247,240,226,.5);cursor:pointer;transition:.3s}
.cater-dots .cd.on{background:var(--gold-lt);width:24px;border-radius:5px}
@media(max-width:680px){.cater-slides{height:360px}.cater-slides .cslide{object-position:50% 50%!important}}

/* ===== checkout / account pages: the plugin's "soo" UI uses gradient gold buttons + a custom font. Flatten to match the site's flat-gold ordering buttons. ===== */
.sooContinueAsGuestButton,.sooCreateAnAccountButton,.sooLoginButton,.sooSignupButton,
.sooResetPasswordButton,.sooCheckoutPrimaryButtonInput,.sooCheckoutSecondaryButtonInput,
.sooApplyCouponButton,.sooDeleteCouponButton,.sooUsePointsButton,.sooRemovePointsButton,
.sooValidatePointsButton,.sooEditPointsButton{
  background:var(--gold)!important;background-image:none!important;color:var(--ink)!important;
  border:1px solid var(--gold)!important;border-radius:2px!important;box-shadow:none!important;
  font-family:var(--sans)!important;letter-spacing:.1em!important;text-transform:uppercase!important;
  font-weight:600!important;text-shadow:none!important
}
.sooContinueAsGuestButton:hover,.sooCreateAnAccountButton:hover,.sooLoginButton:hover,.sooSignupButton:hover,
.sooResetPasswordButton:hover,.sooCheckoutPrimaryButtonInput:hover,.sooCheckoutSecondaryButtonInput:hover,
.sooApplyCouponButton:hover,.sooDeleteCouponButton:hover,.sooUsePointsButton:hover,.sooRemovePointsButton:hover,
.sooValidatePointsButton:hover,.sooEditPointsButton:hover{
  background:var(--gold-lt)!important;background-image:none!important;border-color:var(--gold-lt)!important;color:var(--ink)!important
}
/* keep text-style links as links, just themed */
.sooForgetPasswordButton,.sooTosLinkButton,.sooLoginLinkButton,.sooLoyaltyDetailsButton{
  background:none!important;background-image:none!important;box-shadow:none!important;color:var(--terra)!important;
  font-family:var(--sans)!important;text-transform:none!important;letter-spacing:0!important;border:0!important
}
/* checkout text inputs match the theme */
.sooCheckoutTextInput,.soo-phone-input{font-family:var(--sans)!important;border:1px solid var(--line)!important;border-radius:5px!important}
.sooCheckoutTextInput:focus,.soo-phone-input:focus{border-color:var(--gold)!important;outline:none!important;box-shadow:0 0 0 2px rgba(196,149,63,.15)!important}

/* the plugin themes checkout buttons via #moo-checkout .btn (ID specificity) with a gold gradient + 14px radius.
   Beat it with html-prefixed higher specificity so our flat-gold style wins regardless of load order. */
html #moo-checkout .btn,html #sooAuthSection .btn,html #moo-checkout .sooCheckoutPrimaryButtonInput,
html #moo-checkout .sooCheckoutSecondaryButtonInput,html #moo-checkout input[type=submit].btn{
  background:var(--gold)!important;background-image:none!important;color:var(--ink)!important;
  border:1px solid var(--gold)!important;border-radius:2px!important;box-shadow:none!important;
  font-family:var(--sans)!important;letter-spacing:.1em!important;text-transform:uppercase!important;
  font-weight:600!important;text-shadow:none!important
}
html #moo-checkout .btn:hover,html #sooAuthSection .btn:hover{
  background:var(--gold-lt)!important;background-image:none!important;border-color:var(--gold-lt)!important;color:var(--ink)!important
}

/* precise override: plugin styles checkout buttons via "#moo-checkout button" (1,0,1). Use #moo-checkout + the soo class (1,1,1) so flat-gold wins, without touching the text links. */
html #moo-checkout .sooContinueAsGuestButton,html #moo-checkout .sooCreateAnAccountButton,
html #moo-checkout .sooLoginButton,html #moo-checkout .sooSignupButton,html #moo-checkout .sooResetPasswordButton,
html #moo-checkout .sooCheckoutPrimaryButtonInput,html #moo-checkout .sooCheckoutSecondaryButtonInput,
html #moo-checkout .sooApplyCouponButton,html #moo-checkout .sooDeleteCouponButton,
html #moo-checkout .sooUsePointsButton,html #moo-checkout .sooRemovePointsButton,
html #moo-checkout .sooValidatePointsButton,html #moo-checkout .sooEditPointsButton{
  background:var(--gold)!important;background-image:none!important;color:var(--ink)!important;
  border:1px solid var(--gold)!important;border-radius:2px!important;box-shadow:none!important;
  font-family:var(--sans)!important;letter-spacing:.1em!important;text-transform:uppercase!important;font-weight:600!important
}
html #moo-checkout .sooContinueAsGuestButton:hover,html #moo-checkout .sooCreateAnAccountButton:hover,
html #moo-checkout .sooLoginButton:hover,html #moo-checkout .sooApplyCouponButton:hover,
html #moo-checkout .sooDeleteCouponButton:hover,html #moo-checkout .sooCheckoutPrimaryButtonInput:hover,
html #moo-checkout .sooSignupButton:hover,html #moo-checkout .sooResetPasswordButton:hover{
  background:var(--gold-lt)!important;background-image:none!important;border-color:var(--gold-lt)!important;color:var(--ink)!important
}

/* keep checkout button labels inside their containers (esp. Apply/Remove coupon on phones): tighter spacing, no wrap, room to breathe */
html #moo-checkout .sooApplyCouponButton,html #moo-checkout .sooDeleteCouponButton,
html #moo-checkout .sooContinueAsGuestButton,html #moo-checkout .sooCreateAnAccountButton,
html #moo-checkout .sooLoginButton,html #moo-checkout .sooSignupButton,
html #moo-checkout .sooCheckoutPrimaryButtonInput,html #moo-checkout .sooCheckoutSecondaryButtonInput{
  letter-spacing:.04em!important;white-space:nowrap!important;line-height:1.2!important;height:auto!important;
  min-height:0!important;padding:13px 14px!important;overflow:visible!important;text-overflow:clip!important
}
@media(max-width:680px){
  html #moo-checkout .sooApplyCouponButton,html #moo-checkout .sooDeleteCouponButton{
    font-size:.74rem!important;letter-spacing:.02em!important;padding:11px 6px!important
  }
}

/* VIEW CART button (moo-btn-primary) — match the site's flat-gold buttons */
html a.moo-btn-primary,html .moo-btn-primary{
  background:var(--gold)!important;background-image:none!important;color:var(--ink)!important;
  border:1px solid var(--gold)!important;border-radius:2px!important;box-shadow:none!important;
  font-family:var(--sans)!important;letter-spacing:.1em!important;text-transform:uppercase!important;font-weight:600!important
}
html a.moo-btn-primary:hover,html .moo-btn-primary:hover{
  background:var(--gold-lt)!important;background-image:none!important;border-color:var(--gold-lt)!important;color:var(--ink)!important
}
/* stop the online-store grid from breaking out of the theme card on desktop:
   the plugin hard-sets this container to 1024px with a negative right margin. Fit it to the card and absorb the bootstrap row's -15px gutters with matching padding. */
#moo_OnlineStoreContainer{width:100%!important;max-width:100%!important;margin-left:0!important;margin-right:0!important;padding-left:15px!important;padding-right:15px!important;box-sizing:border-box!important;overflow-x:clip}
