/* =================================================================
   Gantt (Stage 3 + 4) — HotelMap styling
   ================================================================= */
.gantt { width:100%; border:1px solid var(--border); border-radius:var(--radius-card); overflow:hidden; background:var(--surface); box-shadow:var(--shadow-card); }

/* column template shared by header + rows + foot */
.g-cols { display:grid; grid-template-columns: 300px 86px 96px 1fr; }

.g-head { background:var(--surface-sunken); border-bottom:1px solid var(--border); }
.g-head .g-cell { padding:12px 14px; font-size: var(--fs-xs); font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--text-muted); display:flex; align-items:center; }
.g-head .g-days { display:grid; }
.g-day { padding:8px 4px; text-align:center; border-left:1px solid var(--border); }
.g-day .dow { font-size: var(--fs-xs); color:var(--text-muted); font-weight:600; }
.g-day .dom { font-size: var(--fs-md); color:var(--text-heading); font-weight:700; }
.g-day.event .dom { color:var(--accent); }
.g-day.event { background:var(--accent-tint); }

.g-row { border-bottom:1px solid var(--border); transition:background .1s; }
.g-row:last-child { border-bottom:0; }
.g-row:hover { background:var(--surface-hover); }
.g-cell { padding:12px 14px; display:flex; align-items:center; }

/* room info cell */
.g-info { flex-direction:column; align-items:stretch; gap:6px; border-right:1px solid var(--border); }
.g-info .gi-top { display:flex; align-items:center; gap:10px; }
.g-info .gi-num { font-size: var(--fs-xs); font-weight:700; color:var(--text-faint); letter-spacing:.06em; }
.g-info .gi-bed { color:var(--text-muted); display:flex; }
.g-guest { background:var(--surface-sunken); border-radius:8px; padding:6px 10px; font-size: var(--fs-sm); color:var(--text-heading); font-weight:600; cursor:pointer; display:flex; justify-content:space-between; align-items:center; }
.g-guest.placeholder { color:var(--text-faint); font-weight:500; font-style:italic; border:1px dashed var(--border); background:transparent; }
.g-guest:hover { background:var(--accent-tint); }
.g-guest + .g-guest { margin-top:4px; }
.gi-type { font-size: var(--fs-xs); color:var(--text-muted); display:flex; align-items:center; gap:8px; white-space:nowrap; }
.gi-type .up-link { color:var(--link); font-weight:600; cursor:pointer; margin-left:auto; padding-left:8px; }
.gi-type .up-link:hover { text-decoration:underline; text-underline-offset:2px; }
.gi-type .up-tag { color:var(--accent-strong); font-weight:700; }

/* diff-from-default indicator */
.gi-diff { font-size: var(--fs-2xs); font-weight:600; color:var(--accent-strong); background:var(--accent-tint); padding:2px 8px; border-radius:var(--radius-pill); margin-left:auto; cursor:help; white-space:nowrap; }

/* dietary / accessibility chips */
.diet-chips { display:flex; gap:4px; flex-wrap:wrap; margin-top:8px; align-items:center; }
.diet-chip { width:18px; height:18px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size: var(--fs-2xs); cursor:help; box-shadow:inset 0 0 0 1px rgba(var(--black-rgb), .06); }
.diet-chip[data-diet="vegetarian"] { background:var(--diet-bg-vegetarian); }
.diet-chip[data-diet="vegan"]      { background:var(--diet-bg-vegan); }
.diet-chip[data-diet="gluten-free"]{ background:var(--diet-bg-gluten-free); }
.diet-chip[data-diet="halal"]      { background:var(--diet-bg-halal); }
.diet-chip[data-diet="kosher"]     { background:var(--diet-bg-kosher); }
.diet-chip[data-diet="wheelchair"] { background:var(--diet-bg-wheelchair); }
.diet-chip[data-diet="kids"]       { background:var(--diet-bg-kids); }
.diet-chip.add { background:transparent; border:1.5px dashed var(--text-faint); color:var(--text-faint); cursor:pointer; font-weight:600; }
.diet-chip.add:hover { border-color:var(--accent); color:var(--accent); }

/* pay-status slivers (stage 4) */
.gantt.pay-status .g-info { padding-bottom:10px; }
.gi-status { font-size: var(--fs-xs); font-weight:600; margin-top:8px; letter-spacing:.005em; }
.gi-status.will-charge { color:var(--text-heading); }
.gi-status.invited { color:var(--status-danger); }
.gi-status.empty { color:var(--status-danger); }
.gantt.pay-status .g-pay { position:relative; background:var(--surface-warm); }
.gantt.pay-status .pay-chip { pointer-events:none; }
.gantt.pay-status .g-row[data-accept] .g-pay::after {
  content:''; position:absolute; top:9px; right:9px; width:8px; height:8px; border-radius:50%;
  box-shadow:0 0 0 1.5px var(--neutral-0);
}
.gantt.pay-status .g-row[data-accept="will-charge"] .g-pay::after { background:var(--text-heading); }
.gantt.pay-status .g-row[data-accept="invited"] .g-pay::after { background:var(--status-danger); }
.gantt.pay-status .g-row[data-accept="empty"] .g-pay::after { background:var(--status-danger); animation:payPulse 1.4s ease-in-out infinite; }
@keyframes payPulse { 0%,100%{ opacity:1; transform:scale(1);} 50%{ opacity:.4; transform:scale(1.35);} }

.dot-leg { width:9px; height:9px; border-radius:50%; display:inline-block; }
.dot-leg.ink { background:var(--text-heading); }
.dot-leg.coral { background:var(--status-danger); }
.dot-leg.coral.pulse { animation:payPulse 1.4s ease-in-out infinite; }
.dot-leg.good { background:var(--status-success); }
.dot-leg.amber { background:var(--status-warning); }
.dot-leg.blue { background:var(--link); }
.dot-leg.grey { background:var(--text-faint); }

