/* ════════════════════════════════════════════════════════════════════════
 * styles.css — MOSO 호텔 인룸 컨시어지 (★5성급 럭셔리)
 *   숙소용(moso-concierge)보다 한 단계 고급:
 *     · 다크/골드 테마(기본 다크) · 전면 고딕 헤드라인(Pretendard, 타이트 트래킹 — 세리프 폐지)
 *     · 시네마틱 히어로 · 큰 이미지 · 넉넉한 여백 · 정제 타이포 · 마이크로 인터랙션
 *   토스급 위계(제목↔설명 분리·간격·폭 절제) · Pretendard 본문/제목 · MOSO 기조 유지.
 *   반응형: ★인룸 태블릿(가로 ≥1024 풀스크린 럭셔리) + 모바일(QR 세로).
 *   data-brand: haeon | haeonresort  ·  data-theme: dark | light (기본 dark)
 *   모든 색은 토큰(변수)로 — 카피 0 색상(컬러 의미는 토큰이 단일 진실원천).
 * ════════════════════════════════════════════════════════════════════════ */

/* ── 디자인 토큰 ─────────────────────────────────────────────────────────── */
:root {
  /* 타이포 — 전면 고딕(Pretendard). 헤드라인도 동일 고딕(세리프 폐지, 가독성 우선). */
  --font-body: 'Pretendard', -apple-system, BlinkMacSystemFont, system-ui, 'Apple SD Gothic Neo', sans-serif;
  --font-head: 'Pretendard', -apple-system, BlinkMacSystemFont, system-ui, 'Apple SD Gothic Neo', sans-serif;
  --font-serif: var(--font-head);   /* 하위호환 별칭 — 기존 참조가 전부 고딕으로 흐르도록 */
  --font-mono: 'SF Mono', 'JetBrains Mono', ui-monospace, Menlo, Consolas, monospace;

  /* 다크 럭셔리 팔레트(기본) — 깊은 잉크 + 샴페인 골드 */
  --ink-900: #0c0e12;     /* 최심층 배경 */
  --ink-850: #121419;
  --ink-800: #16181f;     /* 카드 배경 */
  --ink-750: #1c1f27;     /* 카드 hover/elevated */
  --ink-700: #232733;     /* 보더/구분 */
  --ink-600: #2e3340;
  --line:    rgba(255,255,255,.08);
  --line-2:  rgba(255,255,255,.12);

  --text-1:  #f4efe6;     /* 주 텍스트(따뜻한 아이보리) */
  --text-2:  #c4bdaf;     /* 보조 */
  --text-3:  #8d8678;     /* 약한 */
  --text-4:  #5f5b51;     /* 가장 약한/placeholder */

  /* 골드 악센트(브랜드 따라 변주) */
  --gold:    #c9a24b;     /* 시그니처 골드 */
  --gold-2:  #e3c277;     /* 밝은 골드(하이라이트) */
  --gold-3:  #9a7a32;     /* 어두운 골드 */
  --gold-soft: rgba(201,162,75,.14);
  --gold-line: rgba(201,162,75,.35);

  --accent:  var(--gold);
  --accent-2: var(--gold-2);
  --accent-soft: var(--gold-soft);
  --accent-line: var(--gold-line);

  /* 상태색(정직 라벨·성공·주의) */
  --ok:    #6fbf8e;
  --info:  #7db5d6;
  --warn:  #d98a6a;
  --soon:  #b9a06a;        /* '연동 예정' 톤(골드-그레이) */

  /* 곡률·그림자·간격 */
  --r-xs: 8px; --r-sm: 12px; --r-md: 16px; --r-lg: 22px; --r-xl: 28px; --r-2xl: 34px;
  --sh-1: 0 1px 2px rgba(0,0,0,.4);
  --sh-2: 0 8px 30px rgba(0,0,0,.35);
  --sh-3: 0 20px 60px rgba(0,0,0,.5);
  --sh-gold: 0 10px 40px rgba(201,162,75,.18);

  /* 8pt 간격 스케일 */
  --s-1: 4px; --s-2: 8px; --s-3: 12px; --s-4: 16px; --s-5: 20px; --s-6: 24px;
  --s-7: 32px; --s-8: 40px; --s-9: 56px; --s-10: 72px; --s-12: 96px;

  /* 폭 절제 */
  --maxw: 1320px;
  --ease: cubic-bezier(.22,1,.36,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);

  --bg: var(--ink-900);
  --bg-grad: radial-gradient(120% 90% at 50% -10%, #1a1d26 0%, var(--ink-900) 55%);
  color-scheme: dark;
}

/* 브랜드 변주: 해온(클래식 골드 / 잉크블루 베이스) ↔ 해온리조트(오션 틸 + 샴페인) */
[data-brand="haeon"] {
  --gold: #c9a24b; --gold-2: #e7c97f; --gold-3: #9a7a32;
  --gold-soft: rgba(201,162,75,.14); --gold-line: rgba(201,162,75,.35);
  --bg-grad: radial-gradient(120% 90% at 50% -10%, #1b1e28 0%, var(--ink-900) 55%);
}
[data-brand="haeonresort"] {
  --gold: #d9b566; --gold-2: #f0d597; --gold-3: #a98a3f;
  --gold-soft: rgba(217,181,102,.14); --gold-line: rgba(217,181,102,.36);
  /* 오션 틸 언더톤(리조트) */
  --ink-900: #0a0f13; --ink-850: #0f151a; --ink-800: #131a20; --ink-750: #18222a; --ink-700: #21303a;
  --info: #7fc6d6;
  --bg-grad: radial-gradient(125% 95% at 50% -10%, #12222a 0%, #0a0f13 58%);
}

/* 라이트 테마(옵션) — 따뜻한 아이보리 + 골드 (낮 시간/밝은 로비용) */
[data-theme="light"] {
  --ink-900: #f6f2ea; --ink-850: #f1ece2; --ink-800: #ffffff; --ink-750: #faf6ee; --ink-700: #ece5d8; --ink-600: #ddd4c4;
  --line: rgba(40,32,18,.10); --line-2: rgba(40,32,18,.16);
  --text-1: #221d14; --text-2: #524a3a; --text-3: #847a66; --text-4: #aba291;
  --gold: #9a7a32; --gold-2: #b8923f; --gold-3: #7a5f24;
  --gold-soft: rgba(154,122,50,.12); --gold-line: rgba(154,122,50,.3);
  --sh-2: 0 8px 30px rgba(40,32,18,.1); --sh-3: 0 20px 60px rgba(40,32,18,.14); --sh-gold: 0 10px 40px rgba(154,122,50,.16);
  --bg-grad: radial-gradient(120% 90% at 50% -10%, #fffdf8 0%, var(--ink-900) 60%);
  color-scheme: light;
}

/* ── 리셋·기본 ──────────────────────────────────────────────────────────── */
* { margin: 0; padding: 0; box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { height: 100%; }
html { word-break: keep-all; overflow-wrap: break-word; }
body {
  font-family: var(--font-body);
  background: var(--bg-grad) fixed, var(--bg);
  color: var(--text-1);
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'tnum' 0; letter-spacing: -.01em;
  overflow: hidden;  /* 셸이 스크롤 관리 */
}
button, input, textarea, select { font-family: inherit; color: inherit; }
button { cursor: pointer; background: none; border: none; }
::selection { background: var(--gold-soft); color: var(--text-1); }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; border-radius: 6px; }

/* ── ★접근성(WCAG): 스킵링크 · sr-only ─────────────────────────────────── */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; top: var(--s-3); left: 50%; transform: translateX(-50%) translateY(-200%); z-index: 9999;
  background: var(--gold); color: #1a1206; font-weight: 700; font-size: 14px; padding: 12px 20px; border-radius: var(--r-sm);
  box-shadow: 0 10px 30px rgba(0,0,0,.4); transition: transform .2s var(--ease); font-family: var(--font-head); letter-spacing: -.01em; }
.skip-link:focus { transform: translateX(-50%) translateY(0); outline: 2px solid var(--text-1); outline-offset: 2px; }

/* 골드 헤어라인 유틸 */
.hair { height: 1px; background: linear-gradient(90deg, transparent, var(--gold-line), transparent); border: 0; }

/* 헤드라인 유틸(과거 .serif 별칭 — 이제 고딕 + 타이트 트래킹) */
.serif { font-family: var(--font-head); font-weight: 700; letter-spacing: -.02em; }

/* ── 접근 게이트(키오스크 잠금 옵션) ────────────────────────────────────── */
html.gated body > .app, html.gated body > #flowSlot { filter: blur(8px); pointer-events: none; }
.gate { position: fixed; inset: 0; z-index: 200; display: grid; place-items: center; padding: var(--s-6);
  background: var(--bg-grad) fixed, var(--bg); }
.gate-card { width: min(420px, 92vw); background: var(--ink-800); border: 1px solid var(--line); border-radius: var(--r-2xl);
  padding: var(--s-9) var(--s-7) var(--s-7); text-align: center; box-shadow: var(--sh-3); }
.gate-mark { font-family: var(--font-head); font-size: 44px; color: var(--gold); line-height: 1; margin-bottom: var(--s-5); }
.gate-card h1 { font-family: var(--font-head); font-size: 26px; font-weight: 700; letter-spacing: -.02em; margin-bottom: var(--s-2); }
.gate-card p { color: var(--text-3); font-size: 14px; margin-bottom: var(--s-6); }
.gate-input { width: 100%; background: var(--ink-850); border: 1px solid var(--line-2); border-radius: var(--r-md);
  padding: 15px 16px; font-size: 17px; text-align: center; letter-spacing: .04em; color: var(--text-1); margin-bottom: var(--s-3); transition: border-color .2s; }
.gate-input:focus { outline: none; border-color: var(--gold); }
.gate-input.err { border-color: var(--warn); animation: shake .42s; }
@keyframes shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-7px)} 75%{transform:translateX(7px)} }
.gate-cta { width: 100%; background: linear-gradient(135deg, var(--gold), var(--gold-3)); color: #1a1408;
  font-weight: 800; font-size: 16px; padding: 15px; border-radius: var(--r-md); letter-spacing: -.01em; transition: transform .14s var(--ease-spring), filter .2s; }
