/* ══════════════════════════════════════════════════════════════════════════
   Flight Finder — Skyscanner-inspired UI v2
   ══════════════════════════════════════════════════════════════════════════ */

:root {
    --bg:           #f1f4f8;
    --card:         #ffffff;
    --primary:      #0770e3;
    --primary-h:    #0560c2;
    --primary-bg:   #e8f1fb;
    --text:         #161616;
    --text-2:       #545860;
    --text-3:       #8f949b;
    --border:       #dddde5;
    --border-l:     #e8eaed;
    --gold:         #ffb400;
    --green:        #0fa958;
    --green-bg:     #e8f8ef;
    --orange:       #ff9332;
    --red:          #eb5757;
    --red-bg:       #fdecea;
    --radius:       12px;
    --shadow:       0 1px 4px rgba(0,0,0,.08), 0 2px 12px rgba(0,0,0,.04);
    --shadow-h:     0 4px 16px rgba(0,0,0,.12);
    --font:         'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: var(--font); background: var(--bg); color: var(--text); min-height: 100vh; }
.hidden { display: none !important; }

/* ── LOGIN ──────────────────────────────────────────────────────────────── */
#login-screen {
    display: flex; align-items: center; justify-content: center;
    min-height: 100vh; background: linear-gradient(135deg, #0b1120 0%, #1a2744 100%);
}
.login-card {
    background: rgba(255,255,255,.06); backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,.12); border-radius: 20px;
    padding: 48px 40px; text-align: center; width: 340px;
}
.login-icon { font-size: 48px; margin-bottom: 24px; }
.login-card input {
    width: 100%; padding: 14px 18px; border: 1px solid rgba(255,255,255,.2);
    border-radius: 10px; background: rgba(255,255,255,.08); color: #fff;
    font-size: 15px; outline: none; transition: border .2s;
}
.login-card input:focus { border-color: var(--primary); }
.login-card input::placeholder { color: rgba(255,255,255,.4); }
.login-card button {
    width: 100%; padding: 14px; margin-top: 16px; border: none;
    border-radius: 10px; background: var(--primary); color: #fff;
    font-size: 15px; font-weight: 600; cursor: pointer; transition: background .2s;
}
.login-card button:hover { background: var(--primary-h); }
.pw-error { color: var(--red); margin-top: 12px; font-size: 13px; min-height: 18px; }
@keyframes shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-8px)} 75%{transform:translateX(8px)} }
.shake { animation: shake .3s ease-in-out; }

/* ── HEADER ─────────────────────────────────────────────────────────────── */
#header {
    background: var(--card); border-bottom: 1px solid var(--border);
    padding: 14px 28px; display: flex; align-items: center;
    justify-content: space-between; position: sticky; top: 0; z-index: 100;
    box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.header-left h1 { font-size: 20px; font-weight: 700; }
.header-right { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
#history-select {
    padding: 8px 12px; border: 1px solid var(--border); border-radius: 8px;
    font-family: var(--font); font-size: 13px; color: var(--text-2);
    background: var(--card); cursor: pointer; max-width: 300px;
}
.btn-icon {
    width: 40px; height: 40px; border: 1px solid var(--border); border-radius: 8px;
    background: var(--card); font-size: 18px; cursor: pointer; transition: background .15s;
    display: flex; align-items: center; justify-content: center;
}
.btn-icon:hover { background: var(--bg); }
.btn-primary {
    padding: 10px 20px; border: none; border-radius: 8px;
    background: var(--primary); color: #fff; font-family: var(--font);
    font-size: 14px; font-weight: 600; cursor: pointer; transition: background .15s;
    white-space: nowrap;
}
.btn-primary:hover { background: var(--primary-h); }
.btn-primary:disabled { opacity: .5; cursor: not-allowed; }
.force-refresh-label {
    display: flex; align-items: center; gap: 4px; font-size: 12px;
    color: var(--text-3); cursor: pointer; white-space: nowrap;
}
.force-refresh-label input { cursor: pointer; }

