    /* ========== TOKENS (Trattoria viva — italiano cálido y apetecible) ========== */
    :root {
      /* Paleta vibrante: tomate · albahaca · dorado · mozzarella */
      --navy: #2b1a14;        /* espresso cálido — texto, títulos, superficie oscura */
      --navy-deep: #1c0f0a;   /* espresso intenso */
      --teal: #4c8c3f;        /* verde albahaca */
      --teal-soft: #cfe3b2;   /* albahaca claro / pistacho suave */
      --mint: #5ba34a;        /* verde fresco */
      --mint-bg: #e7f0d7;     /* verde pálido fresco (chips de ingredientes) */
      --orange: #e03a2f;      /* ROJO TOMATE vivo — acción y acento principal */
      --coral: #f26b4e;       /* tomate coral claro */
      --mustard: #f0a52c;     /* dorado aceite de oliva / queso */
      --yellow-pastel: #f8d98c; /* mantequilla cálida */
      --cream: #fffbf3;       /* mozzarella / crema cálida (superficies) */
      --cream-bg: #fbf4e8;    /* fondo general luminoso */
      --leaf-dark: #2c4a23;   /* verde profundo */
      --white: #ffffff;
      --text: #2b1a14;        /* espresso */
      --text-muted: #8a6f57;  /* marrón cálido medio, legible */

      /* Tonos cálidos para marcos/superficies (antes "madera") */
      --wood-dark: #2b1a14;
      --wood-mid: #ead9bf;    /* passe-partout crema claro */
      --wood-light: #f3e8d4;

      --font-display: 'Fraunces', 'Playfair Display', Georgia, serif;
      --font-body: 'Nunito', system-ui, -apple-system, 'Segoe UI', sans-serif;
      --font-script: 'Caveat', cursive;

      --section-padding: clamp(80px, 12vw, 140px);
      --container-width: 1200px;

      --radius-lg: 18px;
      --radius-md: 14px;
      --radius-sm: 10px;
    }

    /* Glows cálidos muy sutiles (sin textura envejecida ni multiply) */
    body::before {
      content: '';
      position: fixed;
      inset: 0;
      pointer-events: none;
      z-index: 0;
      background-image:
        radial-gradient(ellipse at 12% 8%, rgba(240,165,44,0.10) 0, transparent 42%),
        radial-gradient(ellipse at 88% 92%, rgba(224,58,47,0.06) 0, transparent 46%);
      opacity: 1;
    }
    body {
      background: var(--cream-bg) !important;
    }

    /* ========== RESET ========== */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: var(--font-body);
      background: var(--cream-bg);
      color: var(--text);
      line-height: 1.6;
      overflow-x: hidden;
      -webkit-font-smoothing: antialiased;
      font-weight: 500;
    }
    a { color: inherit; text-decoration: none; }
    img { max-width: 100%; display: block; }
    ul { list-style: none; }
    button { border: none; background: none; cursor: pointer; font-family: inherit; }

    /* ========== UTILITY ========== */
    .container {
      max-width: var(--container-width);
      margin: 0 auto;
      padding: 0 24px;
      position: relative;
    }
    .section-label {
      display: inline-block;
      background: transparent;
      color: var(--orange);
      font-family: var(--font-script);
      font-size: 1.4rem;
      font-weight: 700;
      letter-spacing: 0.5px;
      text-transform: none;
      padding: 0 0 4px;
      border-radius: 0;
      border-bottom: 2px solid var(--orange);
      margin-bottom: 14px;
    }
    .section-title {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(2.4rem, 5.4vw, 3.8rem);
      color: var(--navy);
      line-height: 1.05;
      letter-spacing: -0.5px;
      margin-bottom: 24px;
      font-variation-settings: "opsz" 144, "SOFT" 100;
    }
    .section-title em {
      font-style: italic;
      font-weight: 500;
      color: var(--orange);
      font-variation-settings: "opsz" 144, "SOFT" 100;
    }
    .fade-in {
      opacity: 0;
      transform: translateY(30px);
      transition: opacity 0.8s ease, transform 0.8s ease;
    }
    .fade-in.visible {
      opacity: 1;
      transform: translateY(0);
    }

    /* ========== SVG LEAVES ========== */
    .leaf {
      position: absolute;
      pointer-events: none;
      z-index: 1;
    }

    /* ========== NAVBAR ========== */
    .navbar {
      position: fixed;
      top: 0; left: 0; right: 0;
      z-index: 1000;
      padding: 16px 0;
      transition: all 0.4s ease;
    }
    .navbar.scrolled {
      background: rgba(33,18,12,0.92);
      backdrop-filter: blur(12px) saturate(1.2);
      -webkit-backdrop-filter: blur(12px) saturate(1.2);
      padding: 10px 0;
      box-shadow: 0 8px 28px rgba(43,26,20,0.22);
      border-bottom: 2px solid var(--orange);
    }
    .navbar .container {
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .navbar-brand {
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .brand-circle {
      width: 44px;
      height: 44px;
      border-radius: 50%;
      object-fit: cover;
      flex-shrink: 0;
      display: block;
    }
    .navbar-brand-text {
      display: flex;
      flex-direction: column;
      line-height: 1.1;
    }
    .navbar-brand .name {
      font-family: var(--font-display);
      font-size: 1.2rem;
      color: var(--navy);
      letter-spacing: 0;
      text-transform: uppercase;
    }
    .navbar.scrolled .navbar-brand .name { color: var(--cream); text-shadow: 0 2px 0 rgba(0,0,0,0.5); }
    .navbar-brand .name .logo-b,
    .navbar-brand .name .logo-c { font-size: 1.1em; }
    .navbar-brand .tagline {
      font-size: 0.55rem;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--text-muted);
      margin-top: 3px;
      font-weight: 700;
    }
    .navbar.scrolled .navbar-brand .tagline { color: rgba(232,212,165,0.85); }
    .nav-links {
      display: flex;
      gap: 28px;
      align-items: center;
    }
    .nav-links a {
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--navy);
      transition: color 0.3s;
      position: relative;
    }
    .navbar.scrolled .nav-links a { color: var(--cream); text-shadow: 0 1px 0 rgba(0,0,0,0.5); }
    .nav-links a::after {
      content: '';
      position: absolute;
      bottom: -6px;
      left: 0;
      width: 0;
      height: 2px;
      background: var(--teal);
      transition: width 0.3s;
    }
    .nav-links a:hover { color: var(--teal); }
    .nav-links a:hover::after { width: 100%; }
    .nav-cta {
      background: var(--orange) !important;
      color: var(--cream) !important;
      padding: 11px 22px;
      border-radius: 4px;
      font-size: 0.7rem !important;
      font-weight: 800 !important;
      letter-spacing: 2px !important;
      transition: all 0.3s !important;
      box-shadow: 0 4px 12px rgba(43,26,20,0.12);
    }
    .nav-cta:hover { background: var(--mustard) !important; color: var(--navy) !important; transform: translateY(-1px); }
    .nav-cta::after { display: none !important; }

    /* Hamburger */
    .hamburger {
      display: none;
      flex-direction: column;
      gap: 5px;
      cursor: pointer;
      z-index: 1001;
      padding: 4px;
    }
    .hamburger span {
      width: 26px;
      height: 2px;
      background: var(--navy);
      transition: all 0.3s;
      display: block;
    }
    .navbar.scrolled .hamburger span { background: var(--cream); }
    .hamburger.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
    .hamburger.active span:nth-child(2) { opacity: 0; }
    .hamburger.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

    /* ========== HERO ========== */
    /* ===== Cabecera tipo cartel de pizzería italiana ===== */
    .hero {
      position: relative;
      min-height: 82vh;
      display: flex;
      align-items: center;
      overflow: hidden;
      padding: 140px 24px 90px;
      background:
        radial-gradient(ellipse at 30% 40%, var(--cream) 0%, var(--cream-bg) 60%, color-mix(in srgb, var(--cream-bg) 80%, var(--wood-mid)) 100%);
    }
    /* Manchas decorativas tipo café derramado para textura */
    .hero::before {
      content: '';
      position: absolute;
      top: 18%;
      left: 8%;
      width: 220px;
      height: 220px;
      background: radial-gradient(circle at 30% 30%, rgba(120,60,20,0.10) 0, transparent 65%);
      pointer-events: none;
      z-index: 0;
    }
    .hero::after {
      content: '';
      position: absolute;
      bottom: 12%;
      right: 4%;
      width: 280px;
      height: 280px;
      background: radial-gradient(circle at 70% 70%, rgba(60,40,20,0.12) 0, transparent 60%);
      pointer-events: none;
      z-index: 0;
    }
    .hero-leaves { display: none; }

    .hero-grid {
      width: 100%;
      max-width: 1180px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 0.85fr 1fr;
      gap: clamp(40px, 6vw, 90px);
      align-items: center;
      position: relative;
      z-index: 2;
    }

    /* === Lado foto === */
    .hero-photo {
      position: relative;
      display: flex;
      justify-content: center;
    }
    .hero-photo-frame {
      position: relative;
      width: 100%;
      max-width: 440px;
      aspect-ratio: 4/5;
      border: 14px solid var(--wood-mid);
      outline: 2px solid var(--navy);
      outline-offset: -16px;
      background: var(--wood-dark);
      overflow: hidden;
      transform: rotate(-2deg);
      box-shadow:
        0 22px 50px rgba(0,0,0,0.35),
        0 0 0 1px rgba(255,220,170,0.1);
    }
    .hero-photo-frame img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: saturate(1.08) contrast(1.03);
      display: block;
    }
    /* Cinta adhesiva vintage en la esquina superior */
    .hero-photo-frame::before {
      content: '';
      position: absolute;
      top: -22px;
      left: 24px;
      width: 90px;
      height: 26px;
      background: linear-gradient(rgba(245,234,200,0.55), rgba(245,234,200,0.4));
      border-left: 1px dashed rgba(43,29,16,0.2);
      border-right: 1px dashed rgba(43,29,16,0.2);
      transform: rotate(-12deg);
      box-shadow: 0 2px 6px rgba(0,0,0,0.15);
      pointer-events: none;
      z-index: 5;
    }
    .hero-photo-frame::after {
      content: '';
      position: absolute;
      bottom: -22px;
      right: 36px;
      width: 90px;
      height: 26px;
      background: linear-gradient(rgba(245,234,200,0.55), rgba(245,234,200,0.4));
      border-left: 1px dashed rgba(43,29,16,0.2);
      border-right: 1px dashed rgba(43,29,16,0.2);
      transform: rotate(10deg);
      box-shadow: 0 2px 6px rgba(0,0,0,0.15);
      pointer-events: none;
      z-index: 5;
    }
    /* Sello "FORNO A LEGNA" */
    .hero-photo-badge {
      position: absolute;
      top: -12px;
      right: -22px;
      width: 130px;
      height: 130px;
      border-radius: 50%;
      background: var(--orange);
      color: var(--cream);
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      text-align: center;
      text-transform: uppercase;
      font-family: var(--font-display);
      line-height: 1.05;
      letter-spacing: 1px;
      transform: rotate(10deg);
      box-shadow: 0 8px 20px rgba(0,0,0,0.3);
      border: 3px solid var(--cream);
      outline: 1.5px solid var(--orange);
      outline-offset: -8px;
      z-index: 6;
      padding: 6px;
    }
    .hero-photo-badge .badge-top { font-size: 0.6rem; letter-spacing: 3px; opacity: 0.92; }
    .hero-photo-badge .badge-main { font-size: 1rem; font-style: italic; padding: 4px 0; font-family: var(--font-display); }
    .hero-photo-badge .badge-bot { font-size: 0.6rem; letter-spacing: 3px; opacity: 0.92; }

    /* === Lado texto === */
    .hero-text { position: relative; }
    .hero-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      font-family: var(--font-script);
      color: var(--orange);
      font-size: 1.4rem;
      margin-bottom: 6px;
    }
    .hero-eyebrow .orn {
      font-family: var(--font-display);
      font-size: 0.9rem;
      color: var(--navy);
    }
    .hero-name {
      font-family: var(--font-display);
      font-size: clamp(2.8rem, 7vw, 4.6rem);
      color: var(--navy);
      line-height: 0.95;
      letter-spacing: -1px;
      font-weight: 700;
      margin: 0 0 4px;
      font-variation-settings: "opsz" 144, "SOFT" 100;
    }
    .hero-name-sub {
      font-family: var(--font-display);
      font-style: italic;
      color: var(--orange);
      font-size: clamp(1.3rem, 2.6vw, 1.8rem);
      margin-bottom: 22px;
      font-weight: 500;
      letter-spacing: 0.5px;
    }
    .hero-name-sub .dot { color: var(--text-muted); margin: 0 8px; font-style: normal; }
    .hero-desc {
      max-width: 480px;
      font-family: var(--font-body);
      font-size: clamp(0.95rem, 1.4vw, 1.05rem);
      line-height: 1.7;
      color: var(--text);
      margin: 0 0 24px;
      font-weight: 400;
    }
    .hero-desc strong { color: var(--navy); font-weight: 700; font-family: var(--font-display); font-size: 1.05em; }
    .hero-text .hero-tagline { margin-bottom: 28px; }
    .hero-text .hero-btns { justify-content: flex-start; }

    @media (max-width: 880px) {
      .hero { padding: 120px 24px 60px; min-height: 0; }
      .hero-grid { grid-template-columns: 1fr; gap: 50px; }
      .hero-photo { order: 2; }
      .hero-text { order: 1; text-align: center; }
      .hero-eyebrow { justify-content: center; }
      .hero-desc { margin-left: auto; margin-right: auto; }
      .hero-text .hero-btns { justify-content: center; }
      .hero-text .hero-tagline { display: inline-flex; }
      .hero-photo-frame { max-width: 320px; }
      .hero-photo-badge { width: 110px; height: 110px; right: -10px; }
    }
    .hero-content {
      position: relative;
      z-index: 3;
      text-align: center;
      max-width: 820px;
    }
    .hero-logo-img {
      display: block;
      width: clamp(150px, 20vw, 200px);
      height: clamp(150px, 20vw, 200px);
      border-radius: 50%;
      margin: 0 auto 22px;
      box-shadow: 0 14px 30px rgba(43, 29, 16, 0.35), 0 0 0 5px var(--cream), 0 0 0 6.5px var(--navy);
      object-fit: cover;
    }
    .visually-hidden {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }
    .hero-title {
      font-family: var(--font-display);
      font-size: clamp(2.2rem, 5vw, 3.2rem);
      color: var(--cream);
      line-height: 1;
      letter-spacing: -1px;
      text-transform: capitalize;
      position: relative;
      z-index: 2;
    }
    .hero-title .logo-b,
    .hero-title .logo-c { font-size: 1.3em; }
    .hero-subtitle {
      font-family: var(--font-display);
      font-size: clamp(0.95rem, 2.2vw, 1.2rem);
      letter-spacing: 10px;
      text-transform: uppercase;
      color: var(--navy);
      margin-bottom: 24px;
      font-style: italic;
      font-weight: 500;
    }
    /* Nombre grande de la casa */
    .hero-name {
      font-family: var(--font-display);
      font-size: clamp(2.4rem, 6vw, 3.8rem);
      color: var(--navy);
      line-height: 1;
      letter-spacing: -0.5px;
      margin-bottom: 6px;
      font-weight: 700;
    }
    .hero-name em { font-style: italic; font-weight: 500; color: var(--orange); }
    /* Frase explicativa bajo el nombre */
    .hero-desc {
      max-width: 520px;
      margin: 16px auto 28px;
      font-family: var(--font-body);
      font-size: clamp(0.95rem, 1.6vw, 1.05rem);
      line-height: 1.6;
      color: var(--text-muted);
      font-style: italic;
    }
    .hero-desc strong { color: var(--navy); font-weight: 600; font-style: normal; }
    .hero-tagline {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex-wrap: wrap;
      margin-bottom: 40px;
      background: var(--cream);
      border: 2px solid var(--navy);
      border-radius: 2px;
      padding: 12px 28px;
      gap: 12px;
      box-shadow: 0 8px 20px rgba(43,26,20,0.12);
      position: relative;
    }
    .hero-tagline::before,
    .hero-tagline::after {
      content: '✦';
      color: var(--orange);
      font-size: 0.8rem;
    }
    .hero-tag-item {
      font-size: clamp(0.7rem, 1.5vw, 0.85rem);
      font-weight: 800;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--navy);
    }
    .hero-tag-sep {
      color: var(--orange);
      font-size: 1rem;
      line-height: 1;
    }
    .hero-btns {
      display: flex;
      gap: 16px;
      justify-content: center;
      flex-wrap: wrap;
    }
    .btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 14px 32px;
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      border-radius: 3px;
      transition: all 0.3s;
      font-family: var(--font-body);
    }
    .btn-primary {
      background: var(--navy);
      color: var(--cream);
      border: 2px solid var(--navy);
      box-shadow: 0 8px 20px rgba(43,26,20,0.14);
    }
    .btn-primary:hover {
      background: var(--orange);
      border-color: var(--orange);
      transform: translateY(-2px);
      box-shadow: 0 14px 30px rgba(43,26,20,0.16);
    }
    .btn-outline {
      border: 2px solid var(--navy);
      color: var(--navy);
      background: var(--cream);
      box-shadow: 0 8px 20px rgba(43,26,20,0.12);
    }
    .btn-outline:hover {
      background: var(--navy);
      color: var(--cream);
      transform: translateY(-2px);
      box-shadow: 0 14px 30px rgba(43,26,20,0.16);
    }
    .hero-scroll {
      position: absolute;
      bottom: 24px;
      left: 50%;
      transform: translateX(-50%);
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
      color: var(--navy);
      font-size: 0.6rem;
      font-weight: 700;
      letter-spacing: 3px;
      text-transform: uppercase;
      animation: pulse 2s ease-in-out infinite;
      z-index: 3;
    }
    .hero-scroll .line {
      width: 2px;
      height: 32px;
      background: linear-gradient(to bottom, var(--navy), transparent);
    }
    @keyframes pulse {
      0%, 100% { opacity: 0.5; }
      50% { opacity: 1; }
    }

    /* ========== INFO BANNER ========== */
    .info-banner {
      background: linear-gradient(180deg, var(--mustard), color-mix(in srgb, var(--mustard) 88%, var(--orange)));
      padding: 22px 0;
      position: relative;
      z-index: 2;
      border-top: none;
      border-bottom: none;
    }
    .info-banner .container {
      display: flex;
      justify-content: center;
      gap: clamp(24px, 5vw, 60px);
      flex-wrap: wrap;
    }
    .info-item {
      display: flex;
      align-items: center;
      gap: 12px;
    }
    .info-icon {
      width: 44px;
      height: 44px;
      border-radius: 50%;
      background: var(--navy);
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }
    .info-icon svg {
      width: 20px;
      height: 20px;
      stroke: var(--cream);
      fill: none;
      stroke-width: 2;
    }
    .info-text .label {
      font-size: 0.6rem;
      font-weight: 800;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--navy);
      opacity: 0.7;
    }
    .info-text .value {
      font-size: 0.95rem;
      font-weight: 700;
      color: var(--navy);
    }

    /* ========== ABOUT ========== */
    .about {
      padding: var(--section-padding) 0;
      position: relative;
      overflow: hidden;
      background: var(--cream-bg);
    }
    .about-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
      position: relative;
      z-index: 2;
    }
    .about-images { position: relative; }
    .about-img-main {
      width: 100%;
      aspect-ratio: 4/5;
      object-fit: cover;
      border-radius: var(--radius-md);
      border: 8px solid var(--wood-mid);
      outline: 2px solid var(--navy);
      outline-offset: -10px;
      box-shadow:
        0 18px 40px rgba(43,26,20,0.22),
        inset 0 0 0 1px rgba(255,255,255,0.4);
      filter: saturate(1.06);
    }
    .about-img-float {
      position: absolute;
      bottom: -30px;
      right: -30px;
      width: 200px;
      aspect-ratio: 1;
      object-fit: cover;
      border-radius: 50%;
      border: 8px solid var(--cream);
      outline: 3px solid var(--wood-mid);
      outline-offset: -11px;
      box-shadow: 0 20px 40px rgba(43,26,20,0.28);
      filter: saturate(1.06);
    }
    .about-badge {
      position: absolute;
      top: 20px;
      left: -20px;
      background: var(--orange);
      color: var(--cream);
      padding: 16px;
      border-radius: 50%;
      width: 110px;
      height: 110px;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      text-align: center;
      box-shadow: 0 10px 30px rgba(233, 124, 61, 0.4);
      z-index: 3;
      border: 4px solid var(--cream);
    }
    .about-badge .number {
      font-family: var(--font-display);
      font-size: 1.5rem;
      line-height: 1;
    }
    .about-badge .text {
      font-size: 0.55rem;
      font-weight: 800;
      letter-spacing: 1px;
      text-transform: uppercase;
      line-height: 1.2;
      margin-top: 4px;
    }
    .about-text p {
      color: var(--text);
      margin-bottom: 20px;
      font-size: 1rem;
      line-height: 1.8;
      font-weight: 500;
    }
    .about-text p strong { color: var(--navy); font-weight: 800; }
    .about-features {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
      margin-top: 32px;
    }
    .about-feature {
      background: var(--cream);
      padding: 18px 20px;
      border-radius: var(--radius-md);
      border: 2px solid var(--navy);
    }
    .about-feature h4 {
      font-family: var(--font-display);
      font-size: 0.85rem;
      color: var(--navy);
      margin-bottom: 4px;
      text-transform: uppercase;
      letter-spacing: 0.5px;
    }
    .about-feature p {
      font-size: 0.75rem;
      color: var(--text-muted);
      margin: 0;
      line-height: 1.4;
      font-weight: 500;
    }

    /* ========== CARTA ========== */
    .carta {
      padding: var(--section-padding) 0;
      background:
        linear-gradient(rgba(245, 234, 208, 0.85), rgba(245, 234, 208, 0.85)),
        repeating-linear-gradient(45deg, transparent 0 38px, rgba(58,40,24,0.04) 38px 40px);
      position: relative;
      overflow-x: clip;
      border-top: 1px solid color-mix(in srgb, var(--navy) 20%, transparent);
      border-bottom: 1px solid color-mix(in srgb, var(--navy) 20%, transparent);
    }
    .carta-header {
      text-align: center;
      margin-bottom: 48px;
      position: relative;
      z-index: 2;
    }
    .carta-menu-wrapper {
      max-width: 1080px;
      margin: 0 auto;
      padding: 0 24px;
      position: relative;
      z-index: 2;
    }
    .carta-tabs {
      display: flex;
      justify-content: center;
      gap: 8px;
      margin-bottom: 48px;
      flex-wrap: wrap;
      scroll-margin-top: 80px;
    }
    .carta-tab {
      padding: 10px 22px;
      font-family: var(--font-body);
      font-size: 0.7rem;
      font-weight: 700;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      color: var(--navy);
      background: var(--cream);
      border: 1.5px solid var(--navy);
      border-radius: 2px;
      cursor: pointer;
      transition: all 0.3s;
      box-shadow: 0 6px 16px rgba(43,26,20,0.12);
    }
    .carta-tab:hover { background: var(--yellow-pastel); transform: translateY(-1px); box-shadow: 0 8px 20px rgba(43,26,20,0.12); }
    .carta-tab.active {
      background: var(--navy);
      color: var(--cream);
      box-shadow: 0 6px 16px rgba(43,26,20,0.14);
    }
    .carta-category { display: none; }
    .carta-category.active { display: block; }
    .carta-category-title {
      text-align: center;
      margin-bottom: 40px;
    }
    .carta-category-title h3 {
      font-family: var(--font-display);
      font-size: clamp(2rem, 5vw, 3.2rem);
      color: var(--navy);
      text-transform: uppercase;
      letter-spacing: -0.5px;
      line-height: 0.95;
      display: inline-block;
    }
    .carta-category-title .line {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 12px;
      margin-top: 18px;
    }
    .carta-category-title .line::before,
    .carta-category-title .line::after {
      content: '';
      width: 80px;
      height: 5px;
      border-top: 1.5px solid var(--navy);
      border-bottom: 1.5px solid var(--navy);
    }
    .carta-category-title .line span {
      color: var(--orange);
      font-size: 1.4rem;
      font-family: var(--font-display);
    }
    .carta-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 20px;
    }
    .carta-item {
      background: var(--cream);
      padding: 24px 28px;
      border-radius: var(--radius-lg);
      border: 1px solid rgba(43,26,20,0.06);
      position: relative;
      transition: transform 0.3s ease, box-shadow 0.3s ease;
      cursor: pointer;
      user-select: none;
      -webkit-tap-highlight-color: transparent;
      display: flex;
      flex-direction: column;
      box-shadow: 0 6px 18px rgba(43,26,20,0.08);
    }
    .carta-item:hover {
      transform: translateY(-3px);
      box-shadow: 0 14px 32px rgba(43,26,20,0.14);
    }
    .carta-item:focus-visible {
      outline: 3px solid var(--orange);
      outline-offset: 4px;
    }
    .carta-item:active { transform: translateY(-1px) scale(0.995); }
    .carta-item-plus {
      position: absolute;
      top: 14px;
      right: 14px;
      width: 26px;
      height: 26px;
      border-radius: 50%;
      background: var(--navy);
      color: var(--cream);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.8rem;
      font-weight: 800;
      line-height: 1;
      pointer-events: none;
      transition: background 0.25s ease, transform 0.25s ease;
    }
    .carta-item:hover .carta-item-plus {
      background: var(--orange);
      transform: rotate(90deg);
    }
    .carta-item:nth-child(4n+2) { background: var(--yellow-pastel); }
    .carta-item:nth-child(4n+3) { background: var(--teal-soft); }
    .carta-item:nth-child(4n+4) { background: var(--mustard); }
    .carta-item-header {
      display: flex;
      align-items: baseline;
      gap: 8px;
      margin-bottom: 10px;
      padding-right: 36px;
    }
    .carta-item-name {
      font-family: var(--font-display);
      font-size: 1rem;
      color: var(--navy);
      text-transform: uppercase;
      letter-spacing: 0.3px;
      line-height: 1.2;
      min-width: 0;
      max-width: 60%;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .carta-item-dots {
      flex: 1;
      border-bottom: 2px dotted var(--navy);
      margin-bottom: 4px;
      min-width: 20px;
      opacity: 0.4;
    }
    .carta-item-price {
      font-family: var(--font-display);
      font-size: 1.1rem;
      color: var(--navy);
      white-space: nowrap;
    }
    .carta-item-desc {
      font-size: 0.78rem;
      color: var(--navy);
      opacity: 0.78;
      line-height: 1.5;
      font-weight: 500;
      text-transform: uppercase;
      letter-spacing: 0.3px;
    }
    .carta-item-tag {
      display: inline-block;
      margin-top: 10px;
      padding: 4px 12px;
      font-size: 0.6rem;
      font-weight: 800;
      letter-spacing: 2px;
      text-transform: uppercase;
      border-radius: 50px;
      background: var(--navy);
      color: var(--cream);
    }
    .carta-item-tag.popular { background: var(--orange); }
    .carta-item-bottom {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-top: auto;
      padding-top: 14px;
      flex-wrap: wrap;
    }
    .carta-item-bottom .carta-item-tag { margin-top: 0; }
    .carta-item-bottom .carta-item-allergens { margin-top: 0; margin-left: auto; }
    .carta-note {
      text-align: center;
      margin-top: 40px;
      padding: 20px 32px;
      background: var(--navy);
      color: var(--cream);
      font-family: var(--font-display);
      font-size: 0.85rem;
      letter-spacing: 1px;
      text-transform: uppercase;
      border-radius: var(--radius-lg);
    }

    /* ========== CARTA SEARCH ========== */
    .carta-search-wrap {
      display: flex;
      justify-content: center;
      margin-bottom: 32px;
    }
    .carta-search {
      width: 100%;
      max-width: 480px;
      padding: 12px 20px;
      font-family: var(--font-body);
      font-size: 0.9rem;
      color: var(--navy);
      background: var(--cream);
      border: 1.5px solid var(--navy);
      border-radius: var(--radius-lg);
      box-shadow: 0 4px 12px rgba(43,26,20,0.10);
      outline: none;
      transition: border-color 0.25s, box-shadow 0.25s;
      -webkit-appearance: none;
      appearance: none;
    }
    .carta-search::placeholder { color: rgba(43,26,20,0.45); }
    .carta-search:focus {
      border-color: var(--orange);
      box-shadow: 0 4px 16px rgba(43,26,20,0.14);
    }
    .carta-no-results {
      text-align: center;
      padding: 48px 24px;
      color: var(--navy);
      font-family: var(--font-display);
      font-size: 1.1rem;
      letter-spacing: 0.5px;
    }

    /* ========== DISH MODAL ========== */
    .dish-modal {
      position: fixed;
      inset: 0;
      z-index: 200;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 24px;
      background: rgba(8, 32, 40, 0.55);
      backdrop-filter: blur(6px);
      -webkit-backdrop-filter: blur(6px);
      opacity: 0;
      visibility: hidden;
      transition: opacity 0.25s ease, visibility 0.25s ease;
    }
    .dish-modal.open {
      opacity: 1;
      visibility: visible;
    }
    .dish-modal-card {
      background: var(--cream);
      border: 3px solid var(--navy);
      border-radius: 32px;
      max-width: 820px;
      width: 100%;
      max-height: calc(100vh - 48px);
      display: grid;
      grid-template-columns: minmax(0, 420px) minmax(0, 1fr);
      grid-template-rows: 420px;
      overflow: hidden;
      box-shadow: 0 30px 80px rgba(8, 32, 40, 0.35);
      transform: translateY(20px) scale(0.98);
      opacity: 0;
      transition: transform 0.35s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.3s ease;
    }
    .dish-modal.open .dish-modal-card {
      transform: translateY(0) scale(1);
      opacity: 1;
    }
    .dish-modal-image {
      position: relative;
      background: linear-gradient(135deg, var(--mint-bg) 0%, var(--teal-soft) 100%);
      min-height: 0;
      overflow: hidden;
    }
    .dish-modal-image img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }
    .dish-modal-image.no-image {
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 40px;
    }
    .dish-modal-image .leaf {
      width: 70%;
      max-width: 220px;
      height: auto;
      color: var(--teal);
      opacity: 0.55;
    }
    .dish-modal-content {
      padding: 28px 30px 26px;
      display: flex;
      flex-direction: column;
      overflow-y: auto;
      overscroll-behavior: contain;
      -webkit-overflow-scrolling: touch;
      min-height: 0;
    }
    .dish-modal-tag {
      align-self: flex-start;
      padding: 5px 14px;
      font-size: 0.6rem;
      font-weight: 800;
      letter-spacing: 2px;
      text-transform: uppercase;
      border-radius: 50px;
      background: var(--navy);
      color: var(--cream);
      margin-bottom: 14px;
    }
    .dish-modal-tag.popular { background: var(--orange); }
    .dish-modal-name {
      font-family: var(--font-display);
      font-size: clamp(1.4rem, 2.6vw, 1.85rem);
      color: var(--navy);
      text-transform: uppercase;
      letter-spacing: -0.5px;
      line-height: 1.05;
      margin-bottom: 8px;
    }
    .dish-modal-price {
      font-family: var(--font-display);
      font-size: 1.4rem;
      color: var(--orange);
      margin-bottom: 18px;
      letter-spacing: 0.5px;
    }
    .dish-modal-section-title {
      font-family: var(--font-body);
      font-size: 0.62rem;
      font-weight: 800;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: var(--navy);
      opacity: 0.7;
      margin-bottom: 12px;
    }
    .dish-modal-ingredients {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 18px;
      padding: 0;
      list-style: none;
    }
    .dish-modal-ingredients li {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 14px;
      background: var(--mint-bg);
      border-radius: 999px;
      font-size: 0.82rem;
      color: var(--navy);
      font-weight: 600;
      line-height: 1.2;
    }
    .dish-modal-ingredients li::before {
      content: '';
      flex-shrink: 0;
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--navy);
      margin-top: 0;
    }
    .dish-modal-empty {
      font-size: 0.9rem;
      color: var(--text-muted);
      font-style: italic;
      line-height: 1.55;
      padding: 14px 18px;
      background: var(--cream-bg);
      border: 1.5px dashed rgba(15, 54, 66, 0.25);
      border-radius: 16px;
      margin-bottom: 18px;
    }
    .dish-modal-allergens {
      list-style: none;
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 18px;
    }
    .dish-modal-allergens li {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 6px 12px 6px 6px;
      background: var(--cream-bg);
      border: 1.5px solid rgba(15, 54, 66, 0.18);
      border-radius: 50px;
      font-size: 0.78rem;
      font-weight: 600;
      color: var(--navy);
      letter-spacing: 0.2px;
    }
    .dish-modal-allergens .allergen-dot { width: 26px; height: 26px; }
    .dish-modal-allergens .allergen-dot svg { width: 16px; height: 16px; }
    .dish-modal-allergens-empty {
      font-size: 0.78rem;
      color: var(--text-muted);
      font-style: italic;
      margin-bottom: 18px;
    }
    .dish-modal-allergens-mini {
      display: none;
      flex-wrap: wrap;
      gap: 6px;
      margin: 4px 0 14px;
    }
    .dish-modal-allergens-mini .allergen-dot {
      width: 28px;
      height: 28px;
    }
    .dish-modal-allergens-mini .allergen-dot svg {
      width: 16px;
      height: 16px;
    }
    .allergen-dot {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 22px;
      height: 22px;
      border-radius: 50%;
      background: var(--navy);
      color: var(--cream);
      flex-shrink: 0;
    }
    .allergen-dot svg {
      width: 14px;
      height: 14px;
      color: var(--cream);
      stroke: currentColor;
    }
    /* huevo y mostaza tienen fondo claro → icono navy */
    .allergen-dot.allergen-huevo svg,
    .allergen-dot.allergen-mostaza svg { color: var(--navy); }
    .allergen-dot.allergen-gluten { background: #c98a3a; }
    .allergen-dot.allergen-lacteos { background: #4a8fb5; }
    .allergen-dot.allergen-huevo { background: #e8b948; color: #523a08; }
    .allergen-dot.allergen-pescado { background: #2f8a8a; }
    .allergen-dot.allergen-soja { background: #6a9a4f; }
    .allergen-dot.allergen-frutos-secos { background: #8b5a3c; }
    .allergen-dot.allergen-sesamo { background: #a89070; }
    .allergen-dot.allergen-sulfitos { background: #7a3a5a; }
    .allergen-dot.allergen-mostaza { background: #d6a800; color: #3a2900; }
    .allergen-dot.allergen-apio { background: #5a8a4a; }
    .allergen-dot.allergen-crustaceos { background: #d97a4a; }
    .allergen-dot.allergen-moluscos { background: #5a6a8a; }
    .allergen-dot.allergen-cacahuetes { background: #b07550; }
    /* ===== CARTA ITEM CON FOTO ===== */
    .carta-item.has-photo {
      padding: 0;
      overflow: hidden;
      background: var(--cream) !important;
      border: none;
      box-shadow: 0 6px 18px rgba(8, 32, 40, 0.08);
    }
    .carta-item.has-photo:hover {
      box-shadow: 0 18px 50px rgba(8, 32, 40, 0.18);
    }
    .carta-item-media {
      position: relative;
      width: 100%;
      aspect-ratio: 4 / 3;
      overflow: hidden;
      background: linear-gradient(135deg, var(--teal-soft), var(--mint-bg));
    }
    @media (min-width: 768px) {
      .carta-item-media { aspect-ratio: 1 / 1; }
    }
    .carta-item-media img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
    }
    .carta-item.has-photo:hover .carta-item-media img {
      transform: scale(1.06);
    }
    .carta-item-media-overlay {
      position: absolute;
      inset: 0;
      pointer-events: none;
      background: linear-gradient(to top, rgba(8, 32, 40, 0.72) 0%, rgba(8, 32, 40, 0) 50%);
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      padding: 14px 16px;
    }
    .carta-item-media-price {
      color: white;
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 1.4rem;
      letter-spacing: -0.5px;
      text-shadow: 0 2px 14px rgba(0,0,0,0.45);
    }
    .carta-item.has-photo .carta-item-body {
      padding: 18px 20px 22px;
    }
    .carta-item.has-photo .carta-item-header {
      padding-right: 36px;
      margin-bottom: 8px;
    }
    .carta-item.has-photo .carta-item-name {
      font-size: 1.1rem;
      max-width: none;
      white-space: normal;
      overflow: visible;
      text-overflow: clip;
    }
    .carta-item.has-photo .carta-item-dots,
    .carta-item.has-photo .carta-item-header .carta-item-price {
      display: none;
    }
    .carta-item.has-photo .carta-item-desc {
      text-transform: none;
      letter-spacing: 0;
      font-weight: 500;
      font-size: 0.82rem;
      opacity: 0.7;
      line-height: 1.5;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }
    .carta-item.has-photo .carta-item-plus {
      background: rgba(255, 255, 255, 0.95);
      color: var(--navy);
      backdrop-filter: blur(8px);
      box-shadow: 0 4px 12px rgba(0,0,0,0.15);
      top: 12px;
      right: 12px;
    }
    .carta-item.has-photo:hover .carta-item-plus {
      background: var(--orange);
      color: white;
    }

    .carta-item-allergens {
      display: flex;
      flex-wrap: wrap;
      gap: 5px;
      margin-top: 12px;
      align-items: center;
      justify-content: flex-end;
    }
    .carta-item-allergens-extra {
      font-size: 0.55rem;
      font-weight: 700;
      color: var(--navy);
      opacity: 0.6;
      margin-left: 2px;
    }
    .dish-modal-footer {
      margin-top: auto;
      padding-top: 18px;
      border-top: 2px dotted rgba(15, 54, 66, 0.2);
      font-size: 0.7rem;
      color: var(--text-muted);
      font-weight: 600;
      letter-spacing: 0.5px;
    }
    .dish-modal-close {
      position: absolute;
      top: 14px;
      right: 14px;
      width: 40px;
      height: 40px;
      border-radius: 50%;
      background: var(--cream);
      color: var(--navy);
      border: 2px solid var(--navy);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      z-index: 4;
      transition: all 0.25s ease;
      box-shadow: 0 4px 12px rgba(8, 32, 40, 0.18);
    }
    .dish-modal-close:hover {
      background: var(--orange);
      color: var(--cream);
      transform: rotate(90deg);
    }
    .dish-modal-close svg { width: 18px; height: 18px; }
    body.modal-open { overflow: hidden; }

    /* ========== GALLERY ========== */
    .gallery {
      padding: var(--section-padding) 0;
      background: var(--cream-bg);
      position: relative;
      overflow: hidden;
    }
    .gallery-header {
      text-align: center;
      margin-bottom: 48px;
      position: relative;
      z-index: 2;
    }
    .gallery-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      grid-template-rows: repeat(2, 240px);
      gap: 12px;
      position: relative;
      z-index: 2;
    }
    .gallery-item {
      position: relative;
      overflow: hidden;
      border-radius: var(--radius-md);
      cursor: pointer;
      border: 6px solid var(--wood-mid);
      outline: 2px solid var(--navy);
      outline-offset: -8px;
      box-shadow: 0 10px 22px rgba(0,0,0,0.3);
    }
    .gallery-item img { filter: saturate(1.08) contrast(1.02); }
    .gallery-item:nth-child(1) {
      grid-column: span 2;
      grid-row: span 2;
    }
    .gallery-item img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform 0.6s ease;
    }
    .gallery-item:hover img { transform: scale(1.06); }
    .gallery-cta {
      text-align: center;
      margin-top: 40px;
      position: relative;
      z-index: 2;
    }
    .gallery-cta a {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 14px 32px;
      background: var(--navy);
      color: var(--cream);
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 2px;
      text-transform: uppercase;
      border-radius: 3px;
      transition: all 0.3s;
      box-shadow: 0 8px 20px rgba(43,26,20,0.14);
    }
    .gallery-cta a:hover {
      background: var(--orange);
      transform: translateY(-2px);
    }

    /* ========== REVIEWS ========== */
    .reviews {
      padding: var(--section-padding) 0;
      background: var(--teal-soft);
      position: relative;
      overflow: hidden;
    }
    .reviews-header {
      text-align: center;
      margin-bottom: 48px;
      position: relative;
      z-index: 2;
    }
    .reviews-rating {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 16px;
      margin-top: 24px;
    }
    .reviews-score {
      font-family: var(--font-display);
      font-size: 4rem;
      color: var(--navy);
      line-height: 1;
      text-shadow: 4px -4px 0 var(--mustard);
    }
    .reviews-stars {
      display: flex;
      flex-direction: column;
      gap: 4px;
      align-items: flex-start;
    }
    .stars {
      color: var(--orange);
      font-size: 1.2rem;
      letter-spacing: 2px;
    }
    .reviews-count {
      font-size: 0.75rem;
      color: var(--navy);
      font-weight: 700;
      letter-spacing: 0.5px;
    }
    .reviews-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
      position: relative;
      z-index: 2;
    }
    .review-card {
      background: var(--cream);
      border-radius: var(--radius-md);
      padding: 28px;
      border: 3px solid var(--navy);
    }
    .review-card .stars {
      font-size: 1rem;
      margin-bottom: 16px;
    }
    .review-card p {
      font-size: 0.9rem;
      color: var(--navy);
      line-height: 1.65;
      margin-bottom: 16px;
      font-weight: 500;
    }
    .review-author {
      font-family: var(--font-display);
      font-size: 0.8rem;
      color: var(--navy);
      text-transform: uppercase;
      letter-spacing: 1px;
    }
    .review-source {
      font-size: 0.65rem;
      color: var(--text-muted);
      font-weight: 700;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      margin-top: 4px;
    }
    .reviews-cta {
      margin: 56px auto 0;
      max-width: 760px;
      padding: 44px 36px 40px;
      background: var(--cream);
      border: 3px solid var(--navy);
      border-radius: 40px;
      text-align: center;
      position: relative;
      box-shadow: 0 14px 32px rgba(8, 32, 40, 0.08);
    }
    .reviews-cta::before {
      content: '';
      position: absolute;
      top: -22px;
      left: 50%;
      transform: translateX(-50%);
      width: 56px;
      height: 56px;
      background: var(--orange);
      border: 3px solid var(--navy);
      border-radius: 50%;
      box-shadow: 0 6px 14px rgba(8, 32, 40, 0.15);
    }
    .reviews-cta::after {
      content: '\2605';
      position: absolute;
      top: -22px;
      left: 50%;
      transform: translateX(-50%);
      width: 56px;
      height: 56px;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--cream);
      font-size: 1.6rem;
    }
    .reviews-cta-title {
      font-family: var(--font-display);
      font-weight: 900;
      font-size: clamp(1.6rem, 3.4vw, 2.2rem);
      color: var(--navy);
      line-height: 1.1;
      letter-spacing: -0.5px;
      margin: 14px 0 12px;
    }
    .reviews-cta-title em {
      font-style: italic;
      font-weight: 500;
      color: var(--orange);
    }
    .reviews-cta-text {
      font-size: 0.95rem;
      color: var(--text-muted);
      line-height: 1.55;
      max-width: 480px;
      margin: 0 auto 26px;
      font-weight: 500;
    }
    .reviews-cta-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      justify-content: center;
      align-items: center;
    }
    .reviews-cta-actions .btn { padding: 16px 30px; }
    .reviews-cta-actions .btn svg {
      width: 18px;
      height: 18px;
    }
    .reviews-cta-link {
      font-size: 0.72rem;
      font-weight: 800;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--navy);
      border-bottom: 2px solid var(--navy);
      padding-bottom: 2px;
      transition: color 0.25s, border-color 0.25s;
    }
    .reviews-cta-link:hover {
      color: var(--orange);
      border-color: var(--orange);
    }
    @media (max-width: 540px) {
      .reviews-cta { padding: 40px 24px 32px; border-radius: 32px; }
      .reviews-cta-actions { flex-direction: column; }
      .reviews-cta-actions .btn { width: 100%; justify-content: center; }
    }

    /* ========== CONTACT ========== */
    .contact {
      padding: var(--section-padding) 0;
      background: var(--cream-bg);
      position: relative;
      overflow: hidden;
    }
    .contact-header {
      text-align: center;
      margin-bottom: 48px;
      position: relative;
      z-index: 2;
    }
    .contact-map {
      border-radius: var(--radius-md);
      overflow: hidden;
      height: 360px;
      border: 4px solid var(--navy);
      margin-bottom: 32px;
      position: relative;
      z-index: 2;
    }
    .contact-map iframe {
      width: 100%;
      height: 100%;
      border: 0;
    }
    .contact-info-row {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 20px;
      margin-bottom: 32px;
      position: relative;
      z-index: 2;
    }
    .contact-info-item {
      text-align: center;
      padding: 28px 24px;
      border-radius: var(--radius-md);
      border: 3px solid var(--navy);
      transition: all 0.3s;
    }
    .contact-info-item:nth-child(1) { background: var(--mustard); }
    .contact-info-item:nth-child(2) { background: var(--teal); }
    .contact-info-item:hover {
      transform: translateY(-3px);
      box-shadow: 0 12px 30px rgba(8, 32, 40, 0.15);
    }
    .contact-info-item h4 {
      font-family: var(--font-display);
      font-size: 0.7rem;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: var(--navy);
      opacity: 0.75;
      margin-bottom: 10px;
    }
    .contact-info-item p {
      font-family: var(--font-display);
      font-size: 1.1rem;
      color: var(--navy);
      line-height: 1.4;
      text-transform: uppercase;
    }
    .contact-info-item a { color: var(--navy); transition: color 0.3s; }
    .contact-info-item a:hover { color: var(--orange); }

    .horario {
      max-width: 600px;
      margin: 0 auto;
      background: var(--cream);
      border-radius: var(--radius-md);
      padding: 36px 40px;
      border: 3px solid var(--navy);
      position: relative;
      z-index: 2;
    }
    .horario h3 {
      font-family: var(--font-display);
      font-size: 1.3rem;
      color: var(--navy);
      margin-bottom: 20px;
      text-align: center;
      text-transform: uppercase;
      letter-spacing: 1px;
    }
    .horario-row {
      display: flex;
      justify-content: space-between;
      padding: 10px 0;
      border-bottom: 2px dotted var(--navy);
      font-size: 0.85rem;
      text-transform: uppercase;
      letter-spacing: 0.5px;
    }
    .horario-row:last-child { border-bottom: none; }
    .horario-day { color: var(--navy); font-weight: 700; opacity: 0.8; }
    .horario-hours { color: var(--navy); font-weight: 700; }
    .horario-closed { color: var(--text-muted); font-style: italic; font-weight: 500; }
    .horario-today { color: var(--orange) !important; opacity: 1 !important; }

    /* ========== CTA ========== */
    .cta-section {
      padding: 100px 0;
      background:
        radial-gradient(ellipse at 30% 20%, var(--coral) 0%, transparent 60%),
        linear-gradient(135deg, var(--orange) 0%, color-mix(in srgb, var(--orange) 70%, var(--navy)) 100%);
      text-align: center;
      position: relative;
      overflow: hidden;
      border-top: none;
      border-bottom: none;
    }
    .cta-section .container { position: relative; z-index: 2; }
    .cta-section .section-title {
      color: var(--cream);
    }
    .cta-section .section-title em { color: var(--mustard); }
    .cta-section p {
      color: rgba(255, 250, 234, 0.85);
      max-width: 540px;
      margin: 0 auto 32px;
      font-weight: 500;
    }
    .btn-white {
      background: var(--cream);
      color: var(--orange);
      border: 3px solid var(--cream);
      padding: 16px 40px;
      box-shadow: 0 10px 26px rgba(28,15,10,0.28);
    }
    .btn-white:hover {
      background: var(--mustard);
      border-color: var(--mustard);
      color: var(--navy);
      transform: translateY(-2px);
    }

    /* ========== FOOTER ========== */
    .footer {
      padding: 48px 0 24px;
      background: var(--navy-deep);
      color: var(--cream);
      border-top: 4px solid var(--orange);
    }
    .footer-content {
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
      gap: 24px;
      margin-bottom: 32px;
    }
    .footer-brand {
      display: flex;
      align-items: center;
      gap: 14px;
    }
    .footer-brand .brand-circle { width: 56px; height: 56px; font-size: 1.6rem; }
    .footer-brand .name {
      font-family: var(--font-display);
      font-size: 1.2rem;
      color: var(--cream);
      text-transform: uppercase;
    }
    .footer-brand p {
      font-size: 0.75rem;
      color: rgba(255,250,234,0.6);
      margin-top: 6px;
      font-weight: 500;
      letter-spacing: 0.5px;
    }
    .footer-social { display: flex; gap: 12px; }
    .footer-social a {
      width: 44px;
      height: 44px;
      border-radius: 50%;
      background: var(--cream);
      display: flex;
      align-items: center;
      justify-content: center;
      transition: all 0.3s;
    }
    .footer-social a:hover {
      background: var(--orange);
      transform: translateY(-2px);
    }
    .footer-social a svg {
      width: 20px;
      height: 20px;
      fill: var(--navy);
      transition: fill 0.3s;
    }
    .footer-social a:hover svg { fill: var(--cream); }
    .footer-bottom {
      text-align: center;
      padding-top: 24px;
      border-top: 2px dotted rgba(255,250,234,0.2);
      font-size: 0.72rem;
      color: rgba(255,250,234,0.55);
      font-weight: 500;
      letter-spacing: 1px;
    }
    .footer-bottom a { color: var(--teal); }

    /* ========== RESPONSIVE ========== */
    @media (max-width: 1024px) {
      .about-grid { gap: 40px; }
      .reviews-grid { grid-template-columns: 1fr 1fr; }
    }
    @media (max-width: 768px) {
      .hamburger { display: flex; }
      .nav-links {
        position: fixed;
        top: 0;
        right: -100%;
        width: 280px;
        height: 100vh;
        background: var(--navy-deep);
        flex-direction: column;
        justify-content: center;
        gap: 28px;
        padding: 40px;
        transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        border-left: 3px solid var(--teal);
      }
      .nav-links.open { right: 0; }
      .nav-links a { font-size: 1rem; color: var(--cream); }
      .navbar-brand-text .tagline { display: none; }
      .about-grid {
        grid-template-columns: 1fr;
        gap: 60px;
      }
      .about-img-float { display: none; }
      .about-badge { width: 90px; height: 90px; top: 10px; left: -10px; }
      .about-badge .number { font-size: 1.2rem; }
      .about-features { grid-template-columns: 1fr; }
      .gallery-grid {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto;
      }
      .gallery-item:nth-child(1) {
        grid-column: span 2;
        grid-row: span 1;
      }
      .gallery-item { height: 220px; }
      .reviews-grid { grid-template-columns: 1fr; }
      .contact-info-row { grid-template-columns: 1fr; gap: 16px; }
      .contact-map { height: 280px; }
      .horario { padding: 28px 24px; }
      .carta-grid { grid-template-columns: 1fr; }
      .hero-subtitle { letter-spacing: 6px; }

      .carta-tabs {
        flex-wrap: nowrap;
        justify-content: flex-start;
        overflow-x: auto;
        overflow-y: visible;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        position: sticky;
        top: 60px;
        z-index: 10;
        background: transparent;
        padding: 14px 4px;
        margin-bottom: 32px;
        scroll-snap-type: x proximity;
        scroll-margin-top: 60px;
        border-bottom: none;
      }
      .carta-tabs::-webkit-scrollbar { display: none; }
      .carta-tab { flex-shrink: 0; scroll-snap-align: start; }

      /* Modal responsive */
      .dish-modal { padding: 0; align-items: flex-end; }
      .dish-modal-card {
        width: 100vw;
        max-width: 100vw;
        margin: 0;
        grid-template-columns: 1fr;
        grid-template-rows: auto minmax(0, 1fr);
        height: 82dvh;
        max-height: 82vh;
        border-radius: 28px 28px 0 0;
        border-width: 0;
        border-top: 3px solid var(--navy);
        transform: translateY(40px);
      }
      .dish-modal.open .dish-modal-card { transform: translateY(0); }
      .dish-modal-image {
        width: 100%;
        height: auto;
        min-height: 0;
        aspect-ratio: 4 / 3;
        max-height: none;
      }
      .dish-modal-content { padding: 22px 22px 24px; }
      .dish-modal-name { font-size: 1.4rem; }
      .dish-modal-price { font-size: 1.25rem; margin-bottom: 14px; }
      .dish-modal-ingredients { grid-template-columns: 1fr 1fr; gap: 8px 14px; }
      .dish-modal-ingredients li { font-size: 0.8rem; }
      .dish-modal-allergens-mini[data-has-items="true"] { display: flex; }
      #dishModalAllergensTitle,
      #dishModalAllergens,
      #dishModalAllergensEmpty { display: none !important; }
      .dish-modal-close {
        top: 12px;
        right: 12px;
        width: 36px;
        height: 36px;
        background: rgba(8, 32, 40, 0.55);
        color: #fff;
        border: none;
        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);
        box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
        z-index: 6;
      }
      .dish-modal-close:hover {
        background: rgba(8, 32, 40, 0.75);
        color: #fff;
        transform: none;
      }
      .dish-modal-close svg { width: 15px; height: 15px; stroke-width: 2.5; }
      .dish-modal-card::before {
        content: '';
        position: absolute;
        top: 10px;
        left: 50%;
        transform: translateX(-50%);
        width: 44px;
        height: 5px;
        border-radius: 5px;
        background: rgba(255, 255, 255, 0.85);
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.25);
        z-index: 5;
        pointer-events: none;
      }
    }
    @media (max-width: 480px) {
      .hero { padding: 110px 16px 80px; }
      .hero-tagline { padding: 10px 18px; gap: 8px; }
      .hero-tag-item { font-size: 0.65rem; letter-spacing: 1px; }
      .hero-tag-sep { font-size: 0.85rem; }
      .hero-btns { flex-direction: column; align-items: stretch; }
      .btn { width: 100%; justify-content: center; }
      .info-banner .container { flex-direction: column; align-items: stretch; gap: 16px; max-width: 280px; }
      .info-item { justify-content: flex-start; }
      .carta-tabs { gap: 6px; }
      .carta-tab { padding: 8px 14px; font-size: 0.6rem; letter-spacing: 1px; }
      .carta-item { padding: 20px; border-radius: 32px; }
      .carta-item-header { flex-wrap: wrap; }
      .carta-item-name { font-size: 0.9rem; white-space: normal !important; }
      .carta-item-dots { display: none; }
      .carta-item-price { font-size: 1rem; }
      .gallery-grid { grid-template-columns: 1fr; grid-template-rows: auto; }
      .gallery-item:nth-child(1) { grid-column: span 1; }
      .gallery-item { height: 220px; }
      .reviews-score { font-size: 3rem; }
      .dish-modal-image { width: 100%; aspect-ratio: 4 / 3; max-height: none; }
      .dish-modal-ingredients { grid-template-columns: 1fr 1fr; gap: 8px 12px; }
      .dish-modal-ingredients li { font-size: 0.78rem; line-height: 1.35; }
    }
