/* ============================================================
   Nuvho Demo Hotel — `demohotel-dev/` shared stylesheet (v2)
   Strictly honours the official Nuvho Brand Guidelines.
   Source: ../../uploads/nuvho_brand_guidelines_official 1.html
   ============================================================ */
@import url('colors_and_type.css');
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  /* Brand-derived dark surface for image overlays / footer / cinematic skin.
     Hue family of Dark Teal (#28687f) but darker for legibility under photos.
     Used only on dark surfaces; never as text on light backgrounds. */
  --nv-ink:    #0d2530;
  --nv-ink-2:  #14313d;
  --nv-hair-on-dark: rgba(255,255,255,0.12);
  --nv-hair-on-light: rgba(40,104,127,0.12);
  --nv-ease:   cubic-bezier(0.2,0.7,0.2,1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--nv-font-body);
  font-weight: 300;
  font-size: 15px;
  line-height: 1.7;
  color: var(--nv-charcoal);
  background: var(--nv-bg-page);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, select, textarea { font-family: inherit; }

.wrap { max-width: 1320px; margin: 0 auto; padding: 0 48px; }
.mono { font-family: 'JetBrains Mono', ui-monospace, Consolas, monospace; letter-spacing: 0.05em; }

.eyebrow { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--nv-medium-blue); display: inline-flex; align-items: center; gap: 12px; }
.eyebrow.dark { color: rgba(255,255,255,0.65); }
.eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--nv-dark-teal); }
.eyebrow.dark .dot { background: var(--nv-light-teal); }
.eyebrow .rule { width: 36px; height: 1px; background: currentColor; opacity: 0.4; }

.h-display { font-family: var(--nv-font-display); font-weight: 700; font-size: clamp(40px, 6vw, 80px); line-height: 1.04; letter-spacing: -0.025em; color: var(--nv-dark-teal); text-wrap: balance; }
.h-display em { font-weight: 300; font-style: italic; color: var(--nv-medium-blue); display: block; }
.h-section { font-family: var(--nv-font-display); font-weight: 700; font-size: clamp(30px, 4.4vw, 56px); line-height: 1.06; letter-spacing: -0.02em; color: var(--nv-dark-teal); text-wrap: balance; max-width: 22ch; }
.h-section em { font-weight: 300; font-style: italic; color: var(--nv-medium-blue); }
.lede { font-family: var(--nv-font-body); font-size: 17px; font-weight: 300; line-height: 1.7; color: var(--nv-fg-3); max-width: 58ch; text-wrap: pretty; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; font-family: var(--nv-font-display); font-size: 13px; font-weight: 600; letter-spacing: 0.02em; padding: 14px 26px; border-radius: var(--nv-radius-pill); border: 1.5px solid transparent; transition: background 220ms var(--nv-ease), color 220ms var(--nv-ease), border-color 220ms var(--nv-ease), transform 220ms var(--nv-ease); white-space: nowrap; cursor: pointer; }
.btn i, .btn svg { width: 16px; height: 16px; transition: transform 280ms var(--nv-ease-out); }
.btn:hover .arrow, .btn:hover svg.arrow { transform: translateX(4px); }
.btn-primary { background: var(--nv-dark-teal); color: var(--nv-white); }
.btn-primary:hover { background: #1a566a; transform: translateY(-1px); }
.btn-outline { background: transparent; color: var(--nv-dark-teal); border-color: var(--nv-dark-teal); }
.btn-outline:hover { background: var(--nv-teal-tint); }
.btn-light { background: var(--nv-white); color: var(--nv-dark-teal); }
.btn-light:hover { background: var(--nv-teal-tint); transform: translateY(-1px); }
.btn-ghost-light { background: transparent; color: var(--nv-white); border-color: rgba(255,255,255,0.4); }
.btn-ghost-light:hover { background: rgba(255,255,255,0.10); border-color: var(--nv-white); }

.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 60; padding: 18px 0; transition: background 320ms var(--nv-ease), padding 320ms var(--nv-ease), backdrop-filter 320ms var(--nv-ease), box-shadow 320ms var(--nv-ease); }
.nav-inner { max-width: 1320px; margin: 0 auto; padding: 0 48px; display: flex; align-items: center; gap: 32px; }
.nav.scrolled, .nav.solid { background: rgba(255,255,255,0.94); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); padding: 12px 0; box-shadow: 0 1px 0 rgba(40,104,127,0.08); }

