/* El Patron Pork House — menu styles */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,700;0,900;1,500&family=Oswald:wght@400;500;600;700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --paper: #f2e9d4;
  --paper-2: #eadcbe;
  --paper-deep: #e2d2b0;
  --ink: #16120e;
  --ink-2: #2a231b;
  --ink-soft: #5a4a38;
  --rule: #16120e;
  --blood: #8b1e1e;
  --blood-deep: #6a1414;
  --gold: #b0873b;
  --ok: #2f6b3a;
  --smoke: rgba(22, 18, 14, 0.55);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: #f2e9d4;
  font-family: 'Inter', system-ui, sans-serif;
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  min-height: 100%;
}

@media (max-width: 600px) {
  .item-row { padding-left: 16px !important; padding-right: 16px !important; }
}

.item-row {
  transition: background 0.15s;
}
.item-row:hover {
  background: rgba(22, 18, 14, 0.045);
}
.item-row:active {
  background: rgba(22, 18, 14, 0.09);
}

/* ---------- Paper / vintage textures ---------- */

.paper {
  background:
    radial-gradient(ellipse at 20% 10%, rgba(120, 80, 30, 0.08), transparent 55%),
    radial-gradient(ellipse at 85% 85%, rgba(90, 50, 10, 0.09), transparent 55%),
    radial-gradient(ellipse at 50% 50%, rgba(242, 233, 212, 1), rgba(226, 210, 176, 1));
  position: relative;
}

.paper::before {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.08 0 0 0 0 0.06 0 0 0 0 0.04 0 0 0 0.18 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity: 0.5;
  mix-blend-mode: multiply;
}

.paper::after {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 50% -10%, transparent 55%, rgba(40,25,10,0.22) 100%),
    radial-gradient(ellipse at 50% 110%, transparent 55%, rgba(40,25,10,0.22) 100%);
}

/* ---------- Typography ---------- */

.serif { font-family: 'Playfair Display', serif; }
.cond { font-family: 'Oswald', 'Impact', sans-serif; letter-spacing: 0.04em; }
.mono { font-family: 'JetBrains Mono', monospace; }

.smallcaps {
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-weight: 500;
}

/* ---------- Rules / ornaments ---------- */

.double-rule {
  border-top: 1.5px solid var(--rule);
  border-bottom: 1.5px solid var(--rule);
  padding: 4px 0;
}
.double-rule-thick {
  border-top: 3px solid var(--rule);
  border-bottom: 1.5px solid var(--rule);
}
.thin-rule {
  height: 1px;
  background: var(--rule);
  opacity: 0.55;
}

.ornament {
  display: flex; align-items: center; justify-content: center;
  gap: 10px;
  color: var(--ink);
}
.ornament::before, .ornament::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--rule);
  opacity: 0.55;
}
.ornament svg { flex-shrink: 0; }

/* ---------- Buttons ---------- */

.btn-blood {
  background: var(--blood);
  color: var(--paper);
  border: none;
  padding: 14px 18px;
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.1s, background 0.2s;
  border-radius: 2px;
}
.btn-blood:hover { background: var(--blood-deep); }
.btn-blood:active { transform: translateY(1px); }

.btn-ink {
  background: var(--ink);
  color: var(--paper);
  border: none;
  padding: 12px 16px;
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 500;
  cursor: pointer;
  border-radius: 2px;
}

.btn-ghost {
  background: transparent;
  color: var(--ink);
  border: 1.5px solid var(--ink);
  padding: 10px 14px;
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 500;
  cursor: pointer;
  border-radius: 2px;
}

/* ---------- Dotted price leader ---------- */
.price-leader {
  flex: 1;
  border-bottom: 2px dotted var(--ink);
  opacity: 0.45;
  margin: 0 10px;
  transform: translateY(-5px);
}

/* ---------- Stamp ---------- */
.stamp {
  display: inline-block;
  border: 2px solid var(--blood);
  color: var(--blood);
  padding: 4px 10px;
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 10px;
  font-weight: 700;
  transform: rotate(-4deg);
  background: rgba(139, 30, 30, 0.04);
}