/* manage-mode status slivers + per-row actions */
.gi-status.confirmed { color:var(--status-success); }
.gi-status.awaiting  { color:var(--status-warning); }
.gi-status.modified  { color:var(--link); }
.gi-status.cancelled { color:var(--text-faint); }
.gantt.manage-status .g-row[data-accept] .g-pay::after { content:''; position:absolute; top:9px; right:9px; width:8px; height:8px; border-radius:50%; box-shadow:0 0 0 1.5px var(--neutral-0); }
.gantt.manage-status .g-pay { position:relative; }
.gantt.manage-status .g-row[data-accept="confirmed"] .g-pay::after { background:var(--status-success); }
.gantt.manage-status .g-row[data-accept="awaiting"]  .g-pay::after { background:var(--status-warning); animation:payPulse 1.4s ease-in-out infinite; }
.gantt.manage-status .g-row[data-accept="modified"]  .g-pay::after { background:var(--link); }
.gantt.manage-status .g-row[data-accept="cancelled"] .g-pay::after { background:var(--text-faint); }
.g-row.is-cancelled { opacity:.5; }
.g-row.is-cancelled .g-guest, .g-row.is-cancelled .stay-bar { text-decoration:line-through; }
.g-row.is-cancelled .stay-bar { background:var(--text-faint); text-decoration:none; box-shadow:none; }
.gi-manage { color:var(--link); font-weight:600; cursor:pointer; margin-left:6px; }
.gi-manage:hover { text-decoration:underline; }
.gi-itin { color:var(--link); font-weight:600; cursor:pointer; margin-left:8px; }
.gi-itin:hover { text-decoration:underline; }

/* =================================================================
   Stage 6 — Manage view
   ================================================================= */
.mg-banner { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
  background:var(--accent-tint); border:1.5px solid var(--accent); border-radius:var(--radius-card); padding:14px 18px; margin-bottom:16px; }
.mg-banner.warn { background:var(--status-warning-tint); border-color:var(--status-warning); }
.mg-banner.cancelled { background:var(--surface-sunken); border-color:var(--border); }
.mg-bn-main { display:flex; align-items:center; gap:10px; font-size: var(--fs-sm); color:var(--text-heading); }
.mg-bn-main b { font-weight:700; }
.mg-bn-icon { font-size: var(--fs-lg); }
.mg-days { color:var(--accent-strong); }
.mg-banner.warn .mg-days { color:var(--status-warning); }
.mg-bn-warn { font-size: var(--fs-sm); color:var(--status-danger); font-weight:600; }