/* ── WARNING BANNER ─────────────────────────────────────────────────────── */
.warn-banner {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 28px; background: var(--red-bg); border-bottom: 1px solid var(--red);
    color: var(--red); font-size: 13px; font-weight: 500;
}
.warn-close { background: none; border: none; font-size: 18px; cursor: pointer; color: var(--red); }

/* ── PROGRESS ───────────────────────────────────────────────────────────── */
#progress-wrap { padding: 20px 28px; }
.progress-container {
    height: 8px; background: var(--border-l); border-radius: 8px; overflow: hidden;
}
.progress-bar {
    height: 100%; width: 0%; border-radius: 8px; transition: width .6s ease;
    background: linear-gradient(90deg, var(--primary), #00b4d8);
}
.progress-text { margin-top: 8px; font-size: 13px; color: var(--text-2); }

/* ── RESULTS HEADER ─────────────────────────────────────────────────────── */
#results-header { padding: 16px 28px; }
.results-meta {
    display: flex; align-items: center; justify-content: space-between;
    font-size: 14px; font-weight: 600; margin-bottom: 12px;
}
.text-muted { color: var(--text-3); font-weight: 400; margin-left: 12px; font-size: 13px; }
.results-sort { font-size: 12px; color: var(--text-3); margin-top: 8px; }

/* ── FILTER PANEL ───────────────────────────────────────────────────────── */
.filter-panel {
    background: var(--card); border: 1px solid var(--border);
    border-radius: var(--radius); box-shadow: var(--shadow);
    overflow: hidden;
}
.filter-toggle {
    display: flex; align-items: center; gap: 8px;
    padding: 12px 18px; cursor: pointer; user-select: none;
    font-size: 14px; font-weight: 600; color: var(--text);
    transition: background .15s;
}
.filter-toggle:hover { background: var(--bg); }
.filter-count {
    font-size: 11px; background: var(--primary); color: #fff;
    padding: 1px 7px; border-radius: 10px; font-weight: 700;
}
.filter-arrow { margin-left: auto; font-size: 11px; color: var(--text-3); transition: transform .25s; }
.filter-panel.open .filter-arrow { transform: rotate(180deg); }
.filter-body {
    display: none; padding: 0 18px 18px;
    border-top: 1px solid var(--border-l);
}
.filter-panel.open .filter-body { display: block; }
.filter-group { margin-top: 14px; }
.filter-label {
    display: block; font-size: 12px; font-weight: 600; color: var(--text-2);
    margin-bottom: 8px; text-transform: uppercase; letter-spacing: .3px;
}
.filter-dates { display: flex; gap: 16px; flex-wrap: wrap; }
.df-range {
    display: flex; align-items: center; gap: 6px; font-size: 13px;
}
.df-lbl { font-size: 11px; color: var(--text-3); font-weight: 600; min-width: 48px; }
.df-sep { color: var(--text-3); font-size: 12px; }
.df-range input[type="date"] {
    font-family: var(--font); font-size: 13px; padding: 6px 8px;
    border: 1px solid var(--border); border-radius: 6px;
    background: var(--bg); color: var(--text);
}
.df-range input[type="date"]:focus { outline: none; border-color: var(--primary); }

/* Filter pills (day + airport toggles) */
.filter-pills { display: flex; flex-wrap: wrap; gap: 6px; }
.filter-pill {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 6px 12px; border: 1px solid var(--border); border-radius: 20px;
    font-size: 13px; font-weight: 500; cursor: pointer;
    background: var(--card); color: var(--text-2);
    transition: all .15s; user-select: none;
}
.filter-pill:hover { border-color: var(--primary); color: var(--primary); }
.filter-pill.active {
    background: var(--primary-bg); border-color: var(--primary);
    color: var(--primary); font-weight: 600;
}
.filter-pill.unavailable {
    opacity: 0.35; border-style: dashed;
}
.filter-pill.unavailable:hover { opacity: 0.55; }
.filter-pill input { display: none; }

/* Tier toggle */
.filter-tier-label {
    display: flex; align-items: center; gap: 8px;
    font-size: 14px; font-weight: 500; cursor: pointer;
    padding: 8px 0;
}
.filter-tier-label input { width: 18px; height: 18px; cursor: pointer; accent-color: var(--primary); }

/* Destination mode toggle */
.filter-label-row {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 8px;
}
.filter-label-row .filter-label { margin-bottom: 0; }
.dest-mode-btn {
    padding: 4px 12px; border: 1px solid var(--border); border-radius: 6px;
    background: var(--card); font-family: var(--font); font-size: 12px;
    font-weight: 600; color: var(--primary); cursor: pointer; transition: all .15s;
}
.dest-mode-btn:hover { background: var(--primary-bg); }
.dest-mode-btn.exclude-mode {
    background: var(--red-bg); color: var(--red); border-color: var(--red);
}

/* Late loved filter */
.late-loved-row {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.late-loved-row .filter-pills {
    flex: 1 1 auto; min-width: 200px;
}
.ll-label { font-size: 13px; color: var(--text-2); white-space: nowrap; }
.ll-time-input {
    width: 56px; padding: 6px 8px; border: 1px solid var(--border); border-radius: 6px;
    font-family: var(--font); font-size: 13px; text-align: center; color: var(--text);
    background: var(--card);
}
.ll-time-input:focus { outline: none; border-color: var(--primary); }
.filter-hint { font-size: 11px; color: var(--text-3); margin-top: 6px; }

/* Filter actions */
.filter-actions {
    display: flex; gap: 10px; margin-top: 16px; padding-top: 14px;
    border-top: 1px solid var(--border-l);
}
.btn-filter { font-family: var(--font); }
.btn-sm {
    padding: 6px 14px; border: 1px solid var(--border); border-radius: 6px;
    background: transparent; color: var(--text-2); font-family: var(--font);
    font-size: 13px; font-weight: 500; cursor: pointer; transition: all .15s;
}
.btn-sm:hover { background: var(--bg); border-color: var(--text-3); }
.btn-primary.btn-filter { padding: 8px 20px; font-size: 13px; }

/* ── TRIP CARDS ─────────────────────────────────────────────────────────── */
#trips { padding: 0 28px 28px; display: flex; flex-direction: column; gap: 14px; }
.trip-card {
    background: var(--card); border-radius: var(--radius); box-shadow: var(--shadow);
    overflow: hidden; transition: box-shadow .2s;
}
.trip-card:hover { box-shadow: var(--shadow-h); }

/* Card header */
.tc-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 24px; border-bottom: 1px solid var(--border-l);
    gap: 12px; flex-wrap: wrap;
}
.tc-head-left { display: flex; align-items: center; gap: 10px; }
.tc-rank { font-size: 13px; color: var(--text-3); font-weight: 600; }
.tc-score {
    display: inline-flex; align-items: center; gap: 3px;
    padding: 4px 10px; border-radius: 6px; font-size: 14px; font-weight: 700; color: #fff;
}
.tc-score.high { background: var(--green); }
.tc-score.mid  { background: var(--orange); }
.tc-score.low  { background: var(--red); }
.tc-head-center { flex: 1; text-align: center; min-width: 180px; }
.tc-dates .dur { font-weight: 700; font-size: 15px; }
.tc-dates .range { color: var(--text-2); font-size: 13px; margin-left: 8px; }
.tc-dest-h { display: block; font-size: 12px; color: var(--text-3); margin-top: 2px; }
.tc-price { font-size: 24px; font-weight: 800; color: var(--green); white-space: nowrap; }

/* ── FLIGHT ROW (Outbound / Return) ────────────────────────────────────── */
.flight-row { padding: 16px 24px; }
.flight-row + .flight-row { border-top: 1px dashed var(--border-l); }
.fr-label {
    display: flex; align-items: center; justify-content: space-between;
    font-size: 12px; font-weight: 700; color: var(--text-3);
    text-transform: uppercase; letter-spacing: .5px; margin-bottom: 12px;
}
.fr-label .fl-price {
    font-size: 14px; color: var(--text-2); font-weight: 700;
    letter-spacing: 0; text-transform: none;
}

/* ── SEGMENT ROW (full-width Skyscanner-style) ─────────────────────────── */
.seg-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 16px;
    padding: 8px 0;
}
.seg-point { text-align: center; min-width: 52px; }
.seg-point.seg-dep { text-align: left; }
.seg-point.seg-arr { text-align: right; }
.seg-time { display: block; font-size: 20px; font-weight: 700; line-height: 1.2; }
.seg-iata { display: block; font-size: 12px; color: var(--text-2); font-weight: 500; margin-top: 1px; }
.seg-line {
    display: flex; align-items: center; justify-content: center;
    position: relative; min-height: 28px;
}
.seg-line::before {
    content: ''; position: absolute; top: 50%; left: 0; right: 0;
    height: 2px; background: var(--border); border-radius: 1px;
}
.seg-carrier-lbl {
    position: relative; z-index: 1;
    background: var(--card); padding: 2px 10px;
    font-size: 11px; color: var(--text-3); white-space: nowrap;
    border-radius: 10px; border: 1px solid var(--border-l);
}
.seg-direct-badge {
    position: relative; z-index: 1;
    background: var(--green-bg); padding: 2px 10px;
    font-size: 11px; color: var(--green); font-weight: 600;
    white-space: nowrap; border-radius: 10px;
    border: 1px solid rgba(15,169,88,.2);
    margin-left: 6px;
}
.seg-dot {
    position: relative; z-index: 1; width: 8px; height: 8px;
    background: var(--primary); border-radius: 50%;
    flex-shrink: 0;
}
.next-day { font-size: 10px; color: var(--orange); vertical-align: super; font-weight: 700; }

