/* site/css/styles.css */
/* Purpose: Komponenty UI Los Arcos "Raíces". NOT for: tokeny (→ tokens.css). */

.wrap { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.label { font-size: var(--text-sm); letter-spacing: var(--tracking-label); text-transform: uppercase; font-weight: 600; color: var(--clay); }
.serif { font-family: var(--font-display); }

/* ---------- Reveal on scroll ---------- */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity var(--dur-slow) var(--ease), transform var(--dur-slow) var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ---------- Nav ---------- */
.nav { position: fixed; top: 30px; left: 0; right: 0; z-index: 50; display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem var(--gutter); transition: background var(--dur) var(--ease), box-shadow var(--dur) var(--ease), padding var(--dur) var(--ease); }
.nav:not(.solid) .nav__logo, .nav:not(.solid) .nav__links a, .nav:not(.solid) .nav__cart { text-shadow: 0 1px 14px rgba(15,14,13,0.55); }
.nav.solid { background: var(--cream); box-shadow: 0 1px 0 var(--line); padding-block: 0.7rem; }
.nav.solid .nav__logo, .nav.solid .nav__links a, .nav.solid .nav__cart { text-shadow: none; }
.nav__logo { font-family: var(--font-display); font-size: 1.7rem; font-weight: 700; letter-spacing: 0.04em; color: var(--text-light); transition: color var(--dur); }
.nav.solid .nav__logo { color: var(--text-dark); }
.nav__logo span { color: var(--clay); }
.nav__links { display: flex; gap: 2rem; align-items: center; }
.nav__links a { font-size: 0.9rem; font-weight: 500; color: var(--text-light); letter-spacing: 0.02em; transition: color var(--dur); position: relative; }
.nav.solid .nav__links a { color: var(--text-dark); }
.nav__links a::after { content: ""; position: absolute; left: 0; bottom: -5px; width: 0; height: 1.5px; background: var(--clay); transition: width var(--dur) var(--ease); }
.nav__links a:hover::after { width: 100%; }
.nav__actions { display: flex; gap: 0.8rem; align-items: center; }
.nav__cart { position: relative; display: inline-flex; align-items: center; gap: 0.4rem; color: var(--text-light); font-weight: 600; font-size: 0.9rem; transition: color var(--dur); }
.nav.solid .nav__cart { color: var(--text-dark); }
.nav__cart-count { min-width: 20px; height: 20px; padding: 0 5px; border-radius: 999px; background: var(--clay); color: #fff; font-size: 0.7rem;
  display: grid; place-items: center; font-weight: 700; transform: scale(0); transition: transform var(--dur) var(--ease); }
.nav__cart-count.show { transform: scale(1); }
.nav__toggle { display: none; }

.btn { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.85rem 1.6rem; border-radius: 999px; font-weight: 600; font-size: 0.92rem;
  letter-spacing: 0.01em; transition: transform var(--dur) var(--ease), background var(--dur), color var(--dur), box-shadow var(--dur); }
.btn--clay { background: var(--clay); color: #fff; box-shadow: var(--shadow-soft); }
.btn--clay:hover { background: var(--clay-deep); transform: translateY(-2px); }
.btn--ghost { border: 1.5px solid currentColor; color: var(--text-light); }
.btn--ghost:hover { background: var(--text-light); color: var(--ink); transform: translateY(-2px); }
.btn--block { width: 100%; justify-content: center; }
.btn--lg { padding: 1.05rem 2.1rem; font-size: 1rem; }

/* ---------- Hero ---------- */
.hero { position: relative; min-height: 100svh; display: grid; align-items: center; color: var(--text-light); overflow: hidden; }
.hero__bg { position: absolute; inset: -8% 0 0 0; height: 116%; background-size: cover; background-position: center; will-change: transform; z-index: -2; }
.hero::after { content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(15,14,13,0.45) 0%, rgba(15,14,13,0.35) 45%, rgba(15,14,13,0.78) 100%); }
.hero__inner { padding-top: 6rem; max-width: 920px; }
.hero__badges { display: flex; gap: 1rem; align-items: center; margin-bottom: 1.6rem; flex-wrap: wrap; }
.badge { display: inline-flex; align-items: center; gap: 0.45rem; padding: 0.4rem 0.9rem; border-radius: 999px;
  border: 1px solid var(--line-light); background: rgba(255,255,255,0.06); font-size: 0.8rem; letter-spacing: 0.04em; backdrop-filter: blur(6px); }
.badge .stars { color: #F4C257; letter-spacing: 0.05em; }
.hero h1 { font-family: var(--font-display); font-size: var(--text-hero); line-height: 0.96; font-weight: 600; letter-spacing: -0.01em; }
.hero h1 em { font-style: italic; color: #E9C9A0; }
.hero__lead { font-size: var(--text-lead); max-width: 560px; margin: 1.5rem 0 2.2rem; color: rgba(246,240,228,0.86); }
.hero__cta { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero__scroll { position: absolute; bottom: 1.8rem; left: 50%; transform: translateX(-50%); font-size: 0.72rem; letter-spacing: 0.3em;
  text-transform: uppercase; opacity: 0.7; animation: bob 2.4s var(--ease) infinite; }
@keyframes bob { 0%,100% { transform: translate(-50%,0);} 50% { transform: translate(-50%,8px);} }

/* ---------- Section heading ---------- */
.section { padding-block: var(--space-section); }
.section--ink { background: var(--ink); color: var(--text-light); }
.shead { max-width: 640px; margin-bottom: 3rem; }
.shead.center { margin-inline: auto; text-align: center; }
.shead h2 { font-family: var(--font-display); font-size: var(--text-h2); line-height: 1.04; font-weight: 600; margin-top: 0.7rem; letter-spacing: -0.01em; }
.shead p { margin-top: 1rem; color: var(--muted); font-size: var(--text-lead); }
.section--ink .shead p { color: rgba(246,240,228,0.7); }

/* ---------- Story ---------- */
.story { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(2rem,4vw,5rem); align-items: center; }
.story__media { position: relative; border-radius: var(--radius); overflow: hidden; aspect-ratio: 4/5; box-shadow: var(--shadow); }
.story__media img { width: 100%; height: 100%; object-fit: cover; }
.story__media .tag { position: absolute; left: 1.2rem; bottom: 1.2rem; background: var(--cream); color: var(--text-dark);
  padding: 0.6rem 1.1rem; border-radius: 999px; font-weight: 700; font-size: 0.85rem; }
.story__body h2 { font-family: var(--font-display); font-size: var(--text-h2); line-height: 1.05; font-weight: 600; margin: 0.6rem 0 1.2rem; }
.story__body p { color: var(--muted); margin-bottom: 1rem; font-size: 1.05rem; }
.story__stats { display: flex; gap: 2.4rem; margin-top: 2rem; }
.story__stats b { font-family: var(--font-display); font-size: 2.6rem; color: var(--clay); display: block; line-height: 1; }
.story__stats span { font-size: 0.82rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); }

/* ---------- Menu ---------- */
.menu__tabs { display: flex; gap: 0.5rem; overflow-x: auto; padding-bottom: 0.6rem; margin-bottom: 2.4rem;
  scrollbar-width: none; -webkit-overflow-scrolling: touch; }
.menu__tabs::-webkit-scrollbar { display: none; }
.menu__tab { white-space: nowrap; padding: 0.55rem 1.1rem; border-radius: 999px; font-size: 0.86rem; font-weight: 600; color: var(--muted);
  border: 1px solid var(--line); transition: all var(--dur) var(--ease); }
.menu__tab.active { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.menu__note { color: var(--muted); font-style: italic; margin-bottom: 1.6rem; font-size: 0.95rem; }
.menu__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px,1fr)); gap: 0.6rem 2.4rem; }
.dish { display: flex; justify-content: space-between; gap: 1rem; padding: 1.1rem 0; border-bottom: 1px solid var(--line);
  align-items: baseline; transition: background var(--dur); }
.dish__info h4 { font-size: 1.06rem; font-weight: 600; display: flex; align-items: center; gap: 0.5rem; }
.dish__info p { font-size: 0.88rem; color: var(--muted); margin-top: 0.2rem; }
.dish__right { display: flex; align-items: center; gap: 0.9rem; flex-shrink: 0; }
.dish__price { font-family: var(--font-display); font-size: 1.3rem; font-weight: 600; color: var(--clay); }
.dish__add { width: 34px; height: 34px; border-radius: 50%; background: var(--cream-deep); color: var(--ink); font-size: 1.3rem; line-height: 1;
  display: grid; place-items: center; transition: all var(--dur) var(--ease); flex-shrink: 0; }
.dish__add:hover { background: var(--clay); color: #fff; transform: scale(1.1) rotate(90deg); }

/* ---------- Signature / catering ---------- */
.sig { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 1.2rem; }
.sig__card { position: relative; border-radius: var(--radius); overflow: hidden; aspect-ratio: 3/4; color: #fff; display: flex; align-items: flex-end; }
.sig__card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease); }
.sig__card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 30%, rgba(15,14,13,0.85)); }
.sig__card:hover img { transform: scale(1.06); }
.sig__card .sig__c { position: relative; padding: 1.3rem; }
.sig__card h4 { font-family: var(--font-display); font-size: 1.35rem; font-weight: 600; }
.sig__card span { font-size: 0.85rem; color: #E9C9A0; }

/* ---------- Reviews ticker ---------- */
.ticker { overflow: hidden; mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.ticker__row { display: flex; gap: 1.4rem; width: max-content; animation: scrollx 38s linear infinite; }
.ticker:hover .ticker__row { animation-play-state: paused; }
@keyframes scrollx { to { transform: translateX(-50%); } }
.quote { width: 360px; flex-shrink: 0; padding: 1.6rem; border: 1px solid var(--line-light); border-radius: var(--radius); background: rgba(246,240,228,0.03); }
.quote p { font-family: var(--font-display); font-size: 1.25rem; line-height: 1.4; font-style: italic; }
.quote span { display: block; margin-top: 0.9rem; font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--amber); }

/* ---------- Location ---------- */
.loc { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,4vw,4rem); align-items: stretch; }
.loc__map { border-radius: var(--radius); overflow: hidden; min-height: 360px; box-shadow: var(--shadow); }
.loc__map iframe { width: 100%; height: 100%; border: 0; min-height: 360px; }
.loc__info h2 { font-family: var(--font-display); font-size: var(--text-h2); font-weight: 600; margin-bottom: 1.4rem; }
.loc__line { display: flex; gap: 0.8rem; padding: 0.9rem 0; border-bottom: 1px solid var(--line); }
.loc__line b { min-width: 90px; font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--clay); padding-top: 0.2rem; }
.hours { display: grid; gap: 0.2rem; }
.hours div { display: flex; justify-content: space-between; max-width: 280px; font-size: 0.95rem; }
.hours .today { color: var(--clay); font-weight: 700; }

