/* ============================================================
   Monarca Mexican Grill — Design A (Rotulo, remapped to [data-design="a"])
   ============================================================ */

[data-design="a"] {
  /* Surface — cal-washed adobe wall */
  --cal:        #FBF2DD;
  --cal-2:      #FFF9EC;
  --barro:      #C75B33;
  --barro-soft: #E7B79B;

  /* Ink — cacao, never pure black */
  --tinta:      #2A1C10;
  --tinta-2:    #5A4632;
  --polvo:      #8C7656;

  /* Line */
  --linea:        #E5D2AC;
  --linea-fuerte: #C9A878;

  /* Primary — Talavera cobalt */
  --cobalto:        #15448C;
  --cobalto-hover:  #0F3470;
  --sobre-cobalto:  #FBF2DD;

  /* Accent — cempasuchil marigold */
  --cempasuchil:        #F0A007;
  --cempasuchil-hover:  #D98E04;
  --sobre-cempasuchil:  #2A1C10;

  /* Festival palette */
  --verde:  #2F8F4E;
  --rosa:   #E0457B;
  --limon:  #7CB518;

  /* Semantic */
  --chile:   #C42B1C;
  --success: var(--verde);

  /* Design-a primary token exposure (hard contract) */
  --design-a-primary: var(--cobalto);

  /* Typography */
  --font-rotulo: "Clarendon", "Clarendon URW", "Roboto Slab", "Rockwell", Georgia, serif;
  --font-body:   "DM Sans", "Aktiv Grotesk", -apple-system, "Segoe UI", system-ui, sans-serif;
  --font-mano:   "Caveat", "Sant Joan", "Segoe Script", cursive;
  --font-mono:   "Space Mono", ui-monospace, "JetBrains Mono", monospace;

  --t-meta:   14px;
  --t-body:   16px;
  --t-lg:     18px;
  --t-title:  clamp(22px, 3.2vw, 28px);
  --t-head:   clamp(28px, 5vw, 44px);
  --t-display:clamp(40px, 9vw, 72px);
  --lh-body:  1.55;
  --lh-tight: 1.08;
  --track-slab: 0.005em;
  --track-label: 0.06em;

  --s-hair:  4px;
  --s-tight: 8px;
  --s-snug:  12px;
  --s-base:  16px;
  --s-room:  24px;
  --s-gap:   32px;
  --s-band:  48px;
  --s-sec:   80px;
  --s-sec-m: 56px;

  --menu-row-pad: 10px;
  --menu-item-gap: 2px;
  --menu-col-gap: var(--s-base);
  --menu-sec-gap: var(--s-band);

  --r-sign: 3px;
  --r-tile: 8px;
  --r-clay: 16px;
  --r-pill: 999px;

  --dur-quick:  160ms;
  --dur-base:   240ms;
  --dur-settle: 420ms;
  --ease-pincel:  cubic-bezier(0.22, 1, 0.36, 1);
  --ease-asentar: cubic-bezier(0.34, 1.16, 0.64, 1);
  --ease-voltear: cubic-bezier(0.65, 0, 0.35, 1);
  --ease-mecer:   ease-in-out;

  --elev-flat:   none;
  --elev-line:   0 1px 0 var(--linea-fuerte);
  --elev-tile:   0 2px 0 -1px color-mix(in srgb, var(--barro) 55%, transparent),
                 0 10px 24px -10px rgba(42, 28, 16, 0.22);
  --elev-raised: 0 16px 36px -12px rgba(42, 28, 16, 0.30);

  --focus-ring: 0 0 0 3px color-mix(in srgb, var(--cobalto) 35%, transparent);
}

