/* ==========================================================
   THE TIKI HOUSE — CUSTOM ISLAND ANIMATION LAYER
   Safe shared animation file for all public pages.
   ========================================================== */

:root {
  --tiki-gold: #ffd27a;
  --tiki-orange: #ffb347;
  --tiki-coral: #ff7f5f;
  --tiki-aqua: #1ce0bf;
  --tiki-green-dark: #0b3d2e;
  --tiki-green-mid: #145c43;
  --tiki-shadow: rgba(0, 0, 0, 0.34);
}

html {
  scroll-behavior: smooth;
}

body {
  position: relative;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
  background:
    radial-gradient(circle at 14% 18%, rgba(255, 179, 71, 0.16), transparent 28%),
    radial-gradient(circle at 86% 12%, rgba(28, 224, 191, 0.13), transparent 24%),
    radial-gradient(circle at 50% 96%, rgba(255, 127, 95, 0.13), transparent 32%);
  animation: tikiAmbientGlow 13s ease-in-out infinite alternate;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  opacity: 0.18;
  background-image:
    linear-gradient(120deg, transparent 0 45%, rgba(255, 210, 122, 0.18) 50%, transparent 55% 100%),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.045) 0 1px, transparent 1px 78px);
  background-size: 300% 300%, 120px 120px;
  animation: tikiLightSweep 22s linear infinite;
}

.navbar {
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.18);
  backdrop-filter: blur(10px);
}

.logo,
.nav-links a,
.map-btn,
.cta,
button {
  transition: transform 220ms ease, box-shadow 220ms ease, background 220ms ease, filter 220ms ease;
}

.logo:hover {
  transform: translateY(-1px) rotate(-1deg);
}

.nav-links a:hover,
.nav-links a:focus-visible {
  transform: translateY(-2px);
}

.menu-toggle span {
  transform-origin: center;
  transition: transform 220ms ease, opacity 220ms ease;
}

.menu-toggle.active span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.menu-toggle.active span:nth-child(2) {
  opacity: 0;
}

.menu-toggle.active span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.hero,
.page-hero {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.hero::before,
.page-hero::before {
  content: "";
  position: absolute;
  inset: -20%;
  z-index: -2;
  pointer-events: none;
  background:
    radial-gradient(circle at 15% 20%, rgba(255, 210, 122, 0.26), transparent 20%),
    radial-gradient(circle at 78% 28%, rgba(28, 224, 191, 0.18), transparent 22%),
    radial-gradient(circle at 52% 82%, rgba(255, 127, 95, 0.16), transparent 26%);
  filter: blur(2px);
  animation: tikiHeroGlow 10s ease-in-out infinite alternate;
}

.hero::after,
.page-hero::after {
  content: "";
  position: absolute;
  left: -10%;
  right: -10%;
  bottom: -75px;
  height: 160px;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(90px 48px at 8% 65%, rgba(255, 210, 122, 0.26), transparent 70%),
    radial-gradient(120px 58px at 28% 72%, rgba(255, 179, 71, 0.18), transparent 70%),
    radial-gradient(130px 60px at 52% 68%, rgba(28, 224, 191, 0.13), transparent 70%),
    radial-gradient(120px 56px at 78% 70%, rgba(255, 127, 95, 0.15), transparent 70%),
    radial-gradient(90px 48px at 96% 65%, rgba(255, 210, 122, 0.22), transparent 70%);
  opacity: 0.9;
  animation: tikiLanternBreathe 4.8s ease-in-out infinite alternate;
}

.hero h1,
.hero h2,
.page-hero h1,
.page-hero h2 {
  text-shadow: 0 5px 18px rgba(0, 0, 0, 0.3);
  animation: tikiHeadlineFloat 5.8s ease-in-out infinite;
}

.hero p,
.page-hero p {
  animation: tikiFadeUp 700ms ease both;
}

.cta,
button,
.map-btn {
  position: relative;
  overflow: hidden;
}

.cta::after,
button::after,
.map-btn::after {
  content: "";
  position: absolute;
  top: -80%;
  left: -35%;
  width: 34%;
  height: 260%;
  transform: rotate(22deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.45), transparent);
  opacity: 0;
}

