/* E+ROSE — Shared Design System | WCAG 2.1 AA */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --void:#07070A;
  --charcoal:#111113;
  --ink:#1A1A1E;
  --ivory:#F7F2EB;
  --linen:#EDE6D9;
  --parchment:#E2D8C8;
  --gold-text:#7A5C10;
  --gold-ui:#C09A5A;
  --gold-on-dark:#D4AE72;
  --stone:#5C5752;
  --white:#FDFAF4;
  --serif:'Playfair Display',Georgia,'Times New Roman',serif;
  --sans:'DM Sans','Helvetica Neue',Arial,sans-serif;
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

html{scroll-behavior:smooth;font-size:16px}
body{background:var(--ivory);color:var(--void);font-family:var(--sans);font-weight:300;line-height:1.6;overflow-x:hidden}

/* ── SKIP NAV ── */
.skip-nav{position:absolute;top:-100%;left:0;z-index:9999;padding:14px 24px;background:var(--void);color:var(--white);font-size:14px;font-family:var(--sans);font-weight:400;text-decoration:none;border:2px solid var(--gold-on-dark)}
.skip-nav:focus{top:0;outline:3px solid var(--gold-on-dark);outline-offset:2px}

/* ── FOCUS ── */
*:focus-visible{outline:3px solid var(--gold-ui);outline-offset:3px}
*:focus:not(:focus-visible){outline:none}

/* ── NAV ── */
nav[role="navigation"]{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 56px;height:76px;transition:background .5s}
nav[role="navigation"].scrolled{background:rgba(7,7,10,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(212,174,114,.15)}
.nav-logo{display:flex;align-items:center;height:36px;text-decoration:none}
.nav-logo img{height:32px;width:auto;filter:brightness(0) invert(1)}
.nav-links{display:flex;gap:40px;list-style:none}
.nav-links a{font-size:11px;font-weight:300;letter-spacing:.18em;text-transform:uppercase;color:rgba(253,250,244,.75);text-decoration:none;min-height:44px;display:inline-flex;align-items:center;transition:color .25s}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--white)}
.nav-links a[aria-current="page"]{border-bottom:1px solid var(--gold-on-dark);padding-bottom:2px}
.nav-cta{font-size:11px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--void);background:var(--gold-ui);text-decoration:none;padding:14px 28px;min-height:44px;display:inline-flex;align-items:center;transition:background .25s}
.nav-cta:hover{background:#D4AE72}
.nav-end{display:flex;align-items:center;gap:36px}

/* ── PAGE HERO (inner pages) ── */
.page-hero{padding:160px 80px 80px;background:var(--charcoal);position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(212,174,114,.04) 0%,transparent 60%);pointer-events:none}
.page-hero-label{font-size:10px;font-weight:400;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-on-dark);display:flex;align-items:center;gap:14px;margin-bottom:20px}
.page-hero-label::before{content:'';width:24px;height:1px;background:var(--gold-on-dark);flex-shrink:0}
.page-hero h1{font-family:var(--serif);font-size:clamp(44px,6vw,84px);font-weight:400;line-height:1.05;color:var(--white)}
.page-hero h1 em{font-style:italic;color:var(--gold-on-dark);display:block}
.page-hero-sub{font-size:15px;font-weight:300;line-height:1.85;color:rgba(253,250,244,.65);max-width:560px;margin-top:20px}

/* ── SHARED TYPOGRAPHY ── */
.label{font-size:10px;font-weight:400;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-text);display:flex;align-items:center;gap:14px;margin-bottom:24px}
.label::before{content:'';width:24px;height:1px;background:var(--gold-text);flex-shrink:0}
.label-light{font-size:10px;font-weight:400;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-on-dark);display:flex;align-items:center;gap:14px;margin-bottom:24px}
.label-light::before{content:'';width:24px;height:1px;background:var(--gold-on-dark);flex-shrink:0}
.heading-xl{font-family:var(--serif);font-size:clamp(34px,4vw,56px);font-weight:400;line-height:1.1;color:var(--void);margin-bottom:20px}
.heading-xl em{font-style:italic;color:var(--stone)}
.heading-xl-light{font-family:var(--serif);font-size:clamp(34px,4vw,56px);font-weight:400;line-height:1.1;color:var(--white);margin-bottom:20px}
.heading-xl-light em{font-style:italic;color:var(--gold-on-dark)}
.body-text{font-size:15px;font-weight:300;line-height:1.88;color:var(--stone);margin-bottom:28px}
.text-link{font-size:11px;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-text);text-decoration:underline;text-underline-offset:4px;display:inline-flex;align-items:center;gap:10px;min-height:44px;transition:gap .25s}
.text-link:hover{gap:18px}
.text-link-light{font-size:11px;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-on-dark);text-decoration:underline;text-underline-offset:4px;display:inline-flex;align-items:center;gap:10px;min-height:44px;transition:gap .25s}
.text-link-light:hover{gap:18px}

