@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700&family=Sora:wght@400;600;700&display=swap";.login-page{display:flex;min-height:100vh;font-family:DM Sans,sans-serif}.login-left{flex:1;background-color:#4a1259;display:flex;flex-direction:column;justify-content:space-between;padding:3rem;position:relative;overflow:hidden}.left-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(90deg,rgba(154,72,141,.06) 1px,transparent 1px),linear-gradient(rgba(154,72,141,.06) 1px,transparent 1px);background-size:48px 48px;pointer-events:none}.left-content{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;flex:1;padding:2rem 0}.left-logo{margin-bottom:2rem}.left-logo-icon{width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,#9a488d,#c278b8);display:flex;align-items:center;justify-content:center;color:#fff;font-family:Sora,sans-serif;font-weight:700;font-size:1.4rem;box-shadow:0 6px 20px #9a488d66}.left-title{font-family:Sora,sans-serif;font-size:clamp(4rem,7vw,7rem);font-weight:700;color:#fff;line-height:1;margin-bottom:1rem;letter-spacing:-3px}.left-title span{color:#9a488d}.left-tagline{color:#ffffffb3;font-size:1rem;margin-bottom:.5rem}.left-sub{color:#ffffff73;font-size:.95rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:3rem}.left-dots{display:flex;gap:.6rem}.left-dots span{display:block;width:8px;height:8px;border-radius:50%;background:#fff3}.left-dots span:first-child{background:#9a488d;width:24px;border-radius:4px}.left-footer{position:relative;z-index:1;color:#ffffff40;font-size:.75rem}.login-right{flex:1;background:#f8f9fc;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{background:#fff;border-radius:16px;box-shadow:0 8px 40px #00000014;padding:2.75rem 2.5rem;width:100%;max-width:400px;animation:cardSlideUp .5s ease}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.logo-container{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}.vo-badge{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,#9a488d,#c278b8);display:flex;align-items:center;justify-content:center;color:#fff;font-family:Sora,sans-serif;font-weight:700;font-size:1rem;flex-shrink:0;box-shadow:0 4px 12px #9a488d4d}.vo-label{font-family:Sora,sans-serif;font-size:.85rem;font-weight:600;color:#6b7280;letter-spacing:.3px}.form-title{font-family:Sora,sans-serif;font-size:1.6rem;font-weight:700;color:#4a1259;margin:0 0 .35rem;letter-spacing:-.5px}.page-subtitle{color:#9ca3af;font-size:.9rem;margin-bottom:2rem}.error-banner{background-color:#fee2e2;border:1px solid #FECACA;border-radius:8px;padding:.75rem 1rem;color:#9a488d;font-size:.875rem;margin-bottom:1.5rem;animation:slideDown .25s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-weight:600;color:#374151;font-size:.8rem;text-transform:uppercase;letter-spacing:.6px}.input-wrapper{display:flex;align-items:center;gap:.6rem;border:1.5px solid #E5E7EB;border-radius:8px;background:#fff;padding:0 1rem;transition:border-color .2s,box-shadow .2s}.input-wrapper:focus-within{border-color:#9a488d;box-shadow:0 0 0 3px #9a488d1a}.form-group input{flex:1;border:none;outline:none;padding:.75rem 0;font-size:.95rem;font-family:DM Sans,sans-serif;background:transparent;min-width:0;color:#111827}.form-group input::placeholder{color:#d1d5db}.form-group input:disabled{cursor:not-allowed;opacity:.6}.input-wrapper:has(input:disabled){background:#f9fafb}.sign-in-button{width:100%;padding:.875rem;background:linear-gradient(135deg,#9a488d,#c278b8);color:#fff;border:none;border-radius:8px;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .25s ease;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem}.sign-in-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 28px #9a488d66}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.forgot-password-link{text-align:center}.forgot-password-link a{color:#9a488d;text-decoration:none;font-size:.875rem;font-weight:500;transition:color .2s}@media (max-width: 768px){.login-page{flex-direction:column}.login-left{flex:none;min-height:220px;padding:2rem}.left-title{font-size:1.6rem}.login-right{flex:1;padding:1.5rem}.login-card{box-shadow:none;padding:2rem 1.5rem}}.background-grid{position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(90deg,rgba(154,72,141,.03) 1px,transparent 1px),linear-gradient(rgba(154,72,141,.03) 1px,transparent 1px);background-size:50px 50px;pointer-events:none}.login-card{background:#fff;border-radius:12px;box-shadow:0 25px 50px #0000004d;padding:3rem;width:100%;max-width:420px;position:relative;z-index:1;animation:cardSlideUp .6s ease cubic-bezier(.34,1.56,.64,1)}.logo-container{text-align:center;margin-bottom:2rem}.brand-logo{height:52px;width:auto}.page-title{font-family:Sora,sans-serif;font-size:1.75rem;font-weight:700;text-align:center;color:#4a1259;margin:0 0 .5rem;letter-spacing:-.5px}.page-subtitle{text-align:center;color:#6b7280;font-size:.95rem;margin-bottom:1.5rem}.error-banner{background-color:#fee2e2;border:1px solid #FECACA;border-radius:6px;padding:.75rem 1rem;color:#9a488d;font-size:.9rem;margin-bottom:1.5rem;animation:slideDown .3s ease}.login-form{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:1.5rem}.form-group label{font-weight:600;color:#374151;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.input-wrapper{display:flex;align-items:center;gap:.6rem;border:1.5px solid #E5E7EB;border-radius:8px;background:#fff;padding:0 1rem;transition:border-color .2s ease,box-shadow .2s ease}.input-wrapper:focus-within{border-color:#9a488d;box-shadow:0 0 0 3px #9a488d1a;background-color:#fafafa}.input-icon{display:flex;align-items:center;flex-shrink:0;color:#9ca3af}.form-group input{flex:1;border:none;outline:none;padding:.75rem 0;font-size:.95rem;font-family:DM Sans,sans-serif;background:transparent;min-width:0}.form-group input:focus{outline:none}.form-group input:disabled{background-color:transparent;cursor:not-allowed;opacity:.6}.input-wrapper:has(input:disabled){background-color:#f3f4f6}.sign-in-button{width:100%;padding:.85rem;background:linear-gradient(135deg,#9a488d,#c278b8);color:#fff;border:none;border-radius:8px;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem}.sign-in-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 30px #9a488d66}.sign-in-button:active:not(:disabled){transform:translateY(0)}.sign-in-button:disabled{opacity:.7;cursor:not-allowed}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.forgot-password-link{text-align:center;margin-bottom:1.5rem}.forgot-password-link a{color:#9a488d;text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s ease}.forgot-password-link a:hover{color:#71367b;text-decoration:underline}@media (max-width: 600px){.login-card{padding:2rem;margin:1rem}.page-title{font-size:1.5rem}.page-subtitle{font-size:.85rem}.login-form{gap:1rem}}.forgot-password-page{min-height:100vh;background-color:#4a1259;display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;position:relative;overflow:hidden}.forgot-password-card{background:#fff;border-radius:12px;box-shadow:0 25px 50px #0000004d;padding:3rem;width:100%;max-width:450px;position:relative;z-index:1;animation:cardSlideUp .6s ease cubic-bezier(.34,1.56,.64,1)}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.icon-container{text-align:center;margin-bottom:2rem}.envelope-icon{font-size:4rem;display:inline-block;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.page-title{font-family:Sora,sans-serif;font-size:1.75rem;font-weight:700;text-align:center;color:#4a1259;margin:0 0 1rem;letter-spacing:-.5px}.page-description{text-align:center;color:#6b7280;font-size:.95rem;margin-bottom:2rem;line-height:1.5}.contact-box{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #BFDBFE;border-radius:8px;padding:1.5rem;text-align:center;margin-bottom:2rem}.contact-label{color:#374151;font-weight:600;font-size:.9rem;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.5px}.contact-email{display:inline-block;color:#9a488d;text-decoration:none;font-weight:700;font-size:1.1rem;padding:.5rem 1rem;border-radius:6px;transition:all .2s ease;letter-spacing:.3px}.contact-email:hover{color:#fff;background-color:#9a488d;box-shadow:0 4px 12px #9a488d4d}.additional-info{background-color:#f9fafb;border-left:4px solid #10B981;border-radius:6px;padding:1rem;margin-bottom:2rem;font-size:.9rem;color:#374151}.additional-info p{margin:.5rem 0;line-height:1.5}.back-to-login{display:block;text-align:center;color:#4a1259;text-decoration:none;font-weight:600;padding:.75rem 1.5rem;border:2px solid #E5E7EB;border-radius:8px;transition:all .2s ease;margin-top:1.5rem}.back-to-login:hover{border-color:#9a488d;color:#9a488d;background-color:#fef3f2}@media (max-width: 600px){.forgot-password-card{padding:2rem;margin:1rem}.page-title{font-size:1.5rem}.envelope-icon{font-size:3.5rem}}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;min-width:240px;background-color:#2d0a3b;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;box-shadow:4px 0 20px #00000040}.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:1.5rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo-box{width:40px;height:40px;background-color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:Sora,sans-serif;font-weight:800;font-size:1.05rem;color:#4a1259;flex-shrink:0;letter-spacing:-.5px}.sidebar-title{font-size:1.25rem;font-weight:700;color:#fff;letter-spacing:.2px;font-family:Sora,sans-serif}.sidebar-nav{flex:1;padding:1.5rem .75rem;display:flex;flex-direction:column;gap:.35rem}.sidebar-nav-item{display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;border-radius:10px;text-decoration:none;color:#ffffffa6;font-size:1rem;font-weight:500;transition:background-color .2s ease,color .2s ease;position:relative;cursor:pointer}.sidebar-nav-item:hover{background-color:#ffffff14;color:#fff}.sidebar-nav-item--active{background-color:#9a488d59;color:#fff;font-weight:600}.sidebar-nav-icon{width:22px;height:22px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-nav-icon svg{width:22px;height:22px}.sidebar-nav-label{font-size:1rem;letter-spacing:.1px}.sidebar-nav-indicator{position:absolute;left:0;top:20%;bottom:20%;width:3px;background-color:#c278b8;border-radius:0 3px 3px 0}.sidebar-footer{padding:1rem .75rem 1.5rem;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:.5rem}.sidebar-user{flex:1;display:flex;align-items:center;gap:.75rem;min-width:0}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background-color:#9a488d;color:#fff;font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-user-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.sidebar-user-email{font-size:.82rem;color:#e5e7eb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}.sidebar-role-badge{display:inline-block;padding:.15rem .55rem;border-radius:20px;font-size:.7rem;font-weight:600;text-transform:uppercase;color:#fff;align-self:flex-start}.sidebar-logout-btn{background:none;border:none;cursor:pointer;color:#ffffff80;padding:.4rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:color .2s,background-color .2s;flex-shrink:0}.sidebar-logout-btn:hover{color:#fff;background-color:#ef444440}.sidebar-logout-btn svg{width:20px;height:20px}.main-content{margin-left:240px;flex:1;min-height:100vh}@media (max-width: 768px){.sidebar{width:64px;min-width:64px}.sidebar-title,.sidebar-nav-label,.sidebar-user-info{display:none}.sidebar-brand{justify-content:center;padding:1.25rem .5rem}.sidebar-nav-item{justify-content:center;padding:.85rem}.sidebar-footer{justify-content:center;padding:1rem .5rem}.sidebar-user{justify-content:center}.main-content{margin-left:64px}}.demo-service-panel{grid-column:span 1}.svc-tag{font-size:.72rem;font-weight:700;padding:.18rem .6rem;border-radius:20px;letter-spacing:.5px;text-transform:uppercase}.svc-tag--drm{background:#ede9fe;color:#5b21b6}.svc-tag--ads{background:#fef3c7;color:#92400e}.svc-metrics{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem;margin-bottom:1rem}.svc-metric{display:flex;flex-direction:column;gap:.15rem}.svc-metric-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.4px;color:#9ca3af;font-weight:600}.svc-metric-value{font-family:Sora,sans-serif;font-size:1.6rem;font-weight:800;color:#1f2937;line-height:1.1}.svc-unit{font-size:.95rem;font-weight:500;color:#6b7280}.svc-metric-delta{font-size:.76rem;font-weight:600}.delta--up{color:#059669}.delta--down{color:#dc2626}.delta--neutral{color:#6b7280}.svc-chart-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.4px;color:#9ca3af;font-weight:600;margin-bottom:.2rem}.sparkline{width:100%;display:block}.resp-sparkline-row{margin-top:.75rem}.widget-header--flex{display:flex;align-items:center;justify-content:space-between}.widget-badge{font-size:.72rem;background:#ede9fe;color:#5b21b6;padding:.2rem .6rem;border-radius:20px;font-weight:600}.demo-slos{grid-column:span 1}.slo-list{display:flex;flex-direction:column;gap:1rem}.slo-item{display:flex;align-items:center;gap:1rem}.gauge-svg{width:68px;height:68px;flex-shrink:0}.gauge-val{font-size:11px;font-weight:800;font-family:Sora,sans-serif}.gauge-sub{font-size:9px;font-weight:500}.slo-info{display:flex;flex-direction:column;gap:.25rem}.slo-name{font-size:.82rem;font-weight:600;color:#374151}.slo-status{font-size:.78rem;font-weight:700}.slo-ok{color:#059669}.slo-warn{color:#d97706}.demo-analytics{grid-column:span 2}.bar-chart{display:flex;align-items:flex-end;gap:10px;height:130px;width:100%}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:5px;height:100%}.bar-pair{display:flex;gap:3px;align-items:flex-end;width:100%;height:100%}.bar-fill{flex:1;border-radius:5px 5px 0 0;min-height:4px;transition:height 1.1s cubic-bezier(.34,1.56,.64,1);opacity:.82}.bar-label{font-size:.72rem;color:#9ca3af;font-weight:600}.chart-legend{display:flex;flex-wrap:wrap;align-items:center;gap:.3rem 0;margin-top:.9rem;font-size:.76rem;color:#6b7280;line-height:1.6}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px;flex-shrink:0}.legend-item{font-size:.76rem;color:#6b7280}.demo-alerts{grid-column:span 1}.alert-count{font-size:.75rem;background:#fee2e2;color:#991b1b;padding:.2rem .6rem;border-radius:20px;font-weight:700}.alert-list{display:flex;flex-direction:column;gap:.75rem}.alert-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border-radius:8px}.alert-item--resolved{background:#f0fdf4;border-left:3px solid #10B981}.alert-item--warning{background:#fffbeb;border-left:3px solid #F59E0B}.alert-item--info{background:#eff6ff;border-left:3px solid #3B82F6}.alert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}.alert-item--resolved .alert-dot{background:#10b981}.alert-item--warning .alert-dot{background:#f59e0b}.alert-item--info .alert-dot{background:#3b82f6}.alert-text{display:flex;flex-direction:column;gap:.2rem}.alert-msg{font-size:.85rem;font-weight:600;color:#1f2937}.alert-time{font-size:.75rem;color:#9ca3af}.alert-svc{font-weight:700;color:#6b7280}.dashboard-page{min-height:100vh;background:linear-gradient(135deg,#4a1259,#5c1a70);padding:2.5rem 2rem;font-family:DM Sans,sans-serif}.dashboard-container{max-width:900px;margin:0 auto}.welcome-card{background:#fff;border-radius:12px;box-shadow:0 20px 50px #00000026;padding:3rem 2rem;text-align:center;max-width:600px;margin:0 auto;animation:fadeInUp .8s ease cubic-bezier(.34,1.56,.64,1)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.checkmark{width:80px;height:80px;margin:0 auto 1.5rem;color:#10b981;opacity:0;animation:checkmarkDraw .6s ease .3s forwards}@keyframes checkmarkDraw{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.checkmark svg{width:100%;height:100%;stroke-dasharray:100;stroke-dashoffset:100;animation:drawCheckmark .8s ease forwards}@keyframes drawCheckmark{0%{stroke-dashoffset:100}to{stroke-dashoffset:0}}.welcome-title{font-family:Sora,sans-serif;font-size:2.5rem;font-weight:700;color:#4a1259;margin:0 0 .5rem;letter-spacing:-.5px}.welcome-subtitle{color:#6b7280;font-size:1.1rem;margin-bottom:2rem;font-weight:500}.welcome-subtitle strong{color:#4a1259;font-weight:700}.role-badge{display:inline-block;padding:.6rem 1.2rem;border-radius:25px;font-size:.85rem;font-weight:600;text-transform:uppercase;color:#fff;letter-spacing:.5px;margin-bottom:2rem;box-shadow:0 4px 12px #00000026}.running-services-section{margin-top:3rem;padding-top:3rem;border-top:2px solid #E5E7EB}.services-title{font-family:Sora,sans-serif;font-size:1.25rem;font-weight:600;color:#4a1259;margin:0 0 1.5rem}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-top:1.5rem}.service-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #BFDBFE;border-radius:8px;padding:1.5rem;text-align:center;transition:all .3s ease;cursor:pointer}.service-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #3b82f633;border-color:#3b82f6}.service-icon{font-size:2.5rem;margin-bottom:.75rem}.service-name{font-weight:600;color:#0c4a6e;font-size:.95rem}@media (max-width: 768px){.dashboard-page{padding:1rem}.welcome-card{padding:2rem 1.5rem}.welcome-title{font-size:2rem}.welcome-subtitle{font-size:1rem}.services-grid{grid-template-columns:repeat(2,1fr)}}.env-card{background:#fff;border-radius:12px;box-shadow:0 20px 50px #00000026;padding:2.5rem;max-width:760px;margin:0 auto;animation:fadeInUp .6s ease}.env-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid #F3F4F6}.env-avatar{width:64px;height:64px;border-radius:14px;background-color:#4a1259;color:#fff;font-size:1.75rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:Sora,sans-serif}.env-label{font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:#9ca3af;font-weight:600;margin:0 0 .25rem}.env-name{font-family:Sora,sans-serif;font-size:1.8rem;font-weight:800;color:#1f2937;margin:0;letter-spacing:-.5px}.env-meta{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem}.env-login{font-size:.9rem;color:#6b7280}.env-login strong{color:#374151}.env-services-section{padding-top:1.5rem;border-top:2px solid #F3F4F6}.no-services{color:#9ca3af;font-size:.9rem;margin:.5rem 0 0}@media (max-width: 600px){.welcome-card{padding:1.5rem 1rem}.checkmark{width:60px;height:60px;margin-bottom:1rem}.welcome-title{font-size:1.5rem}.services-grid{grid-template-columns:1fr}}.env-workspace{min-height:100vh;background:#f1f5f9;display:flex;flex-direction:column;font-family:DM Sans,sans-serif}.env-topbar{background:#2d0a3b;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-shrink:0}.env-topbar-left{display:flex;align-items:center;gap:1rem}.env-topbar-right{display:flex;align-items:center;gap:.75rem}.back-btn{display:inline-flex;align-items:center;gap:.35rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.18);color:#fff;font-size:.85rem;font-weight:600;padding:.45rem .9rem;border-radius:7px;cursor:pointer;transition:background-color .2s;font-family:DM Sans,sans-serif;flex-shrink:0}.back-btn:hover{background:#fff3}.back-btn svg{width:16px;height:16px}.env-topbar-identity{display:flex;align-items:center;gap:.9rem}.env-avatar-sm{width:42px;height:42px;border-radius:10px;background-color:#9a488d;color:#fff;font-size:1.1rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:Sora,sans-serif}.env-label{font-size:.72rem;text-transform:uppercase;letter-spacing:1px;color:#ffffff80;font-weight:600;margin:0 0 .15rem}.env-name{font-family:Sora,sans-serif;font-size:1.25rem;font-weight:800;color:#fff;margin:0;letter-spacing:-.3px}.env-meta-row{display:flex;gap:0;background:#fff;border-bottom:1px solid #E5E7EB;flex-shrink:0}.env-meta-tile{flex:1;display:flex;flex-direction:column;gap:.25rem;padding:1rem 1.5rem;border-right:1px solid #E5E7EB}.env-meta-tile:last-child{border-right:none}.meta-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.6px;color:#9ca3af;font-weight:600}.meta-value{font-size:.95rem;color:#1f2937;font-weight:600}.meta-value.mono{font-family:monospace;font-size:.88rem}.status-badge{display:inline-block;padding:.3rem .8rem;border-radius:20px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.status-badge--active{background:#d1fae5;color:#065f46}.status-badge--disabled{background:#fee2e2;color:#991b1b}.env-content-grid{flex:1;display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(220px,auto);gap:1.25rem;padding:1.5rem 2rem 2rem;align-content:start}.env-widget{background:#fff;border-radius:12px;box-shadow:0 1px 4px #00000012;display:flex;flex-direction:column;overflow:hidden}.env-widget--wide{grid-column:span 2}.env-widget--services{grid-column:span 3;grid-auto-rows:auto}.widget-header{padding:1rem 1.25rem .75rem;border-bottom:1px solid #F3F4F6}.widget-title{font-family:Sora,sans-serif;font-size:.9rem;font-weight:700;color:#374151;margin:0;text-transform:uppercase;letter-spacing:.4px}.widget-body{flex:1;padding:1.25rem}.widget-body--empty{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#9ca3af;font-size:.9rem;gap:.5rem;text-align:center}.placeholder-icon{font-size:2rem}.widget-empty{color:#9ca3af;font-size:.88rem;font-style:italic;margin:0}.env-widget--placeholder{background:#fafafa;border:2px dashed #E5E7EB;box-shadow:none}.services-chips{display:flex;flex-wrap:wrap;gap:.6rem}.service-chip{display:inline-flex;align-items:center;gap:.5rem;background:#f5f0fa;border:1px solid #C4B5D4;color:#4a1259;padding:.45rem 1rem;border-radius:20px;font-size:.88rem;font-weight:600}.service-chip-dot{width:8px;height:8px;border-radius:50%;background-color:#9a488d;flex-shrink:0}.env-state{background:#fff;border-radius:12px;padding:3rem;text-align:center;color:#6b7280;margin:2rem}.env-state--error{color:#dc2626}@media (max-width: 1100px){.env-content-grid{grid-template-columns:repeat(2,1fr)}.env-widget--services,.env-widget--wide{grid-column:span 2}}@media (max-width: 700px){.env-topbar{padding:.75rem 1rem}.env-meta-row{flex-wrap:wrap}.env-meta-tile{min-width:50%;border-right:none;border-bottom:1px solid #E5E7EB}.env-content-grid{grid-template-columns:1fr;padding:1rem}.env-widget--services,.env-widget--wide{grid-column:span 1}}.user-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.user-table{width:100%;border-collapse:collapse;font-size:.95rem}.user-table thead{background-color:#f3f4f6;border-bottom:2px solid #E5E7EB}.user-table th{padding:1rem;text-align:left;font-weight:600;color:#374151;text-transform:uppercase;font-size:.85rem;letter-spacing:.5px}.user-table tbody tr{border-bottom:1px solid #E5E7EB;transition:background-color .2s ease}.user-table tbody tr:hover{background-color:#f9fafb}.user-table td{padding:1rem;color:#374151}.email-cell{font-weight:500;color:#4a1259;font-family:Courier New,monospace;font-size:.9rem}.date-cell{color:#6b7280;font-size:.9rem}.role-badge{display:inline-block;padding:.4rem .8rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#fff}.action-cell{text-align:left}.action-group{display:flex;gap:.5rem;justify-content:flex-start;flex-wrap:wrap}.action-btn{padding:.4rem .8rem;border:none;border-radius:6px;font-size:.82rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.action-btn:disabled{opacity:.4;cursor:not-allowed}.reset-btn{background-color:#3b82f6;color:#fff}.reset-btn:hover:not(:disabled){background-color:#2563eb}.disable-btn{background-color:#ef4444;color:#fff}.disable-btn:hover:not(:disabled){background-color:#dc2626}.enable-btn{background-color:#10b981;color:#fff}.enable-btn:hover:not(:disabled){background-color:#059669}.delete-btn{background-color:#6b7280;color:#fff}.delete-btn:hover:not(:disabled){background-color:#374151}.role-select{border:1px solid #D1D5DB;border-radius:6px;padding:.3rem .5rem;font-size:.85rem;background:#fff;cursor:pointer;color:#374151}.role-select:disabled{opacity:.5;cursor:not-allowed}.status-badge{display:inline-block;padding:.25rem .6rem;border-radius:12px;font-size:.78rem;font-weight:600;text-transform:uppercase}.row--disabled td{opacity:.55}.loading,.empty-state{padding:3rem 2rem;text-align:center;color:#6b7280;font-size:1rem}@media (max-width: 768px){.user-table{font-size:.85rem}.user-table th,.user-table td{padding:.75rem .5rem}.action-btn{padding:.4rem .8rem;font-size:.75rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:8px;box-shadow:0 20px 25px #00000026;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #E5E7EB}.modal-header h2{margin:0;font-size:1.5rem;color:#4a1259;font-family:Sora,sans-serif}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;transition:color .2s ease;padding:0}.modal-close:hover{color:#374151}.create-user-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.form-group input,.form-group select{padding:.75rem;border:1px solid #D1D5DB;border-radius:6px;font-size:.95rem;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#9a488d;box-shadow:0 0 0 3px #9a488d1a}.service-input-group{display:flex;gap:.5rem;margin-bottom:.75rem}.service-input-group input{flex:1}.add-service-btn{padding:.75rem 1.5rem;background-color:#9a488d;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.add-service-btn:hover{background-color:#71367b}.service-tags{display:flex;flex-wrap:wrap;gap:.5rem}.service-tag{display:inline-flex;align-items:center;gap:.5rem;background-color:#f3f4f6;border:1px solid #D1D5DB;padding:.5rem .75rem;border-radius:20px;font-size:.9rem;color:#374151}.remove-tag{background:none;border:none;color:#9ca3af;cursor:pointer;padding:0;font-size:.9rem}.remove-tag:hover{color:#ef4444}.ai-suggestion-section{padding:1rem;background-color:#fef3f2;border-radius:6px;border:1px solid #FCDDD0}.ai-suggest-btn{width:100%;padding:.75rem;background-color:#f59e0b;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.ai-suggest-btn:hover:not(:disabled){background-color:#d97706}.ai-suggest-btn:disabled{opacity:.6;cursor:not-allowed}.ai-suggestion-result{margin-top:1rem;padding:1rem;background:#fff;border-radius:6px;border-left:3px solid #F59E0B}.suggestion-note{margin:0 0 .75rem;color:#374151;font-size:.9rem;line-height:1.5}.apply-suggestion-btn{width:100%;padding:.5rem;background-color:#10b981;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.apply-suggestion-btn:hover{background-color:#059669}.submit-btn{background-color:#9a488d;color:#fff}.submit-btn:hover:not(:disabled){background-color:#71367b;transform:translateY(-2px)}.field-error{color:#dc2626;font-size:.82rem;margin:.25rem 0 0}@media (max-width: 600px){.modal-content{max-width:95%}.create-user-form{gap:1rem;padding:1rem}.modal-header{padding:1rem}}.reset-user-info{padding:1.5rem 1.5rem 0;color:#6b7280;font-size:.95rem;background-color:#f0f9ff;margin:0 1.5rem 1.5rem;padding:1rem;border-left:4px solid #3B82F6;border-radius:6px}.reset-user-info strong{color:#4a1259;font-weight:600}.reset-password-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.error-message{padding:.75rem 1rem;background-color:#fee2e2;border:1px solid #FECACA;border-radius:6px;color:#9a488d;font-size:.95rem;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#374151;font-size:.95rem}.form-group input{padding:.75rem;border:1px solid #D1D5DB;border-radius:6px;font-size:.95rem;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-actions{display:flex;gap:1rem;margin-top:1rem}.submit-btn,.cancel-btn{flex:1;padding:.75rem;border:none;border-radius:6px;font-weight:600;cursor:pointer;font-size:.95rem;transition:all .2s ease}.submit-btn{background-color:#3b82f6;color:#fff}.submit-btn:hover:not(:disabled){background-color:#2563eb;transform:translateY(-2px)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.cancel-btn{background-color:#e5e7eb;color:#374151}.cancel-btn:hover{background-color:#d1d5db}@media (max-width: 600px){.reset-password-form{gap:1rem;padding:1rem}}.toast-container{position:fixed;top:1rem;right:1rem;z-index:2000;display:flex;flex-direction:column;gap:.75rem;pointer-events:none}.toast{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-width:300px;max-width:400px;padding:1rem;border-radius:8px;font-size:.95rem;font-weight:500;box-shadow:0 10px 25px #00000026;animation:slideInRight .3s ease;pointer-events:auto}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast.toast-success{background-color:#d1fae5;border:1px solid #A7F3D0;border-left:4px solid #10B981;color:#065f46}.toast.toast-error{background-color:#fee2e2;border:1px solid #FECACA;border-left:4px solid #EF4444;color:#7f1d1d}.toast.toast-warning{background-color:#fef3c7;border:1px solid #FCD34D;border-left:4px solid #F59E0B;color:#78350f}.toast.toast-info{background-color:#dbeafe;border:1px solid #BFDBFE;border-left:4px solid #3B82F6;color:#1e3a8a}.toast-message{flex:1}.toast-close{background:none;border:none;cursor:pointer;padding:0;font-size:1.2rem;opacity:.7;transition:opacity .2s ease}.toast-close:hover{opacity:1}@media (max-width: 600px){.toast-container{left:1rem;right:1rem}.toast{min-width:unset}}.admin-users-page{min-height:100vh;background:linear-gradient(135deg,#4a1259,#5c1a70);padding:2.5rem 2rem;font-family:DM Sans,sans-serif}.admin-container{max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}.page-title{font-family:Sora,sans-serif;font-size:2rem;font-weight:700;color:#fff;margin:0 0 .5rem;letter-spacing:-.5px}.page-description{color:#d1d5db;font-size:.95rem;margin:0}.create-user-btn{background:linear-gradient(135deg,#9a488d,#c278b8);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;white-space:nowrap;box-shadow:0 4px 12px #9a488d4d}.create-user-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #9a488d66}.create-user-btn:active{transform:translateY(0)}.users-section{background:#fff;border-radius:12px;box-shadow:0 20px 50px #00000026;overflow:hidden;animation:slideUp .6s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.admin-users-page{padding:1rem}.admin-container{padding-top:1rem}.page-header{flex-direction:column;gap:1rem}.page-title{font-size:1.5rem}.create-user-btn{width:100%;text-align:center}}.delete-confirm-modal{max-width:440px;padding:0;overflow:hidden}.dcm-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #FEE2E2;background:#fff5f5}.dcm-header-left{display:flex;align-items:center;gap:.65rem}.dcm-icon{width:20px;height:20px;color:#dc2626;flex-shrink:0}.dcm-icon svg{width:100%;height:100%;display:block}.dcm-title{font-family:Sora,sans-serif;font-size:1.1rem;font-weight:700;color:#991b1b;margin:0}.dcm-body{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.dcm-desc{font-size:.9rem;color:#374151;line-height:1.65;margin:0}.dcm-hint{font-size:.85rem;color:#6b7280;margin:0}.dcm-hint code{background:#f3f4f6;padding:.1rem .4rem;border-radius:4px;font-size:.85rem;color:#dc2626;font-weight:700}.delete-confirm-input{width:100%;padding:.65rem .85rem;border:2px solid #E5E7EB;border-radius:6px;font-size:.95rem;font-family:DM Sans,sans-serif;outline:none;transition:border-color .15s;box-sizing:border-box;color:#1f2937}.delete-confirm-input:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.dcm-footer{display:flex;justify-content:flex-end;align-items:center;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #F3F4F6;background:#fafafa}.btn-secondary{padding:.5rem 1.1rem;border:1px solid #D1D5DB;border-radius:6px;background:#fff;color:#374151;font-size:.9rem;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif;transition:background .15s}.btn-secondary:hover{background:#f9fafb}.dcm-btn-delete{padding:.5rem 1.2rem;border:none;border-radius:6px;background:#dc2626;color:#fff;font-size:.9rem;font-weight:700;font-family:DM Sans,sans-serif;cursor:pointer;transition:background .15s,opacity .15s}.dcm-btn-delete:hover:not(:disabled){background:#b91c1c}.dcm-btn-delete:disabled{opacity:.35;cursor:not-allowed}.customers-page{min-height:100vh;background:linear-gradient(135deg,#4a1259,#5c1a70);padding:2.5rem 2rem;font-family:DM Sans,sans-serif}.customers-container{max-width:1200px;margin:0 auto}.customers-page .page-header{margin-bottom:2rem}.customers-page .page-title{font-family:Sora,sans-serif;font-size:2rem;font-weight:700;color:#fff;margin:0 0 .5rem;letter-spacing:-.5px}.customers-page .page-description{color:#d1d5db;font-size:.95rem;margin:0}.customers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.customers-loading,.customers-empty{background:#fff;border-radius:12px;padding:3rem;text-align:center;color:#6b7280}.customer-card{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001f;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.customer-card--clickable{cursor:pointer}.customer-card--clickable:hover{transform:translateY(-3px);box-shadow:0 8px 30px #0000002e}.customer-card--disabled{opacity:.6}.customer-card-header{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;border-bottom:1px solid #F3F4F6}.customer-avatar{width:48px;height:48px;border-radius:10px;background-color:#4a1259;color:#fff;font-size:1.3rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:Sora,sans-serif}.customer-card-info{flex:1;min-width:0}.customer-name{font-family:Sora,sans-serif;font-size:1rem;font-weight:700;color:#1f2937;margin:0 0 .2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.customer-login{font-size:.82rem;color:#9ca3af;font-family:monospace}.status-badge{display:inline-block;padding:.25rem .6rem;border-radius:12px;font-size:.72rem;font-weight:600;text-transform:uppercase;flex-shrink:0}.status-badge--active{background-color:#d1fae5;color:#065f46}.status-badge--disabled{background-color:#fee2e2;color:#991b1b}.customer-card-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.customer-meta{display:flex;gap:2rem;flex-wrap:wrap}.meta-item{display:flex;flex-direction:column;gap:.2rem}.meta-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:#9ca3af;font-weight:600}.meta-value{font-size:.88rem;color:#374151;font-weight:500}.customer-services{display:flex;flex-direction:column;gap:.5rem}.services-tags{display:flex;flex-wrap:wrap;gap:.4rem}.service-tag{background-color:#ede9fe;color:#5b21b6;padding:.25rem .65rem;border-radius:20px;font-size:.8rem;font-weight:500}.no-services-label{font-size:.85rem;color:#9ca3af;font-style:italic}.customer-card-footer{padding-top:.75rem;border-top:1px solid #F3F4F6;text-align:right}.view-env-hint{font-size:.82rem;color:#9a488d;font-weight:600}@media (max-width: 768px){.customers-page{padding:1.5rem 1rem}.customers-grid{grid-template-columns:1fr}}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:DM Sans,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#4a1259,#5c1a70);color:#fff;gap:1rem}.spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}body{margin:0;background-color:#f5f7fa}#root{min-height:100vh}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:DM Sans,sans-serif}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background-color:#f5f7fa}::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:4px}::-webkit-scrollbar-thumb:hover{background-color:#9ca3af}
