*,:before,:after{box-sizing:border-box}:root{color:#0f172a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;font-family:Inter,system-ui,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5}body{min-height:100vh;margin:0;overflow-x:clip}#root{flex-direction:column;min-height:100vh;display:flex}button,input,select{font-family:inherit}.app-shell{background:#f8fafc;flex-direction:column;min-height:100vh;display:flex}.app-header{background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 100%);position:relative;overflow:hidden}.app-header:before{content:"";pointer-events:none;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;inset:0}.header-inner{justify-content:space-between;align-items:flex-start;gap:16px;max-width:1400px;margin:0 auto;padding:28px 20px 26px;display:flex;position:relative}.header-brand{align-items:center;gap:14px;display:flex}.header-logo{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff2e;border:1px solid #ffffff40;border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.header-titles{text-align:left}.app-header h1{color:#fff;letter-spacing:-.5px;align-items:center;gap:10px;margin:0 0 3px;font-size:1.75rem;font-weight:700;display:flex}.admin-badge{color:#fde68a;letter-spacing:.08em;text-transform:uppercase;vertical-align:middle;background:#fbbf2440;border:1px solid #fbbf2480;border-radius:999px;align-items:center;padding:2px 10px;font-size:.65rem;font-weight:700;display:inline-flex}.app-header p{color:#ffffffa6;margin:0;font-size:.85rem;font-weight:400}.header-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:8px;display:flex}.today-date{color:#fffc;white-space:nowrap;letter-spacing:.01em;background:#ffffff1f;border:1px solid #ffffff2e;border-radius:8px;padding:5px 12px;font-size:.78rem;font-weight:500}.app-header .quote-badge{background:#ffffff1f;border-color:#fff3}.app-header .quote-badge--stale{background:#f59e0b38;border-color:#fbbf2473}.app-header .quote-badge-ticker{color:#ffffffe6}.app-header .quote-badge--stale .quote-badge-ticker{color:#fde68a}.app-header .quote-badge-price{color:#fff}.app-header .quote-badge--stale .quote-badge-price{color:#fef3c7}.app-header .quote-badge-time{color:#ffffffa6;border-color:#fff3}.app-header .quote-badge--stale .quote-badge-time{color:#fcd34d;border-color:#fbbf2466}.app-header .quote-badge-refresh{color:#ffffffb3}.app-header .quote-badge-refresh:hover{color:#fff;opacity:1}.app-header .quote-badge--stale .quote-badge-refresh{color:#fcd34d}.quote-badge{white-space:nowrap;background:#eef2ff;border:1px solid #c7d2fe;border-radius:10px;align-items:center;gap:6px;padding:6px 12px;display:flex}.quote-badge--stale{background:#fef3c7;border-color:#fcd34d}.quote-badge-ticker{color:#4f46e5;letter-spacing:.04em;text-transform:uppercase;font-size:.76rem;font-weight:700}.quote-badge--stale .quote-badge-ticker{color:#92400e}.quote-badge-price{color:#3730a3;font-variant-numeric:tabular-nums;font-size:.88rem;font-weight:700}.quote-badge--stale .quote-badge-price{color:#78350f}.quote-badge-time{color:#6366f1;border-left:1px solid #c7d2fe;padding-left:6px;font-size:.73rem}.quote-badge--stale .quote-badge-time{color:#b45309;border-color:#fcd34d}.quote-badge-refresh{cursor:pointer;color:#6366f1;opacity:.6;background:0 0;border:none;align-items:center;padding:0 0 0 4px;font-size:.85rem;line-height:1;transition:opacity .15s;display:flex}.quote-badge-refresh:hover{opacity:1}.quote-badge--stale .quote-badge-refresh{color:#b45309}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.quote-badge-refresh--spinning{opacity:1;animation:.6s linear spin}.app{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:0 20px 80px}.app-nav{margin:28px 0 0}.nav-pills{background:#e2e8f0;border-radius:12px;gap:2px;padding:4px;display:inline-flex}.nav-link{color:#64748b;white-space:nowrap;letter-spacing:.01em;border-radius:9px;padding:8px 24px;font-size:.88rem;font-weight:600;text-decoration:none;transition:all .18s}.nav-link:hover{color:#4f46e5}.nav-link--active{color:#4f46e5;background:#fff;box-shadow:0 1px 4px #0000001a,0 1px 2px #0000000f}.app-main{flex-direction:column;gap:20px;margin-top:24px;display:flex}.card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:28px;box-shadow:0 2px 8px #0f172a0f,0 1px 3px #0f172a0a}.card h2{color:#0f172a;letter-spacing:-.2px;margin:0 0 20px;font-size:1rem;font-weight:700}.expense-form{flex-direction:column;gap:20px;display:flex}.form-row{flex-wrap:wrap;gap:16px;display:flex}.field{flex-direction:column;flex:240px;gap:6px;display:flex}.field-amount{flex:0 160px}.field label{color:#475569;letter-spacing:.02em;text-transform:uppercase;font-size:.82rem;font-weight:600}.field input{color:#0f172a;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;padding:10px 13px;font-size:.95rem;transition:border-color .18s,background .18s,box-shadow .18s}.field input:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.estimated-toggle{color:#475569;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:.875rem;font-weight:500;display:flex}.estimated-toggle input[type=checkbox]{accent-color:#6366f1;cursor:pointer;width:16px;height:16px}.year-section{flex-direction:column;gap:10px;display:flex}.section-label{color:#475569;letter-spacing:.02em;text-transform:uppercase;font-size:.82rem;font-weight:600}.year-chips{flex-wrap:wrap;gap:8px;display:flex}.year-chip{color:#475569;cursor:pointer;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:999px;align-items:center;gap:6px;padding:8px 16px;font-size:.88rem;font-weight:600;transition:all .16s;display:flex}.year-chip:hover{color:#6366f1;background:#eef2ff;border-color:#6366f1}.year-chip--open{color:#fff;background:#6366f1;border-color:#6366f1}.year-chip--has-months:not(.year-chip--open){color:#4338ca;background:#eef2ff;border-color:#c7d2fe}.year-chip-badge{color:#4338ca;background:#c7d2fe;border-radius:999px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.68rem;font-weight:700;line-height:1;display:inline-flex}.year-chip--open .year-chip-badge{color:#fff;background:#ffffff4d}.month-panel{background:#eef2ff;border:1.5px solid #c7d2fe;border-radius:12px;padding:16px}.month-panel-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.month-panel-year{color:#4338ca;font-size:.9rem;font-weight:700}.months-actions{align-items:center;gap:6px;display:flex}.btn-link{color:#6366f1;cursor:pointer;background:0 0;border:none;padding:0;font-size:.78rem;font-weight:600;text-decoration:underline}.sep{color:#c7d2fe;font-size:.8rem}.months-grid{grid-template-columns:repeat(6,1fr);gap:7px;display:grid}.month-btn{color:#475569;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:9px;padding:8px 0;font-size:.83rem;font-weight:500;transition:all .15s}.month-btn:hover{color:#6366f1;background:#eef2ff;border-color:#6366f1}.month-btn.selected{color:#fff;background:#6366f1;border-color:#6366f1}.form-error{color:#ef4444;margin:0;font-size:.875rem}.btn-primary{color:#fff;cursor:pointer;letter-spacing:.01em;background:#6366f1;border:none;border-radius:10px;align-self:flex-start;padding:11px 28px;font-size:.95rem;font-weight:600;transition:background .18s,transform .12s,box-shadow .18s;box-shadow:0 2px 6px #6366f159}.btn-primary:hover{background:#4f46e5;transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.btn-primary:active{transform:translateY(0);box-shadow:0 2px 4px #6366f14d}.planner-table-wrapper{border-radius:10px;margin:0 -4px;overflow-x:auto}.planner-table{border-collapse:collapse;width:100%;font-size:.875rem}.planner-table thead th{color:#94a3b8;text-align:right;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid #f1f5f9;padding:0 16px 12px;font-size:.75rem;font-weight:700}.planner-col-month{min-width:90px;text-align:left!important;padding-left:4px!important}.planner-col-income{min-width:160px}.planner-col-expenses,.planner-col-pct,.planner-col-balance{min-width:120px}.planner-col-pac{white-space:nowrap;min-width:140px}.planner-col-savings{min-width:140px}.planner-row:nth-child(2n){background:#fafbfc}.planner-row--current,.planner-row--current:nth-child(2n){outline-offset:-1px;background:#eef2ff;outline:1px solid #c7d2fe}.planner-row--year-end td{border-bottom:2px solid #cbd5e1}.planner-month-label{color:#0f172a;white-space:nowrap;padding:10px 16px 10px 4px;font-weight:600}.planner-income-cell{padding:6px 12px}.planner-input-wrap{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;align-items:center;gap:4px;padding:0 10px;transition:border-color .18s,background .18s,box-shadow .18s;display:flex}.planner-input-wrap:focus-within{background:#fff;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.planner-currency{color:#94a3b8;-webkit-user-select:none;user-select:none;font-size:.85rem}.planner-income-input{color:#0f172a;text-align:right;background:0 0;border:none;outline:none;width:100%;padding:7px 0;font-size:.88rem}.planner-income-input--saving{opacity:.4}.planner-income-input::-webkit-outer-spin-button{-webkit-appearance:none}.planner-income-input::-webkit-inner-spin-button{-webkit-appearance:none}.planner-income-input[type=number]{-moz-appearance:textfield}.planner-cell{text-align:right;white-space:nowrap;border-left:1px solid #f8fafc;padding:10px 16px}.planner-cell--zero{color:#cbd5e1}.planner-cell--expense{color:#4f46e5;font-weight:600}.planner-cell--positive{color:#10b981;font-weight:600}.planner-cell--negative{color:#ef4444;font-weight:600}.planner-cell--warning{color:#f59e0b;font-weight:600}.planner-cell--pac{font-size:.82rem}.planner-quote-badge{color:#4f46e5;vertical-align:middle;letter-spacing:.01em;background:#eef2ff;border-radius:999px;margin-left:6px;padding:2px 7px;font-size:.7rem;font-weight:700;display:inline-block}.planner-quote-badge--stale{color:#92400e;background:#fef3c7}.planner-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.planner-header h2{margin:0}.planner-toggle-btn{color:#64748b;cursor:pointer;letter-spacing:.01em;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;padding:7px 16px;font-size:.83rem;font-weight:600;transition:all .16s}.planner-toggle-btn:hover{color:#475569;background:#f1f5f9;border-color:#cbd5e1}.planner-toggle-btn--active{color:#4f46e5;background:#eef2ff;border-color:#c7d2fe}.expense-table-wrapper{margin:0 -4px;overflow-x:auto}.expense-table{border-collapse:collapse;width:100%;font-size:.875rem}.expense-table thead th{white-space:nowrap;border-bottom:2px solid #f1f5f9;padding:0 12px 12px}.expense-table-month-col{text-align:left;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;min-width:80px;font-size:.75rem;font-weight:700;padding-left:4px!important}.expense-table-expense-col{text-align:center;min-width:110px}.expense-table-header-cell{flex-direction:column;align-items:center;gap:2px;display:flex}.expense-table-header-name{color:#0f172a;font-size:.82rem;font-weight:700}.expense-table-header-amount{color:#6366f1;font-size:.78rem;font-weight:700}.expense-table-row:nth-child(2n){background:#fafbfc}.expense-table-row--current,.expense-table-row--current:nth-child(2n){outline-offset:-1px;background:#eef2ff;outline:1px solid #c7d2fe}.expense-table-row--year-end td{border-bottom:2px solid #cbd5e1}.expense-table-month-label{color:#0f172a;white-space:nowrap;padding:9px 12px 9px 4px;font-weight:600}.expense-table-cell{text-align:center;color:#cbd5e1;border-left:1px solid #f8fafc;padding:9px 12px}.expense-table-cell--active{color:#4f46e5;font-weight:600}.expense-table-toggle{color:#94a3b8;cursor:pointer;background:0 0;border:1.5px dashed #e2e8f0;border-radius:10px;width:100%;margin-top:14px;padding:9px;font-size:.82rem;font-weight:600;transition:color .15s,border-color .15s;display:block}.expense-table-toggle:hover{color:#6366f1;border-color:#c7d2fe}.btn-remove{color:#cbd5e1;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:.9rem;line-height:1;transition:color .15s,background .15s}.btn-remove:hover{color:#ef4444;background:#fee2e2}.card--wide{width:calc(100vw - 48px);max-width:calc(100vw - 48px);margin-left:calc(50% - 50vw + 24px);margin-right:calc(50% - 50vw + 24px)}.chart-card{padding-bottom:32px}.chart-wrapper{height:420px;position:relative}.breakdown-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.breakdown-header h2{margin:0}.breakdown-select{color:#475569;cursor:pointer;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:9px;outline:none;padding:7px 12px;font-size:.88rem;font-weight:500;transition:border-color .16s}.breakdown-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.breakdown-empty{color:#94a3b8;text-align:center;padding:1rem 0}.breakdown-body{align-items:flex-start;gap:32px;display:flex}.breakdown-chart{flex:0 0 240px;height:240px}.breakdown-list{flex:1;min-width:0}.breakdown-table{border-collapse:collapse;width:100%;font-size:.88rem}.breakdown-table thead th{text-align:left;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;border-bottom:1.5px solid #f1f5f9;padding:0 8px 10px;font-size:.72rem;font-weight:700}.breakdown-table tbody tr:nth-child(2n){background:#fafbfc}.breakdown-table tbody td{color:#0f172a;border-bottom:1px solid #f8fafc;padding:9px 8px}.breakdown-col-amount,.breakdown-col-pct,.breakdown-table thead th.breakdown-col-amount,.breakdown-table thead th.breakdown-col-pct{text-align:right;white-space:nowrap}.breakdown-col-amount{font-variant-numeric:tabular-nums;color:#4f46e5;font-weight:600}.breakdown-col-pct{color:#94a3b8;font-size:.83rem}.breakdown-dot{vertical-align:middle;border-radius:50%;flex-shrink:0;width:9px;height:9px;margin-right:8px;display:inline-block}.breakdown-total-row td{color:#0f172a;border-top:2px solid #f1f5f9;padding:10px 8px;font-weight:700}.planner-table-wrapper,.expense-table-wrapper{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent}.home{padding:40px 0 20px}.home-hero{text-align:center;margin-bottom:40px}.home-title{color:#0f172a;letter-spacing:-.5px;margin:0 0 10px;font-size:1.75rem;font-weight:700}.home-subtitle{color:#64748b;margin:0;font-size:1rem}.home-cards{grid-template-columns:1fr 1fr;gap:20px;display:grid}.home-card{cursor:pointer;background:#fff;border:1.5px solid #f1f5f9;border-radius:20px;flex-direction:column;gap:16px;padding:32px 28px 28px;text-decoration:none;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;box-shadow:0 2px 10px #0f172a0f,0 1px 3px #0f172a0a}.home-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px #0f172a1a,0 4px 8px #0f172a0f}.home-card--planner:hover{border-color:#c7d2fe}.home-card--spese:hover{border-color:#a7f3d0}.home-card-icon-wrap{border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:60px;height:60px;display:flex}.home-card--planner .home-card-icon-wrap{color:#6366f1;background:#eef2ff}.home-card--spese .home-card-icon-wrap{color:#059669;background:#d1fae5}.home-card-body{flex:1}.home-card-title{color:#0f172a;letter-spacing:-.3px;margin:0 0 10px;font-size:1.25rem;font-weight:700}.home-card-desc{color:#64748b;margin:0;font-size:.9rem;line-height:1.6}.home-card-footer{margin-top:4px}.home-card-cta{align-items:center;gap:6px;font-size:.88rem;font-weight:700;transition:gap .18s;display:inline-flex}.home-card--planner .home-card-cta{color:#6366f1}.home-card--spese .home-card-cta{color:#059669}.home-card:hover .home-card-cta{gap:10px}.spese-top-row{grid-template-columns:1fr 1fr;align-items:stretch;gap:20px;display:grid}.spese-top-row--no-chart{grid-template-columns:1fr;max-width:560px}.spese-right-col{flex-direction:column;gap:12px;display:flex}.spese-right-col>.card{flex:1}.spese-chart-card{flex-direction:column;display:flex}.spese-chart-card .chart-wrapper{flex:1;height:auto;min-height:260px;position:relative}.btn-show-expenses{color:#6366f1;cursor:pointer;letter-spacing:.01em;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px 20px;font-size:.9rem;font-weight:600;transition:background .18s,border-color .18s,box-shadow .18s;display:flex}.btn-show-expenses:hover{background:#eef2ff;border-color:#c7d2fe;box-shadow:0 2px 8px #6366f11a}.btn-show-expenses-count{color:#4f46e5;background:#eef2ff;border-radius:999px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 6px;font-size:.75rem;font-weight:700;line-height:1;display:inline-flex}.btn-show-expenses:hover .btn-show-expenses-count{background:#c7d2fe}.modal-overlay{z-index:9000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a8c;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:#fff;border-radius:20px;flex-direction:column;width:100%;max-width:960px;max-height:85vh;animation:.2s slideUp;display:flex;box-shadow:0 24px 64px #0f172a2e,0 8px 24px #0f172a1a}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid #f1f5f9;flex-shrink:0;justify-content:space-between;align-items:center;padding:24px 28px 20px;display:flex}.modal-title{color:#0f172a;letter-spacing:-.2px;margin:0;font-size:1.1rem;font-weight:700}.modal-close-btn{color:#64748b;cursor:pointer;background:#f8fafc;border:none;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:background .15s,color .15s;display:flex}.modal-close-btn:hover{color:#0f172a;background:#f1f5f9}.modal-body{scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent;flex:1;padding:24px 28px 28px;overflow:hidden auto}@media (width<=768px){.header-inner{padding:22px 20px 20px}.app-header h1{font-size:1.5rem}.chart-wrapper{height:320px}}@media (width<=640px){.home-cards{grid-template-columns:1fr}.home-title{font-size:1.4rem}.spese-top-row{grid-template-columns:1fr}.spese-right-col>.card{flex:none}.spese-chart-card .chart-wrapper{height:260px;min-height:unset;flex:none}.modal-overlay{align-items:flex-end;padding:12px}.modal-container{border-radius:20px 20px 14px 14px;max-height:90vh}.modal-header{padding:20px 20px 16px}.modal-body{padding:16px 20px 24px}.header-inner{flex-direction:column;align-items:flex-start;gap:12px;padding:18px 16px 16px}.app-header h1{font-size:1.4rem}.header-right{flex-flow:wrap;align-items:center;gap:8px;width:100%}.app{padding:0 16px 60px}.app-main{gap:14px;margin-top:18px}.card{padding:20px 18px}.card h2{margin-bottom:16px;font-size:.95rem}.chart-wrapper{height:260px}.nav-link{padding:8px 18px;font-size:.85rem}.field,.field-amount{flex:100%}.btn-primary{text-align:center;width:100%}.months-grid{grid-template-columns:repeat(4,1fr)}.month-btn{min-height:44px;padding:10px 0}.year-chip{min-height:44px}.breakdown-body{flex-direction:column;align-items:center}.breakdown-chart{flex:0 0 200px;width:200px;height:200px}.breakdown-list{width:100%}.planner-header{flex-direction:column;align-items:flex-start;gap:10px}.planner-toggle-btn{text-align:center;width:100%;min-height:44px;padding:10px}.card--wide{width:calc(100vw - 32px);max-width:calc(100vw - 32px);margin-left:calc(50% - 50vw + 16px);margin-right:calc(50% - 50vw + 16px)}}@media (width<=480px){.home{padding:24px 0 16px}.home-hero{margin-bottom:28px}.home-card{padding:24px 20px 22px}.app{padding:0 12px 48px}.card--wide{width:calc(100vw - 24px);max-width:calc(100vw - 24px);margin-left:calc(50% - 50vw + 12px);margin-right:calc(50% - 50vw + 12px)}.app-header h1{font-size:1.3rem}.app-header p{font-size:.8rem}.card{border-radius:13px;padding:16px 14px}.nav-link{padding:7px 14px;font-size:.82rem}.chart-wrapper{height:220px}.months-grid{grid-template-columns:repeat(3,1fr)}.breakdown-chart{flex:0 0 170px;width:170px;height:170px}.today-date{padding:4px 10px;font-size:.74rem}}@media (width<=360px){.app{padding:0 10px 40px}.card--wide{width:calc(100vw - 20px);max-width:calc(100vw - 20px);margin-left:calc(50% - 50vw + 10px);margin-right:calc(50% - 50vw + 10px)}.app-header h1{font-size:1.2rem}.months-grid{grid-template-columns:repeat(3,1fr);gap:5px}.month-btn{font-size:.76rem}.nav-link{padding:7px 12px;font-size:.8rem}.breakdown-chart{flex:0 0 150px;width:150px;height:150px}}.auth-page{background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:#fff;border-radius:20px;width:100%;max-width:420px;padding:40px 36px;box-shadow:0 20px 60px #0003}.auth-card--wide{max-width:600px}.auth-brand{text-align:center;margin-bottom:32px}.auth-logo{background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 100%);border-radius:18px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 14px;display:flex}.auth-brand h1{color:#1e1b4b;letter-spacing:-.5px;margin:0 0 4px;font-size:1.6rem;font-weight:700}.auth-brand p{color:#64748b;margin:0;font-size:.9rem}.auth-form{flex-direction:column;gap:18px;display:flex}.auth-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:#374151;letter-spacing:.01em;font-size:.82rem;font-weight:600}.auth-field input{color:#1e293b;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;padding:11px 14px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.auth-field input:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f}.auth-field input:disabled{opacity:.6;cursor:not-allowed}.auth-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:10px 14px;font-size:.875rem;font-weight:500}.auth-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#4f46e5 0%,#7c3aed 100%);border:none;border-radius:10px;margin-top:4px;padding:13px;font-size:1rem;font-weight:600;transition:opacity .15s,transform .1s}.auth-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px)}.auth-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.auth-switch{text-align:center;color:#64748b;margin:20px 0 0;font-size:.875rem}.auth-switch a{color:#4f46e5;font-weight:600;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.header-user{align-items:center;gap:10px;margin-top:6px;display:flex}.header-username{color:#ffffffd9;white-space:nowrap;font-size:.82rem;font-weight:500}.logout-btn{color:#ffffffe6;cursor:pointer;white-space:nowrap;background:#ffffff26;border:1px solid #ffffff40;border-radius:8px;align-items:center;gap:5px;padding:5px 12px;font-size:.8rem;font-weight:500;transition:background .15s;display:flex}.logout-btn:hover{background:#ffffff40}@media (width<=640px){.auth-row{grid-template-columns:1fr}.auth-card{padding:28px 20px}.header-username,.logout-btn span{display:none}.logout-btn{padding:6px 8px}}