.brand-mark { font-family: var(--nv-font-display); font-size: 24px; font-weight: 700; letter-spacing: -0.02em; color: var(--nv-white); text-transform: lowercase; line-height: 1; transition: color 220ms var(--nv-ease); }
.nav.scrolled .brand-mark, .nav.solid .brand-mark { color: var(--nv-dark-teal); }
.brand { display: inline-flex; align-items: center; gap: 8px; }

.nav-menu { display: flex; gap: 22px; margin-left: auto; align-items: center; }
.nav-menu > .nav-item > a, .nav-menu > .nav-item > button { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.78); display: inline-flex; align-items: center; gap: 6px; padding: 8px 0; cursor: pointer; transition: color 220ms var(--nv-ease); }
.nav-menu > .nav-item > a:hover, .nav-menu > .nav-item > button:hover { color: var(--nv-white); }
.nav.scrolled .nav-menu > .nav-item > a, .nav.scrolled .nav-menu > .nav-item > button, .nav.solid .nav-menu > .nav-item > a, .nav.solid .nav-menu > .nav-item > button { color: var(--nv-fg-3); }
.nav.scrolled .nav-menu > .nav-item > a:hover, .nav.scrolled .nav-menu > .nav-item > button:hover, .nav.solid .nav-menu > .nav-item > a:hover, .nav.solid .nav-menu > .nav-item > button:hover { color: var(--nv-dark-teal); }
.nav-menu > .nav-item > a.active, .nav.scrolled .nav-menu > .nav-item > a.active, .nav.solid .nav-menu > .nav-item > a.active { color: var(--nv-dark-teal); }
.nav-menu .caret { width: 10px; height: 10px; transition: transform 220ms var(--nv-ease); }

.nav-item { position: relative; }
.nav-dropdown { position: absolute; top: calc(100% + 8px); left: -16px; min-width: 320px; background: rgba(255,255,255,0.97); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border: 1px solid var(--nv-border-soft); border-radius: var(--nv-radius-lg); box-shadow: 0 24px 56px -24px rgba(40,104,127,0.20); padding: 8px; opacity: 0; visibility: hidden; transform: translateY(-4px); transition: opacity 220ms var(--nv-ease), transform 220ms var(--nv-ease), visibility 220ms; }
.nav-item:hover > .nav-dropdown, .nav-item.open > .nav-dropdown { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-item:hover > a .caret, .nav-item.open > a .caret { transform: rotate(180deg); }
.nav-dropdown a { display: grid; grid-template-columns: 56px 1fr auto; gap: 14px; align-items: center; padding: 10px 12px; border-radius: var(--nv-radius-md); text-transform: none; letter-spacing: 0; color: var(--nv-charcoal); font-family: var(--nv-font-body); font-size: 14px; transition: background 180ms var(--nv-ease); }
.nav-dropdown a:hover { background: var(--nv-bg-section); }
.nav-dropdown a img { width: 56px; height: 44px; object-fit: cover; border-radius: var(--nv-radius-sm); }
.nav-dropdown .item-title { font-family: var(--nv-font-display); font-weight: 700; font-size: 14px; color: var(--nv-dark-teal); display: block; line-height: 1.2; }
.nav-dropdown .item-meta { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--nv-fg-4); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 3px; }
.nav-dropdown .item-price { font-family: var(--nv-font-display); font-weight: 600; font-size: 13px; color: var(--nv-medium-blue); white-space: nowrap; }
.nav-dropdown .divider { height: 1px; background: var(--nv-border-soft); margin: 6px 8px; }
.nav-dropdown .all-rooms { display: block; text-align: center; padding: 12px; font-family: var(--nv-font-display); font-size: 12px; font-weight: 600; color: var(--nv-dark-teal); letter-spacing: 0.04em; text-transform: uppercase; }

