@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-color:#0f172a;--bg-surface:#1e293b;--bg-surface-hover:#334155;--text-primary:#f8fafc;--text-secondary:#94a3b8;--accent-color:#3b82f6;--accent-hover:#60a5fa;--border-color:#334155;--danger-color:#ef4444;--success-color:#10b981;--warn-color:#f59e0b}body.light-theme{--bg-color:#f8fafc;--bg-surface:#fff;--bg-surface-hover:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--border-color:#cbd5e1;--accent-color:#2563eb;--accent-hover:#3b82f6}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;line-height:1.5;transition:background-color .3s,color .3s}#root{flex-direction:column;height:100vh;display:flex;overflow:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.glass-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1e293bb3;border:1px solid #ffffff1a;border-radius:12px;transition:background-color .3s,border-color .3s}body.light-theme .glass-panel{background:#fffc;border:1px solid #00000014;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008}body.light-theme .timeline-outer-container{border-color:var(--border-color);background:#fff9}body.light-theme .wagon-compact-box{background:#f1f5f9}body.light-theme .wagon-compact-select{color:var(--text-primary)}body.light-theme .wagon-tooltip{color:#0f172a;background:#fff;border-color:#cbd5e1;box-shadow:0 4px 12px #00000026}body.light-theme .grid-line{border-right:1px dashed #0000000a}body.light-theme .trip-block-absolute{background:#fffffff2;box-shadow:0 4px 12px #00000014}.btn{background-color:var(--accent-color);color:#fff;cursor:pointer;border:none;border-radius:6px;align-items:center;gap:8px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.btn:hover{background-color:var(--accent-hover);transform:translateY(-1px)}.select-input{background-color:var(--bg-color);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;outline:none;width:100%;padding:6px 8px;font-size:.875rem;transition:border-color .2s}.select-input:focus{border-color:var(--accent-color)}.badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;align-items:center;padding:2px 6px;font-size:.7rem;font-weight:600;display:inline-flex}.badge.blue{color:#60a5fa;background-color:#3b82f633}.badge.orange{color:#fbbf24;background-color:#f59e0b33}.badge.green{color:#34d399;background-color:#10b98133}.app-container{background-color:var(--bg-color);flex-direction:column;height:100vh;display:flex;overflow:hidden}.header{background:var(--bg-surface);border-bottom:1px solid var(--border-color);z-index:20;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.header h1{align-items:center;gap:10px;font-size:1.3rem;font-weight:700;display:flex}.header-controls{align-items:center;gap:20px;display:flex}.zoom-control{color:var(--text-secondary);align-items:center;gap:10px;font-size:.8rem;display:flex}.zoom-slider{width:120px;accent-color:var(--accent-color);cursor:pointer}.action-buttons{gap:8px;display:flex}.btn-secondary{color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;background-color:#0000;border-radius:6px;padding:6px 12px;font-size:.8rem;font-weight:500;transition:all .2s}.btn-secondary:hover{border-color:var(--text-secondary);color:var(--text-primary)}.main-content{flex-direction:column;flex:1;padding:16px;display:flex;overflow:auto}.timeline-outer-container{border:1px solid var(--border-color);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1e293b66;border-radius:12px;flex-direction:column;flex:1;display:flex;overflow:auto}.timeline-wrapper{flex-direction:column;display:flex;position:relative}.timeline-axis{border-bottom:1px solid var(--border-color);background:var(--bg-surface);z-index:15;height:40px;display:flex;position:sticky;top:0}.axis-label-col{border-right:1px solid var(--border-color);background:var(--bg-surface);z-index:18;width:140px;color:var(--text-secondary);flex-shrink:0;align-items:center;padding-left:16px;font-size:.75rem;font-weight:600;display:flex;position:sticky;left:0}.axis-time-cols{flex:1;display:flex;position:relative}.time-marker{color:var(--text-secondary);border-right:1px dashed #ffffff0d;flex:1;justify-content:flex-start;align-items:center;padding-left:6px;font-family:monospace;font-size:.7rem;display:flex}.timeline-row{border-bottom:1px solid var(--border-color);min-height:140px;display:flex;position:relative}.row-label-col{border-right:1px solid var(--border-color);background:var(--bg-surface);z-index:10;flex-direction:column;flex-shrink:0;justify-content:center;width:140px;padding:16px;display:flex;position:sticky;left:0;box-shadow:4px 0 8px #00000026}.row-label-col h3{color:var(--text-primary);font-size:.85rem;font-weight:700}.row-label-col span{color:var(--text-secondary);margin-top:2px;font-size:.7rem}.row-content-col{background-image:linear-gradient(90deg,#ffffff05 1px,#0000 1px);flex:1;position:relative}.grid-lines{pointer-events:none;display:flex;position:absolute;inset:0}.grid-line{border-right:1px dashed #ffffff08;flex:1}.trip-block-absolute{border:1px solid var(--border-color);z-index:5;background:#1e293be6;border-radius:8px;flex-direction:column;transition:border-color .2s,box-shadow .2s;display:flex;position:absolute;top:10px;bottom:10px;overflow:hidden;box-shadow:0 4px 12px #0000004d}.trip-block-absolute:hover{z-index:8;border-color:#ffffff40;box-shadow:0 8px 16px #0006}.trip-block-absolute.selected{border-color:var(--accent-color);box-shadow:0 0 0 2px #3b82f666}.trip-mini-header{background:#0003;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:4px 8px;display:flex}.trip-mini-title{color:var(--text-primary);font-size:.75rem;font-weight:700}.trip-mini-route{color:var(--text-secondary);font-size:.65rem}.trip-mini-time{color:var(--text-secondary);font-family:monospace;font-size:.65rem}.trip-wagons-compact{flex:1;align-items:center;gap:3px;padding:4px;display:flex;overflow-x:auto}.wagon-rules-icons{justify-content:center;align-items:center;gap:3px;height:12px;margin:1px 0;display:flex}.rule-icon{justify-content:center;align-items:center;display:inline-flex}.rule-icon.family{color:var(--success-color)}.rule-icon.animal{color:var(--warn-color)}.wagon-compact-box{border:1px solid var(--border-color);background:#0f172a99;border-radius:6px;flex-direction:column;flex-shrink:0;justify-content:space-between;width:40px;height:56px;padding:3px;transition:border-color .15s;display:flex;position:relative}.wagon-compact-box:hover{border-color:#ffffff4d}.wagon-compact-box.has-rule{border-bottom-width:2px}.wagon-compact-box.rule-djur{border-bottom-color:var(--warn-color)}.wagon-compact-box.rule-familj{border-bottom-color:var(--success-color)}.wagon-num-line{color:var(--text-primary);text-align:center;font-size:.8rem;font-weight:800;line-height:1}.wagon-type-line{color:var(--text-secondary);text-align:center;margin-top:1px;font-size:.55rem;font-weight:500;line-height:1}.rule-micro-badge{text-align:center;text-transform:uppercase;text-overflow:ellipsis;white-space:nowrap;border-radius:2px;max-width:100%;margin:1px auto;padding:1px 2px;font-size:6px;font-weight:800;line-height:1.1;overflow:hidden}.rule-micro-badge.djur{background-color:var(--warn-color);color:#000}.rule-micro-badge.familj{background-color:var(--success-color);color:#fff}.wagon-select-wrapper{margin-top:auto}.wagon-compact-select{width:100%;color:var(--text-primary);cursor:pointer;text-align:center;appearance:none;background:0 0;border:none;outline:none;padding:0;font-size:.65rem;font-weight:700}.global-wagon-tooltip{color:#fff;white-space:nowrap;border:1px solid var(--border-color);pointer-events:none;background:#1e293b;border-radius:6px;padding:6px 10px;font-size:.7rem;transition:opacity .15s;box-shadow:0 10px 15px -3px #0000004d,0 4px 6px -2px #0000000d}body.light-theme .global-wagon-tooltip{color:#0f172a;background:#fff;border-color:#cbd5e1;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.toast{background:var(--success-color);color:#fff;z-index:100;border-radius:8px;padding:12px 20px;font-size:.85rem;font-weight:600;animation:.3s ease-out slideIn;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 12px #0000004d}@keyframes slideIn{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.search-container{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;align-items:center;gap:6px;padding:6px 12px;transition:all .2s;display:flex}body.light-theme .search-container{background-color:#f1f5f9}.search-container:focus-within{border-color:var(--accent-color);box-shadow:0 0 0 2px #3b82f633}body.light-theme .search-container:focus-within{box-shadow:0 0 0 2px #2563eb33}.search-input{color:var(--text-primary);background:0 0;border:none;outline:none;width:140px;font-size:.8rem;font-weight:500;transition:width .2s}.search-input:focus{width:200px}.search-input::placeholder{color:var(--text-secondary)}.search-clear-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.search-clear-btn:hover{color:var(--text-primary)}.timeline-outer-container.has-search .trip-block-absolute:not(.trip-matched){opacity:.25;filter:saturate(.3)blur(.5px);transition:all .25s}.timeline-outer-container.has-search .trip-block-absolute:not(.trip-matched):hover{opacity:.5;filter:none}.trip-block-absolute.trip-matched{z-index:10;transition:all .25s;transform:translateY(-2px);box-shadow:0 0 16px #3b82f666;border:2px solid var(--accent-color)!important}body.light-theme .trip-block-absolute.trip-matched{box-shadow:0 0 16px #2563eb33}.wagon-compact-box.wagon-matched{box-shadow:0 0 12px var(--accent-color);z-index:15;animation:2s ease-in-out infinite pulse-glow-wagon;transform:scale(1.08);border-color:var(--accent-color)!important;background-color:#3b82f633!important}body.light-theme .wagon-compact-box.wagon-matched{background-color:#2563eb26!important}@keyframes pulse-glow-wagon{0%,to{box-shadow:0 0 8px var(--accent-color)}50%{box-shadow:0 0 18px var(--accent-color)}}
