:root{--bg-primary:#09090b;--bg-secondary:#18181b;--bg-tertiary:#27272a;--bg-hover:#3f3f46;--border:#27272a;--border-light:#3f3f46;--text-primary:#fafafa;--text-secondary:#a1a1aa;--text-muted:#71717a;--accent-blue:#3b82f6;--accent-blue-glow:#3b82f626;--accent-green:#10b981;--accent-red:#ef4444;--accent-amber:#f59e0b;--gap-bg:#facc1514;--gap-border:#facc154d;--gap-text:#facc15;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 30px #0009;--transition:.2s cubic-bezier(.4,0,.2,1);--font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);height:100vh;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);width:280px;min-width:280px;transition:all var(--transition);flex-direction:column;display:flex;position:relative;overflow-y:auto}.sidebar-collapsed{width:48px;min-width:48px}.sidebar-toggle{z-index:10;background:var(--bg-tertiary);border:1px solid var(--border-light);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;width:28px;height:28px;transition:all var(--transition);justify-content:center;align-items:center;display:flex;position:absolute;top:12px;right:10px}.sidebar-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-collapsed .sidebar-toggle{right:10px}.sidebar-header{padding:20px 16px 12px}.sidebar-logo{color:var(--accent-blue);align-items:center;gap:10px;display:flex}.sidebar-title{background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:700}.sidebar-subtitle{color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;margin-top:2px;padding-left:34px;font-size:.78rem;font-weight:400}.sidebar-section{flex:1;padding:0 12px 12px}.sidebar-section-header{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 4px 8px;display:flex}.sidebar-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-size:.75rem;font-weight:600}.btn-add{background:var(--accent-blue);color:#fff;border-radius:var(--radius-sm);cursor:pointer;width:26px;height:26px;transition:all var(--transition);border:none;justify-content:center;align-items:center;display:flex}.btn-add:hover{background:#2563eb;transform:scale(1.05)}.van-form{background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border);flex-direction:column;gap:8px;margin-bottom:8px;padding:10px;animation:.2s ease-out slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-size:.85rem;font-family:var(--font);transition:border-color var(--transition);outline:none;padding:8px 10px}.input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px var(--accent-blue-glow)}.input::placeholder{color:var(--text-muted)}.color-picker{align-items:center;gap:8px;display:flex}.color-picker-label{color:var(--text-secondary);white-space:nowrap;font-size:.78rem}.color-options{flex-wrap:wrap;gap:4px;display:flex}.color-dot{cursor:pointer;width:20px;height:20px;transition:all var(--transition);border:2px solid #0000;border-radius:50%}.color-dot:hover{transform:scale(1.15)}.color-dot-active{box-shadow:0 0 0 2px var(--bg-primary);border-color:#fff}.btn-primary{border-radius:var(--radius-sm);color:#fff;width:100%;font-size:.82rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--transition);background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;padding:8px 12px}.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.van-list{flex-direction:column;gap:2px;display:flex}.van-item{border-radius:var(--radius-sm);transition:background var(--transition);justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.van-item:hover{background:var(--bg-tertiary)}.van-item-info{align-items:center;gap:8px;display:flex;overflow:hidden}.van-color-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.van-name{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.btn-delete{color:var(--text-muted);cursor:pointer;transition:all var(--transition);opacity:0;background:0 0;border:none;border-radius:4px;padding:4px}.van-item:hover .btn-delete{opacity:1}.btn-delete:hover{color:var(--accent-red);background:#ef44441a}.empty-state{color:var(--text-muted);text-align:center;padding:20px 10px;font-size:.78rem;line-height:1.5}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.main-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.header-left{align-items:center;gap:14px;display:flex}.app-title{letter-spacing:-.3px;font-size:1.15rem;font-weight:700}.sync-status{color:var(--text-muted);background:var(--bg-primary);border:1px solid var(--border);border-radius:100px;padding:3px 8px;font-size:.72rem}.header-right{align-items:center;gap:14px;display:flex}.btn-sync{background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font);cursor:pointer;transition:all var(--transition);align-items:center;gap:6px;padding:6px 12px;font-size:.78rem;display:flex}.btn-sync:hover{background:var(--bg-hover);color:var(--text-primary)}.clock-widget{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:10px;padding:6px 14px;display:flex}.clock-time{font-variant-numeric:tabular-nums;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.1rem;font-weight:700}.clock-day{color:var(--text-primary);font-size:.75rem;font-weight:600}.clock-date{color:var(--text-muted);font-size:.68rem}.timeline-container{flex-direction:column;flex:1;display:flex;overflow:hidden}.timeline-nav{background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;padding:10px 20px;display:flex}.btn-nav{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);font-family:var(--font);justify-content:center;align-items:center;padding:5px 8px;font-size:.78rem;display:flex}.btn-nav:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-today{padding:5px 12px;font-weight:500}.timeline-week-label{color:var(--text-primary);text-align:center;min-width:200px;font-size:.88rem;font-weight:600}.timeline-scroll{flex:1;padding:0;overflow:auto}.timeline-grid{grid-template-columns:140px repeat(7,1fr);min-width:700px;display:grid}.timeline-header-cell{text-align:center;color:var(--text-secondary);background:var(--bg-secondary);border-bottom:2px solid var(--border);border-right:1px solid var(--border);z-index:5;padding:10px 8px;font-size:.82rem;font-weight:600;position:sticky;top:0}.timeline-label-col{z-index:6;text-align:left;padding-left:16px;position:sticky;left:0}.timeline-label-text{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-size:.72rem}.timeline-header-today{color:var(--accent-blue);background:linear-gradient(to bottom,#3b82f614,var(--bg-secondary));border-bottom-color:var(--accent-blue)}.timeline-row-group{display:contents}.timeline-row-label{background:var(--bg-primary);border-bottom:1px solid var(--border);border-right:1px solid var(--border);z-index:4;align-items:center;gap:8px;min-height:36px;padding:0 12px;display:flex;position:sticky;left:0}.van-color-dot-sm{border-radius:50%;flex-shrink:0;width:8px;height:8px}.timeline-van-name{white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:500;overflow:hidden}.timeline-cell{background:var(--bg-primary);border-bottom:1px solid var(--border);border-right:1px solid var(--border);min-height:36px;padding:4px 2px;position:relative}.timeline-cell-today{background:#3b82f608}.event-block{cursor:default;transition:opacity var(--transition);box-shadow:var(--shadow-sm);z-index:2;border-radius:0;align-items:center;padding:0 6px;display:flex;position:absolute;top:0;bottom:0;overflow:hidden}.event-block:after{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(#ffffff1a 0%,#0000 100%);position:absolute;inset:0}.event-block:hover{opacity:.85;z-index:3}.event-text{color:#fff;white-space:nowrap;text-overflow:ellipsis;text-shadow:0 1px 2px #0000004d;z-index:1;font-size:.8rem;font-weight:700;position:relative;overflow:hidden}.event-content{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.event-icon-start{color:var(--bg-primary);z-index:2;background:#fff;border-radius:50%;justify-content:center;align-items:center;padding:2px;display:flex;position:absolute;left:4px;box-shadow:0 2px 5px #00000080}.event-icon-end{color:var(--bg-primary);z-index:2;background:#fff;border-radius:50%;justify-content:center;align-items:center;padding:2px;display:flex;position:absolute;right:4px;box-shadow:0 2px 5px #00000080}.gap-block{background:var(--gap-bg);border:1px dashed var(--gap-border);cursor:default;z-index:1;background-image:repeating-linear-gradient(-45deg,#0000,#0000 4px,#facc150a 4px 8px);border-radius:2px;justify-content:center;align-items:center;display:flex;position:absolute;top:1px;bottom:1px}.gap-block-urgent{background:#ef444426 repeating-linear-gradient(-45deg,#0000,#0000 4px,#ef44441a 4px 8px);border-color:#ef444499}.gap-block-urgent .gap-text{color:#ef4444}.gap-block-urgent .gap-text-clean{color:#ef4444;text-shadow:0 1px 2px #00000080;font-weight:800}.gap-text-container{flex-direction:column;justify-content:center;align-items:center;padding:0 4px;display:flex;overflow:hidden}.gap-text{color:var(--gap-text);white-space:nowrap;letter-spacing:.3px;font-size:.62rem;font-weight:700}.gap-text-clean{color:#ef4444;text-transform:uppercase;white-space:nowrap;margin-top:1px;font-size:.58rem;font-weight:700;text-decoration:underline}.empty-cell-marker{width:100%;height:100%}.movements-container{background:var(--bg-secondary);border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:8px;padding:8px 20px;display:flex}.movements-row{align-items:center;gap:4px;display:flex}.movements-title-container{align-items:center;gap:4px;min-width:110px;display:flex}.movements-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-primary);font-size:.8rem;font-weight:700}.movements-icon{justify-content:center;align-items:center;display:flex}.text-accent-blue{color:var(--accent-blue)}.text-accent-amber{color:var(--accent-amber)}.movements-list{flex:1;gap:6px;padding-bottom:2px;display:flex;overflow-x:auto}.movement-card{border-radius:var(--radius-sm);color:#fff;flex-direction:column;min-width:105px;display:flex;overflow:hidden;box-shadow:0 2px 5px #0006}.movement-card-header{background:#0003;align-items:center;gap:6px;padding:3px 6px;display:flex}.movement-van-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.68rem;font-weight:700;overflow:hidden}.movement-card-body{flex-direction:column;gap:0;padding:4px 6px;display:flex}.movement-date{color:#ffffffe6;font-size:.68rem;font-weight:500}.movement-countdown{color:#fff;text-shadow:0 1px 2px #00000080;font-size:.75rem;font-weight:800}.movements-empty{color:var(--text-muted);align-items:center;height:100%;font-size:.85rem;font-style:italic;display:flex}.timeline-empty{grid-column:1/-1;justify-content:center;align-items:center;min-height:300px;display:flex}.timeline-empty-content{text-align:center;color:var(--text-muted)}.timeline-empty-content p{max-width:280px;margin-top:12px;font-size:.88rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@media (max-width:768px){.sidebar{width:240px;min-width:240px}.sidebar-collapsed{border:none;width:0;min-width:0;overflow:hidden}.clock-widget{display:none}.timeline-grid{grid-template-columns:100px repeat(7,1fr);min-width:500px}}
