/* ============================================================
   C'S CAFE - GLOBAL STYLESHEET
   assets/css/style.css
   Design Bridge Studios / Master's Touch Network
   ============================================================ */

/* SECTION 1 - CSS CUSTOM PROPERTIES */
:root {
  --color-cream:#F5F0E8;--color-cream-dark:#EDE5D4;--color-espresso:#3B1F0C;
  --color-coffee:#6B3A1F;--color-amber:#C07A2F;--color-amber-light:#E8A94A;
  --color-sage:#7A8C6E;--color-white:#FFFFFF;--color-border:#D6C9B4;
  --bg-page:var(--color-cream);--bg-section-alt:var(--color-cream-dark);
  --bg-hero:#2A1506;--bg-card:var(--color-white);--bg-footer:#2A1506;
  --font-display:'Playfair Display',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --text-primary:var(--color-espresso);--text-secondary:var(--color-coffee);
  --text-muted:#7A6A58;--text-on-dark:var(--color-cream);
  --text-link:var(--color-amber);--text-link-hover:var(--color-amber-light);
  --text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-md:1.125rem;
  --text-lg:1.25rem;--text-xl:1.5rem;
  --text-2xl:clamp(1.5rem,3vw,1.875rem);--text-3xl:clamp(1.75rem,4vw,2.25rem);
  --text-4xl:clamp(2rem,5vw,3rem);--text-hero:clamp(2.25rem,5vw,4rem);
  --space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;
  --space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;
  --space-section:clamp(3rem,6vw,6rem);
  --max-width:1200px;--max-width-text:720px;--gutter:clamp(1rem,4vw,2rem);
  --radius-sm:4px;--radius-md:8px;--radius-lg:16px;--radius-pill:999px;
  --shadow-card:0 2px 12px rgba(59,31,12,0.10);
  --shadow-hover:0 6px 24px rgba(59,31,12,0.18);
  --btn-primary-bg:var(--color-coffee);--btn-primary-text:var(--color-cream);
  --btn-primary-hover:var(--color-espresso);
  --btn-secondary-bg:transparent;--btn-secondary-text:var(--color-coffee);
  --btn-secondary-border:var(--color-coffee);
  --transition-fast:150ms ease;--transition-base:250ms ease;
}

/* SECTION 2 - RESET & BASE */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}
body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.6;color:var(--text-primary);background-color:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,picture,video,canvas,svg{display:block;max-width:100%}
input,button,textarea,select{font:inherit}
p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}
nav ul,nav ol{list-style:none}
a{color:var(--text-link);text-decoration:none}
a:hover{color:var(--text-link-hover);text-decoration:underline}
button{cursor:pointer}
table{border-collapse:collapse;width:100%}

/* SECTION 3 - TYPOGRAPHY */
h1,h2,h3,h4{font-family:var(--font-display);color:var(--text-secondary);line-height:1.2;font-weight:700}
h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-xl)}
h4{font-size:var(--text-lg);font-weight:400;font-style:italic}
p{font-family:var(--font-body);line-height:1.6;color:var(--text-primary)}
p+p{margin-top:var(--space-md)}
.lead{font-size:var(--text-md);line-height:1.75;color:var(--text-muted)}
strong{font-weight:600;color:var(--text-secondary)}
em{font-style:italic}
small{font-size:var(--text-sm)}

/* SECTION 4 - LAYOUT UTILITIES */
.container{max-width:var(--max-width);margin-inline:auto;padding-inline:var(--gutter)}
.container-text{max-width:var(--max-width-text);margin-inline:auto;padding-inline:var(--gutter)}
.section-pad{padding-block:var(--space-section)}
.flex{display:flex}.flex-col{display:flex;flex-direction:column}
.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}

