:root{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:#e2e8f0;background-color:#020617}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top,#0f172a,#020617 55%);min-height:100vh}#root{min-height:100vh}.app-shell{display:grid;grid-template-columns:300px 1fr;min-height:100vh}.sidebar{border-right:1px solid #1e293b;padding:2rem 1.25rem;background:#0f172acc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.sidebar h1{margin-top:0;margin-bottom:.5rem}.sidebar-subtitle{color:#94a3b8;margin-bottom:1rem}.sidebar-meta{margin:.25rem 0;color:#cbd5e1;font-size:.85rem}nav{display:flex;flex-direction:column;gap:.75rem}.nav-item{text-decoration:none;color:#cbd5e1;border:1px solid #1e293b;border-radius:.9rem;padding:.85rem .95rem;display:flex;flex-direction:column;gap:.2rem;transition:all .2s ease}.nav-item span{color:#94a3b8;font-size:.85rem}.nav-item:hover,.nav-item.active{border-color:#38bdf8;background:#38bdf81f;color:#f8fafc}.content{padding:2rem}.page-header h2{margin:0}.page-header p{color:#94a3b8}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.data-card,.panel{border:1px solid #1e293b;border-radius:1rem;padding:1rem;background:#0f172ab3}.two-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}ul{margin:0;padding-left:1.25rem}li{margin-bottom:.65rem}small,.info-message{color:#94a3b8}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid #1e293b}}button{border:1px solid #38bdf8;border-radius:.7rem;background:#38bdf82e;color:#e2e8f0;padding:.5rem .8rem;cursor:pointer}button:disabled{opacity:.5;cursor:wait}.icon-button,.icon-link-button{width:2.35rem;height:2.35rem;min-width:2.35rem;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;font-size:1rem}.connection-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.connection-form input{width:100%;border:1px solid #334155;border-radius:.7rem;padding:.55rem .7rem;background:#0f172a;color:#e2e8f0}.connection-form button{justify-self:start}.form-panel{margin-bottom:1rem}.checkbox-row{display:flex;gap:.5rem;align-items:center}.meta-line{color:#94a3b8;margin:.25rem 0}.with-actions{display:flex;justify-content:space-between;align-items:end;gap:1rem}.status-ok{color:#34d399}.status-ko{color:#f87171}.project-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.project-row button{flex-shrink:0}.icon-link-button{color:#38bdf8;text-decoration:none;border:1px solid #38bdf8;border-radius:.5rem;background:#38bdf81a}.icon-link-button:hover{filter:brightness(1.2)}.connection-form select{width:100%;border:1px solid #334155;border-radius:.7rem;padding:.55rem .7rem;background:#0f172a;color:#e2e8f0}.dss-instance-display{border:1px solid #334155;border-radius:.7rem;padding:.5rem .7rem;background:#0f172a;color:#e2e8f0;min-height:42px}.dss-instance-display small{display:block;line-height:1.1}.dss-instance-display strong{display:block;margin-top:.15rem;font-size:.95rem}.metrics-grid{margin:1rem 0}.metric-card{min-height:110px}.metric-label{margin:0;color:#94a3b8}.metric-value{display:block;margin-top:.45rem;font-size:1.4rem}.panel-title-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.link-button{border:none;background:transparent;color:#38bdf8;padding:0}.link-button:disabled{color:#64748b;cursor:not-allowed}.project-filter-button{flex:1;text-align:left;border:none;background:transparent;color:inherit;padding:0}.project-row-selected{border:1px solid #38bdf8;border-radius:.5rem;padding:.45rem .6rem;background:#38bdf814}.panel li{display:flex;align-items:center;gap:.45rem}.schedule-table{width:100%;border-collapse:collapse}.schedule-table th,.schedule-table td{border-bottom:1px solid #1e293b;text-align:left;padding:.6rem;vertical-align:middle}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617cc;display:flex;align-items:center;justify-content:center;z-index:100}.modal-content{width:min(560px,92vw);border:1px solid #334155;border-radius:1rem;background:#0f172a;padding:1rem}.modal-content form{display:grid;gap:.75rem}.modal-content label{display:grid;gap:.35rem}.modal-content input,.modal-content select{width:100%;border:1px solid #334155;border-radius:.7rem;padding:.55rem .7rem;background:#020617;color:#e2e8f0}.modal-content select[multiple]{min-height:120px}.modal-actions{display:flex;justify-content:flex-end;gap:.6rem}.settings-gear{position:fixed;top:1rem;right:1rem;border-radius:999px;width:2.5rem;height:2.5rem;padding:0}.timezone-hint{margin:.25rem 0 .75rem;color:#94a3b8;font-size:.85rem}.toast-stack{position:fixed;top:1rem;right:1rem;z-index:80;width:min(360px,calc(100vw - 2rem));display:flex;flex-direction:column;gap:.85rem;pointer-events:none}.toast{position:relative;display:grid;grid-template-columns:8px 2.2rem 1fr auto;align-items:start;column-gap:.8rem;min-height:84px;border-radius:.8rem;background:#f8fafc;color:#111827;box-shadow:0 12px 30px #0f172a59;overflow:hidden;pointer-events:auto}.toast-accent{width:8px;height:100%;grid-column:1;grid-row:1 / -1}.toast-icon{width:2rem;height:2rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;margin-top:1rem;font-size:1.1rem;font-weight:700}.toast-content{padding:.85rem 0 .8rem}.toast-title{margin:0;font-size:1.1rem;font-weight:700;color:#111827}.toast-message{margin:.2rem 0 0;color:#4b5563;line-height:1.35}.toast-action-button{margin-top:.5rem;border:none;background:transparent;color:#0f172a;text-decoration:underline;padding:0}.toast-close-button{border:none;background:transparent;color:#6b7280;font-size:1.3rem;line-height:1;padding:.5rem .8rem 0 0}.toast-success .toast-accent{background:#4ade80}.toast-success .toast-icon{background:#4ade80;color:#fff}.toast-error .toast-accent{background:#f43f5e}.toast-error .toast-icon{background:#f43f5e;color:#fff}.toast-info .toast-accent{background:#3b82f6}.toast-info .toast-icon{background:#3b82f6;color:#fff}.toast-warning .toast-accent{background:#f59e0b}.toast-warning .toast-icon{background:#f59e0b;color:#fff}.top-header{display:flex;justify-content:flex-end;margin-bottom:1rem}.jobs-badge{display:flex;align-items:center;gap:.5rem}.jobs-badge-normal{border-color:#34d399;background:#34d3992e}.jobs-badge-alert{border-color:#f59e0b;background:#f59e0b33}.jobs-badge-blocked{border-color:#f87171;background:#f8717133}.jobs-panel ul{list-style:none;padding-left:0}.job-row{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #1e293b;padding:.4rem 0}.job-actions{display:flex;align-items:center;gap:.6rem}.header-actions{display:flex;gap:.6rem}.offcanvas-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#02061773;border:none;z-index:45}.jobs-offcanvas{position:fixed;top:0;right:0;height:100vh;width:min(460px,92vw);background:#0b1329;border-left:1px solid #1e293b;padding:1rem;overflow-y:auto;z-index:50;box-shadow:-10px 0 30px #00000059}.jobs-offcanvas-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.job-item-card{list-style:none;border:1px solid #1e293b;border-radius:.75rem;padding:.75rem;margin-bottom:.75rem;background:#0f172ab3}.job-item-card p{margin:.25rem 0}.jobs-fab{position:fixed;right:1rem;bottom:1rem;z-index:55;border-radius:999px;padding:.55rem .8rem;box-shadow:0 10px 25px #00000059}.jobs-fab span:last-child{font-size:.85rem;font-weight:700}.job-diagnostics{margin-top:.6rem;background:#020617;border:1px solid #334155;border-radius:.6rem;padding:.55rem;font-size:.78rem;color:#cbd5e1;max-height:180px;overflow:auto}.form-helper{margin-top:-.25rem;color:#94a3b8;font-size:.9rem}.title-icon{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;margin-right:.6rem;border:1px solid #38bdf8;border-radius:.7rem;background:#38bdf81f;font-size:1rem;vertical-align:middle}.sidebar{display:flex;flex-direction:column}.sidebar-logo{margin-top:auto;padding-top:2rem}.sidebar-logo img{display:block;width:4rem;height:auto}.sortable-table th button{width:100%;border:none;background:transparent;color:inherit;padding:0;text-align:left;font:inherit}.sortable-table th button:hover{color:#38bdf8}.row-main{min-width:0;flex:1}.row-actions{margin-left:auto;display:inline-flex;align-items:center;justify-content:flex-end;gap:.45rem;flex-shrink:0}.project-row .project-filter-button{min-width:0;flex:1 1 auto}.scenario-row{justify-content:space-between}.danger-button{border-color:#f87171;background:#f8717124}.danger-button:hover{background:#f871713d}
