/* ============================================================
   SIPS & SLICES CORNER — style.css (no cursor effects)
   ============================================================ */

/* ── 1. CSS VARIABLES ── */
:root {
  --bg:         #0e0b08;
  --bg2:        #161008;
  --text:       #f5ede0;
  --text-muted: #7a6a58;
  --gold:       #c9913a;
  --amber:      #e8a94e;
  --terra:      #b85c38;
  --border:     rgba(201,145,58,0.18);
  --card-bg:    rgba(255,255,255,0.03);
  --input-bg:   rgba(255,255,255,0.04);
  --nav-bg:     rgba(14,11,8,0.95);
}
body.light {
  --bg:         #faf6f0;
  --bg2:        #f0e9de;
  --text:       #1e1209;
  --text-muted: #6b5a47;
  --gold:       #9a6818;
  --amber:      #b87e25;
  --border:     rgba(100,65,20,0.16);
  --card-bg:    rgba(255,255,255,0.75);
  --input-bg:   rgba(255,255,255,0.9);
  --nav-bg:     rgba(250,246,240,0.97);
}

/* ── 2. RESET & BASE ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background:var(--bg); color:var(--text);
  font-family:'DM Sans',sans-serif; font-weight:300;
  overflow-x:hidden;
  transition:background 0.4s, color 0.4s;
}
img { max-width:100%; display:block; }
a   { color:inherit; text-decoration:none; }
.container   { max-width:1200px; margin:0 auto; padding:0 44px; }
.text-center { text-align:center; }

body::before {
  content:''; position:fixed; inset:0; z-index:1; pointer-events:none; opacity:0.022;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ── 3. LOADER ── */
#page-loader { position:fixed; inset:0; z-index:10000; background:var(--bg); display:flex; align-items:center; justify-content:center; transition:opacity 0.6s, visibility 0.6s; }
#page-loader.hidden { opacity:0; visibility:hidden; }
.loader-logo { font-family:'Pinyon Script',cursive; font-size:3rem; color:var(--gold); display:block; margin-bottom:24px; text-align:center; }
.loader-bar  { width:200px; height:1px; background:var(--border); overflow:hidden; }
.loader-fill { height:100%; width:100%; background:var(--gold); transform:translateX(-100%); animation:loaderSlide 1.6s cubic-bezier(0.23,1,0.32,1) forwards; }
@keyframes loaderSlide { to { transform:translateX(0); } }