@media (prefers-color-scheme: dark) {
  [data-design="a"] {
    --cal:        #1A130C;
    --cal-2:      #241A11;
    --barro:      #A8482A;
    --barro-soft: #5C3322;
    --tinta:      #F3E6CE;
    --tinta-2:    #C9B596;
    --polvo:      #A48E6E;
    --linea:        #3A2C1C;
    --linea-fuerte: #5A4630;
    --cobalto:        #5C8FD6;
    --cobalto-hover:  #7AA6E2;
    --sobre-cobalto:  #1A130C;
    --cempasuchil:        #F6B12E;
    --cempasuchil-hover:  #FFC24E;
    --sobre-cempasuchil:  #1A130C;
    --verde:  #5CB874;
    --rosa:   #EC6A97;
    --limon:  #9AD13A;
    --chile:  #E5563F;
    --design-a-primary: var(--cobalto);
  }
}

[data-design="a"].dq-design {
  background: var(--cal);
  color: var(--tinta);
  font-family: var(--font-body);
  font-size: var(--t-body);
  line-height: var(--lh-body);
  isolation: isolate;
}

/* ============ Element 1 — Header ============ */
[data-design="a"] .rotulo-header { position: sticky; top: 0; z-index: 50;
  background: var(--cal); box-shadow: var(--elev-line); box-sizing: border-box; }
[data-design="a"] .rh-papel { height: 22px; overflow: hidden; }
[data-design="a"] .rh-papel__svg { width: 100%; height: 44px; display: block; }
[data-design="a"] .rh-papel__row { transform-origin: 50% 0;
  animation: a-rotulo-mecer 24s var(--ease-mecer) infinite; }
[data-design="a"] .rh-bar { display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-base); max-width: 1200px; margin: 0 auto; padding: var(--s-snug) var(--s-room);
  box-sizing: border-box; }
[data-design="a"] .rh-logo { text-decoration: none; }
[data-design="a"] .rh-logo__mark { font-family: var(--font-rotulo); font-weight: 700;
  font-size: clamp(18px, 4vw, 26px); letter-spacing: var(--track-slab); color: var(--cobalto);
  display: inline-block; clip-path: inset(0 0 0 0); animation: a-rotulo-paint-on 720ms var(--ease-pincel) both; }
[data-design="a"] .rh-burger { display: inline-flex; flex-direction: column; gap: 5px;
  width: 44px; height: 44px; align-items: center; justify-content: center; background: none;
  border: 0; cursor: pointer; border-radius: var(--r-sign); }
[data-design="a"] .rh-burger__l { width: 24px; height: 2.5px; background: var(--tinta);
  border-radius: 2px; transition: transform var(--dur-quick) var(--ease-pincel), opacity var(--dur-quick); }
[data-design="a"] .rh-burger:focus-visible { outline: none; box-shadow: var(--focus-ring); }
[data-design="a"] .rh-burger[aria-expanded="true"] .rh-burger__l:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
[data-design="a"] .rh-burger[aria-expanded="true"] .rh-burger__l:nth-child(2) { opacity: 0; }
[data-design="a"] .rh-burger[aria-expanded="true"] .rh-burger__l:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }
[data-design="a"] .rh-drawer { position: fixed; inset: 0; z-index: 60; }
[data-design="a"] .rh-drawer[hidden] { display: none; }
[data-design="a"] .rh-drawer__scrim { position: absolute; inset: 0;
  background: color-mix(in srgb, var(--tinta) 55%, transparent); opacity: 0;
  transition: opacity var(--dur-base); }
[data-design="a"] .rh-drawer.is-open .rh-drawer__scrim { opacity: 1; }
[data-design="a"] .rh-drawer__panel { position: absolute; inset: 0; background: var(--cal-2);
  border-top: 6px solid transparent; padding: clamp(56px, 12vh, 96px) var(--s-room) var(--s-room);
  display: flex; flex-direction: column; gap: var(--s-base); box-sizing: border-box;
  transform: scale(0.98); opacity: 0; transition: transform var(--dur-base) var(--ease-pincel), opacity var(--dur-base);
  background-image: repeating-linear-gradient(90deg, var(--cobalto) 0 18px, var(--rosa) 18px 36px,
    var(--cempasuchil) 36px 54px, var(--verde) 54px 72px, var(--barro) 72px 90px);
  background-size: 90px 6px; background-repeat: repeat-x; background-position: top; }