/* SECTION 5 - NAVIGATION */
.skip-link{position:absolute;top:-100%;left:0;z-index:9999;background:var(--bg-hero);color:var(--text-on-dark);padding:var(--space-md) var(--space-lg);font-family:var(--font-body);font-weight:600;text-decoration:none;transition:top var(--transition-fast)}
.skip-link:focus{top:0}
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:transparent;transition:background var(--transition-base),box-shadow var(--transition-base)}
.site-header.is-scrolled{background:var(--bg-footer);box-shadow:0 2px 16px rgba(42,21,6,0.4)}
.nav-container{display:flex;align-items:center;justify-content:space-between;max-width:var(--max-width);margin-inline:auto;padding-inline:var(--gutter);height:72px}
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.nav-logo img{height:48px;width:auto}
.nav-links{display:none;flex-direction:column;gap:var(--space-lg);list-style:none;position:absolute;top:72px;left:0;right:0;background:var(--bg-footer);padding:var(--space-xl) var(--gutter);box-shadow:0 8px 24px rgba(42,21,6,0.3);transform:translateY(-8px);opacity:0;pointer-events:none;transition:transform var(--transition-base),opacity var(--transition-base)}
.nav-links.open{display:flex;transform:translateY(0);opacity:1;pointer-events:auto}
.nav-links a{font-family:var(--font-body);font-weight:500;font-size:var(--text-base);color:var(--text-on-dark);text-decoration:none;padding-block:var(--space-sm);display:block;transition:color var(--transition-fast)}
.nav-links a:hover,.nav-links a.active{color:var(--color-amber);text-decoration:none}
.nav-links a.active{text-decoration:underline;text-underline-offset:4px}
.nav-phone{display:none;font-family:var(--font-body);font-weight:600;font-size:var(--text-sm);color:var(--text-on-dark);text-decoration:none;letter-spacing:0.01em;transition:color var(--transition-fast)}
.nav-phone:hover{color:var(--color-amber);text-decoration:none}
.site-header:not(.is-scrolled) .nav-links a{color:var(--text-on-dark)}
.nav-hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;background:transparent;border:none;cursor:pointer;padding:var(--space-sm);border-radius:var(--radius-sm);transition:background var(--transition-fast)}
.nav-hamburger:hover{background:rgba(255,255,255,0.08)}
.nav-hamburger:focus-visible{outline:2px solid var(--color-amber);outline-offset:2px}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--color-cream);border-radius:2px;transition:transform var(--transition-base),opacity var(--transition-base)}

/* SECTION 6 - HERO */
.section-hero{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-overlay{position:absolute;inset:0;background:rgba(42,21,6,0.62);z-index:1}
.hero-content{position:relative;z-index:2;width:100%;max-width:800px;padding-inline:var(--gutter);margin-inline:auto;text-align:center}
.hero-eyebrow{display:inline-block;font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--color-amber);margin-bottom:var(--space-lg)}
.section-hero h1{font-size:var(--text-hero);color:var(--text-on-dark);font-family:var(--font-display);line-height:1.15;margin-bottom:var(--space-lg)}
.hero-sub{font-size:var(--text-md);color:var(--text-on-dark);opacity:0.85;line-height:1.7;max-width:640px;margin-inline:auto;margin-bottom:var(--space-xl)}
.hero-cta-group{display:flex;gap:var(--space-md);flex-wrap:wrap;justify-content:center;margin-top:var(--space-xl);margin-bottom:var(--space-lg)}
.hero-meta{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-on-dark);opacity:0.7;letter-spacing:0.02em;margin-top:var(--space-lg)}
.hero-meta a{color:var(--text-on-dark);text-decoration:none;opacity:0.9;transition:opacity var(--transition-fast)}
.hero-meta a:hover{opacity:1;text-decoration:underline}
.hero-meta .meta-sep{margin-inline:var(--space-sm);opacity:0.4}

/* SECTION 7 - FEATURES STRIP */
.section-features{background:var(--bg-section-alt);padding-block:var(--space-section)}
.features-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}
.feature-tile{text-align:center;padding-top:var(--space-lg);border-top:3px solid var(--color-amber)}
.feature-title{font-family:var(--font-display);font-style:italic;font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-sm)}
.feature-desc{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);line-height:1.6}