.cta:hover::after,
button:hover::after,
.map-btn:hover::after {
  animation: tikiButtonShine 760ms ease;
}

.cta:hover,
button:hover,
.map-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.22);
}

.content-card,
.home-box,
.menu-card,
.form-card,
.admin-card,
.vibe-card,
.contact-card,
.event-card,
.reservation-card,
.career-card,
section[class*="card"],
article[class*="card"] {
  transform-style: preserve-3d;
  transition: transform 280ms ease, box-shadow 280ms ease, border-color 280ms ease, filter 280ms ease;
}

.content-card:hover,
.home-box:hover,
.menu-card:hover,
.form-card:hover,
.admin-card:hover,
.vibe-card:hover,
.contact-card:hover,
.event-card:hover,
.reservation-card:hover,
.career-card:hover,
section[class*="card"]:hover,
article[class*="card"]:hover {
  transform: translateY(-6px);
  box-shadow: 0 22px 48px rgba(0, 0, 0, 0.28);
  border-color: rgba(255, 210, 122, 0.42);
}

.menu-card,
.home-box,
.content-card,
.vibe-card {
  position: relative;
  overflow: hidden;
}

.menu-card::before,
.home-box::before,
.content-card::before,
.vibe-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  background:
    radial-gradient(circle at var(--tiki-x, 20%) var(--tiki-y, 20%), rgba(255, 210, 122, 0.18), transparent 24%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.06), transparent 42%);
  transition: opacity 220ms ease;
}

.menu-card:hover::before,
.home-box:hover::before,
.content-card:hover::before,
.vibe-card:hover::before {
  opacity: 1;
}

.vibe-card img {
  transition: transform 900ms ease, filter 900ms ease;
}

.vibe-card:hover img {
  transform: scale(1.045) rotate(0.35deg);
  filter: saturate(1.12) contrast(1.04);
}

.tiki-reveal {
  opacity: 0;
  transform: translateY(28px) scale(0.985);
  filter: blur(5px);
  transition:
    opacity 700ms ease,
    transform 700ms cubic-bezier(.2,.8,.2,1),
    filter 700ms ease;
  transition-delay: var(--tiki-delay, 0ms);
}

.tiki-reveal.is-visible,
.vibe-intro.is-visible,
.vibe-card.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}

.vibe-intro,
.vibe-card {
  opacity: 0;
  transform: translateY(28px) scale(0.985);
  filter: blur(5px);
  transition:
    opacity 750ms ease,
    transform 750ms cubic-bezier(.2,.8,.2,1),
    filter 750ms ease;
}

.tiki-ambient-layer {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 12;
}

.tiki-leaf,
.tiki-spark,
.tiki-bubble {
  position: absolute;
  pointer-events: none;
  will-change: transform, opacity;
}

.tiki-leaf {
  top: -80px;
  width: var(--size, 34px);
  height: calc(var(--size, 34px) * 1.7);
  left: var(--left, 50%);
  border-radius: 100% 0 100% 0;
  background:
    linear-gradient(135deg, rgba(28, 224, 191, 0.86), rgba(16, 118, 82, 0.72));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.18), 0 10px 30px rgba(0,0,0,0.12);
  opacity: 0;
  transform: rotate(var(--rotate, 12deg));
  animation: tikiLeafDrift var(--duration, 16s) linear infinite;
  animation-delay: var(--delay, 0s);
}

.tiki-leaf::after {
  content: "";
  position: absolute;
  inset: 12% 47%;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.28);
  transform: rotate(-12deg);
}