.mg-actions { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.mg-act { height:38px; padding:0 15px; border-radius:var(--radius-pill); border:1.5px solid var(--border); background:var(--surface);
  color:var(--text-body); font-size: var(--fs-sm); font-weight:600; cursor:pointer; transition:all .12s; }
.mg-act:hover { border-color:var(--accent); color:var(--accent-strong); }
.mg-act.danger { color:var(--status-danger); }
.mg-act.danger:hover { border-color:var(--status-danger); background:var(--status-danger-tint); }

/* side panel — activity + messages */
.mg-side { display:flex; flex-direction:column; padding:0; }
.mg-tabs { display:flex; flex-shrink:0; border-bottom:1px solid var(--border); }
.mg-tab { flex:1; height:48px; border:0; background:none; font-family:var(--font-sans); font-size: var(--fs-sm); font-weight:600;
  color:var(--text-muted); cursor:pointer; border-bottom:2px solid transparent; }
.mg-tab.active { color:var(--accent-strong); border-bottom-color:var(--accent); }
.mg-tabpane { flex:1; overflow-y:auto; padding:18px 20px; }
.mg-tabpane[data-pane="messages"] { display:flex; flex-direction:column; padding:0; }

.mg-party-card { background:var(--surface-sunken); border-radius:var(--radius-row); padding:14px 16px; margin-bottom:18px; }
.mg-pc-ref { font-size: var(--fs-2xs); font-weight:700; letter-spacing:.08em; color:var(--text-muted); font-family:'IBM Plex Mono',monospace; }
.mg-pc-hotel { font-size: var(--fs-md); font-weight:700; color:var(--text-heading); margin-top:3px; }
.mg-pc-meta { font-size: var(--fs-sm); color:var(--text-muted); margin-top:2px; font-feature-settings:"tnum" 1; }
.mg-pc-finance { display:flex; justify-content:space-between; gap:10px; margin-top:10px; padding-top:10px; border-top:1px solid var(--border); font-size: var(--fs-xs); }
.mg-pc-finance span:first-child { color:var(--status-success); font-weight:600; }
.mg-finance-cc { color:var(--link); font-weight:600; cursor:pointer; }
.mg-finance-cc.done { color:var(--status-success); cursor:default; }

/* invite + response tracking */
.mg-invites { margin-top:12px; padding-top:12px; border-top:1px solid var(--border); }
.mg-inv-head { display:flex; justify-content:space-between; align-items:baseline; font-size: var(--fs-xs); color:var(--text-muted); margin-bottom:7px; }
.mg-inv-head b { color:var(--text-heading); font-weight:700; font-feature-settings:"tnum" 1; }
.mg-inv-bar { height:6px; border-radius:var(--radius-pill); background:var(--surface-sunken-2); overflow:hidden; }
.mg-inv-bar span { display:block; height:100%; background:var(--status-success); border-radius:var(--radius-pill); transition:width .3s ease; }
.mg-inv-legend { display:flex; flex-wrap:wrap; gap:10px; margin-top:8px; font-size: var(--fs-xs); }
.mg-inv-legend .mi { font-weight:600; }
.mg-inv-legend .mi.good { color:var(--status-success); }
.mg-inv-legend .mi.amber { color:var(--status-warning); }
.mg-inv-legend .mi.grey { color:var(--text-faint); }

.mg-log-item { display:flex; gap:11px; padding:9px 0; }
.mg-log-dot { width:8px; height:8px; border-radius:50%; background:var(--accent); margin-top:6px; flex-shrink:0; box-shadow:0 0 0 3px var(--accent-tint); }
.mg-log-body { flex:1; }
.mg-log-txt { font-size: var(--fs-sm); color:var(--text-body); line-height:1.45; }
.mg-log-txt b { color:var(--text-heading); font-weight:600; }
.mg-log-t { font-size: var(--fs-xs); color:var(--text-faint); margin-top:1px; }

.mg-thread { flex:1; overflow-y:auto; padding:18px 20px; display:flex; flex-direction:column; gap:12px; }
.mg-msg { max-width:84%; }
.mg-msg.you { align-self:flex-end; text-align:right; }
.mg-msg-bubble { display:inline-block; padding:9px 13px; border-radius:14px; font-size: var(--fs-sm); line-height:1.45; text-align:left; }
.mg-msg.hotel .mg-msg-bubble { background:var(--surface-sunken); color:var(--text-heading); border-bottom-left-radius:4px; }
.mg-msg.you .mg-msg-bubble { background:var(--accent); color:var(--neutral-0); border-bottom-right-radius:4px; }
.mg-msg-t { font-size: var(--fs-2xs); color:var(--text-faint); margin-top:3px; }
.mg-compose { flex-shrink:0; display:flex; gap:8px; padding:14px 18px; border-top:1px solid var(--border); }
.mg-compose input { flex:1; height:42px; border:1.5px solid var(--border); border-radius:var(--radius-button); padding:0 12px; font-family:var(--font-sans); font-size: var(--fs-sm); }
.mg-compose input:focus { outline:none; border-color:var(--accent); }
.mg-compose .hm-btn { height:42px; padding:0 18px; }

/* manage popover (row menu, dialogs) */
.mg-pop { position:fixed; z-index:240; background:var(--neutral-0); border-radius:12px; box-shadow:var(--shadow-float); padding:8px; width:240px; display:none; }
.mg-pop.show { display:block; }
.mgp-title { font-size: var(--fs-sm); font-weight:700; color:var(--text-heading); padding:8px 10px 10px; }
.mgp-item { display:flex; justify-content:space-between; align-items:center; gap:10px; width:100%; height:40px; padding:0 10px;
  border:0; background:none; border-radius:8px; font-family:var(--font-sans); font-size: var(--fs-sm); font-weight:500; color:var(--text-body); cursor:pointer; text-align:left; }
.mgp-item span { font-size: var(--fs-xs); color:var(--text-muted); font-weight:600; }
.mgp-item:hover:not(:disabled) { background:var(--accent-tint); color:var(--accent-strong); }
.mgp-item:disabled { opacity:.4; cursor:not-allowed; }
.mgp-item.danger { color:var(--status-danger); }
.mgp-item.danger:hover { background:var(--status-danger-tint); }
.mgp-body { font-size: var(--fs-sm); color:var(--text-muted); line-height:1.5; padding:0 10px 12px; }
.mgp-body b { color:var(--text-heading); }
.mgp-input { width:100%; height:42px; border:1.5px solid var(--border); border-radius:8px; padding:0 12px; font-family:var(--font-sans); font-size: var(--fs-sm); margin:4px 0 10px; }
.mgp-input:focus { outline:none; border-color:var(--accent); }
.mgp-row { display:flex; gap:8px; padding:0 2px 2px; }
.mgp-row .hm-btn { flex:1; height:42px; }

.mg-toast { position:fixed; bottom:28px; left:50%; transform:translateX(-50%) translateY(20px); z-index:300;
  background:var(--text-heading); color:var(--neutral-0); font-size: var(--fs-sm); font-weight:500; padding:12px 20px; border-radius:var(--radius-pill);
  box-shadow:var(--shadow-float); opacity:0; pointer-events:none; transition:opacity .2s, transform .2s; }
.mg-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* =================================================================
   Doc — invoice / quote sheet
   ================================================================= */
.doc-overlay { position:fixed; inset:0; z-index:280; display:none; }
.doc-overlay.show { display:block; }
.doc-scrim { position:absolute; inset:0; background:rgba(var(--scrim-rgb), .5); }
.doc-sheet { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:min(680px,94vw); max-height:92vh; display:flex; flex-direction:column; }
.doc-toolbar { display:flex; align-items:center; justify-content:space-between; padding:0 4px 12px; }
.doc-kind { color:var(--neutral-0); font-size: var(--fs-sm); font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.doc-tools { display:flex; align-items:center; gap:10px; }
.doc-tools .hm-btn { height:40px; }
.doc-x { width:40px; height:40px; border-radius:50%; border:0; background:rgba(var(--on-dark-rgb), .16); color:var(--neutral-0); font-size: var(--fs-md); cursor:pointer; }
.doc-x:hover { background:rgba(var(--on-dark-rgb), .28); }
.doc-paper { background:var(--neutral-0); border-radius:var(--radius-float); overflow-y:auto; padding:36px 40px 32px; box-shadow:var(--shadow-float); }

.doc-head { display:flex; align-items:flex-start; justify-content:space-between; gap:20px; padding-bottom:22px; border-bottom:2px solid var(--text-heading); }
.doc-brand { display:flex; align-items:center; gap:8px; }
.doc-dot { width:10px; height:10px; border-radius:50%; background:var(--accent); }
.doc-mark { font-size: var(--fs-md); font-weight:700; letter-spacing:.18em; color:var(--text-heading); }
.doc-sub-mark { font-size: var(--fs-xs); color:var(--text-muted); margin-left:4px; }
.doc-meta { text-align:right; }
.doc-meta-row { font-size: var(--fs-xs); color:var(--text-muted); display:flex; gap:12px; justify-content:flex-end; padding:1px 0; }
.doc-meta-row b { color:var(--text-heading); font-weight:600; font-feature-settings:"tnum" 1; }

.doc-parties { display:grid; grid-template-columns:1fr 1fr; gap:24px; padding:22px 0; border-bottom:1px solid var(--border); }
.doc-pl { font-size: var(--fs-2xs); font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); margin-bottom:5px; }
.doc-pv { font-size: var(--fs-md); font-weight:700; color:var(--text-heading); }
.doc-pm { font-size: var(--fs-sm); color:var(--text-muted); margin-top:2px; }
.doc-refs { font-size: var(--fs-xs); color:var(--text-body); margin-top:6px; font-family:'IBM Plex Mono',monospace; }

.doc-table { width:100%; border-collapse:collapse; margin:18px 0 6px; }
.doc-table th { font-size: var(--fs-2xs); font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--text-muted); text-align:left; padding:0 8px 10px; border-bottom:1px solid var(--border); }
.doc-table th.r, .doc-table td.r { text-align:right; }
.doc-table td { padding:11px 8px; border-bottom:1px solid var(--border); font-size: var(--fs-sm); color:var(--text-body); vertical-align:top; }
.doc-num { color:var(--text-faint); font-family:'IBM Plex Mono',monospace; font-size: var(--fs-xs); }
.doc-guest { font-weight:600; color:var(--text-heading); }
.doc-payer { font-size: var(--fs-xs); color:var(--text-muted); margin-top:1px; }
.doc-dates { font-size: var(--fs-xs); color:var(--text-muted); margin-top:1px; }
.doc-amt { font-weight:600; color:var(--text-heading); font-feature-settings:"tnum" 1; }

