:root{--navy:#0d1b3e;--gold:#c8a96e;--blue:#2563ff;--success:#27a644;--error:#e53e3e;--warning:#d97706;--text-primary:#0d1b3e;--text-secondary:#64748b;--text-muted:#94a3b8;--text-inverse:#fff;--surface:#fff;--surface-raised:#f8fafc;--surface-border:#e2e8f0;--sidebar-width:220px;--nav-height:60px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--shadow-sm:0 1px 3px rgba(0,0,0,.08);--shadow-md:0 4px 12px rgba(0,0,0,.1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;font-family:system-ui,-apple-system,sans-serif;font-size:15px;color:var(--text-primary);background:var(--surface-raised)}a{color:inherit;text-decoration:none}h1{font-size:1.75rem;font-weight:700}h2{font-size:1.25rem}h2,h3{font-weight:600}h3{font-size:1rem}.text-muted{color:var(--text-secondary)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-success{color:var(--success)}.text-error{color:var(--error)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-4{margin-top:2rem}.mb-2{margin-bottom:1rem}.mb-4{margin-bottom:2rem}.gap-2{gap:1rem}.gap-1{gap:.5rem}.flex{display:flex}.flex-col{flex-direction:column}.flex-center{justify-content:center}.flex-between,.flex-center{display:flex;align-items:center}.flex-between{justify-content:space-between}.items-center{align-items:center}.flex-1{flex:1 1}.card{padding:1.5rem;box-shadow:var(--shadow-sm)}.card,.stat-card{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-lg)}.stat-card{padding:1.25rem 1.5rem}.stat-card .stat-label{font-size:.8rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.stat-card .stat-value{font-size:2rem;font-weight:700;margin-top:.25rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;border:none;transition:opacity .15s,box-shadow .15s}.btn:hover{opacity:.88}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--blue);color:#fff}.btn-navy{background:var(--navy);color:#fff}.btn-gold{background:var(--gold);color:var(--navy)}.btn-ghost{background:transparent;color:var(--text-primary);border:1px solid var(--surface-border)}.btn-danger{background:var(--error);color:#fff}.btn-sm{padding:.35rem .75rem;font-size:.82rem}.form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.1rem}.form-label{font-size:.85rem;font-weight:500;color:var(--text-primary)}.form-input,.form-select{width:100%;padding:.6rem .85rem;border:1px solid var(--surface-border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--surface);color:var(--text-primary);transition:border-color .15s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--blue)}.form-hint{font-size:.78rem;color:var(--text-secondary)}.form-error{font-size:.82rem;color:var(--error)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.88rem}thead th{text-align:left;padding:.65rem 1rem;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:var(--surface-raised)}tbody td,thead th{border-bottom:1px solid var(--surface-border)}tbody td{padding:.85rem 1rem}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--surface-raised)}.badge{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-active{background:#dcfce7;color:#15803d}.badge-provisioning{background:#fef9c3;color:#854d0e}.badge-error{background:#fee2e2;color:#991b1b}.badge-disconnected,.badge-pending{background:#f1f5f9;color:#475569}.alert{padding:.85rem 1.1rem;border-radius:var(--radius-md);font-size:.88rem;margin-bottom:1rem}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}.alert-info{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.spinner{width:20px;height:20px;border:2px solid var(--surface-border);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;flex-direction:column;gap:1rem;color:var(--text-secondary)}.admin-shell{display:flex;height:100vh;overflow:hidden}.admin-sidebar{width:var(--sidebar-width);background:var(--navy);color:var(--text-inverse);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.admin-sidebar-logo{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid hsla(0,0%,100%,.1)}.admin-sidebar-logo .brand{font-weight:700;font-size:1.05rem;color:var(--gold)}.admin-sidebar-logo .sub{font-size:.72rem;color:hsla(0,0%,100%,.45);margin-top:.15rem}.admin-nav{padding:1rem 0;flex:1 1}.admin-nav-section{padding:.5rem 1.25rem .2rem;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:hsla(0,0%,100%,.35)}.admin-nav a{display:flex;align-items:center;gap:.6rem;padding:.55rem 1.25rem;font-size:.88rem;color:hsla(0,0%,100%,.75);transition:background .15s,color .15s}.admin-nav a.active,.admin-nav a:hover{background:hsla(0,0%,100%,.08);color:#fff}.admin-nav a.active{border-left:3px solid var(--gold)}.admin-user{padding:1rem 1.25rem;border-top:1px solid hsla(0,0%,100%,.1);font-size:.8rem;color:hsla(0,0%,100%,.55)}.admin-user .name{color:hsla(0,0%,100%,.85);font-weight:500;margin-bottom:.15rem}.admin-main{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.admin-header{height:var(--nav-height);padding:0 2rem;border-bottom:1px solid var(--surface-border);background:var(--surface);display:flex;align-items:center}.admin-content{flex:1 1;overflow-y:auto;padding:2rem}.portal-shell{display:flex;height:100vh;overflow:hidden}.portal-sidebar{width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--surface-border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.portal-sidebar-logo{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--surface-border)}.portal-sidebar-logo .brand{font-weight:700;font-size:1.05rem;color:var(--navy)}.portal-sidebar-logo .brand span{color:var(--gold)}.portal-sidebar-logo .sub{font-size:.72rem;color:var(--text-muted);margin-top:.15rem}.portal-nav{padding:1rem 0;flex:1 1}.portal-nav-section{padding:.5rem 1.25rem .2rem;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.portal-nav a{display:flex;align-items:center;gap:.6rem;padding:.55rem 1.25rem;font-size:.88rem;color:var(--text-secondary);transition:background .15s,color .15s}.portal-nav a:hover{background:var(--surface-raised);color:var(--text-primary)}.portal-nav a.active{background:var(--surface-raised);color:var(--navy);font-weight:600;border-left:3px solid var(--blue)}.portal-user{padding:1rem 1.25rem;border-top:1px solid var(--surface-border);font-size:.8rem;color:var(--text-secondary)}.portal-user .name{color:var(--text-primary);font-weight:500;margin-bottom:.15rem}.portal-main{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.portal-content{flex:1 1;overflow-y:auto;padding:2rem}.connection-card{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.connection-card .platform-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--surface-raised);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.connection-card .platform-info{flex:1 1}.connection-card .platform-name{font-weight:600;font-size:.95rem}.connection-card .platform-detail{font-size:.8rem;color:var(--text-secondary);margin-top:.15rem}.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:var(--surface);border-radius:var(--radius-lg);padding:2rem;width:100%;max-width:480px;box-shadow:var(--shadow-md)}.modal-title{font-size:1.15rem;font-weight:700;margin-bottom:.25rem}.modal-subtitle{font-size:.85rem;color:var(--text-secondary);margin-bottom:1.5rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.login-layout{display:flex;min-height:100vh}.login-panel-left{flex:0 0 45%;background:var(--navy);display:flex;flex-direction:column;justify-content:space-between;padding:3rem}.login-panel-right{flex:1 1;display:flex;align-items:center;justify-content:center;background:var(--surface-raised);padding:2rem}.login-panel-right-inner{width:100%;max-width:400px}@media (max-width:680px){.login-layout{flex-direction:column}.login-panel-left{flex:none;padding:1.75rem;justify-content:flex-start;gap:1rem}.login-panel-left .login-copyright,.login-panel-left .login-tagline{display:none}.login-panel-right{padding:1.75rem 1.25rem}}.hamburger{display:none;background:none;border:none;cursor:pointer;padding:.35rem;color:var(--text-primary);line-height:1;border-radius:var(--radius-sm)}.hamburger:hover{background:var(--surface-raised)}.mobile-topbar{display:none;align-items:center;justify-content:space-between;padding:0 1rem;height:var(--nav-height);background:var(--surface);border-bottom:1px solid var(--surface-border);flex-shrink:0}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:199}@media (max-width:768px){.hamburger,.mobile-topbar{display:flex}.admin-sidebar,.portal-sidebar{position:fixed;top:0;left:0;bottom:0;z-index:200;transform:translateX(-100%);transition:transform .22s ease;box-shadow:var(--shadow-md)}.admin-sidebar.open,.portal-sidebar.open{transform:translateX(0)}.sidebar-overlay{display:block}.admin-header{padding:0 1rem}.admin-content,.portal-content{padding:1.25rem}}