/* ── BUTTONS ── */
.btn-gold{font-size:11px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;color:var(--void);background:var(--gold-ui);padding:16px 40px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;transition:background .25s,transform .2s}
.btn-gold:hover{background:#D4AE72;transform:translateY(-1px)}
.btn-ghost{font-size:11px;font-weight:300;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;color:var(--white);border:1.5px solid rgba(253,250,244,.5);padding:14px 40px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;transition:border-color .25s}
.btn-ghost:hover{border-color:var(--white)}
.btn-dark{font-size:11px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;color:var(--gold-on-dark);background:var(--void);padding:18px 52px;min-height:44px;display:inline-flex;align-items:center;transition:background .25s,transform .2s}
.btn-dark:hover{background:var(--ink);transform:translateY(-1px)}

/* ── CHIPS ── */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}
.chip{font-size:10px;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--void);border:1px solid rgba(7,7,10,.25);padding:8px 16px;min-height:36px;display:inline-flex;align-items:center}

/* ── MARQUEE ── */
.marquee{background:var(--charcoal);border-top:1px solid rgba(212,174,114,.12);border-bottom:1px solid rgba(212,174,114,.12);padding:16px 0;overflow:hidden}
.marquee-inner{display:inline-flex;white-space:nowrap;animation:ticker 32s linear infinite}
.marquee-item{font-family:var(--serif);font-style:italic;font-size:15px;font-weight:300;color:rgba(212,174,114,.5);padding:0 48px}
.marquee-sep{font-style:normal;color:rgba(212,174,114,.7)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── ORDER CTA BAND ── */
.order-band{background:#8B6914;padding:72px 80px;display:grid;grid-template-columns:1fr auto;align-items:center;gap:48px}
.order-band h2{font-family:var(--serif);font-size:clamp(26px,3.5vw,46px);font-weight:400;line-height:1.2;color:var(--white)}
.order-band h2 em{font-style:italic}
.order-band p{font-size:13px;font-weight:300;color:rgba(255,255,255,.8);margin-top:10px}

/* ── FOOTER ── */
footer{background:var(--void);padding:80px 56px 44px;border-top:1px solid rgba(212,174,114,.1)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;margin-bottom:60px}
.footer-logo img{height:30px;width:auto;filter:brightness(0) invert(1);margin-bottom:16px;display:block}
.footer-tagline{font-size:13px;font-weight:300;line-height:1.8;color:rgba(253,250,244,.55);max-width:240px;margin-bottom:24px}
.footer-col-head{font-size:10px;font-weight:400;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-on-dark);margin-bottom:20px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer-links a{font-size:14px;font-weight:300;color:rgba(253,250,244,.55);text-decoration:none;min-height:44px;display:inline-flex;align-items:center;transition:color .2s}
.footer-links a:hover{color:var(--white);text-decoration:underline}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(255,255,255,.07)}
.footer-copy{font-size:12px;font-weight:300;color:rgba(253,250,244,.35);letter-spacing:.05em}
.footer-legal{display:flex;gap:24px;list-style:none}
.footer-legal a{font-size:12px;font-weight:300;color:rgba(253,250,244,.35);text-decoration:underline;text-underline-offset:2px;min-height:44px;display:inline-flex;align-items:center;transition:color .2s}
.footer-legal a:hover{color:rgba(253,250,244,.8)}

/* ── REVEAL ANIMATION ── */
.r{opacity:0;transform:translateY(24px);transition:opacity .85s ease,transform .85s ease}
.r.in{opacity:1;transform:translateY(0)}
.r-d1{transition-delay:.12s}.r-d2{transition-delay:.22s}.r-d3{transition-delay:.32s}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  nav[role="navigation"]{padding:0 24px}
  .nav-links{display:none}
  .page-hero{padding:120px 32px 60px}
  .order-band{grid-template-columns:1fr;gap:24px;padding:56px 32px}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:600px){
  .footer-top{grid-template-columns:1fr}
  .page-hero h1{font-size:clamp(36px,10vw,56px)}
}

