/* ==========================================================================
   Cadillac Jo's — All American Grill · shared styles
   ========================================================================== */
:root{
  --ink:#1a1410;
  --ink-2:#241c16;
  --cream:#f4ead7;
  --cream-2:#ebdfc4;
  --rust:#9a2418;
  --rust-2:#c0392b;
  --gold:#c9a04a;
  --gold-2:#e3c074;
  --muted:#8a7a66;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;}
h1,h2,h3,h4{font-family:'Playfair Display',serif;font-weight:700;line-height:1.15;}
a{color:var(--rust);}
.eyebrow{
  font-family:'Bebas Neue',sans-serif;
  letter-spacing:4px;font-size:14px;
  color:var(--rust-2);text-transform:uppercase;
}
.container{max-width:1280px;margin:0 auto;padding:0 32px;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.btn{
  display:inline-block;padding:16px 36px;
  font-family:'Bebas Neue',sans-serif;
  letter-spacing:3px;font-size:14px;
  text-transform:uppercase;text-decoration:none;
  transition:all .2s ease;cursor:pointer;border:none;
}
.btn-primary{background:var(--rust);color:var(--cream);border:2px solid var(--rust);}
.btn-primary:hover{background:var(--rust-2);}
.btn-outline{background:transparent;color:var(--cream);border:2px solid var(--gold);}
.btn-outline:hover{background:var(--gold);color:var(--ink);}
.btn-dark{background:var(--ink);color:var(--gold-2);border:2px solid var(--ink);}
.btn-dark:hover{background:#000;}

/* NAV */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(20,16,12,.95);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(201,160,74,.2);
}
.nav-inner{
  max-width:1400px;margin:0 auto;padding:16px 32px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav-logo{height:52px;display:block;}
.nav-links{display:flex;gap:32px;list-style:none;flex-wrap:wrap;}
.nav-links a{
  color:var(--cream);text-decoration:none;
  font-family:'Bebas Neue',sans-serif;
  letter-spacing:2px;font-size:15px;transition:color .2s;
}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--gold-2);}
.nav-cta{
  background:var(--rust);color:var(--cream);
  padding:12px 24px;text-decoration:none;white-space:nowrap;
  font-family:'Bebas Neue',sans-serif;letter-spacing:2px;font-size:13px;
}
.nav-cta:hover{background:var(--rust-2);}
@media(max-width:900px){
  .nav-inner{flex-wrap:wrap;justify-content:center;gap:12px;padding:12px 18px;}
  .nav-logo{height:42px;}
  .nav-links{order:3;width:100%;justify-content:center;gap:18px;font-size:13px;}
  .nav-cta{padding:10px 18px;font-size:12px;}
}

/* HERO (home) */
.hero{
  height:100vh;min-height:680px;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  color:var(--cream);text-align:center;
}
.hero-bg{
  position:absolute;inset:0;
  background-image:url('https://images.unsplash.com/photo-1558030006-450675393462?w=2000&q=85&auto=format&fit=crop');
  background-size:cover;background-position:center;filter:brightness(.55);
}
.hero-vignette{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 30%,rgba(20,16,12,.9) 100%);}
.hero-content{position:relative;z-index:2;max-width:900px;padding:0 24px;}
.hero-logo{width:min(540px,80vw);margin:0 auto 8px;display:block;filter:drop-shadow(0 6px 24px rgba(0,0,0,.7));}
.hero-tag{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(20px,2.4vw,28px);color:var(--gold-2);margin:8px 0 36px;}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.scroll-hint{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);color:var(--cream);font-family:'Bebas Neue',sans-serif;letter-spacing:3px;font-size:12px;opacity:.7;z-index:2;}

/* PAGE HERO (interior pages) */
.page-hero{
  position:relative;min-height:44vh;overflow:hidden;
  display:flex;align-items:center;justify-content:center;text-align:center;
  color:var(--cream);padding:150px 24px 70px;
}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.45);}
.page-hero-vignette{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 20%,rgba(20,16,12,.85) 100%);}
.page-hero-content{position:relative;z-index:2;max-width:840px;}
.page-hero h1{font-size:clamp(38px,6vw,66px);color:var(--gold-2);margin:8px 0 16px;}
.page-hero p{font-size:clamp(16px,2vw,20px);opacity:.92;max-width:660px;margin:0 auto;}
.breadcrumb{font-family:'Bebas Neue',sans-serif;letter-spacing:2px;font-size:12px;color:var(--cream);opacity:.75;margin-bottom:4px;}
.breadcrumb a{color:var(--gold-2);text-decoration:none;}
.breadcrumb a:hover{text-decoration:underline;}