.doc-totals { margin:14px 0 0; }
.doc-tot-row { display:flex; justify-content:space-between; font-size: var(--fs-sm); color:var(--text-muted); padding:4px 8px; }
.doc-tot-row.grand { border-top:2px solid var(--text-heading); margin-top:8px; padding-top:12px; font-size: var(--fs-md); font-weight:700; color:var(--text-heading); }
.doc-tot-row.grand span:last-child { font-feature-settings:"tnum" 1; }
.doc-extax { font-size: var(--fs-xs); font-weight:400; color:var(--text-faint); }

.doc-foot { margin-top:24px; padding-top:18px; border-top:1px solid var(--border); }
.doc-share { display:flex; align-items:baseline; gap:10px; background:var(--surface-sunken); border-radius:8px; padding:10px 14px; margin-bottom:12px; }
.doc-share-l { font-size: var(--fs-xs); font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--text-muted); white-space:nowrap; }
.doc-share-u { font-size: var(--fs-sm); color:var(--accent-strong); font-family:'IBM Plex Mono',monospace; }
.doc-note { font-size: var(--fs-xs); color:var(--text-muted); line-height:1.55; margin:0; }

@media print {
  body.doc-printing > *:not(.doc-overlay) { display:none !important; }
  body.doc-printing .doc-overlay { display:block !important; position:static; }
  body.doc-printing .doc-scrim, body.doc-printing .doc-toolbar { display:none !important; }
  body.doc-printing .doc-sheet { position:static; transform:none; width:100%; max-height:none; }
  body.doc-printing .doc-paper { box-shadow:none; border-radius:0; max-height:none; overflow:visible; padding:0; }
}

/* =================================================================
   Guest itinerary (ResLink-style self-service surface)
   ================================================================= */