/* ═══════════════════════════════════════════════════════════
   MOBILE NAVIGATION — Hamburger menu
═══════════════════════════════════════════════════════════ */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px; height: 44px;
  background: none; border: none;
  cursor: pointer; padding: 0;
  z-index: 300;
}
.nav-hamburger span {
  display: block;
  width: 22px; height: 1.5px;
  background: var(--white);
  transition: transform 0.3s ease, opacity 0.3s ease;
  transform-origin: center;
}
.nav-hamburger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity: 0; }
.nav-hamburger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile drawer */
.mobile-nav-drawer {
  display: none;
  position: fixed;
  top: 76px; left: 0; right: 0; bottom: 0;
  background: rgba(7,7,10,0.98);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  z-index: 199;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0;
  overflow-y: auto;
  padding: 32px 24px 48px;
}
.mobile-nav-drawer.open { display: flex; }
.mobile-nav-drawer a {
  font-family: var(--serif);
  font-size: clamp(28px, 7vw, 40px);
  font-weight: 300;
  color: rgba(253,250,244,0.75);
  text-decoration: none;
  padding: 16px 0;
  width: 100%; text-align: center;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  transition: color 0.2s;
  min-height: 64px; display: flex; align-items: center; justify-content: center;
}
.mobile-nav-drawer a:hover, .mobile-nav-drawer a[aria-current="page"] { color: var(--white); }
.mobile-nav-drawer a:first-child { border-top: 1px solid rgba(255,255,255,0.06); }
.mobile-nav-cta {
  margin-top: 32px !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--void) !important;
  background: var(--gold-ui) !important;
  border: none !important;
  padding: 18px 52px !important;
  min-height: 52px !important;
  width: auto !important;
}

/* ═══════════════════════════════════════════════════════════
   GLOBAL MOBILE FIXES (≤768px)
═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* Nav */
  nav[role="navigation"] { padding: 0 20px; }
  .nav-links, .nav-end .nav-links { display: none; }
  .nav-end .nav-cta { display: none; }
  .nav-hamburger { display: flex; }

  /* Page heroes */
  .page-hero { padding: 110px 24px 52px; }
  .page-hero h1 { font-size: clamp(34px, 9vw, 52px); }
  .page-hero-sub { font-size: 14px; max-width: 100%; }

  /* Section padding */
  .order-band { padding: 52px 24px; grid-template-columns: 1fr; gap: 24px; }
  .order-band h2 { font-size: clamp(24px, 6vw, 38px); }

  /* Footer */
  footer { padding: 56px 24px 36px; }
  .footer-top { grid-template-columns: 1fr; gap: 32px; }
  .footer-bottom { flex-direction: column; gap: 16px; align-items: flex-start; }
  .footer-legal { gap: 20px; }

  /* Typography */
  .heading-xl { font-size: clamp(28px, 7vw, 44px); }
  .heading-xl-light { font-size: clamp(28px, 7vw, 44px); }

  /* Buttons — full width on small screens */
  .btn-gold, .btn-dark, .btn-ghost {
    width: 100%; justify-content: center;
    padding: 16px 24px;
  }

  /* Marquee — slow down slightly on mobile */
  .marquee-inner { animation-duration: 20s; }
}

/* ═══════════════════════════════════════════════════════════
   HOMEPAGE MOBILE FIXES
═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* Hero */
  .hero { min-height: 100svh; }
  .hero-content {
    grid-template-columns: 1fr !important;
    padding: 0 24px 56px !important;
    gap: 28px !important;
  }
  .hero h1 { font-size: clamp(42px, 11vw, 68px) !important; }
  .hero-sub { max-width: 100% !important; }
  .hero-right {
    align-items: flex-start !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
  }
  .btn-gold, .btn-ghost { width: auto !important; }
  .hero-right .btn-gold,
  .hero-right .btn-ghost { width: auto; flex: 1; min-width: 140px; }

  /* About split */
  .about { grid-template-columns: 1fr !important; }
  .about-text { padding: 56px 24px !important; }
  .about-img { min-height: 280px; }

  /* Statement */
  .statement { padding: 72px 24px !important; }

  /* Image strip — 2 cols on mobile */
  .img-strip {
    grid-template-columns: 1fr 1fr !important;
    height: 280px !important;
  }

  /* Menu section */
  .menu-section { padding: 72px 24px !important; }
  .menu-header {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 16px !important;
  }
  .menu-grid { grid-template-columns: 1fr 1fr !important; }

  /* Locations section */
  .loc-grid { grid-template-columns: 1fr !important; }
  .loc-city { padding: 48px 24px !important; }
  .city-name { font-size: 40px !important; }

  /* Pillars */
  .pillars { padding: 72px 24px !important; }
  .pillars-grid { grid-template-columns: 1fr !important; }
  .pillar { padding: 36px 28px !important; }

  /* Order CTA banner */
  .order-cta {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    padding: 64px 24px !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   ABOUT PAGE MOBILE
═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .story-grid { grid-template-columns: 1fr !important; }
  .story-text { padding: 56px 24px !important; }
  .story-img { min-height: 260px; }
  .mantra-section { padding: 64px 24px !important; }
  .mantra-quote { font-size: clamp(18px, 5vw, 30px) !important; }
  .pillars-row { grid-template-columns: 1fr !important; }
  .team-grid { grid-template-columns: 1fr !important; }
  .team-section { padding: 64px 24px !important; }
  .values-grid { grid-template-columns: 1fr !important; }
  .value-card { padding: 36px 24px !important; }
}