.nav-reserve { font-family: var(--nv-font-display); font-size: 12px; font-weight: 600; letter-spacing: 0.04em; background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.30); color: var(--nv-white); padding: 10px 20px; border-radius: var(--nv-radius-pill); display: inline-flex; align-items: center; gap: 8px; transition: background 220ms var(--nv-ease), color 220ms var(--nv-ease), border-color 220ms var(--nv-ease); }
.nav-reserve:hover { background: var(--nv-white); color: var(--nv-dark-teal); border-color: var(--nv-white); }
.nav.scrolled .nav-reserve, .nav.solid .nav-reserve { background: var(--nv-dark-teal); color: var(--nv-white); border-color: var(--nv-dark-teal); }
.nav.scrolled .nav-reserve:hover, .nav.solid .nav-reserve:hover { background: #1a566a; border-color: #1a566a; }

.nav-toggle { display: none; margin-left: auto; width: 40px; height: 40px; border-radius: 999px; background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.30); color: var(--nv-white); align-items: center; justify-content: center; }
.nav.scrolled .nav-toggle, .nav.solid .nav-toggle { background: var(--nv-dark-teal); border-color: var(--nv-dark-teal); color: var(--nv-white); }

.mobile-menu { position: fixed; top: 0; right: 0; bottom: 0; width: min(360px, 88vw); background: var(--nv-white); z-index: 70; padding: 80px 24px 24px; transform: translateX(100%); transition: transform 320ms var(--nv-ease); overflow-y: auto; box-shadow: -16px 0 48px -24px rgba(40,104,127,0.20); }
.mobile-menu.open { transform: translateX(0); }
.mobile-menu .close { position: absolute; top: 18px; right: 18px; width: 40px; height: 40px; border-radius: 999px; background: var(--nv-bg-section); color: var(--nv-dark-teal); display: inline-flex; align-items: center; justify-content: center; }
.mobile-menu nav { display: flex; flex-direction: column; }
.mobile-menu nav > a, .mobile-menu nav > details > summary { padding: 16px 8px; font-family: var(--nv-font-display); font-size: 18px; font-weight: 600; color: var(--nv-charcoal); border-bottom: 1px solid var(--nv-border-soft); cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; }
.mobile-menu nav > details > summary::-webkit-details-marker { display: none; }
.mobile-menu nav > details[open] > summary { color: var(--nv-dark-teal); }
.mobile-menu nav > details > div { padding: 8px 8px 16px; display: flex; flex-direction: column; gap: 4px; }
.mobile-menu nav > details > div a { padding: 10px 12px; font-family: var(--nv-font-body); font-size: 15px; color: var(--nv-fg-3); border-radius: var(--nv-radius-sm); }
.mobile-menu nav > details > div a:hover { background: var(--nv-bg-section); color: var(--nv-dark-teal); }
.mobile-menu .nav-reserve { margin-top: 24px; background: var(--nv-dark-teal); color: var(--nv-white); border-color: var(--nv-dark-teal); text-align: center; justify-content: center; }
.mobile-overlay { position: fixed; inset: 0; z-index: 65; background: rgba(13,37,48,0.4); opacity: 0; visibility: hidden; transition: opacity 220ms var(--nv-ease), visibility 220ms; }
.mobile-overlay.open { opacity: 1; visibility: visible; }