/* SECTION 8 - MENU PREVIEW CARDS */
.section-menu-preview{background:var(--bg-page);padding-block:var(--space-section)}
.section-menu-preview>.container>.section-intro{text-align:center;max-width:var(--max-width-text);margin-inline:auto;margin-bottom:var(--space-2xl)}
.section-menu-preview>.container>.section-intro h2{margin-bottom:var(--space-md)}
.menu-preview-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}
.menu-card{background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-card);transition:box-shadow var(--transition-base),transform var(--transition-base)}
.menu-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}
.menu-card img{display:block;width:100%;aspect-ratio:3/2;object-fit:cover}
.menu-card-body{padding:var(--space-lg)}
.menu-card-body h3{font-family:var(--font-display);color:var(--text-secondary);font-size:var(--text-lg);margin-bottom:var(--space-sm)}
.menu-card-body p{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);line-height:1.6;margin-bottom:var(--space-md)}
.card-link{display:inline-flex;align-items:center;gap:var(--space-xs);color:var(--color-amber);font-weight:600;font-size:var(--text-sm);text-decoration:none;transition:gap var(--transition-fast),color var(--transition-fast)}
.card-link:hover{color:var(--color-amber-light);gap:var(--space-sm);text-decoration:none}
.card-link::after{content:'\2192';display:inline-block}

/* SECTION 9 - FULL MENU */
.section-menu{background:var(--bg-page);padding-block:var(--space-section)}
.section-menu>.container>.section-intro{text-align:center;max-width:var(--max-width-text);margin-inline:auto;margin-bottom:var(--space-2xl)}
.section-menu>.container>.section-intro h2{margin-bottom:var(--space-md)}
.menu-jump-nav{display:flex;gap:var(--space-sm);flex-wrap:wrap;overflow-x:auto;padding-block:var(--space-md);padding-inline:var(--gutter);margin-bottom:var(--space-2xl);position:sticky;top:72px;z-index:100;background:var(--bg-page);border-bottom:1px solid var(--color-border);-webkit-overflow-scrolling:touch;scrollbar-width:none}
.menu-jump-nav::-webkit-scrollbar{display:none}
.menu-jump-nav a{display:inline-flex;align-items:center;padding:0.4rem 1rem;border-radius:var(--radius-pill);background:var(--color-cream-dark);color:var(--text-secondary);font-family:var(--font-body);font-size:var(--text-sm);font-weight:500;white-space:nowrap;text-decoration:none;transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0}
.menu-jump-nav a:hover,.menu-jump-nav a.active{background:var(--btn-primary-bg);color:var(--btn-primary-text);text-decoration:none}
.menu-category{margin-bottom:var(--space-3xl)}
.menu-category:last-child{margin-bottom:0}
.menu-category-header{background:var(--bg-section-alt);padding:var(--space-md) var(--space-lg);border-left:4px solid var(--color-amber);margin-bottom:var(--space-xl)}
.menu-category-header h2{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--text-secondary);margin-bottom:var(--space-xs)}
.menu-category-header .category-intro{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-sm)}
.menu-items-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md)}
.menu-item-card{background:var(--bg-card);border-radius:var(--radius-sm);padding:var(--space-md);box-shadow:0 1px 6px rgba(59,31,12,0.07)}
.menu-item-card .item-name{font-family:var(--font-body);font-weight:600;font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-xs)}
.menu-item-card .item-desc{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);line-height:1.5;margin:0}
.menu-note{font-style:italic;font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);border-left:2px solid var(--color-border)}
.menu-specials-cta{background:var(--bg-section-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-xl);text-align:center;margin-top:var(--space-3xl)}
.menu-specials-cta p{font-size:var(--text-md);color:var(--text-secondary);margin-bottom:var(--space-md)}
.menu-specials-cta a{color:var(--color-amber);font-weight:600}
.menu-section-img{width:100%;border-radius:var(--radius-md);margin-bottom:var(--space-xl);overflow:hidden}
.menu-section-img img{width:100%;height:280px;object-fit:cover;display:block}