/* ── LAYOVER BAR ────────────────────────────────────────────────────────── */
.seg-layover {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 0 6px 28px; margin: 2px 0 2px 24px;
    font-size: 12px; color: var(--text-2);
    border-left: 2px dashed var(--border);
}
.seg-layover .lay-dur { font-weight: 700; color: var(--text); }
.seg-layover .stop-score { font-weight: 700; font-size: 12px; }
.seg-layover .stop-score.s-high { color: var(--green); }
.seg-layover .stop-score.s-mid  { color: var(--orange); }
.seg-layover .stop-score.s-low  { color: var(--red); }
.seg-layover .avoid-tag { color: var(--red); font-size: 10px; }

/* ── HOME QUALITY FOOTER ───────────────────────────────────────────────── */
.tc-home {
    display: flex; align-items: center; justify-content: center; gap: 24px;
    padding: 10px 24px; background: #f8f9fb; border-top: 1px solid var(--border-l);
    font-size: 13px; flex-wrap: wrap;
}
.home-badge { display: inline-flex; align-items: center; gap: 6px; }
.home-badge .tag-gold { color: var(--gold); font-weight: 700; }
.home-badge .tag-good { color: var(--green); font-weight: 600; }
.home-badge .tag-meh  { color: var(--text-3); }
.home-badge .tag-poor { color: var(--red); font-weight: 600; }

