/* ════════════════════════════════════════════════════════════════
   IN-RIGA operator console — UI kit styles
   Shell + components. Tokens come from ../../colors_and_type.css.
   ════════════════════════════════════════════════════════════════ */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--paper);color:var(--ink);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
.mono{font-family:var(--font-mono)}
button{font-family:inherit}
::selection{background:var(--orange);color:#fff}

/* ── App shell ── */
.app{display:grid;grid-template-columns:232px 1fr;height:100vh;overflow:hidden}
.rail{display:flex;flex-direction:column;height:100vh;overflow:auto;border-right:1.5px solid var(--ink);padding:20px 16px;background:var(--paper)}
.rail-brand{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.rail-name{font-family:var(--font-display);font-weight:900;font-size:15px;letter-spacing:-0.01em;line-height:1;white-space:nowrap}
.rail-sub{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.14em;color:var(--muted);margin:10px 0 16px}
.rail-grp{font-family:var(--font-mono);font-size:9px;color:var(--muted-2);letter-spacing:0.14em;padding:14px 10px 4px;text-transform:uppercase}
.rail-link{display:flex;align-items:center;justify-content:space-between;gap:8px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);text-decoration:none;padding:8px 10px;border-radius:var(--r-sm);cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:background .1s}
.rail-link:hover{color:var(--ink);background:var(--paper-2)}
.rail-link.active{color:var(--ink);background:var(--paper-2);font-weight:600}
.rail-link.active::before{content:"";position:absolute}
.rail-link .ct{font-family:var(--font-mono);font-size:10px;background:var(--paper-3);color:var(--muted);border-radius:999px;padding:1px 7px}
.rail-link.active .ct{background:var(--orange);color:#fff}
.rail-foot{margin-top:auto;padding-top:14px;border-top:1px dotted var(--line);font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted-2);line-height:1.8}
.rail-me{display:flex;align-items:center;gap:9px;padding:8px 10px;border:1.5px solid var(--ink);border-radius:var(--r-md);margin-top:14px}
.rail-me .av{width:26px;height:26px;border-radius:50%;background:var(--ink);color:var(--paper);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;font-weight:700;flex-shrink:0}
.rail-me .nm{font-size:12px;font-weight:600;line-height:1.2}
.rail-me .em{font-family:var(--font-mono);font-size:9px;color:var(--muted);letter-spacing:0.02em}

.main{display:flex;flex-direction:column;min-width:0;overflow:hidden}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 28px;border-bottom:1px solid var(--line);background:color-mix(in oklab,var(--paper) 86%,transparent);backdrop-filter:blur(8px);flex-shrink:0}
.topbar .crumb{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted)}
.topbar .crumb b{color:var(--ink);font-weight:600}
.topbar-actions{display:flex;align-items:center;gap:10px}
.search{display:flex;align-items:center;gap:8px;border:1.5px solid var(--ink);border-radius:var(--r-pill);padding:7px 14px;background:var(--paper);min-width:220px}
.search input{border:none;background:none;outline:none;font-family:var(--font-mono);font-size:12px;color:var(--ink);width:100%}
.search .k{font-family:var(--font-mono);font-size:9px;color:var(--muted-2);border:1px solid var(--line);border-radius:4px;padding:1px 5px}
.scroll{flex:1;overflow:auto;padding:28px}
.page-head{margin-bottom:22px}
.page-head h1{font-family:var(--font-display);font-weight:900;font-size:34px;letter-spacing:-0.02em;line-height:1}
.page-head p{font-size:13px;color:var(--muted);margin-top:6px;max-width:560px}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.08em;font-weight:600;border:1.5px solid var(--ink);border-radius:var(--r-md);background:var(--paper);color:var(--ink);cursor:pointer;transition:transform .05s,background .1s;white-space:nowrap}
.btn:hover{background:var(--paper-2)}.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--ink);color:var(--paper)}.btn.primary:hover{background:var(--ink-soft)}
.btn.accent{background:var(--orange);border-color:var(--orange);color:#fff}.btn.accent:hover{background:#e63d0e}
.btn.danger{background:var(--paper);border-color:var(--bad);color:var(--bad)}.btn.danger:hover{background:color-mix(in oklab,var(--bad) 6%,var(--paper))}
.btn.danger.solid{background:var(--bad);color:#fff}
.btn.ghost{border-color:var(--line);color:var(--ink)}.btn.ghost:hover{border-color:var(--ink);background:var(--paper-2)}
.btn.sm{padding:6px 12px;font-size:10px}
.btn:disabled,.btn.is-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}

/* ── State pills ── */
.state-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--r-pill);border:1.25px solid;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:0.06em;white-space:nowrap;line-height:1.3;color:var(--muted);background:var(--paper-2);border-color:var(--line)}
.state-pill-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:currentColor}
.state-pill-icon{font-size:11px;line-height:1;opacity:.85}
.state-pill-label{text-transform:uppercase;letter-spacing:0.08em}
.state-pill.compact{padding:2px 8px;font-size:10px;gap:5px}
.state-pill.compact .state-pill-label{text-transform:none;letter-spacing:0.03em;font-weight:500}
.state-pill.tone-grey{color:var(--muted);background:var(--paper-2);border-color:var(--line)}
.state-pill.tone-amber{color:var(--warn);background:color-mix(in oklab,var(--warn) 9%,var(--paper));border-color:color-mix(in oklab,var(--warn) 55%,var(--line))}
.state-pill.tone-blue{color:var(--tone-blue);background:color-mix(in oklab,var(--tone-blue) 8%,var(--paper));border-color:color-mix(in oklab,var(--tone-blue) 50%,var(--line))}
.state-pill.tone-navy{color:var(--tone-navy);background:color-mix(in oklab,var(--tone-navy) 8%,var(--paper));border-color:color-mix(in oklab,var(--tone-navy) 45%,var(--line))}
.state-pill.tone-red{color:var(--bad);background:color-mix(in oklab,var(--bad) 9%,var(--paper));border-color:color-mix(in oklab,var(--bad) 55%,var(--line))}
.state-pill.tone-green{color:var(--good);background:color-mix(in oklab,var(--good) 9%,var(--paper));border-color:color-mix(in oklab,var(--good) 50%,var(--line))}
.state-pill.tone-paid{color:#fff;background:var(--good);border-color:var(--good);font-weight:600}
.state-pill.tone-paid .state-pill-dot{background:#fff}
.state-pill.tone-debug{color:var(--orange);background:var(--orange-soft);border:1.5px dashed var(--orange)}

/* ── Role pills ── */
.role{display:inline-flex;align-items:center;border-radius:var(--r-pill);padding:2px 9px;font-family:var(--font-mono);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em}
.role.admin{background:var(--ink);color:var(--paper)}
.role.operator{background:var(--paper-3);color:var(--ink)}
.role.viewer{background:var(--paper-2);color:var(--muted);border:1px dashed var(--line)}
.role.is-external{background:var(--paper);color:var(--ink);border:1px solid var(--ink);font-weight:600}
.role.hotel.is-external{color:var(--info);border-color:var(--info)}
.role.transfer.is-external{color:var(--tone-navy);border-color:var(--tone-navy)}
.role.activity.is-external{color:var(--warn);border-color:var(--warn)}
.linkchip{display:inline-flex;align-items:center;height:18px;padding:0 6px;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-sm);font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:0.04em}

/* ── Cards ── */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.card.heavy{border:1.5px solid var(--ink)}
.card-soft{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.card-head{padding:12px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-head .title{font-size:13px;font-weight:600;letter-spacing:-0.005em}
.card-head .eyebrow{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted)}
.card-body{padding:18px}

/* ── Inputs ── */
.input{width:100%;padding:10px 14px;border:1.5px solid var(--ink);border-radius:var(--r-md);background:var(--paper);font-family:var(--font-mono);font-size:12px;color:var(--ink)}
.input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-soft)}
.textarea{width:100%;padding:10px 14px;border:1.5px solid var(--ink);border-radius:var(--r-md);background:var(--paper);font-family:var(--font-sans);font-size:13px;line-height:1.5;color:var(--ink);resize:vertical;min-height:80px}
.field-label{display:block;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);margin-bottom:6px}