.newsletter { padding: 96px 48px; background: var(--nv-bg-section); border-top: 0.5px solid var(--nv-hair-on-light); border-bottom: 0.5px solid var(--nv-hair-on-light); }
.newsletter-inner { max-width: 760px; margin: 0 auto; text-align: center; }
.newsletter h3 { font-family: var(--nv-font-display); font-weight: 700; font-size: clamp(26px, 3.2vw, 40px); line-height: 1.12; letter-spacing: -0.02em; color: var(--nv-dark-teal); margin-top: 18px; text-wrap: balance; }
.newsletter h3 em { font-weight: 300; font-style: italic; color: var(--nv-medium-blue); }
.newsletter p { margin-top: 14px; font-size: 15px; color: var(--nv-fg-3); max-width: 52ch; margin-left: auto; margin-right: auto; }
.newsletter form { margin-top: 36px; display: flex; gap: 8px; background: var(--nv-white); border: 1px solid var(--nv-border-soft); border-radius: var(--nv-radius-pill); padding: 6px 6px 6px 24px; max-width: 520px; margin-left: auto; margin-right: auto; box-shadow: var(--nv-shadow-sm); transition: border-color 220ms var(--nv-ease), box-shadow 220ms var(--nv-ease); }
.newsletter form:focus-within { border-color: var(--nv-dark-teal); box-shadow: 0 0 0 4px var(--nv-dark-teal-08); }
.newsletter input[type="email"] { flex: 1; border: none; outline: none; background: transparent; font-size: 15px; color: var(--nv-charcoal); font-weight: 400; }
.newsletter input::placeholder { color: var(--nv-fg-5); }
.newsletter .legal { margin-top: 18px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.06em; color: var(--nv-fg-4); }

.foot { background: var(--nv-ink); color: rgba(255,255,255,0.72); padding: 96px 48px 32px; }
.foot-grid { max-width: 1320px; margin: 0 auto; display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr; gap: 56px; }
.foot-brand .brand-mark { color: var(--nv-white); font-size: 36px; display: inline-block; margin-bottom: 18px; }
.foot-brand p { font-size: 14px; line-height: 1.7; color: rgba(255,255,255,0.6); max-width: 36ch; }
.foot-contact { margin-top: 22px; display: flex; flex-direction: column; gap: 10px; }
.foot-contact a, .foot-contact span { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; color: rgba(255,255,255,0.78); transition: color 220ms var(--nv-ease); }
.foot-contact a:hover { color: var(--nv-white); }
.foot-contact svg { width: 14px; height: 14px; flex-shrink: 0; color: rgba(128,185,191,0.85); }

.foot-social { margin-top: 22px; display: flex; gap: 10px; }
.foot-social a { width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); color: rgba(255,255,255,0.78); transition: background 220ms var(--nv-ease), color 220ms var(--nv-ease), border-color 220ms var(--nv-ease), transform 220ms var(--nv-ease); }
.foot-social a:hover { background: var(--nv-light-teal); color: var(--nv-ink); border-color: var(--nv-light-teal); transform: translateY(-2px); }
.foot-social svg { width: 16px; height: 16px; }

.foot-col h5 { font-family: var(--nv-font-display); font-size: 11px; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(255,255,255,0.45); margin-bottom: 20px; }
.foot-col ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.foot-col a { font-size: 14px; color: rgba(255,255,255,0.78); transition: color 220ms var(--nv-ease); }
.foot-col a:hover { color: var(--nv-white); }

.foot-bottom { max-width: 1320px; margin: 56px auto 0; padding-top: 24px; border-top: 0.5px solid rgba(255,255,255,0.10); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.06em; color: rgba(255,255,255,0.4); }
.foot-bottom .legal-links { display: flex; gap: 24px; flex-wrap: wrap; }
.foot-bottom a:hover { color: rgba(255,255,255,0.85); }