.gi-overlay { position:fixed; inset:0; z-index:285; display:none; }
.gi-overlay.show { display:block; }
.gi-scrim { position:absolute; inset:0; background:rgba(var(--scrim-rgb), .5); }
.gi-sheet { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:min(440px,94vw); max-height:92vh; display:flex; flex-direction:column; }
.gi-toolbar { display:flex; align-items:center; justify-content:space-between; padding:0 4px 12px; }
.gi-kind { color:var(--neutral-0); font-size: var(--fs-sm); font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.gi-x { width:40px; height:40px; border-radius:50%; border:0; background:rgba(var(--on-dark-rgb), .16); color:var(--neutral-0); font-size: var(--fs-md); cursor:pointer; }
.gi-x:hover { background:rgba(var(--on-dark-rgb), .28); }
.gi-card { background:var(--neutral-0); border-radius:var(--radius-float); overflow-y:auto; box-shadow:var(--shadow-float); }
.gi-url { background:var(--text-heading); color:var(--neutral-0); font-size: var(--fs-xs); padding:9px 16px; text-align:center; }
.gi-url b { font-family:'IBM Plex Mono',monospace; font-weight:500; }
.gi-hero { height:130px; position:relative; display:flex; flex-direction:column; justify-content:space-between; padding:14px 18px; }
.gi-hero-brand { display:flex; align-items:center; gap:7px; color:var(--neutral-0); font-size: var(--fs-sm); font-weight:700; letter-spacing:.16em; text-shadow:0 1px 4px rgba(var(--black-rgb), .25); }
.gi-hero-brand .doc-dot { background:var(--neutral-0); }
.gi-hero-foot { color:var(--neutral-0); text-shadow:0 1px 6px rgba(var(--black-rgb), .35); }
.gi-hero-name { font-size: var(--fs-lg); font-weight:700; }
.gi-hero-loc { font-size: var(--fs-xs); opacity:.92; }
.gi-body { padding:20px 22px 24px; }
.gi-eyebrow { font-size: var(--fs-xs); font-weight:700; letter-spacing:.09em; text-transform:uppercase; color:var(--accent); margin:0; }
.gi-title { font-size: var(--fs-2xl); font-weight:700; color:var(--text-heading); margin:5px 0 16px; letter-spacing:-0.01em; }
.gi-facts { display:flex; flex-direction:column; gap:0; border:1px solid var(--border); border-radius:var(--radius-row); overflow:hidden; margin-bottom:16px; }
.gi-fact { display:flex; justify-content:space-between; gap:14px; padding:11px 14px; border-bottom:1px solid var(--border); }
.gi-fact:last-child { border-bottom:0; }
.gi-fl { font-size: var(--fs-xs); color:var(--text-muted); }
.gi-fv { font-size: var(--fs-sm); font-weight:600; color:var(--text-heading); text-align:right; }
.gi-codes { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; margin-bottom:8px; }
.gi-code { background:var(--accent-tint); border-radius:8px; padding:9px 10px; text-align:center; }
.gi-cl { display:block; font-size: var(--fs-2xs); font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--accent-strong); }
.gi-cv { display:block; font-size: var(--fs-sm); font-weight:700; color:var(--text-heading); font-family:'IBM Plex Mono',monospace; margin-top:2px; }
.gi-codenote { font-size: var(--fs-xs); color:var(--text-muted); line-height:1.5; margin:0 0 18px; }
.gi-section { border-top:1px solid var(--border); padding-top:14px; margin-bottom:14px; }
.gi-sec-title { font-size: var(--fs-xs); font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text-muted); margin-bottom:8px; }
.gi-arrival { font-size: var(--fs-sm); color:var(--text-body); line-height:1.7; }
.gi-arrival b { color:var(--text-heading); }
.gi-selfserve { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.gi-ss-field { display:flex; flex-direction:column; gap:5px; font-size: var(--fs-xs); color:var(--text-muted); }
.gi-ss-field input { height:40px; border:1.5px solid var(--border); border-radius:8px; padding:0 11px; font-family:var(--font-sans); font-size: var(--fs-sm); }
.gi-ss-field input:focus { outline:none; border-color:var(--accent); }
.gi-ss-note { font-size: var(--fs-xs); color:var(--text-muted); line-height:1.5; margin:8px 0 0; }
.gi-actions { display:flex; flex-direction:column; gap:8px; margin-top:18px; }

/* who-pays + breakfast chips */
.g-pay, .g-bk { justify-content:center; border-right:1px solid var(--border); }
.pay-chip { width:54px; height:34px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size: var(--fs-xs); font-weight:700; cursor:pointer; user-select:none; border:1.5px solid var(--border); }
.pay-chip.booker { background:var(--accent); color:var(--neutral-0); border-color:var(--accent); }
.pay-chip.guest { background:var(--surface); color:var(--accent-strong); border-color:var(--accent); }
.bk-chip { width:46px; height:34px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size: var(--fs-xs); font-weight:700; cursor:pointer; border:1.5px solid var(--border); color:var(--text-muted); }
.bk-chip.yes { background:var(--accent-tint); color:var(--accent-strong); border-color:var(--accent); }

/* track + bars */
.g-track { position:relative; padding:0; }
.g-track .g-grid { position:absolute; inset:0; display:grid; }
.g-track .g-gcell { border-left:1px solid var(--border); }
.g-track .g-gcell.event { background:rgba(var(--shadow-rgb), .05); }
.stay-bar {
  position:absolute; top:14px; bottom:14px;
  background:var(--accent); border-radius:8px;
  display:flex; align-items:center; justify-content:center; gap:8px;
  color:var(--neutral-0); cursor:grab; box-shadow:0 2px 8px rgba(var(--shadow-rgb), .32);
  min-width:54px; z-index:2;
}
.stay-bar:active { cursor:grabbing; }
.stay-bar .nights { font-size: var(--fs-md); font-weight:700; }
.stay-bar .nlabel { font-size: var(--fs-2xs); font-weight:600; opacity:.85; letter-spacing:.04em; }
.stay-bar .handle { position:absolute; top:0; bottom:0; width:14px; cursor:ew-resize; display:flex; align-items:center; justify-content:center; }
.stay-bar .handle::before { content:''; width:3px; height:14px; background:rgba(var(--on-dark-rgb), .7); border-radius:2px; }
.stay-bar .handle.l { left:0; } .stay-bar .handle.r { right:0; }
.stay-bar .flag { position:absolute; top:-9px; left:50%; transform:translateX(-50%); white-space:nowrap; background:var(--text-heading); color:var(--neutral-0); font-size: var(--fs-2xs); font-weight:600; padding:2px 7px; border-radius:var(--radius-pill); }

/* conflict pill + popover */
.stay-bar.has-conflict { box-shadow:0 0 0 2px var(--status-danger), 0 2px 8px rgba(var(--shadow-rgb), .2); }
.conflict-pill { position:absolute; top:-11px; right:-8px; background:var(--status-danger); color:var(--neutral-0); font-size: var(--fs-2xs); font-weight:700; letter-spacing:.04em; padding:3px 7px; border-radius:var(--radius-pill); cursor:pointer; z-index:6; box-shadow:0 2px 6px rgba(var(--danger-rgb), .4); }
.conflict-popover { position:absolute; top:20px; right:-6px; width:248px; padding:13px 15px; background:var(--neutral-0); border:1.5px solid var(--status-danger); border-radius:12px; box-shadow:0 12px 32px rgba(var(--danger-rgb), .22); z-index:12; font-size: var(--fs-xs); line-height:1.5; color:var(--text-body); cursor:default; }
.conflict-popover b { color:var(--status-danger); font-weight:600; display:block; margin-bottom:10px; }
.conflict-popover .cp-fixes { display:flex; flex-direction:column; gap:7px; }
.conflict-popover .cp-fix { height:36px; border:0; border-radius:8px; background:var(--text-heading); color:var(--neutral-0); font-family:var(--font-sans); font-size: var(--fs-xs); font-weight:600; cursor:pointer; }
.conflict-popover .cp-fix.ghost { background:transparent; color:var(--link); border:1.5px solid var(--border); }
.conflict-popover .cp-fix.ghost:hover { border-color:var(--link); }

/* foot */
.g-foot { background:var(--surface-sunken); border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; padding:14px 18px; }
.g-foot .gf-left { font-size: var(--fs-sm); color:var(--text-muted); }
.g-foot .gf-left b { color:var(--text-heading); }
.g-foot .gf-split { display:flex; gap:20px; font-size: var(--fs-sm); }
.g-foot .gf-split .sp .k { color:var(--text-muted); } .g-foot .gf-split .sp .v { font-weight:700; color:var(--text-heading); }
.g-foot .gf-add { color:var(--link); font-weight:600; font-size: var(--fs-sm); cursor:pointer; }

/* gantt legend */
.gantt-legend { display:flex; gap:18px; margin-top:14px; font-size: var(--fs-xs); color:var(--text-muted); flex-wrap:wrap; }
.gantt-legend .lg { display:flex; align-items:center; gap:6px; }
.gantt-legend .sw { width:14px; height:14px; border-radius:4px; }

/* hotel summary side panel */
.hs { padding:24px; }
.hs .hs-photo { height:150px; border-radius:var(--radius-card); background:linear-gradient(135deg,var(--placeholder-1),var(--placeholder-2)); margin-bottom:14px; position:relative; }
.hs .hs-name { font-size: var(--fs-xl); font-weight:700; color:var(--text-heading); }
.hs .hs-stars { color:var(--star); font-size: var(--fs-sm); margin:2px 0 12px; }
.hs .hs-meta { font-size: var(--fs-sm); color:var(--text-muted); line-height:1.7; padding-bottom:14px; border-bottom:1px solid var(--border); margin-bottom:14px; }
.hs .hs-meta b { color:var(--text-body); }
.hs .hs-row { display:flex; justify-content:space-between; font-size: var(--fs-sm); padding:7px 0; }
.hs .hs-row .k { color:var(--text-muted); } .hs .hs-row .v { color:var(--text-heading); font-weight:600; }
.hs .hs-total { display:flex; justify-content:space-between; align-items:baseline; margin:14px 0; padding-top:14px; border-top:1px solid var(--border); }
.hs .hs-total .k { font-size: var(--fs-sm); color:var(--text-muted); } .hs .hs-total .v { font-size: var(--fs-3xl); font-weight:700; color:var(--text-heading); }
.hs .hs-swap { display:block; text-align:center; margin-top:12px; color:var(--link); font-weight:600; font-size: var(--fs-sm); cursor:pointer; }

/* upgrade modal */
.modal-bg { position:fixed; inset:0; background:rgba(var(--scrim-rgb), .45); display:none; align-items:center; justify-content:center; z-index:200; }
.modal-bg.show { display:flex; }
.modal { background:var(--neutral-0); border-radius:var(--radius-float); width:440px; max-width:90vw; box-shadow:var(--shadow-float); overflow:hidden; }
.modal-head { padding:20px 24px; border-bottom:1px solid var(--border); }
.modal-head h3 { margin:0; font-size: var(--fs-lg); font-weight:700; color:var(--text-heading); }
.modal-head .sub { font-size: var(--fs-sm); color:var(--text-muted); margin-top:2px; }
.modal-body { padding:16px 24px 24px; max-height:60vh; overflow:auto; }
.up-opt { border:2px solid var(--border); border-radius:var(--radius-row); padding:14px 16px; margin-bottom:10px; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:12px; transition:border-color .12s, background .12s; }
.up-opt:hover { border-color:var(--accent-soft); }
.up-opt.sel { border-color:var(--accent); background:var(--accent-tint); }
.up-opt .uo-name { font-size: var(--fs-md); font-weight:700; color:var(--text-heading); }
.up-opt .uo-desc { font-size: var(--fs-sm); color:var(--text-muted); }
.up-opt .uo-extra { font-size: var(--fs-md); font-weight:700; color:var(--accent); white-space:nowrap; }

/* guest editor popover (simple inline) */
.guest-pop { position:fixed; z-index:210; background:var(--neutral-0); border-radius:12px; box-shadow:var(--shadow-float); padding:14px; width:280px; display:none; }
.guest-pop.show { display:block; }
.guest-pop label { font-size: var(--fs-xs); color:var(--text-muted); display:block; margin-bottom:4px; }
.guest-pop input { width:100%; height:40px; border:1.5px solid var(--border); border-radius:8px; padding:0 12px; font-family:var(--font-sans); font-size: var(--fs-sm); margin-bottom:10px; }
.guest-pop input:focus { outline:none; border-color:var(--accent); }

/* =================================================================
   Checkout panel (Stage 4) — 3-step stepper
   ================================================================= */
.stage[data-stage="4"] .side-panel { width: 430px; }
.checkout-panel { display:flex; flex-direction:column; }
.co-stepper { display:flex; align-items:center; gap:6px; padding:18px 22px; border-bottom:1px solid var(--border); background:var(--surface-sunken); }
.co-step { display:flex; align-items:center; gap:7px; font-size: var(--fs-xs); font-weight:600; color:var(--text-faint); }
.co-step .co-pip { width:22px; height:22px; border-radius:50%; background:var(--surface-sunken-2); color:var(--text-faint); display:flex; align-items:center; justify-content:center; font-size: var(--fs-xs); font-weight:700; flex-shrink:0; }
.co-step.active { color:var(--text-heading); } .co-step.active .co-pip { background:var(--accent); color:var(--neutral-0); box-shadow:0 0 0 4px var(--accent-tint); }
.co-step.done { color:var(--text-body); } .co-step.done .co-pip { background:var(--accent); color:var(--neutral-0); }
.co-line { flex:1; height:1px; background:var(--border); min-width:8px; }
.co-step .co-slbl { white-space:nowrap; }
@media (max-width:1320px){ .co-step:not(.active) .co-slbl { display:none; } }

.co-body { flex:1; overflow-y:auto; }
.co-pane { padding:22px 24px 28px; }
.co-eyebrow { font-size: var(--fs-xs); font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.co-title { font-size: var(--fs-xl); font-weight:700; color:var(--text-heading); margin:6px 0 8px; line-height:1.2; }
.co-sub { font-size: var(--fs-sm); color:var(--text-muted); margin:0 0 18px; line-height:1.55; }

/* method cards */
.co-methods { display:flex; flex-direction:column; gap:10px; margin-bottom:22px; }
.co-method { display:flex; gap:13px; align-items:flex-start; border:1.5px solid var(--border); border-radius:var(--radius-row); padding:14px 16px; cursor:pointer; transition:border-color .12s, background .12s; }
.co-method:hover { border-color:var(--accent-soft); }
.co-method.sel { border-color:var(--accent); background:var(--accent-tint); }
.co-method .oc-radio { width:20px; height:20px; border-radius:50%; border:2px solid var(--text-faint); flex-shrink:0; margin-top:1px; display:flex; align-items:center; justify-content:center; }
.co-method.sel .oc-radio { border-color:var(--accent); } .co-method.sel .oc-radio::after { content:''; width:10px; height:10px; border-radius:50%; background:var(--accent); }
.cm-head { display:flex; align-items:center; gap:8px; margin-bottom:3px; }
.cm-name { font-size: var(--fs-md); font-weight:700; color:var(--text-heading); }
.cm-tag { font-size: var(--fs-2xs); font-weight:700; letter-spacing:.03em; text-transform:uppercase; color:var(--accent-strong); background:var(--accent-tint-2); padding:2px 7px; border-radius:var(--radius-pill); }
.cm-tag.groups { color:var(--status-warning); background:var(--status-warning-tint); }
.cm-desc { font-size: var(--fs-xs); color:var(--text-muted); line-height:1.45; }
.cm-meta { font-size: var(--fs-xs); color:var(--text-faint); margin-top:4px; }
.cm-cards { display:flex; gap:6px; margin-top:8px; }
.card-pill { font-size: var(--fs-2xs); font-weight:700; letter-spacing:.05em; color:var(--text-muted); border:1px solid var(--border); border-radius:4px; padding:2px 6px; background:var(--neutral-0); }

/* forms */
.co-form { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.co-field { display:flex; flex-direction:column; gap:5px; font-size: var(--fs-xs); color:var(--text-muted); }
.co-field.full { grid-column:1 / -1; }
.co-field .opt { color:var(--text-faint); font-weight:400; }
.co-field input { height:44px; border:1.5px solid var(--border); border-radius:8px; padding:0 12px; font-family:var(--font-sans); font-size: var(--fs-sm); color:var(--text-heading); background:var(--neutral-0); }
.co-field input:focus { outline:none; border-color:var(--accent); }
.co-subform { margin-top:22px; padding-top:20px; border-top:1px solid var(--border); }
.co-subtitle { font-size: var(--fs-sm); font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--text-heading); margin:0 0 14px; }
.co-note { font-size: var(--fs-xs); color:var(--text-muted); line-height:1.5; margin-top:12px; background:var(--surface-sunken); border-radius:8px; padding:10px 12px; }
.co-wire { background:var(--surface-sunken); border-radius:var(--radius-row); padding:14px 16px; margin-bottom:16px; }
.cw-row { display:flex; justify-content:space-between; gap:12px; padding:5px 0; font-size: var(--fs-xs); }
.cw-k { color:var(--text-muted); } .cw-v { color:var(--text-heading); font-weight:600; font-family:'IBM Plex Mono',monospace; font-size: var(--fs-xs); text-align:right; }

/* review */
.co-review { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:18px; }
.co-rcard { background:var(--surface-sunken); border-radius:var(--radius-row); padding:14px 16px; }
.rc-k { font-size: var(--fs-2xs); font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text-muted); margin-bottom:5px; }
.rc-main { font-size: var(--fs-md); font-weight:700; color:var(--text-heading); }
.rc-meta { font-size: var(--fs-xs); color:var(--text-muted); margin-top:2px; line-height:1.4; }
.co-totals { background:var(--surface-sunken); border-radius:var(--radius-row); padding:14px 16px; margin-bottom:16px; }
.ct-row { display:flex; justify-content:space-between; font-size: var(--fs-sm); color:var(--text-body); padding:4px 0; }
.ct-row span:last-child { font-weight:600; color:var(--text-heading); }
.ct-line { height:1px; background:var(--border); margin:8px 0; }
.ct-row.total { font-size: var(--fs-md); font-weight:700; } .ct-row.total span:last-child { color:var(--accent); font-size: var(--fs-lg); }
.co-tc { display:flex; gap:10px; align-items:flex-start; font-size: var(--fs-xs); color:var(--text-muted); line-height:1.5; margin-bottom:18px; cursor:pointer; }
.co-tc input { accent-color:var(--accent); width:18px; height:18px; flex-shrink:0; margin-top:1px; }
.co-tc u { color:var(--link); cursor:pointer; }

.co-actions { display:flex; gap:10px; }
.co-actions .hm-btn { flex:1; height:48px; }

/* =================================================================
   Progressive (two-phase) commit overlay
   ================================================================= */
.commit-overlay { position:absolute; inset:0; z-index:120; background:rgba(var(--scrim-light-rgb), .86); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .25s ease; }
.commit-overlay.show { opacity:1; }
.commit-card { width:min(440px,90%); background:var(--neutral-0); border-radius:var(--radius-float); box-shadow:var(--shadow-float); padding:30px 32px 28px; text-align:center; }
.commit-eyebrow { font-size: var(--fs-xs); font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.commit-title { font-size: var(--fs-2xl); font-weight:700; color:var(--text-heading); margin:8px 0 6px; letter-spacing:-0.01em; }
.commit-sub { font-size: var(--fs-sm); color:var(--text-muted); line-height:1.5; margin-bottom:18px; }
.commit-counter { font-size: var(--fs-sm); font-weight:600; color:var(--accent-strong); font-feature-settings:"tnum" 1; min-height:18px; margin-bottom:14px; }
.commit-rooms { display:grid; grid-template-columns:repeat(auto-fit,minmax(92px,1fr)); gap:8px; }
.commit-room { display:flex; align-items:center; gap:7px; background:var(--surface-sunken); border-radius:8px; padding:8px 10px; transition:background .2s; }
.commit-room .cr-dot { width:10px; height:10px; border-radius:50%; background:var(--border-disabled); flex-shrink:0; transition:background .2s, box-shadow .2s; }
.commit-room .cr-lbl { font-size: var(--fs-xs); font-weight:600; color:var(--text-muted); font-feature-settings:"tnum" 1; }
.commit-room.held { background:var(--accent-tint); }
.commit-room.held .cr-dot { background:var(--accent); box-shadow:0 0 0 3px var(--accent-tint-2); }
.commit-room.held .cr-lbl { color:var(--accent-strong); }
.commit-room.committed { background:var(--status-success-tint); }
.commit-room.committed .cr-dot { background:var(--status-success); box-shadow:0 0 0 3px var(--status-success-tint-2); }
.commit-room.committed .cr-lbl { color:var(--status-success-strong); }
.commit-gate { margin-top:6px; font-size: var(--fs-sm); font-weight:600; color:var(--status-success); display:flex; align-items:center; justify-content:center; gap:8px; }
.commit-gate .cg-tick { width:22px; height:22px; border-radius:50%; background:var(--status-success); color:var(--neutral-0); display:inline-flex; align-items:center; justify-content:center; font-size: var(--fs-sm); }
.commit-bigtick { width:72px; height:72px; border-radius:50%; background:var(--status-success); display:flex; align-items:center; justify-content:center; margin:0 auto 18px; box-shadow:0 8px 26px rgba(var(--success-rgb), .34); animation:commitPop .35s ease; }
@keyframes commitPop { 0%{ transform:scale(.6); opacity:0; } 100%{ transform:scale(1); opacity:1; } }

/* =================================================================
   Stage 5 — Confirmed
   ================================================================= */
.confirmed { width:100%; height:100%; overflow:auto; background:var(--bg-app); display:flex; justify-content:center; }
.cf-inner { max-width:720px; width:100%; padding:56px 32px 80px; }
.cf-tick { width:72px; height:72px; border-radius:50%; background:var(--status-success); display:flex; align-items:center; justify-content:center; margin:0 auto 22px; box-shadow:0 8px 26px rgba(var(--success-rgb), .35); }
.cf-sub { text-align:center; font-size: var(--fs-md); color:var(--text-muted); margin:0 0 32px; }
.cf-sub b { color:var(--text-body); font-weight:600; }
.cf-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:20px; }
.cf-card { background:var(--surface); border-radius:var(--radius-card); box-shadow:var(--shadow-card); padding:18px 20px; }
.cf-card .cf-k { font-size: var(--fs-xs); font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text-muted); margin-bottom:6px; }
.cf-card .cf-v { font-size: var(--fs-lg); font-weight:700; color:var(--text-heading); }
.cf-card .cf-v.mono { font-family:'IBM Plex Mono',monospace; letter-spacing:.02em; }
.cf-card .cf-meta { font-size: var(--fs-xs); color:var(--text-muted); margin-top:4px; }
.cf-share { background:var(--surface); border-radius:var(--radius-card); box-shadow:var(--shadow-card); padding:18px 20px; margin-bottom:24px; }
.cf-share .cf-k { font-size: var(--fs-xs); font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text-muted); }
.cf-share-row { display:flex; gap:10px; }
.cf-share-row input { flex:1; height:48px; border:1.5px solid var(--border); border-radius:8px; padding:0 14px; font-family:'IBM Plex Mono',monospace; font-size: var(--fs-sm); color:var(--text-body); background:var(--surface-sunken); }
.cf-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.cf-foot { text-align:center; font-size: var(--fs-sm); color:var(--text-muted); margin:26px auto 0; max-width:480px; line-height:1.6; }
@media (max-width:680px){ .cf-grid { grid-template-columns:1fr; } }