[data-design="a"] .rh-drawer.is-open .rh-drawer__panel { transform: scale(1); opacity: 1; }
[data-design="a"] .rh-drawer__panel a { font-family: var(--font-rotulo); font-weight: 700;
  font-size: var(--t-title); color: var(--tinta); text-decoration: none; width: max-content;
  position: relative; padding: var(--s-tight) 0; }
[data-design="a"] .rh-drawer__panel a::after { content: ""; position: absolute; left: 0; bottom: 2px;
  height: 3px; width: 100%; background: var(--cobalto); clip-path: inset(0 100% 0 0);
  transition: clip-path var(--dur-base) var(--ease-pincel); }
[data-design="a"] .rh-drawer__panel a:focus-visible { outline: none; }
[data-design="a"] .rh-drawer__panel a:focus-visible::after { clip-path: inset(0 0 0 0); }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .rh-drawer__panel a:hover::after { clip-path: inset(0 0 0 0); }
}
[data-design="a"] .rh-drawer__actions { margin-top: var(--s-base); }
@keyframes a-rotulo-mecer { 0%,100% { transform: rotate(-0.5deg) translateX(-4px); }
  50% { transform: rotate(0.5deg) translateX(4px); } }
@keyframes a-rotulo-paint-on { from { clip-path: inset(0 100% 0 0); opacity: 0.4; }
  to { clip-path: inset(0 0 0 0); opacity: 1; } }
@keyframes a-rotulo-paint-on-clip { from { clip-path: inset(0 100% 0 0); }
  to { clip-path: inset(0 0 0 0); } }
@media (max-width: 560px) { [data-design="a"] .rh-bar { padding: var(--s-tight) var(--s-base); } }
@media (max-width: 380px) { [data-design="a"] .rh-logo__mark { font-size: 18px; } }

/* ============ Chips (styled anchors — hard contract) ============ */
[data-design="a"] .a-chip { display: inline-flex; align-items: center; justify-content: center;
  gap: var(--s-tight); padding: 12px var(--s-room); border-radius: var(--r-sign);
  font-family: var(--font-rotulo); font-weight: 700; font-size: var(--t-body);
  letter-spacing: var(--track-slab); text-decoration: none; box-sizing: border-box;
  min-height: 44px; transition: transform var(--dur-quick) var(--ease-pincel),
  box-shadow var(--dur-quick) var(--ease-pincel), background-color var(--dur-quick); }
[data-design="a"] .a-chip--primary { background: var(--cempasuchil); color: var(--sobre-cempasuchil);
  box-shadow: 0 3px 0 0 var(--cobalto), var(--elev-tile); }
[data-design="a"] .a-chip--secondary { background: var(--cal-2); color: var(--cobalto);
  border: 2px solid var(--cobalto); }
[data-design="a"] .a-chip--ghost { background: none; color: var(--cobalto);
  border: 2px solid var(--linea-fuerte); }
[data-design="a"] .a-chip--tel { background: var(--cal-2); color: var(--cobalto);
  border: 2px solid var(--cobalto); }
[data-design="a"] .a-chip:focus-visible { outline: none; box-shadow: var(--focus-ring); }
[data-design="a"] .a-chip--primary:active { transform: translateY(2px); box-shadow: 0 1px 0 0 var(--cobalto); }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .a-chip--primary:hover { transform: translateY(-1px); background: var(--cempasuchil-hover);
    box-shadow: 0 4px 0 0 var(--cobalto-hover), var(--elev-raised); }
  [data-design="a"] .a-chip--secondary:hover,
  [data-design="a"] .a-chip--tel:hover { transform: translateY(-1px); background: var(--barro-soft); }
  [data-design="a"] .a-chip--ghost:hover { transform: translateY(-1px); border-color: var(--cobalto); }
}

