/* =========================================================================
   Punjabi Zaika — base theme + bespoke components.
   Tailwind CDN loads first; this file extends with restaurant-specific
   styles, liquid keyframes and form chrome.
   ========================================================================= */

:root {
  --maroon: #7a0e1f;
  --ember:  #c0392b;
  --saffron:#f59e0b;
  --gold:   #d4af37;
  --cream:  #fff8ec;
  --chai:   #3a1f12;
  --haldi:  #e8a317;
  --mint:   #0f7a5a;
}

html { scroll-behavior: smooth; }
html, body, #root { height: 100%; }

body {
  font-family: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
  background-color: var(--cream);
  color: var(--chai);
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(245,158,11,0.18), transparent 60%),
    radial-gradient(900px 500px at -10% 30%, rgba(122,14,31,0.10), transparent 60%);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection { background: var(--ember); color: var(--cream); }

/* ------------------------------------------------------------------ Layout */
.container-z {
  margin-inline: auto;
  width: 100%;
  max-width: 80rem;
  padding-inline: 1.25rem;
}
@media (min-width: 640px) { .container-z { padding-inline: 2rem; } }

/* ----------------------------------------------------------------- Display */
.heading-display {
  font-family: "Cormorant Garamond", Georgia, serif;
  letter-spacing: -0.01em;
  font-feature-settings: "ss01","liga";
}
.font-deva { font-family: "Tiro Devanagari Hindi", serif; }

/* ------------------------------------------------------------------ Pieces */
.pill {
  display: inline-flex; align-items: center; gap: 0.5rem;
  border-radius: 9999px;
  border: 1px solid rgba(122,14,31,0.18);
  background: rgba(255,255,255,0.6);
  padding: 0.25rem 0.75rem;
  font-size: 0.75rem; font-weight: 500;
  color: var(--maroon);
  backdrop-filter: blur(8px);
}

.btn-primary {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  border-radius: 9999px;
  background: var(--maroon);
  color: var(--cream);
  padding: 0.85rem 1.5rem;
  font-size: 0.85rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
  box-shadow: 0 18px 40px -12px rgba(122,14,31,0.6);
  transition: transform 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
}
.btn-primary:hover { background: var(--ember); }

.btn-ghost {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  border-radius: 9999px;
  border: 1px solid rgba(58,31,18,0.2);
  padding: 0.85rem 1.5rem;
  font-size: 0.85rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--chai);
  transition: background 0.25s ease, color 0.25s ease, transform 0.25s ease;
}
.btn-ghost:hover { background: var(--chai); color: var(--cream); }

.card-warm {
  border-radius: 1.5rem;
  border: 1px solid rgba(122,14,31,0.1);
  background: rgba(255,255,255,0.7);
  padding: 1.5rem;
  box-shadow: 0 30px 60px -30px rgba(58,31,18,0.25);
  backdrop-filter: blur(8px);
}

.divider-spice {
  display: inline-flex; align-items: center; gap: 0.75rem;
  color: var(--maroon);
}
.divider-spice::before,
.divider-spice::after {
  content: "";
  display: block;
  width: 3rem; height: 1px;
  background: linear-gradient(to right, transparent, rgba(122,14,31,0.6), transparent);
}

/* --------------------------------------------------------------- Goo / SVG */
.goo-wrap { filter: url(#zaika-goo); }

/* --------------------------------------------------------- Liquid blobs    */
.liquid-blob {
  position: absolute;
  top: var(--top, 0);
  left: var(--left, 0);
  width: var(--size, 320px);
  height: var(--size, 320px);
  border-radius: 50%;
  background: var(--bg, #f59e0b);
  will-change: transform;
  animation: blob-drift 16s ease-in-out infinite;
  animation-delay: var(--delay, 0s);
  --tx: var(--dx, 60px);
  --ty: var(--dy, 50px);
}
@keyframes blob-drift {
  0%,100% { transform: translate(0,0) scale(0.92) rotate(0deg); }
  25%     { transform: translate(var(--tx), var(--ty)) scale(1.08) rotate(8deg); }
  50%     { transform: translate(calc(var(--tx) * -0.6), calc(var(--ty) * 0.4)) scale(0.96) rotate(-6deg); }
  75%     { transform: translate(calc(var(--tx) * 0.4), calc(var(--ty) * -0.7)) scale(1.04) rotate(4deg); }
}

/* --------------------------------------------------------- Hero flourishes */
.hero-plate {
  animation: plate-float 8s ease-in-out infinite;
}
@keyframes plate-float {
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-12px); }
}

.float-chip {
  position: absolute;
  top: var(--top); left: var(--left);
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(122,14,31,0.15);
  border-radius: 9999px;
  padding: 0.5rem 0.9rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--maroon);
  white-space: nowrap;
  box-shadow: 0 18px 40px -18px rgba(58,31,18,0.3);
  animation: chip-bob 6s ease-in-out infinite;
  animation-delay: var(--delay, 0s);
  z-index: 5;
}
@keyframes chip-bob {
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-10px); }
}