.gate-cta:active { transform: scale(.97); filter: brightness(1.06); }
.gate-err { color: var(--warn); font-size: 13px; min-height: 18px; margin-top: var(--s-3); font-weight: 600; }
.gate-hint { color: var(--text-4); font-size: 12px; margin-top: var(--s-4); }

/* ════════════════════════════════════════════════════════════════════════
 * 앱 셸 — 가로형 인룸 태블릿 기본 + 모바일 반응형
 * ════════════════════════════════════════════════════════════════════════ */
.app { height: 100dvh; display: flex; flex-direction: column; }

/* ── 상단바 ─────────────────────────────────────────────────────────────── */
.topbar {
  flex: none; display: flex; align-items: center; gap: var(--s-5);
  padding: var(--s-4) var(--s-7); padding-top: calc(var(--s-4) + env(safe-area-inset-top, 0px));
  background: linear-gradient(180deg, rgba(0,0,0,.28), transparent), var(--ink-850);
  border-bottom: 1px solid var(--line);
  position: relative; z-index: 10;
}
.topbar::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-line) 38%, var(--gold-line) 62%, transparent); opacity: .35; }

.brand-id { display: flex; align-items: center; gap: var(--s-3); min-width: 0; }
.brand-mark { font-family: var(--font-head); font-size: 26px; line-height: 1; color: var(--gold);
  width: 46px; height: 46px; display: grid; place-items: center; border: 1px solid var(--gold-line);
  border-radius: 50%; flex: none; background: var(--gold-soft); }
.brand-meta { min-width: 0; }
.brand-meta b { font-family: var(--font-head); font-size: 19px; font-weight: 700; letter-spacing: -.02em; display: block; line-height: 1.15;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 38vw; }
.brand-meta span { font-size: 11px; color: var(--gold-2); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }

.topbar-spacer { flex: 1; }

/* 실시간 시계 */
.top-clock { text-align: right; line-height: 1.1; }
.top-clock .time { font-family: var(--font-mono); font-size: 19px; font-weight: 600; font-variant-numeric: tabular-nums; letter-spacing: .02em; color: var(--text-1); }
.top-clock .date { font-size: 11px; color: var(--text-3); font-weight: 500; margin-top: 2px; }

/* 체크아웃 카운트다운 + 객실번호 칩 */
.checkout-pill { display: flex; align-items: center; gap: var(--s-3);
  background: var(--ink-800); border: 1px solid var(--line-2); border-radius: 999px; padding: 7px 7px 7px 14px; }
.checkout-pill .co-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold-2); box-shadow: 0 0 0 4px var(--gold-soft); flex: none; animation: pulse 2.4s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.5} }
.checkout-pill.over .co-dot { background: var(--warn); box-shadow: 0 0 0 4px rgba(217,138,106,.18); }
.checkout-pill .co-text { line-height: 1.05; display: flex; flex-direction: column; }
.checkout-pill .co-text small { font-size: 9.5px; color: var(--text-3); font-weight: 600; letter-spacing: .06em; text-transform: uppercase; }
.checkout-pill .co-text b { font-family: var(--font-mono); font-size: 15px; font-variant-numeric: tabular-nums; color: var(--text-1); font-weight: 600; }
.co-cta { background: var(--gold-soft); color: var(--gold-2); border: 1px solid var(--gold-line); font-size: 11.5px; font-weight: 700;
  padding: 7px 12px; border-radius: 999px; letter-spacing: -.01em; transition: background .2s, transform .14s var(--ease-spring); white-space: nowrap; }
.co-cta:active { transform: scale(.95); }
.co-cta:hover { background: rgba(201,162,75,.22); }

.room-chip { display: flex; align-items: center; gap: 7px; background: var(--ink-800); border: 1px solid var(--line-2);
  border-radius: 999px; padding: 7px 14px; }
.room-chip .rc-ic { width: 15px; height: 15px; color: var(--gold-2); }
.room-chip small { font-size: 9.5px; color: var(--text-3); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; }
.room-chip b { font-size: 15px; font-weight: 700; color: var(--text-1); font-variant-numeric: tabular-nums; }

/* 언어 스위처 — 국기 + 라벨 병기(잘 보이게: 대비·크기·선택 강조) */
.lang-switch { display: flex; gap: 2px; background: var(--ink-850); border: 1px solid var(--line-2); border-radius: 999px; padding: 4px; }
.lang-switch button { display: flex; align-items: center; gap: 7px; padding: 7px 13px; border-radius: 999px; transition: background .2s, color .2s; }
.lang-switch button .flag { font-size: 16px; line-height: 1; }
.lang-switch button .lname { font-size: 13px; font-weight: 600; color: var(--text-2); letter-spacing: -.01em; transition: color .2s; }
.lang-switch button .lname-short { display: none; font-size: 12px; font-weight: 600; color: var(--text-2); letter-spacing: -.01em; transition: color .2s; }
.lang-switch button.on { background: var(--gold-soft); border: 1px solid var(--gold-line); padding: 6px 12px; }
.lang-switch button.on .lname, .lang-switch button.on .lname-short { color: var(--gold-2); font-weight: 700; }
.lang-switch button:not(.on):hover .lname, .lang-switch button:not(.on):hover .lname-short { color: var(--text-1); }