/* ---------- Plate placeholder ---------- */
.plate-ph {
  background: repeating-linear-gradient(
    45deg,
    rgba(22, 18, 14, 0.08),
    rgba(22, 18, 14, 0.08) 6px,
    rgba(22, 18, 14, 0.02) 6px,
    rgba(22, 18, 14, 0.02) 12px
  );
  border: 1.5px solid var(--ink);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.plate-ph .monogram {
  font-family: 'Playfair Display', serif;
  font-weight: 900;
  font-style: italic;
  color: var(--ink);
  opacity: 0.6;
}

/* ---------- Scrollbar in phone ---------- */
.scroll-hide::-webkit-scrollbar { display: none; }
.scroll-hide { scrollbar-width: none; }

/* ---------- Animations ---------- */
@keyframes popIn {
  0% { transform: scale(0.6); opacity: 0; }
  60% { transform: scale(1.1); opacity: 1; }
  100% { transform: scale(1); }
}
.pop-in { animation: popIn 0.28s ease-out; }

@keyframes slideUp {
  from { transform: translateY(100%); }
  to { transform: translateY(0); }
}
.slide-up { animation: slideUp 0.28s cubic-bezier(.2,.9,.3,1); }

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
.fade-in { animation: fadeIn 0.22s ease-out; }

@keyframes smokeRise {
  0% { transform: translateY(0) scale(1); opacity: 0.7; }
  100% { transform: translateY(-40px) scale(1.8); opacity: 0; }
}

/* ---------- Order buttons ---------- */
.order-btn {
  flex: 1;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 10px;
  border-radius: 3px;
  font-family: 'Oswald', sans-serif;
  font-size: 13px; font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  transition: filter 0.15s, transform 0.1s;
  white-space: nowrap;
}
.order-btn:active { transform: translateY(1px); }
.order-btn-wa {
  background: #25D366; color: #fff;
}
.order-btn-wa:hover { filter: brightness(0.92); }
.order-btn-py {
  background: #fff; color: #fa0050;
  border: 2px solid #fa0050;
}
.order-btn-py:hover { background: #fff5f7; }

/* Sticky order bar */
.order-bar-sticky {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 50;
  display: flex; gap: 0;
  box-shadow: 0 -2px 12px rgba(22,18,14,0.18);
}
.order-bar-sticky .order-btn {
  border-radius: 0; flex: 1;
  padding: 14px 10px;
  font-size: 13px;
}
@media (min-width: 600px) {
  .order-bar-sticky { display: none; }
}
@media (max-width: 599px) {
  body { padding-bottom: 56px; }
}

/* ---------- Product modal ---------- */
.modal-overlay {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(22, 18, 14, 0.72);
  display: flex; align-items: flex-end; justify-content: center;
  animation: fadeIn 0.18s ease-out;
}
@media (min-width: 600px) {
  .modal-overlay { align-items: center; }
}
.modal-sheet {
  background: var(--paper);
  width: 100%; max-width: 480px;
  border-radius: 8px 8px 0 0;
  overflow: hidden;
  animation: slideUp 0.26s cubic-bezier(.2,.9,.3,1);
  max-height: 90dvh;
  display: flex; flex-direction: column;
}
@media (min-width: 600px) {
  .modal-sheet { border-radius: 6px; max-height: 85dvh; }
}
.modal-img {
  width: 100%; aspect-ratio: 4/3;
  object-fit: cover; display: block; flex-shrink: 0;
}
.modal-body {
  padding: 20px 22px 28px;
  overflow-y: auto;
}
.modal-close {
  position: absolute; top: 12px; right: 14px;
  background: rgba(22,18,14,0.55); color: #f2e9d4;
  border: none; border-radius: 50%;
  width: 32px; height: 32px;
  font-size: 18px; line-height: 1;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
}

/* ---------- Badge ticks ---------- */
.tick {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: 'Oswald', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 9px;
  font-weight: 600;
  padding: 3px 7px;
  border: 1px solid currentColor;
  border-radius: 2px;
}