/* ---------- Footer ---------- */
.foot { background: var(--ink); color: rgba(246,240,228,0.6); padding-block: 3.4rem 2rem; }
.foot__top { display: flex; justify-content: space-between; gap: 2rem; flex-wrap: wrap; align-items: flex-start; padding-bottom: 2.4rem; border-bottom: 1px solid var(--line-light); }
.foot__logo { font-family: var(--font-display); font-size: 2rem; color: var(--cream); }
.foot__logo span { color: var(--clay); }
.foot__cols { display: flex; gap: 3.5rem; flex-wrap: wrap; }
.foot__col h5 { font-size: 0.78rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--amber); margin-bottom: 0.8rem; }
.foot__col a, .foot__col p { display: block; font-size: 0.92rem; margin-bottom: 0.4rem; color: rgba(246,240,228,0.7); }
.foot__col a:hover { color: var(--cream); }
.foot__bottom { padding-top: 1.6rem; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; font-size: 0.8rem; }
.foot__bottom a { color: var(--clay); font-weight: 600; }

/* ---------- Cart drawer ---------- */
.scrim { position: fixed; inset: 0; background: rgba(15,14,13,0.5); opacity: 0; visibility: hidden; transition: opacity var(--dur); z-index: 60; backdrop-filter: blur(2px); }
.scrim.open { opacity: 1; visibility: visible; }
.drawer { position: fixed; top: 0; right: 0; height: 100%; width: min(420px, 92vw); background: var(--cream); z-index: 70;
  transform: translateX(100%); transition: transform var(--dur-slow) var(--ease); display: flex; flex-direction: column; box-shadow: var(--shadow); }