/* 브랜드/테마 토글 */
.brand-toggle { display: flex; align-items: center; gap: 8px; background: var(--ink-850); border: 1px solid var(--line);
  border-radius: 999px; padding: 7px 12px; transition: border-color .2s; }
.brand-toggle:hover { border-color: var(--gold-line); }
.brand-toggle .bt-mark { font-family: var(--font-head); font-size: 16px; color: var(--gold); line-height: 1; }
.brand-toggle .bt-name { font-size: 12.5px; font-weight: 700; color: var(--text-2); white-space: nowrap; letter-spacing: -.01em; }
.brand-toggle .demo-chip { font-size: 9px; font-weight: 800; padding: 2px 7px; border-radius: 999px; background: var(--gold-soft); color: var(--soon); letter-spacing: .04em; text-transform: uppercase; }

.theme-toggle { width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--line); background: var(--ink-850);
  display: grid; place-items: center; color: var(--text-2); transition: border-color .2s, color .2s, transform .3s var(--ease); }
.theme-toggle:hover { border-color: var(--gold-line); color: var(--gold-2); }
.theme-toggle svg { width: 19px; height: 19px; }
.theme-toggle:active { transform: rotate(40deg) scale(.92); }

/* ── 본문 무대 ──────────────────────────────────────────────────────────── */
.stage { flex: 1; min-height: 0; position: relative; display: flex; flex-direction: column; }
.views-host { flex: 1; min-height: 0; overflow-y: auto; -webkit-overflow-scrolling: touch; scroll-behavior: smooth; }
.views-host::-webkit-scrollbar { width: 8px; }
.views-host::-webkit-scrollbar-thumb { background: var(--ink-700); border-radius: 8px; }
.views-host::-webkit-scrollbar-track { background: transparent; }

.view { animation: viewIn .5s var(--ease) both; }
@keyframes viewIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
.view-pad { max-width: var(--maxw); margin: 0 auto; padding: var(--s-8) var(--s-8) var(--s-12); }

/* 공통 nav 행 */
.nav-row { display: flex; align-items: center; gap: var(--s-3); margin-bottom: var(--s-6); }
.nav-btn { display: inline-flex; align-items: center; gap: 7px; font-size: 14px; font-weight: 600; color: var(--text-2);
  border: 1px solid var(--line); background: var(--ink-800); padding: 10px 16px; border-radius: 999px; transition: border-color .2s, color .2s, transform .14s var(--ease-spring); }
.nav-btn svg { width: 17px; height: 17px; }
.nav-btn:hover { border-color: var(--gold-line); color: var(--text-1); }
.nav-btn:active { transform: scale(.96); }
.nav-btn.ghost { background: transparent; }

/* 섹션 헤더(토스급 위계: 큰 세리프 제목 ↔ 정제된 설명, 골드 키커) */
.sec-head { margin-bottom: var(--s-8); max-width: 720px; }
.sec-head .kicker { font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--gold-2); margin-bottom: var(--s-3); display: flex; align-items: center; gap: 10px; }
.sec-head .kicker::before { content: ''; width: 22px; height: 1px; background: var(--gold-line); }
.sec-head h1 { font-family: var(--font-head); font-size: clamp(28px, 3.6vw, 42px); font-weight: 700; line-height: 1.12; letter-spacing: -.025em; }
.sec-head p { color: var(--text-3); font-size: 15.5px; margin-top: var(--s-3); line-height: 1.55; letter-spacing: -.01em; }

.brand-accent { color: var(--text-1); }

/* ════════════════════════════════════════════════════════════════════════
 * HOME — 시네마틱 히어로 + 럭셔리 타일 그리드
 * ════════════════════════════════════════════════════════════════════════ */
.home-wrap { max-width: var(--maxw); margin: 0 auto; padding: var(--s-7) var(--s-8) var(--s-12); }

/* 상단 표지 회전판(시네마틱 히어로) */
.promo-rail { position: relative; border-radius: var(--r-2xl); overflow: hidden; height: clamp(260px, 34vh, 440px);
  margin-bottom: var(--s-8); box-shadow: var(--sh-3); border: 1px solid var(--line); }
