/* =========================================================================
   Harmony Hotel — boutique hospitality theme
   Light (ivory/teal/brass) + Dark (forest charcoal/brass) via CSS variables.
   Type: Cormorant Garamond (display) + Jost (body). Refined, subtle radius.
   ========================================================================= */

:root, :root.light {
  --background:             #f1eee6;
  --surface:                #faf8f1;
  --surface-container:      #ebe7da;
  --surface-container-high: #e1dccb;
  --on-surface:             #1c2420;
  --on-surface-variant:     #515c55;
  --heading:                #14302b;
  --primary:                #1d4a40;
  --on-primary:             #f4f1e8;
  --accent:                 #8a6e2c;
  --accent-strong:          #b3923f;
  --outline:                #7d8a82;
  --outline-variant:        #d9d3c4;
  --error:                  #b3261e;
  --hero-overlay:           linear-gradient(180deg, rgba(10,28,24,0.32), rgba(8,22,19,0.74));
  --grain-opacity:          0.04;
}
:root.dark {
  --background:             #0d1512;
  --surface:                #0d1512;
  --surface-container:      #17211d;
  --surface-container-high: #1f2c26;
  --on-surface:             #e7eae3;
  --on-surface-variant:     #a7b3aa;
  --heading:                #f1efe5;
  --primary:                #2f7263;
  --on-primary:             #f1f6f2;
  --accent:                 #d6b265;
  --accent-strong:          #e3c277;
  --outline:                #7d8a82;
  --outline-variant:        #2b372f;
  --error:                  #ffb4ab;
  --hero-overlay:           linear-gradient(180deg, rgba(4,12,10,0.42), rgba(4,10,8,0.80));
  --grain-opacity:          0.06;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { background: var(--background); color: var(--on-surface); font-family: "Jost", system-ui, sans-serif; overflow-x: hidden; transition: background-color .35s ease, color .35s ease; }
.font-display { font-family: "Cormorant Garamond", Georgia, serif; }
.label { font-family: "Jost", sans-serif; font-weight: 500; text-transform: uppercase; letter-spacing: 0.22em; font-size: 12px; line-height: 1; }

.grain { position: relative; }
.grain::after { content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: var(--grain-opacity); mix-blend-mode: overlay; }
.hero-overlay { background: var(--hero-overlay); }

.btn-primary { background: var(--primary); color: var(--on-primary); border-radius: 3px; transition: filter .25s ease, transform .1s ease; }
.btn-primary:hover { filter: brightness(1.1); }
.btn-primary:active { transform: scale(.98); }
.btn-outline { border: 1px solid var(--accent); color: var(--accent); border-radius: 3px; transition: background-color .3s ease, color .3s ease; }
.btn-outline:hover { background: var(--accent); color: #fff; }
.btn-ghost-light { border: 1px solid rgba(255,255,255,.5); color: #fff; border-radius: 3px; transition: background-color .3s ease; }
.btn-ghost-light:hover { background: rgba(255,255,255,.14); }

.field { width: 100%; background: var(--surface); border: 1px solid var(--outline-variant); border-radius: 3px; padding: .7rem .9rem; color: var(--on-surface); font-family: "Jost", sans-serif; outline: none; transition: border-color .25s ease; }
.field::placeholder { color: var(--on-surface-variant); opacity: .7; }
.field:focus { border-color: var(--accent); }
.field option { color: #1c2420; }

#site-nav { background: color-mix(in srgb, var(--surface) 88%, transparent); }
.nav-scrolled { box-shadow: 0 1px 0 var(--outline-variant), 0 10px 30px rgba(0,0,0,.10); }
.card { background: var(--surface); border: 1px solid var(--outline-variant); border-radius: 4px; }

.lang-menu[hidden] { display: none; }
.lang-option .material-symbols-outlined { opacity: 0; transition: opacity .15s ease; }
.lang-option[aria-current="true"] .material-symbols-outlined { opacity: 1; }
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .8s ease, transform .8s ease; }
.reveal.is-visible { opacity: 1; transform: none; }
.material-symbols-outlined { font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 24; vertical-align: middle; }

html.capture #home { min-height: 0 !important; height: auto !important; }
html.capture .reveal { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } .reveal { transition: none; opacity: 1; transform: none; } * { animation-duration: .01ms !important; transition-duration: .01ms !important; } }
