/* ============================================================
   LATIN FIXIN'S — BRAND STYLESHEET v3
   Colors: Orange #F5A623 / Dark #1a1a1a / White #fff
   Fonts: Oswald (display) / Open Sans (body)
   ============================================================ */

:root {
  --orange:      #F5A623;
  --orange-dark: #d4891a;
  --dark:        #1a1a1a;
  --dark2:       #2a2a2a;
  --charcoal:    #333333;
  --white:       #ffffff;
  --text:        #222222;
  --text-mid:    #555555;
  --border:      #e0e0e0;

  --font-display: 'Oswald', sans-serif;
  --font-body:    'Open Sans', sans-serif;

  --max-w: 1200px;
  --nav-h: 80px;
}

/* ── RESET ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); color: var(--text); background:#fff; line-height:1.6; -webkit-font-smoothing:antialiased; }
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
.container { max-width:var(--max-w); margin:0 auto; padding:0 20px; }

/* ── TOPBAR ─────────────────────────────────────────────────── */
.topbar { background:var(--orange); padding:10px 24px; display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.topbar-left { font-family:var(--font-display); font-size:0.85rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--white); }
.topbar-right { display:flex; gap:10px; flex-wrap:wrap; }
.topbar-btn { border:2px solid var(--white); color:var(--white); font-family:var(--font-display); font-size:0.75rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:5px 14px; border-radius:2px; transition:background 0.15s, color 0.15s; }
.topbar-btn:hover { background:var(--white); color:var(--orange); }

/* ── HEADER / NAV ───────────────────────────────────────────── */
.site-header { background:var(--white); border-bottom:1px solid var(--border); position:sticky; top:0; z-index:200; box-shadow:0 2px 8px rgba(0,0,0,0.07); }

/* Desktop: 3-col grid with centered logo */
.nav-wrap { max-width:var(--max-w); margin:0 auto; padding:0 20px; height:var(--nav-h); display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:0; position:relative; }
.nav-left { display:flex; align-items:center; gap:4px; }
.nav-right { display:flex; align-items:center; gap:4px; justify-content:flex-end; }
.nav-logo { display:flex; justify-content:center; align-items:center; padding:0 16px; }
.nav-logo img { height:64px; width:auto; }
.nav-link { font-family:var(--font-display); font-size:0.82rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase; color:var(--dark); padding:8px 12px; position:relative; transition:color 0.15s; white-space:nowrap; }
.nav-link::after { content:''; position:absolute; bottom:4px; left:12px; right:12px; height:2px; background:var(--orange); transform:scaleX(0); transition:transform 0.2s; }
.nav-link:hover, .nav-link.active { color:var(--orange); }
.nav-link:hover::after, .nav-link.active::after { transform:scaleX(1); }

/* Mobile toggle — hidden by default on desktop */
.nav-toggle { display:none; flex-direction:column; gap:5px; padding:8px; }
.nav-toggle span { display:block; width:24px; height:2px; background:var(--dark); border-radius:2px; transition:transform 0.25s, opacity 0.2s; }
.nav-toggle.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity:0; }
.nav-toggle.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile menu — HIDDEN by default, shown only when .open */
.nav-mobile-menu { display:none; flex-direction:column; background:var(--white); border-bottom:2px solid var(--orange); box-shadow:0 8px 20px rgba(0,0,0,0.1); }
.nav-mobile-menu.open { display:flex; }
.nav-mobile-menu .nav-link { padding:14px 20px; border-bottom:1px solid var(--border); }
.nav-mobile-menu .nav-link::after { display:none; }

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn-orange { display:inline-block; background:var(--orange); color:var(--white); font-family:var(--font-display); font-size:0.82rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:12px 24px; border-radius:2px; transition:background 0.15s; }
.btn-orange:hover { background:var(--orange-dark); }
.btn-dark { display:inline-block; background:var(--dark); color:var(--white); font-family:var(--font-display); font-size:0.82rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:12px 24px; border-radius:2px; transition:background 0.15s; }
.btn-dark:hover { background:var(--charcoal); }
.btn-outline-white { display:inline-block; border:2px solid var(--white); color:var(--white); font-family:var(--font-display); font-size:0.82rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:11px 24px; border-radius:2px; transition:background 0.15s; }
.btn-outline-white:hover { background:rgba(255,255,255,0.15); }

/* ── HERO ────────────────────────────────────────────────────── */
.hero { width:100%; overflow:hidden; line-height:0; }
.hero img { width:100%; height:560px; object-fit:cover; object-position:center 55%; display:block; }