.promo-track { position: absolute; inset: 0; }
.promo-slide { position: absolute; inset: 0; opacity: 0; transition: opacity 1.1s var(--ease); cursor: pointer; }
.promo-slide.on { opacity: 1; }
.promo-bg { position: absolute; inset: 0; background-size: cover; background-position: center; transform: scale(1.04); }
.promo-slide.on .promo-bg { animation: kenburns 9s ease-out both; }
@keyframes kenburns { from { transform: scale(1.04); } to { transform: scale(1.14); } }
/* 사진 없을 때: 브랜드 그라데이션 무드(tone) — 카피 0 색상 */
.promo-slide:not(.has-img) .promo-bg { background: var(--tone-grad, linear-gradient(135deg, #1d2230, #0e1014)); transform: none; animation: none; }
.promo-slide.tone-brand:not(.has-img) .promo-bg { --tone-grad: linear-gradient(135deg, #232838 0%, #14171f 55%, #0d0f14 100%); }
.promo-slide.tone-ink:not(.has-img) .promo-bg { --tone-grad: linear-gradient(135deg, #1a1d27 0%, #0c0e13 100%); }
.promo-slide.tone-gold:not(.has-img) .promo-bg { --tone-grad: linear-gradient(135deg, #2a2415 0%, #181410 55%, #0e0c0a 100%); }
.promo-slide.tone-night:not(.has-img) .promo-bg { --tone-grad: linear-gradient(135deg, #141a24 0%, #0a0d12 100%); }
.promo-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.66) 0%, rgba(0,0,0,.36) 42%, rgba(0,0,0,.08) 100%),
  linear-gradient(0deg, rgba(0,0,0,.5), transparent 60%); }
.promo-content { position: absolute; left: 0; bottom: 0; padding: clamp(24px, 4vw, 52px); max-width: 680px; }
.promo-kicker { font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--gold-2); margin-bottom: var(--s-3);
  display: inline-flex; align-items: center; gap: 10px; }
.promo-kicker::before { content: ''; width: 24px; height: 1px; background: var(--gold-2); opacity: .8; }
.promo-title { font-family: var(--font-head); font-size: clamp(26px, 3.4vw, 42px); font-weight: 700; line-height: 1.12; letter-spacing: -.025em; color: #fff; text-shadow: 0 2px 24px rgba(0,0,0,.4); }
.promo-sub { font-size: clamp(13px, 1.4vw, 16px); color: rgba(255,255,255,.84); margin-top: var(--s-3); line-height: 1.55; font-weight: 400; }
.promo-cta { display: inline-flex; align-items: center; gap: 8px; margin-top: var(--s-5); font-size: 13.5px; font-weight: 700; color: #1a1408;
  background: linear-gradient(135deg, var(--gold-2), var(--gold)); padding: 11px 18px; border-radius: 999px; letter-spacing: -.01em; transition: transform .2s var(--ease-spring); }
.promo-cta svg { width: 16px; height: 16px; }
.promo-slide:hover .promo-cta { transform: translateX(3px); }
.promo-dots { position: absolute; right: clamp(20px, 3vw, 40px); bottom: clamp(20px, 3vw, 40px); display: flex; gap: 9px; z-index: 3; }
.promo-dot { width: 30px; height: 3px; border-radius: 2px; background: rgba(255,255,255,.28); overflow: hidden; position: relative; transition: background .3s; }
.promo-dot.on { background: rgba(255,255,255,.3); }
.promo-dot .pd-fill { position: absolute; inset: 0; width: 0; background: var(--gold-2); }
.promo-dot.on .pd-fill { animation: dotfill 5s linear both; }
@keyframes dotfill { from { width: 0; } to { width: 100%; } }

/* 히어로 + 타일 분할 */
.home-split { display: grid; grid-template-columns: 1fr; gap: var(--s-7); }
.home-hero { padding: var(--s-2) var(--s-1) var(--s-3); }
.home-hero .eyebrow { font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--gold-2);
  margin-bottom: var(--s-3); display: inline-flex; align-items: center; gap: 10px; }
.home-hero .eyebrow::before { content: ''; width: 22px; height: 1px; background: var(--gold-line); }
.home-hero h1 { font-family: var(--font-head); font-size: clamp(32px, 4.6vw, 52px); font-weight: 800; line-height: 1.08; letter-spacing: -.03em; }
.home-hero .room { font-size: 15px; color: var(--text-2); margin-top: var(--s-4); display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.home-hero .room .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--gold); flex: none; }
.home-hero .room .rt { color: var(--gold-2); font-weight: 600; }

/* 럭셔리 타일 그리드 */
.tile-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(248px, 1fr)); gap: var(--s-4); }
.tile { position: relative; text-align: left; padding: var(--s-6); min-height: 148px; border-radius: var(--r-lg);
  background: var(--ink-800); border: 1px solid var(--line); overflow: hidden;
  display: flex; flex-direction: column; justify-content: space-between;
  transition: transform .32s var(--ease), border-color .3s, box-shadow .35s, background .3s; }
.tile::before { content: ''; position: absolute; inset: 0; background: var(--tile-grad, linear-gradient(135deg, transparent, transparent)); opacity: 0; transition: opacity .35s; }
.tile[data-tone="sage"]  { --tile-grad: radial-gradient(120% 110% at 100% 0%, rgba(111,191,142,.1), transparent 60%); }
.tile[data-tone="warm"]  { --tile-grad: radial-gradient(120% 110% at 100% 0%, rgba(217,138,106,.12), transparent 60%); }
.tile[data-tone="gold"]  { --tile-grad: radial-gradient(120% 110% at 100% 0%, rgba(201,162,75,.16), transparent 60%); }
.tile[data-tone="mist"]  { --tile-grad: radial-gradient(120% 110% at 100% 0%, rgba(125,181,214,.1), transparent 60%); }
.tile[data-tone="ink"]   { --tile-grad: radial-gradient(120% 110% at 100% 0%, rgba(255,255,255,.05), transparent 60%); }
.tile:hover { transform: translateY(-4px); border-color: var(--gold-line); box-shadow: var(--sh-2), var(--sh-gold); background: var(--ink-750); }
.tile:hover::before { opacity: 1; }
.tile:active { transform: translateY(-1px) scale(.99); }
.tile .t-ic { width: 46px; height: 46px; border-radius: var(--r-md); display: grid; place-items: center;
  background: var(--gold-soft); border: 1px solid var(--gold-line); color: var(--gold-2); position: relative; z-index: 1; }
.tile .t-ic svg { width: 24px; height: 24px; }
.tile .t-arrow { position: absolute; top: var(--s-6); right: var(--s-6); width: 22px; height: 22px; color: var(--text-4); opacity: 0; transform: translateX(-4px); transition: opacity .3s, transform .3s, color .3s; z-index: 1; }
.tile:hover .t-arrow { opacity: 1; transform: none; color: var(--gold-2); }
.tile .t-body { position: relative; z-index: 1; }
.tile .t-body b { font-family: var(--font-head); font-size: 19px; font-weight: 700; display: block; line-height: 1.2; letter-spacing: -.02em; }
.tile .t-body span { font-size: 12.5px; color: var(--text-3); margin-top: 4px; display: block; line-height: 1.45; }
.tile.feature { background: linear-gradient(140deg, var(--ink-750), var(--ink-800)); border-color: var(--gold-line); }
.tile.feature .t-ic { background: linear-gradient(135deg, var(--gold), var(--gold-3)); color: #1a1408; border-color: transparent; }

/* ── ★법적 고지(CCTV §25 · 개인정보 · 연령) — 인룸 상시 노출, 럭셔리 톤 ──────── */
.legal-notice { margin-top: var(--s-9); padding-top: var(--s-7); border-top: 1px solid var(--line); }
.legal-notice .ln-head { margin-bottom: var(--s-5); }
.legal-notice .ln-kicker { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--gold-2); margin-bottom: var(--s-2); }
.legal-notice .ln-head h2 { font-size: 19px; font-weight: 700; color: var(--text-2); letter-spacing: -.02em; line-height: 1.3; }
.ln-grid { display: grid; grid-template-columns: 1fr; gap: var(--s-3); }
.ln-item { display: flex; gap: var(--s-4); padding: var(--s-5); border-radius: var(--r-md); background: var(--ink-800); border: 1px solid var(--line); }
.ln-item .ln-ic { flex: none; width: 38px; height: 38px; border-radius: var(--r-sm); display: grid; place-items: center; background: var(--gold-soft); border: 1px solid var(--gold-line); color: var(--gold-2); }
.ln-item .ln-ic svg { width: 20px; height: 20px; }
.ln-item .ln-tx { min-width: 0; }
.ln-item .ln-tx b { font-family: var(--font-head); font-size: 14.5px; font-weight: 700; letter-spacing: -.01em; color: var(--text-1); display: block; line-height: 1.3; }
.ln-item .ln-tx span { font-size: 12.5px; color: var(--text-3); line-height: 1.55; margin-top: 4px; display: block; }
.ln-contact { display: flex; align-items: center; gap: var(--s-2); margin-top: var(--s-4); padding: var(--s-4) var(--s-5); border-radius: var(--r-md); background: var(--gold-soft); border: 1px solid var(--gold-line); font-size: 12.5px; color: var(--text-2); line-height: 1.5; }
.ln-contact svg { width: 17px; height: 17px; flex: none; color: var(--gold-2); }
.ln-contact b { color: var(--text-1); font-weight: 700; }
.legal-notice .ln-disc { margin-top: var(--s-4); font-size: 11.5px; color: var(--text-4); line-height: 1.6; }
@media (min-width: 768px) { .ln-grid { grid-template-columns: repeat(3, 1fr); } .ln-item { flex-direction: column; } }

/* ════════════════════════════════════════════════════════════════════════
 * 카드 · 리스트 공통(럭셔리)
 * ════════════════════════════════════════════════════════════════════════ */
.card { background: var(--ink-800); border: 1px solid var(--line); border-radius: var(--r-lg); transition: border-color .25s, box-shadow .3s, background .25s; }

/* 가이드(객실 안내) — 라벨:값 + 와이파이 복사 */
.guide-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: var(--s-4); align-items: start; }
.guide-card { overflow: hidden; }
.gc-head { display: flex; align-items: center; gap: var(--s-3); padding: var(--s-5) var(--s-6); cursor: pointer; }
.gc-ic { width: 40px; height: 40px; border-radius: var(--r-sm); display: grid; place-items: center; background: var(--gold-soft); border: 1px solid var(--gold-line); color: var(--gold-2); flex: none; }
.gc-ic svg { width: 21px; height: 21px; }
.gc-head b { font-family: var(--font-head); font-size: 17px; font-weight: 700; letter-spacing: -.02em; flex: 1; }
.gc-chev { width: 20px; height: 20px; color: var(--text-4); transition: transform .3s var(--ease); }
.guide-card.collapsible:not(.open) .gc-body { display: none; }
.guide-card.collapsible.open .gc-chev { transform: rotate(180deg); }
.gc-body { padding: 0 var(--s-6) var(--s-5); }
.kv-row { display: flex; align-items: center; gap: var(--s-3); padding: var(--s-3) 0; border-top: 1px solid var(--line); }
.kv-row:first-child { border-top: none; }
.kv-k { font-size: 13px; color: var(--text-3); min-width: 116px; flex: none; font-weight: 500; }
.kv-v { font-size: 14.5px; color: var(--text-1); flex: 1; font-weight: 500; line-height: 1.5; }
.kv-v.mono { font-family: var(--font-mono); letter-spacing: .02em; color: var(--gold-2); font-weight: 600; }
.copy-btn { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; color: var(--gold-2);
  border: 1px solid var(--gold-line); background: var(--gold-soft); padding: 7px 12px; border-radius: 999px; flex: none; transition: background .2s, transform .14s var(--ease-spring); }
.copy-btn svg { width: 14px; height: 14px; }
.copy-btn:active { transform: scale(.94); }
.copy-btn.done { background: rgba(111,191,142,.16); color: var(--ok); border-color: rgba(111,191,142,.4); }

/* 룸타입 카드(객실 안내 상단) — 큰 이미지 무드 */
.roomtype-card { display: grid; grid-template-columns: 200px 1fr; overflow: hidden; margin-bottom: var(--s-5); }
.rt-thumb { position: relative; background: linear-gradient(135deg, var(--ink-700), var(--ink-850)); display: grid; place-items: center; min-height: 168px; overflow: hidden; }
.rt-thumb::after { content: ''; position: absolute; inset: 0; background: radial-gradient(120% 120% at 70% 20%, var(--gold-soft), transparent 55%); }
.rt-thumb svg { width: 52px; height: 52px; color: var(--gold-line); position: relative; }
.rt-thumb .ph-tag { position: absolute; bottom: 10px; left: 10px; font-size: 9.5px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--text-4); background: rgba(0,0,0,.4); padding: 4px 9px; border-radius: 999px; }
.rt-main { padding: var(--s-6); }
.rt-main .rt-name { font-family: var(--font-head); font-size: 22px; font-weight: 700; line-height: 1.15; letter-spacing: -.025em; }
.rt-main .rt-view { font-size: 13.5px; color: var(--gold-2); margin-top: 5px; font-weight: 500; letter-spacing: -.01em; }
.rt-specs { display: flex; flex-wrap: wrap; gap: var(--s-2) var(--s-5); margin-top: var(--s-5); }
.rt-spec { display: flex; flex-direction: column; gap: 2px; }
.rt-spec small { font-size: 10px; color: var(--text-4); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; }
.rt-spec b { font-size: 14px; color: var(--text-1); font-weight: 600; }
.rt-amenities { margin-top: var(--s-5); padding-top: var(--s-4); border-top: 1px solid var(--line); font-size: 13px; color: var(--text-2); line-height: 1.6; }

/* 아이템 리스트(다이닝·스파·체험) */
.chip-row { display: flex; gap: var(--s-2); overflow-x: auto; padding-bottom: var(--s-3); margin-bottom: var(--s-5); -webkit-overflow-scrolling: touch; }
.chip-row::-webkit-scrollbar { display: none; }
.chip { flex: none; font-size: 13px; font-weight: 600; color: var(--text-2); border: 1px solid var(--line); background: var(--ink-800);
  padding: 9px 16px; border-radius: 999px; transition: all .2s; white-space: nowrap; }
.chip.on { background: var(--gold-soft); color: var(--gold-2); border-color: var(--gold-line); }
.chip:not(.on):hover { border-color: var(--line-2); color: var(--text-1); }

.item-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(420px, 1fr)); gap: var(--s-4); }
.item-card { display: flex; gap: var(--s-4); padding: var(--s-4); background: var(--ink-800); border: 1px solid var(--line);
  border-radius: var(--r-lg); transition: border-color .25s, transform .25s, box-shadow .3s, background .25s; align-items: stretch; }
