/* ============================================================
   SHARED BASE STYLES
   Used by all pages. Variables, layout, components.
   ============================================================ */
:root{
      --green:#066c3b;
      --green-2:#0f9a5c;
      --green-dark:#032b1a;
      --red:#c8232c;
      --red-dark:#8c1118;
      --cream:#fff7e6;
      --cream-2:#fff1d0;
      --gold:#ffc94b;
      --orange:#f36b21;
      --ink:#1f1712;
      --muted:#6f6254;
      --white:#fff;
      --line:rgba(75,45,20,.12);
      --shadow:0 24px 70px rgba(43,25,12,.22);
      --soft-shadow:0 14px 40px rgba(44,25,12,.10);
      --radius:28px;
      --max:1180px;
    }
    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      margin:0;
      color:var(--ink);
      background:
        radial-gradient(circle at top left, rgba(255,201,75,.30), transparent 34rem),
        radial-gradient(circle at 95% 18%, rgba(200,35,44,.10), transparent 26rem),
        linear-gradient(180deg,#fffaf0 0%,#fff2d3 45%,#fff8ef 100%);
      font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;
      line-height:1.55;
    }
    img{max-width:100%;display:block}
    a{color:inherit}
    .skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
    .skip-link:focus{left:16px;top:16px;width:auto;height:auto;background:#fff;padding:10px 14px;border-radius:10px;z-index:999}
    .utility{
      background:linear-gradient(90deg,var(--green-dark),var(--green),var(--red-dark));
      color:#fff;
      font-weight:900;
      font-size:14px;
    }
    .utility-inner{
      max-width:var(--max);margin:auto;padding:8px 20px;display:flex;justify-content:space-between;gap:14px;align-items:center;flex-wrap:wrap;
    }
    .utility a{text-decoration:none;border-bottom:1px solid rgba(255,255,255,.45)}
    .topbar{position:sticky;top:0;z-index:40;background:rgba(255,247,230,.94);backdrop-filter:blur(16px);border-bottom:1px solid rgba(140,17,24,.14)}
    .nav{max-width:var(--max);margin:auto;padding:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:18px}
    .brand{display:flex;align-items:center;gap:12px;text-decoration:none;font-weight:950;letter-spacing:.02em;min-width:max-content}
    .brand-logo{width:52px;height:52px;object-fit:contain;display:block;}
    .brand small{display:block;color:var(--red);font-weight:850;font-size:12px;letter-spacing:.08em;text-transform:uppercase}
    .nav-links{display:flex;gap:15px;align-items:center;font-weight:850;font-size:14px}
    .nav-links a{text-decoration:none;opacity:.82}
    .nav-links a:hover{opacity:1;color:var(--red)}
    .nav-actions{display:flex;gap:10px;align-items:center}
    .btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;text-decoration:none;font-weight:950;padding:13px 20px;border-radius:999px;border:0;cursor:pointer;transition:.2s transform ease,.2s box-shadow ease,.2s background ease;white-space:nowrap;text-align:center}
    .btn:hover{transform:translateY(-2px)}
    .btn-red{background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;box-shadow:0 14px 30px rgba(200,35,44,.25)}
    .btn-green{background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;box-shadow:0 14px 30px rgba(6,108,59,.25)}
    .btn-gold{background:linear-gradient(135deg,var(--gold),#ff9c1b);color:#2c1707;box-shadow:0 14px 30px rgba(255,156,27,.25)}
    .btn-ghost{border:2px solid rgba(255,255,255,.72);color:#fff;background:rgba(255,255,255,.12)}
    .btn-outline{background:#fff;color:var(--green-dark);border:2px solid rgba(6,108,59,.16);box-shadow:none}
    .hero{position:relative;overflow:hidden;color:white;background:linear-gradient(110deg,rgba(3,53,31,.97),rgba(6,108,59,.80) 42%,rgba(140,17,24,.88))}
    .hero::before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,rgba(255,255,255,.035) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.035) 50%,rgba(255,255,255,.035) 75%,transparent 75%,transparent);background-size:34px 34px;opacity:.55}
    .hero::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 75% 18%,rgba(255,201,75,.34),transparent 20rem),radial-gradient(circle at 10% 65%,rgba(255,255,255,.14),transparent 22rem);pointer-events:none}
    .hero-inner{position:relative;z-index:1;max-width:var(--max);margin:auto;padding:88px 20px 70px;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:44px}
    .eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 13px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.24);border-radius:999px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;font-size:12px}
    h1{font-size:clamp(46px,8vw,94px);line-height:.90;margin:22px 0 18px;letter-spacing:-.065em;text-wrap:balance}
    h1 .script{display:block;color:var(--gold);text-shadow:0 3px 0 rgba(0,0,0,.22);font-family:Impact,Haettenschweiler,"Arial Narrow Bold",sans-serif;letter-spacing:.01em}
    .lead{font-size:clamp(18px,2.1vw,24px);max-width:680px;color:rgba(255,255,255,.93);margin:0 0 28px}
    .hero-actions{display:flex;flex-wrap:wrap;gap:13px;margin-bottom:24px}
    .quick-info{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:730px}
    .info-pill{background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:13px}
    .info-pill strong{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--gold)}
    .info-pill span{font-weight:850}
    .hero-card{position:relative;background:rgba(255,247,230,.96);color:var(--ink);border-radius:38px;padding:18px;box-shadow:var(--shadow);transform:rotate(1.2deg);border:8px solid rgba(255,255,255,.72)}
    .hero-card::before{content:"Popular Pick";position:absolute;top:22px;left:22px;z-index:2;background:var(--gold);color:#2c1707;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.08em;box-shadow:0 10px 24px rgba(0,0,0,.18)}
    .hero-card img{border-radius:24px;aspect-ratio:1.1/1;object-fit:contain;background:#050505;padding:6px}
    .hero-card .caption{padding:16px 8px 4px;font-weight:950;font-size:22px;text-align:center;color:var(--green-dark)}
    .trust-ribbon{position:relative;z-index:2;max-width:var(--max);margin:-28px auto 0;padding:0 20px;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
    .trust-item{background:#fff;border:1px solid var(--line);border-radius:22px;padding:16px;box-shadow:var(--soft-shadow);font-weight:900}
    .trust-item strong{display:block;color:var(--red);font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px}
    .section{max-width:var(--max);margin:auto;padding:78px 20px}
    .section-head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:30px}
    .section-kicker{color:var(--red);font-weight:950;letter-spacing:.12em;text-transform:uppercase;font-size:13px}
    .script-kicker{font-family:"Brush Script MT","Segoe Script",cursive!important;font-size:30px!important;text-transform:none!important;letter-spacing:.02em!important;color:var(--green)!important;text-shadow:1px 1px 0 #fff,3px 3px 0 rgba(200,35,44,.15)}
    h2{font-size:clamp(34px,5vw,60px);line-height:1;margin:8px 0 0;letter-spacing:-.045em;text-wrap:balance}
    h3{line-height:1.15}
    .section-text{max-width:620px;color:var(--muted);font-size:18px}
    .feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
    .feature{background:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--soft-shadow);border:1px solid rgba(140,17,24,.08)}
    .feature-icon{font-size:32px;width:58px;height:58px;display:grid;place-items:center;border-radius:18px;background:#fff2d3;margin-bottom:12px}
    .feature h3{margin:0 0 8px;font-size:22px}
    .feature p{margin:0;color:var(--muted)}
    .menu-showcase{position:relative;background:linear-gradient(180deg,rgba(6,108,59,.05),rgba(200,35,44,.05));border-radius:38px;padding:26px;box-shadow:inset 0 0 0 1px rgba(6,108,59,.08)}
    .menu-intro{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px;padding:0 4px;flex-wrap:wrap}
    .menu-note{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;background:#fff;color:var(--red-dark);font-size:13px;font-weight:900;box-shadow:0 10px 24px rgba(44,25,12,.08)}
    /* .menu-card styles are defined in menu.php inline <style> block */
    .menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
    .tag{display:inline-flex;padding:6px 11px;border-radius:999px;background:rgba(6,108,59,.10);color:var(--green);font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.06em}
    .seo-panel{display:grid;grid-template-columns:1fr .9fr;gap:24px;align-items:center;background:#fff;border-radius:38px;padding:30px;box-shadow:var(--soft-shadow);border:1px solid rgba(140,17,24,.08)}
    .seo-copy p{color:var(--muted);font-size:18px;margin:16px 0 0}
    .city-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
    .city-tags a{background:#fff7e6;border:1px solid rgba(200,35,44,.12);text-decoration:none;border-radius:999px;padding:9px 13px;font-weight:900;color:var(--red-dark)}
    .highlight-card{background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff;border-radius:30px;padding:26px;box-shadow:var(--shadow)}
    .highlight-card h3{font-size:34px;margin:0 0 8px;letter-spacing:-.03em}
    .highlight-card p{color:rgba(255,255,255,.88);font-size:18px;margin:0 0 18px}
    .steps-grid,.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
    .step,.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--soft-shadow)}
    .step-number{width:44px;height:44px;border-radius:999px;display:grid;place-items:center;background:var(--red);color:#fff;font-weight:950;margin-bottom:12px}
    .review-stars{color:#c68500;font-weight:950;letter-spacing:.08em}
    .review p{color:var(--muted);font-size:17px;margin:10px 0 14px}
    .review strong{color:var(--green-dark)}
    .split{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:center;background:linear-gradient(135deg,var(--green-dark),var(--green));border-radius:38px;color:#fff;padding:28px;box-shadow:var(--shadow);overflow:hidden}
    .split img{border-radius:28px;background:#000;box-shadow:0 20px 45px rgba(0,0,0,.24)}
    .split-content{padding:12px 8px}.split h2{color:#fff}.split p{color:rgba(255,255,255,.86);font-size:18px}
    .hours{display:grid;gap:12px;margin:22px 0}.hours-row{display:flex;justify-content:space-between;gap:18px;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);font-weight:900}
    .gallery-stack--full{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.gallery-stack--full img{border-radius:26px;box-shadow:0 18px 48px rgba(44,25,12,.13);background:#000;height:260px;width:100%;object-fit:contain;object-position:center;transition:transform .22s ease,box-shadow .22s ease}.gallery-stack--full img:hover{transform:translateY(-6px);box-shadow:0 28px 60px rgba(44,25,12,.20)}
    .contact-card{background:#fff;border-radius:38px;padding:30px;box-shadow:0 20px 58px rgba(44,25,12,.10);display:grid;grid-template-columns:1fr 1fr;gap:24px;border:1px solid rgba(140,17,24,.08)}
    .contact-list{display:grid;gap:12px;margin-top:20px}.contact-item{padding:16px;border-radius:20px;background:#fff7e6;font-weight:850}.contact-item strong{display:block;color:var(--red);font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}.contact-item a{text-decoration:none;color:var(--green-dark)}
    .map{border:0;width:100%;min-height:370px;border-radius:28px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.1)}
    .faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.faq{background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--soft-shadow)}.faq h3{margin:0 0 8px;font-size:20px}.faq p{margin:0;color:var(--muted)}
    .cta{margin:0 auto 78px;max-width:var(--max);border-radius:40px;padding:52px 20px;text-align:center;color:#fff;background:linear-gradient(135deg,var(--red-dark),var(--red));box-shadow:var(--shadow);position:relative;overflow:hidden}.cta::before{content:"";position:absolute;inset:-40%;background:radial-gradient(circle,rgba(255,201,75,.30),transparent 30rem);transform:translateX(20%)}.cta>*{position:relative}.cta h2{margin-bottom:14px}.cta p{max-width:760px;margin:0 auto 24px;color:rgba(255,255,255,.90);font-size:19px}.cta-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
    footer{background:#1c120e;color:rgba(255,255,255,.74);padding:0}.footer-inner{max-width:var(--max);margin:auto;padding:38px 20px;display:grid;grid-template-columns:1.2fr repeat(3,.7fr);gap:24px}.footer-inner h3,.footer-inner h4{color:#fff;margin:0 0 10px}.footer-inner a{display:block;text-decoration:none;margin:7px 0;color:rgba(255,255,255,.78)}.footer-bottom{text-align:center;border-top:1px solid rgba(255,255,255,.10);padding:18px 20px;color:rgba(255,255,255,.62)}
    .sticky-mobile{display:none;position:fixed;left:12px;right:12px;bottom:12px;z-index:60;gap:10px;background:rgba(255,247,230,.94);backdrop-filter:blur(14px);border:1px solid rgba(140,17,24,.14);border-radius:999px;padding:8px;box-shadow:0 18px 50px rgba(0,0,0,.22)}.sticky-mobile .btn{flex:1;padding:12px 10px;font-size:14px}
    /* ── Hamburger (shared, used by pages that have it in their HTML) ── */
    .hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;background:none;border:none;cursor:pointer;padding:6px;border-radius:10px;transition:background .2s;flex-shrink:0}
    .hamburger:hover{background:rgba(140,17,24,.08)}
    .hamburger span{display:block;height:2.5px;background:var(--ink);border-radius:2px;transition:transform .25s ease,opacity .25s ease;transform-origin:center}
    .hamburger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
    .hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
    .hamburger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
    /* Mobile slide-down nav (shared) */
    .mobile-nav{display:none;flex-direction:column;gap:4px;padding:12px 16px 16px;background:rgba(255,247,230,.98);border-top:1px solid rgba(140,17,24,.10);backdrop-filter:blur(16px);box-shadow:0 12px 32px rgba(43,25,12,.12)}
    .mobile-nav a{display:block;padding:12px 14px;border-radius:14px;font-weight:850;font-size:15px;text-decoration:none;color:var(--ink);transition:background .18s}
    .mobile-nav a:hover{background:rgba(200,35,44,.07);color:var(--red-dark)}
    .mobile-nav.open{display:flex}
    /* ── Tablet (≤980px) ── */
    @media (max-width:980px){
      .nav-links{display:none}
      .hamburger{display:flex}
      .hero-inner,.seo-panel,.split,.contact-card{grid-template-columns:1fr}
      .quick-info,.feature-grid,.steps-grid,.review-grid{grid-template-columns:1fr 1fr}
      .menu-grid{grid-template-columns:repeat(2,1fr)}
      .trust-ribbon{grid-template-columns:repeat(2,1fr)}
      .hero-card{transform:none}
      .gallery-stack--full{grid-template-columns:repeat(2,1fr)}
      .gallery-stack--full img{height:210px}
      .footer-inner{grid-template-columns:1fr 1fr}
    }
    /* ── Mobile (≤640px) ── */
    @media (max-width:640px){
      .utility-inner{flex-direction:column;align-items:center;text-align:center;gap:6px;padding:10px 14px}
      .nav{padding:10px 14px}
      .nav-actions .btn-outline{display:none}
      .brand small{font-size:10px}
      .brand-logo{width:44px;height:44px}
      .hero-inner{padding:48px 16px 44px}
      .quick-info,.feature-grid,.menu-grid,.steps-grid,.review-grid,.faq-grid,.trust-ribbon{grid-template-columns:1fr}
      .section{padding:48px 16px}
      .section-head{display:block}
      /* Hero buttons stack but don't force ALL buttons full-width */
      .hero-actions{display:flex;flex-direction:column;align-items:stretch}
      .hero-actions .btn{width:100%}
      .cta-actions{flex-direction:column;align-items:center}
      .cta-actions .btn{width:100%;max-width:320px}
      .menu-showcase{padding:18px;border-radius:28px}
      .menu-actions{flex-direction:column}
      .seo-panel,.split,.contact-card{padding:18px;border-radius:28px}
      .hours-row{display:grid;gap:4px}
      .gallery-stack--full{grid-template-columns:repeat(2,1fr);gap:12px}
      .gallery-stack--full img{height:150px}
      .footer-inner{grid-template-columns:1fr}
      .sticky-mobile{display:flex}
      body{padding-bottom:82px}
      footer{padding-bottom:82px}
      h1{font-size:clamp(38px,10vw,60px)}
      h2{font-size:clamp(28px,7vw,44px)}
    }

/* ============================================================
   CONTACT PAGE
   Unique classes: .announce, .announce-inner, .contact-hero-grid, .contact-icon, .contact-tile, .hours-card, .link-card, .link-grid, .local-links, .main-contact, .mobile-sticky, .order-grid
   ============================================================ */
.announce{
      background:linear-gradient(90deg,var(--green-dark),var(--red-dark));
      color:#fff;
      font-weight:850;
      font-size:14px;
    }
.announce-inner{
      max-width:var(--max);
      margin:auto;
      padding:8px 20px;
      display:flex;
      justify-content:space-between;
      gap:16px;
      flex-wrap:wrap;
    }
.announce a{text-decoration:none;color:#fff}
.contact-hero-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:18px;
    }
.contact-tile{
      background:#fff;
      border-radius:var(--radius);
      padding:24px;
      box-shadow:0 18px 45px rgba(44,25,12,.08);
      border:1px solid rgba(140,17,24,.08);
    }
.contact-icon{
      font-size:32px;
      width:58px;
      height:58px;
      display:grid;
      place-items:center;
      border-radius:18px;
      background:#fff2d3;
      margin-bottom:12px;
    }
.contact-tile h3{
      margin:0 0 8px;
      font-size:23px;
      color:var(--green-dark);
    }
.contact-tile p{
      margin:0 0 16px;
      color:var(--muted);
    }
.contact-tile .btn{
      width:100%;
      padding:12px 16px;
    }
.main-contact{
      background:#fff;
      border-radius:38px;
      padding:30px;
      box-shadow:0 20px 58px rgba(44,25,12,.10);
      display:grid;
      grid-template-columns:.9fr 1.1fr;
      gap:24px;
      border:1px solid rgba(140,17,24,.08);
    }
.hours-card{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:28px;
      align-items:center;
      background:linear-gradient(135deg,var(--green-dark),var(--green));
      border-radius:38px;
      color:#fff;
      padding:34px;
      box-shadow:var(--shadow);
      overflow:hidden;
    }
.hours-card img{
      border-radius:28px;
      background:#000;
      box-shadow:0 20px 45px rgba(0,0,0,.24);
    }
.hours-card h2{color:#fff}
.hours-card p{
      color:rgba(255,255,255,.88);
      font-size:18px;
    }
.order-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:18px;
      counter-reset:steps;
    }
.local-links{
      background:linear-gradient(180deg,rgba(6,108,59,.05),rgba(200,35,44,.05));
      border-radius:38px;
      padding:26px;
      box-shadow:inset 0 0 0 1px rgba(6,108,59,.08);
    }
.link-grid{
      display:grid;
      grid-template-columns:repeat(4,1fr);
      gap:16px;
    }
.link-card{
      background:#fff;
      border-radius:24px;
      padding:22px;
      text-decoration:none;
      box-shadow:0 16px 40px rgba(44,25,12,.08);
      border:1px solid rgba(140,17,24,.08);
      transition:.22s transform ease, .22s box-shadow ease;
    }
.link-card:hover{
      transform:translateY(-6px);
      box-shadow:0 24px 54px rgba(44,25,12,.15);
    }
.link-card strong{
      display:block;
      color:var(--green-dark);
      font-size:20px;
      line-height:1.1;
.link-card--img{
      padding:0;
      overflow:hidden;
      display:flex;
      flex-direction:column;
    }
.link-card--img .link-card-img{
      width:100%;
      height:160px;
      overflow:hidden;
    }
.link-card--img .link-card-img img{
      width:100%;
      height:100%;
      object-fit:cover;
      object-position:center;
      transition:transform .35s ease;
      display:block;
    }
.link-card--img:hover .link-card-img img{
      transform:scale(1.06);
    }
.link-card--img .link-card-body{
      padding:18px 22px 22px;
      flex:1;
    }
.link-card--img .link-card-body strong{
      display:block;
      color:var(--green-dark);
      font-size:18px;
      margin-bottom:4px;
    }
.link-card--img .link-card-body span{
      font-size:14px;
      color:var(--muted);
    }
      margin-bottom:8px;
    }
.link-card span{
      color:var(--muted);
      font-weight:750;
    }
.mobile-sticky{
      position:fixed;
      left:0;
      right:0;
      bottom:0;
      z-index:50;
      display:none;
      grid-template-columns:1fr 1fr;
      gap:8px;
      padding:10px;
      background:rgba(255,247,230,.95);
      border-top:1px solid rgba(140,17,24,.14);
      backdrop-filter:blur(14px);
    }
.mobile-sticky .btn{padding:12px 10px}
@media (max-width:900px){
      .hero-inner,
      .main-contact,
      .hours-card,
      .footer-inner{grid-template-columns:1fr}
      .quick-info,
      .contact-hero-grid,
      .order-grid,
      .faq-grid,
      .link-grid{grid-template-columns:1fr 1fr}
      .nav-links{display:none}
      .hamburger{display:flex}
      .hero-card{transform:none}
    }
@media (max-width:620px){
      .announce-inner{display:block;text-align:center}
      .quick-info,
      .contact-hero-grid,
      .order-grid,
      .faq-grid,
      .link-grid{grid-template-columns:1fr}
      .hero-inner{padding-top:48px}
      .section{padding:48px 16px}
      .section-head{display:block}
      .hero-actions{display:flex;flex-direction:column;align-items:stretch}
      .hero-actions .btn{width:100%}
      .main-contact,
      .hours-card,
      .local-links{padding:20px;border-radius:28px}
      .hours-row{display:block}
      .mobile-sticky{display:grid}
      footer{padding-bottom:96px}
    }

/* ============================================================
   MEXICAN FOOD TRUCK PAGE
   Unique classes: .announce, .announce-inner, .area-list, .check-list, .content-card, .how-grid, .local-seo, .mobile-sticky
   ============================================================ */
.announce{
      background:linear-gradient(90deg,var(--green-dark),var(--red-dark));
      color:#fff;
      font-weight:850;
      font-size:14px;
    }
.announce-inner{
      max-width:var(--max);
      margin:auto;
      padding:8px 20px;
      display:flex;
      justify-content:space-between;
      gap:16px;
      flex-wrap:wrap;
    }
.announce a{text-decoration:none;color:#fff}
.content-card{
      background:#fff;
      border-radius:38px;
      padding:34px;
      box-shadow:0 20px 58px rgba(44,25,12,.10);
      border:1px solid rgba(140,17,24,.08);
      display:grid;
      grid-template-columns:1.05fr .95fr;
      gap:28px;
      align-items:center;
    }
.content-card img{
      border-radius:30px;
      background:#000;
      box-shadow:0 20px 45px rgba(0,0,0,.18);
    }
.check-list{
      list-style:none;
      padding:0;
      margin:22px 0 0;
      display:grid;
      gap:12px;
    }
.check-list li{
      padding:14px 16px;
      border-radius:18px;
      background:#fff7e6;
      font-weight:850;
      border:1px solid rgba(255,201,75,.28);
    }
.local-seo{
      background:linear-gradient(135deg,var(--green-dark),var(--green));
      color:#fff;
      border-radius:38px;
      padding:38px;
      box-shadow:var(--shadow);
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:28px;
      align-items:start;
    }
.local-seo p{color:rgba(255,255,255,.88);font-size:18px}
.area-list{
      display:grid;
      grid-template-columns:repeat(2,1fr);
      gap:12px;
      margin-top:10px;
    }
.area-list a,
    .area-list span{
      background:rgba(255,255,255,.12);
      border:1px solid rgba(255,255,255,.15);
      border-radius:16px;
      padding:12px 14px;
      text-decoration:none;
      font-weight:900;
    }
.how-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:18px;
      counter-reset:steps;
    }
.mobile-sticky{
      position:fixed;
      left:0;
      right:0;
      bottom:0;
      z-index:50;
      display:none;
      grid-template-columns:1fr 1fr;
      gap:8px;
      padding:10px;
      background:rgba(255,247,230,.95);
      border-top:1px solid rgba(140,17,24,.14);
      backdrop-filter:blur(14px);
    }
.mobile-sticky .btn{padding:12px 10px}
@media (max-width:900px){
      .hero-inner,
      .content-card,
      .local-seo,
      .contact-card,
      .footer-inner{grid-template-columns:1fr}
      .quick-info,
      .feature-grid,
      .menu-grid,
      .faq-grid,
      .how-grid{grid-template-columns:1fr 1fr}
      .nav-links{display:none}
      .hamburger{display:flex}
      .hero-card{transform:none}
    }
@media (max-width:620px){
      .announce-inner{display:block;text-align:center}
      .quick-info,
      .feature-grid,
      .menu-grid,
      .faq-grid,
      .area-list,
      .how-grid{grid-template-columns:1fr}
      .hero-inner{padding-top:48px}
      .section{padding:48px 16px}
      .section-head{display:block}
      .hero-actions{display:flex;flex-direction:column;align-items:stretch}
      .hero-actions .btn{width:100%}
      .content-card,
      .local-seo,
      .contact-card{padding:20px;border-radius:28px}
      .mobile-sticky{display:grid}
    }

/* ============================================================
   QUESABIRRIA PAGE
   Unique classes: .announce, .announce-inner, .area-list, .check-list, .local-seo, .mobile-sticky, .story-card
   ============================================================ */
.announce{
      background:linear-gradient(90deg,var(--green-dark),var(--red-dark));
      color:#fff;
      font-weight:850;
      font-size:14px;
    }
.announce-inner{
      max-width:var(--max);
      margin:auto;
      padding:8px 20px;
      display:flex;
      justify-content:space-between;
      gap:16px;
      flex-wrap:wrap;
    }
.announce a{text-decoration:none;color:#fff}
.story-card{
      background:#fff;
      border-radius:38px;
      padding:34px;
      box-shadow:0 20px 58px rgba(44,25,12,.10);
      border:1px solid rgba(140,17,24,.08);
      display:grid;
      grid-template-columns:1.05fr .95fr;
      gap:28px;
      align-items:center;
    }
.story-card img{
      border-radius:30px;
      background:#000;
      box-shadow:0 20px 45px rgba(0,0,0,.18);
    }
.check-list{
      list-style:none;
      padding:0;
      margin:22px 0 0;
      display:grid;
      gap:12px;
    }
.check-list li{
      padding:14px 16px;
      border-radius:18px;
      background:#fff7e6;
      font-weight:850;
      border:1px solid rgba(255,201,75,.28);
    }
.local-seo{
      background:linear-gradient(135deg,var(--green-dark),var(--green));
      color:#fff;
      border-radius:38px;
      padding:38px;
      box-shadow:var(--shadow);
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:28px;
      align-items:start;
    }
.local-seo p{color:rgba(255,255,255,.88);font-size:18px}
.area-list{
      display:grid;
      grid-template-columns:repeat(2,1fr);
      gap:12px;
      margin-top:10px;
    }
.area-list a,
    .area-list span{
      background:rgba(255,255,255,.12);
      border:1px solid rgba(255,255,255,.15);
      border-radius:16px;
      padding:12px 14px;
      text-decoration:none;
      font-weight:900;
    }
.mobile-sticky{
      position:fixed;
      left:0;
      right:0;
      bottom:0;
      z-index:50;
      display:none;
      grid-template-columns:1fr 1fr;
      gap:8px;
      padding:10px;
      background:rgba(255,247,230,.95);
      border-top:1px solid rgba(140,17,24,.14);
      backdrop-filter:blur(14px);
    }
.mobile-sticky .btn{padding:12px 10px}
@media (max-width:900px){
      .hero-inner,
      .story-card,
      .local-seo,
      .contact-card,
      .footer-inner{grid-template-columns:1fr}
      .quick-info,
      .feature-grid,
      .menu-grid,
      .faq-grid{grid-template-columns:1fr 1fr}
      .nav-links{display:none}
      .hamburger{display:flex}
      .hero-card{transform:none}
    }
@media (max-width:620px){
      .announce-inner{display:block;text-align:center}
      .quick-info,
      .feature-grid,
      .menu-grid,
      .faq-grid,
      .area-list{grid-template-columns:1fr}
      .hero-inner{padding-top:48px}
      .section{padding:48px 16px}
      .section-head{display:block}
      .hero-actions{display:flex;flex-direction:column;align-items:stretch}
      .hero-actions .btn{width:100%}
      .story-card,
      .local-seo,
      .contact-card{padding:20px;border-radius:28px}
      .mobile-sticky{display:grid}
    }

/* ============================================================
   TACOS PAGE (subhero section)
   Unique classes: .area-pill, .breadcrumb, .content-card, .faq-list, .hero-photo, .mini-card, .mini-grid, .order-buttons, .order-strip, .related-card, .related-grid, .service-area, .subhero, .subhero-inner, .taco-item, .taco-list, .two-col
   ============================================================ */
.subhero{padding:52px 20px 34px;background:linear-gradient(110deg,rgba(3,53,31,.97),rgba(6,108,59,.82),rgba(140,17,24,.90));color:#fff;position:relative;overflow:hidden}
.subhero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 82% 20%,rgba(255,201,75,.34),transparent 21rem),radial-gradient(circle at 15% 70%,rgba(255,255,255,.12),transparent 18rem)}
.subhero-inner{position:relative;z-index:1;max-width:var(--max);margin:auto;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.breadcrumb{font-weight:900;font-size:13px;letter-spacing:.04em;margin-bottom:18px;color:rgba(255,255,255,.82)}
.breadcrumb a{text-decoration:none;border-bottom:1px solid rgba(255,255,255,.45)}
.subhero h1{font-size:clamp(44px,7vw,84px);line-height:.92;margin:0 0 18px;letter-spacing:-.055em}
.subhero .lead{max-width:720px}
.hero-photo{background:rgba(255,247,230,.96);border-radius:36px;padding:18px;border:8px solid rgba(255,255,255,.70);box-shadow:var(--shadow);transform:rotate(1deg)}
.hero-photo img{border-radius:24px;background:#050505;aspect-ratio:1.12/1;object-fit:contain;width:100%}
.hero-photo figcaption{color:var(--green-dark);font-weight:950;text-align:center;padding:15px 6px 2px;font-size:22px}
.mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:26px}
.mini-card{background:#fff;border-radius:24px;padding:18px;box-shadow:var(--soft-shadow);border:1px solid var(--line)}
.mini-card strong{display:block;color:var(--red);font-size:13px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.content-card{background:#fff;border-radius:32px;padding:28px;box-shadow:var(--soft-shadow);border:1px solid var(--line)}
.content-card h3{font-size:30px;line-height:1.05;margin:0 0 12px;color:var(--green-dark);letter-spacing:-.025em}
.content-card p{color:var(--muted);font-size:18px;margin:0 0 14px}
.taco-list{display:grid;gap:12px;margin-top:18px}
.taco-item{display:flex;gap:14px;align-items:flex-start;background:#fff7e6;border-radius:20px;padding:16px;border:1px solid rgba(255,201,75,.42)}
.taco-item span{font-size:26px;line-height:1}
.taco-item strong{display:block;color:var(--green-dark)}
.service-area{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.area-pill{background:#fff;border-radius:22px;padding:18px;text-align:center;font-weight:950;box-shadow:var(--soft-shadow);border:1px solid var(--line)}
.order-strip{background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff;border-radius:36px;padding:32px;display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center;box-shadow:var(--shadow)}
.order-strip h2{color:#fff;margin:0 0 10px}
.order-strip p{color:rgba(255,255,255,.88);font-size:18px;margin:0}
.order-buttons{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.related-card{background:#fff;border-radius:28px;padding:24px;box-shadow:var(--soft-shadow);border:1px solid var(--line);text-decoration:none;transition:.2s transform ease,.2s box-shadow ease}
.related-card:hover{transform:translateY(-6px);box-shadow:0 24px 56px rgba(44,25,12,.16)}
.related-card strong{font-size:22px;color:var(--green-dark);display:block;margin-bottom:8px}
.related-card span{color:var(--muted)}
.faq-list{display:grid;gap:14px}
@media (max-width:900px){.subhero-inner,.two-col,.order-strip{grid-template-columns:1fr}.mini-grid,.service-area,.related-grid{grid-template-columns:1fr 1fr}.hero-photo{transform:none}.order-buttons{justify-content:flex-start}.nav-links{display:none}.hamburger{display:flex}}
@media (max-width:620px){.mini-grid,.service-area,.related-grid{grid-template-columns:1fr}.subhero{padding-top:34px}.content-card{padding:22px;border-radius:26px}.hero-actions{display:flex;flex-direction:column;align-items:stretch}.hero-actions .btn{width:100%}}

/* ============================================================
   GALLERY PAGE
   Unique classes: .announce, .announce-inner, .empty-gallery, .gallery-caption, .gallery-item, .gallery-masonry, .gallery-note, .gallery-toolbar, .gallery-wrap, .hero-card-grid, .is-open, .lightbox, .lightbox-close, .lightbox-inner, .lightbox-title, .mobile-sticky, .tip, .tip-icon, .tips-grid
   ============================================================ */
.announce{
      background:linear-gradient(90deg,var(--green-dark),var(--red-dark));
      color:#fff;
      font-weight:850;
      font-size:14px;
    }
.announce-inner{
      max-width:var(--max);
      margin:auto;
      padding:8px 20px;
      display:flex;
      justify-content:space-between;
      gap:16px;
      flex-wrap:wrap;
    }
.announce a{text-decoration:none;color:#fff}
.hero-card-grid{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:12px;
    }
.hero-card-grid img{
      width:100%;
      height:190px;
      object-fit:cover;
      border-radius:22px;
      background:#050505;
    }
.hero-card-grid img:first-child{
      grid-row:span 2;
      height:392px;
    }
.gallery-wrap{
      position:relative;
      background:linear-gradient(180deg,rgba(6,108,59,.06),rgba(200,35,44,.06));
      border-radius:38px;
      padding:18px;
      box-shadow:inset 0 0 0 1px rgba(6,108,59,.08);
    }
.gallery-toolbar{
      display:flex;
      justify-content:space-between;
      align-items:center;
      gap:18px;
      margin-bottom:18px;
      padding:6px 6px 0;
      flex-wrap:wrap;
    }
.gallery-note{
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding:8px 12px;
      border-radius:999px;
      background:#fff;
      color:var(--red-dark);
      font-size:13px;
      font-weight:900;
      box-shadow:0 10px 24px rgba(44,25,12,.08);
    }
.gallery-masonry{
      columns:4 250px;
      column-gap:18px;
    }
.gallery-item{
      break-inside:avoid;
      margin:0 0 18px;
      border-radius:28px;
      overflow:hidden;
      background:#15100d;
      box-shadow:0 18px 48px rgba(44,25,12,.16);
      border:8px solid #fff;
      position:relative;
      cursor:pointer;
      isolation:isolate;
    }
.gallery-item::after{
      content:"";
      position:absolute;
      inset:0;
      background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.64));
      opacity:.78;
      transition:.22s opacity ease;
      pointer-events:none;
    }
.gallery-item:hover::after{opacity:.96}
.gallery-item img{
      width:100%;
      height:auto;
      min-height:220px;
      max-height:560px;
      object-fit:cover;
      object-position:center;
      background:#050505;
      transition:.28s transform ease, .28s filter ease;
    }
.gallery-item:hover img{
      transform:scale(1.045);
      filter:saturate(1.08) contrast(1.04);
    }
.gallery-caption{
      position:absolute;
      left:0;
      right:0;
      bottom:0;
      z-index:2;
      color:#fff;
      padding:38px 16px 16px;
      font-weight:950;
      font-size:18px;
      text-shadow:0 2px 10px rgba(0,0,0,.45);
    }
.empty-gallery{
      background:#fff;
      border-radius:30px;
      padding:34px;
      text-align:center;
      border:2px dashed rgba(200,35,44,.25);
      box-shadow:0 18px 45px rgba(44,25,12,.08);
    }
.empty-gallery h3{
      font-size:30px;
      margin:0 0 8px;
      color:var(--green-dark);
    }
.empty-gallery p{
      margin:0 auto 18px;
      color:var(--muted);
      max-width:760px;
      font-size:18px;
    }
.tips-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:18px;
    }
.tip{
      background:#fff;
      border-radius:var(--radius);
      padding:24px;
      box-shadow:0 18px 45px rgba(44,25,12,.08);
      border:1px solid rgba(140,17,24,.08);
    }
.tip-icon{
      font-size:32px;
      width:58px;
      height:58px;
      display:grid;
      place-items:center;
      border-radius:18px;
      background:#fff2d3;
      margin-bottom:12px;
    }
.tip h3{
      margin:0 0 8px;
      font-size:22px;
      color:var(--green-dark);
    }
.tip p{margin:0;color:var(--muted)}
.mobile-sticky{
      position:fixed;
      left:0;
      right:0;
      bottom:0;
      z-index:50;
      display:none;
      grid-template-columns:1fr 1fr;
      gap:8px;
      padding:10px;
      background:rgba(255,247,230,.95);
      border-top:1px solid rgba(140,17,24,.14);
      backdrop-filter:blur(14px);
    }
.mobile-sticky .btn{padding:12px 10px}
.lightbox{
      position:fixed;
      inset:0;
      z-index:100;
      background:rgba(12,8,5,.88);
      display:none;
      align-items:center;
      justify-content:center;
      padding:22px;
      backdrop-filter:blur(10px);
    }
.lightbox.is-open{display:flex}
.lightbox-inner{
      position:relative;
      max-width:min(1100px,96vw);
      max-height:92vh;
      background:#fff7e6;
      border-radius:30px;
      padding:14px;
      box-shadow:0 30px 90px rgba(0,0,0,.55);
    }
.lightbox img{
      width:auto;
      max-width:calc(96vw - 28px);
      max-height:calc(92vh - 90px);
      object-fit:contain;
      border-radius:22px;
      background:#050505;
    }
.lightbox-title{
      display:flex;
      justify-content:space-between;
      gap:16px;
      align-items:center;
      padding:12px 8px 2px;
      font-weight:950;
      color:var(--green-dark);
    }
.lightbox-close{
      position:absolute;
      top:-14px;
      right:-14px;
      width:46px;
      height:46px;
      display:grid;
      place-items:center;
      border-radius:999px;
      border:3px solid #fff;
      background:linear-gradient(135deg,var(--red),var(--red-dark));
      color:#fff;
      font-weight:950;
      cursor:pointer;
      box-shadow:0 14px 30px rgba(0,0,0,.24);
    }
@media (max-width:900px){
      .hero-inner,
      .contact-card,
      .footer-inner{grid-template-columns:1fr}
      .quick-info,
      .tips-grid{grid-template-columns:1fr 1fr}
      .nav-links{display:none}
      .hamburger{display:flex}
      .hero-card{transform:none}
      .hero-card-grid img,
      .hero-card-grid img:first-child{height:200px;grid-row:auto}
    }
@media (max-width:620px){
      .announce-inner{display:block;text-align:center}
      .quick-info,
      .tips-grid{grid-template-columns:1fr}
      .hero-inner{padding-top:48px}
      .section{padding:48px 16px}
      .section-head{display:block}
      .hero-actions{display:flex;flex-direction:column;align-items:stretch}
      .hero-actions .btn{width:100%}
      .gallery-wrap{padding:12px;border-radius:28px}
      .gallery-masonry{columns:1;column-gap:0}
      .gallery-item{border-width:5px;border-radius:22px}
      .gallery-item img{min-height:180px}
      .contact-card{padding:20px;border-radius:28px}
      .mobile-sticky{display:grid}
    }

/* ============================================================
   MENU PAGE
   Unique classes: .announce, .announce-inner, .category-nav, .category-section, .mobile-sticky, .placeholder-img, .status-box, .status-inner, .variation, .variation-list, .warning
   ============================================================ */
.announce{
      background:linear-gradient(90deg,var(--green-dark),var(--red-dark));
      color:#fff;
      font-weight:850;
      font-size:14px;
    }
.announce-inner{
      max-width:var(--max);
      margin:auto;
      padding:8px 20px;
      display:flex;
      justify-content:space-between;
      gap:16px;
      flex-wrap:wrap;
    }
.announce a{text-decoration:none;color:#fff}
.status-box{
      max-width:var(--max);
      margin:24px auto 0;
      padding:0 20px;
    }
.status-inner{
      border-radius:20px;
      padding:14px 16px;
      font-weight:850;
      background:#fff;
      border:1px solid rgba(6,108,59,.12);
      box-shadow:0 12px 30px rgba(44,25,12,.07);
      color:var(--green-dark);
    }
.status-inner.warning{
      color:var(--red-dark);
      border-color:rgba(200,35,44,.18);
      background:#fff7e6;
    }
.category-nav{
      max-width:var(--max);
      margin:0 auto;
      padding:26px 20px 0;
      display:flex;
      gap:10px;
      flex-wrap:wrap;
    }
.category-nav a{
      text-decoration:none;
      padding:10px 14px;
      border-radius:999px;
      background:#fff;
      color:var(--green-dark);
      font-weight:900;
      border:1px solid rgba(6,108,59,.12);
      box-shadow:0 10px 24px rgba(44,25,12,.06);
    }
.category-section{
      padding-top:60px;
    }
.img-wrap{
      height:190px;
      background:radial-gradient(circle at 50% 30%,#2a2a2a,#000 72%);
      display:grid;
      place-items:center;
      padding:0 6px;
      margin:0 16px;
      border-radius:26px;
      overflow:visible;
      position:relative;
      top:-48px;
      margin-bottom:-48px;
    }
.img-wrap img{
      width:100%;
      height:100%;
      object-fit:cover;
      object-position:center;
      transition:transform .25s ease;
    }
.menu-card:hover .img-wrap img{transform:scale(1.08)}
.placeholder-img{
      width:100%;
      height:100%;
      display:grid;
      place-items:center;
      color:#fff;
      text-align:center;
      padding:18px;
      font-weight:950;
      font-size:22px;
      background:
        radial-gradient(circle at top left,rgba(255,201,75,.24),transparent 12rem),
        linear-gradient(135deg,var(--green-dark),var(--red-dark));
    }
.variation-list{
      display:grid;
      gap:8px;
      margin-top:16px;
    }
.variation{
      display:flex;
      justify-content:space-between;
      gap:12px;
      align-items:center;
      padding:9px 11px;
      border-radius:14px;
      background:#fff;
      border:1px solid rgba(6,108,59,.09);
      font-weight:850;
    }
.variation span:last-child{
      color:var(--red-dark);
      font-weight:950;
    }
.mobile-sticky{
      position:fixed;
      left:0;
      right:0;
      bottom:0;
      z-index:50;
      display:none;
      grid-template-columns:1fr 1fr;
      gap:8px;
      padding:10px;
      background:rgba(255,247,230,.95);
      border-top:1px solid rgba(140,17,24,.14);
      backdrop-filter:blur(14px);
    }
.mobile-sticky .btn{padding:12px 10px}
@media (max-width:620px){
      .announce-inner{display:block;text-align:center}
      .quick-info,
      .menu-grid{grid-template-columns:1fr}
      .hero-inner{padding-top:48px}
      .section{padding:48px 16px}
      .section-head{display:block}
      .hero-actions{display:flex;flex-direction:column;align-items:stretch}
      .hero-actions .btn{width:100%}
      .menu-actions{flex-direction:column}
      .contact-card{padding:20px;border-radius:28px}
      .mobile-sticky{display:grid}
      footer{padding-bottom:96px}
    }
/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-form-wrap{
      max-width:720px;
      margin:0 auto;
    }
.contact-form{
      background:#fff;
      border-radius:var(--radius);
      padding:40px;
      box-shadow:var(--soft-shadow);
      border:1px solid var(--line);
    }
.form-row{
      display:grid;
      gap:18px;
      margin-bottom:18px;
    }
.form-row--2{
      grid-template-columns:1fr 1fr;
    }
.form-group{
      display:flex;
      flex-direction:column;
      gap:6px;
    }
.form-group label{
      font-weight:850;
      font-size:14px;
      color:var(--ink);
    }
.form-group input,
.form-group textarea{
      width:100%;
      padding:12px 16px;
      border:1.5px solid rgba(140,17,24,.18);
      border-radius:14px;
      font-size:15px;
      font-family:inherit;
      color:var(--ink);
      background:#fff;
      transition:border-color .18s ease, box-shadow .18s ease;
      box-sizing:border-box;
    }
.form-group input:focus,
.form-group textarea:focus{
      outline:none;
      border-color:var(--green);
      box-shadow:0 0 0 3px rgba(6,108,59,.12);
    }
.form-group input.input-error,
.form-group textarea.input-error{
      border-color:var(--red);
      box-shadow:0 0 0 3px rgba(200,35,44,.1);
    }
.form-group textarea{
      resize:vertical;
      min-height:130px;
    }
.char-count{
      font-size:12px;
      color:var(--muted);
      text-align:right;
      margin-top:2px;
    }
.required{
      color:var(--red);
      margin-left:2px;
    }
.optional{
      color:var(--muted);
      font-weight:400;
      font-size:12px;
      margin-left:4px;
    }
.recaptcha-notice{
      font-size:12px;
      color:var(--muted);
      margin:16px 0 20px;
    }
.recaptcha-notice a{
      color:var(--green);
    }
.form-actions{
      display:flex;
      align-items:center;
      gap:20px;
      flex-wrap:wrap;
    }
.btn-submit{
      min-width:160px;
    }
.btn-submit:disabled{
      opacity:.65;
      cursor:not-allowed;
    }
.form-note{
      font-size:14px;
      color:var(--muted);
    }
.form-note a{
      color:var(--green);
      font-weight:700;
    }
.form-alert{
      border-radius:14px;
      padding:16px 20px;
      margin-bottom:24px;
      font-weight:700;
      font-size:15px;
    }
.form-alert--success{
      background:#e8f5ee;
      color:#034d2a;
      border:1.5px solid #a3d9b8;
    }
.form-alert--error{
      background:#fdf1f1;
      color:#7a1119;
      border:1.5px solid #f0b9bc;
    }
.form-alert--error a{
      color:var(--red-dark);
      font-weight:700;
    }
@media(max-width:640px){
      .contact-form{padding:24px 18px}
      .form-row--2{grid-template-columns:1fr}
    }

