@import url("https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=Inter:wght@400;500;600&display=swap");:root{--bg:#f5f6fa;--card:#fff;--card-2:#f9fafb;--border:#e4e7ef;--border-2:#d1d5e0;--text-1:#111827;--text-2:#374151;--text-3:#6b7280;--text-4:#9ca3af;--teal:#0d9488;--teal-light:#14b8a6;--teal-bg:#f0fdfa;--teal-bd:#99f6e4;--green:#16a34a;--green-bg:#f0fdf4;--green-bd:#bbf7d0;--yellow:#d97706;--yellow-bg:#fffbeb;--yellow-bd:#fde68a;--red:#dc2626;--red-bg:#fef2f2;--red-bd:#fecaca;--blue:#2563eb;--blue-bg:#eff6ff;--blue-bd:#bfdbfe;--purple:#7c3aed;--purple-bg:#f5f3ff;--purple-bd:#ddd6fe;--ff-head:"Outfit",sans-serif;--ff-body:"Inter",sans-serif;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-2xl:24px;--shadow-sm:0 1px 3px rgba(17,24,39,.06),0 1px 2px rgba(17,24,39,.04);--shadow:0 4px 12px rgba(17,24,39,.08),0 1px 3px rgba(17,24,39,.05);--shadow-md:0 8px 24px rgba(17,24,39,.1),0 2px 6px rgba(17,24,39,.06);--shadow-lg:0 20px 48px rgba(17,24,39,.12),0 4px 12px rgba(17,24,39,.07);--sidebar-w:264px;--topbar-h:64px}[data-theme=dark]{--bg:#0f172a;--card:#1e293b;--card-2:#253047;--border:hsla(0,0%,100%,.08);--border-2:hsla(0,0%,100%,.12);--text-1:#f1f5f9;--text-2:#cbd5e1;--text-3:#94a3b8;--text-4:#64748b;--teal-bg:rgba(13,148,136,.12);--teal-bd:rgba(13,148,136,.3);--green-bg:rgba(22,163,74,.1);--green-bd:rgba(22,163,74,.3);--yellow-bg:rgba(217,119,6,.1);--yellow-bd:rgba(217,119,6,.3);--red-bg:rgba(220,38,38,.1);--red-bd:rgba(220,38,38,.3);--blue-bg:rgba(37,99,235,.1);--blue-bd:rgba(37,99,235,.3);--purple-bg:rgba(124,58,237,.1);--purple-bd:rgba(124,58,237,.3);--shadow-sm:0 1px 3px rgba(0,0,0,.2);--shadow:0 4px 12px rgba(0,0,0,.25);--shadow-md:0 8px 24px rgba(0,0,0,.3)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--ff-body);background:var(--bg);color:var(--text-2);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;transition:background .25s,color .25s}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}img{max-width:100%;display:block}.app-layout{display:flex;min-height:100vh}.app-main{margin-left:var(--sidebar-w);flex:1 1}.app-main,.sidebar{display:flex;flex-direction:column;min-height:100vh}.sidebar{width:var(--sidebar-w);position:fixed;top:0;left:0;background:var(--card);border-right:1px solid var(--border);z-index:300;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s}.sidebar-logo{height:var(--topbar-h);display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-5);border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-logo img{height:32px;width:auto}.sidebar-logo .logo-name{font-family:var(--ff-head);font-size:var(--text-xl);font-weight:800;color:var(--teal);letter-spacing:-.02em}.sidebar-nav{flex:1 1;padding:var(--space-4) var(--space-3);overflow-y:auto;overflow-x:hidden}.nav-group{margin-bottom:var(--space-5)}.nav-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-4);padding:0 var(--space-3);margin-bottom:var(--space-2)}.nav-link{display:flex;align-items:center;gap:var(--space-3);padding:10px var(--space-3);border-radius:var(--r-md);color:var(--text-3);font-size:var(--text-sm);font-weight:500;transition:all .15s ease;position:relative;margin-bottom:2px}.nav-link:hover{background:var(--bg);color:var(--text-2)}.nav-link.active{background:var(--teal-bg);color:var(--teal);font-weight:600}.nav-link .nav-ico{width:32px;height:32px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;background:transparent;transition:background .15s}.nav-link:hover .nav-ico{background:var(--border)}.nav-link.active .nav-ico{background:var(--teal-bg)}.nav-link .nav-txt{flex:1 1;line-height:1}.nav-chip{font-size:10px;font-weight:700;background:var(--teal);color:#fff;padding:2px 7px;border-radius:20px}.sidebar-user{padding:var(--space-3);border-top:1px solid var(--border);flex-shrink:0}.user-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--r-md);cursor:pointer;transition:background .15s}.user-row:hover{background:var(--bg)}.user-row .u-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--teal-bd);flex-shrink:0}.user-row .u-name{font-size:var(--text-sm);font-weight:600;color:var(--text-1);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-row .u-role{font-size:11px;color:var(--text-4)}.user-row .u-info{flex:1 1;min-width:0}.user-row .u-dots{color:var(--text-4);font-size:12px}.topbar{height:var(--topbar-h);background:var(--card);border-bottom:1px solid var(--border);gap:var(--space-4);padding:0 var(--space-8);position:-webkit-sticky;position:sticky;top:0;z-index:200;flex-shrink:0}.topbar,.topbar-left{display:flex;align-items:center}.topbar-left{gap:var(--space-3);flex:1 1;min-width:0}.topbar-right{display:flex;align-items:center;gap:var(--space-2)}.page-title{font-family:var(--ff-head);font-size:var(--text-xl);font-weight:700;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-breadcrumb{font-size:var(--text-sm);color:var(--text-4);white-space:nowrap}.topbar-btn{width:38px;height:38px;border-radius:var(--r-md);border:1px solid var(--border);background:transparent;color:var(--text-3);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px;position:relative;transition:all .15s}.topbar-btn:hover{background:var(--bg);color:var(--text-2);border-color:var(--border-2)}.topbar-btn .dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:var(--red);border-radius:50%;border:2px solid var(--card)}.ham-btn{display:none}.page-body{padding:var(--space-8);flex:1 1}.section-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.section-hd h2{font-family:var(--ff-head);font-size:var(--text-lg);font-weight:700;color:var(--text-1)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm)}.card-pad{padding:var(--space-6)}.card-pad-lg{padding:var(--space-8)}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--space-5) var(--space-6);display:flex;align-items:center;gap:var(--space-4);box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.stat-ico{width:48px;height:48px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.stat-ico.teal{background:var(--teal-bg);color:var(--teal)}.stat-ico.green{background:var(--green-bg);color:var(--green)}.stat-ico.red{background:var(--red-bg);color:var(--red)}.stat-ico.blue{background:var(--blue-bg);color:var(--blue)}.stat-ico.yellow{background:var(--yellow-bg);color:var(--yellow)}.stat-ico.purple{background:var(--purple-bg);color:var(--purple)}.stat-body{flex:1 1;min-width:0}.stat-label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:3px}.stat-val{font-family:var(--ff-head);font-size:var(--text-2xl);font-weight:800;color:var(--text-1);line-height:1.1}.stat-sub{font-size:var(--text-xs);color:var(--text-4);margin-top:3px;display:flex;align-items:center;gap:4px}.stat-sub.up{color:var(--green)}.stat-sub.down{color:var(--red)}.g2{grid-template-columns:1fr 1fr;grid-gap:var(--space-6);gap:var(--space-6)}.g2,.g3{display:grid}.g3{grid-template-columns:repeat(3,1fr);grid-gap:var(--space-5);gap:var(--space-5)}.g4{grid-template-columns:repeat(4,1fr);grid-gap:var(--space-4)}.g-stats,.g4{display:grid;gap:var(--space-4)}.g-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:var(--space-4)}.field{margin-bottom:var(--space-5)}.field label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--text-2);margin-bottom:var(--space-2)}.field .hint{font-size:var(--text-xs);color:var(--text-4);margin-top:var(--space-1)}.ctrl{display:block;width:100%;padding:11px 14px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-md);color:var(--text-1);font-size:var(--text-base);transition:border-color .15s,box-shadow .15s,background .15s;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}.ctrl:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-bg);background:var(--card)}.ctrl::placeholder{color:var(--text-4)}.ctrl.is-err{border-color:var(--red);box-shadow:0 0 0 3px var(--red-bg)}.ctrl-icon{position:relative}.ctrl-icon .ctrl{padding-left:40px}.ctrl-icon .ico{left:13px;pointer-events:none}.ctrl-icon .eye,.ctrl-icon .ico{position:absolute;top:50%;transform:translateY(-50%);color:var(--text-4);font-size:14px}.ctrl-icon .eye{right:12px;background:none;border:none;cursor:pointer;padding:2px;transition:color .15s}.ctrl-icon .eye:hover{color:var(--text-2)}.field-err{font-size:var(--text-xs);font-weight:600;color:var(--red);margin-top:var(--space-1);display:flex;align-items:center;gap:4px}select.ctrl{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}select.ctrl option{background:var(--card);color:var(--text-1)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px 20px;border-radius:var(--r-md);border:1.5px solid transparent;font-family:var(--ff-body);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap;text-decoration:none;line-height:1}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--teal);color:#fff;border-color:var(--teal);box-shadow:0 2px 8px rgba(13,148,136,.25)}.btn-primary:hover:not(:disabled){background:var(--teal-light);border-color:var(--teal-light);box-shadow:0 4px 14px rgba(13,148,136,.35);transform:translateY(-1px)}.btn-outline{background:transparent;border-color:var(--border-2);color:var(--text-2)}.btn-outline:hover:not(:disabled){border-color:var(--teal);color:var(--teal);background:var(--teal-bg)}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-3)}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text-2)}.btn-danger{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}.btn-danger:hover:not(:disabled){background:var(--red-bd)}.btn-sm{padding:7px 14px;font-size:12px}.btn-lg{padding:13px 28px;font-size:var(--text-base)}.btn-xl{padding:15px 36px;font-size:var(--text-lg)}.btn-block{width:100%}.btn-loading{opacity:.7;pointer-events:none}.btn-loading:after{content:"";width:14px;height:14px;border:2px solid hsla(0,0%,100%,.4);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-left:4px}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-4);border-radius:var(--r-lg);border:1px solid;font-size:var(--text-sm);margin-bottom:var(--space-5)}.alert i{font-size:16px;flex-shrink:0;margin-top:1px}.alert-success{background:var(--green-bg);border-color:var(--green-bd);color:#166534}.alert-error{background:var(--red-bg);border-color:var(--red-bd);color:#991b1b}.alert-warning{background:var(--yellow-bg);border-color:var(--yellow-bd);color:#92400e}.alert-info{background:var(--blue-bg);border-color:var(--blue-bd);color:#1e40af}[data-theme=dark] .alert-success{color:#86efac}[data-theme=dark] .alert-error{color:#fca5a5}[data-theme=dark] .alert-warning{color:#fde68a}[data-theme=dark] .alert-info{color:#93c5fd}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700}.badge-green{background:var(--green-bg);color:var(--green)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-yellow{background:var(--yellow-bg);color:var(--yellow)}.badge-blue{background:var(--blue-bg);color:var(--blue)}.badge-teal{background:var(--teal-bg);color:var(--teal)}.badge-purple{background:var(--purple-bg);color:var(--purple)}.badge-gray{background:var(--bg);color:var(--text-3)}.progress-track{height:8px;background:var(--bg);border-radius:99px;overflow:hidden}.progress-fill{height:100%;border-radius:99px;transition:width .5s cubic-bezier(.4,0,.2,1)}.progress-fill.safe{background:var(--green)}.progress-fill.warn{background:var(--yellow)}.progress-fill.danger{background:var(--red)}.progress-fill.teal{background:var(--teal)}.tbl{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.tbl th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);background:var(--card-2);white-space:nowrap}.tbl td,.tbl th{border-bottom:1px solid var(--border)}.tbl td{padding:13px 14px;color:var(--text-2);vertical-align:middle}.tbl tr:last-child td{border-bottom:none}.tbl tbody tr:hover td{background:var(--card-2)}.tbl-wrap{overflow-x:auto;border-radius:var(--r-xl);border:1px solid var(--border)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) 0;border-bottom:1px solid var(--border)}.toggle-row:last-child{border-bottom:none}.toggle-title{font-size:var(--text-sm);font-weight:600;color:var(--text-1)}.toggle-desc{font-size:var(--text-xs);color:var(--text-3);margin-top:2px}.switch{position:relative;width:44px;height:24px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.switch-track{position:absolute;inset:0;background:var(--border-2);border-radius:99px;cursor:pointer;transition:.2s}.switch-track:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}.switch input:checked+.switch-track{background:var(--teal)}.switch input:checked+.switch-track:before{transform:translateX(20px)}.overlay{position:fixed;inset:0;background:rgba(17,24,39,.45);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:500;display:flex;align-items:center;justify-content:center;padding:var(--space-4);opacity:0;pointer-events:none;transition:opacity .2s}.overlay.open{opacity:1;pointer-events:all}.modal{background:var(--card);border:1px solid var(--border);border-radius:var(--r-2xl);max-width:520px;width:100%;padding:var(--space-8);box-shadow:var(--shadow-lg);transform:translateY(12px) scale(.98);transition:transform .25s cubic-bezier(.34,1.56,.64,1)}.overlay.open .modal{transform:translateY(0) scale(1)}.modal-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.modal-hd h3{font-family:var(--ff-head);font-size:var(--text-xl);font-weight:700;color:var(--text-1)}.modal-close{width:32px;height:32px;border-radius:var(--r-sm);border:1px solid var(--border);background:transparent;color:var(--text-3);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:var(--bg);color:var(--text-1)}#toasts{position:fixed;top:var(--space-5);right:var(--space-5);z-index:1000;display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none}.toast{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--space-4) var(--space-5);display:flex;align-items:center;gap:var(--space-3);min-width:260px;max-width:340px;box-shadow:var(--shadow-md);font-size:var(--text-sm);font-weight:500;transform:translateX(110%);transition:transform .3s cubic-bezier(.34,1.56,.64,1);pointer-events:all}.toast.in{transform:translateX(0)}.toast .t-ico{font-size:16px;flex-shrink:0}.toast-success .t-ico{color:var(--green)}.toast-error .t-ico{color:var(--red)}.toast-info .t-ico{color:var(--blue)}.toast .t-close{margin-left:auto;background:none;border:none;color:var(--text-4);cursor:pointer;font-size:13px;padding:2px}.search-box{position:relative;flex:1 1;max-width:320px}.search-box input{width:100%;padding:9px 14px 9px 36px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-md);color:var(--text-1);font-size:var(--text-sm);outline:none;transition:.15s}.search-box input:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-bg);background:var(--card)}.search-box .s-ico{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-4);font-size:13px;pointer-events:none}.chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.chip{padding:6px 14px;border-radius:99px;border:1.5px solid var(--border);background:var(--card);font-size:var(--text-xs);font-weight:600;color:var(--text-3);cursor:pointer;transition:.15s;white-space:nowrap}.chip:hover{border-color:var(--teal)}.chip.on,.chip:hover{color:var(--teal);background:var(--teal-bg)}.chip.on{border-color:var(--teal-bd)}.empty{text-align:center;padding:var(--space-12) var(--space-6)}.empty-ico{width:72px;height:72px;border-radius:50%;background:var(--card-2);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto var(--space-4)}.empty h3{font-family:var(--ff-head);font-size:var(--text-lg);font-weight:700;color:var(--text-1);margin-bottom:var(--space-2)}.empty p{font-size:var(--text-sm);color:var(--text-3);margin-bottom:var(--space-5)}.divider{height:1px;background:var(--border);margin:var(--space-5) 0}.fw6{font-weight:600}.fw7{font-weight:700}.fw8{font-weight:800}.c1{color:var(--text-1)}.c3{color:var(--text-3)}.c-teal{color:var(--teal)}.c-green{color:var(--green)}.c-red{color:var(--red)}.c-yellow{color:var(--yellow)}.ff-head{font-family:var(--ff-head)}.text-right{text-align:right}.text-center{text-align:center}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.mb-0{margin-bottom:0}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skel{background:linear-gradient(90deg,var(--card-2) 25%,var(--border) 50%,var(--card-2) 75%);background-size:600px 100%;animation:shimmer 1.3s linear infinite;border-radius:var(--r-sm)}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.fade-in{animation:fade-in .3s ease both}.mob-overlay{display:none;position:fixed;inset:0;background:rgba(17,24,39,.5);z-index:299;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mob-overlay.open{display:block}@media (max-width:1024px){:root{--sidebar-w:240px}}@media (max-width:768px){.sidebar{transform:translateX(-100%);width:280px}.sidebar.open{transform:translateX(0);box-shadow:var(--shadow-lg)}.app-main{margin-left:0}.ham-btn{display:flex}.page-body{padding:var(--space-5) var(--space-4)}.topbar{padding:0 var(--space-4)}.g-stats,.g2,.g3,.g4{grid-template-columns:1fr}.stat-val{font-size:var(--text-xl)}}@media (max-width:480px){.page-body{padding:var(--space-4) var(--space-3)}}.auth-layout{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.auth-brand{background:linear-gradient(145deg,#0d9488,#0ea5e9);display:flex;flex-direction:column;justify-content:center;padding:var(--space-12);position:relative;overflow:hidden}.auth-brand:before{top:-80px;right:-80px;width:320px;height:320px;background:hsla(0,0%,100%,.07)}.auth-brand:after,.auth-brand:before{content:"";position:absolute;border-radius:50%}.auth-brand:after{bottom:-60px;left:-40px;width:260px;height:260px;background:hsla(0,0%,100%,.05)}.auth-brand .a-logo{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-12);position:relative;z-index:1}.auth-brand .a-logo img{height:40px}.auth-brand .a-logo span{font-family:var(--ff-head);font-size:var(--text-2xl);font-weight:800;color:#fff}.auth-brand .a-headline{position:relative;z-index:1}.auth-brand h1{font-family:var(--ff-head);font-size:var(--text-3xl);font-weight:800;color:#fff;line-height:1.25;margin-bottom:var(--space-4)}.auth-brand p{color:hsla(0,0%,100%,.8);font-size:var(--text-base);line-height:1.7;margin-bottom:var(--space-8)}.auth-brand .feat-list{list-style:none;position:relative;z-index:1}.auth-brand .feat-list li{display:flex;align-items:center;gap:var(--space-3);color:hsla(0,0%,100%,.9);font-size:var(--text-sm);font-weight:500;margin-bottom:var(--space-3)}.auth-brand .feat-list .f-ico{width:30px;height:30px;border-radius:var(--r-sm);background:hsla(0,0%,100%,.18);font-size:14px;flex-shrink:0}.auth-brand .feat-list .f-ico,.auth-form-col{display:flex;align-items:center;justify-content:center}.auth-form-col{flex-direction:column;padding:var(--space-12);background:var(--bg)}.auth-box{width:100%;max-width:420px}.auth-box .a-label{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--teal);margin-bottom:var(--space-2)}.auth-box h2{font-family:var(--ff-head);font-size:var(--text-2xl);font-weight:800;color:var(--text-1);margin-bottom:var(--space-1)}.auth-box .a-sub{font-size:var(--text-sm);color:var(--text-3);margin-bottom:var(--space-8)}.auth-btn{width:100%;padding:13px;background:var(--teal);color:#fff;border:none;border-radius:var(--r-lg);font-family:var(--ff-body);font-size:var(--text-base);font-weight:700;cursor:pointer;transition:.15s;box-shadow:0 4px 12px rgba(13,148,136,.3);display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.auth-btn:hover{background:var(--teal-light);box-shadow:0 6px 18px rgba(13,148,136,.4);transform:translateY(-1px)}.auth-btn:active{transform:scale(.98)}@media (max-width:768px){.auth-layout{grid-template-columns:1fr}.auth-brand{display:none}.auth-form-col{padding:var(--space-8) var(--space-6)}}.oauth-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:12px 20px;border-radius:var(--r-md);font-size:var(--text-base);font-weight:600;font-family:var(--ff-body);text-decoration:none;transition:all .15s;cursor:pointer;border:1.5px solid var(--border);background:var(--card);color:var(--text-1)}.oauth-btn:hover:not(:disabled){border-color:var(--teal);box-shadow:var(--shadow);transform:translateY(-1px)}.oauth-btn.facebook-btn:hover{border-color:#1877f2}.oauth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:12px;margin:4px 0 20px;color:var(--text-4);font-size:13px}.auth-divider:after,.auth-divider:before{content:"";flex:1 1;height:1px;background:var(--border)}.spinner{display:inline-block;width:14px;height:14px;border:2px solid hsla(0,0%,100%,.4);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.spinner.dark{border-color:rgba(0,0,0,.2);border-top-color:var(--teal)}.welcome-card{background:linear-gradient(135deg,#0d9488,#0ea5e9);border-radius:var(--r-2xl);padding:var(--space-8);display:flex;align-items:center;justify-content:space-between;position:relative;overflow:hidden}.welcome-card:before{top:-60px;right:160px;width:200px;height:200px;background:hsla(0,0%,100%,.07)}.welcome-card:after,.welcome-card:before{content:"";position:absolute;border-radius:50%}.welcome-card:after{bottom:-80px;right:40px;width:220px;height:220px;background:hsla(0,0%,100%,.05)}.welcome-card h2{font-family:var(--ff-head);font-size:var(--text-2xl);font-weight:800;color:#fff;margin-bottom:4px}.welcome-card p{color:hsla(0,0%,100%,.82);font-size:var(--text-sm)}.welcome-card .w-avatar,.welcome-card .w-text{position:relative;z-index:1}.welcome-card .w-avatar{width:72px;height:72px;border-radius:50%;border:3px solid hsla(0,0%,100%,.35);object-fit:cover;flex-shrink:0}.balance-row{display:grid;grid-template-columns:2fr 1fr 1fr;grid-gap:var(--space-4);gap:var(--space-4)}.bal-main{background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--space-6) var(--space-7);box-shadow:var(--shadow-sm)}.bal-main .lbl{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:var(--space-2)}.bal-main .amount{font-family:var(--ff-head);font-size:2.5rem;font-weight:800;color:var(--text-1);line-height:1}.bal-main .amount.pos{color:var(--green)}.bal-main .amount.neg{color:var(--red)}.bal-main .note{font-size:var(--text-xs);color:var(--text-4);margin-top:var(--space-2);display:flex;align-items:center;gap:4px}.qa-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:var(--space-3);gap:var(--space-3)}.qa{background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--space-5) var(--space-4);text-align:center;cursor:pointer;transition:all .2s;text-decoration:none;box-shadow:var(--shadow-sm)}.qa:hover{border-color:var(--teal);box-shadow:var(--shadow);transform:translateY(-2px)}.qa .qa-ico{width:48px;height:48px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:18px;margin:0 auto var(--space-3)}.qa .qa-lbl{font-size:var(--text-xs);font-weight:700;color:var(--text-2);line-height:1.3}.ai-strip{background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:var(--r-xl);padding:var(--space-5) var(--space-6);display:flex;align-items:center;gap:var(--space-4);text-decoration:none;transition:.2s;box-shadow:0 6px 20px rgba(79,70,229,.25)}.ai-strip:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(79,70,229,.35)}.ai-strip .ai-ball{width:48px;height:48px;border-radius:50%;background:hsla(0,0%,100%,.18);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.ai-strip .ai-body h3{font-family:var(--ff-head);font-size:var(--text-base);font-weight:700;color:#fff;margin-bottom:2px}.ai-strip .ai-body p{font-size:var(--text-sm);color:hsla(0,0%,100%,.78)}.ai-strip .ai-arr{margin-left:auto;color:hsla(0,0%,100%,.6);font-size:18px}.tx-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border)}.tx-row:last-child{border-bottom:none}.t-ico2{width:40px;height:40px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.t-body{flex:1 1}.t-title{font-size:var(--text-sm);font-weight:600;color:var(--text-1)}.t-sub{font-size:var(--text-xs);color:var(--text-3);margin-top:2px}.t-end{text-align:right}.t-monto{font-family:var(--ff-head);font-size:var(--text-base);font-weight:700}.t-monto.ing{color:var(--green)}.t-monto.gas{color:var(--red)}.t-dt{font-size:var(--text-xs);color:var(--text-4)}.bud-row{margin-bottom:var(--space-4)}.bud-row:last-child{margin-bottom:0}.bud-top{justify-content:space-between;margin-bottom:var(--space-2)}.bud-cat,.bud-top{display:flex;align-items:center}.bud-cat{font-size:var(--text-sm);font-weight:600;color:var(--text-1);gap:6px}.bud-num{font-size:var(--text-xs);font-weight:700}.goal-item{padding:var(--space-4);border:1px solid var(--border);border-radius:var(--r-lg);background:var(--card-2)}.goal-nm{font-size:var(--text-sm);font-weight:700;color:var(--text-1);margin-bottom:var(--space-3)}.goal-ft{display:flex;justify-content:space-between;font-size:var(--text-xs);color:var(--text-3);margin-top:var(--space-2)}@media(max-width:900px){.balance-row{grid-template-columns:1fr}.qa-grid{grid-template-columns:repeat(2,1fr)}.welcome-card{flex-direction:column;align-items:flex-start;gap:var(--space-4)}}