.drawer.open { transform: none; }
.drawer__head { display: flex; justify-content: space-between; align-items: center; padding: 1.4rem 1.6rem; border-bottom: 1px solid var(--line); }
.drawer__head h3 { font-family: var(--font-display); font-size: 1.6rem; }
.drawer__close { font-size: 1.5rem; width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; transition: background var(--dur); }
.drawer__close:hover { background: var(--cream-deep); }
.drawer__items { flex: 1; overflow-y: auto; padding: 0.6rem 1.6rem; }
.drawer__empty { text-align: center; color: var(--muted); padding: 3rem 1rem; }
.cart-item { display: flex; gap: 0.9rem; padding: 1rem 0; border-bottom: 1px solid var(--line); }
.cart-item__main { flex: 1; }
.cart-item__main h4 { font-size: 0.98rem; font-weight: 600; }
.cart-item__main .p { color: var(--clay); font-weight: 600; font-size: 0.9rem; margin-top: 0.2rem; }
.qty { display: inline-flex; align-items: center; gap: 0.7rem; margin-top: 0.5rem; }
.qty button { width: 26px; height: 26px; border-radius: 50%; border: 1px solid var(--line); display: grid; place-items: center; font-size: 1rem; transition: all var(--dur); }
.qty button:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.cart-item__rm { font-size: 0.75rem; color: var(--muted); text-decoration: underline; align-self: flex-start; }
.drawer__foot { padding: 1.4rem 1.6rem; border-top: 1px solid var(--line); background: var(--cream-deep); }
.drawer__row { display: flex; justify-content: space-between; margin-bottom: 0.5rem; font-size: 0.95rem; }
.drawer__row.total { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; color: var(--ink); margin: 0.8rem 0 1.2rem; }

