@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #080d18;--bg2: #1e293b;--bg3: #080d18;--border: #1e293b;--border2: #334155;--text: #e2e8f0;--text2: #94a3b8;--text3: #64748b;--accent: #3b82f6;--accent2: #2563eb;--green: #22c55e;--yellow: #eab308;--red: #ef4444;--purple: #8b5cf6;--cyan: #06b6d4;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--mono: "SF Mono", "Fira Code", monospace;--radius: 8px;--radius-lg: 10px}html,body,#root{height:100%;background:#080d18;color:var(--text);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:8px}::-webkit-scrollbar-track{background:#1e293b;border-radius:4px}::-webkit-scrollbar-thumb{background:#475569;border-radius:4px}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}.content-area{flex:1;overflow-y:auto;padding:20px 24px}.topbar{background:#080d18;border-bottom:1px solid #1e293b;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;z-index:30}.topbar-left{display:flex;align-items:flex-end;gap:16px}.topbar-logo{height:64px;width:auto;object-fit:contain}.topbar-sov{font-size:32px;color:#475569;font-weight:800;text-transform:uppercase;letter-spacing:-.02em;line-height:.9;padding-bottom:2px}.topbar-flow{display:flex;align-items:flex-end;gap:6px;margin-left:220px;padding-bottom:2px}.topbar-flow-step{display:flex;flex-direction:column;align-items:center;gap:4px;padding:0 8px}.topbar-flow-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center}.topbar-flow-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.topbar-flow-step.reserved .topbar-flow-icon{background:#eab3081a;color:#eab308}.topbar-flow-step.reserved .topbar-flow-label{color:#eab308}.topbar-flow-step.confirmed .topbar-flow-icon{background:#22c55e1a;color:#22c55e}.topbar-flow-step.confirmed .topbar-flow-label{color:#22c55e}.topbar-flow-step.contracted .topbar-flow-icon{background:#3b82f61a;color:#3b82f6}.topbar-flow-step.contracted .topbar-flow-label{color:#3b82f6}.topbar-flow-step.success .topbar-flow-icon{background:#8b5cf61a;color:#8b5cf6}.topbar-flow-step.success .topbar-flow-label{color:#8b5cf6}.topbar-flow-step.delivery .topbar-flow-icon{background:#06b6d41a;color:#06b6d4}.topbar-flow-step.delivery .topbar-flow-label{color:#06b6d4}.topbar-flow-arrow{color:#64748b;display:flex;align-items:center;padding-bottom:14px}.topbar-right{display:flex;align-items:center;gap:4px;font-size:12px;color:#64748b}.dot-live{width:7px;height:7px;border-radius:50%;background:#22c55e;display:inline-block;margin-right:4px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.topbar-user{margin-left:12px;font-weight:500;color:#e2e8f0}.tabs{background:#080d18;border-bottom:1px solid #1e293b;padding:0 24px;display:flex;gap:0;flex-shrink:0}.tab-btn{padding:12px 16px;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;transition:all .15s;font-family:inherit;white-space:nowrap}.tab-btn:hover{color:#94a3b8}.tab-btn.active{color:#3b82f6;border-bottom-color:#3b82f6}.month-bar{background:#080d18;border-bottom:1px solid #1e293b;padding:8px 24px;display:flex;gap:4px;flex-shrink:0;flex-wrap:wrap}.month-pill{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;color:#64748b;background:none;border:none;cursor:pointer;transition:all .15s;font-family:inherit}.month-pill:hover{color:#94a3b8}.month-pill.active{background:#3b82f6;color:#fff}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.stat-card{background:#1e293b;border:1px solid #334155;border-radius:var(--radius-lg);padding:16px 18px}.stat-label{font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.stat-value{font-size:28px;font-weight:700;color:#e2e8f0;margin-top:4px}.stat-value.green{color:#22c55e}.stat-value.yellow{color:#eab308}.stat-value.blue{color:#60a5fa}.dash-grid{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}.dash-card{background:#1e293b;border:1px solid #334155;border-radius:var(--radius-lg);padding:18px 20px}.dash-card-title{font-size:14px;font-weight:600;color:#e2e8f0;margin-bottom:16px}.progress-card{background:#1e293b;border:1px solid #334155;border-radius:var(--radius-lg);padding:18px 20px;margin-bottom:16px}.progress-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}.progress-title{font-size:14px;font-weight:600;color:#e2e8f0}.progress-pct{font-size:24px;font-weight:700;color:#22c55e}.progress-track{display:flex;height:18px;border-radius:9px;background:#334155;overflow:hidden}.progress-fill{height:100%;transition:width .6s ease}.progress-fill.confirmed{background:#22c55e}.progress-fill.reserved{background:#eab308}.progress-legend{display:flex;gap:18px;margin-top:10px;font-size:12px;color:#94a3b8}.legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px;vertical-align:middle}.legend-item{display:flex;align-items:center}.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.filter-label{font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.filter-btn{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;color:#64748b;background:#1e293b;border:none;cursor:pointer;transition:all .15s;font-family:inherit}.filter-btn:hover{color:#cbd5e1}.filter-btn.active{background:#3b82f6;color:#fff}.grid-wrap{overflow-x:auto;border:1px solid #1e293b;border-radius:var(--radius-lg)}.grid-table{width:100%;border-collapse:collapse;font-size:13px;min-width:900px}.grid-table th{text-align:left;padding:8px 12px;font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-weight:500;white-space:nowrap;background:#080d18;border-bottom:1px solid #1e293b}.grid-table th.sticky{position:sticky;left:0;background:#080d18;z-index:5;min-width:200px}.grid-table th.month-col{min-width:88px;cursor:pointer;transition:all .15s;text-align:center;font-size:10px}.grid-table th.month-col:hover{color:#94a3b8}.grid-table th.month-col.selected{color:#60a5fa;background:#3b82f60f}.grid-table td{padding:8px 12px;border-top:1px solid #1e293b}.grid-table td.sticky{position:sticky;left:0;background:#080d18;z-index:5}.grid-table td.month-cell{text-align:center}.grid-table td.month-cell.selected{background:#3b82f60a}.grid-table tr:hover td{background:#ffffff05}.grid-table tr:hover td.sticky{background:#080d18}.sold-loz{display:inline-block;margin-top:4px;padding:1px 7px;border-radius:10px;font-size:9px;font-weight:600;letter-spacing:.03em;white-space:nowrap}.sold-loz-high{background:#22c55e26;color:#22c55e}.sold-loz-mid{background:#f59e0b26;color:#f59e0b}.sold-loz-low{background:#ef444426;color:#ef4444}.cat-name{font-weight:500;color:#e2e8f0}.cat-meta{font-size:11px;color:#475569}.slot-stack{display:flex;flex-direction:column;gap:2px}.slot-bar{width:100%;height:22px;border-radius:3px;display:flex;align-items:center;padding:0 6px;font-size:10px;font-weight:600;color:#cbd5e1;cursor:pointer;transition:all .15s;border:none;border-left:3px solid transparent;text-align:left;font-family:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slot-bar:hover{filter:brightness(1.3);transform:translate(1px)}.slot-bar.available{background:#1e293b;border-left:3px solid #334155;color:#334155}.slot-bar.available:hover{border-left-color:#475569;color:#475569}.slot-open-label{font-size:11px;color:#475569;margin-top:4px;text-align:center}.slot-sold-label{font-size:10px;color:#22c55e;margin-top:4px;text-align:center;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.cat-card{background:#1e293b;border-radius:var(--radius-lg);border:1px solid #334155;padding:16px;margin-bottom:12px}.cat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cat-card-slots{display:grid;gap:8px}.slot-card{border-radius:var(--radius);padding:12px;text-align:left;cursor:pointer;transition:all .15s;border:1px solid transparent;font-family:inherit;background:none;color:inherit;width:100%}.slot-card:hover{transform:translateY(-1px);box-shadow:0 3px 10px #00000040}.slot-card.available{background:#080d18;border:2px dashed #334155}.slot-card.reserved{border-style:dashed}.slot-num{font-size:11px;color:#64748b;margin-bottom:4px}.slot-client{font-weight:500;font-size:13px;display:flex;align-items:center;gap:6px}.slot-client-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.slot-adset{font-size:11px;color:#64748b;margin-top:2px}.slot-person{font-size:10px;color:#64748b;margin-top:3px;font-style:italic}.slot-avail{font-size:12px;color:#475569}.status-badge{display:inline-block;font-size:10px;padding:2px 7px;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-top:4px}.role-badge{display:inline-block;font-size:9px;padding:1px 6px;border-radius:4px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;vertical-align:middle}.role-badge.admin{background:#3b82f626;color:#60a5fa}.role-badge.sales{background:#22c55e26;color:#22c55e}.role-badge.sales-manager{background:#8b5cf626;color:#a78bfa}.role-badge.client-success{background:#f59e0b26;color:#fbbf24}.role-badge.contracting{background:#06b6d426;color:#22d3ee}.role-badge.adops{background:#ec489926;color:#f472b6}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.page-count{font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.item-card{background:#1e293b;border:1px solid #334155;border-radius:var(--radius-lg);padding:16px;transition:border-color .15s}.item-card:hover{border-color:#475569}.item-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.client-swatch{width:12px;height:12px;border-radius:50%;flex-shrink:0}.item-name{font-weight:600;font-size:14px;color:#e2e8f0}.item-meta{font-size:11px;color:#64748b}.btn{padding:8px 16px;border-radius:var(--radius);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s}.btn-blue{background:#3b82f6;color:#fff}.btn-blue:hover{background:#2563eb}.btn-ghost{background:#334155;color:#cbd5e1;border:none}.btn-ghost:hover{background:#475569;color:#e2e8f0}.btn-danger{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.25)}.btn-danger:hover{background:#ef444433}.btn-sm{padding:5px 12px;font-size:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#1e293b;border-radius:12px;box-shadow:0 20px 60px #00000080;width:100%;max-width:480px;margin:16px;border:1px solid #334155;padding:20px}.modal-title{font-size:16px;font-weight:600;color:#e2e8f0;margin-bottom:20px}.form-field{margin-bottom:14px}.form-label{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:4px}.form-input,.form-select{width:100%;padding:8px 12px;background:#080d18;border:1px solid #334155;border-radius:var(--radius);font-family:var(--font);font-size:13px;color:#e2e8f0;outline:none;transition:border-color .15s}.form-input:focus,.form-select:focus{border-color:#3b82f6}.form-select option{background:#1e293b}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.error-msg{background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius);padding:8px 12px;font-size:12px;color:#f87171;margin-bottom:12px}.users-table{width:100%;border-collapse:collapse}.users-table th{padding:10px 12px;font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid #334155;text-align:left}.users-table td{padding:10px 12px;border-bottom:1px solid #1e293b;font-size:13px;color:#94a3b8}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover td{background:#ffffff05}.login-split{display:flex;min-height:100vh;background:#0a0f1a}.login-hero{flex:1.15;position:relative;overflow:hidden;display:flex;align-items:flex-end}.login-hero-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center}.login-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000d9,#0003 40%,#0000000d)}.login-hero-content{position:absolute;bottom:0;left:0;z-index:2;padding:40px 44px}.login-hero-sov{font-size:52px;font-weight:800;color:#fff;line-height:1;letter-spacing:-.02em;text-transform:uppercase;text-shadow:0 2px 24px rgba(0,0,0,.5)}.login-panel{flex:0 0 480px;display:flex;flex-direction:column;justify-content:center;padding:48px 56px;background:#000;border-left:1px solid #1a1a1a;position:relative}.login-inner{max-width:360px;width:100%;margin:0 auto}.login-logo{width:100%;max-width:360px;height:auto;display:block;margin-bottom:36px;cursor:pointer}.login-input-wrap{position:relative;display:flex;align-items:center;margin-bottom:20px}.login-icon{position:absolute;left:14px;color:#475569;pointer-events:none;transition:color .2s}.login-input{width:100%;background:#111;border:1px solid #2a2a2a;color:#f1f5f9;border-radius:10px;padding:13px 14px 13px 44px;font-size:14px;font-family:inherit;transition:all .2s;outline:none}.login-input::placeholder{color:#555}.login-input:focus{border-color:#e52020;background:#0a0a0a;box-shadow:0 0 0 3px #e520201a}.login-submit{width:100%;padding:13px;border-radius:10px;font-size:15px;font-weight:600;border:none;cursor:pointer;font-family:inherit;color:#fff;background:#e52020;box-shadow:0 4px 14px #e5202040;transition:all .2s;text-transform:uppercase;letter-spacing:.05em}.login-submit:hover{background:#f33;box-shadow:0 6px 20px #e5202059;transform:translateY(-1px)}.login-footer{position:absolute;bottom:24px;left:0;right:0;text-align:center;font-size:11px;color:#333}.login-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:10px;color:#f87171;font-size:13px;font-weight:500;margin-bottom:20px}.quick-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200}.quick-modal{background:#111;border:1px solid #2a2a2a;border-radius:12px;width:320px;max-height:80vh;overflow:hidden;box-shadow:0 20px 60px #0009}.quick-title{font-size:13px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.05em;padding:14px 18px;border-bottom:1px solid #2a2a2a;display:flex;justify-content:space-between;align-items:center}.quick-close{background:none;border:none;color:#666;font-size:20px;cursor:pointer;padding:0 4px;line-height:1}.quick-close:hover{color:#fff}.quick-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:11px 18px;background:none;border:none;border-bottom:1px solid #1a1a1a;color:#e2e8f0;font-size:14px;font-family:inherit;cursor:pointer;transition:background .1s;text-align:left}.quick-item:last-child{border-bottom:none}.quick-item:hover{background:#1a1a1a}.quick-name{font-weight:500}.spinner{width:32px;height:32px;border:3px solid #1e293b;border-top-color:#3b82f6;border-radius:50%;animation:spin .7s linear infinite;margin:40px auto;display:block}@keyframes spin{to{transform:rotate(360deg)}}.recharts-default-tooltip{background:#1e293b!important;border:1px solid #334155!important;border-radius:8px!important;font-size:12px!important}