/* Score breakdown footer */
.tc-footer {
    display: flex; flex-wrap: wrap; gap: 8px; padding: 10px 24px;
    border-top: 1px solid var(--border-l);
}
.badge {
    font-size: 11px; padding: 3px 8px; border-radius: 4px;
    background: var(--bg); color: var(--text-2); white-space: nowrap;
}

/* ── PAGINATION ─────────────────────────────────────────────────────────── */
#pagination {
    display: flex; align-items: center; justify-content: center;
    gap: 6px; padding: 20px 28px 40px; flex-wrap: wrap;
}
.pg-btn {
    min-width: 38px; height: 38px; border: 1px solid var(--border);
    border-radius: 8px; background: var(--card); font-family: var(--font);
    font-size: 14px; cursor: pointer; transition: all .15s;
    display: flex; align-items: center; justify-content: center;
}
.pg-btn:hover { background: var(--bg); border-color: var(--primary); }
.pg-btn.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.pg-btn:disabled { opacity: .4; cursor: default; }
.pg-info { font-size: 13px; color: var(--text-3); margin: 0 12px; }

/* ── EMPTY STATE ────────────────────────────────────────────────────────── */
#empty-state { text-align: center; padding: 80px 28px; }
.empty-icon { font-size: 48px; margin-bottom: 16px; }
#empty-state p { color: var(--text-2); font-size: 15px; }