.item-card:hover { border-color: var(--gold-line); transform: translateY(-2px); box-shadow: var(--sh-2); background: var(--ink-750); }
.item-thumb { position: relative; width: 96px; flex: none; border-radius: var(--r-md); background: linear-gradient(135deg, var(--ink-700), var(--ink-850));
  display: grid; place-items: center; overflow: hidden; }
.item-thumb::after { content: ''; position: absolute; inset: 0; background: radial-gradient(120% 120% at 60% 20%, var(--gold-soft), transparent 60%); }
.item-thumb svg { width: 30px; height: 30px; color: var(--gold-line); position: relative; }
.item-thumb .ph-tag { position: absolute; bottom: 6px; left: 50%; transform: translateX(-50%); font-size: 8px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--text-4); white-space: nowrap; }
.item-main { flex: 1; min-width: 0; display: flex; flex-direction: column; padding: 4px 0; }
.item-main b { font-family: var(--font-head); font-size: 17px; font-weight: 700; line-height: 1.25; letter-spacing: -.02em; }
.item-main > span { font-size: 13px; color: var(--text-3); margin-top: 5px; line-height: 1.5; }
.item-side { display: flex; flex-direction: column; align-items: flex-end; justify-content: space-between; gap: var(--s-3); flex: none; padding: 4px 0; }
.item-price { font-family: var(--font-mono); font-size: 15px; font-weight: 600; color: var(--text-1); white-space: nowrap; letter-spacing: .01em; }
.item-price.free { color: var(--ok); font-family: var(--font-body); font-size: 13px; font-weight: 700; }
.item-meta-row { font-size: 11.5px; color: var(--text-3); margin-top: 8px; }

.tag { display: inline-flex; align-items: center; font-size: 10.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  color: var(--gold-2); background: var(--gold-soft); border: 1px solid var(--gold-line); padding: 4px 10px; border-radius: 999px; }

.add-btn { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 700; color: #1a1408;
  background: linear-gradient(135deg, var(--gold-2), var(--gold)); padding: 10px 16px; border-radius: 999px; transition: transform .14s var(--ease-spring), filter .2s; white-space: nowrap; }
.add-btn svg { width: 15px; height: 15px; }
.add-btn:active { transform: scale(.94); }
.add-btn:hover { filter: brightness(1.05); }
.add-btn.ghost { background: transparent; color: var(--gold-2); border: 1px solid var(--gold-line); }
.add-btn.ghost:hover { background: var(--gold-soft); }
.add-btn.done { background: rgba(111,191,142,.18); color: var(--ok); }

/* 서브 헤더(다이닝 장소·섹션) */
.sub-head { display: flex; align-items: baseline; gap: var(--s-3); margin: var(--s-7) 0 var(--s-4); }
.sub-head b { font-family: var(--font-head); font-size: 20px; font-weight: 700; letter-spacing: -.025em; }
.sub-head span { font-size: 13px; color: var(--text-3); }
.sub-head .hline { flex: 1; height: 1px; background: var(--line); }

/* 다이닝 베뉴(레스토랑/바) 카드 */
.venue-card { padding: var(--s-6); margin-bottom: var(--s-4); position: relative; overflow: hidden; }
.venue-card::before { content: ''; position: absolute; top: 0; right: 0; width: 200px; height: 200px; background: radial-gradient(circle at 100% 0%, var(--gold-soft), transparent 70%); pointer-events: none; }
.venue-head { display: flex; align-items: flex-start; gap: var(--s-4); }
.venue-ic { width: 48px; height: 48px; border-radius: var(--r-md); display: grid; place-items: center; background: var(--gold-soft); border: 1px solid var(--gold-line); color: var(--gold-2); flex: none; }
.venue-ic svg { width: 24px; height: 24px; }
.venue-info { flex: 1; }
.venue-info .vn { font-family: var(--font-head); font-size: 20px; font-weight: 700; line-height: 1.18; letter-spacing: -.025em; }
.venue-info .vd { font-size: 13.5px; color: var(--text-3); margin-top: 6px; line-height: 1.55; max-width: 560px; }
.venue-meta { display: flex; flex-wrap: wrap; gap: var(--s-2) var(--s-5); margin-top: var(--s-5); padding-top: var(--s-4); border-top: 1px solid var(--line); }
.venue-meta .vm { display: flex; flex-direction: column; gap: 2px; }
.venue-meta .vm small { font-size: 10px; color: var(--text-4); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; }
.venue-meta .vm b { font-size: 13.5px; color: var(--text-1); font-weight: 600; }
.venue-cta { margin-top: var(--s-5); }

