.app { display:flex; min-height:100vh; }
.drawer {
  position:fixed; inset:0 auto 0 0; width:306px; max-width:86vw; z-index:35;
  display:flex; flex-direction:column; gap:14px;
  background: linear-gradient(180deg, rgba(19,40,75,.98), rgba(7,17,38,.98));
  border-right:1px solid var(--line); padding:18px; transform:translateX(-104%);
  transition: transform .25s ease; box-shadow: var(--shadow);
}
.drawer.open { transform:translateX(0); }
.drawer-head { display:flex; gap:12px; align-items:center; }
.drawer-head small, .brand small { display:block; color:var(--muted); font-size:.78rem; }
.mini-logo img { width:46px; height:46px; object-fit:cover; border-radius:13px; }
.nav { display:grid; gap:8px; overflow:auto; padding-right:4px; }
.nav button, .ghost {
  border:1px solid var(--line); color:var(--text); background:rgba(255,255,255,.045);
  border-radius:16px; padding:12px 14px; text-align:left;
}
.nav button:hover, .ghost:hover { border-color:var(--gold); background:rgba(201,163,78,.12); }
.drawer-foot { display:grid; gap:8px; margin-top:auto; padding-top:8px; border-top:1px solid var(--line); }
.file-label { display:block; cursor:pointer; }

.shell { flex:1; min-width:0; }
.topbar {
  position:sticky; top:0; z-index:20; display:flex; align-items:center; gap:10px; padding:12px 16px;
  background:rgba(7,17,38,.84); backdrop-filter: blur(14px); border-bottom:1px solid var(--line);
}
.top-left{display:flex;gap:8px;}
.icon-btn {
  width:42px; height:42px; border:1px solid var(--line); border-radius:14px; background:rgba(255,255,255,.06); color:var(--text);
}
.icon-btn:hover { border-color:var(--gold); color:var(--gold); }
.brand { flex:1; min-width:160px; }
.brand span { color:var(--gold); font-weight:900; letter-spacing:.02em; }
.top-actions { display:flex; align-items:center; gap:8px; }
.top-actions select { width:220px; max-width:32vw; }

.processbar {
  position:sticky; top:67px; z-index:19; display:grid; grid-template-columns:auto 1fr auto; gap:10px; align-items:center;
  padding:10px 16px; background:rgba(12,27,51,.93); backdrop-filter:blur(12px); border-bottom:1px solid var(--line);
}
.route-chips { display:flex; gap:8px; flex-wrap:nowrap; overflow:auto; scrollbar-width:none; }
.route-chips::-webkit-scrollbar{display:none;}
.chip-btn { white-space:nowrap; border:1px solid var(--line); background:rgba(255,255,255,.045); color:var(--text); border-radius:999px; padding:9px 12px; }
.chip-btn.active { background:rgba(201,163,78,.16); border-color:var(--gold); color:var(--gold); }
.nav-arrow{min-width:110px;}

.view { padding:22px; max-width:1440px; margin:0 auto; }
.hero, .card, .panel {
  background: linear-gradient(180deg, rgba(19,40,75,.86), rgba(10,22,43,.78));
  border:1px solid var(--line); border-radius:var(--radius); box-shadow: var(--shadow);
}
.hero { padding:24px; margin-bottom:20px; position:relative; overflow:hidden; }
.hero:after { content:""; position:absolute; inset:auto -20% -50% auto; width:360px; height:360px; border-radius:50%; background:radial-gradient(circle, rgba(201,163,78,.16), transparent 68%); }
.hero h2, .section-title { margin:0 0 8px; color:var(--gold); }
.hero p { margin:0; color:var(--muted); max-width:900px; line-height:1.55; }

.grid { display:grid; gap:16px; }
.grid.cards { grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); }
.card { padding:18px; min-height:150px; position:relative; overflow:hidden; }
.card h3 { margin:0 0 10px; }
.card p { color:var(--muted); line-height:1.45; }
.card .emoji { font-size:2rem; display:inline-block; margin-bottom:8px; }
.card button { margin-top:10px; }
.stat { font-size:2.1rem; font-weight:900; color:var(--gold); }
.badge { display:inline-flex; align-items:center; gap:6px; border:1px solid var(--line); border-radius:999px; padding:5px 10px; font-size:.78rem; color:var(--muted); background:rgba(255,255,255,.045); }
.badge.ok { color:var(--success); border-color:rgba(71,209,140,.4); }
.badge.warn { color:var(--warning); border-color:rgba(255,204,102,.4); }
.badge.danger { color:var(--danger); border-color:rgba(255,107,107,.4); }
.badge.info { color:var(--info); border-color:rgba(125,198,255,.4); }

