
:root { color-scheme: dark; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; background: #080b10; color: #f6f8fb; --surface: #111821; --line: #273341; --muted: #a6b2c3; --gold: #f0c45a; --green: #3fd0a0; --blue: #6ca8ff; }
* { box-sizing: border-box; }
body { margin: 0; min-width: 320px; background: linear-gradient(180deg, rgba(23, 31, 42, .96), #080b10 420px), #080b10; }
.planner { width: 100%; max-width: 1460px; margin: 0 auto; padding: 20px; }
.planner-head { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 22px; border: 1px solid rgba(255,255,255,.08); border-radius: 8px; background: linear-gradient(135deg, rgba(18,24,33,.98), rgba(9,14,21,.96)); box-shadow: 0 18px 50px rgba(0,0,0,.34); }
.eyebrow { margin: 0 0 8px; color: var(--gold); font-size: 12px; text-transform: uppercase; font-weight: 850; letter-spacing: .08em; }
h1, h2, p { margin: 0; }
h1 { font-size: clamp(30px, 3.4vw, 48px); line-height: 1; letter-spacing: 0; }
.status { min-width: 112px; padding: 9px 12px; border: 1px solid #566172; border-radius: 7px; text-align: center; text-transform: uppercase; letter-spacing: .04em; font-size: 13px; font-weight: 900; }
.status.ok { border-color: #2e936d; color: #9ff0c8; background: rgba(46,147,109,.12); }
.status.warn { border-color: #b98932; color: #ffd37a; background: rgba(185,137,50,.12); }
.toolbar { position: sticky; top: 0; z-index: 3; display: grid; grid-template-columns: minmax(240px, 1fr) 220px 180px; gap: 10px; padding: 14px 0; background: rgba(8,11,16,.9); backdrop-filter: blur(14px); }
label { display: grid; gap: 6px; color: var(--muted); font-size: 12px; font-weight: 850; text-transform: uppercase; letter-spacing: .04em; }
input, select { width: 100%; min-height: 42px; border: 1px solid rgba(255,255,255,.11); border-radius: 7px; padding: 9px 11px; background: #0f151d; color: #f6f8fb; font: inherit; font-size: 14px; letter-spacing: 0; }
.summary { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; margin-bottom: 14px; }
.stat, .series-card { border: 1px solid rgba(255,255,255,.08); border-radius: 8px; background: rgba(17,24,33,.95); min-width: 0; }
.stat { padding: 14px; border-left: 3px solid var(--blue); }
.stat:nth-child(2) { border-left-color: var(--gold); }
.stat:nth-child(3) { border-left-color: var(--green); }
.stat b { display: block; margin-top: 6px; font-size: 22px; }
.label { color: var(--muted); font-size: 11px; font-weight: 850; text-transform: uppercase; letter-spacing: .05em; }
.series-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.series-card { padding: 15px; display: grid; gap: 12px; }
h2 { font-size: 17px; line-height: 1.2; letter-spacing: 0; text-transform: none; color: #fff; }
.chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip { display: inline-flex; align-items: center; min-height: 26px; border-radius: 999px; padding: 4px 8px; background: rgba(108,168,255,.14); color: #c6ddff; font-size: 12px; font-weight: 850; white-space: nowrap; }
.chip.fixed { background: rgba(63,208,160,.14); color: #a8f2d8; }
.chip.open { background: rgba(240,196,90,.14); color: #ffe0a0; }
.cars, .weeks { color: #d5dde8; font-size: 13px; line-height: 1.45; }
.weeks { display: grid; gap: 6px; }
.week { display: grid; grid-template-columns: 44px minmax(0, 1fr); gap: 8px; padding: 8px; border-radius: 7px; background: rgba(8,12,18,.72); }
.week b { color: var(--gold); font-size: 12px; }
.week span { overflow-wrap: anywhere; }
.empty { grid-column: 1 / -1; padding: 22px; border: 1px solid rgba(255,255,255,.08); border-radius: 8px; background: rgba(17,24,33,.95); color: var(--muted); line-height: 1.5; }
@media (max-width: 980px) { .series-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .summary, .toolbar { grid-template-columns: 1fr 1fr; } .search-box { grid-column: 1 / -1; } }
@media (max-width: 640px) { .planner { padding: 12px; } .planner-head { align-items: flex-start; flex-direction: column; padding: 18px; } .series-grid, .summary, .toolbar { grid-template-columns: 1fr; } .search-box { grid-column: auto; } h1 { font-size: 30px; } }