/* ---------- Checkout modal ---------- */
.modal { position: fixed; inset: 0; z-index: 80; display: grid; place-items: center; padding: 1.2rem; opacity: 0; visibility: hidden; transition: opacity var(--dur); }
.modal.open { opacity: 1; visibility: visible; }
.modal__card { background: var(--cream); border-radius: var(--radius); width: min(560px, 96vw); max-height: 92vh; overflow-y: auto; box-shadow: var(--shadow);
  transform: translateY(20px) scale(0.98); transition: transform var(--dur-slow) var(--ease); }
.modal.open .modal__card { transform: none; }
.modal__head { padding: 1.6rem; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; }
.modal__head h3 { font-family: var(--font-display); font-size: 1.8rem; }
.modal__body { padding: 1.6rem; }
.field { margin-bottom: 1.1rem; }
.field label { display: block; font-size: 0.78rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); margin-bottom: 0.4rem; font-weight: 600; }
.field input, .field select { width: 100%; padding: 0.8rem 1rem; border: 1px solid var(--line); border-radius: 10px; font-family: inherit; font-size: 0.95rem; background: #fff; }
.field input:focus, .field select:focus { outline: 2px solid var(--clay); border-color: transparent; }
.seg { display: flex; gap: 0.5rem; }
.seg label { flex: 1; cursor: pointer; }
.seg input { position: absolute; opacity: 0; }
.seg span { display: block; text-align: center; padding: 0.8rem; border: 1px solid var(--line); border-radius: 10px; font-weight: 600; font-size: 0.9rem; transition: all var(--dur); }
.seg input:checked + span { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.ok { text-align: center; padding: 2.4rem 1.6rem; }
.ok__check { width: 68px; height: 68px; border-radius: 50%; background: var(--clay); color: #fff; font-size: 2rem; display: grid; place-items: center; margin: 0 auto 1.2rem; }
.ok h3 { font-family: var(--font-display); font-size: 1.9rem; margin-bottom: 0.6rem; }
.ok p { color: var(--muted); }

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
  .nav__links { display: none; }
  .story, .loc { grid-template-columns: 1fr; }
  .story__media { aspect-ratio: 16/11; }
  .hero__inner { padding-top: 5rem; }
}
.demo-banner { position: fixed; top: 0; left: 0; right: 0; z-index: 56; height: 30px; display: flex; align-items: center; justify-content: center;
  background: var(--amber); color: #fff; text-align: center; font-size: 0.72rem; letter-spacing: 0.03em; padding: 0 0.8rem; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
