@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#e2e8f0;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#060d1a;font-family:Inter,system-ui,sans-serif}body{min-height:100vh}#root{flex-direction:column;min-height:100vh;display:flex}a{color:inherit;text-decoration:none}button,input{font-family:inherit}@keyframes drift{0%,to{transform:translate(0)scale(1)}33%{transform:translate(30px,-30px)scale(1.05)}66%{transform:translate(-20px,20px)scale(.95)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.animate-spin{animation:1s linear infinite spin}.app-shell{background:#060d1a;min-height:100vh;display:flex}.sidebar{z-index:40;background:#0b1221;border-right:1px solid #ffffff0f;flex-direction:column;width:240px;min-height:100vh;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid #ffffff0f;flex-shrink:0;align-items:center;gap:.75rem;height:64px;padding:0 1.25rem;display:flex}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:1rem .75rem;display:flex}.nav-item{color:#64748b;border-radius:10px;align-items:center;gap:.75rem;padding:.7rem 1rem;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{color:#e2e8f0;background:#ffffff0a}.nav-item--active{color:#60a5fa;background:#3b82f61f}.nav-item--active:hover{background:#3b82f629}.sidebar-footer{border-top:1px solid #ffffff0f;padding:.75rem}.user-card{background:#ffffff08;border:1px solid #ffffff0f;border-radius:10px;align-items:center;gap:.625rem;margin-bottom:.5rem;padding:.75rem;display:flex}.user-avatar{color:#60a5fa;background:#3b82f626;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.user-info{overflow:hidden}.user-email{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;font-weight:500;display:block;overflow:hidden}.user-role{color:#475569;text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:.25rem;margin-top:1px;font-size:.65rem;display:flex}.signout-btn{color:#475569;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.6rem;font-size:.8rem;transition:all .15s;display:flex}.signout-btn:hover{color:#f87171;background:#ef444414}.main-content{background:#060d1a;flex:1;min-height:100vh;margin-left:240px}.page-container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.auth-page-wrapper{background:#060d1a;min-height:100vh}.public-nav{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#060d1acc;border-bottom:1px solid #ffffff0f;height:60px}.public-nav-inner{align-items:center;max-width:1200px;height:100%;margin:0 auto;padding:0 1.5rem;display:flex}.brand{align-items:center;gap:.625rem;display:flex}.brand-logo{color:#fff;background:linear-gradient(135deg,#3b82f6,#6366f1);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex;box-shadow:0 2px 10px #3b82f64d}.brand-name{color:#fff;letter-spacing:-.02em;font-size:1rem;font-weight:700}.card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0b1221cc;border:1px solid #ffffff12;border-radius:16px;padding:1.5rem}.card-header{color:#fff;align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:.9375rem;font-weight:600;display:flex}.card-header svg{color:#3b82f6}.dashboard-grid{grid-template-columns:340px 1fr;align-items:start;gap:1.5rem;display:grid}@media (width<=900px){.dashboard-grid{grid-template-columns:1fr}}.card-warning{background:#fb923c0a;border-color:#fb923c33}.form-group{margin-bottom:1.125rem}.form-label{color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.45rem;font-size:.775rem;font-weight:600;display:block}.form-input{color:#fff;background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;outline:none;width:100%;padding:.75rem 1rem;font-size:.9rem;transition:border-color .2s,background .2s,box-shadow .2s}.form-input::placeholder{color:#2d3f55}.form-input:focus{background:#3b82f60a;border-color:#3b82f680;box-shadow:0 0 0 3px #3b82f614}.btn-row{gap:.75rem;margin-top:.5rem;display:flex}.btn-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.8rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 4px 12px #3b82f640}.btn-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #3b82f659}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:#94a3b8;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.8rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.btn-secondary:hover:not(:disabled){color:#fff;background:#ffffff12}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{color:#f87171;cursor:pointer;background:#ef444414;border:1px solid #ef444433;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:.75rem;padding:.8rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.btn-danger:hover:not(:disabled){background:#ef444424;border-color:#ef444459}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-ms365{color:#fff;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.75rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.btn-ms365:hover{background:#ffffff14}.progress-wrap{background:#ffffff0d;border-radius:9999px;height:6px;margin-bottom:.625rem;overflow:hidden}.progress-bar{background:linear-gradient(90deg,#3b82f6,#6366f1);border-radius:9999px;height:100%;transition:width .3s}.progress-meta{color:#475569;justify-content:space-between;margin-bottom:1.25rem;font-size:.78rem;display:flex}.status-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:9999px;padding:.25rem .75rem;font-size:.7rem;font-weight:700}.status-idle{color:#64748b;background:#64748b26}.status-running{color:#60a5fa;background:#3b82f626}.status-previewed{color:#818cf8;background:#6366f126}.status-completed{color:#4ade80;background:#22c55e26}.status-error{color:#f87171;background:#ef444426}.status-rolling_back{color:#fb923c;background:#fb923c26}.log-viewer{background:#060d1a;border:1px solid #ffffff0f;border-radius:12px;overflow:hidden}.log-header{color:#475569;background:#ffffff08;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:.625rem 1rem;font-size:.75rem;font-weight:600;display:flex}.log-counts{gap:1rem;display:flex}.log-count-success{color:#4ade80}.log-count-error{color:#f87171}.log-body{flex-direction:column;gap:.3rem;height:350px;padding:.75rem 1rem;font-family:ui-monospace,Cascadia Code,Fira Code,monospace;font-size:.75rem;display:flex;overflow-y:auto}.log-body::-webkit-scrollbar{width:4px}.log-body::-webkit-scrollbar-track{background:0 0}.log-body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:9999px}.log-entry{color:#475569;align-items:flex-start;gap:.5rem;display:flex}.log-entry.success{color:#4ade80}.log-entry.error{color:#f87171}.log-time{color:#2d3f55;flex-shrink:0}.log-empty{text-align:center;color:#2d3f55;padding:4rem 1rem;font-size:.8rem}.preview-callout{color:#a5b4fc;background:#6366f112;border:1px solid #6366f133;border-radius:10px;margin-top:.875rem;padding:.875rem 1rem;font-size:.85rem}.preview-callout strong{color:#c7d2fe}.ms-banner{background:#fb923c0f;border:1px solid #fb923c2e;border-radius:12px;margin-bottom:1rem;padding:1rem 1.25rem}.ms-banner-title{color:#fed7aa;align-items:center;gap:.5rem;margin-bottom:.375rem;font-size:.875rem;font-weight:600;display:flex}.ms-banner-sub{color:#92400e;margin-bottom:.875rem;font-size:.8rem}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:5rem 2rem;display:flex}.empty-icon{color:#475569;background:#ffffff0a;border:1px solid #ffffff14;border-radius:18px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:1.5rem;display:flex}.empty-title{color:#fff;margin-bottom:.5rem;font-size:1.25rem;font-weight:700}.empty-sub{color:#475569;max-width:360px;margin-bottom:2rem;font-size:.875rem;line-height:1.6}.btn-primary-solo{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex;box-shadow:0 4px 12px #3b82f640}.btn-primary-solo:hover{transform:translateY(-1px);box-shadow:0 6px 18px #3b82f659}.settings-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0b1221cc;border:1px solid #ffffff12;border-radius:20px;max-width:620px;overflow:hidden}.settings-header{background:#ffffff05;border-bottom:1px solid #ffffff0f;align-items:center;gap:1rem;padding:1.5rem;display:flex}.settings-icon{color:#60a5fa;background:#3b82f61f;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.settings-title{color:#fff;font-size:1rem;font-weight:700}.settings-subtitle{color:#475569;margin-top:2px;font-size:.8rem}.settings-body{padding:1.5rem}.settings-fields{flex-direction:column;gap:1.25rem;display:flex}.settings-hint{color:#334155;margin-top:.3rem;font-size:.73rem}.settings-input-icon{color:#64748b;text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:.5rem;margin-bottom:.45rem;font-size:.775rem;font-weight:600;display:flex}.settings-footer{border-top:1px solid #ffffff0f;padding:1rem 1.5rem}.settings-save{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 4px 12px #3b82f640}.settings-save:hover{transform:translateY(-1px);box-shadow:0 6px 18px #3b82f659}.success-banner{color:#4ade80;background:#22c55e14;border:1px solid #22c55e33;border-radius:10px;align-items:center;gap:.625rem;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.85rem;display:flex}.login-page{background:#060d1a;justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex;position:relative;overflow:hidden}.login-bg-glow-1{pointer-events:none;background:radial-gradient(circle,#3b82f61f 0%,#0000 70%);width:600px;height:600px;animation:12s ease-in-out infinite drift;position:absolute;top:-20%;left:-10%}.login-bg-glow-2{pointer-events:none;background:radial-gradient(circle,#8b5cf61a 0%,#0000 70%);width:500px;height:500px;animation:15s ease-in-out infinite reverse drift;position:absolute;bottom:-20%;right:-10%}.login-card{z-index:10;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f172acc;border:1px solid #ffffff14;border-radius:24px;width:100%;max-width:420px;padding:2.5rem;position:relative;box-shadow:0 32px 64px #00000080,0 0 80px #3b82f60d}.login-brand{align-items:center;gap:.75rem;margin-bottom:2.5rem;display:flex}.login-brand-icon{color:#fff;background:linear-gradient(135deg,#3b82f6,#6366f1);border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;display:flex;box-shadow:0 4px 14px #3b82f659}.login-brand-name{color:#fff;letter-spacing:-.025em;font-size:1.125rem;font-weight:700}.login-header{margin-bottom:2rem}.login-title{color:#fff;letter-spacing:-.035em;font-size:1.75rem;font-weight:800;line-height:1.2}.login-subtitle{color:#64748b;margin-top:.375rem;font-size:.875rem}.login-error{color:#fca5a5;background:#ef444414;border:1px solid #ef444440;border-radius:12px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.85rem;font-weight:500;display:flex}.login-form{flex-direction:column;gap:1.25rem;display:flex}.login-field{flex-direction:column;gap:.45rem;display:flex}.login-label{color:#64748b;text-transform:uppercase;letter-spacing:.06em;font-size:.775rem;font-weight:600}.login-input-wrap{position:relative}.login-input-icon{color:#334155;pointer-events:none;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.login-input{color:#fff;background:#ffffff0a;border:1px solid #ffffff14;border-radius:12px;outline:none;width:100%;padding:.875rem 1rem .875rem 2.75rem;font-size:.925rem;transition:border-color .2s,background .2s,box-shadow .2s}.login-input::placeholder{color:#1e2d40}.login-input:focus{background:#3b82f60d;border-color:#3b82f680;box-shadow:0 0 0 3px #3b82f614}.login-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;border-radius:12px;justify-content:center;align-items:center;gap:.625rem;width:100%;margin-top:.5rem;padding:.9rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 4px 14px #3b82f64d}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #3b82f666}.login-submit:disabled{opacity:.7;cursor:not-allowed}.login-footer{color:#1e2d40;border-top:1px solid #ffffff0f;justify-content:center;align-items:center;gap:.5rem;margin-top:2rem;padding-top:1.5rem;font-size:.73rem;display:flex}.guide-content{color:#64748b;flex-direction:column;gap:.375rem;font-size:.82rem;line-height:1.7;display:flex}.guide-content p{margin:0}.guide-content ul{margin:.25rem 0 0;padding-left:1.25rem}.guide-content li{margin-bottom:.2rem}.guide-content strong{color:#94a3b8;font-weight:600}.guide-content code{color:#a5b4fc;background:#6366f11a;border:1px solid #6366f133;border-radius:5px;padding:.1rem .4rem;font-family:ui-monospace,Cascadia Code,monospace;font-size:.78rem}.guide-link{color:#60a5fa;align-items:center;gap:.25rem;text-decoration:none;display:inline-flex}.guide-link:hover{text-decoration:underline}.autocomplete-dropdown{z-index:50;background:#111827;border:1px solid #ffffff14;border-radius:12px;max-height:220px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 12px 32px #00000080}.autocomplete-item{cursor:pointer;color:#94a3b8;text-align:left;background:0 0;border:none;align-items:center;gap:.625rem;width:100%;padding:.625rem .875rem;transition:background .15s;display:flex}.autocomplete-item:hover{background:#3b82f61a}.autocomplete-item+.autocomplete-item{border-top:1px solid #ffffff0a}.filter-mode-tabs{border:1px solid #ffffff14;border-radius:10px;gap:0;display:flex;overflow:hidden}.filter-tab{color:#475569;cursor:pointer;background:#ffffff05;border:none;flex:1;padding:.55rem .75rem;font-size:.8rem;font-weight:500;transition:all .2s}.filter-tab+.filter-tab{border-left:1px solid #ffffff0f}.filter-tab:hover{color:#94a3b8;background:#ffffff0a}.filter-tab.active{color:#60a5fa;background:#3b82f626}select.form-input{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:2rem}select.form-input option{color:#e2e8f0;background:#0f172a}.folder-checkbox-list{background:#0f172a66;border:1px solid #ffffff14;border-radius:12px;flex-direction:column;gap:1px;max-height:260px;padding:.5rem;display:flex;overflow-y:auto}.folder-checkbox-item{cursor:pointer;color:#94a3b8;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:.75rem;padding:.55rem .75rem;font-size:.85rem;transition:all .15s;display:flex}.folder-checkbox-item:hover{color:#fff;background:#ffffff0a}.folder-checkbox-item.active{color:#60a5fa;background:#3b82f614}.folder-checkbox-item.indent{opacity:.8;padding-left:2rem;font-size:.8rem}.folder-checkbox-item input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;border-radius:4px;width:16px;height:16px}.folder-checkbox-list::-webkit-scrollbar{width:5px}.folder-checkbox-list::-webkit-scrollbar-track{background:0 0}.folder-checkbox-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}