/* SECTION 10 - ABOUT */
.section-about{background:var(--bg-section-alt);padding-block:var(--space-section)}
.about-layout{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);align-items:center}
.about-img{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3}
.about-img img{width:100%;height:100%;object-fit:cover;display:block}
.about-text{display:flex;flex-direction:column;gap:var(--space-lg)}
.about-eyebrow{display:inline-block;font-family:var(--font-body);font-size:var(--text-xs);font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-amber);margin-bottom:var(--space-xs)}
.about-text h2{margin-bottom:var(--space-md)}
.about-body p{font-family:var(--font-body);font-size:1.1rem;color:var(--text-primary);line-height:1.7;margin-bottom:var(--space-md)}
.about-body p:last-of-type{margin-bottom:0}
.about-tiles{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);margin-top:var(--space-md)}
.about-tile{padding-top:var(--space-md);border-top:2px solid var(--color-amber)}
.about-tile-title{font-family:var(--font-body);font-weight:600;font-size:var(--text-sm);color:var(--text-secondary)}
.about-social-cta{margin-top:var(--space-lg)}
.about-social-cta p{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-sm)}
.about-social-links{display:flex;gap:var(--space-md);flex-wrap:wrap}
.about-social-links a{font-family:var(--font-body);font-weight:600;font-size:var(--text-sm);color:var(--color-amber);text-decoration:none;transition:color var(--transition-fast)}
.about-social-links a:hover{color:var(--color-amber-light)}
.about-secondary-img{margin-top:var(--space-2xl);border-radius:var(--radius-md);overflow:hidden}
.about-secondary-img img{width:100%;height:280px;object-fit:cover;display:block}

/* SECTION 11 - REVIEWS */
.section-reviews{background:var(--bg-page);padding-block:var(--space-section)}
.section-reviews>.container>.section-intro{text-align:center;max-width:var(--max-width-text);margin-inline:auto;margin-bottom:var(--space-2xl)}
.section-reviews>.container>.section-intro h2{margin-bottom:var(--space-sm)}
.reviews-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}
.review-card{background:var(--bg-card);border-radius:var(--radius-md);padding:var(--space-xl);box-shadow:var(--shadow-card);position:relative}
.review-card::before{content:'\201C';position:absolute;top:var(--space-md);left:var(--space-lg);font-family:var(--font-display);font-size:4rem;line-height:1;color:var(--color-amber);opacity:0.25}
.review-stars{display:flex;gap:2px;margin-bottom:var(--space-md)}
.review-stars .star{color:var(--color-amber);font-size:var(--text-md)}
.review-stars .star-empty{color:var(--color-border);font-size:var(--text-md)}
.review-text{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-primary);line-height:1.7;margin-bottom:var(--space-lg)}
.reviewer-name{font-family:var(--font-body);font-weight:600;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-xs)}
.reviewer-source{font-family:var(--font-body);font-size:var(--text-xs);color:var(--text-muted)}
.reviews-attribution{text-align:center;margin-top:var(--space-2xl);font-size:var(--text-sm);color:var(--text-muted)}
.reviews-attribution a{color:var(--color-amber);font-weight:600}