/* GENERIC SECTIONS */
.section{padding:88px 32px;}
.section-cream{background:var(--cream);}
.section-cream-2{background:var(--cream-2);}
.section-ink{background:var(--ink);color:var(--cream);}
.section-ink h2,.section-ink h3{color:var(--gold-2);}
.narrow{max-width:820px;margin:0 auto;}
.center{text-align:center;}
.section h2.section-title{font-size:clamp(32px,4.5vw,52px);margin:14px 0 24px;}
.section-ink h2.section-title{color:var(--gold-2);}
.lead{font-size:18px;opacity:.85;max-width:620px;margin:0 auto 8px;}
.prose p{font-size:17px;margin-bottom:18px;color:#3a2e24;}
.section-ink .prose p{color:var(--cream);opacity:.9;}
.prose p:last-child{margin-bottom:0;}

/* SIGNATURE STRIP */
.signature{display:grid;grid-template-columns:repeat(3,1fr);background:var(--ink);}
.sig-card{aspect-ratio:1/1;position:relative;overflow:hidden;}
.sig-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s ease;}
.sig-card:hover img{transform:scale(1.06);}
.sig-card .overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,16,12,.95) 0%,rgba(20,16,12,.3) 50%,transparent 100%);}
.sig-card .caption{position:absolute;left:0;right:0;bottom:0;padding:36px;color:var(--cream);}
.sig-card h3{font-size:32px;color:var(--gold-2);margin-bottom:6px;}
.sig-card p{font-size:14px;opacity:.9;}
@media(max-width:820px){.signature{grid-template-columns:1fr;}}

/* STORY (split) */
.story{display:grid;grid-template-columns:1.1fr 1fr;}
.story-img{background-image:url('/img/restaurant-interior.jpg');background-size:cover;background-position:center;min-height:520px;}
.story-text{padding:88px 72px;background:var(--cream);}
.story-text h2{font-size:clamp(34px,4vw,50px);margin:14px 0 28px;color:var(--ink);}
.story-text p{font-size:17px;color:#3a2e24;margin-bottom:18px;max-width:540px;}
.story-text .signature-line{margin-top:32px;font-family:'Playfair Display',serif;font-style:italic;font-size:20px;color:var(--rust);}
@media(max-width:900px){.story{grid-template-columns:1fr;}.story-text{padding:60px 32px;}.story-img{min-height:340px;}}

/* MENU CARD PREVIEW GRID */
.menu-preview{padding:110px 32px;background:var(--ink);color:var(--cream);text-align:center;background-image:radial-gradient(ellipse at top,rgba(154,36,24,.12),transparent 60%);}
.menu-preview h2{font-size:clamp(40px,5vw,60px);color:var(--gold-2);margin:14px 0 12px;}
.menu-preview .lead{font-size:18px;color:var(--cream);opacity:.8;max-width:560px;margin:0 auto 56px;}
.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1280px;margin:0 auto;}
.menu-card{background:var(--ink-2);border:1px solid rgba(201,160,74,.2);text-align:left;transition:transform .3s,border-color .3s;}
.menu-card:hover{transform:translateY(-6px);border-color:var(--gold);}
.menu-card .img{aspect-ratio:4/3;background-size:cover;background-position:center;}
.menu-card .body{padding:24px;}
.menu-card h3,.menu-card h4{font-size:22px;color:var(--gold-2);margin-bottom:6px;}
.menu-card .desc{font-size:13px;opacity:.75;margin-bottom:12px;line-height:1.5;}
.menu-card .price{font-family:'Bebas Neue',sans-serif;letter-spacing:2px;font-size:18px;color:var(--cream);}
.menu-cta{margin-top:56px;}
@media(max-width:1000px){.menu-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.menu-grid{grid-template-columns:1fr;}}

/* FULL TEXT MENU (menu page) */
.menu-full{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:24px 64px;}
.menu-cat{break-inside:avoid;margin-bottom:28px;}
.menu-cat > h2{font-size:clamp(26px,3.4vw,38px);color:var(--gold-2);border-bottom:2px solid rgba(201,160,74,.35);padding-bottom:10px;margin-bottom:6px;}
.menu-cat .cat-note{font-size:13.5px;opacity:.7;font-style:italic;margin-bottom:20px;}
.menu-item{margin-bottom:20px;}
.menu-item-head{display:flex;justify-content:space-between;align-items:baseline;gap:14px;}
.menu-item .name{font-family:'Playfair Display',serif;font-weight:700;font-size:19px;color:var(--gold-2);}
.menu-item .price{font-family:'Bebas Neue',sans-serif;letter-spacing:1px;font-size:19px;color:var(--cream);white-space:nowrap;}
.menu-item .desc{font-size:14px;opacity:.78;margin-top:3px;max-width:520px;}
.menu-note{max-width:1120px;margin:44px auto 0;font-size:13px;opacity:.65;font-style:italic;text-align:center;}
.menu-image{width:100%;max-width:900px;height:auto;border:1px solid rgba(201,160,74,.3);box-shadow:0 20px 60px rgba(0,0,0,.5);display:block;margin:0 auto;}
@media(max-width:820px){.menu-full{grid-template-columns:1fr;gap:8px;}}