.packages { max-width: 1320px; margin: 0 auto; padding: 96px 48px; }
.packages-head { display: flex; align-items: end; justify-content: space-between; gap: 32px; margin-bottom: 40px; flex-wrap: wrap; }
.packages-head .text { max-width: 720px; display: flex; flex-direction: column; gap: 16px; }
.pkg-controls { display: flex; gap: 8px; }
.pkg-controls button { width: 44px; height: 44px; border-radius: 50%; background: var(--nv-white); border: 1px solid var(--nv-border-soft); color: var(--nv-dark-teal); display: inline-flex; align-items: center; justify-content: center; transition: background 220ms var(--nv-ease), border-color 220ms var(--nv-ease), opacity 220ms var(--nv-ease); }
.pkg-controls button:hover { background: var(--nv-bg-section); border-color: var(--nv-dark-teal); }
.pkg-controls button[disabled] { opacity: 0.35; cursor: default; }
.pkg-controls svg { width: 16px; height: 16px; }

.pkg-rail { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(340px, 360px); gap: 18px; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; padding-bottom: 12px; scrollbar-width: thin; scrollbar-color: var(--nv-medium-blue) transparent; }
.pkg-rail::-webkit-scrollbar { height: 6px; }
.pkg-rail::-webkit-scrollbar-thumb { background: var(--nv-medium-blue); border-radius: 999px; }
.pkg-card { scroll-snap-align: start; background: var(--nv-white); border: 1px solid var(--nv-border-soft); border-radius: var(--nv-radius-xl); overflow: hidden; display: flex; flex-direction: column; transition: transform 280ms var(--nv-ease), box-shadow 280ms var(--nv-ease), border-color 280ms var(--nv-ease); }
.pkg-card:hover { transform: translateY(-4px); border-color: var(--nv-dark-teal); box-shadow: var(--nv-shadow-md); }
.pkg-card .pkg-photo { aspect-ratio: 4 / 3; overflow: hidden; position: relative; }
.pkg-card .pkg-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--nv-ease); }
.pkg-card:hover .pkg-photo img { transform: scale(1.05); }
.pkg-card .pkg-tag { position: absolute; top: 14px; left: 14px; background: rgba(255,255,255,0.95); color: var(--nv-dark-teal); font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; padding: 6px 12px; border-radius: var(--nv-radius-pill); }
.pkg-card .pkg-body { padding: 24px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.pkg-card h4 { font-family: var(--nv-font-display); font-size: 22px; font-weight: 700; color: var(--nv-dark-teal); letter-spacing: -0.015em; }
.pkg-card p { font-size: 14px; color: var(--nv-fg-3); line-height: 1.6; flex: 1; }
.pkg-card .pkg-meta { display: flex; align-items: center; justify-content: space-between; margin-top: 6px; padding-top: 16px; border-top: 1px solid var(--nv-border-soft); }
.pkg-card .pkg-price { font-family: var(--nv-font-display); font-size: 18px; font-weight: 700; color: var(--nv-dark-teal); letter-spacing: -0.015em; }
.pkg-card .pkg-price small { display: block; font-family: 'JetBrains Mono', monospace; font-size: 9px; font-weight: 400; color: var(--nv-fg-4); letter-spacing: 0.12em; text-transform: uppercase; }
.pkg-card .pkg-link { font-family: var(--nv-font-display); font-size: 12px; font-weight: 600; color: var(--nv-dark-teal); letter-spacing: 0.04em; display: inline-flex; align-items: center; gap: 6px; }
.pkg-card .pkg-link svg { width: 14px; height: 14px; transition: transform 220ms var(--nv-ease); }
.pkg-card:hover .pkg-link svg { transform: translateX(4px); }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity 800ms var(--nv-ease), transform 800ms var(--nv-ease); }
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal.d1 { transition-delay: 80ms; }
.reveal.d2 { transition-delay: 160ms; }
.reveal.d3 { transition-delay: 240ms; }