/* SECTION 12 - CONTACT */
.section-contact{background:var(--bg-section-alt);padding-block:var(--space-section)}
.section-contact>.container>.section-intro{margin-bottom:var(--space-2xl)}
.section-contact>.container>.section-intro h2{margin-bottom:var(--space-sm)}
.contact-layout{display:grid;grid-template-columns:1fr;gap:var(--space-3xl)}
.contact-info-block{display:flex;flex-direction:column;gap:var(--space-2xl)}
.contact-info-group h3{font-family:var(--font-display);font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-sm)}
.contact-info-group p{font-size:var(--text-sm);color:var(--text-primary);line-height:1.7}
.contact-info-group a{color:var(--color-amber);font-weight:600;text-decoration:none;display:inline-block;margin-top:var(--space-xs)}
.contact-info-group a:hover{color:var(--color-amber-light)}
.hours-table{width:100%;border:none}
.hours-table th{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:var(--text-sm);color:var(--text-secondary);text-align:left;padding:var(--space-sm) var(--space-md) var(--space-sm) 0;white-space:nowrap;width:40%}
.hours-table td{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-primary);padding:var(--space-sm) 0}
.hours-table tr+tr th,.hours-table tr+tr td{border-top:1px solid var(--color-border)}
.map-embed-wrapper{width:100%;aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius-md);background:var(--color-cream-dark)}
.map-embed-wrapper iframe{width:100%;height:100%;border:0;display:block}
.delivery-links{display:flex;gap:var(--space-md);flex-wrap:wrap;margin-top:var(--space-sm)}
.delivery-links a{display:inline-flex;align-items:center;padding:0.5rem 1.25rem;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--color-border);color:var(--text-secondary);font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;text-decoration:none;transition:border-color var(--transition-fast),color var(--transition-fast)}
.delivery-links a:hover{border-color:var(--color-amber);color:var(--color-amber);text-decoration:none}
.contact-storefront-img{border-radius:var(--radius-md);overflow:hidden;margin-top:var(--space-xl)}
.contact-storefront-img img{width:100%;height:220px;object-fit:cover;display:block}
.contact-form{display:flex;flex-direction:column;gap:var(--space-md)}
.contact-form .form-group{display:flex;flex-direction:column;gap:var(--space-xs)}
.contact-form label{font-family:var(--font-body);font-weight:500;font-size:var(--text-sm);color:var(--text-secondary)}
.contact-form input,.contact-form textarea{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);font-family:var(--font-body);font-size:var(--text-base);color:var(--text-primary);width:100%;transition:border-color var(--transition-fast),outline var(--transition-fast)}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--color-amber);outline-offset:1px;border-color:var(--color-amber)}
.contact-form textarea{resize:vertical;min-height:140px}
.contact-form .form-footer-note{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-sm)}
.contact-form .form-footer-note a{color:var(--color-amber);font-weight:600}

/* SECTION 13 - FOOTER */
.site-footer{background:var(--bg-footer);color:var(--text-on-dark);padding:var(--space-2xl) var(--gutter)}
.footer-inner{max-width:var(--max-width);margin-inline:auto}
.footer-grid{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);padding-bottom:var(--space-2xl)}
.footer-logo{display:flex;align-items:flex-start;margin-bottom:var(--space-md)}
.footer-logo img{height:40px;width:auto;filter:brightness(0) invert(1) opacity(0.9)}
.footer-about{font-size:var(--text-sm);color:var(--text-on-dark);opacity:0.75;line-height:1.65;max-width:280px}
.footer-col h4{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-on-dark);opacity:0.55;margin-bottom:var(--space-md)}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-sm)}
.footer-col ul li a,.footer-col p a{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-on-dark);opacity:0.8;text-decoration:none;transition:opacity var(--transition-fast),color var(--transition-fast);display:inline-block}
.footer-col ul li a:hover,.footer-col p a:hover{opacity:1;color:var(--color-amber);text-decoration:none}
.footer-col p{font-size:var(--text-sm);color:var(--text-on-dark);opacity:0.8;line-height:1.7;margin-bottom:var(--space-sm)}
.footer-copyright{text-align:center;font-size:var(--text-xs);color:var(--text-on-dark);opacity:0.5;border-top:1px solid rgba(255,255,255,0.1);margin-top:var(--space-xl);padding-top:var(--space-md);letter-spacing:0.02em}