/* ── 4. NAVBAR ── */
nav#navbar {
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:26px 52px; gap:20px;
  transition:background 0.5s, padding 0.4s, border-color 0.5s;
}
nav#navbar.scrolled { background:var(--nav-bg); backdrop-filter:blur(24px); padding:15px 52px; border-bottom:1px solid var(--border); }
.nav-logo { font-family:'Pinyon Script',cursive; font-size:1.9rem; color:var(--gold); line-height:1.1; flex-shrink:0; }
.nav-logo small { display:block; font-family:'DM Sans',sans-serif; font-size:0.5rem; letter-spacing:0.38em; text-transform:uppercase; color:var(--text-muted); }
.nav-links { display:flex; gap:38px; list-style:none; flex:1; justify-content:center; }
.nav-links a { font-size:0.73rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--text); opacity:0.58; transition:opacity 0.3s, color 0.3s; position:relative; }
.nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; right:100%; height:1px; background:var(--gold); transition:right 0.35s cubic-bezier(0.23,1,0.32,1); }
.nav-links a:hover,.nav-links a.active { opacity:1; color:var(--amber); }
.nav-links a:hover::after,.nav-links a.active::after { right:0; }
.nav-right { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.mode-btn { width:38px; height:38px; border:1px solid var(--border); background:transparent; color:var(--gold); font-size:1rem; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background 0.3s, color 0.3s, border-color 0.3s; }
.mode-btn:hover { background:var(--gold); color:var(--bg); border-color:var(--gold); }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.hamburger span { width:26px; height:1px; background:var(--text); display:block; transition:transform 0.3s, opacity 0.3s; }

/* ── 5. HERO SLIDER ── */
#hero { position:relative; min-height:100vh; overflow:hidden; }
.hero-slides { position:relative; height:100vh; }
.slide { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transition:opacity 0.9s ease; display:flex; align-items:center; }
.slide.active { opacity:1; }
.slide-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(10,7,4,0.82) 0%,rgba(10,7,4,0.42) 100%); }
body.light .slide-overlay { background:linear-gradient(135deg,rgba(10,7,4,0.72) 0%,rgba(10,7,4,0.38) 100%); }
.slide-content { position:relative; z-index:2; width:100%; max-width:1200px; margin:0 auto; padding:80px 52px 0; display:flex; align-items:center; gap:60px; }
.slide-content.reverse { flex-direction:row-reverse; }
.slide-content.center  { justify-content:center; }
.slide-text { flex:1; max-width:560px; }
.slide-content.center .slide-text { max-width:720px; text-align:center; }
.slide-img  { flex:0 0 360px; }
.slide-img img { width:100%; filter:drop-shadow(0 24px 64px rgba(0,0,0,0.65)); }
.subheading { display:inline-block; font-size:0.7rem; letter-spacing:0.38em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; position:relative; padding-left:28px; }
.subheading::before { content:''; position:absolute; left:0; top:50%; transform:translateY(-50%); width:18px; height:1px; background:var(--gold); }
.slide-text h1 { font-family:'Cormorant Garamond',serif; font-size:clamp(3rem,7vw,6.5rem); font-weight:300; line-height:0.95; letter-spacing:-0.02em; margin-bottom:28px; color:#f5ede0; }
.slide-text p { color:rgba(245,237,224,0.72); line-height:1.85; font-size:0.95rem; margin-bottom:40px; }
.slide-btns  { display:flex; gap:20px; align-items:center; }
.center-btns { justify-content:center; }
.slide-prev,.slide-next { position:absolute; top:50%; z-index:10; transform:translateY(-50%); background:rgba(201,145,58,0.1); border:1px solid var(--border); color:#f5ede0; width:52px; height:52px; font-size:1.3rem; cursor:pointer; transition:background 0.3s, color 0.3s; }
.slide-prev:hover,.slide-next:hover { background:var(--gold); color:#0e0b08; }
.slide-prev { left:28px; } .slide-next { right:28px; }
.slide-dots { position:absolute; bottom:36px; left:50%; transform:translateX(-50%); z-index:10; display:flex; gap:10px; }
.dot { width:28px; height:2px; background:rgba(245,237,224,0.3); border:none; cursor:pointer; transition:background 0.3s, width 0.3s; }
.dot.active { background:var(--gold); width:48px; }

/* ── 6. PAGE HERO ── */
.page-hero { position:relative; height:52vh; min-height:360px; display:flex; align-items:center; justify-content:center; background-size:cover; background-position:center; }
.page-hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(10,7,4,0.84) 0%,rgba(10,7,4,0.55) 100%); }
.page-hero-content { position:relative; z-index:2; text-align:center; padding:80px 24px 0; }
.page-hero-content h1 { font-family:'Cormorant Garamond',serif; font-size:clamp(3rem,7vw,6rem); font-weight:300; line-height:1; letter-spacing:-0.02em; margin-bottom:18px; color:#f5ede0; opacity:0; animation:fadeUp 0.9s 0.3s forwards; }
.page-hero-content .subheading { opacity:0; animation:fadeUp 0.9s 0.1s forwards; }
.breadcrumbs { font-size:0.7rem; letter-spacing:0.22em; text-transform:uppercase; color:rgba(245,237,224,0.5); display:flex; align-items:center; justify-content:center; gap:10px; opacity:0; animation:fadeUp 0.9s 0.5s forwards; }
.breadcrumbs a { color:var(--gold); } .breadcrumbs a:hover { color:var(--amber); }

/* ── 7. INFO BAR ── */
.info-bar { background:rgba(201,145,58,0.05); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.info-bar-inner { max-width:1200px; margin:0 auto; padding:0 44px; display:flex; align-items:stretch; flex-wrap:wrap; }
.info-item { display:flex; align-items:center; gap:14px; padding:22px 36px; border-right:1px solid var(--border); flex:1; }
.info-icon { font-size:1.3rem; flex-shrink:0; }
.info-text strong { display:block; font-size:0.88rem; font-weight:400; color:var(--text); }
.info-text span   { font-size:0.78rem; color:var(--text-muted); }
.info-social { display:flex; align-items:center; gap:12px; padding:22px 36px; }
.info-social a { width:34px; height:34px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:0.78rem; color:var(--text-muted); transition:border-color 0.3s, color 0.3s; }
.info-social a:hover { border-color:var(--gold); color:var(--gold); }

/* ── 8. SECTIONS ── */
.section-light { padding:100px 0; background:var(--bg); }
.section-dark  { padding:100px 0; background:var(--bg2); position:relative; }
.section-dark .container { position:relative; z-index:2; }
.section-label { display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.section-label.center { justify-content:center; }
.section-label span { font-size:0.67rem; letter-spacing:0.32em; text-transform:uppercase; color:var(--gold); }
.label-line { width:32px; height:1px; background:var(--gold); }
.section-title { font-family:'Cormorant Garamond',serif; font-size:clamp(2.4rem,4.5vw,4.2rem); font-weight:300; line-height:1.05; letter-spacing:-0.01em; margin-bottom:20px; color:var(--text); }
.section-title em { font-style:italic; color:var(--gold); }
.section-sub { color:var(--text-muted); line-height:1.85; font-size:0.95rem; max-width:640px; margin:0 auto 60px; }
.reveal { opacity:0; transform:translateY(34px); transition:opacity 0.85s cubic-bezier(0.23,1,0.32,1), transform 0.85s cubic-bezier(0.23,1,0.32,1); }
.reveal.visible { opacity:1; transform:none; }

/* ── 9. BUTTONS ── */
.btn-primary { background:var(--gold); color:#0e0b08; border:none; padding:14px 40px; font-family:'DM Sans',sans-serif; font-size:0.8rem; letter-spacing:0.12em; text-transform:uppercase; font-weight:500; cursor:pointer; display:inline-block; position:relative; overflow:hidden; }
.btn-primary::before { content:''; position:absolute; inset:0; background:var(--amber); transform:scaleX(0); transform-origin:left; transition:transform 0.4s cubic-bezier(0.23,1,0.32,1); }
.btn-primary:hover::before { transform:scaleX(1); }
.btn-primary span { position:relative; z-index:1; }
.btn-ghost { color:rgba(245,237,224,0.75); font-size:0.8rem; letter-spacing:0.1em; text-transform:uppercase; transition:color 0.3s; cursor:pointer; }
body.light .btn-ghost { color:var(--text-muted); }
.btn-ghost:hover { color:var(--amber); }
.btn-outline { border:1px solid var(--gold); color:var(--gold); background:transparent; padding:8px 22px; font-size:0.72rem; letter-spacing:0.12em; text-transform:uppercase; cursor:pointer; display:inline-block; transition:background 0.3s, color 0.3s; }
.btn-outline:hover { background:var(--gold); color:#0e0b08; }
.btn-outline-sm { border:1px solid var(--gold); color:var(--gold); background:transparent; padding:6px 16px; font-size:0.68rem; letter-spacing:0.12em; text-transform:uppercase; cursor:pointer; display:inline-block; white-space:nowrap; transition:background 0.3s, color 0.3s; }
.btn-outline-sm:hover { background:var(--gold); color:#0e0b08; }
.price { font-family:'Cormorant Garamond',serif; font-size:1.4rem; font-weight:300; color:var(--gold); }

/* ── 10. ABOUT ── */
.section-about { display:grid; grid-template-columns:1fr 1fr; min-height:580px; }
.about-img { background-size:cover; background-position:center; min-height:480px; }
.about-content { background:var(--bg2); padding:90px 72px; display:flex; flex-direction:column; justify-content:center; }
.about-content p { color:var(--text-muted); line-height:1.9; font-size:0.95rem; margin-bottom:16px; }

/* ── 11. SERVICES ── */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:56px; }
.service-card { background:var(--card-bg); border:1px solid var(--border); padding:52px 40px; text-align:center; transition:background 0.4s; }
.service-card:hover { background:rgba(201,145,58,0.08); }
.service-icon-wrap { font-size:2.8rem; margin-bottom:24px; }
.service-card h3 { font-family:'Cormorant Garamond',serif; font-size:1.6rem; font-weight:400; margin-bottom:12px; color:var(--text); }
.service-card p { color:var(--text-muted); font-size:0.9rem; line-height:1.8; }

/* ── 12. HOW IT WORKS ── */
.how-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; margin-top:56px; }
.how-step { background:var(--card-bg); border:1px solid var(--border); padding:44px 32px; text-align:center; position:relative; overflow:hidden; transition:background 0.4s; }
.how-step:hover { background:rgba(201,145,58,0.08); }
.how-num { font-family:'Cormorant Garamond',serif; font-size:4.5rem; font-weight:300; color:rgba(201,145,58,0.1); position:absolute; top:10px; right:16px; line-height:1; pointer-events:none; }
.how-icon { font-size:2.4rem; margin-bottom:20px; }
.how-step h3 { font-family:'Cormorant Garamond',serif; font-size:1.5rem; font-weight:400; margin-bottom:12px; color:var(--text); }
.how-step p { color:var(--text-muted); font-size:0.88rem; line-height:1.8; }

/* ── 13. PIZZA MEALS ── */
.pizza-grid { display:grid; grid-template-columns:repeat(3,1fr); }
.pizza-card { display:flex; border:1px solid var(--border); border-top:none; border-left:none; transition:background 0.4s; background:var(--bg); }
.pizza-card:hover { background:rgba(201,145,58,0.05); }
.pizza-img { width:140px; flex-shrink:0; background-size:cover; background-position:center; min-height:185px; }
.pizza-info { padding:28px 24px; flex:1; }
.pizza-info h3 { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:400; margin-bottom:8px; color:var(--text); }
.pizza-info p { color:var(--text-muted); font-size:0.83rem; line-height:1.7; margin-bottom:16px; }
.pizza-footer { display:flex; align-items:center; gap:16px; }

/* ── 14. PRICING ── */
.pricing-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px; margin-top:56px; }
.pricing-col  { display:flex; flex-direction:column; gap:4px; }
.pricing-entry { display:flex; align-items:center; gap:16px; padding:18px 0; border-bottom:1px solid var(--border); }
.pricing-img  { width:64px; height:64px; flex-shrink:0; background-size:cover; background-position:center; }
.pricing-desc { flex:1; }
.pricing-desc h3 { font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:400; margin-bottom:4px; color:var(--text); }
.pricing-desc p  { font-size:0.78rem; color:var(--text-muted); }
.pricing-price   { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:300; color:var(--gold); white-space:nowrap; }

/* ── 15. GALLERY ── */
.gallery-strip { display:grid; grid-template-columns:repeat(4,1fr); }
.gallery-item  { aspect-ratio:1; background-size:cover; background-position:center; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; }
.gallery-overlay { position:absolute; inset:0; background:rgba(10,7,4,0); display:flex; align-items:center; justify-content:center; font-size:1.8rem; transition:background 0.4s; }
.gallery-item:hover .gallery-overlay { background:rgba(184,92,56,0.58); }

/* ── 16. COUNTER ── */
.section-counter { position:relative; padding:90px 0; background-size:cover; background-position:center; }
.section-counter .container { position:relative; z-index:2; }
.counter-grid  { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.counter-item  { background:rgba(14,11,8,0.58); border:1px solid var(--border); padding:48px 24px; text-align:center; }
.counter-icon  { font-size:2rem; margin-bottom:16px; }
.counter-num   { font-family:'Cormorant Garamond',serif; font-size:3.2rem; font-weight:300; color:var(--gold); display:block; line-height:1; }
.counter-item > span { font-size:0.7rem; letter-spacing:0.22em; text-transform:uppercase; color:rgba(245,237,224,0.6); margin-top:8px; display:block; }

/* ── 17. MENU TABS ── */
.section-menu { background:var(--bg2); }
.menu-layout  { display:grid; grid-template-columns:320px 1fr; min-height:660px; }
.menu-side-img { background-size:cover; background-position:center; }
.menu-content  { padding:80px 64px; }
.menu-tabs { display:flex; border:1px solid var(--border); margin:36px 0 32px; }
.menu-tab  { padding:11px 26px; background:transparent; border:none; border-right:1px solid var(--border); color:var(--text-muted); font-family:'DM Sans',sans-serif; font-size:0.7rem; letter-spacing:0.15em; text-transform:uppercase; cursor:pointer; transition:background 0.3s, color 0.3s; }
.menu-tab:last-child { border-right:none; }
.menu-tab.active { background:var(--gold); color:#0e0b08; }
.menu-panel        { display:none; }
.menu-panel.active { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.menu-card { background:var(--card-bg); border:1px solid var(--border); overflow:hidden; transition:background 0.4s; }
.menu-card:hover { background:rgba(201,145,58,0.07); }
.menu-card-img  { height:160px; background-size:cover; background-position:center; }
.menu-card-body { padding:20px; }
.menu-card-body h3 { font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:400; margin-bottom:8px; color:var(--text); }
.menu-card-body p  { font-size:0.78rem; color:var(--text-muted); line-height:1.65; margin-bottom:14px; }
.menu-card-footer  { display:flex; justify-content:space-between; align-items:center; }

/* ── 18. SHOWCASE ── */
.showcase-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:56px; }
.showcase-card { background:var(--card-bg); border:1px solid var(--border); overflow:hidden; transition:background 0.4s, transform 0.4s; }
.showcase-card:hover { background:rgba(201,145,58,0.07); transform:translateY(-4px); }
.showcase-img  { height:200px; background-size:cover; background-position:center; transition:transform 0.5s; }
.showcase-card:hover .showcase-img { transform:scale(1.05); }
.showcase-body { padding:22px 20px; }
.showcase-body h3 { font-family:'Cormorant Garamond',serif; font-size:1.2rem; font-weight:400; margin-bottom:8px; color:var(--text); }
.showcase-body p  { font-size:0.8rem; color:var(--text-muted); line-height:1.65; margin-bottom:16px; }
.showcase-footer  { display:flex; justify-content:space-between; align-items:center; }

/* ── 19. CTA BANNER ── */
.cta-banner { background:var(--terra); padding:80px 60px; display:flex; align-items:center; justify-content:space-between; gap:40px; }
.cta-text h2 { font-family:'Cormorant Garamond',serif; font-size:clamp(2rem,4vw,3.2rem); font-weight:300; line-height:1.1; margin-top:10px; color:#f5ede0; }
.cta-text h2 em { font-style:italic; }
.cta-actions { display:flex; gap:20px; align-items:center; flex-shrink:0; }

/* ── 20. CONTACT ── */
.contact-layout { display:grid; grid-template-columns:1fr 1fr; gap:80px; margin-top:60px; }
.contact-info p { color:var(--text-muted); line-height:1.9; font-size:0.95rem; margin-bottom:40px; }
.contact-details { display:flex; flex-direction:column; gap:24px; margin-bottom:40px; }
.contact-item { display:flex; gap:18px; align-items:flex-start; }
.contact-item-icon { width:46px; height:46px; flex-shrink:0; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:1.1rem; color:var(--gold); }
.contact-item-text .lbl { font-size:0.62rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:4px; }
.contact-item-text .val { color:var(--text); font-size:0.9rem; line-height:1.65; }
.contact-item-text a { color:var(--text); transition:color 0.3s; }
.contact-item-text a:hover { color:var(--gold); }
.hours-box { border:1px solid var(--border); overflow:hidden; }
.hours-title { background:var(--gold); color:#0e0b08; padding:12px 22px; font-size:0.67rem; letter-spacing:0.26em; text-transform:uppercase; font-weight:500; }
.hours-row { display:flex; justify-content:space-between; padding:13px 22px; border-bottom:1px solid var(--border); font-size:0.88rem; }
.hours-row:last-child { border-bottom:none; }
.hours-row .day  { color:var(--text-muted); }
.hours-row .time { color:var(--text); font-weight:400; }
.hours-row.today { background:rgba(201,145,58,0.07); }
.hours-row.today .day { color:var(--gold); }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-group { display:flex; flex-direction:column; gap:9px; }
.form-group.full { grid-column:span 2; }
.form-group label { font-size:0.62rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--gold); }
.form-group input,.form-group textarea,.form-group select { background:var(--input-bg); border:1px solid var(--border); padding:13px 18px; color:var(--text); font-family:'DM Sans',sans-serif; font-size:0.9rem; outline:none; appearance:none; transition:border-color 0.3s; }
.form-group input::placeholder,.form-group textarea::placeholder { color:var(--text-muted); }
.form-group input:focus,.form-group textarea:focus,.form-group select:focus { border-color:var(--gold); }
.form-group textarea { resize:vertical; min-height:130px; }
.form-group select option { background:var(--bg2); color:var(--text); }
.btn-submit { background:var(--gold); color:#0e0b08; border:none; padding:15px; width:100%; font-family:'DM Sans',sans-serif; font-size:0.82rem; letter-spacing:0.15em; text-transform:uppercase; font-weight:500; cursor:pointer; margin-top:8px; position:relative; overflow:hidden; transition:background 0.3s; }
.btn-submit::before { content:''; position:absolute; inset:0; background:var(--amber); transform:scaleX(0); transform-origin:left; transition:transform 0.4s cubic-bezier(0.23,1,0.32,1); }
.btn-submit:hover::before { transform:scaleX(1); }
.btn-submit span { position:relative; z-index:1; }
.btn-submit.sent { background:#2a6a3a !important; color:#d4f4d4; pointer-events:none; }
.form-note { font-size:0.72rem; color:var(--text-muted); margin-top:12px; text-align:center; }
.map-section iframe { display:block; width:100%; height:440px; border:0; }

/* ── 21. FOOTER ── */
footer { position:relative; padding:90px 0 0; background:var(--bg2); border-top:1px solid var(--border); }
.footer-overlay { position:absolute; inset:0; pointer-events:none; background:rgba(0,0,0,0.18); }
body.light .footer-overlay { background:rgba(0,0,0,0.04); }
footer .container { position:relative; z-index:2; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1.2fr; gap:52px; margin-bottom:60px; }
.footer-logo { font-family:'Pinyon Script',cursive; font-size:2.2rem; color:var(--gold); display:block; margin-bottom:20px; line-height:1.1; }
.footer-logo small { display:block; font-family:'DM Sans',sans-serif; font-size:0.5rem; letter-spacing:0.35em; text-transform:uppercase; color:var(--text-muted); }
.footer-col p { color:var(--text-muted); font-size:0.86rem; line-height:1.85; }
.footer-social { display:flex; gap:10px; margin-top:24px; }
.footer-social a { width:36px; height:36px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:0.78rem; transition:border-color 0.3s, color 0.3s; }
.footer-social a:hover { border-color:var(--gold); color:var(--gold); }
.footer-col h4 { font-size:0.64rem; letter-spacing:0.28em; text-transform:uppercase; color:var(--gold); margin-bottom:22px; }
.footer-col ul { list-style:none; }
.footer-col ul li { margin-bottom:10px; }
.footer-col ul li a { color:var(--text-muted); font-size:0.86rem; transition:color 0.3s; }
.footer-col ul li a:hover { color:var(--text); }
.footer-contact-list { list-style:none; }
.footer-contact-list li { display:flex; gap:12px; margin-bottom:14px; align-items:flex-start; }
.fc-icon { flex-shrink:0; font-size:1rem; margin-top:2px; }
.footer-contact-list li span,.footer-contact-list li a { font-size:0.84rem; color:var(--text-muted); line-height:1.55; transition:color 0.3s; }
.footer-contact-list li a:hover { color:var(--gold); }
.footer-bottom { border-top:1px solid var(--border); padding:28px 40px; text-align:center; }
.footer-bottom p { font-size:0.78rem; color:var(--text-muted); }
.footer-bottom span { color:var(--gold); }

/* ── 22. ANIMATIONS ── */
@keyframes fadeUp { from { opacity:0; transform:translateY(30px); } to { opacity:1; transform:none; } }

/* ── 23. RESPONSIVE ── */
@media (max-width:1100px) {
  .footer-grid { grid-template-columns:1fr 1fr; gap:36px; }
  .menu-layout { grid-template-columns:1fr; }
  .menu-side-img { display:none; }
  .menu-content { padding:60px 40px; }
  .menu-panel.active { grid-template-columns:1fr 1fr; }
  .how-grid { grid-template-columns:repeat(2,1fr); }
  .showcase-grid { grid-template-columns:repeat(2,1fr); }
  .contact-layout { gap:48px; }
}
@media (max-width:900px) {
  .pizza-grid { grid-template-columns:1fr 1fr; }
  .services-grid { grid-template-columns:1fr; }
  .section-about { grid-template-columns:1fr; }
  .about-img { min-height:320px; }
  .about-content { padding:60px 36px; }
  .counter-grid { grid-template-columns:repeat(2,1fr); }
  .pricing-grid { grid-template-columns:1fr; }
  .contact-layout { grid-template-columns:1fr; gap:52px; }
}
@media (max-width:768px) {
  nav#navbar { padding:18px 24px; }
  nav#navbar.scrolled { padding:14px 24px; }
  .nav-links { display:none; flex-direction:column; gap:20px; }
  .nav-links.open { display:flex; position:fixed; top:64px; left:0; right:0; background:var(--nav-bg); backdrop-filter:blur(20px); padding:28px 24px; border-bottom:1px solid var(--border); z-index:199; }
  .hamburger { display:flex; }
  .slide-content { padding:0 24px; padding-top:80px; flex-direction:column; text-align:center; }
  .slide-content.reverse { flex-direction:column; }
  .slide-img { display:none; }
  .slide-btns { justify-content:center; }
  .slide-prev { left:10px; } .slide-next { right:10px; }
  .info-bar-inner { flex-direction:column; }
  .info-item { border-right:none; border-bottom:1px solid var(--border); }
  .pizza-grid { grid-template-columns:1fr; }
  .gallery-strip { grid-template-columns:1fr 1fr; }
  .counter-grid { grid-template-columns:1fr 1fr; }
  .menu-panel.active { grid-template-columns:1fr; }
  .menu-tabs { flex-wrap:wrap; }
  .menu-content { padding:48px 24px; }
  .how-grid { grid-template-columns:1fr; }
  .showcase-grid { grid-template-columns:1fr; }
  .cta-banner { flex-direction:column; padding:60px 24px; text-align:center; }
  .cta-actions { flex-direction:column; }
  .form-grid { grid-template-columns:1fr; }
  .form-group.full { grid-column:span 1; }
  .footer-grid { grid-template-columns:1fr; gap:36px; }
  .footer-bottom { padding:24px; }
  .page-hero { height:44vh; min-height:280px; }
  .container { padding:0 22px; }
  .section-light,.section-dark { padding:72px 0; }
  .about-content { padding:48px 24px; }
}