/* ── CONFIG MODAL ───────────────────────────────────────────────────────── */
.modal-overlay {
    position: fixed; inset: 0; z-index: 200;
    background: rgba(0,0,0,.45); display: flex; align-items: start; justify-content: center;
    padding: 40px 20px; overflow-y: auto;
}
.modal {
    background: var(--card); border-radius: 16px; width: 880px;
    max-width: 100%; box-shadow: 0 20px 60px rgba(0,0,0,.25); animation: modalIn .2s ease;
}
@keyframes modalIn { from { opacity: 0; transform: translateY(-20px); } }
.modal-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 20px 24px; border-bottom: 1px solid var(--border-l);
}
.modal-header h2 { font-size: 18px; }
.btn-close {
    width: 36px; height: 36px; border: none; border-radius: 8px;
    background: transparent; font-size: 22px; cursor: pointer; color: var(--text-3);
    transition: background .15s;
}
.btn-close:hover { background: var(--bg); }
.modal-body { padding: 20px 28px; max-height: 70vh; overflow-y: auto; }
.modal-footer {
    padding: 16px 24px; border-top: 1px solid var(--border-l);
    display: flex; align-items: center; justify-content: space-between;
}
.weight-sum { font-size: 13px; color: var(--text-3); }

/* Config sections */
.cfg-history {
    margin-bottom: 18px; padding-bottom: 18px;
    border-bottom: 2px solid var(--primary-bg);
}
.cfg-history-select {
    width: 100%; padding: 10px 14px; border: 1px solid var(--border);
    border-radius: 8px; font-family: var(--font); font-size: 13px;
    color: var(--text-2); background: var(--bg); cursor: pointer;
}
.cfg-history-select:focus { outline: none; border-color: var(--primary); }
.cfg-section { margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid var(--border-l); }
.cfg-section:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.cfg-section-title {
    font-size: 13px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .8px; color: var(--primary); margin-bottom: 12px;
}
.cfg-subsection-title {
    font-size: 12px; font-weight: 600; color: var(--text-2);
    margin-bottom: 8px; text-transform: uppercase; letter-spacing: .4px;
}
.cfg-row {
    display: flex; align-items: center; gap: 12px; margin-bottom: 8px;
}
.cfg-row label {
    flex: 0 0 170px; font-size: 13px; color: var(--text-2); text-align: right;
}
.cfg-row input, .cfg-row select {
    flex: 1; padding: 8px 10px; border: 1px solid var(--border);
    border-radius: 6px; font-family: var(--font); font-size: 13px; color: var(--text);
}
.cfg-row input:focus { outline: none; border-color: var(--primary); }
.cfg-hint { font-size: 11px; color: var(--text-3); margin-left: 182px; margin-top: -4px; margin-bottom: 6px; }
.cfg-tolerated-box {
    background: var(--bg); border: 1px solid var(--border-l); border-radius: 8px;
    padding: 10px 14px; margin: 10px 0 6px;
}
.cfg-tolerated-box label {
    font-size: 12px; font-weight: 600; color: var(--text-2);
    text-transform: uppercase; letter-spacing: .4px;
}
.cfg-tolerated-list {
    font-size: 13px; color: var(--text); margin-top: 6px; line-height: 1.6;
}
.dep-rules-table {
    width: 100%; border-collapse: collapse; margin: 8px 0 4px; font-size: 13px;
}
.dep-rules-table th {
    text-align: center; font-weight: 600; padding: 6px 8px;
    border-bottom: 2px solid var(--border); text-transform: capitalize;
}
.dep-rules-table td { padding: 4px 6px; text-align: center; border-bottom: 1px solid var(--border-l); }
.dep-rules-table td:first-child { text-align: left; width: 60px; }
.dep-rule-input {
    width: 54px; padding: 6px 4px; border: 1px solid var(--border); border-radius: 4px;
    text-align: center; font-family: var(--font); font-size: 13px; color: var(--text);
}
.dep-rule-input:focus { outline: none; border-color: var(--primary); }
.dep-rule-input::placeholder { color: var(--text-3); font-size: 11px; }
.day-checks { display: flex; gap: 10px; flex-wrap: wrap; }
.day-check { display: flex; align-items: center; gap: 3px; font-size: 13px; cursor: pointer; }
.day-check input[type="checkbox"] { width: 16px; height: 16px; cursor: pointer; }
.cfg-row input[type="checkbox"] { width: 18px; height: 18px; cursor: pointer; }

