/* === RESET & BASE === */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 80px;
}

body {
  font-family: var(--font-sans);
  background: var(--bg-primary);
  color: var(--text-primary);
  overflow-x: hidden;
  transition: background-color 0.3s, color 0.3s;
}

img { max-width: 100%; height: auto; }
a { color: inherit; }

/* === FONT UTILITY CLASSES === */
.serif-font { font-family: var(--font-serif); }

/* === SECTION DIVIDER === */
.section-divider {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin: 0 auto;
  max-width: 300px;
}
.section-divider::before,
.section-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--text-secondary), transparent);
}

/* === BUTTONS === */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 14px 32px;
  background: var(--brown);
  color: var(--cream);
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  text-decoration: none;
}
.btn-primary:hover {
  background: var(--terracotta);
  color: var(--cream);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(196, 107, 74, 0.25);
}
.btn-primary:active {
  transform: scale(0.97);
}

.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 13px 30px;
  background: transparent;
  color: var(--cream);
  border: 1.5px solid rgba(250, 245, 238, 0.4);
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  text-decoration: none;
}
.btn-outline:hover {
  border-color: var(--cream);
  color: var(--cream);
  background: rgba(250, 245, 238, 0.12);
}
.btn-outline:active {
  transform: scale(0.97);
}

.btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 12px 28px;
  background: var(--terracotta);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s;
  text-decoration: none;
}
.btn-secondary:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}
.btn-secondary:active {
  transform: scale(0.97);
}

/* === ANIMATIONS === */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

/* === SCROLL REVEAL === */
.scroll-reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: all 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.scroll-reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}
.scroll-reveal[data-reveal="left"] {
  transform: translateX(-40px);
}
.scroll-reveal[data-reveal="right"] {
  transform: translateX(40px);
}
.scroll-reveal[data-reveal="left"].revealed,
.scroll-reveal[data-reveal="right"].revealed {
  transform: translateX(0);
}
.scroll-reveal[data-delay="1"] { transition-delay: 0.1s; }
.scroll-reveal[data-delay="2"] { transition-delay: 0.2s; }
.scroll-reveal[data-delay="3"] { transition-delay: 0.3s; }
.scroll-reveal[data-delay="4"] { transition-delay: 0.4s; }
.scroll-reveal[data-delay="5"] { transition-delay: 0.5s; }
.scroll-reveal[data-delay="6"] { transition-delay: 0.6s; }

/* === SCROLLBAR === */
.menu-scroll::-webkit-scrollbar { height: 8px; }
.menu-scroll::-webkit-scrollbar-thumb { background: var(--brown); border-radius: 10px; }
.menu-scroll::-webkit-scrollbar-track { background: var(--border-subtle); border-radius: 10px; }
.menu-scroll { scrollbar-width: auto; scrollbar-color: var(--brown) var(--border-subtle); }

/* === INPUTS === */
.input-field {
  padding: 14px 20px;
  border: 1.5px solid var(--border-medium);
  border-radius: var(--radius-md);
  background: var(--bg-card);
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--text-primary);
  outline: none;
  transition: border-color 0.3s, background 0.3s;
  width: 100%;
}
.input-field:focus { border-color: var(--terracotta); }
.input-field::placeholder { color: var(--text-secondary); opacity: 0.6; }

/* === TAG BADGES === */
.tag-signature { background: linear-gradient(135deg, #b8860b22, #b8860b11); color: var(--gold); }
.tag-special { background: linear-gradient(135deg, #c46b4a22, #c46b4a11); color: var(--terracotta); }
.tag-new { background: linear-gradient(135deg, #7a8b6f22, #7a8b6f11); color: var(--sage); }
.tag-healthy { background: linear-gradient(135deg, #7a8b6f22, #7a8b6f11); color: var(--sage); }
.tag-recommended { background: linear-gradient(135deg, #c46b4a22, #c46b4a11); color: var(--terracotta); }

/* === GRAIN TEXTURE === */
.grain-overlay {
  position: absolute;
  inset: 0;
  opacity: 0.06;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-size: 200px;
  pointer-events: none;
}

[data-theme="dark"] .grain-overlay {
  opacity: 0.03;
}

/* === SECTION PADDING === */
.section-padding {
  padding: clamp(80px, 12vw, 140px) clamp(20px, 5vw, 80px);
}

.container {
  max-width: 1200px;
  margin: 0 auto;
}

/* === SECTION LABEL === */
.section-label {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 15px;
  color: var(--terracotta);
  letter-spacing: 1px;
}

/* === CARD HOVER === */
.card-hover {
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.3s;
}
.card-hover:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-card-hover);
}

/* === RESPONSIVE === */
@media (max-width: 768px) {
  .hide-mobile { display: none !important; }
}
@media (min-width: 769px) {
  .hide-desktop { display: none !important; }
}