/* ── Table ── */
.tbl{border:1.5px solid var(--ink);border-radius:var(--r-lg);overflow:hidden;background:var(--paper)}
.thead,.trow{display:grid;gap:14px;padding:11px 18px;align-items:center}
.thead{background:var(--paper-2);border-bottom:1.5px solid var(--ink);font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted)}
.trow{border-bottom:1px dotted var(--line);font-size:13px;text-decoration:none;color:var(--ink);cursor:pointer;background:none;width:100%;text-align:left;border-left:none;border-right:none;border-top:none}
.trow:last-child{border-bottom:none}
.trow:hover{background:var(--paper-2)}
.trow.sel{background:var(--orange-soft)}
.trow .id{font-family:var(--font-mono);color:var(--orange);font-size:12px}
.trow .num{font-family:var(--font-mono);font-feature-settings:"tnum";text-align:right}
.trow .cust{font-weight:500}
.trow .sub{font-family:var(--font-mono);font-size:10px;color:var(--muted-2);letter-spacing:0.02em;margin-top:2px}

/* ── Chips / tabs ── */
.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--r-pill);border:1.25px solid var(--line);background:var(--paper);font-family:var(--font-mono);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);cursor:pointer;transition:background .1s}
.chip:hover{background:var(--paper-2);color:var(--ink)}
.chip.active{background:color-mix(in oklab,var(--ink) 90%,var(--paper));color:var(--paper);border-color:color-mix(in oklab,var(--ink) 90%,var(--paper))}
.chip .ct{background:rgba(0,0,0,.08);padding:0 6px;border-radius:999px;font-size:10px}
.chip.active .ct{background:rgba(255,255,255,.18)}
.tabs{display:flex;gap:4px;flex-wrap:wrap}
.tab{appearance:none;background:none;border:0;padding:8px 14px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.08em;font-weight:600;color:var(--muted);border-radius:var(--r-pill);cursor:pointer}
.tab:hover{color:var(--ink)}
.tab.active{background:color-mix(in oklab,var(--ink) 90%,var(--paper));color:var(--paper)}