/* 옵션 카드(컨시어지·하우스키핑·빌 진입) */
.option-card { display: flex; align-items: center; gap: var(--s-4); padding: var(--s-5) var(--s-6); margin-bottom: var(--s-3); cursor: pointer; }
.option-card:hover { border-color: var(--gold-line); background: var(--ink-750); }
.oc-ic { width: 46px; height: 46px; border-radius: var(--r-md); display: grid; place-items: center; background: var(--gold-soft); border: 1px solid var(--gold-line); color: var(--gold-2); flex: none; }
.oc-ic svg { width: 23px; height: 23px; }
.oc-main { flex: 1; min-width: 0; }
.oc-main b { font-family: var(--font-head); font-size: 17px; font-weight: 700; letter-spacing: -.02em; display: block; line-height: 1.25; }
.oc-main span { font-size: 13px; color: var(--text-3); margin-top: 3px; display: block; line-height: 1.45; }
.oc-arrow { width: 20px; height: 20px; color: var(--text-4); flex: none; transition: transform .25s, color .25s; }
.option-card:hover .oc-arrow { transform: translateX(3px); color: var(--gold-2); }

/* DND 토글(하우스키핑) */
.dnd-card { display: flex; align-items: center; gap: var(--s-4); padding: var(--s-5) var(--s-6); margin-bottom: var(--s-4); }
.dnd-card.active { border-color: var(--gold-line); background: linear-gradient(120deg, var(--gold-soft), transparent); }
.dnd-main { flex: 1; }
.dnd-main b { font-family: var(--font-head); font-size: 17px; font-weight: 700; letter-spacing: -.02em; display: block; }
.dnd-main span { font-size: 13px; color: var(--text-3); margin-top: 3px; display: block; }
.dnd-state { font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; margin-top: 6px; color: var(--text-4); }
.dnd-card.active .dnd-state { color: var(--gold-2); }
.toggle { width: 56px; height: 32px; border-radius: 999px; background: var(--ink-700); border: 1px solid var(--line-2); position: relative; flex: none; transition: background .3s; }
.toggle .knob { position: absolute; top: 3px; left: 3px; width: 24px; height: 24px; border-radius: 50%; background: var(--text-3); transition: transform .3s var(--ease-spring), background .3s; }
.dnd-card.active .toggle { background: var(--gold-soft); border-color: var(--gold-line); }
.dnd-card.active .toggle .knob { transform: translateX(24px); background: var(--gold-2); }

/* 폴리오(빌/체크아웃) */
.folio-card { padding: var(--s-6); margin-bottom: var(--s-5); }
.folio-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: var(--s-4); }
.folio-head .fh-room { font-size: 12px; color: var(--text-3); }
.folio-head .fh-room b { color: var(--gold-2); font-weight: 600; }
.folio-line { display: flex; align-items: center; justify-content: space-between; gap: var(--s-3); padding: var(--s-4) 0; border-top: 1px solid var(--line); }
.folio-line:first-of-type { border-top: none; }
.folio-line .fl-label { font-size: 14.5px; color: var(--text-1); }
.folio-line .fl-sub { font-size: 11px; color: var(--text-4); font-family: var(--font-mono); margin-top: 2px; }
.folio-line .fl-amt { font-family: var(--font-mono); font-size: 15px; font-weight: 600; color: var(--text-1); white-space: nowrap; }
.folio-total { display: flex; align-items: center; justify-content: space-between; margin-top: var(--s-5); padding-top: var(--s-5); border-top: 1px solid var(--gold-line); }
.folio-total .ft-label { font-family: var(--font-head); font-size: 17px; font-weight: 700; letter-spacing: -.02em; }
.folio-total .ft-amt { font-family: var(--font-mono); font-size: 26px; font-weight: 600; color: var(--gold-2); }

/* 지도 + 명소 */
.map-canvas { position: relative; height: 240px; border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--line);
  background: linear-gradient(135deg, var(--ink-750), var(--ink-850)); }
.map-canvas::before { content: ''; position: absolute; inset: 0;
  background-image: linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 40px 40px; opacity: .5; }
.map-canvas::after { content: ''; position: absolute; inset: 0; background: radial-gradient(60% 60% at 46% 40%, var(--gold-soft), transparent 70%); }
.map-canvas .pin { position: absolute; width: 14px; height: 14px; border-radius: 50% 50% 50% 0; background: var(--gold); transform: rotate(-45deg); box-shadow: 0 0 0 6px var(--gold-soft); }
.map-overlay-note { position: absolute; top: 14px; right: 14px; }
.place-row { display: flex; align-items: center; gap: var(--s-4); padding: var(--s-4) var(--s-5); }
.place-row:hover { border-color: var(--gold-line); }
.place-ic { width: 42px; height: 42px; border-radius: var(--r-sm); display: grid; place-items: center; background: var(--gold-soft); border: 1px solid var(--gold-line); color: var(--gold-2); flex: none; }
.place-ic svg { width: 21px; height: 21px; }
.place-main { flex: 1; min-width: 0; }
.place-main b { font-family: var(--font-head); font-size: 16px; font-weight: 700; letter-spacing: -.02em; display: block; line-height: 1.25; }
.place-main span { font-size: 12.5px; color: var(--text-3); margin-top: 2px; display: block; }
.dir-btn { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 700; color: var(--gold-2);
  border: 1px solid var(--gold-line); background: var(--gold-soft); padding: 9px 14px; border-radius: 999px; flex: none; transition: background .2s, transform .14s var(--ease-spring); }
.dir-btn svg { width: 15px; height: 15px; }
.dir-btn:active { transform: scale(.95); }

/* 시설(어메니티) */
.facility-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--s-4); }
.facility-card { padding: var(--s-6); }
.fac-head { display: flex; align-items: center; gap: var(--s-3); margin-bottom: var(--s-4); }
.fac-ic { width: 42px; height: 42px; border-radius: var(--r-sm); display: grid; place-items: center; background: var(--gold-soft); border: 1px solid var(--gold-line); color: var(--gold-2); flex: none; }
.fac-ic svg { width: 21px; height: 21px; }
.fac-head b { font-family: var(--font-head); font-size: 17px; font-weight: 700; letter-spacing: -.02em; }
.fac-rows { display: flex; flex-direction: column; gap: var(--s-2); }
.fac-row { display: flex; gap: var(--s-3); font-size: 13px; }
.fac-row .fr-k { color: var(--text-4); min-width: 60px; flex: none; font-weight: 600; font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase; align-self: center; }
.fac-row .fr-v { color: var(--text-1); font-weight: 500; line-height: 1.5; }

/* 상태 라벨(정직) */
.status { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 600; color: var(--text-3); }
.status .dot { width: 7px; height: 7px; border-radius: 50%; flex: none; }
.status.ok { color: var(--ok); } .status.ok .dot { background: var(--ok); }
.status.info { color: var(--info); } .status.info .dot { background: var(--info); }
.status.muted .dot { background: var(--text-4); }
.soon-chip { display: inline-flex; align-items: center; gap: 7px; font-size: 11px; font-weight: 700; color: var(--soon);
  background: rgba(185,160,106,.12); border: 1px solid rgba(185,160,106,.3); padding: 6px 11px; border-radius: 999px; letter-spacing: .02em; }
.soon-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--soon); flex: none; }