/* ============ Element 3 — Hero carta ============ */
[data-design="a"] .ra-hero { max-width: 1100px; margin: 0 auto; padding: var(--s-band) var(--s-room) var(--s-sec-m);
  text-align: center; box-sizing: border-box; position: relative; z-index: 1; }
[data-design="a"] .ra-hero__head { font-family: var(--font-rotulo); font-weight: 700; color: var(--cobalto);
  font-size: var(--t-display); line-height: var(--lh-tight); letter-spacing: var(--track-slab);
  margin: 0 0 var(--s-snug); text-wrap: balance; opacity: 1; }
[data-design="a"] .ra-hero__sub { font-family: var(--font-body); color: var(--tinta-2);
  font-size: var(--t-lg); line-height: var(--lh-body); max-width: 56ch; margin: 0 auto var(--s-gap); opacity: 1; }
[data-design="a"] .ra-carta { position: relative; background: var(--cal-2); border: 2px solid var(--linea-fuerte);
  border-radius: var(--r-clay); padding: var(--s-room) clamp(var(--s-base), 4vw, var(--s-gap));
  box-shadow: var(--elev-tile); max-width: 680px; margin: 0 auto; box-sizing: border-box; overflow: hidden; }
[data-design="a"] .ra-carta__corner { position: absolute; width: 16px; height: 16px; border: 3px solid var(--cobalto); }
[data-design="a"] .ra-carta__corner--tl { top: 8px; left: 8px; border-right: 0; border-bottom: 0; }
[data-design="a"] .ra-carta__corner--br { bottom: 8px; right: 8px; border-left: 0; border-top: 0; }
[data-design="a"] .ra-carta__list { list-style: none; margin: 0; padding: 0; text-align: left; }
[data-design="a"] .ra-dish { display: grid; grid-template-columns: minmax(0,1fr) auto; align-items: baseline;
  column-gap: var(--s-base); padding: var(--menu-row-pad) 0; border-bottom: 1px dashed var(--linea);
  clip-path: inset(0 100% 0 0); opacity: 1; transform: translateY(8px); }
[data-design="a"] .ra-carta.is-in .ra-dish { animation: a-rotulo-paint-on-clip 520ms var(--ease-pincel) both,
  a-rotulo-asentar 520ms var(--ease-asentar) both; animation-delay: calc(var(--i) * 140ms); }
[data-design="a"] .ra-dish:last-child { border-bottom: 0; }
[data-design="a"] .ra-dish__name { font-family: var(--font-rotulo); font-weight: 700; font-size: var(--t-lg);
  color: var(--tinta); min-width: 0; overflow-wrap: anywhere; }
[data-design="a"] .ra-dish__desc { grid-column: 1 / -1; font-family: var(--font-body); font-size: var(--t-meta);
  color: var(--polvo); line-height: 1.4; margin-top: 2px; }
[data-design="a"] .ra-dish__price { font-family: var(--font-body); font-weight: 600; color: var(--barro);
  font-variant-numeric: tabular-nums; white-space: nowrap; justify-self: end; }
[data-design="a"] .ra-carta__rule { display: block; height: 3px; margin-top: var(--s-base); border-radius: 2px;
  background: linear-gradient(90deg, var(--cempasuchil), var(--barro), var(--cempasuchil));
  background-size: 200% 100%; animation: a-rotulo-shimmer 9s linear infinite; }