/* ── Toast ── */
.toast-host{position:fixed;right:24px;bottom:24px;display:flex;flex-direction:column;gap:10px;z-index:200}
.toast{display:flex;align-items:center;gap:10px;width:340px;max-width:100%;border:1.5px solid color-mix(in oklab,var(--good) 45%,var(--line));border-radius:var(--r-md);background:color-mix(in oklab,var(--good) 10%,var(--paper));padding:12px 14px;position:relative;overflow:hidden;animation:toastIn .18s ease}
@keyframes toastIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.toast.bad{background:color-mix(in oklab,var(--bad) 10%,var(--paper));border-color:color-mix(in oklab,var(--bad) 50%,var(--line))}
.toast.info{background:color-mix(in oklab,var(--info) 9%,var(--paper));border-color:color-mix(in oklab,var(--info) 45%,var(--line))}
.toast .tt{font-size:13px;font-weight:500}
.toast .ts{font-family:var(--font-mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;margin-top:1px}

/* ── Empty ── */
.empty{border:1px dashed var(--line);border-radius:var(--r-lg);background:var(--paper);padding:48px;text-align:center}
.empty .eb{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted-2);margin-bottom:8px}
.empty .bd{font-size:12px;color:var(--muted);line-height:1.55}

/* ── Modal ── */
.scrim{position:fixed;inset:0;background:color-mix(in oklab,var(--ink) 28%,transparent);display:flex;align-items:center;justify-content:center;padding:30px;z-index:300;animation:fade .14s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.dialog{width:480px;max-width:100%;background:var(--paper);border:1.5px solid var(--ink);border-radius:var(--r-lg);box-shadow:var(--shadow-dialog);overflow:hidden}
.dialog-head{padding:16px 20px;border-bottom:1.5px solid var(--ink);display:flex;align-items:center;gap:12px}
.dialog-eyebrow{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted)}
.dialog-title{font-family:var(--font-display);font-weight:900;font-size:22px;letter-spacing:-0.02em;line-height:1;margin-top:3px}
.dialog-body{padding:18px 20px;font-size:13px;color:var(--ink-soft);line-height:1.55}
.dialog-foot{padding:14px 20px;border-top:1.5px dashed var(--ink);display:flex;gap:10px;justify-content:flex-end}

