/* Shared kit CSS — extends colors_and_type.css tokens */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-ui);
  font-size: 14.5px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

/* ---- Buttons ---- */
.btn { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-ui); font-weight:700; font-size:13.5px; padding:9px 15px; border-radius:var(--r-md); border:1px solid transparent; cursor:pointer; letter-spacing:-0.003em; transition:transform .14s var(--spring), background .16s var(--ease-out), box-shadow .16s var(--ease-out), border-color .16s var(--ease-out); }
.btn:active { transform: scale(0.96); }
.btn.primary { background:var(--accent); color:#fff; box-shadow:var(--shadow-pop); }
.btn.primary:hover { background:var(--accent-600); color:#fff; transform:translateY(-1.5px); box-shadow:0 12px 32px rgba(24,119,242,0.32); }
.btn.secondary { background:var(--surface); color:var(--text); border-color:var(--border-strong); }
.btn.secondary:hover { border-color:var(--accent); color:var(--accent-700); transform:translateY(-1px); }
.btn.ghost { background:transparent; color:var(--muted); }
.btn.ghost:hover { background:var(--n-100); color:var(--text); }
.btn .kbd { font-family:var(--font-mono); font-size:11px; padding:1px 5px; border-radius:4px; background:rgba(0,0,0,.08); font-weight:500; }
.btn.primary .kbd { background:rgba(0,0,0,.15); }
.icon-btn { width:32px; height:32px; display:inline-flex; align-items:center; justify-content:center; border-radius:var(--r-md); background:transparent; border:none; color:var(--muted); cursor:pointer; transition:background .12s var(--ease-out), color .12s var(--ease-out); }
.icon-btn:hover { background:var(--n-100); color:var(--text); }

/* ---- Input ---- */
.input { width:100%; font-family:var(--font-ui); font-size:13px; padding:8px 11px; border:1px solid var(--border-strong); border-radius:var(--r-md); background:var(--surface); color:var(--text); transition:box-shadow .12s var(--ease-out), border-color .12s var(--ease-out); }
.input:focus { outline:none; border-color:var(--accent); box-shadow:var(--shadow-focus); }

/* ---- Badge ---- */
.badge { display:inline-flex; align-items:center; gap:6px; font-size:11.5px; font-weight:500; padding:3px 10px; border-radius:var(--r-pill); border:1px solid transparent; line-height:1.4; }
.badge .dot { width:6px; height:6px; border-radius:50%; background:currentColor; }
.badge.neutral { background:var(--n-100); color:var(--n-700); border-color:var(--border); }
.badge.ok { background:color-mix(in srgb,var(--ok) 12%,transparent); color:var(--ok); border-color:color-mix(in srgb,var(--ok) 22%,transparent); }
.badge.warn { background:color-mix(in srgb,var(--warn) 14%,transparent); color:#B4680A; border-color:color-mix(in srgb,var(--warn) 28%,transparent); }
.badge.err { background:color-mix(in srgb,var(--err) 12%,transparent); color:var(--err); border-color:color-mix(in srgb,var(--err) 25%,transparent); }
.badge.info { background:var(--accent-tint); color:var(--accent-700); border-color:color-mix(in srgb,var(--accent) 25%,transparent); }

/* ---- Cards & shells ---- */
.card { border:1px solid var(--border); border-radius:var(--r-lg); background:var(--surface); box-shadow:var(--shadow-sm); }
.panel { border:1px solid var(--border); border-radius:var(--r-lg); background:var(--surface); overflow:hidden; }
.eyebrow { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.12em; color:var(--faint); }
.mono { font-family:var(--font-mono); font-feature-settings:"tnum" 1, "ss01" 1; }
.muted { color:var(--muted); }
.faint { color:var(--faint); }

/* ---- Agent app shell ---- */
.app { display:grid; grid-template-columns: 232px 1fr; min-height: 100vh; }
.sidebar { background:var(--surface-2); border-right:1px solid var(--border); padding:14px 10px; }
.side-logo { display:flex; align-items:center; gap:8px; padding:6px 10px 16px; font-weight:700; font-size:15px; letter-spacing:-0.02em; }
.side-logo .mark { width:22px; height:22px; border-radius:7px; background:var(--accent); position:relative; box-shadow:0 2px 8px rgba(24,119,242,0.35); }
.side-logo .mark::after { content:""; position:absolute; inset:5px; border-radius:3px; background:#fff; }
.side-group { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; color:var(--faint); padding:12px 10px 4px; }
.side-nav { display:flex; flex-direction:column; gap:1px; }
.side-nav a { display:flex; align-items:center; gap:10px; padding:7px 10px; color:var(--muted); text-decoration:none; border-radius:var(--r-md); font-size:13px; font-weight:500; position:relative; cursor:pointer; transition:background .12s var(--ease-out), color .12s var(--ease-out); }
.side-nav a svg { width:15px; height:15px; flex-shrink:0; }
.side-nav a:hover:not(.active) { background:var(--n-100); color:var(--text); }
.side-nav a.active { background:var(--accent-tint); color:var(--accent-700); font-weight:700; }
.side-nav a.active::before { content:""; position:absolute; left:-10px; top:6px; bottom:6px; width:3px; border-radius:0 3px 3px 0; background:var(--accent); }
.side-nav a .count { margin-left:auto; font-size:10.5px; color:var(--accent); font-weight:600; }

.topbar { display:flex; align-items:center; gap:12px; padding:10px 18px; border-bottom:1px solid var(--border); background:var(--surface); }
.search { display:flex; align-items:center; gap:8px; padding:6px 11px; border:1px solid var(--border); border-radius:var(--r-md); background:var(--surface-2); width:360px; color:var(--muted); font-size:12.5px; cursor:pointer; transition:border-color .12s var(--ease-out); }
.search:hover { border-color:var(--border-strong); }
.search .kbd { margin-left:auto; font-family:var(--font-mono); font-size:11px; padding:1px 5px; border-radius:4px; background:var(--surface); border:1px solid var(--border); color:var(--faint); }
.avatar { width:28px; height:28px; border-radius:50%; background:linear-gradient(135deg,var(--accent),var(--accent-700)); color:#fff; display:inline-flex; align-items:center; justify-content:center; font-weight:600; font-size:11px; }
.main-col { display:flex; flex-direction:column; min-width:0; }
.content { padding:22px; overflow:auto; }

/* ---- Page head ---- */
.page-head { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; margin-bottom:20px; }
.page-title { font-size:26px; font-weight:700; letter-spacing:-0.03em; margin:0 0 4px; }
.page-sub { color:var(--muted); font-size:13.5px; }

/* ---- Stats ---- */
.stats { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:18px; }
.stat { border:1px solid var(--border); border-radius:var(--r-md); padding:14px; background:var(--surface); transition:transform .12s var(--spring), box-shadow .15s var(--ease-out), border-color .15s var(--ease-out); cursor:pointer; }
.stat:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:var(--border-strong); }
.stat .k { font-size:10.5px; color:var(--muted); text-transform:uppercase; letter-spacing:0.1em; font-weight:600; }
.stat .v { font-family:var(--font-mono); font-size:24px; font-weight:600; margin-top:6px; letter-spacing:-0.02em; font-feature-settings:"tnum" 1, "ss01" 1; }
.stat .d { font-size:11.5px; color:var(--ok); margin-top:2px; font-weight:500; }
.stat .d.warn { color:var(--warn-deep); }

/* ---- Table ---- */
.table-wrap { border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; background:var(--surface); }
.table-head { display:flex; align-items:center; justify-content:space-between; padding:11px 14px; border-bottom:1px solid var(--border); background:var(--surface-2); }
.chip { font-size:11.5px; padding:4px 10px; border-radius:var(--r-pill); border:1px solid var(--border-strong); background:var(--surface); color:var(--muted); cursor:pointer; transition:all .12s var(--ease-out); }
.chip:hover { color:var(--text); border-color:var(--n-500); }
.chip.on { color:var(--accent-700); background:var(--accent-tint); border-color:color-mix(in srgb,var(--accent) 30%,transparent); font-weight:600; }
table.bk { width:100%; border-collapse:collapse; }
table.bk thead th { text-align:left; font-size:10.5px; font-weight:600; text-transform:uppercase; letter-spacing:0.08em; color:var(--faint); padding:10px 14px; border-bottom:1px solid var(--border); background:var(--surface); }
table.bk td { padding:12px 14px; border-bottom:1px solid var(--border); font-size:13px; }
table.bk tbody tr:last-child td { border-bottom:0; }
table.bk tbody tr { cursor:pointer; transition:background .08s; }
table.bk tbody tr:hover td { background:var(--surface-2); }
.t-id { font-family:var(--font-mono); font-size:11.5px; color:var(--muted); }
.t-route { font-family:var(--font-mono); font-weight:500; font-size:12.5px; }
.t-amt { text-align:right; font-family:var(--font-mono); font-weight:600; font-feature-settings:"tnum" 1; }
.t-pax { color:var(--muted); font-family:var(--font-mono); font-feature-settings:"tnum" 1; }

/* ---- Inbox ---- */
.inbox-grid { display:grid; grid-template-columns: 340px 1fr; border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; background:var(--surface); min-height:540px; box-shadow:var(--shadow-sm); }
.inbox-list { border-right:1px solid var(--border); background:var(--surface-2); overflow:auto; }
.inbox-list-head { padding:10px 14px; border-bottom:1px solid var(--border); font-size:10.5px; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; color:var(--faint); display:flex; justify-content:space-between; }
.msg { padding:10px 14px; border-bottom:1px solid var(--border); cursor:pointer; transition:background .08s; position:relative; }
.msg:hover { background:var(--n-100); }
.msg.active { background:var(--accent-tint); }
.msg.active::before { content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--accent); }
.msg .from { display:flex; justify-content:space-between; gap:8px; margin-bottom:2px; }
.msg .from .name { font-weight:600; font-size:12.5px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.msg .time { font-family:var(--font-mono); font-size:10.5px; color:var(--faint); flex-shrink:0; }
.msg .sub { font-size:12.5px; color:var(--muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; margin-bottom:2px; }
.msg .preview { font-size:11.5px; color:var(--faint); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.msg .pill-row { display:flex; gap:4px; margin-top:6px; }
.thread { padding:22px; overflow:auto; }
.thread h3 { font-size:19px; font-weight:700; letter-spacing:-0.025em; margin:0; }
.thread .meta { font-family:var(--font-mono); font-size:11px; color:var(--muted); margin:4px 0 16px; }
.thread p { margin:0 0 10px; font-size:13.5px; line-height:1.6; }

.ai-block { border:1px solid color-mix(in srgb,var(--accent) 35%,transparent); background:var(--accent-tint); border-radius:var(--r-lg); padding:16px 18px; position:relative; overflow:hidden; margin-top:14px; }
.ai-block::before { content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--accent); }
.ai-tag { display:inline-flex; align-items:center; gap:6px; font-size:10.5px; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; color:var(--accent-700); margin-bottom:8px; }
.ai-tag .spark { width:10px; height:10px; border-radius:3px; background:var(--accent); }
.ai-data { font-family:var(--font-mono); font-size:12.5px; line-height:1.75; font-feature-settings:"tnum" 1; color:var(--n-700); }
.ai-data b { color:var(--text); }
.ai-btns { display:flex; gap:6px; margin-top:12px; flex-wrap:wrap; }

/* ---- Booking detail ---- */
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.section { padding:18px 20px; border-bottom:1px solid var(--border); }
.section:last-child { border-bottom:0; }
.section h3 { font-size:14px; font-weight:600; margin:0 0 12px; letter-spacing:-0.01em; }
.info-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.info-cell .lbl { font-size:10.5px; color:var(--muted); text-transform:uppercase; letter-spacing:0.1em; font-weight:600; margin-bottom:3px; }
.info-cell .val { font-size:13.5px; font-weight:500; }
.info-cell .val.mono { font-family:var(--font-mono); font-feature-settings:"tnum" 1; }

/* PNR card */
.pnr-card { display:flex; justify-content:space-between; align-items:center; padding:12px 14px; border:1px solid var(--border); border-radius:var(--r-md); background:var(--surface); margin-bottom:6px; }
.pnr-card.selected { border-color:color-mix(in srgb,var(--accent) 50%,transparent); background:var(--accent-tint); }
.pnr-card .code { font-family:var(--font-mono); font-weight:600; font-size:13.5px; }
.pnr-card .route { font-family:var(--font-mono); color:var(--muted); font-size:12px; margin-top:2px; }
.pnr-card .price { font-family:var(--font-mono); font-weight:600; font-feature-settings:"tnum" 1; }

/* Passenger row */
.pax-row { display:grid; grid-template-columns: 1fr auto auto auto; gap:12px; align-items:center; padding:10px 14px; border-bottom:1px solid var(--border); font-size:13px; }
.pax-row:last-child { border:0; }
.pax-row .nm { font-family:var(--font-mono); font-weight:500; }
.pax-row .doc { font-family:var(--font-mono); color:var(--muted); font-size:12px; }

/* ---- Portal ---- */
.portal-shell { min-height:100vh; background:var(--surface-2); padding:24px 16px; }
.portal-card { max-width:720px; margin:0 auto; border:1px solid var(--border); border-radius:var(--r-xl); background:var(--surface); overflow:hidden; box-shadow:var(--shadow-md); }
.portal-nav { background:var(--n-950); padding:14px 20px; display:flex; align-items:center; justify-content:space-between; }
.portal-nav img { height:20px; }
.portal-nav .secure { font-size:11px; color:var(--n-400); display:flex; align-items:center; gap:6px; letter-spacing:0.01em; }
.portal-hero { padding:36px 32px 28px; border-bottom:1px solid var(--border); background: linear-gradient(135deg, var(--surface-2) 0%, var(--surface) 60%), radial-gradient(circle at 92% 12%, var(--accent-tint) 0%, transparent 50%); position:relative; }
.portal-hero h1 { font-size:30px; font-weight:700; letter-spacing:-0.03em; margin:6px 0 8px; }
.portal-hero p { color:var(--muted); font-size:14.5px; line-height:1.55; margin:0; max-width:54ch; }
.portal-progress { display:flex; align-items:center; gap:10px; margin-top:18px; font-size:11.5px; color:var(--muted); font-family:var(--font-mono); }
.portal-bar { flex:1; max-width:260px; height:4px; border-radius:var(--r-pill); background:var(--border); overflow:hidden; position:relative; }
.portal-bar .fill { position:absolute; top:0; left:0; bottom:0; background:linear-gradient(90deg,var(--accent),var(--accent-600)); border-radius:var(--r-pill); }
.portal-body { padding:28px 32px; }
.portal-form { display:grid; grid-template-columns:1fr 1fr; gap:14px 18px; }
.portal-form .f { display:flex; flex-direction:column; gap:5px; }
.portal-form .f.full { grid-column:1 / -1; }
.portal-form label { font-size:11.5px; font-weight:600; color:var(--muted); }
.portal-form .hint { font-size:11px; color:var(--faint); }
.portal-form .hint.ok { color:var(--ok); }
.portal-actions { display:flex; justify-content:flex-end; gap:8px; padding-top:18px; margin-top:6px; border-top:1px solid var(--border); }
.portal-roster { padding:20px 32px; background:var(--surface-2); border-top:1px solid var(--border); }
.roster-item { display:flex; align-items:center; gap:12px; padding:10px 12px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-md); margin-bottom:6px; font-size:13px; }
.roster-item .rn { display:inline-flex; align-items:center; justify-content:center; width:22px; height:22px; border-radius:50%; background:var(--n-100); color:var(--muted); font-family:var(--font-mono); font-size:11px; font-weight:600; }
.roster-item.me { border-color:color-mix(in srgb,var(--accent) 40%,transparent); background:var(--accent-tint); }
.roster-item.me .rn { background:var(--accent); color:#fff; }

/* Login */
.login-shell { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px; background:var(--surface-2); }
.login-card { width:100%; max-width:420px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-xl); padding:32px; box-shadow:var(--shadow-md); }
.login-logo { display:flex; align-items:center; gap:10px; margin-bottom:20px; font-weight:700; font-size:18px; letter-spacing:-0.02em; }
.login-logo .mark { width:26px; height:26px; border-radius:8px; background:linear-gradient(135deg,var(--accent),var(--accent-700)); position:relative; }
.login-logo .mark::after { content:""; position:absolute; inset:6px; border-radius:3px; background:var(--surface); }