.grain { position: relative; }
.grain::after {
  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='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode: multiply;
  opacity: 0.55;
}

/* ------------------------------------------------------------------ Marquee */
@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.marquee-track {
  animation: marquee 40s linear infinite;
  width: max-content;
}

/* ------------------------------------------------------------------ Spin   */
.spin-slow { animation: spin 22s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ----------------------------------------------------------------- Reveal  */
.js-fade { opacity: 0; transform: translateY(24px); transition: none; }
.js-fade.is-in {
  opacity: 1; transform: none;
  transition: opacity 0.9s cubic-bezier(0.22,1,0.36,1),
              transform 0.9s cubic-bezier(0.22,1,0.36,1);
}

/* ---------------------------------------------------------------- Navlinks */
.nav-link::after {
  content: "";
  position: absolute;
  left: 1rem; right: 1rem; bottom: 0.4rem;
  height: 2px;
  background: var(--maroon);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s cubic-bezier(0.22,1,0.36,1);
  border-radius: 1px;
}
.nav-link:hover::after { transform: scaleX(1); }

/* ----------------------------------------------------------------- Menu UI */
.menu-tab {
  border-color: rgba(122,14,31,0.18);
  color: var(--chai);
  background: rgba(255,255,255,0.6);
}
.menu-tab:hover { color: var(--maroon); }
.menu-tab.is-active {
  background: var(--maroon);
  color: var(--cream);
  border-color: var(--maroon);
  box-shadow: 0 12px 30px -12px rgba(122,14,31,0.55);
}

.menu-row {
  animation: menu-row-in 0.7s both;
  animation-delay: calc(var(--i, 0) * 60ms);
}
@keyframes menu-row-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: none; }
}
.menu-row:hover {
  background: rgba(255,255,255,0.6);
  border-radius: 1rem;
  padding-inline: 1rem;
}

/* ---------------------------------------------------------------- Contact  */
.contact-row {
  display: flex; align-items: center; gap: 1rem;
  padding: 1rem 1.25rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(122,14,31,0.12);
  background: rgba(255,255,255,0.65);
  backdrop-filter: blur(8px);
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}
.contact-row:hover {
  transform: translateX(4px);
  box-shadow: 0 18px 40px -18px rgba(58,31,18,0.25);
  background: rgba(255,255,255,0.85);
}
.contact-icon {
  flex: none;
  display: inline-flex; align-items: center; justify-content: center;
  height: 2.5rem; width: 2.5rem;
  border-radius: 9999px;
  background: linear-gradient(135deg, rgba(245,158,11,0.18), rgba(192,57,43,0.12));
  color: var(--maroon);
}

/* ---------------------------------------------------------------- Form     */
.field { display: block; }
.field > span {
  display: block;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(58,31,18,0.55);
  margin-bottom: 0.4rem;
}
.field input,
.field select,
.field textarea {
  width: 100%;
  border: 1px solid rgba(122,14,31,0.15);
  background: rgba(255,255,255,0.85);
  border-radius: 0.85rem;
  padding: 0.85rem 1rem;
  font-size: 0.95rem;
  color: var(--chai);
  transition: border-color 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}
.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: none;
  border-color: var(--maroon);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(122,14,31,0.08);
}

/* ---------------------------------------------------------------- Navbar   */
#navbar.is-scrolled {
  background-color: rgba(255,248,236,0.86);
  backdrop-filter: blur(20px);
  box-shadow: 0 10px 30px -20px rgba(58,31,18,0.4);
}

/* ---------------------------------------------------------------- Drawer   */
#drawer.is-open { display: block; }
#drawer.is-open #drawerPanel { transform: translateX(0); }

/* -------------------------------------------------------------- Sig hover  */
.signature-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 40px 80px -30px rgba(58,31,18,0.3);
}

/* -------------------------------------------------------------- Reduce mo  */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .js-fade { opacity: 1; transform: none; }
}