/* ── Debug chip ── */
.debug-chip{position:fixed;left:20px;bottom:20px;display:inline-flex;align-items:center;gap:8px;border:1.5px dashed var(--ink);border-radius:var(--r-pill);background:var(--paper);padding:8px 14px;box-shadow:var(--shadow-hard);font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:var(--ink);cursor:pointer;z-index:150}
.debug-chip .dot{width:7px;height:7px;border-radius:50%;background:var(--orange)}
.debug-chip .ct{background:var(--orange);color:#fff;border-radius:999px;padding:0 6px;font-size:9px;font-weight:700}

/* ── Bullseye ── */
.bullseye{display:inline-block;width:22px;height:22px;border-radius:50%;border:2px solid var(--ink);position:relative;flex-shrink:0}
.bullseye::before{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--orange)}
.bullseye::after{content:"";position:absolute;inset:8px;border-radius:50%;background:var(--ink)}
.bullseye.sm{width:16px;height:16px}.bullseye.sm::before{inset:2px}.bullseye.sm::after{inset:6px}
.bullseye.lg{width:54px;height:54px;border-width:3px}.bullseye.lg::before{inset:8px}.bullseye.lg::after{inset:20px}

/* ── Login ── */
.login{display:flex;align-items:center;justify-content:center;height:100vh;padding:24px}
.login-card{width:380px;max-width:100%}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:26px}
.login-brand .nm{font-family:var(--font-display);font-weight:900;font-size:24px;letter-spacing:-0.02em}
.login-brand .sb{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.14em;color:var(--muted);margin-top:3px}
.login-box{border:1.5px solid var(--ink);border-radius:var(--r-lg);padding:24px;background:var(--paper)}
.login-box h2{font-family:var(--font-display);font-weight:900;font-size:20px;letter-spacing:-0.01em;margin-bottom:4px}
.login-box .lead{font-size:12px;color:var(--muted);margin-bottom:20px}
.login-row{margin-bottom:14px}
.login-foot{margin-top:18px;font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted-2);line-height:1.7;text-align:center}

/* ── Detail layout ── */
.detail-grid{display:grid;grid-template-columns:1fr 320px;gap:18px;align-items:start}
.kv{display:grid;grid-template-columns:120px 1fr;gap:10px;font-size:13px;padding:8px 0;border-top:1px dotted var(--line)}
.kv:first-child{border-top:none}
.kv .k{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);padding-top:2px}
.kv .v{font-weight:500}
.stat{display:flex;flex-direction:column;gap:3px}
.stat .lab{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted)}
.stat .big{font-family:var(--font-display);font-weight:900;font-size:26px;letter-spacing:-0.02em}
.timeline{position:relative;padding-left:18px}
.timeline .ev{position:relative;padding:0 0 16px}
.timeline .ev::before{content:"";position:absolute;left:-18px;top:4px;width:8px;height:8px;border-radius:50%;background:var(--orange)}
.timeline .ev::after{content:"";position:absolute;left:-15px;top:12px;bottom:-4px;width:1px;border-left:1px dotted var(--line)}
.timeline .ev:last-child::after{display:none}
.timeline .ev .when{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:0.04em}
.timeline .ev .what{font-size:13px;margin-top:1px}

@media(max-width:880px){.app{grid-template-columns:1fr}.rail{display:none}.detail-grid{grid-template-columns:1fr}}