/* SECTION 14 - BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:0.75rem 1.5rem;border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:600;font-size:0.9375rem;line-height:1;text-decoration:none;cursor:pointer;border:2px solid transparent;transition:background var(--transition-base),color var(--transition-base),border-color var(--transition-base),transform var(--transition-fast),box-shadow var(--transition-base);white-space:nowrap}
.btn:focus-visible{outline:2px solid var(--color-amber);outline-offset:3px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text);border-color:var(--btn-primary-bg)}
.btn-primary:hover{background:var(--btn-primary-hover);border-color:var(--btn-primary-hover);color:var(--btn-primary-text);text-decoration:none}
.btn-secondary{background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border-color:var(--btn-secondary-border)}
.btn-secondary:hover{background:var(--btn-secondary-text);color:var(--btn-primary-text);border-color:var(--btn-secondary-text);text-decoration:none}
.btn-ghost{background:transparent;border-color:transparent;color:var(--color-amber);padding-inline:0}
.btn-ghost:hover{color:var(--color-amber-light);text-decoration:underline;background:transparent}
.btn-on-dark{background:var(--color-cream);color:var(--color-espresso);border-color:var(--color-cream)}
.btn-on-dark:hover{background:var(--color-amber-light);border-color:var(--color-amber-light);color:var(--color-espresso);text-decoration:none}

/* SECTION 15 - UTILITIES */
.sr-only,.visually-hidden{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border-width:0!important}
.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}
.mt-auto{margin-top:auto}.mb-0{margin-bottom:0}.pb-0{padding-bottom:0}
.section-eyebrow{display:block;font-family:var(--font-body);font-size:var(--text-xs);font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-amber);margin-bottom:var(--space-sm)}
.amber-rule{display:block;width:48px;height:3px;background:var(--color-amber);margin-block:var(--space-md)}
.amber-rule-center{margin-inline:auto}
.faq-section{padding-block:var(--space-section)}
.faq-list{display:flex;flex-direction:column;gap:var(--space-lg);max-width:var(--max-width-text);margin-inline:auto}
.faq-item{border-bottom:1px solid var(--color-border);padding-bottom:var(--space-lg)}
.faq-item:last-child{border-bottom:none;padding-bottom:0}
.faq-question{font-family:var(--font-display);font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-sm)}
.faq-answer{font-size:var(--text-sm);color:var(--text-primary);line-height:1.75}
.faq-answer a{color:var(--color-amber);font-weight:600}
.breadcrumb{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-sm);color:var(--text-muted);padding-block:var(--space-lg);flex-wrap:wrap}
.breadcrumb a{color:var(--text-muted);text-decoration:none}
.breadcrumb a:hover{color:var(--color-amber)}
.breadcrumb .sep{color:var(--color-border);user-select:none}
.breadcrumb .current{color:var(--text-secondary);font-weight:500}

/* SECTION 16 - MEDIA QUERIES (mobile-first) */
@media(min-width:480px){
  .hero-cta-group{flex-direction:row}
  .menu-preview-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
}
@media(min-width:768px){
  .nav-hamburger{display:none}
  .nav-links{display:flex;flex-direction:row;align-items:center;gap:var(--space-xl);position:static;background:transparent;padding:0;box-shadow:none;transform:none;opacity:1;pointer-events:auto}
  .nav-links a{font-size:var(--text-sm);color:var(--text-on-dark);padding-block:0;display:inline}
  .nav-links a:hover,.nav-links a.active{color:var(--color-amber)}
  .nav-phone{display:inline}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .menu-preview-grid{grid-template-columns:repeat(2,1fr)}
  .menu-items-grid{grid-template-columns:repeat(2,1fr)}
  .about-layout{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .map-embed-wrapper{aspect-ratio:16/9}
  .about-secondary-img img{height:340px}
  .contact-storefront-img img{height:280px}
}
@media(min-width:1024px){
  .features-grid{grid-template-columns:repeat(4,1fr)}
  .menu-preview-grid{grid-template-columns:repeat(3,1fr)}
  .about-layout{grid-template-columns:1fr 1fr;gap:var(--space-3xl)}
  .reviews-grid{grid-template-columns:repeat(3,1fr)}
  .contact-layout{grid-template-columns:1fr 1fr;gap:var(--space-3xl);align-items:start}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr;gap:var(--space-3xl)}
  .menu-section-img img{height:360px}
  .about-secondary-img img{height:400px}
}
@media(min-width:1280px){
  .hero-content{max-width:900px}
  .section-hero h1{font-size:var(--text-hero)}
  .hero-sub{max-width:680px}
  .footer-grid{grid-template-columns:1.6fr 1fr 1fr}
}