[data-design="a"] .ra-carta__steam { position: absolute; top: 12px; right: 26px; width: 10px; height: 26px;
  border-radius: 50%; background: radial-gradient(circle, color-mix(in srgb,#fff 80%,transparent), transparent 70%);
  opacity: 0; animation: a-rotulo-steam 9s var(--ease-mecer) infinite; }
[data-design="a"] .ra-hero__actions { margin-top: var(--s-gap); display: flex; flex-wrap: wrap;
  align-items: center; justify-content: center; gap: var(--s-tight); }
[data-design="a"] .ra-hero__actions .a-chip { font-size: var(--t-meta); padding: 10px var(--s-room); }
@keyframes a-rotulo-asentar { to { transform: translateY(0); } }
@keyframes a-rotulo-shimmer { to { background-position: 200% 0; } }
@keyframes a-rotulo-steam { 0% { opacity: 0; transform: translateY(0) scaleX(1); }
  35% { opacity: 0.55; } 100% { opacity: 0; transform: translateY(-22px) scaleX(1.4); } }
@media (max-width: 380px) { [data-design="a"] .ra-dish__name { font-size: var(--t-body); } }

/* ============ Element 6 — Pointer ============ */
[data-design="a"] .rp-pointer { display: flex; flex-direction: column; align-items: center;
  gap: var(--s-tight); padding: var(--s-room) 0; cursor: pointer; box-sizing: border-box;
  opacity: 1; position: relative; z-index: 1; }
[data-design="a"] .rp-line { position: relative; width: 2px; height: 56px; border-radius: 2px;
  background: linear-gradient(180deg, var(--cobalto), var(--cempasuchil));
  clip-path: inset(0 0 0 0); animation: a-rotulo-draw-down 5s var(--ease-pincel) infinite; }
[data-design="a"] .rp-ember { position: absolute; left: 50%; top: 0; width: 9px; height: 9px;
  margin-left: -4.5px; border-radius: 50%; background: radial-gradient(circle, var(--cempasuchil), transparent 72%);
  filter: drop-shadow(0 0 4px color-mix(in srgb, var(--cempasuchil) 70%, transparent));
  animation: a-rotulo-ember 5s var(--ease-mecer) infinite; }
[data-design="a"] .rp-label { font-family: var(--font-mano); font-size: 22px; color: var(--barro);
  line-height: 1; }
@keyframes a-rotulo-draw-down { 0% { clip-path: inset(0 0 100% 0); } 55%,100% { clip-path: inset(0 0 0 0); } }
@keyframes a-rotulo-ember { 0% { transform: translateY(0); opacity: 0; } 20% { opacity: 1; }
  80% { opacity: 1; } 100% { transform: translateY(47px); opacity: 0; } }

/* ============ Element 5 — Loteria reveal ============ */
[data-design="a"] .ri-special { background: var(--barro); padding: var(--s-sec) var(--s-room);
  text-align: center; box-sizing: border-box; }
[data-design="a"] .ri-special__title { font-family: var(--font-rotulo); font-weight: 700; color: var(--cal);
  font-size: var(--t-head); margin: 0 0 var(--s-gap); }
[data-design="a"] .ri-loteria { display: inline-flex; flex-direction: column; align-items: center;
  gap: var(--s-base); }
[data-design="a"] .ri-card { width: min(280px, 80vw); aspect-ratio: 3 / 4; perspective: 1100px;
  background: none; border: 0; padding: 0; cursor: pointer; border-radius: var(--r-clay); }
[data-design="a"] .ri-card:focus-visible { outline: none; box-shadow: var(--focus-ring); }
[data-design="a"] .ri-card__inner { position: relative; display: block; width: 100%; height: 100%;
  transform-style: preserve-3d; transition: transform var(--dur-settle) var(--ease-voltear); }
[data-design="a"] .ri-card.is-flipped .ri-card__inner { transform: rotateY(180deg); }
[data-design="a"] .ri-card__back, [data-design="a"] .ri-card__face { position: absolute; inset: 0;
  backface-visibility: hidden; -webkit-backface-visibility: hidden; border-radius: var(--r-clay);
  border: 6px solid var(--cobalto); box-shadow: var(--elev-raised); box-sizing: border-box;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--s-snug);
  padding: var(--s-room); }
[data-design="a"] .ri-card__back { background: var(--rosa);
  background-image: radial-gradient(color-mix(in srgb,#fff 22%,transparent) 1.5px, transparent 1.6px);
  background-size: 14px 14px; }
[data-design="a"] .ri-card__deck, [data-design="a"] .ri-card__no { font-family: var(--font-rotulo);
  font-weight: 700; letter-spacing: var(--track-label); color: var(--cal); text-transform: uppercase; }
[data-design="a"] .ri-card__no { font-size: var(--t-meta); }
[data-design="a"] .ri-card__sol { animation: a-rotulo-brasa 5s var(--ease-mecer) infinite; }
[data-design="a"] .ri-card__face { background: var(--cal-2); transform: rotateY(180deg); }
[data-design="a"] .ri-card__day { font-family: var(--font-mano); font-size: 30px; color: var(--barro);
  line-height: 1; }
[data-design="a"] .ri-card__special { font-family: var(--font-rotulo); font-weight: 700;
  font-size: var(--t-title); color: var(--cobalto); text-wrap: balance; }
[data-design="a"] .ri-card__price { font-family: var(--font-body); font-weight: 600; color: var(--barro);
  font-variant-numeric: tabular-nums; }
[data-design="a"] .ri-card__link { font-family: var(--font-body); font-weight: 600; color: var(--cobalto);
  text-decoration: none; border-bottom: 2px solid var(--cempasuchil); }
[data-design="a"] .ri-special__hint { font-family: var(--font-body); color: var(--cal); opacity: 0.92;
  margin: 0; }
[data-design="a"] .ri-card.is-flipped + .ri-special__hint,
[data-design="a"] .ri-loteria:has(.is-flipped) .ri-special__hint { visibility: hidden; }
@keyframes a-rotulo-brasa { 0%,100% { opacity: 0.28; filter: brightness(1); }
  50% { opacity: 0.5; filter: brightness(1.12) saturate(1.08); } }

/* ============ Element 4 — Full menu ============ */
[data-design="a"] .rb-menu { max-width: 1100px; margin: 0 auto; padding: var(--s-sec) var(--s-room);
  box-sizing: border-box; }
[data-design="a"] .rb-frieze { position: relative; height: 26px; overflow: hidden; border-radius: var(--r-sign);
  background-image: repeating-linear-gradient(45deg, var(--cobalto) 0 13px, var(--cal-2) 13px 26px),
    repeating-linear-gradient(-45deg, color-mix(in srgb,var(--cempasuchil) 70%, transparent) 0 13px, transparent 13px 26px);
  background-size: 26px 26px; opacity: 0.9; }
[data-design="a"] .rb-frieze__sheen { position: absolute; inset: 0; transform: translateX(-30%);
  background: linear-gradient(100deg, transparent 40%, color-mix(in srgb,#fff 60%,transparent) 50%, transparent 60%);
  animation: a-rotulo-sheen 14s linear infinite; }
[data-design="a"] .rb-menu__title { font-family: var(--font-rotulo); font-weight: 700; color: var(--cobalto);
  font-size: var(--t-head); text-align: center; margin: var(--s-room) 0 var(--s-band); }
[data-design="a"] .rb-menu__cols { display: grid; grid-template-columns: 1fr; gap: var(--menu-sec-gap); }
[data-design="a"] .rb-sec__head { display: grid; grid-template-columns: 1fr auto; align-items: baseline;
  column-gap: var(--s-base); border-bottom: 2px solid var(--cobalto); padding-bottom: var(--s-tight);
  margin-bottom: var(--s-snug); }
[data-design="a"] .rb-sec__head h3 { font-family: var(--font-rotulo); font-weight: 700; font-size: var(--t-title);
  color: var(--tinta); margin: 0; min-width: 0; overflow-wrap: anywhere; }
[data-design="a"] .rb-sec__no { font-family: var(--font-mono); font-size: var(--t-meta); color: var(--polvo);
  justify-self: end; white-space: nowrap; }
[data-design="a"] .rb-rows { list-style: none; margin: 0; padding: 0; }
[data-design="a"] .rb-row { display: grid; grid-template-columns: minmax(0,auto) 1fr auto; align-items: baseline;
  column-gap: var(--menu-col-gap); padding: var(--menu-row-pad) 0; opacity: 0; transform: translateY(10px); }
[data-design="a"] .rb-menu.is-in .rb-row { animation: a-rotulo-asentar-fade 460ms var(--ease-asentar) both;
  animation-delay: calc(var(--i) * 60ms); }
[data-design="a"] .rb-row__name { font-family: var(--font-body); font-weight: 600; font-size: var(--t-lg);
  color: var(--tinta); min-width: 0; overflow-wrap: anywhere; }
[data-design="a"] .rb-row__lead { align-self: flex-end; transform: translateY(-5px);
  border-bottom: 2px dotted var(--linea-fuerte); }
[data-design="a"] .rb-row__price { font-family: var(--font-body); font-weight: 600; color: var(--barro);
  font-variant-numeric: tabular-nums; white-space: nowrap; justify-self: end; }
@keyframes a-rotulo-sheen { 0% { transform: translateX(-30%); } 60%,100% { transform: translateX(130%); } }
@keyframes a-rotulo-asentar-fade { to { opacity: 1; transform: translateY(0); } }
@media (min-width: 1024px) { [data-design="a"] .rb-menu__cols { grid-template-columns: 1fr 1fr;
  column-gap: var(--s-sec); } }
@media (max-width: 380px) { [data-design="a"] .rb-row__name { font-size: var(--t-body); } }

/* ============ Hours & Location / Order / Gallery / About / Catering / Footer ============ */
[data-design="a"] .a-hoursloc,
[data-design="a"] .a-order,
[data-design="a"] .a-gallery,
[data-design="a"] .a-about,
[data-design="a"] .a-catering { max-width: 1100px; margin-inline: auto; padding: var(--s-sec-m) var(--s-room);
  box-sizing: border-box; }
[data-design="a"] .a-hoursloc__title,
[data-design="a"] .a-order__title,
[data-design="a"] .a-gallery__title,
[data-design="a"] .a-about__title,
[data-design="a"] .a-catering__title { font-family: var(--font-rotulo); font-weight: 700; color: var(--cobalto);
  font-size: var(--t-head); margin: 0 0 var(--s-gap); text-align: center; }
[data-design="a"] .a-hoursloc__grid { display: grid; grid-template-columns: 1fr; gap: var(--s-room); }
@media (min-width: 768px) { [data-design="a"] .a-hoursloc__grid { grid-template-columns: 1fr 1fr; } }
[data-design="a"] .a-azulejo { background: var(--cal-2); border: 1px solid var(--linea); border-radius: var(--r-tile);
  box-shadow: var(--elev-tile); padding: var(--s-room); box-sizing: border-box;
  transition: transform var(--dur-quick) var(--ease-pincel); }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .a-azulejo:hover { transform: translateY(-2px); }
}
[data-design="a"] .a-azulejo__h { font-family: var(--font-rotulo); font-weight: 700; font-size: var(--t-title);
  color: var(--tinta); margin: 0 0 var(--s-tight); }
[data-design="a"] .a-azulejo__body { font-family: var(--font-body); color: var(--tinta-2);
  line-height: var(--lh-body); margin: 0 0 var(--s-snug); }
[data-design="a"] .a-azulejo__meta { font-family: var(--font-body); color: var(--polvo);
  font-size: var(--t-meta); margin: 0 0 var(--s-snug); }
[data-design="a"] .a-order { text-align: center; }
[data-design="a"] .a-order__body { color: var(--tinta-2); max-width: 56ch; margin: 0 auto var(--s-gap); }
[data-design="a"] .a-order__actions,
[data-design="a"] .a-catering__actions { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--s-tight); }
[data-design="a"] .a-gallery__grid { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 640px) { [data-design="a"] .a-gallery__grid { grid-template-columns: 1fr 1fr 1fr; } }
[data-design="a"] .a-gallery__item { margin: 0; padding: 0; overflow: hidden; }
[data-design="a"] .a-gallery__item img { display: block; width: 100%; height: 100%; aspect-ratio: 4/3;
  object-fit: cover; }
[data-design="a"] .a-about { max-width: 62ch; }
[data-design="a"] .a-about__title { text-align: left; }
[data-design="a"] .a-about__body { color: var(--tinta-2); line-height: var(--lh-body); }
[data-design="a"] .a-catering { text-align: center; }
[data-design="a"] .a-catering__body { color: var(--tinta-2); max-width: 56ch; margin: 0 auto var(--s-gap); }

[data-design="a"] .a-footer { background: var(--barro); color: var(--cal); padding: var(--s-sec-m) var(--s-room);
  box-sizing: border-box; position: relative; }
[data-design="a"] .a-footer::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 8px;
  background-image: repeating-linear-gradient(90deg, var(--cobalto) 0 18px, var(--rosa) 18px 36px,
    var(--cempasuchil) 36px 54px, var(--verde) 54px 72px, var(--cal) 72px 90px);
  background-size: 90px 8px; }
[data-design="a"] .a-footer__inner { max-width: 1100px; margin-inline: auto; text-align: center; }
[data-design="a"] .a-footer__hours,
[data-design="a"] .a-footer__addr { margin: 0 0 var(--s-tight); font-family: var(--font-body); }
[data-design="a"] .a-footer__links { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--s-tight);
  margin: var(--s-room) 0; }
[data-design="a"] .a-footer .a-chip--ghost { color: var(--cal); border-color: color-mix(in srgb, var(--cal) 40%, transparent); }
[data-design="a"] .a-footer__copy { font-size: var(--t-meta); opacity: 0.85; margin: 0; }

/* ============ Reduced motion ============ */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .rh-papel__row { animation: none; }
  [data-design="a"] .rh-logo__mark { animation: none; clip-path: inset(0 0 0 0); }
  [data-design="a"] .rh-drawer__panel,
  [data-design="a"] .rh-drawer__scrim { transition: none; }
  [data-design="a"] .ra-dish { clip-path: inset(0 0 0 0); opacity: 1; transform: none; }
  [data-design="a"] .ra-carta.is-in .ra-dish { animation: none; }
  [data-design="a"] .ra-carta__rule { animation: none; }
  [data-design="a"] .ra-carta__steam { animation: none; opacity: 0; }
  [data-design="a"] .rp-line { animation: none; clip-path: inset(0 0 0 0); }
  [data-design="a"] .rp-ember { animation: none; opacity: 0; }
  [data-design="a"] .ri-card__inner { transition: opacity var(--dur-base); transform: none !important;
    transform-style: flat; }
  [data-design="a"] .ri-card__face { transform: none; opacity: 0; transition: opacity var(--dur-base); }
  [data-design="a"] .ri-card.is-flipped .ri-card__back { opacity: 0; }
  [data-design="a"] .ri-card.is-flipped .ri-card__face { opacity: 1; }
  [data-design="a"] .ri-card__sol { animation: none; }
  [data-design="a"] .rb-frieze__sheen { animation: none; opacity: 0; }
  [data-design="a"] .rb-row { opacity: 1; transform: none; }
  [data-design="a"] .rb-menu.is-in .rb-row { animation: none; }
  [data-design="a"] .a-azulejo { transition: none; }
  [data-design="a"] .a-chip { transition: none; }
}

/* ============ Mobile / overflow guard (HARD — appended at bottom) ============ */
[data-design="a"].dq-design,[data-design="a"] .dq-design{max-width:100%;overflow-x:clip;}
[data-design="a"].dq-design *{min-width:0;}
[data-design="a"].dq-design img,[data-design="a"].dq-design svg:not([data-keep-size]){max-width:100%;height:auto;}

/* Phase-3.4 hero visibility floor (forge_assemble) */
[data-design="a"] [data-mf-role="hero"] :is(h1,h2,p,.headline,.subtitle,.proof,[class*="headline"],[class*="subtitle"],[class*="proof"]),
[data-design="a"] [data-mf-role="cta"] { opacity: 1 !important; }