/* 빈 상태 */
.empty-state { text-align: center; padding: var(--s-12) var(--s-6); }
.empty-state .es-ic { width: 64px; height: 64px; margin: 0 auto var(--s-4); border-radius: 50%; display: grid; place-items: center; background: var(--gold-soft); border: 1px solid var(--gold-line); color: var(--gold-line); }
.empty-state .es-ic svg { width: 30px; height: 30px; }
.empty-state b { font-family: var(--font-head); font-size: 19px; font-weight: 700; letter-spacing: -.02em; display: block; color: var(--text-2); }
.empty-state span { font-size: 13px; color: var(--text-4); margin-top: 6px; display: block; }

/* ════════════════════════════════════════════════════════════════════════
 * 하단 주문 내역 바(룸 다이닝)
 * ════════════════════════════════════════════════════════════════════════ */
.cart-bar { position: absolute; left: 50%; bottom: calc(var(--s-5) + env(safe-area-inset-bottom, 0px)); transform: translate(-50%, 150%);
  width: min(560px, calc(100vw - 40px)); display: flex; align-items: center; gap: var(--s-4);
  background: var(--ink-750); border: 1px solid var(--gold-line); border-radius: 999px; padding: 10px 10px 10px 22px;
  box-shadow: var(--sh-3), var(--sh-gold); z-index: 20; transition: transform .42s var(--ease-spring); }
.cart-bar.on { transform: translate(-50%, 0); }
.cb-info { flex: 1; line-height: 1.1; }
.cb-info small { font-size: 10.5px; color: var(--text-3); font-weight: 600; letter-spacing: .06em; text-transform: uppercase; }
.cb-info b { font-family: var(--font-mono); font-size: 18px; font-weight: 600; color: var(--text-1); display: block; }
.cb-cta { display: inline-flex; align-items: center; gap: 9px; font-size: 14.5px; font-weight: 800; color: #1a1408;
  background: linear-gradient(135deg, var(--gold-2), var(--gold)); padding: 13px 22px; border-radius: 999px; transition: transform .14s var(--ease-spring), filter .2s; }
.cb-cta:active { transform: scale(.96); }
.cb-cta:hover { filter: brightness(1.05); }
.cb-count { background: rgba(0,0,0,.22); color: #1a1408; min-width: 24px; height: 24px; border-radius: 999px; display: grid; place-items: center; font-size: 13px; font-weight: 800; padding: 0 7px; }

/* ════════════════════════════════════════════════════════════════════════
 * 오버레이 — 바텀시트/모달(주문·예약·요청·폴리오·택시·길찾기)
 * ════════════════════════════════════════════════════════════════════════ */
html.sheet-open .views-host { overflow: hidden; }
.sheet-scrim { position: fixed; inset: 0; z-index: 100; display: flex; align-items: flex-end; justify-content: center;
  background: rgba(6,7,10,0); backdrop-filter: blur(0px); transition: background .3s, backdrop-filter .3s; }
.sheet-scrim.on { background: rgba(6,7,10,.62); backdrop-filter: blur(6px); }
.sheet { position: relative; width: min(560px, 100vw); max-height: 90dvh; background: var(--ink-850); border: 1px solid var(--line-2);
  border-radius: var(--r-2xl) var(--r-2xl) 0 0; box-shadow: var(--sh-3); display: flex; flex-direction: column; overflow: hidden;
  transform: translateY(100%); transition: transform .42s var(--ease); }
.sheet-scrim.on .sheet { transform: none; }
.sheet::before { content: ''; position: absolute; top: 10px; left: 50%; transform: translateX(-50%); width: 42px; height: 4px; border-radius: 999px; background: var(--line-2); }
.sheet-x { position: absolute; top: 16px; right: 16px; width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--line); background: var(--ink-800);
  display: grid; place-items: center; color: var(--text-3); z-index: 3; transition: color .2s, border-color .2s; }
.sheet-x svg { width: 18px; height: 18px; }
.sheet-x:hover { color: var(--text-1); border-color: var(--gold-line); }
.sheet-head { padding: var(--s-8) var(--s-7) var(--s-4); }
.sheet-head h2 { font-family: var(--font-head); font-size: 24px; font-weight: 700; letter-spacing: -.025em; line-height: 1.15; padding-right: 40px; }
.sheet-head p { font-size: 13.5px; color: var(--text-3); margin-top: 7px; line-height: 1.5; }
.sheet-body { padding: 0 var(--s-7) var(--s-5); overflow-y: auto; flex: 1; }
.sheet-foot { padding: var(--s-5) var(--s-7) calc(var(--s-7) + env(safe-area-inset-bottom, 0px)); border-top: 1px solid var(--line); display: flex; gap: var(--s-3); }
.sheet-foot.vert { flex-direction: column; }
.sheet-cta { flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 9px; font-size: 15.5px; font-weight: 800;
  color: #1a1408; background: linear-gradient(135deg, var(--gold-2), var(--gold)); padding: 16px; border-radius: var(--r-md); letter-spacing: -.01em; transition: transform .14s var(--ease-spring), filter .2s; }
.sheet-cta svg { width: 18px; height: 18px; }
.sheet-cta:active { transform: scale(.98); }
.sheet-cta:hover { filter: brightness(1.05); }
.sheet-cta.ghost { background: transparent; color: var(--text-1); border: 1px solid var(--line-2); }
.sheet-cta.ghost:hover { border-color: var(--gold-line); filter: none; background: var(--ink-800); }

.sheet-honest { display: flex; align-items: center; gap: var(--s-3); margin-top: var(--s-4); padding: var(--s-3) var(--s-4); background: var(--ink-800); border: 1px solid var(--line); border-radius: var(--r-md); }
.sheet-honest span:last-child { font-size: 12px; color: var(--text-3); line-height: 1.5; }

/* 주문 행·스텝퍼 */
.cart-row { display: flex; align-items: center; gap: var(--s-4); padding: var(--s-4) 0; border-top: 1px solid var(--line); }
.cart-row:first-child { border-top: none; }
.cr-main { flex: 1; min-width: 0; }
.cr-main b { font-size: 15px; font-weight: 600; display: block; line-height: 1.25; }
.cr-main span { font-family: var(--font-mono); font-size: 12.5px; color: var(--text-3); margin-top: 3px; display: block; }
.stepper { display: flex; align-items: center; gap: var(--s-2); background: var(--ink-800); border: 1px solid var(--line); border-radius: 999px; padding: 4px; }
.stepper.big { padding: 6px; gap: var(--s-3); }
.st-btn { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; color: var(--text-2); border: 1px solid var(--line); background: var(--ink-850); transition: all .15s; }
.stepper.big .st-btn { width: 42px; height: 42px; }
.st-btn svg { width: 17px; height: 17px; }
.st-btn:hover { border-color: var(--gold-line); color: var(--gold-2); }
.st-btn:active { transform: scale(.9); }
.st-n { min-width: 28px; text-align: center; font-size: 16px; font-weight: 700; font-variant-numeric: tabular-nums; }
.stepper.big .st-n { font-size: 19px; min-width: 40px; }

/* 결제 분해 */
.pay-breakdown { margin-top: var(--s-5); padding: var(--s-5); background: var(--ink-800); border: 1px solid var(--line); border-radius: var(--r-md); }
.pay-line { display: flex; align-items: center; justify-content: space-between; gap: var(--s-3); padding: var(--s-2) 0; font-size: 13.5px; color: var(--text-3); }
.pay-line b { font-family: var(--font-mono); color: var(--text-2); font-weight: 600; }
.pay-line.total { margin-top: var(--s-2); padding-top: var(--s-4); border-top: 1px solid var(--gold-line); font-size: 15px; color: var(--text-1); font-weight: 700; }
.pay-line.total b { font-size: 20px; color: var(--gold-2); }

/* 요약/영수증 라인 */
.sum-block { margin-top: var(--s-4); }
.sum-line { display: flex; align-items: center; justify-content: space-between; gap: var(--s-3); padding: var(--s-3) 0; border-top: 1px solid var(--line); font-size: 14px; }
.sum-line:first-child { border-top: none; }
.sum-line span { color: var(--text-2); }
.sum-line b { font-family: var(--font-mono); font-weight: 600; color: var(--text-1); white-space: nowrap; }

/* 필드(요청·날짜·시간) */
.field-label { display: block; font-size: 12px; font-weight: 700; color: var(--text-3); letter-spacing: .06em; text-transform: uppercase; margin: var(--s-5) 0 var(--s-2); }
.field { width: 100%; background: var(--ink-800); border: 1px solid var(--line-2); border-radius: var(--r-md); padding: 13px 15px; font-size: 15px; color: var(--text-1); transition: border-color .2s; resize: vertical; }
.field:focus { outline: none; border-color: var(--gold-line); }
.field::placeholder { color: var(--text-4); }
.time-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(78px, 1fr)); gap: var(--s-2); margin-top: var(--s-2); }
.time-slot { font-family: var(--font-mono); font-size: 14px; font-weight: 600; color: var(--text-2); border: 1px solid var(--line); background: var(--ink-800); padding: 11px 0; border-radius: var(--r-sm); text-align: center; transition: all .18s; }
.time-slot.on { background: var(--gold-soft); color: var(--gold-2); border-color: var(--gold-line); }
.time-slot:not(.on):hover { border-color: var(--line-2); color: var(--text-1); }

