*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;color:#1e293b;line-height:1.6}#root{min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.flex{display:flex}.flex-column{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.space-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media (min-width: 768px){.md-grid-cols-2{grid-template-columns:repeat(2,1fr)}.md-grid-cols-3{grid-template-columns:repeat(3,1fr)}.md-grid-cols-4{grid-template-columns:repeat(4,1fr)}}@media (min-width: 1024px){.lg-grid-cols-3{grid-template-columns:repeat(3,1fr)}.lg-grid-cols-4{grid-template-columns:repeat(4,1fr)}}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.m-4{margin:1rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.ml-4{margin-left:1rem}.text-white{color:#fff}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-gray-700{color:#374151}.text-gray-900{color:#111827}.text-blue-600{color:#2563eb}.text-blue-700{color:#1d4ed8}.text-green-600{color:#16a34a}.text-green-800{color:#166534}.text-red-600{color:#dc2626}.text-red-700{color:#b91c1c}.text-red-800{color:#991b1b}.text-yellow-600{color:#ca8a04}.text-yellow-800{color:#854d0e}.bg-white{background-color:#fff}.bg-gray-50{background-color:#f9fafb}.bg-gray-100{background-color:#f3f4f6}.bg-gray-200{background-color:#e5e7eb}.bg-blue-50{background-color:#eff6ff}.bg-blue-100{background-color:#dbeafe}.bg-blue-500{background-color:#3b82f6}.bg-blue-600{background-color:#2563eb}.bg-blue-700{background-color:#1d4ed8}.bg-green-100{background-color:#dcfce7}.bg-green-500{background-color:#22c55e}.bg-green-600{background-color:#16a34a}.bg-red-100{background-color:#fee2e2}.bg-yellow-100{background-color:#fef3c7}.bg-yellow-500{background-color:#eab308}.bg-purple-500{background-color:#a855f7}.bg-purple-600{background-color:#9333ea}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.text-center{text-align:center}.text-right{text-align:right}.border{border:1px solid #e5e7eb}.border-gray-200{border-color:#e5e7eb}.border-gray-300{border-color:#d1d5db}.border-b{border-bottom:1px solid #e5e7eb}.border-t{border-top:1px solid #e5e7eb}.rounded{border-radius:.25rem}.rounded-md{border-radius:.375rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 1px 2px #0000000d}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.w-full{width:100%}.w-64{width:16rem}.w-8{width:2rem}.w-6{width:1.5rem}.w-5{width:1.25rem}.w-4{width:1rem}.h-full{height:100%}.h-screen{height:100vh}.h-16{height:4rem}.h-12{width:3rem;height:3rem}.h-8{width:2rem;height:2rem}.h-6{width:1.5rem;height:1.5rem}.h-5{width:1.25rem;height:1.25rem}.h-4{width:1rem;height:1rem}.min-h-screen{min-height:100vh}.min-w-0{min-width:0}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.inset-0{top:0;right:0;bottom:0;left:0}.inset-y-0{top:0;bottom:0}.left-0{left:0}.right-0{right:0}.top-0{top:0}.bottom-0{bottom:0}.z-40{z-index:40}.z-50{z-index:50}.flex-1{flex:1 1 0%}.flex-col{flex-direction:column}.hidden{display:none}.block{display:block}.inline-flex{display:inline-flex}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transform{transform:var(--transform-rotate) var(--transform-scale) var(--transform-translate)}.translate-x-0{--transform-translate-x: 0px;transform:translate(var(--transform-translate-x))}.-translate-x-full{--transform-translate-x: -100%;transform:translate(var(--transform-translate-x))}.-translate-y-1\/2{--transform-translate-y: -50%;transform:translateY(var(--transform-translate-y))}.transition-colors{transition-property:color,background-color,border-color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.hover\:bg-gray-50:hover{background-color:#f9fafb}.hover\:bg-gray-100:hover{background-color:#f3f4f6}.hover\:bg-gray-200:hover{background-color:#e5e7eb}.hover\:bg-blue-700:hover{background-color:#1d4ed8}.hover\:bg-green-700:hover{background-color:#15803d}.hover\:bg-red-50:hover{background-color:#fef2f2}.hover\:text-blue-600:hover{color:#2563eb}.hover\:text-blue-800:hover{color:#1e40af}.hover\:text-green-600:hover{color:#16a34a}.hover\:text-red-600:hover{color:#dc2626}.hover\:text-gray-600:hover{color:#4b5563}.hover\:text-gray-700:hover{color:#374151}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--ring-offset-shadow: var(--ring-inset) 0 0 0 var(--ring-offset-width) var(--ring-offset-color);--ring-shadow: var(--ring-inset) 0 0 0 calc(2px + var(--ring-offset-width)) var(--ring-color);box-shadow:var(--ring-offset-shadow),var(--ring-shadow),var(--shadow, 0 0 #0000)}.focus\:ring-blue-500:focus{--ring-color: #3b82f6}.focus\:border-blue-500:focus{border-color:#3b82f6}.btn{display:inline-flex;align-items:center;padding:.5rem 1rem;border-radius:.5rem;font-weight:500;font-size:.875rem;cursor:pointer;border:none;transition:all .2s;text-decoration:none}.btn-primary{background-color:#2563eb;color:#fff}.btn-primary:hover{background-color:#1d4ed8}.btn-secondary{background-color:#f3f4f6;color:#374151}.btn-secondary:hover{background-color:#e5e7eb}.input{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;line-height:1.25rem;background-color:#fff}.input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.select{width:100%;padding:.5rem 2.5rem .5rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;background-color:#fff;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em}.select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:.35rem .8rem;font-size:.875rem}.card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;border:1px solid #e5e7eb}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-green{background-color:#dcfce7;color:#166534}.badge-yellow{background-color:#fef3c7;color:#854d0e}.badge-red{background-color:#fee2e2;color:#991b1b}.badge-blue{background-color:#dbeafe;color:#1e40af}@media (max-width: 768px){.md-hidden{display:none}.container{padding:0 .5rem}}@media (min-width: 768px){.md-flex{display:flex}.md-block{display:block}.md-hidden{display:none}}@media (min-width: 1024px){.lg-static{position:static}.lg-translate-x-0{transform:translate(0)}.lg-block{display:block}.lg-hidden{display:none}}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.pointer-events-none{pointer-events:none}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.opacity-50{opacity:.5}.opacity-90{opacity:.9}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.saas-shell{min-height:100vh;display:flex;background:#f6f8fb;color:#0f172a}.saas-sidebar{position:fixed;inset:0 auto 0 0;z-index:50;width:274px;background:linear-gradient(180deg,#051e3d,#021526);color:#e8f2ff;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.08);box-shadow:20px 0 50px #0f172a29}.saas-brand{min-height:120px;padding:18px 20px;display:flex;align-items:center;justify-content:center;gap:10px}.brand-logo{display:block;width:min(190px,100%);height:auto;border-radius:10px;background:#fff;box-shadow:0 18px 35px #02061738}.sidebar-close{display:none;margin-left:auto;flex:0 0 auto;color:#fff;background:transparent;border:0}.saas-nav{flex:1;min-height:0;overflow-y:auto;padding:0 16px 18px}.nav-group{margin-bottom:24px}.nav-group p{margin:8px 8px 10px;font-size:.72rem;color:#6f8bab;font-weight:800;text-transform:uppercase}.nav-link{width:100%;display:flex;align-items:center;gap:12px;min-height:48px;padding:0 14px;margin-bottom:8px;border-radius:9px;color:#d9e8fa;text-decoration:none;font-size:.92rem;font-weight:700;transition:background .18s,color .18s,transform .18s}.nav-link:hover{background:#ffffff14;transform:translate(2px)}.nav-link.active{color:#fff;background:linear-gradient(135deg,#0b63df,#0b45b5);box-shadow:0 15px 25px #0646ac59}.nav-link span{flex:1}.nav-chevron{opacity:.45}.quick-panel{flex:0 0 auto;margin:0 16px 18px;padding:16px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff0a}.quick-panel h4{margin:0 0 12px;font-size:.9rem}.quick-link{height:42px;display:flex;align-items:center;gap:10px;padding:0 12px;margin-bottom:8px;border-radius:8px;background:#ffffff0f;color:#eef6ff;text-decoration:none;font-size:.82rem;font-weight:700}.sidebar-version{flex:0 0 auto;padding:0 22px 22px;color:#7892ae;font-size:.75rem}.saas-main{flex:1;min-width:0;margin-left:274px}.saas-topbar{height:86px;position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:16px;padding:0 24px;background:#ffffffeb;border-bottom:1px solid #e6ebf3;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.topbar-search{flex:1 1 360px;max-width:520px;min-width:260px;height:52px;display:flex;align-items:center;gap:12px;padding:0 14px;border:1px solid #e3e8f1;border-radius:10px;background:#fff;box-shadow:0 10px 30px #0f172a0a}.topbar-search input{flex:1;min-width:0;border:0;outline:0;color:#0f172a}.topbar-search kbd{padding:5px 9px;border-radius:6px;background:#f2f5fa;color:#334155;font-size:.72rem;font-weight:800}.tenant-picker,.date-pill,.topbar-user{height:52px;flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:0 14px;border:1px solid #e3e8f1;border-radius:10px;background:#fff}.tenant-picker select{border:0;outline:0;min-width:220px;max-width:270px;color:#0f172a;font-weight:800;background:transparent}.date-pill span{font-size:.9rem;font-weight:800;white-space:nowrap}.date-pill{min-width:190px;justify-content:center}.topbar-icon{width:52px;height:52px;display:grid;place-items:center;border:1px solid #e3e8f1;border-radius:10px;background:#fff;color:#0f172a}.notification{position:relative}.notification span{position:absolute;top:-7px;right:-6px;min-width:20px;height:20px;display:grid;place-items:center;border-radius:99px;color:#fff;background:#ef233c;font-size:.72rem;font-weight:800}.topbar-user{padding-right:8px}.topbar-user .user-avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#eaf2ff,#b7d5ff);color:#052b61;font-weight:900}.topbar-user strong,.topbar-user span{display:block;white-space:nowrap}.topbar-user{min-width:224px}.topbar-user strong{font-size:.92rem}.topbar-user span{color:#64748b;font-size:.78rem}.topbar-user button{width:36px;height:36px;border:0;border-radius:8px;background:#f5f7fb;color:#0f172a}.saas-content{padding:28px 32px 44px}.mobile-menu{display:none}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#0206177a}@media (max-width: 1180px){.saas-sidebar{transform:translate(-100%);transition:transform .24s ease}.saas-sidebar.open{transform:translate(0)}.saas-main{margin-left:0}.mobile-menu,.sidebar-close{display:grid}.saas-topbar{padding:0 18px}.topbar-search kbd,.date-pill{display:none}}@media (max-width: 1500px){.saas-topbar{gap:12px;padding:0 18px}.topbar-search{max-width:420px}.tenant-picker select{min-width:180px;max-width:220px}.date-pill{min-width:168px;padding:0 12px}.topbar-user{min-width:198px}}@media (max-width: 760px){.saas-topbar{height:auto;min-height:78px;flex-wrap:wrap;padding:12px}.topbar-search{order:10;width:100%;max-width:none;flex-basis:100%}.tenant-picker{flex:1}.tenant-picker select{min-width:0;width:100%}.topbar-user div:not(.user-avatar){display:none}.saas-content{padding:20px 14px 32px}}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:22px}.page-head h1{margin:0 0 6px;color:#07142f;font-size:1.72rem;line-height:1.15}.page-head p{margin:0;color:#64748b}.head-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.btn{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:0 14px;border-radius:9px;border:1px solid #dbe4f0;background:#fff;color:#0f172a;font-weight:800;cursor:pointer}.btn-primary{border-color:#0b63df;background:#0b63df;color:#fff;box-shadow:0 12px 25px #0b63df33}.btn-danger{border-color:#fee2e2;background:#fff1f2;color:#be123c}.panel-card{border:1px solid #e4eaf3;border-radius:10px;background:#fff;box-shadow:0 14px 35px #0f172a0a}.stat-grid{display:grid;grid-template-columns:repeat(5,minmax(170px,1fr));gap:16px;margin-bottom:18px}.stat-tile{min-height:132px;padding:18px;border:1px solid #e4eaf3;border-radius:10px;background:#fff;box-shadow:0 14px 35px #0f172a0a}.stat-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}.stat-icon{width:45px;height:45px;display:grid;place-items:center;border-radius:50%;color:#fff}.stat-label{color:#334155;font-size:.84rem;font-weight:800}.stat-value{color:#07142f;font-size:1.65rem;font-weight:900;line-height:1.1}.stat-sub{margin-top:10px;color:#64748b;font-size:.8rem}.content-grid{display:grid;grid-template-columns:1.4fr 1fr .9fr;gap:16px;margin-bottom:16px}.panel-header{min-height:58px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 18px;border-bottom:1px solid #edf1f7}.panel-header h3{margin:0;color:#07142f;font-size:1rem}.panel-body{padding:18px}.bar-chart{height:226px;display:grid;grid-template-columns:repeat(7,1fr);align-items:end;gap:16px;padding-top:16px}.bar-item{min-width:0;text-align:center}.bar{min-height:8px;border-radius:8px 8px 3px 3px;background:linear-gradient(180deg,#5db3ff,#116be7);box-shadow:0 12px 26px #116be738}.bar-item span{display:block;margin-top:10px;color:#64748b;font-size:.78rem}.donut-wrap{display:grid;grid-template-columns:180px 1fr;gap:18px;align-items:center}.donut{width:170px;aspect-ratio:1;border-radius:50%;background:conic-gradient(#24b26b 0,#24b26b 40%,#3394f5 40%,#3394f5 70%,#ffab20 70%,#ffab20 90%,#ef334e 90%,#ef334e);position:relative}.donut:after{content:"";position:absolute;top:38px;right:38px;bottom:38px;left:38px;border-radius:50%;background:#fff}.legend-row,.quick-row,.movement-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 0;border-bottom:1px solid #eef2f7}.legend-row:last-child,.quick-row:last-child,.movement-row:last-child{border-bottom:0}.legend-dot{width:10px;height:10px;border-radius:50%}.muted{color:#64748b}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;min-width:760px}.data-table th,.data-table td{padding:14px 16px;border-bottom:1px solid #eef2f7;text-align:left;font-size:.88rem}.data-table th{color:#64748b;font-size:.72rem;text-transform:uppercase}.data-table td{color:#0f172a;font-weight:650}.badge{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:99px;font-size:.75rem;font-weight:900}.badge.active{background:#dcfce7;color:#15803d}.badge.suspended,.badge.inactive{background:#fff7ed;color:#c2410c}.badge.expired,.badge.deleted{background:#ffe4e6;color:#be123c}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-field{display:flex;flex-direction:column;gap:7px}.form-field.full{grid-column:1 / -1}.form-field label{color:#334155;font-size:.78rem;font-weight:900}.form-field input,.form-field select,.form-field textarea{min-height:42px;padding:0 12px;border:1px solid #dbe4f0;border-radius:8px;outline:0;color:#0f172a;background:#fff}.form-field textarea{min-height:78px;padding-top:10px}.modal-backdrop.saas-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;padding:20px;background:#0206178c}.modal-card{width:min(860px,100%);max-height:90vh;overflow:auto;background:#fff;border-radius:14px;box-shadow:0 30px 70px #0f172a3d}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid #edf1f7}.modal-head h3{margin:0}.modal-head button{border:0;background:#f3f6fb;border-radius:8px;width:36px;height:36px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px 20px}.empty-state{padding:42px 20px;text-align:center;color:#64748b}.empty-state strong{display:block;margin-bottom:6px;color:#0f172a}.module-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:16px}.module-card{padding:18px;border:1px solid #e4eaf3;border-radius:10px;background:#fff}.module-card strong{display:block;font-size:1.55rem;color:#07142f}.module-card span{color:#64748b;font-size:.83rem}.control-stats{grid-template-columns:repeat(5,minmax(160px,1fr))}.control-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.9fr);gap:16px;margin-bottom:16px}.action-row{width:100%;min-height:64px;display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:12px;padding:12px 0;border:0;border-bottom:1px solid #eef2f7;background:transparent;color:#0f172a;text-align:left;cursor:pointer}.action-row:last-child{border-bottom:0}.action-row svg{color:#ef334e}.action-row small{display:block;margin-top:3px;color:#64748b;font-weight:700}.limit-list{display:grid;gap:14px}.limit-card{padding:14px;border:1px solid #e4eaf3;border-radius:10px;background:#fbfdff}.limit-title,.limit-line-head{display:flex;align-items:center;justify-content:space-between;gap:14px}.limit-title{margin-bottom:12px}.limit-title span{color:#64748b;font-weight:900;text-transform:uppercase;font-size:.72rem}.limit-line{margin-top:10px}.limit-line-head{margin-bottom:7px;color:#64748b;font-size:.78rem;font-weight:850}.limit-line-head strong{color:#0f172a}.limit-track{height:9px;overflow:hidden;border-radius:99px;background:#e8eef7}.limit-track span{display:block;height:100%;border-radius:inherit;background:#1478f2}.limit-track span.warn{background:#ff9f1c}.limit-track span.danger{background:#ef334e}.control-table .btn{min-height:34px;padding:0 12px}.collection-strip{display:grid;grid-template-columns:repeat(9,minmax(120px,1fr));gap:10px;margin-top:16px}.collection-pill{min-height:74px;padding:12px;border:1px solid #e4eaf3;border-radius:10px;background:#fff}.collection-pill span{display:block;color:#64748b;font-size:.72rem;font-weight:900}.collection-pill strong{display:block;margin-top:8px;color:#07142f;font-size:1.2rem}.error-box{margin-bottom:16px;padding:12px 14px;border:1px solid #fecdd3;border-radius:9px;background:#fff1f2;color:#be123c;font-weight:800}@media (max-width: 1280px){.stat-grid{grid-template-columns:repeat(3,1fr)}.content-grid{grid-template-columns:1fr}.module-grid{grid-template-columns:repeat(2,1fr)}.control-grid{grid-template-columns:1fr}.collection-strip{grid-template-columns:repeat(3,1fr)}}@media (max-width: 720px){.page-head{flex-direction:column}.stat-grid,.module-grid,.form-grid,.donut-wrap{grid-template-columns:1fr}.collection-strip{grid-template-columns:repeat(2,1fr)}.action-row{grid-template-columns:24px 1fr}.action-row .badge{grid-column:2;width:fit-content}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:#eaf0ff;padding:24px}.login-background{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 0% 12%,rgba(255,255,255,.34) 0 18%,transparent 19%),radial-gradient(circle at 93% 82%,rgba(103,128,255,.13) 0 21%,transparent 22%),linear-gradient(135deg,#e8efff,#cdd8ff);opacity:1}.login-background:before,.login-background:after{content:"";position:absolute;width:540px;height:540px;background:linear-gradient(135deg,#ffffff38,#5f75ff08);border-radius:50%;animation:float 25s ease-in-out infinite;z-index:0}.login-background:before{top:-10%;left:-20%}.login-background:after{bottom:-15%;right:-15%;animation-delay:-10s}@keyframes float{0%{transform:translateY(0) translate(0) rotate(0)}33%{transform:translateY(-20px) translate(15px) rotate(15deg)}66%{transform:translateY(10px) translate(-20px) rotate(-20deg)}to{transform:translateY(0) translate(0) rotate(0)}}.login-content{position:relative;z-index:1;width:100%;max-width:520px}.login-card{background:#fffffff5;border-radius:24px;padding:54px 56px 42px;box-shadow:0 28px 70px #20347029;border:1px solid rgba(255,255,255,.88)}.login-header{text-align:center;margin-bottom:30px}.logo-container{margin-bottom:30px}.logo-image{width:min(260px,86%);height:auto;border-radius:14px}.login-title{color:#111b33;font-size:clamp(2rem,4vw,2.8rem);line-height:1.24;font-weight:800;margin:0 0 18px;letter-spacing:0}.login-subtitle{color:#6b7b95;font-size:1.08rem;margin:0}.login-form{display:flex;flex-direction:column;gap:24px}.form-fields{display:flex;flex-direction:column;gap:14px}.login-form .form-group{display:flex;flex-direction:column;gap:8px}.error-message{display:flex;align-items:center;gap:.75rem;padding:.875rem;background:#fee2e2;border:1px solid #fecaca;border-radius:12px;color:#b91c1c;font-size:.875rem;font-weight:500}.form-label{font-size:.96rem;font-weight:800;color:#2f3d56}.input-container{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#94a3b8;pointer-events:none}.form-input{width:100%;height:58px;padding:0 48px 0 16px;border:1px solid #c7d2e3;border-radius:12px;font-size:1rem;background:#fff;color:#1e293b;transition:all .2s ease;outline:none;box-shadow:inset 0 0 0 1px #ffffff73}.form-input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.form-input::placeholder{color:#94a3b8}.password-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:34px;height:34px;display:grid;place-items:center;background:transparent;border:none;border-radius:8px;cursor:pointer;color:#94a3b8;padding:0}.password-toggle:hover{color:#2563eb;background:#f1f5ff}.login-button{width:100%;height:56px;display:inline-flex;align-items:center;justify-content:center;gap:10px;border:0;border-radius:12px;background:linear-gradient(135deg,#146df5,#0b45c4);color:#fff;font-size:1rem;font-weight:900;cursor:pointer;box-shadow:0 18px 35px #146df547;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease;-moz-appearance:none;appearance:none;-webkit-appearance:none}.login-button:hover:not(.loading){transform:translateY(-2px);box-shadow:0 22px 42px #146df557}.login-button:disabled{cursor:not-allowed;opacity:.72}.loading-content{display:inline-flex;align-items:center;gap:10px}.loading-content .spinner{width:18px;height:18px;border-width:2px;border-color:#ffffff6b;border-top-color:#fff}.demo-info{background:#f8fafc;border:1px solid #e2e8f0}.demo-info h4{color:#334155}.demo-credentials p{color:#64748b}.demo-credentials strong{color:#1e293b}.login-footer p{color:#94a3b8;margin:22px 0 0;text-align:center;font-size:.95rem}@media (max-width: 480px){.login-card{padding:34px 22px 28px;border-radius:20px}.logo-image{width:min(220px,88%)}.login-title{font-size:1.9rem}}.app{min-height:100vh}.auth-blocked{min-height:100vh;display:grid;place-items:center;padding:24px;background:#f6f8fb}.auth-blocked-card{width:min(520px,100%);padding:32px;border:1px solid #e4eaf3;border-radius:14px;background:#fff;box-shadow:0 20px 55px #0f172a14}.auth-blocked-card h1{margin:0 0 12px;color:#07142f}.auth-blocked-card p{color:#475569;line-height:1.6}