.tiki-spark {
  width: var(--size, 7px);
  height: var(--size, 7px);
  left: var(--left, 50%);
  top: var(--top, 50%);
  border-radius: 50%;
  background: rgba(255, 210, 122, 0.85);
  box-shadow: 0 0 20px rgba(255, 179, 71, 0.9);
  opacity: 0;
  animation: tikiSparkle var(--duration, 5s) ease-in-out infinite;
  animation-delay: var(--delay, 0s);
}

.tiki-bubble {
  width: var(--size, 12px);
  height: var(--size, 12px);
  left: var(--left, 50%);
  bottom: -40px;
  border: 1px solid rgba(255, 210, 122, 0.42);
  border-radius: 50%;
  opacity: 0;
  animation: tikiBubbleRise var(--duration, 8s) ease-in infinite;
  animation-delay: var(--delay, 0s);
}

.site-footer,
.site-footer-small {
  position: relative;
  overflow: hidden;
}

.site-footer::before,
.site-footer-small::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(255, 210, 122, 0.08), transparent);
  transform: translateX(-100%);
  animation: tikiFooterGlow 9s ease-in-out infinite;
}

@keyframes tikiAmbientGlow {
  from { transform: scale(1); opacity: 0.82; }
  to { transform: scale(1.08); opacity: 1; }
}

@keyframes tikiLightSweep {
  from { background-position: 0% 50%, 0 0; }
  to { background-position: 100% 50%, 120px 0; }
}

@keyframes tikiHeroGlow {
  from { transform: translate3d(-1%, -1%, 0) scale(1); }
  to { transform: translate3d(1.5%, 1%, 0) scale(1.05); }
}

@keyframes tikiLanternBreathe {
  from { opacity: 0.55; transform: translateY(6px) scale(0.98); }
  to { opacity: 0.95; transform: translateY(-4px) scale(1.02); }
}

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

@keyframes tikiFadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes tikiButtonShine {
  0% { opacity: 0; left: -45%; }
  25% { opacity: 1; }
  100% { opacity: 0; left: 125%; }
}

@keyframes tikiLeafDrift {
  0% { opacity: 0; transform: translate3d(0, -80px, 0) rotate(var(--rotate, 12deg)); }
  8% { opacity: 0.38; }
  50% { transform: translate3d(var(--sway, 44px), 54vh, 0) rotate(calc(var(--rotate, 12deg) + 130deg)); }
  92% { opacity: 0.26; }
  100% { opacity: 0; transform: translate3d(calc(var(--sway, 44px) * -1), 110vh, 0) rotate(calc(var(--rotate, 12deg) + 260deg)); }
}

@keyframes tikiSparkle {
  0%, 100% { opacity: 0; transform: scale(0.2); }
  45% { opacity: 0.65; transform: scale(1); }
  65% { opacity: 0.25; transform: scale(1.7); }
}

@keyframes tikiBubbleRise {
  0% { opacity: 0; transform: translateY(0) scale(0.7); }
  15% { opacity: 0.45; }
  100% { opacity: 0; transform: translateY(-96vh) translateX(var(--sway, 20px)) scale(1.35); }
}

@keyframes tikiFooterGlow {
  0%, 40% { transform: translateX(-120%); }
  70%, 100% { transform: translateX(120%); }
}

@media (max-width: 900px) {
  .nav-links.open {
    animation: tikiMobileMenuDrop 230ms ease both;
  }

  .tiki-leaf:nth-of-type(n + 7),
  .tiki-spark:nth-of-type(n + 8),
  .tiki-bubble:nth-of-type(n + 6) {
    display: none;
  }
}