/* ── RESPONSIVE ─────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
    #header { flex-direction: column; gap: 10px; padding: 12px 16px; }
    .header-right { width: 100%; justify-content: center; flex-wrap: wrap; }
    #history-select { max-width: 100%; }
    #results-header { padding: 12px 16px; }
    #trips { padding: 0 12px 20px; }
    .trip-card { border-radius: 10px; }
    .tc-head { padding: 14px 16px; flex-direction: column; align-items: stretch; text-align: center; }
    .tc-head-left { justify-content: center; }
    .tc-head-center { text-align: center; min-width: 0; }
    .tc-price { text-align: center; font-size: 22px; }
    .flight-row { padding: 14px 16px; }
    .seg-row { gap: 10px; }
    .seg-time { font-size: 17px; }
    .seg-iata { font-size: 11px; }
    .seg-carrier-lbl { font-size: 10px; padding: 2px 6px; }
    .seg-layover { padding-left: 18px; margin-left: 16px; }
    .tc-home { padding: 10px 16px; gap: 12px; }
    .tc-footer { padding: 8px 16px; }
    .filter-dates { flex-direction: column; }
    .modal { width: 100%; }
    .cfg-row { flex-direction: column; align-items: stretch; }
    .cfg-row label { text-align: left; flex: none; }
    .cfg-hint { margin-left: 0; }
    .cfg-tolerated-box { margin: 8px 0; }
    .late-loved-row { flex-direction: column; align-items: flex-start; }
    #pagination { padding: 16px 12px 30px; }
}

@media (max-width: 480px) {
    #header { padding: 10px 12px; }
    .header-left h1 { font-size: 17px; }
    .header-right { gap: 6px; }
    #history-select { font-size: 12px; padding: 6px 8px; }
    .btn-primary { padding: 8px 14px; font-size: 13px; }
    #results-header { padding: 10px 12px; }
    #trips { padding: 0 8px 16px; gap: 10px; }
    .tc-head { padding: 12px; gap: 6px; }
    .tc-score { font-size: 13px; padding: 3px 8px; }
    .tc-price { font-size: 20px; }
    .tc-dates .dur { font-size: 14px; }
    .tc-dates .range { font-size: 12px; }
    .flight-row { padding: 12px; }
    .fr-label { font-size: 11px; margin-bottom: 10px; }
    .seg-row { gap: 6px; grid-template-columns: 50px 1fr 50px; }
    .seg-time { font-size: 15px; }
    .seg-point { min-width: 42px; }
    .seg-layover { font-size: 11px; padding-left: 12px; margin-left: 10px; gap: 5px; }
    .tc-home { font-size: 12px; padding: 8px 12px; gap: 8px; flex-direction: column; }
    .tc-footer { padding: 8px 12px; gap: 6px; }
    .badge { font-size: 10px; padding: 2px 6px; }
    .filter-panel { border-radius: 8px; }
    .filter-toggle { padding: 10px 14px; font-size: 13px; }
    .filter-body { padding: 0 14px 14px; }
    .filter-pill { padding: 5px 10px; font-size: 12px; }
    .pg-btn { min-width: 34px; height: 34px; font-size: 13px; }
    .pg-info { font-size: 12px; margin: 0 6px; }
}

/* ── LIVE LOGS PANEL ────────────────────────────────────────────────────── */
.logs-panel {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 150;
    background: #1a1d23; color: #c8ccd4; font-family: 'Menlo', 'Monaco', 'Courier New', monospace;
    font-size: 12px; box-shadow: 0 -4px 20px rgba(0,0,0,.3);
    transition: height .3s ease; border-top: 2px solid var(--primary);
}
.logs-panel.collapsed { height: 38px; }
.logs-panel.expanded { height: 320px; }
.logs-toggle {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 20px; cursor: pointer; user-select: none;
    background: #21252b; font-family: var(--font); font-size: 13px; font-weight: 600;
    color: #abb2bf;
}
.logs-toggle:hover { background: #282c34; }
.logs-arrow { margin-left: auto; font-size: 10px; transition: transform .3s; }
.logs-panel.expanded .logs-arrow { transform: rotate(180deg); }
.logs-badge {
    background: var(--primary); color: #fff; font-size: 10px; font-weight: 700;
    padding: 1px 6px; border-radius: 8px; min-width: 18px; text-align: center;
}
.logs-body { display: flex; flex-direction: column; height: calc(100% - 38px); }
.logs-controls {
    display: flex; align-items: center; gap: 12px;
    padding: 6px 20px; background: #282c34; border-bottom: 1px solid #3a3f4b;
}
.log-auto-label { font-family: var(--font); font-size: 12px; color: #8b929e; display: flex; align-items: center; gap: 4px; cursor: pointer; }
.log-auto-label input { cursor: pointer; }
.logs-controls .btn-sm {
    padding: 3px 10px; border: 1px solid #3a3f4b; border-radius: 4px;
    background: transparent; color: #8b929e; font-family: var(--font); font-size: 11px;
    cursor: pointer;
}
.logs-controls .btn-sm:hover { background: #3a3f4b; color: #c8ccd4; }
.logs-controls select {
    padding: 3px 8px; border: 1px solid #3a3f4b; border-radius: 4px;
    background: #1a1d23; color: #c8ccd4; font-family: var(--font); font-size: 11px;
    cursor: pointer;
}
.logs-output {
    flex: 1; overflow-y: auto; padding: 8px 20px; line-height: 1.6;
}
.logs-output::-webkit-scrollbar { width: 6px; }
.logs-output::-webkit-scrollbar-track { background: #1a1d23; }
.logs-output::-webkit-scrollbar-thumb { background: #3a3f4b; border-radius: 3px; }
.log-line { white-space: pre-wrap; word-break: break-word; }
.log-ts { color: #5c6370; }
.log-level-INFO { color: #61afef; }
.log-level-WARNING { color: #e5c07b; }
.log-level-ERROR { color: #e06c75; font-weight: 700; }
.log-name { color: #c678dd; }
.log-msg { color: #abb2bf; }
.log-msg-search { color: #98c379; }
.log-msg-progress { color: #61afef; font-weight: 600; }