/* 도착지 카드(택시/길찾기) */
.dest-card { display: flex; align-items: center; gap: var(--s-4); padding: var(--s-4); background: var(--ink-800); border: 1px solid var(--line); border-radius: var(--r-md); margin-top: var(--s-4); }
.dest-main { flex: 1; min-width: 0; }
.dest-main small { font-size: 11px; color: var(--text-4); font-weight: 600; letter-spacing: .06em; text-transform: uppercase; display: block; }
.dest-main b { font-size: 15.5px; font-weight: 600; margin-top: 2px; display: block; }

/* 성공/체크 시트 */
.sheet-success { text-align: center; padding: var(--s-9) var(--s-7) var(--s-4); }
.ss-check { width: 72px; height: 72px; margin: 0 auto var(--s-5); border-radius: 50%; display: grid; place-items: center;
  background: rgba(111,191,142,.14); border: 1px solid rgba(111,191,142,.4); color: var(--ok); }
.ss-check svg { width: 36px; height: 36px; }
.sheet-success h2 { font-family: var(--font-head); font-size: 24px; font-weight: 700; letter-spacing: -.025em; }
.sheet-success p { font-size: 14px; color: var(--text-3); margin-top: 8px; line-height: 1.5; }
.receipt-meta { display: flex; align-items: center; justify-content: space-between; padding: var(--s-4); background: var(--ink-800); border: 1px solid var(--line); border-radius: var(--r-md); margin-bottom: var(--s-4); }
.receipt-meta span { font-size: 12px; color: var(--text-3); }
.receipt-meta b.mono { font-family: var(--font-mono); font-size: 14px; color: var(--gold-2); letter-spacing: .03em; }

/* ════════════════════════════════════════════════════════════════════════
 * ★ 인룸 태블릿(가로 ≥1024) — 풀스크린 럭셔리(2단 레이아웃·큰 여백)
 * ════════════════════════════════════════════════════════════════════════ */
@media (min-width: 1024px) {
  .home-split { grid-template-columns: minmax(300px, 380px) 1fr; align-items: start; gap: var(--s-9); }
  .home-hero { position: sticky; top: 0; padding-top: var(--s-4); }
  .tile-grid { grid-template-columns: repeat(2, 1fr); gap: var(--s-5); }
  .promo-rail { height: clamp(300px, 38vh, 460px); }
  /* 오버레이를 중앙 모달로(태블릿 풀스크린 — 하단 시트 대신 우아한 카드) */
  .sheet-scrim { align-items: center; }
  .sheet { border-radius: var(--r-2xl); max-height: 86dvh; transform: translateY(20px) scale(.97); opacity: 0; transition: transform .42s var(--ease), opacity .3s; }
  .sheet::before { display: none; }
  .sheet-scrim.on .sheet { transform: none; opacity: 1; }
  .cart-bar { bottom: calc(var(--s-7) + env(safe-area-inset-bottom, 0px)); }
}
@media (min-width: 1440px) {
  .tile .t-body b { font-size: 21px; }
  .view-pad, .home-wrap { padding-left: var(--s-9); padding-right: var(--s-9); }
}

/* 초대형 인룸 디스플레이(43"+ 가로) — 더 넉넉하게 */
@media (min-width: 1800px) {
  :root { --maxw: 1560px; }
  .tile-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ════════════════════════════════════════════════════════════════════════
 * 모바일(QR 세로) — 한 손 도달·큰 터치 타깃
 * ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 720px) {
  .topbar { flex-wrap: wrap; gap: var(--s-3); padding: var(--s-3) var(--s-4); padding-top: calc(var(--s-3) + env(safe-area-inset-top, 0px)); }
  .brand-meta b { font-size: 17px; max-width: 52vw; }
  .brand-mark { width: 42px; height: 42px; font-size: 26px; }
  .top-clock { order: 3; }
  .topbar-spacer { display: none; }
  .checkout-pill { order: 4; margin-left: auto; }
  .room-chip { order: 2; }
  .lang-switch { order: 5; width: 100%; justify-content: space-between; }
  .lang-switch button { flex: 1; justify-content: center; gap: 5px; padding: 8px 4px; }
  .lang-switch button.on { padding: 7px 4px; }
  .lang-switch button .lname { display: none; }            /* 풀네임 → 모바일은 숨기고 */
  .lang-switch button .lname-short { display: inline; }    /* 짧은 라벨(국기+라벨 유지) */
  .lang-switch button .flag { font-size: 16px; }
  .brand-toggle { order: 6; }
  .brand-toggle .bt-name { display: none; }
  .theme-toggle { order: 7; }

  .home-wrap, .view-pad { padding: var(--s-5) var(--s-4) var(--s-10); }
  .promo-rail { height: clamp(200px, 30vh, 280px); border-radius: var(--r-xl); margin-bottom: var(--s-6); }
  .home-split { gap: var(--s-6); }
  .home-hero { text-align: left; }
  .tile-grid { grid-template-columns: 1fr 1fr; gap: var(--s-3); }
  .tile { min-height: 124px; padding: var(--s-4); }
  .tile .t-ic { width: 40px; height: 40px; }
  .tile .t-ic svg { width: 21px; height: 21px; }
  .tile .t-body b { font-size: 16px; }
  .tile .t-body span { font-size: 11px; }
  .tile .t-arrow { display: none; }

  .sec-head h1 { font-size: 28px; }
  .sec-head { margin-bottom: var(--s-6); }
  .guide-grid, .item-list, .facility-grid { grid-template-columns: 1fr; }
  .roomtype-card { grid-template-columns: 1fr; }
  .rt-thumb { min-height: 140px; }
  .item-card { gap: var(--s-3); padding: var(--s-3); flex-wrap: wrap; }
  .item-thumb { width: 72px; }
  .item-main b { font-size: 16px; }
  .item-side { width: 100%; flex-direction: row; align-items: center; padding-top: var(--s-2); border-top: 1px solid var(--line); }
  .sheet { width: 100vw; max-height: 92dvh; }
  .sheet-head h2 { font-size: 23px; }
  .cart-bar { width: calc(100vw - 24px); padding: 9px 9px 9px 18px; }
  .folio-total .ft-amt { font-size: 22px; }
}
@media (max-width: 400px) {
  .tile-grid { grid-template-columns: 1fr; }
  .tile { min-height: 100px; }
}

/* ── 모션 감소 선호 ─────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  .promo-slide.on .promo-bg { animation: none; }
  .view { animation: none; }
}