/* ── ABOUT SECTION ───────────────────────────────────────────── */
.about-section { padding:72px 0; background:#fff; }
.about-inner { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.about-img-main { width:100%; aspect-ratio:4/3; object-fit:cover; object-position:top center; border-radius:2px; }
.about-text h2 { font-family:var(--font-display); font-size:clamp(1.6rem,2.8vw,2.4rem); font-weight:700; text-transform:uppercase; color:var(--dark); line-height:1.15; margin-bottom:20px; }
.about-text p { font-size:0.9rem; color:var(--text-mid); line-height:1.75; margin-bottom:12px; }
.about-text strong { color:var(--dark); }
.about-text a.orange-link { color:var(--orange); font-weight:700; }
.about-hours { margin:16px 0; font-size:0.9rem; color:var(--text-mid); line-height:1.8; }
.about-btns { display:flex; gap:10px; flex-wrap:wrap; margin-top:20px; }

/* ── REVIEWS ─────────────────────────────────────────────────── */
.reviews-section { background:#f9f9f9; padding:56px 0; }
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.review-card { background:#fff; padding:28px; border-left:4px solid var(--orange); box-shadow:0 2px 8px rgba(0,0,0,0.06); }
.review-card p { font-size:0.88rem; color:#444; font-style:italic; line-height:1.75; margin-bottom:14px; }
.review-card cite { font-family:var(--font-display); font-size:0.82rem; font-weight:700; color:var(--orange); font-style:normal; letter-spacing:0.06em; text-transform:uppercase; }

/* ── SERVICES MOSAIC ─────────────────────────────────────────── */
.services-mosaic { display:grid; grid-template-columns:1fr 1fr; }
.mosaic-tile { position:relative; overflow:hidden; height:420px; }
.mosaic-tile img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.mosaic-tile:hover img { transform:scale(1.03); }
.mosaic-overlay { position:absolute; inset:0; background:rgba(0,0,0,0.42); display:flex; align-items:flex-end; padding:32px; }
.mosaic-label { font-family:var(--font-display); font-size:2rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--white); }

/* ── CLIENTS ─────────────────────────────────────────────────── */
.clients-section { padding:64px 0; background:#fff; text-align:center; }
.clients-section h2 { font-family:var(--font-display); font-size:1.8rem; font-weight:700; text-transform:uppercase; color:var(--dark); margin-bottom:40px; }
.clients-row { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:32px 48px; }
.clients-row img { max-height:52px; max-width:150px; width:auto; object-fit:contain; filter:grayscale(20%); opacity:0.8; transition:opacity 0.2s, filter 0.2s; }
.clients-row img:hover { opacity:1; filter:none; }

/* ── COLLAGE 6-PANEL ─────────────────────────────────────────── */
.collage-section { display:grid; grid-template-columns:repeat(3,1fr); grid-template-rows:280px 280px; }
.collage-img { overflow:hidden; }
.collage-img img { width:100%; height:100%; object-fit:cover; object-position:center; display:block; }
.collage-panel-orange { background:var(--orange); display:flex; align-items:center; justify-content:center; padding:32px; text-align:center; }
.collage-panel-orange h3 { font-family:var(--font-display); font-size:1.6rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--white); line-height:1.2; }
.collage-panel-dark { background:var(--dark); display:flex; align-items:center; justify-content:center; padding:32px; text-align:center; }
.collage-panel-dark h3 { font-family:var(--font-display); font-size:1.6rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--white); line-height:1.2; }

/* ── INSTAGRAM / SOCIAL ──────────────────────────────────────── */
.social-section { padding:56px 0 40px; background:#fff; }
.social-section-header { text-align:center; margin-bottom:28px; }
.social-section-header h2 { font-family:var(--font-display); font-size:1.8rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--dark); margin-bottom:12px; }
.social-handle { display:flex; align-items:center; gap:10px; justify-content:center; margin-bottom:10px; }
.social-handle img { width:36px; height:36px; border-radius:50%; object-fit:cover; }
.social-handle span { font-size:0.9rem; font-weight:700; color:var(--dark); }
.social-bio { font-size:0.8rem; color:#888; text-align:center; max-width:520px; margin:0 auto 24px; }
.ig-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.ig-thumb { aspect-ratio:1; overflow:hidden; background:#eee; }
.ig-thumb img { width:100%; height:100%; object-fit:cover; transition:transform 0.3s; }
.ig-thumb:hover img { transform:scale(1.05); }
.social-cta { text-align:center; margin-top:28px; }
.social-cta a { font-family:var(--font-display); font-size:0.85rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--orange); border-bottom:2px solid var(--orange); padding-bottom:2px; }

/* ── CONTACT FORM SECTION ────────────────────────────────────── */
.contact-form-section { background:var(--dark); padding:64px 0; }
.contact-form-inner { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.contact-form-left h2 { font-family:var(--font-display); font-size:2rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--white); margin-bottom:12px; }
.contact-form-left p { font-size:0.88rem; color:rgba(255,255,255,0.65); line-height:1.7; }
.form-fields { display:flex; flex-direction:column; gap:12px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-input { width:100%; padding:12px 14px; background:transparent; border:1px solid rgba(255,255,255,0.3); border-radius:2px; font-family:var(--font-body); font-size:0.9rem; color:var(--white); transition:border-color 0.15s; appearance:none; }
.form-input::placeholder { color:rgba(255,255,255,0.45); }
.form-input:focus { outline:none; border-color:var(--orange); }
textarea.form-input { min-height:120px; resize:vertical; }
.form-submit-btn { background:var(--orange); color:var(--white); font-family:var(--font-display); font-size:0.85rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:13px 32px; border-radius:2px; cursor:pointer; border:none; transition:background 0.15s; width:fit-content; }
.form-submit-btn:hover { background:var(--orange-dark); }
.form-msg { display:none; padding:12px 14px; border-radius:2px; font-size:0.88rem; margin-top:8px; }
.form-msg.success { background:rgba(255,255,255,0.1); color:#a8f5c8; border:1px solid rgba(168,245,200,0.3); }
.form-msg.error { background:rgba(255,0,0,0.08); color:#ffaaaa; border:1px solid rgba(255,100,100,0.3); }

/* ── FOOD GRID (Our Food page) ───────────────────────────────── */
.food-grid-section { padding:56px 0; background:#fff; }
.food-grid-intro { text-align:center; max-width:720px; margin:0 auto 40px; }
.food-grid-intro h1 { font-family:var(--font-display); font-size:clamp(1.8rem,3vw,2.4rem); font-weight:700; text-transform:uppercase; margin-bottom:16px; }
.food-grid-intro p { font-size:0.9rem; color:var(--text-mid); line-height:1.75; }
.food-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.food-item { position:relative; overflow:hidden; cursor:pointer; background:#111; }
.food-item img { width:100%; aspect-ratio:1; object-fit:cover; transition:transform 0.35s, opacity 0.3s; }
.food-item:hover img { transform:scale(1.05); opacity:0.85; }
.food-item-caption { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(transparent,rgba(0,0,0,0.72)); padding:24px 14px 14px; opacity:0; transition:opacity 0.25s; }
.food-item:hover .food-item-caption { opacity:1; }
.food-item-caption strong { display:block; font-family:var(--font-display); font-size:1rem; font-weight:700; text-transform:uppercase; color:#fff; letter-spacing:0.06em; }
.food-item-caption span { font-size:0.78rem; color:rgba(255,255,255,0.8); line-height:1.4; }

/* ── SERVICES PAGE ───────────────────────────────────────────── */
.services-hero { width:100%; overflow:hidden; line-height:0; }
.services-hero img { width:100%; height:480px; object-fit:cover; object-position:center 40%; display:block; }
.services-title { text-align:center; padding:56px 20px 40px; background:#fff; }
.services-title h1 { font-family:var(--font-display); font-size:clamp(1.8rem,3vw,2.6rem); font-weight:700; text-transform:uppercase; color:var(--dark); }
.service-split { display:grid; grid-template-columns:1fr 1fr; min-height:380px; }
.service-split-img { overflow:hidden; position:relative; }
.service-split-img img { width:100%; height:100%; object-fit:cover; }
.service-split-img .img-label { position:absolute; bottom:28px; left:28px; font-family:var(--font-display); font-size:2rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--white); }
.service-split-panel { padding:48px 40px; display:flex; flex-direction:column; justify-content:center; }
.panel-orange { background:var(--orange); }
.panel-dark { background:var(--dark2); }
.service-split-panel li { font-family:var(--font-display); font-size:0.9rem; font-weight:400; letter-spacing:0.04em; text-transform:uppercase; color:var(--white); text-align:center; padding:3px 0; }
.service-split-panel .panel-note { margin-top:20px; font-size:0.82rem; color:rgba(255,255,255,0.85); font-style:italic; text-align:center; }
.quote-strip { background:var(--dark); padding:48px 24px; text-align:center; }
.quote-strip h2 { font-family:var(--font-display); font-size:2rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--white); margin-bottom:24px; }

/* ── ABOUT PAGE ──────────────────────────────────────────────── */
.about-page-hero { width:100%; overflow:hidden; line-height:0; }
.about-page-hero img { width:100%; height:400px; object-fit:cover; display:block; }
.page-section-title { text-align:center; padding:56px 20px 32px; }
.page-section-title h1 { font-family:var(--font-display); font-size:clamp(1.8rem,3vw,2.4rem); font-weight:700; text-transform:uppercase; }
.wood-bg { background:url('https://latinfixins.com/wp-content/uploads/2022/04/Home_about.jpg') center/cover no-repeat; position:relative; padding:64px 0; }
.wood-bg::before { content:''; position:absolute; inset:0; background:rgba(30,15,5,0.72); }
.wood-bg .container { position:relative; z-index:1; }
.story-inner { max-width:900px; margin:0 auto; display:grid; grid-template-columns:280px 1fr; background:#fff; box-shadow:0 4px 24px rgba(0,0,0,0.08); overflow:hidden; }
.story-img img { width:100%; height:100%; object-fit:cover; object-position:top center; display:block; }
.story-text { padding:40px 36px; position:relative; }
.story-text h2 { font-family:var(--font-display); font-size:1.5rem; font-weight:700; text-transform:uppercase; color:var(--dark); margin-bottom:16px; }
.story-text p { font-size:0.9rem; color:var(--text-mid); line-height:1.8; margin-bottom:12px; }
.story-text p strong { color:var(--dark); }
.story-text::after { content:''; position:absolute; bottom:0; left:0; right:0; height:6px; background:var(--orange); }
.family-block { padding:72px 0; background:#fff; }
.family-inner { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.family-text h2 { font-family:var(--font-display); font-size:1.8rem; font-weight:700; text-transform:uppercase; color:var(--dark); margin-bottom:16px; }
.family-text p { font-size:0.9rem; color:var(--text-mid); line-height:1.8; margin-bottom:12px; }
.family-text p strong { color:var(--dark); }
.family-img img { width:100%; border-radius:2px; box-shadow:0 6px 32px rgba(0,0,0,0.12); }

/* ── CONTACT PAGE ────────────────────────────────────────────── */
.contact-page { padding:72px 0; background:var(--dark); }
.contact-page-inner { display:grid; grid-template-columns:1fr 1.2fr; gap:64px; align-items:start; }
.contact-page-info h1 { font-family:var(--font-display); font-size:2rem; font-weight:700; text-transform:uppercase; color:var(--white); margin-bottom:16px; }
.contact-page-info p { font-size:0.88rem; color:rgba(255,255,255,0.65); line-height:1.7; margin-bottom:28px; }
.contact-detail-list { display:flex; flex-direction:column; gap:18px; }
.contact-detail-item { display:flex; gap:14px; align-items:flex-start; }
.contact-detail-item svg { color:var(--orange); flex-shrink:0; margin-top:2px; }
.contact-detail-item strong { display:block; font-size:0.78rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.5); margin-bottom:2px; }
.contact-detail-item p, .contact-detail-item a { font-size:0.92rem; color:rgba(255,255,255,0.85); margin:0; }
.contact-detail-item a { color:var(--orange); }

/* ── FOOTER ──────────────────────────────────────────────────── */
.site-footer { background:var(--orange); padding:40px 0 0; }
.footer-inner { display:grid; grid-template-columns:1fr auto 1fr; align-items:start; gap:40px; padding-bottom:32px; }
.footer-col-left h3, .footer-col-right h3 { font-family:var(--font-display); font-size:1.1rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--white); margin-bottom:16px; }
.footer-social-icons { display:flex; gap:16px; align-items:center; }
.footer-social-icons a { color:var(--white); opacity:0.9; transition:opacity 0.15s, transform 0.15s; }
.footer-social-icons a:hover { opacity:1; transform:scale(1.1); }
.footer-social-icons svg { width:28px; height:28px; }
.footer-logo { display:flex; justify-content:center; align-items:flex-start; }
.footer-logo img { width:80px; height:auto; }
.footer-col-right .contact-list { display:flex; flex-direction:column; gap:8px; }
.footer-col-right .contact-list li { display:flex; align-items:center; gap:8px; font-size:0.88rem; color:var(--white); }
.footer-col-right .contact-list a { color:var(--white); }
.footer-marketing-btn { margin-top:16px; display:inline-block; background:var(--dark); color:var(--white); font-family:var(--font-display); font-size:0.78rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:10px 20px; border-radius:2px; transition:background 0.15s; }
.footer-marketing-btn:hover { background:var(--charcoal); }
.footer-bottom { background:var(--orange-dark); padding:14px 24px; text-align:center; }
.footer-bottom p { font-size:0.78rem; color:rgba(255,255,255,0.8); }
.footer-bottom a { color:rgba(255,255,255,0.9); font-weight:700; }

/* ── COOKIE CONSENT BANNER ───────────────────────────────────── */
.cookie-banner { display:none; position:fixed; bottom:0; left:0; right:0; background:var(--dark); color:rgba(255,255,255,0.88); padding:16px 24px; z-index:9999; box-shadow:0 -4px 20px rgba(0,0,0,0.3); }
.cookie-banner.visible { display:block; }
.cookie-banner-inner { max-width:var(--max-w); margin:0 auto; display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.cookie-banner-text { flex:1; font-size:0.83rem; line-height:1.6; min-width:240px; }
.cookie-banner-text a { color:var(--orange); text-decoration:underline; }
.cookie-banner-actions { display:flex; gap:10px; flex-shrink:0; flex-wrap:wrap; }
.cookie-accept { background:var(--orange); color:var(--white); font-family:var(--font-display); font-size:0.78rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; padding:10px 20px; border-radius:2px; border:none; cursor:pointer; transition:background 0.15s; }
.cookie-accept:hover { background:var(--orange-dark); }
.cookie-decline { background:transparent; color:rgba(255,255,255,0.6); font-family:var(--font-display); font-size:0.78rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; padding:10px 20px; border-radius:2px; border:1px solid rgba(255,255,255,0.25); cursor:pointer; transition:background 0.15s; }
.cookie-decline:hover { background:rgba(255,255,255,0.08); }

/* ── SKIP LINK (A11Y) ────────────────────────────────────────── */
.skip-link { position:absolute; top:-100%; left:16px; background:var(--orange); color:#fff; font-weight:700; padding:8px 16px; z-index:9999; border-radius:0 0 4px 4px; font-size:0.85rem; }
.skip-link:focus { top:0; }

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media (max-width:768px) {
  :root { --nav-h:70px; }

  /* Nav: hide split links, show hamburger */
  .nav-wrap { grid-template-columns:auto 1fr auto; padding:0 16px; }
  .nav-left, .nav-right { display:none; }
  .nav-logo { justify-content:flex-start; }
  .nav-logo img { height:52px; }
  .nav-toggle { display:flex; }

  /* Hero */
  .hero img { height:300px; }

  /* About */
  .about-inner { grid-template-columns:1fr; gap:32px; }

  /* Reviews */
  .reviews-grid { grid-template-columns:1fr; }

  /* Services mosaic */
  .services-mosaic { grid-template-columns:1fr; }
  .mosaic-tile { height:280px; }

  /* Collage */
  .collage-section { grid-template-columns:1fr 1fr; grid-template-rows:200px 200px 200px; }

  /* IG */
  .ig-grid { grid-template-columns:repeat(2,1fr); }

  /* Contact form */
  .contact-form-inner { grid-template-columns:1fr; gap:36px; }
  .form-row { grid-template-columns:1fr; }

  /* Footer */
  .footer-inner { grid-template-columns:1fr; text-align:center; }
  .footer-social-icons { justify-content:center; }
  .footer-logo { justify-content:center; }

  /* Services page */
  .service-split { grid-template-columns:1fr; }
  .service-split-img { height:280px; }
  .services-hero img { height:260px; }

  /* About page */
  .story-inner { grid-template-columns:1fr; }
  .story-img img { height:260px; object-position:top; }
  .family-inner { grid-template-columns:1fr; gap:32px; }
  .about-page-hero img { height:280px; }

  /* Contact page */
  .contact-page-inner { grid-template-columns:1fr; gap:40px; }

  /* Food grid */
  .food-grid { grid-template-columns:repeat(2,1fr); }

  /* Cookie banner */
  .cookie-banner-inner { flex-direction:column; align-items:flex-start; }
}

@media (max-width:480px) {
  .food-grid { grid-template-columns:1fr; }
  .collage-section { grid-template-columns:1fr; grid-template-rows:repeat(6,200px); }
  .hero img { height:240px; }
  .about-btns { flex-direction:column; }
  .about-btns .btn-orange, .about-btns .btn-dark { text-align:center; }
  .topbar { flex-direction:column; gap:8px; text-align:center; }
}

/* ── A11Y ────────────────────────────────────────────────────── */
*:focus-visible { outline:3px solid var(--orange); outline-offset:2px; }
@media (prefers-reduced-motion:reduce) { *, *::before, *::after { transition-duration:0.01ms !important; } }