/* FEATURE BAND */
.feature{height:600px;position:relative;overflow:hidden;display:flex;align-items:center;color:var(--cream);}
.feature-bg{position:absolute;inset:0;background-image:url('/img/feature-filet-sandwich.jpg');background-size:cover;background-position:center;filter:brightness(.6);}
.feature-content{position:relative;z-index:2;margin-left:8%;max-width:520px;padding:48px;background:rgba(20,16,12,.78);border-left:4px solid var(--gold);backdrop-filter:blur(4px);}
.feature-content h2{font-size:clamp(30px,4vw,44px);color:var(--gold-2);margin:14px 0 20px;}
.feature-content p{font-size:16px;opacity:.92;margin-bottom:28px;}
@media(max-width:820px){.feature{height:auto;padding:60px 0;}.feature-content{margin:0 20px;}}

/* VIBE GRID */
.vibe{padding:110px 32px;background:var(--cream);text-align:center;}
.vibe h2{font-size:clamp(38px,5vw,56px);margin:14px 0 12px;color:var(--ink);}
.vibe .lead{font-size:18px;color:#5a4a38;max-width:560px;margin:0 auto 56px;}
.vibe-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:280px 280px;gap:16px;max-width:1280px;margin:0 auto;}
.vibe-grid > div{background-size:cover;background-position:center;transition:transform .6s;}
.vibe-grid > div:hover{transform:scale(1.02);}
.v1{grid-row:1/3;background-image:url('https://images.unsplash.com/photo-1514362545857-3bc16c4c7d1b?w=1200&q=85&auto=format&fit=crop');}
.v2{background-image:url('https://images.unsplash.com/photo-1551024709-8f23befc6f87?w=800&q=85&auto=format&fit=crop');}
.v3{background-image:url('https://images.unsplash.com/photo-1470337458703-46ad1756a187?w=800&q=85&auto=format&fit=crop');}
.v4{background-image:url('https://images.unsplash.com/photo-1517248135467-4c7edcad34c4?w=800&q=85&auto=format&fit=crop');}
.v5{background-image:url('https://images.unsplash.com/photo-1485872299829-c673f5194813?w=800&q=85&auto=format&fit=crop');}
@media(max-width:820px){.vibe-grid{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,200px);}.v1{grid-row:auto;grid-column:1/3;}}

/* CTA BAND */
.cta-band{padding:88px 32px;background:linear-gradient(135deg,var(--rust) 0%,#6a1810 100%);color:var(--cream);text-align:center;}
.cta-band .eyebrow{color:var(--gold-2);}
.cta-band h2{font-size:clamp(34px,4.5vw,54px);color:var(--gold-2);margin:14px 0 16px;}
.cta-band .lead{font-size:17px;opacity:.92;max-width:520px;margin:0 auto 8px;}
.phone-lg{margin-top:18px;font-family:'Bebas Neue',sans-serif;font-size:34px;letter-spacing:2px;color:var(--gold-2);display:inline-block;text-decoration:none;}
.phone-lg:hover{color:var(--cream);}

/* INFO CARDS (visit) */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1120px;margin:0 auto;}
.info-card{background:var(--cream-2);padding:34px;border-top:3px solid var(--gold);}
.info-card h3{font-family:'Bebas Neue',sans-serif;letter-spacing:2px;font-size:15px;color:var(--rust);margin-bottom:12px;}
.info-card p{font-size:17px;color:var(--ink);}
.info-card a{color:var(--rust);text-decoration:none;}
.info-card a:hover{text-decoration:underline;}
@media(max-width:820px){.info-grid{grid-template-columns:1fr;}}

/* MAP */
.map-wrap{max-width:1120px;margin:44px auto 0;border:1px solid rgba(201,160,74,.35);line-height:0;}
.map-embed{width:100%;border:0;min-height:420px;display:block;}

/* FAQ */
.faq{max-width:820px;margin:0 auto;}
.faq-item{border-bottom:1px solid rgba(201,160,74,.3);padding:24px 0;}
.faq-item:first-child{border-top:1px solid rgba(201,160,74,.3);}
.faq-item h3{font-size:20px;margin-bottom:8px;color:var(--ink);}
.section-ink .faq-item h3{color:var(--gold-2);}
.faq-item p{font-size:16px;color:#3a2e24;}
.section-ink .faq-item p{color:var(--cream);opacity:.88;}

/* FOOTER */
.footer{background:var(--ink);color:var(--cream);padding:64px 32px 40px;text-align:center;}
.footer-logo{height:76px;margin:0 auto 20px;display:block;}
.footer-links{display:flex;justify-content:center;gap:32px;margin:24px 0;flex-wrap:wrap;}
.footer-links a{color:var(--cream);text-decoration:none;font-family:'Bebas Neue',sans-serif;letter-spacing:2px;font-size:13px;}
.footer-links a:hover{color:var(--gold);}
.footer .footer-contact{font-size:14px;opacity:.8;margin:16px 0;}
.footer .footer-contact a{color:var(--gold-2);text-decoration:none;}
.footer small{color:#8a7a66;font-size:12px;display:block;margin-top:24px;}
