:root{--text:#4a5568;--text-h:#1a202c;--bg:#fff;--bg-secondary:#f7fafc;--border:#e2e8f0;--code-bg:#edf2f7;--accent:#1e40af;--accent-hover:#1e3a8a;--accent-bg:#1e40af14;--accent-border:#1e40af66;--shadow:0 4px 24px #00000014;--shadow-lg:0 8px 32px #0000001f;--sans:"Segoe UI", system-ui, -apple-system, sans-serif;--heading:"Segoe UI", system-ui, -apple-system, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/1.5 var(--sans);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}html,body{max-width:100%;overflow-x:hidden}body{background:var(--bg-secondary);margin:0;overflow-x:hidden}#root{max-width:100%;min-height:100vh;overflow-x:hidden}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:600}h1{letter-spacing:-.5px;font-size:28px}h2{font-size:20px;line-height:1.3}p{margin:0}.layout{min-height:100vh;display:flex}.sidebar{background:var(--accent);color:#fff;z-index:100;flex-direction:column;width:260px;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{border-bottom:1px solid #ffffff26;align-items:center;gap:12px;padding:20px;display:flex}.user-avatar{color:#fff;background:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:16px;font-weight:700;display:flex}.user-meta{flex-direction:column;display:flex;overflow:hidden}.user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.user-role{color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px;font-size:11px}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-link{color:#ffffffbf;align-items:center;gap:12px;padding:12px 24px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-link:hover{color:#fff;background:#ffffff1a}.nav-link.active{color:#fff;background:#ffffff26;border-right:3px solid #fff}.nav-link svg{flex-shrink:0;width:18px;height:18px}.sidebar-footer{border-top:1px solid #ffffff26;padding:16px 24px}.logout-btn{color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff4d;border-radius:8px;align-items:center;gap:12px;width:100%;padding:10px;font-size:14px;transition:background .2s;display:flex}.logout-btn:hover{background:#ffffff26}.logout-btn svg{width:18px;height:18px}.sidebar-toggle{z-index:200;background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:none;position:fixed;top:16px;left:16px}.sidebar-overlay{display:none}.main-content{flex-direction:column;flex:1;max-width:100%;min-height:100vh;margin-left:260px;display:flex;overflow-x:hidden}.topbar{background:var(--bg);border-bottom:1px solid var(--border);justify-content:flex-end;align-items:center;padding:12px 24px;display:flex}.topbar-title{color:var(--accent);font-size:14px;font-weight:600}.page-content{background:var(--bg-secondary);flex:1;min-width:0;max-width:100%;padding:24px;overflow-x:hidden}@media (width<=768px){.sidebar{width:280px;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-toggle{display:flex}.sidebar-overlay{z-index:90;background:#00000080;display:block;position:fixed;inset:0}.main-content{margin-left:0}.topbar{padding:12px 16px 12px 56px}.page-content{padding:16px}}@media (width<=480px){.sidebar{width:260px}.sidebar-header{padding:16px}.nav-link{padding:10px 16px;font-size:13px}.sidebar-footer{padding:12px 16px}.topbar{padding:10px 16px 10px 56px}.topbar-title{font-size:13px}.page-content{padding:12px}}.dashboard h1{color:var(--text-h);margin:0 0 24px;font-size:24px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg);border:1px solid var(--border);border-left:4px solid var(--accent);box-shadow:var(--shadow);border-radius:12px;align-items:center;gap:16px;padding:20px;transition:transform .2s,box-shadow .2s;display:flex}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;display:flex}.stat-info{flex-direction:column;min-width:0;display:flex}.stat-value{color:var(--text-h);font-size:26px;font-weight:700;line-height:1}.stat-label{color:var(--text);margin-top:4px;font-size:13px}.stat-sub{color:#a0aec0;margin-top:2px;font-size:11px}.charts-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.chart-card{background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;min-width:0;max-width:100%;padding:20px;overflow:hidden}.chart-card h3{color:var(--text-h);margin:0 0 16px;font-size:14px;font-weight:600}.chart-wide{grid-column:1/-1}.chart-box{width:100%;height:260px;position:relative}.chart-box canvas{width:100%!important;height:100%!important}.chart-box-doughnut{height:240px}@media (width<=1024px){.charts-grid{grid-template-columns:1fr}.chart-wide{grid-column:auto}}@media (width<=768px){.dashboard h1{margin-bottom:16px;font-size:20px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.stat-card{gap:10px;padding:14px}.stat-icon{width:40px;height:40px;font-size:18px}.stat-value{font-size:20px}.stat-label{font-size:11px}.charts-grid{grid-template-columns:1fr;gap:12px}.chart-card{padding:14px}.chart-card h3{margin-bottom:12px;font-size:13px}.chart-box{height:220px}.chart-box-doughnut{height:200px}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.chart-box{height:200px}.chart-box-doughnut{height:180px}}.crud-page{min-width:0;max-width:100%;overflow-x:hidden}.crud-page h1{color:var(--text-h);margin:0;font-size:24px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.search-bar{gap:8px;margin-bottom:20px;display:flex}.search-bar input{border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:8px;flex:1;padding:10px 14px;font-size:14px}.search-bar input:focus{border-color:var(--accent);outline:none}.search-bar button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500}.search-bar button:hover{background:var(--accent-hover)}.table-wrapper{background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;min-width:0;max-width:100%;overflow-x:auto}table{border-collapse:collapse;width:100%}table th,table td{text-align:left;border-bottom:1px solid var(--border);padding:12px 16px;font-size:14px}table th{background:var(--bg-secondary);color:var(--text-h);white-space:nowrap;font-weight:600}table td{color:var(--text)}table tr:last-child td{border-bottom:none}table .empty{text-align:center;color:#a0aec0;padding:32px}.badge{border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.badge-activo,.badge-vigente{color:#065f46;background:#d1fae5}.badge-inactivo,.badge-vencido,.badge-anulado{color:#991b1b;background:#fee2e2}.badge-suspendido,.badge-bloqueado{color:#92400e;background:#fef3c7}.actions{gap:6px;display:flex}.btn-icon{border:1px solid var(--border);background:var(--bg);width:32px;height:32px;color:var(--text);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:inline-flex}.btn-icon:hover{border-color:var(--accent);color:var(--accent)}.btn-icon.btn-danger:hover{color:#dc2626;border-color:#dc2626}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;display:inline-flex}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;display:inline-flex}.btn-secondary:hover{background:var(--bg-secondary)}.pagination{justify-content:center;align-items:center;gap:16px;margin-top:20px;display:flex}.pagination span{color:var(--text);font-size:14px}.pagination button{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:6px;padding:8px 16px;font-size:13px}.pagination button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg);border-radius:12px;width:100%;max-width:600px;max-height:90vh;padding:32px;overflow-y:auto}.modal h2{color:var(--text-h);margin:0 0 20px;font-size:20px}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-grid label{color:var(--text-h);flex-direction:column;font-size:13px;font-weight:500;display:flex}.form-grid input,.form-grid select{border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:6px;margin-top:4px;padding:10px 12px;font-size:14px}:is(.form-grid input,.form-grid select):focus{border-color:var(--accent);outline:none}.form-section-title{color:var(--text-h);border-bottom:1px solid var(--border);margin:20px 0 12px;padding-bottom:6px;font-size:14px;font-weight:600}.form-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-bottom:16px;padding:10px 12px;font-size:13px}.form-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.modal-lg{max-width:720px}.modal-result{text-align:center;max-width:400px}.modal-result .modal-icon{color:#fff;background:#22c55e;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:24px;font-weight:700;display:flex}.modal-result h2{text-align:center}.modal-result .modal-message{color:var(--text);margin-bottom:8px;font-size:15px}.modal-result .modal-detail{color:var(--accent);margin-bottom:0;font-size:14px}.modal-result .form-actions{justify-content:center}.modal-qr{text-align:center;max-width:420px}.modal-qr h2{text-align:center}.modal-qr .qr-nombre{color:var(--text);margin-bottom:16px;font-size:14px}.modal-qr .qr-content img{border:1px solid var(--border);border-radius:8px;max-width:250px;max-height:250px}.modal-qr .qr-error{color:#dc2626;margin-top:8px;font-size:13px}.modal-qr .qr-empty p{color:#a0aec0;padding:24px 0;font-size:14px}.modal-qr .form-actions{justify-content:center}.roles-section,.permisos-section{margin-top:20px}.roles-label{color:var(--text-h);margin-bottom:8px;font-size:13px;font-weight:500;display:block}.roles-list{flex-wrap:wrap;gap:8px 16px;display:flex}.role-check{color:var(--text);cursor:pointer;align-items:center;gap:6px;font-size:13px;display:flex}.role-check input{cursor:pointer}.permiso-grupo{margin-bottom:12px}.permiso-grupo strong{text-transform:uppercase;color:var(--text);margin-bottom:6px;font-size:12px;display:block}.log-detalle{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}@media (width<=768px){.page-header{flex-direction:column;align-items:flex-start}.header-actions{justify-content:flex-end;width:100%}.search-bar{flex-direction:column;gap:8px}.search-bar input,.search-bar button{width:100%}.table-wrapper{box-shadow:none;background:0 0;border:none;border-radius:8px;max-width:100%;margin:0;overflow:hidden}.crud-page table,.crud-page .table-wrapper table{border-collapse:collapse;width:100%;max-width:100%;display:block}.crud-page thead,.table-wrapper thead{display:none!important}.crud-page tbody,.table-wrapper tbody{width:100%;display:block}.crud-page tr,.table-wrapper tr{background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:10px;flex-direction:column;margin-bottom:10px;padding:14px 16px;display:flex}.crud-page td,.table-wrapper td{border-bottom:1px solid var(--border);text-align:left;word-break:break-word;justify-content:space-between;align-items:center;gap:8px;min-width:0;max-width:100%;padding:6px 0;font-size:13px;display:flex}.crud-page code,.table-wrapper code{background:var(--bg-secondary);word-break:break-all;border-radius:4px;padding:2px 6px;font-size:11px}.crud-page td:last-child,.table-wrapper td:last-child{border-bottom:none}.crud-page td:before,.table-wrapper td:before{content:attr(data-label);color:var(--text-h);text-transform:uppercase;letter-spacing:.3px;flex-shrink:0;min-width:70px;max-width:100px;font-size:11px;font-weight:600}.crud-page td.actions,.table-wrapper td.actions{justify-content:flex-end}.crud-page td.actions:before,.table-wrapper td.actions:before{display:none}.crud-page .empty,.table-wrapper .empty{text-align:center;padding:24px;font-size:13px}.pagination{flex-wrap:wrap;gap:8px}.pagination span{text-align:center;width:100%}.pagination button{flex:1;min-width:0}.modal{max-height:85vh;margin:12px}.modal-lg{max-width:100%}.log-detalle{white-space:normal;max-width:none;text-overflow:unset;overflow:visible}}@media (width<=640px){.form-grid{grid-template-columns:1fr}.modal{padding:20px}.modal-overlay{padding:12px}.form-actions{flex-direction:column-reverse}.form-actions button{justify-content:center;width:100%}}@media (width<=400px){.crud-page td,.table-wrapper td{flex-direction:column;align-items:flex-start;gap:2px;padding:8px 0}.crud-page td:before,.table-wrapper td:before{min-width:auto;margin-bottom:2px}.crud-page td.actions,.table-wrapper td.actions{justify-content:flex-start;padding-top:6px}}.header-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.header-actions .btn-secondary,.header-actions .btn-primary{white-space:nowrap}.import-status{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:14px}.import-result{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:14px;position:relative}.import-result.with-errors{color:#854d0e;background:#fefce8;border-color:#fde68a}.import-result p{margin:4px 0}.import-result ul{margin:6px 0 0;padding-left:18px;font-size:13px}.import-result .btn-close{cursor:pointer;color:inherit;background:0 0;border:none;font-size:18px;position:absolute;top:8px;right:10px}.pcv-container{box-sizing:border-box;background:linear-gradient(135deg,#e8eef5 0%,#d5dde8 100%);flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:100vh;padding:24px;font-family:Montserrat,system-ui,sans-serif;display:flex}.pcv-card{perspective:1200px;cursor:default;width:380px;height:560px;position:relative}.pcv-face{backface-visibility:hidden;border-radius:16px;transition:transform .6s cubic-bezier(.4,0,.2,1);position:absolute;inset:0;overflow:hidden;box-shadow:0 8px 32px #0000002e,0 2px 8px #00000014}.pcv-front{background:#f0f0f0;flex-direction:column;display:flex}.pcv-back{background:#f0f0f0;flex-direction:column;display:flex;transform:rotateY(180deg)}.pcv-flipped .pcv-front{transform:rotateY(180deg)}.pcv-flipped .pcv-back{transform:rotateY(0)}.pcv-front-header{z-index:1;background:#fff;border-bottom:1px solid #e0e0e0;align-items:center;gap:12px;padding:16px 20px;display:flex;position:relative}.pcv-logo{object-fit:contain;flex-shrink:0;width:56px;height:56px}.pcv-university{color:#1a3a5a;letter-spacing:.3px;flex-direction:column;font-size:13px;font-weight:700;line-height:1.2;display:flex}.pcv-blue-strip{z-index:0;background:#1a5aa0;border-radius:0 16px 16px 0;width:28px;height:100%;position:absolute;top:0;right:0}.pcv-front-body{z-index:1;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:20px 30px;display:flex;position:relative}.pcv-photo-frame{background:#e0e0e0;border:3px solid #d0d0d0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:160px;height:190px;display:flex;overflow:hidden}.pcv-photo{object-fit:cover;width:100%;height:100%}.pcv-photo-placeholder{color:#1a5aa0;font-size:48px;font-weight:800}.pcv-name{color:#1a5aa0;text-align:center;margin:0;font-size:20px;font-weight:700;line-height:1.3}.pcv-divider{background:silver;width:60%;height:1px;margin:4px 0}.pcv-cargo{color:#666;text-align:center;margin:0;font-size:14px;font-weight:500}.pcv-front-footer{z-index:1;background:linear-gradient(#e8e8e8 0%,#d8d8d8 100%);border-top:1px solid #d0d0d0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex;position:relative}.pcv-nfc{color:#555;align-items:center;gap:6px;display:flex}.pcv-nfc-icon{font-size:16px}.pcv-nfc-label{color:#fff;background:#444;border-radius:3px;padding:2px 6px;font-size:11px;font-weight:700}.pcv-code{color:#333;letter-spacing:1px;font-family:Courier New,monospace;font-size:16px;font-weight:600}.pcv-back-header{text-align:center;background:#1a5aa0;padding:14px 20px}.pcv-back-header h3{color:#fff;letter-spacing:1.5px;margin:0;font-size:15px;font-weight:700}.pcv-back-body{flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.pcv-back-blue-strip{z-index:0;background:#1a5aa0;width:16px;height:100%;position:absolute;top:0;right:0}.pcv-back-content{z-index:1;flex-direction:column;flex:1;padding:14px 18px 10px;display:flex;position:relative;overflow:hidden}.pcv-section{margin-bottom:10px}.pcv-section h4{color:#1a5aa0;border-bottom:1px solid #ddd;margin:0 0 6px;padding-bottom:3px;font-size:13px;font-weight:700}.pcv-info-row{justify-content:space-between;align-items:baseline;gap:8px;padding:3px 0;display:flex}.pcv-info-row span:first-child{color:#888;flex-shrink:0;min-width:85px;font-size:12px;font-weight:500}.pcv-info-row span:last-child{color:#222;text-align:right;word-break:break-word;font-size:12.5px;font-weight:600;line-height:1.3}.pcv-firma-section{flex-direction:column;flex:1;justify-content:center;align-items:center;margin-top:auto;padding-top:4px;display:flex}.pcv-firma-img-wrap{justify-content:center;align-items:center;width:220px;height:120px;margin-bottom:2px;display:flex}.pcv-firma-img{object-fit:contain;max-width:100%;max-height:100%}.pcv-firma-line{background:#999;width:160px;height:1px}.pcv-firma-label{color:#888;letter-spacing:1px;margin-top:3px;font-size:9px;font-weight:600}.pcv-back-footer{text-align:center;color:#666;z-index:1;background:linear-gradient(#e8e8e8 0%,#d8d8d8 100%);border-top:1px solid #d0d0d0;padding:10px 16px;font-size:10.5px;position:relative}.pcv-toggle{color:#fff;cursor:pointer;background:#1a5aa0;border:none;border-radius:12px;align-items:center;gap:8px;padding:12px 28px;font-size:15px;font-weight:600;transition:background .2s,transform .15s;display:inline-flex;box-shadow:0 4px 12px #1a5aa059}.pcv-toggle:hover{background:#14488a}.pcv-toggle:active{transform:scale(.97)}.pcv-overlay{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:40px;display:flex}.pcv-spinner{border:4px solid #1a5aa026;border-top-color:#1a5aa0;border-radius:50%;width:48px;height:48px;animation:.8s linear infinite pcv-spin}@keyframes pcv-spin{to{transform:rotate(360deg)}}.pcv-overlay p{color:#555;font-size:14px;font-weight:500}.pcv-error{background:#fff;border-radius:12px;padding:32px;box-shadow:0 4px 16px #0000001a}.pcv-error h2{color:#1a3a5a;margin:0 0 8px;font-size:18px}.pcv-error p{color:#666;margin:0}@media (width<=440px){.pcv-card{width:320px;height:480px}.pcv-photo-frame{width:130px;height:160px}.pcv-name{font-size:17px}.pcv-front-header{padding:12px 16px}.pcv-logo{width:44px;height:44px}.pcv-university{font-size:11px}.pcv-front-body{padding:16px 24px}.pcv-back-content{padding:12px 16px}}.login-container{background:linear-gradient(135deg,#1e3a8a 0%,#1e40af 50%,#2563eb 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-form{background:var(--bg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);text-align:center;border-radius:16px;padding:48px 40px}.login-form .login-icon{background:var(--accent-bg);width:72px;height:72px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;margin-bottom:16px;display:inline-flex}.login-form h1{color:var(--accent);text-align:center;margin:0 0 4px;font-size:24px}.login-form .subtitle{text-align:center;color:var(--text);margin:0 0 32px;font-size:14px}.login-form label{color:var(--text-h);margin-bottom:16px;font-size:14px;font-weight:500;display:block}.login-form input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-h);box-sizing:border-box;border-radius:8px;margin-top:6px;padding:12px 14px;font-size:15px;transition:border-color .2s,box-shadow .2s;display:block}.login-form input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #1e40af26}.login-form input::placeholder{color:#a0aec0}.login-form .password-wrapper{position:relative}.login-form .password-wrapper input{padding-right:44px}.login-form .password-wrapper .toggle-password{cursor:pointer;color:var(--text);opacity:.6;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:opacity .2s;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.login-form .password-wrapper .toggle-password:hover{opacity:1}.login-form button[type=submit]{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:8px;padding:12px;font-size:16px;font-weight:600;transition:background .2s,transform .1s}.login-form button[type=submit]:hover:not(:disabled){background:var(--accent-hover)}.login-form button[type=submit]:active:not(:disabled){transform:scale(.98)}.login-form button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px;padding:12px 14px;font-size:14px}.app-header{background:var(--accent);color:#fff;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 24px;display:flex}.app-header h1{color:#fff;margin:0;font-size:18px}.user-info{align-items:center;gap:16px;display:flex}.user-info span{color:#ffffffe6;font-size:14px}.user-info button{color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff4d;border-radius:6px;padding:8px 16px;font-size:13px;transition:background .2s}.user-info button:hover{background:#ffffff26}.app-main{padding:32px 24px}.app-main p{color:var(--text);margin:0;font-size:16px}@media (width<=768px){.login-container{padding:20px}.login-form{padding:36px 28px}.app-header{padding:14px 16px}.app-main{padding:24px 16px}}@media (width<=480px){.login-container{align-items:flex-start;padding:40px 16px 16px}.login-form{border-radius:12px;padding:28px 20px}.login-form .login-icon{width:60px;height:60px;font-size:28px}.login-form h1{font-size:18px}.login-form .subtitle{margin-bottom:24px;font-size:13px}.login-form label{font-size:13px}.login-form input{padding:10px 12px;font-size:14px}.login-form button[type=submit]{padding:11px;font-size:15px}.app-header{text-align:center;flex-direction:column;padding:14px 12px}.app-header h1{font-size:15px}.user-info{flex-direction:column;gap:8px}.user-info button{width:100%}.app-main{padding:16px 12px}}
