/* ============================================================
   Troy's Burgers CA — Site Stylesheet
   California Burgers. Greek Roots. Legendary Flavor.
   ============================================================ */
:root{
  --ink:#14100C;            /* warm near-black */
  --ink-2:#1E1712;          /* card dark */
  --red:#C8102E;            /* brand red */
  --red-bright:#E22234;     /* hover / accent red */
  --gold:#F2B33D;           /* script yellow */
  --cream:#F3EBDC;          /* section cream */
  --paper:#FAF4E6;          /* note paper */
  --bone:#EFE6D4;
  --line:rgba(243,235,220,.16);
  --line-dark:rgba(20,16,12,.1);
  --shadow:0 18px 50px rgba(0,0,0,.45);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation:none!important;transition:none!important}}
body{font-family:'Barlow',system-ui,sans-serif;background:var(--ink);color:var(--cream);line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px}

.display{font-family:'Anton',sans-serif;letter-spacing:.01em;text-transform:uppercase}
.script{font-family:'Caveat',cursive;color:var(--gold)}
.cond{font-family:'Barlow Condensed',sans-serif;text-transform:uppercase;letter-spacing:.08em}
.wrap{width:min(1240px,92%);margin-inline:auto}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--gold);color:var(--ink);padding:.7rem 1.2rem;font-weight:700;z-index:100;border-radius:0 0 10px 0}
.skip-link:focus{left:0}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.85rem;padding:.95rem 1.5rem;border-radius:12px;font-weight:700;transition:transform .18s ease,background .18s ease,border-color .18s ease,color .18s ease;border:2px solid transparent;cursor:pointer;font-family:inherit;font-size:1rem}
.btn:hover{transform:translateY(-2px)}
.btn .arr{font-size:1.15rem;line-height:1}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 26px rgba(200,16,46,.35)}
.btn-red:hover{background:var(--red-bright)}
.btn-ghost{border-color:var(--cream);color:var(--cream);background:transparent}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-ghost-dark{border-color:#191310;color:#191310;background:transparent}
.btn-ghost-dark:hover{border-color:var(--red);color:var(--red)}
.btn-stack{display:flex;flex-direction:column;align-items:flex-start;line-height:1.15}
.btn-stack small{font-weight:500;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;opacity:.85}

/* ---------- Header ---------- */
header.site{position:sticky;top:0;z-index:60;background:rgba(20,16,12,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:2rem;padding:.8rem 0}
.brand{display:flex;align-items:center;gap:.75rem}
.brand img{height:54px;width:auto}
.brand-words{line-height:1}
.brand-words .display{font-size:1.35rem;color:#fff}
.brand-words .sub{font-size:.6rem;letter-spacing:.22em;color:var(--gold);text-transform:uppercase;font-weight:600}
.nav-links{display:flex;gap:1.9rem;margin-left:auto;align-items:center}
.nav-links a{font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.1em;font-weight:700;font-size:1rem;color:var(--cream);padding:.35rem 0;border-bottom:3px solid transparent;transition:color .15s,border-color .15s}
.nav-links a:hover{color:var(--gold)}
.nav-links a.active{color:#fff;border-color:var(--red)}
.nav-cta{margin-left:1.5rem;border-bottom:none!important}
.menu-toggle{display:none;margin-left:auto;background:none;border:2px solid var(--line);border-radius:10px;color:var(--cream);font-size:1.4rem;padding:.3rem .7rem;cursor:pointer}

/* ---------- Hero (home) ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(900px 600px at 78% 30%, rgba(120,62,18,.5), transparent 60%),
  radial-gradient(700px 500px at 10% 110%, rgba(200,16,46,.16), transparent 60%),
  var(--ink)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:2.5rem;align-items:center;padding:3.5rem 0 2.5rem}
.kicker{font-size:1.7rem;line-height:1.2;display:inline-block;transform:rotate(-2deg);margin-bottom:1rem;position:relative}
.kicker::after{content:"";position:absolute;left:2px;bottom:-6px;width:64%;height:3px;background:var(--red);border-radius:3px;transform:rotate(-1deg)}
.hero h1{font-size:clamp(3.2rem,7.2vw,6.2rem);line-height:.95;color:#fff;margin:.4rem 0 1.4rem}
.hero h1 .red{color:var(--red-bright);display:block}
.hero p.lede{max-width:46ch;font-size:1.08rem;color:var(--bone);opacity:.92}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.8rem}

.hero-visual{position:relative;min-height:420px;display:flex;align-items:center;justify-content:center}
.hero-visual .glow{position:absolute;inset:8% 4%;background:radial-gradient(closest-side, rgba(244,160,66,.30), transparent 70%);filter:blur(8px)}
.hero-visual img.burger{position:relative;width:min(560px,100%);filter:drop-shadow(0 36px 44px rgba(0,0,0,.6))}
.stamp{position:absolute;top:2%;right:0;width:138px;height:138px;color:#D9B98C;opacity:.9;transform:rotate(12deg)}
.note{position:absolute;right:-2%;bottom:4%;background:var(--paper);color:#1a140e;padding:1rem 1.25rem;max-width:240px;transform:rotate(-2deg);box-shadow:var(--shadow);font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:1.05rem;line-height:1.5}
.note::before{content:"";position:absolute;top:-12px;left:50%;width:90px;height:24px;transform:translateX(-50%) rotate(-1deg);background:rgba(214,196,160,.7)}
.note .way{display:block;margin-top:.35rem;font-family:'Caveat';font-size:1.25rem;letter-spacing:0;text-transform:none;color:var(--red)}

.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.5rem 0 2.8rem;border-top:1px solid var(--line)}
.trust-item{display:flex;gap:.8rem;align-items:center;padding-right:1rem}
.trust-item + .trust-item{border-left:1px solid var(--line);padding-left:1.4rem}
.trust-item svg{flex:0 0 34px;width:34px;height:34px;color:var(--gold)}
.trust-item .big{font-weight:700;color:#fff;font-size:1rem;line-height:1.25}
.trust-item .sm{font-size:.82rem;color:var(--bone);opacity:.8}
.stars{color:var(--gold);letter-spacing:.08em}

/* ---------- Greek key divider ---------- */
.meander{height:14px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='14' viewBox='0 0 28 14'%3E%3Cpath d='M2 12V2h12v6H8V6h4V4H4v8h20V2h2v10z' fill='%23C8102E'/%3E%3C/svg%3E");background-repeat:repeat-x;background-size:28px 14px}

/* ---------- Page hero (interior pages) ---------- */
.page-hero{position:relative;background:
  radial-gradient(700px 420px at 85% 0%, rgba(120,62,18,.4), transparent 60%),
  radial-gradient(500px 380px at 5% 100%, rgba(200,16,46,.14), transparent 60%),
  var(--ink);padding:3.2rem 0 2.6rem;overflow:hidden}
.page-hero .kicker{font-size:1.55rem}
.page-hero h1{font-size:clamp(2.6rem,6vw,4.6rem);line-height:.96;color:#fff;margin:.4rem 0 .9rem}
.page-hero h1 .red{color:var(--red-bright)}
.page-hero p.lede{max-width:62ch;font-size:1.06rem;color:var(--bone);opacity:.92}
.page-hero .hero-ctas{margin-top:1.5rem}

/* ---------- Cream sections / cards ---------- */
.cream{background:var(--cream);color:#191310;padding:3.6rem 0 4rem;background-image:radial-gradient(rgba(20,16,12,.045) 1px, transparent 1px);background-size:14px 14px}
.section-head{display:flex;align-items:center;justify-content:center;gap:1.4rem;margin-bottom:2.6rem;text-align:center}
.section-head h2{font-size:clamp(2rem,4.4vw,3.1rem);color:#191310}
.section-head .key{width:74px;height:14px;flex:0 0 auto;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='14' viewBox='0 0 28 14'%3E%3Cpath d='M2 12V2h12v6H8V6h4V4H4v8h20V2h2v10z' fill='%23C8102E'/%3E%3C/svg%3E");background-repeat:repeat-x;background-size:28px 14px}

.card-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1.3rem}
.card{background:#fff;border:1px solid rgba(20,16,12,.08);border-radius:16px;padding:1.4rem 1.2rem 1.2rem;display:flex;flex-direction:column;gap:.6rem;box-shadow:0 8px 22px rgba(20,16,12,.07);transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-5px);box-shadow:0 16px 34px rgba(20,16,12,.13)}
.card svg{width:46px;height:46px;color:var(--red)}
.card h3{font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.06em;font-size:1.25rem;color:#191310}
.card p{font-size:.92rem;color:#4d423a;flex:1}
.card a{font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--red);font-size:1rem}
.card a:hover{color:#8f0a20}

.gallery{margin-top:3rem;display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem}
.shot{background:#fff;border-radius:16px;border:1px solid rgba(20,16,12,.08);box-shadow:0 8px 22px rgba(20,16,12,.07);overflow:hidden;display:flex;flex-direction:column}
.shot .ph{background:radial-gradient(closest-side,#f6e8cf,#efe0c2);padding:1rem;display:flex;align-items:center;justify-content:center;min-height:170px}
.shot img{max-height:160px;width:auto;filter:drop-shadow(0 10px 14px rgba(20,16,12,.25))}
.shot figcaption{padding:.8rem 1rem;font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.07em;font-weight:700;color:#191310;display:flex;justify-content:space-between;align-items:baseline}
.shot figcaption span{color:var(--red)}

/* ---------- Menu page ---------- */
.menu-nav{position:sticky;top:71px;z-index:50;background:rgba(20,16,12,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);overflow-x:auto}
.menu-nav .wrap{display:flex;gap:.6rem;padding:.7rem 0;white-space:nowrap}
.menu-nav a{font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.07em;font-weight:700;font-size:.95rem;color:var(--bone);padding:.45rem 1rem;border:1px solid var(--line);border-radius:999px;transition:background .15s,color .15s,border-color .15s}
.menu-nav a:hover{border-color:var(--gold);color:var(--gold)}

.menu-section{padding:3.2rem 0 1rem;scroll-margin-top:130px}
.menu-section.cream-block{background:var(--cream);color:#191310;background-image:radial-gradient(rgba(20,16,12,.045) 1px, transparent 1px);background-size:14px 14px;padding-bottom:3.2rem}
.menu-section .section-head{justify-content:flex-start;text-align:left;margin-bottom:.4rem}
.menu-section .section-head .key{width:46px}
.menu-section .section-sub{font-family:'Caveat';font-size:1.5rem;color:var(--red);margin-bottom:1.8rem}
.menu-section.cream-block .section-head h2{color:#191310}

.menu-cat{margin-bottom:2.4rem}
.menu-cat h3{font-family:'Anton';text-transform:uppercase;font-size:1.45rem;color:var(--red);margin-bottom:.2rem}
.menu-cat .cat-note{font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.08em;font-weight:600;font-size:.95rem;color:#6e6056;margin-bottom:1rem}
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem 3rem;margin-top:1rem}
.mi{padding:.55rem 0;border-bottom:1px dashed rgba(20,16,12,.18);break-inside:avoid}
.mi-line{display:flex;align-items:baseline;gap:.6rem}
.mi-name{font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.05em;font-weight:700;font-size:1.12rem;color:#191310}
.mi-dots{flex:1;border-bottom:2px dotted rgba(20,16,12,.3);transform:translateY(-4px)}
.mi-price{font-family:'Barlow Condensed';font-weight:700;font-size:1.12rem;color:var(--red)}
.mi-desc{font-size:.9rem;color:#5d5147;margin-top:.15rem;max-width:52ch}

.menu-banner{background:var(--ink);color:var(--cream);border-radius:20px;padding:2rem 2.2rem;display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:center;margin:2.4rem 0;border:1px solid var(--line);box-shadow:var(--shadow)}
.menu-banner h3{font-family:'Anton';text-transform:uppercase;font-size:1.8rem;color:#fff}
.menu-banner ul{list-style:none;display:flex;gap:1.4rem;flex-wrap:wrap;margin:.6rem 0 0;font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.06em;font-weight:600;color:var(--bone)}
.menu-banner ul li::before{content:"+ ";color:var(--gold)}
.menu-banner ul li:first-child::before{content:""}
.menu-banner .price-tag{font-family:'Anton';font-size:2.6rem;color:var(--gold)}
.menu-banner img{max-height:130px;width:auto}

.diet-flag{display:inline-block;font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.1em;font-weight:700;font-size:.78rem;padding:.2rem .65rem;border-radius:999px;margin-left:.6rem;vertical-align:middle}
.diet-flag.keto{background:#1e4d2b;color:#d6f2dd}
.diet-flag.vegan{background:#3f6212;color:#e7f5d0}

/* ---------- Locations ---------- */
.locations{padding:4rem 0;background:
  radial-gradient(700px 420px at 88% 0%, rgba(200,16,46,.12), transparent 60%),var(--ink)}
.loc-head{display:flex;align-items:end;justify-content:space-between;gap:1rem;margin-bottom:2.2rem;flex-wrap:wrap}
.loc-head h2{font-size:clamp(2rem,4.4vw,3rem);color:#fff}
.loc-head .script{font-size:1.5rem}
.loc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.loc{background:var(--ink-2);border:1px solid var(--line);border-radius:18px;padding:1.6rem 1.5rem;display:flex;flex-direction:column;gap:.55rem}
.loc .city{font-family:'Anton';text-transform:uppercase;font-size:1.5rem;color:#fff}
.loc .city em{font-style:normal;color:var(--gold);font-family:'Caveat';font-size:1.2rem;margin-left:.4rem;text-transform:none}
.loc .addr{color:var(--bone);opacity:.85;font-size:.96rem}
.loc .tel{color:var(--gold);font-weight:600}
.loc .tel:hover{color:#fff}
.loc .hours-mini{font-size:.88rem;color:var(--bone);opacity:.75}
.loc-actions{display:flex;gap:.7rem;margin-top:auto;padding-top:1rem;flex-wrap:wrap}
.loc-actions .btn{padding:.65rem 1.1rem;font-size:.92rem;border-radius:10px}

/* ---------- Location detail ---------- */
.loc-detail{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:start}
.info-cards{display:grid;gap:1.1rem}
.info-card{background:#fff;border:1px solid var(--line-dark);border-radius:16px;padding:1.4rem 1.5rem;box-shadow:0 8px 22px rgba(20,16,12,.07)}
.info-card h3{font-family:'Anton';text-transform:uppercase;font-size:1.15rem;color:var(--red);margin-bottom:.6rem;display:flex;align-items:center;gap:.6rem}
.info-card h3 svg{width:22px;height:22px}
.info-card p,.info-card a.plain{color:#3c332c;font-size:1rem}
.info-card a.plain{font-weight:600;color:var(--red)}
.info-card a.plain:hover{color:#8f0a20}
.hours-table{width:100%;border-collapse:collapse}
.hours-table td{padding:.4rem 0;color:#3c332c;border-bottom:1px dashed rgba(20,16,12,.15)}
.hours-table tr:last-child td{border-bottom:none}
.hours-table td:last-child{text-align:right;font-weight:600}
.loc-photo{border-radius:18px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line-dark)}
.loc-photo img{width:100%;height:100%;object-fit:cover}

/* ---------- CTA band ---------- */
.cta-band{background:var(--red);color:#fff;padding:2.6rem 0}
.cta-band .wrap{display:flex;align-items:center;justify-content:space-between;gap:1.4rem;flex-wrap:wrap}
.cta-band h2{font-family:'Anton';text-transform:uppercase;font-size:clamp(1.6rem,3.4vw,2.3rem)}
.cta-band .script{color:#FFD98A;font-size:1.4rem}
.cta-band .btn{background:#fff;color:var(--red)}
.cta-band .btn:hover{background:var(--cream)}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
.form-card{background:#fff;border:1px solid var(--line-dark);border-radius:18px;padding:2rem;box-shadow:0 8px 22px rgba(20,16,12,.07)}
.form-row{margin-bottom:1.1rem}
.form-row label{display:block;font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.08em;font-weight:700;font-size:.95rem;color:#191310;margin-bottom:.35rem}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:.8rem .95rem;border:2px solid rgba(20,16,12,.18);border-radius:10px;font-family:'Barlow';font-size:1rem;color:#191310;background:#fff}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--red)}
.form-note{font-size:.85rem;color:#6e6056;margin-top:.8rem}
.form-status{margin-top:1rem;font-weight:600;display:none;padding:.8rem 1rem;border-radius:10px}
.form-status.ok{display:block;background:#e4f3e6;color:#1e4d2b}
.form-status.err{display:block;background:#fbe4e7;color:#8f0a20}

/* ---------- Prose (accessibility statement) ---------- */
.prose{max-width:72ch}
.prose h2{font-family:'Anton';text-transform:uppercase;font-size:1.5rem;color:var(--red);margin:2rem 0 .7rem}
.prose p{margin-bottom:1rem;color:#3c332c}
.prose ul{margin:0 0 1rem 1.3rem;color:#3c332c}
.prose a{color:var(--red);font-weight:600}

/* ---------- Footer ---------- */
footer.site{background:#0E0B08;border-top:4px solid var(--red);padding:1.6rem 0}
.foot{display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap}
.foot .brand img{height:42px}
.foot .tag{font-size:1.35rem;line-height:1.2}
.foot .grow{margin-left:auto;display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap}
.foot .cond{font-size:.85rem;color:var(--bone)}
.socials{display:flex;gap:.8rem}
.socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--cream);transition:border-color .15s,color .15s}
.socials a:hover{border-color:var(--gold);color:var(--gold)}
.socials svg{width:17px;height:17px}
.est{font-family:'Barlow Condensed';text-transform:uppercase;letter-spacing:.12em;color:var(--gold);border:1px solid rgba(242,179,61,.5);border-radius:999px;padding:.35rem .9rem;font-weight:700;font-size:.85rem}
.legal{margin-top:1.1rem;padding-top:1rem;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem;color:rgba(239,230,212,.55)}
.legal nav{display:flex;gap:1.2rem;flex-wrap:wrap}
.legal a:hover{color:var(--gold)}

/* ---------- Responsive ---------- */
@media (max-width:1020px){
  .hero-grid{grid-template-columns:1fr;padding-top:2.5rem}
  .hero-visual{min-height:340px}
  .note{right:0}
  .trust{grid-template-columns:repeat(2,1fr);row-gap:1.4rem}
  .trust-item:nth-child(3){border-left:none;padding-left:0}
  .card-row{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .loc-grid{grid-template-columns:1fr}
  .loc-detail,.contact-grid{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:1fr}
  .menu-banner{grid-template-columns:1fr}
}
@media (max-width:760px){
  .menu-toggle{display:block}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--ink-2);flex-direction:column;align-items:flex-start;padding:1.2rem 6%;gap:1.1rem;border-bottom:1px solid var(--line)}
  .nav-links.open{display:flex}
  .nav-cta{margin-left:0}
  .brand-words{display:none}
  .trust{grid-template-columns:1fr}
  .trust-item + .trust-item{border-left:none;padding-left:0}
  .card-row,.gallery{grid-template-columns:1fr}
  .stamp{width:104px;height:104px}
  .menu-nav{top:71px}
}