@keyframes tikiMobileMenuDrop {
  from { opacity: 0; transform: translateY(-12px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }

  .tiki-ambient-layer {
    display: none;
  }

  .tiki-reveal,
  .vibe-intro,
  .vibe-card {
    opacity: 1;
    transform: none;
    filter: none;
  }
}

/* ==========================================================
   TIKI HOUSE REPAIR THEME — fixed paths, logo nav, gallery,
   background image, and safe color overhaul.
   This file is loaded after each page CSS, so it overrides
   colors without renaming classes or touching JS/backend logic.
   ========================================================== */

:root {
  --tiki-bg: #1A1715;
  --tiki-card: #F4DFB8;
  --tiki-teal: #0E5A63;
  --tiki-teal-dark: #073D43;
  --tiki-gold: #F2A63A;
  --tiki-orange: #E86B1D;
  --tiki-green: #2E4F38;
  --tiki-brown: #5B3520;
  --tiki-cream: #FFF5E5;
  --tiki-ink: #17110D;
}

body {
  color: var(--tiki-cream) !important;
  background:
    linear-gradient(rgba(26, 23, 21, 0.78), rgba(26, 23, 21, 0.9)),
    var(--tiki-bg) !important;
}

body::before {
  background-image:
    linear-gradient(rgba(26, 23, 21, 0.20), rgba(26, 23, 21, 0.78)),
    url("../images/tiki-page-bg.png") !important;
  background-repeat: no-repeat !important;
  background-position: center 76px !important;
  background-size: min(1800px, 100vw) auto !important;
  opacity: 0.42 !important;
  animation: tikiBackgroundBreath 14s ease-in-out infinite alternate !important;
}

.navbar {
  background: rgba(7, 61, 67, 0.96) !important;
  border-bottom: 3px solid var(--tiki-gold) !important;
  box-shadow: 0 14px 36px rgba(0,0,0,0.42) !important;
}

.logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  color: var(--tiki-cream) !important;
  font-weight: 900 !important;
  letter-spacing: 0.04em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

.logo img {
  height: 56px !important;
  width: 56px !important;
  object-fit: cover !important;
  border-radius: 50% !important;
  border: 2px solid var(--tiki-gold) !important;
  box-shadow: 0 0 18px rgba(232,107,29,0.45) !important;
  background: #000 !important;
  flex: 0 0 auto !important;
}

.nav-links a {
  color: var(--tiki-cream) !important;
}

.nav-links a:hover {
  background: rgba(242, 166, 58, 0.18) !important;
}

.map-btn,
.cta,
button {
  background: linear-gradient(135deg, var(--tiki-orange), var(--tiki-gold)) !important;
  color: var(--tiki-ink) !important;
  font-weight: 900 !important;
  border: 1px solid rgba(255,245,229,0.28) !important;
}

.hero,
.page-hero {
  background:
    linear-gradient(rgba(7,61,67,0.70), rgba(26,23,21,0.62)),
    url("../images/tiki-page-bg.png") center / cover no-repeat !important;
  min-height: 420px !important;
  display: grid !important;
  place-content: center !important;
  padding: 92px 20px !important;
  border-bottom: 4px solid rgba(242,166,58,0.55) !important;
}

.hero h1,
.hero h2,
.page-hero h1,
.page-hero h2 {
  color: var(--tiki-cream) !important;
  text-shadow: 0 6px 26px rgba(0,0,0,0.82) !important;
}

.hero p,
.page-hero p {
  color: var(--tiki-cream) !important;
  text-shadow: 0 4px 18px rgba(0,0,0,0.75) !important;
}

main::before {
  display: none !important;
}

.content-card,
.home-box,
.menu-item,
.menu-card,
.cart,
.form-card,
.admin-card,
.contact-card,
.event-card,
.reservation-card,
.career-card {
  background: rgba(244, 223, 184, 0.94) !important;
  color: var(--tiki-brown) !important;
  border: 2px solid rgba(242, 166, 58, 0.42) !important;
  box-shadow: 0 18px 45px rgba(0,0,0,0.36) !important;
}

.content-card h2,
.content-card h3,
.home-box h3,
.menu-item h3,
.menu-card h3,
.form-card h2,
.contact-card h2,
.event-card h2,
.reservation-card h2,
.career-card h2 {
  color: var(--tiki-teal-dark) !important;
}

.site-footer,
.site-footer-small {
  background: rgba(7, 61, 67, 0.96) !important;
  border-top: 3px solid var(--tiki-gold) !important;
  color: var(--tiki-cream) !important;
}

input,
select,
textarea {
  background: rgba(26, 23, 21, 0.88) !important;
  color: var(--tiki-cream) !important;
  border-color: rgba(242, 166, 58, 0.35) !important;
}

.landing-gallery-section {
  width: min(1180px, calc(100% - 32px));
  margin: 36px auto 52px;
  padding: 28px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(7,61,67,0.90), rgba(26,23,21,0.88));
  border: 2px solid rgba(242,166,58,0.38);
  box-shadow: 0 24px 60px rgba(0,0,0,0.42);
  position: relative;
  z-index: 2;
  overflow: hidden;
}

