*{box-sizing:border-box}body,html{margin:0;padding:0;font-family:Segoe UI,Arial,sans-serif;background:#f6f8fb;color:#182230}a{color:inherit;text-decoration:none}.shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.shell.admin-shell{grid-template-columns:72px 1fr}.shell.portal-shell{grid-template-columns:260px 1fr}.sidebar{background:#0f172a;color:#fff;padding:20px}.sidebar h1{margin:0 0 20px;font-size:20px}.sidebar .section{margin-top:18px;font-size:12px;opacity:.8;text-transform:uppercase}.sidebar nav{display:flex;flex-direction:column;gap:8px;margin-top:10px}.sidebar nav a{padding:8px 10px;border-radius:8px}.sidebar nav a.active,.sidebar nav a:hover{background:#1e293b}.sidebar .nav-group-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;border-radius:8px;background:none;border:none;color:#fff;font-size:inherit;cursor:pointer;text-align:left}.sidebar .nav-group-btn:hover{background:#1e293b}.sidebar .nav-group-btn .chevron{font-size:10px;opacity:.6;transition:transform .2s}.sidebar .nav-group-btn.open .chevron{transform:rotate(90deg)}.sidebar .nav-sub{display:flex;flex-direction:column;gap:4px;overflow:hidden;max-height:0;transition:max-height .25s ease}.sidebar .nav-sub.open{max-height:400px}.sidebar .nav-sub a{padding-left:22px!important}.admin-sidebar{position:relative;padding:0;overflow:visible}.admin-sidebar .admin-rail{width:72px;min-height:100vh;background:#0f172a;border-right:1px solid #1e293b;padding:10px 0;gap:10px}.admin-sidebar .admin-rail,.admin-sidebar .rail-nav{display:flex;flex-direction:column;align-items:center}.admin-sidebar .rail-nav{gap:8px;width:100%}.admin-sidebar .rail-bottom-nav{margin-top:auto;padding-bottom:8px}.admin-sidebar .rail-icon-btn{width:50px;min-height:50px;border:1px solid #31415f;border-radius:14px;background:transparent;color:#dbe7ff;display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;text-decoration:none;box-shadow:inset 0 0 0 1px rgba(15,23,42,.18);transition:transform .15s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}.admin-sidebar .rail-icon-btn:hover{background:linear-gradient(180deg,#17233c,#101a30);border-color:#466189;color:#f8fbff;box-shadow:0 8px 18px rgba(2,6,23,.2);transform:translateY(-1px)}.admin-sidebar .rail-icon-btn.active{background:linear-gradient(180deg,#1f4fd1,#173a9c);border-color:#8fb4ff;color:#fff;box-shadow:0 10px 22px rgba(30,64,175,.38)}.admin-sidebar .rail-icon-btn.active .rail-icon{color:#fff}.admin-sidebar .rail-icon{width:20px;height:20px;stroke-linecap:round;stroke-linejoin:round}.admin-sidebar .rail-toggle{margin-bottom:4px;font-size:16px}.admin-sidebar .admin-flyout{display:none}.rail-submenu-popover{position:fixed;left:78px;z-index:200;background:#0f172a;border:1px solid #1e293b;border-radius:10px;box-shadow:6px 8px 32px rgba(2,6,23,.55);padding:6px;min-width:186px;display:flex;flex-direction:column;gap:2px}.rail-submenu-popover:before{content:"";position:absolute;left:-7px;top:14px;width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-right:7px solid #1e293b}.rail-submenu-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#64748b;padding:4px 10px 6px;margin:0;border-bottom:1px solid #1e293b}.rail-submenu-item{display:block;padding:8px 12px;border-radius:7px;color:#cbd5e1;font-size:13px;font-weight:500;text-decoration:none;transition:background .12s}.rail-submenu-item:hover{background:#1e293b;color:#fff}.rail-submenu-item.active{background:#1e40af;color:#fff}@media (max-width:980px){.shell.admin-shell{grid-template-columns:1fr}.admin-sidebar{display:none}}.main{padding:24px}.topbar{background:#fff;border:1px solid #dde3ec;border-radius:12px;display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding:12px 14px;min-height:66px}.topbar-brand-wrap{display:flex;flex-direction:column;gap:2px}.topbar-product-branding{display:flex;align-items:center;gap:10px}.topbar-product-logo{width:36px;height:36px;border-radius:10px;border:1px solid #1e3a8a;background:#fff;object-fit:cover}.topbar-branding{display:flex;align-items:center;gap:10px}.topbar-logo{width:34px;height:34px;border-radius:8px;object-fit:cover;border:1px solid #c5cfdb;background:#fff}.topbar-logo-fallback{width:34px;height:34px;border-radius:8px;border:1px solid #1e293b;background:#0f172a;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.topbar-brand{font-size:16px;font-weight:700;color:#0f172a;letter-spacing:.02em}.topbar-company{font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.topbar-meta{display:flex;align-items:center;gap:10px}.topbar-meta .topbar-company{text-transform:none;letter-spacing:0;font-size:13px;color:#0f172a;font-weight:700}.card{background:#fff;border:1px solid #dde3ec;border-radius:12px;padding:16px;margin-bottom:16px}.card h2{margin-top:0}.grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}.input,.select,.textarea{width:100%;border:1px solid #c5cfdb;border-radius:8px;padding:10px;font-size:14px}.textarea{min-height:140px;font-family:Consolas,monospace}.actions{display:flex;gap:8px;margin-top:10px}.button{border:0;background:#2563eb;color:#fff;padding:10px 14px;border-radius:8px;cursor:pointer}.button.secondary{background:#64748b}.button.refresh-btn{background:#fff;color:#0f172a;border:1px solid #cbd5e1;box-shadow:0 4px 12px rgba(15,23,42,.08);border-radius:10px;font-weight:600;transition:transform .15s ease,box-shadow .2s ease,background .2s ease}.button.refresh-btn:hover{background:#f8fafc;box-shadow:0 8px 20px rgba(15,23,42,.14);transform:translateY(-1px)}.button.refresh-btn:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:0 2px 8px rgba(15,23,42,.06)}.button.refresh-icon-btn{background:#fff;color:#0f172a;border:1px solid #cbd5e1;width:40px;height:40px;padding:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:18px;line-height:1;box-shadow:0 4px 12px rgba(15,23,42,.08);transition:transform .15s ease,box-shadow .2s ease,background .2s ease}.button.refresh-icon-btn:hover{background:#f8fafc;box-shadow:0 8px 20px rgba(15,23,42,.14);transform:translateY(-1px)}.button.refresh-icon-btn:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:0 2px 8px rgba(15,23,42,.06)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes icon-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.icon-spin{animation:icon-spin .9s linear infinite}.button.topbar-logout-btn{background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff;border:1px solid #1e293b;border-radius:10px;font-weight:600;box-shadow:0 6px 16px rgba(15,23,42,.24);transition:transform .15s ease,box-shadow .2s ease,filter .2s ease}.button.topbar-logout-btn:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(15,23,42,.3);filter:brightness(1.05)}.output{background:#0b1020;color:#d8e0f2;padding:12px;font-family:Consolas,monospace;white-space:pre-wrap;min-height:120px}.output,.toast{border-radius:8px}.toast{position:-webkit-sticky;position:sticky;top:1rem;z-index:30;margin-bottom:1rem;padding:.75rem 1rem;font-weight:600;border:1px solid}.toast.success{border-color:#dde3ec;border-left:4px solid #2563eb}.toast.error,.toast.success{background:#fff;color:#182230}.toast.error{border-color:#c5cfdb;border-left:4px solid #64748b}.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:12px;gap:12px}.kpi{background:#fff;border:1px solid #dde3ec;border-radius:10px;padding:14px;transition:box-shadow .2s}.kpi.kpi-green{background:#e6f9ec;border-color:#34c759;color:#1a7f37}.kpi.kpi-orange{background:#fff7e6;border-color:#ff9500;color:#b26a00}.kpi.kpi-red{background:#ffe6e6;border-color:#ff3b30;color:#b22222}.kpi.kpi-blue{background:#e6f0ff;border-color:#2563eb;color:#1e40af}.kpi strong{display:block;font-size:22px;margin-top:6px}.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px}.page-head h1{margin:0 0 6px}.page-head p{margin:0;color:#64748b}.list{margin:0;padding-left:18px;display:grid;grid-gap:8px;gap:8px}.table-wrap{width:100%;overflow:auto}.table{width:100%;border-collapse:collapse;min-width:860px}.table td,.table th{border-bottom:1px solid #dde3ec;text-align:left;padding:10px 8px;font-size:14px}.table th{font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.03em}.status-chip{display:inline-block;border:1px solid #c5cfdb;border-radius:999px;padding:2px 10px;font-size:12px;background:#fff}.tab-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.tab-btn{border:1px solid #c5cfdb;border-radius:10px;background:#fff;color:#1f2937;padding:8px 12px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.tab-btn:hover{background:#f8fafc;border-color:#93c5fd}.tab-btn.active{background:#1d4ed8;border-color:#1d4ed8;color:#fff}.invoice-link-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:1px solid #dde3ec;border-radius:6px;padding:3px 8px;cursor:pointer;font-size:12px;color:#1a56db;transition:background .12s,border-color .12s;text-align:left;white-space:nowrap}.invoice-link-btn:hover{background:#eff6ff;border-color:#93c5fd}.inv-type-badge{font-size:10px;font-weight:700;padding:1px 5px;border-radius:4px;letter-spacing:.04em}.inv-type-badge.pi{background:#fef3c7;color:#92400e}.inv-type-badge.pi.paid{background:#d1fae5;color:#065f46}.inv-type-badge.ti{background:#dbeafe;color:#1e40af}.inv-type-badge.qt{background:#ede9fe;color:#5b21b6}.inv-no{color:#374151;font-weight:600}.inv-status{color:#6b7280;font-size:11px}.inv-status.paid{color:#059669;font-weight:600}.inv-register-link{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:12px;color:#6b7280;background:none;border:none;border-radius:3px;line-height:1;flex-shrink:0;cursor:pointer;padding:0;transition:color .15s,background .15s}.inv-register-link:hover{color:#2563eb;background:#eff6ff}tr.row-selected td{background:#eff6ff!important}tr.row-selected{outline:2px solid #2563eb;outline-offset:-1px}.login-wrap{min-height:calc(100vh - 48px);display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 18% 22%,#2457cf 0,#153b97 45%,#0f2f86 100%)}.login-shell{width:min(1080px,100%);min-height:620px;border-radius:22px;overflow:hidden;display:grid;grid-template-columns:1.2fr .9fr;box-shadow:0 30px 70px rgba(4,20,56,.42);border:1px solid hsla(0,0%,100%,.16);background:#fff}.login-visual{position:relative;padding:42px;background:linear-gradient(150deg,#f8fbff,#eaf1ff 54%,#d8e6ff);display:flex;flex-direction:column;justify-content:space-between}.login-logo-chip{display:inline-flex;align-items:center;gap:12px;width:-moz-fit-content;width:fit-content;border-radius:14px;border:1px solid #cddbf7;background:hsla(0,0%,100%,.88);padding:10px 14px}.login-logo-chip img{width:34px;height:34px;border-radius:10px;border:1px solid #a9c2f0}.login-logo-chip strong{display:block;color:#123a8e;font-size:17px;line-height:1.1}.login-logo-chip span{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#4b6da9}.login-visual-copy{max-width:440px;z-index:2}.login-visual-copy h2{margin:0 0 12px;font-size:38px;line-height:1.12;color:#123a8e}.login-visual-copy p{margin:0;font-size:17px;color:#35568f}.login-orb{position:absolute;border-radius:999px}.login-orb-a{width:220px;height:220px;right:-60px;bottom:-60px;background:radial-gradient(circle,rgba(39,105,238,.48) 0,rgba(39,105,238,.04) 72%,transparent 100%)}.login-orb-b{width:150px;height:150px;left:-48px;top:120px;background:radial-gradient(circle,rgba(84,154,255,.42) 0,rgba(84,154,255,.04) 70%,transparent 100%)}.login-orb-c{width:86px;height:86px;right:110px;top:110px;background:radial-gradient(circle,rgba(15,80,217,.34) 0,rgba(15,80,217,.06) 74%,transparent 100%)}.login-panel{padding:46px 40px;background:linear-gradient(180deg,#eef3fb,#e4edf9);display:flex;flex-direction:column;justify-content:center}.login-head h1{margin:0;font-size:38px;color:#123a8e}.login-head p{margin:10px 0 0;color:#4a638f}.login-form{margin-top:24px}.login-form .input{border-color:#c5d3e8;background:#f8fbff}.login-form .input:focus{outline:none;border-color:#4d79d7;box-shadow:0 0 0 3px rgba(77,121,215,.15)}.login-actions .button{min-width:132px}@media (max-width:980px){.login-shell{grid-template-columns:1fr;min-height:auto}.login-visual{min-height:250px;padding:28px}.login-visual-copy h2{font-size:30px}.login-panel{padding:30px 24px}}