@media (max-width: 1080px) {
  .nav-inner { padding: 0 24px; }
  .nav-menu { display: none; }
  .nav-reserve { display: none; }
  .nav-toggle { display: inline-flex; }
  .wrap { padding: 0 24px; }
  .newsletter, .foot { padding-left: 24px; padding-right: 24px; }
  .foot-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .packages { padding: 64px 24px; }
}
@media (max-width: 600px) {
  .foot-grid { grid-template-columns: 1fr; gap: 32px; }
  .foot-bottom { flex-direction: column; align-items: flex-start; }
  .newsletter form { flex-direction: column; border-radius: var(--nv-radius-lg); padding: 8px; gap: 8px; }
  .newsletter input[type="email"] { padding: 12px 14px; }
  .newsletter form .btn { width: 100%; }
}

html, body { overflow-x: hidden; }
a, button, summary { -webkit-tap-highlight-color: rgba(40,104,127,0.18); }

@media (max-width: 768px) {
  input[type="email"], input[type="text"], input[type="tel"], input[type="number"], input[type="date"], input[type="search"], input[type="url"], textarea, select { font-size: 16px; }
  .btn { min-height: 44px; padding: 12px 22px; }
  .nav-toggle { width: 44px; height: 44px; }
  .nav-reserve { padding: 11px 18px; }
  .wrap { padding: 0 20px; }
  .newsletter, .foot { padding-left: 20px; padding-right: 20px; }
  .packages { padding: 56px 20px; }
  .h-display { font-size: clamp(30px, 8vw, 48px); line-height: 1.06; max-width: 18ch; }
  .h-section { font-size: clamp(26px, 7vw, 38px); line-height: 1.1; max-width: 18ch; letter-spacing: -0.02em; }
  .lede { font-size: 15.5px; line-height: 1.6; max-width: none; }
  .eyebrow { font-size: 10px; gap: 8px; letter-spacing: 0.18em; }
  .newsletter { padding-top: 72px; padding-bottom: 72px; }
  .newsletter h3 { font-size: clamp(24px, 6.5vw, 32px); margin-top: 14px; }
  .newsletter p { font-size: 14px; }
  .newsletter form { margin-top: 28px; }
  .newsletter input[type="email"] { font-size: 16px; }
  .foot { padding: 72px 20px 28px; }
  .foot-grid { gap: 36px; }
  .foot-brand .brand-mark { font-size: 28px; }
  .foot-brand p { font-size: 13.5px; line-height: 1.65; }
  .foot-col h5 { margin-bottom: 14px; font-size: 10px; }
  .foot-col a, .foot-contact a, .foot-contact span { font-size: 13.5px; }
  .foot-bottom { font-size: 10px; gap: 10px; padding-top: 18px; margin-top: 40px; }
  .foot-bottom .legal-links { gap: 16px; }
  .mobile-menu { padding: 80px 20px 28px; box-shadow: -16px 0 56px -20px rgba(40,104,127,0.32); }
  .mobile-menu nav > a, .mobile-menu nav > details > summary { font-size: 17px; padding: 14px 6px; }
  .mobile-menu .nav-reserve { padding: 14px 22px; font-size: 13px; }
  .nav-inner { padding: 0 18px; gap: 12px; }
  .brand-mark { font-size: 22px; }
  .packages-head { gap: 18px; }
  .pkg-rail { grid-auto-columns: minmax(82vw, 320px); }
  .pkg-controls button { width: 40px; height: 40px; }
}

@media (max-width: 480px) {
  .wrap, .newsletter, .foot { padding-left: 16px; padding-right: 16px; }
  .nav-inner { padding: 0 16px; }
  .h-section { font-size: clamp(24px, 7.5vw, 32px); }
  .lede { font-size: 15px; }
  .foot-bottom .legal-links { flex-wrap: wrap; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .marquee-track { animation: none; }
  .reveal { opacity: 1 !important; transform: none !important; }
}