.landing-gallery-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 8% 12%, rgba(232,107,29,0.22), transparent 28%),
    radial-gradient(circle at 90% 0%, rgba(242,166,58,0.16), transparent 30%);
  pointer-events: none;
}

.landing-gallery-intro,
.landing-gallery-group {
  position: relative;
  z-index: 1;
}

.landing-gallery-intro {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 28px;
}

.landing-gallery-intro .eyebrow {
  color: var(--tiki-gold) !important;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 900;
}

.landing-gallery-intro h2 {
  margin: 8px 0 10px;
  color: var(--tiki-cream);
  font-size: clamp(2rem, 5vw, 3.4rem);
  text-shadow: 0 6px 20px rgba(0,0,0,0.7);
}

.landing-gallery-intro p {
  color: rgba(255,245,229,0.88);
  line-height: 1.65;
}

.landing-gallery-group {
  margin-top: 32px;
}

.landing-gallery-group h3 {
  display: inline-block;
  margin: 0 0 18px;
  padding: 10px 22px;
  border-radius: 999px;
  background: var(--tiki-teal);
  color: var(--tiki-cream);
  border: 2px solid rgba(242,166,58,0.45);
  box-shadow: 0 10px 24px rgba(0,0,0,0.25);
}

.landing-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.landing-gallery-card {
  margin: 0;
  overflow: hidden;
  border-radius: 22px;
  border: 2px solid rgba(242,166,58,0.36);
  background: rgba(244,223,184,0.16);
  box-shadow: 0 18px 38px rgba(0,0,0,0.32);
  min-height: 240px;
}

.landing-gallery-card img {
  width: 100%;
  height: 260px;
  display: block;
  object-fit: cover;
  object-position: center;
  transition: transform 900ms ease, filter 900ms ease;
}

.landing-gallery-card:hover img {
  transform: scale(1.06);
  filter: saturate(1.12) contrast(1.05);
}

@keyframes tikiBackgroundBreath {
  from { transform: scale(1); opacity: 0.34; }
  to { transform: scale(1.018); opacity: 0.48; }
}

@media (max-width: 900px) {
  body::before {
    background-size: auto 360px !important;
    background-position: center 70px !important;
    opacity: 0.26 !important;
  }

  .logo span {
    font-size: 1rem !important;
  }

  .logo img {
    height: 46px !important;
    width: 46px !important;
  }

  .nav-links.open {
    background: rgba(7, 61, 67, 0.98) !important;
    border: 1px solid rgba(242, 166, 58, 0.32) !important;
  }

  .landing-gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .landing-gallery-card img {
    height: 220px;
  }
}

@media (max-width: 600px) {
  .landing-gallery-section {
    width: min(100% - 20px, 1180px);
    padding: 18px;
    border-radius: 22px;
  }

  .landing-gallery-grid {
    grid-template-columns: 1fr;
  }

  .landing-gallery-card img {
    height: auto;
    max-height: 430px;
    object-fit: contain;
    background: rgba(26,23,21,0.9);
  }

  .hero,
  .page-hero {
    min-height: 360px !important;
    padding: 72px 18px !important;
  }
}