button.primary, .primary {
  border:0; border-radius:18px; padding:12px 18px; color:#071126; font-weight:900;
  background:linear-gradient(135deg, var(--gold), var(--gold-2)); box-shadow:0 14px 30px rgba(0,0,0,.18);
}
button.secondary { border:1px solid var(--gold); color:var(--gold); background:rgba(201,163,78,.08); border-radius:16px; padding:10px 14px; }
button.ghost, .ghost { border:1px solid var(--line); color:var(--text); background:rgba(255,255,255,.045); border-radius:16px; padding:10px 14px; }
button.danger { border:1px solid rgba(255,107,107,.45); color:#fff; background:rgba(255,107,107,.15); border-radius:16px; padding:10px 14px; }
.wide { width:100%; text-align:center; }
.actions-inline{display:flex; gap:8px; flex-wrap:wrap; align-items:center;}
.actions-right{display:flex; gap:8px; justify-content:flex-end; flex-wrap:wrap;}
.compact-btn{padding:8px 10px; border-radius:12px; font-size:.9rem;}
.edit-pill{font-size:.78rem; color:var(--info);}

.alert { border-radius:16px; padding:12px 14px; border:1px solid var(--line); margin:12px 0; }
.alert.info { border-color:rgba(125,198,255,.38); background:rgba(125,198,255,.10); }
.alert.warn { border-color:rgba(255,204,102,.45); background:rgba(255,204,102,.10); }
.alert.danger { border-color:rgba(255,107,107,.45); background:rgba(255,107,107,.10); }

.table-wrap { overflow:auto; border:1px solid var(--line); border-radius:18px; }
table { width:100%; border-collapse:collapse; min-width:780px; }
th, td { padding:12px; border-bottom:1px solid var(--line); vertical-align:top; text-align:left; }
th { color:var(--gold); background:rgba(255,255,255,.045); position:sticky; top:0; }
td { color:var(--text); }
td small { color:var(--muted); }

.tabs { display:flex; gap:8px; flex-wrap:wrap; margin:14px 0; }
.tabs button { border:1px solid var(--line); background:rgba(255,255,255,.045); color:var(--text); border-radius:999px; padding:9px 12px; }
.tabs button.active { background:rgba(201,163,78,.16); border-color:var(--gold); color:var(--gold); }

.wizard { display:grid; gap:16px; }
.stepper { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.stepper span { flex:1; min-width:130px; padding:10px; border-radius:14px; border:1px solid var(--line); color:var(--muted); text-align:center; }
.stepper span.active { border-color:var(--gold); color:var(--gold); background:rgba(201,163,78,.10); }
.form-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap:12px; }
.two-col {display:grid; grid-template-columns:1fr 1fr; gap:16px;}

.progress { width:100%; height:10px; background:rgba(255,255,255,.08); border-radius:999px; overflow:hidden; }
.progress > span { display:block; height:100%; background:linear-gradient(90deg, var(--gold), var(--success)); border-radius:999px; }

.toast {
  position:fixed; z-index:50; bottom:20px; left:50%; transform:translateX(-50%) translateY(120%);
  background:rgba(7,17,38,.96); color:var(--text); border:1px solid var(--line); border-radius:16px; padding:12px 16px;
  box-shadow:var(--shadow); transition:.25s ease;
}
.toast.show { transform:translateX(-50%) translateY(0); }

.tooltip {
  display:inline-flex; width:20px; height:20px; align-items:center; justify-content:center; margin-left:4px;
  border-radius:50%; border:1px solid var(--line); color:var(--info); font-size:.8rem; position:relative;
}
.tooltip:hover::after {
  content:attr(data-tip); position:absolute; left:50%; top:120%; transform:translateX(-50%);
  width:260px; background:var(--bg-deep); border:1px solid var(--line); padding:10px; border-radius:12px; color:var(--text);
  box-shadow:var(--shadow); z-index:10; line-height:1.35;
}

@media (max-width:860px) {
  .processbar{grid-template-columns:1fr;}
  .nav-arrow{min-width:0;}
}
@media (max-width:760px) {
  .top-actions select { display:none; }
  .view { padding:14px; }
  .hero { padding:18px; }
  .card { min-height:auto; }
  table { min-width:620px; }
  .two-col{grid-template-columns:1fr;}
  .processbar{top:67px; padding:10px 12px;}
}