/* ═══════════════════════════════════════════════════════════
   LOCATIONS PAGE MOBILE
═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .loc-page-content { grid-template-columns: 1fr !important; padding: 0 24px 48px !important; }
  .loc-page-btns { flex-direction: row !important; align-items: flex-start !important; flex-wrap: wrap !important; gap: 12px !important; }
  .loc-page-btns .btn-ghost { width: auto !important; flex: 1; min-width: 130px; }
  .city-head { padding: 56px 24px 0 !important; flex-direction: column !important; align-items: flex-start !important; gap: 4px !important; }
  .city-head-rule { display: none; }
  .city-head-name { font-size: clamp(52px, 14vw, 80px) !important; }
  .locs-wrap { padding: 24px 24px 56px !important; }
  .locs-grid { grid-template-columns: 1fr !important; }
  .awards-bar { padding: 36px 24px !important; gap: 28px !important; }
  .award-img { height: 40px !important; }
  .cta-band { padding: 56px 24px !important; }
}

/* ═══════════════════════════════════════════════════════════
   CATERING PAGE MOBILE
═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .how-grid { grid-template-columns: 1fr !important; }
  .how-img { min-height: 240px; }
  .how-text { padding: 56px 24px !important; }
  .menus-section { padding: 64px 24px !important; }
  .menu-options { grid-template-columns: 1fr !important; }
  .menu-option { padding: 40px 28px !important; }
  .faq-section { padding: 64px 24px !important; }
  .catering-cta { grid-template-columns: 1fr !important; gap: 36px !important; padding: 64px 24px !important; }
}

/* ═══════════════════════════════════════════════════════════
   CONTACT PAGE MOBILE
═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .contact-layout { grid-template-columns: 1fr !important; }
  .contact-sidebar { padding: 56px 24px !important; order: 2; }
  .contact-form-wrap { padding: 56px 24px !important; order: 1; }
  .form-row { grid-template-columns: 1fr !important; }
  .quick-links { grid-template-columns: 1fr 1fr !important; }
  .form-submit { width: 100%; justify-content: center; }
}

/* ═══════════════════════════════════════════════════════════
   ATLANTA PAGE MOBILE
═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .atl-hero-content { padding: 0 24px 52px !important; }
  .atl-hero-actions { flex-direction: row !important; flex-wrap: wrap !important; gap: 12px !important; }
  .atl-hero-actions .btn-gold,
  .atl-hero-actions .btn-ghost { width: auto !important; flex: 1; min-width: 130px; }
  .atl-intro { grid-template-columns: 1fr !important; padding: 56px 24px !important; }
  .atl-intro-img { min-height: 240px; }
  .atl-locs { padding: 64px 24px !important; }
  .atl-loc-grid { grid-template-columns: 1fr !important; }
  .atl-diff { padding: 64px 24px !important; }
  .atl-diff-grid { grid-template-columns: 1fr !important; }
  .atl-diff-item { padding: 36px 28px !important; }
  .atl-cta { grid-template-columns: 1fr !important; gap: 24px !important; padding: 56px 24px !important; }
}

/* ═══════════════════════════════════════════════════════════
   REVIEWS PAGE MOBILE
═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .reviews-hero { padding: 120px 24px 56px !important; }
  .reviews-hero-inner { grid-template-columns: 1fr !important; gap: 32px !important; }
  .rating-summary { min-width: unset !important; padding: 24px !important; }
  .awards-row { padding: 36px 24px !important; gap: 24px !important; }
  .platform-bar { padding: 20px 24px !important; gap: 10px !important; }
  .platform-btn { padding: 9px 14px !important; font-size: 10px !important; }
  .review-featured { padding: 56px 24px !important; }
  .reviews-section { padding: 64px 24px !important; }
  .reviews-section > div[style] { padding: 28px 24px !important; flex-direction: column !important; align-items: flex-start !important; gap: 20px !important; }
}

/* ═══════════════════════════════════════════════════════════
   VERY SMALL PHONES (≤380px)
═══════════════════════════════════════════════════════════ */
@media (max-width: 380px) {
  .menu-grid { grid-template-columns: 1fr !important; }
  .img-strip { grid-template-columns: 1fr !important; height: auto !important; }
  .img-strip .strip-img { height: 200px; }
  .hero h1 { font-size: clamp(36px, 11vw, 52px) !important; }
  .hero-right { flex-direction: column !important; }
  .hero-right .btn-gold,
  .hero-right .btn-ghost { width: 100% !important; }
  .atl-hero-actions { flex-direction: column !important; }
  .atl-hero-actions .btn-gold,
  .atl-hero-actions .btn-ghost { width: 100% !important; }
  .quick-links { grid-template-columns: 1fr !important; }
  .platform-bar { flex-direction: column !important; align-items: flex-start !important; }
}
