*,*::before,*::after{box-sizing:border-box}svg{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}html,body{height:100%}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:#0f172a;background-color:#f8fafc}:root{--page-bg-from:#f8fafc;--page-bg-to:#e2e8f0;--card-bg:#ffffff;--card-border:#e2e8f0;--card-radius:1rem;--text-main:#0f172a;--text-muted:#64748b;--text-soft:#94a3b8;--text-weak:#6b7280;--blue-50:#eff6ff;--blue-100:#dbeafe;--blue-500:#3b82f6;--blue-600:#2563eb;--blue-700:#1d4ed8;--green-50:#ecfdf5;--green-100:#dcfce7;--green-500:#22c55e;--green-600:#16a34a;--green-700:#15803d;--orange-50:#fff7ed;--orange-100:#ffedd5;--orange-500:#f97316;--orange-600:#ea580c;--purple-50:#faf5f6;--purple-100:#f5e8eb;--purple-600:#cd7e8e;--purple-700:#b86a7a;--yellow-50:#fefce8;--yellow-100:#fef9c3;--yellow-500:#eab308;--yellow-600:#ca8a04;--yellow-700:#a16207;--red-50:#fef2f2;--red-100:#fee2e2;--red-500:#ef4444;--red-600:#dc2626;--red-700:#b91c1c;--shadow-sm:0 1px 2px rgba(15,23,42,0.08);--shadow-md:0 4px 6px rgba(15,23,42,0.12);--shadow-lg:0 10px 15px rgba(15,23,42,0.18);--radius-lg:0.75rem;--radius-xl:1rem;--radius-full:9999px;--gap-sm:0.5rem;--gap-md:1rem;--gap-lg:1.5rem;--gap-xl:2rem;--transition-fast:0.15s cubic-bezier(0.4,0,0.2,1)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background-image:linear-gradient( to bottom right,var(--page-bg-from),var(--page-bg-to) )}.auth-card{width:100%;max-width:480px;background-color:var(--card-bg);border-radius:var(--card-radius);border:1px solid var(--card-border);box-shadow:var(--shadow-lg);padding:2rem 1.75rem 1.75rem}.auth-header{margin-bottom:1.5rem}.auth-title{margin:0 0 0.25rem;font-size:1.5rem;color:var(--text-main)}.auth-subtitle{margin:0;font-size:0.9rem;color:var(--text-muted)}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:0.35rem}.form-label{font-size:0.85rem;color:rgba(255,255,255,0.85)}.form-label-white-bg{font-size:0.85rem;color:rgba(0,0,0,0.85)}.form-required{color:var(--orange-500);margin-left:0.15rem}.form-input,.form-select{width:100%;border-radius:0.65rem;border:1px solid var(--card-border);padding:0.6rem 0.75rem;font-size:0.9rem;background-color:#f9fafb;color:var(--text-main);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}.form-input::placeholder{color:var(--text-weak)}.form-input:focus,.form-select:focus{border-color:var(--purple-600);box-shadow:0 0 0 1px rgba(205,126,142,0.25);background-color:#ffffff}.phone-group{display:flex;gap:0.5rem}.phone-group-cc{max-width:130px;flex-shrink:0}.phone-group-number{flex:1}.auth-submit{margin-top:0.5rem}.auth-footer{margin-top:1rem;font-size:0.85rem;color:var(--text-soft);text-align:center}.auth-link{color:var(--purple-600);font-weight:500;text-decoration:none}.auth-link:hover{color:var(--purple-700);text-decoration:underline}.auth-links-row{margin-top:-0.25rem;margin-bottom:0.5rem;font-size:0.82rem;display:flex;align-items:center;justify-content:space-between}.remember-me-label{display:flex;align-items:center;gap:0.4rem;font-size:0.85rem;color:var(--text-soft);cursor:pointer;user-select:none}.remember-me-label input[type="checkbox"]{width:16px;height:16px;accent-color:var(--purple-600);cursor:pointer}.remember-me-label span{line-height:1}.btn{border-radius:var(--radius-lg);border:0;font-size:0.875rem;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;padding:0.5rem 1rem;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.btn--primary{background-color:var(--purple-600);color:#ffffff;box-shadow:var(--shadow-sm)}.btn--primary:hover{background-color:var(--purple-700);box-shadow:var(--shadow-md)}.btn--outline{background-color:transparent;border:1px solid rgba(255,255,255,0.6);color:#ffffff}.btn--outline:hover{background-color:rgba(255,255,255,0.1)}.btn--full{width:100%;padding-top:0.75rem;padding-bottom:0.75rem}.top-nav-btn{border-radius:var(--radius-full);border:1px solid transparent;padding:0.4rem 0.95rem;background:transparent;font-size:0.875rem;font-weight:500;color:var(--text-soft);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.top-nav-btn--logout:hover,.top-nav-btn--logout:focus-visible{background-color:#fef2f2;border-color:#fee2e2;color:#b91c1c;box-shadow:var(--shadow-sm)}.top-nav-btn--logout:active{background-color:#fee2e2;border-color:#fecaca;color:#991b1b}@media (max-width:768px){.top-nav-btn{padding:0.5rem 0.875rem;font-size:0.8rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.top-nav-btn--logout{color:#64748b}}@media (max-width:480px){.top-nav-btn{padding:0.4rem 0.75rem;font-size:0.75rem}}.card{padding:1.5rem;margin-bottom:2rem}.card,.flying-card{background-color:var(--card-bg);border-radius:var(--card-radius);border:1px solid var(--card-border);box-shadow:var(--shadow-sm)}.card{padding:1.5rem}.flying-card{padding:1.5rem;transition:box-shadow var(--transition-fast),transform var(--transition-fast),border-color var(--transition-fast)}.flying-card:hover{box-shadow:var(--shadow-md);border-color:#ddd6fe;transform:translateY(-1px)}.card-header{margin-bottom:1rem}.card-title{display:flex;align-items:center;gap:0.6rem}.flying-cards--locked{position:relative}.flying-cards--locked .flying-card{filter:blur(4px);pointer-events:none;user-select:none}.flying-cards-lock-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.5rem;z-index:10;background:rgba(255,255,255,0.3);border-radius:var(--card-radius)}.flying-cards-lock-overlay svg{width:2rem;height:2rem;color:var(--text-muted)}.flying-cards-lock-overlay span{font-size:0.875rem;color:var(--text-muted);font-weight:500}/* Checkbox de aceite */.form-field--checkbox{margin-top:0.5rem}.checkbox-label{display:flex;align-items:flex-start;gap:0.625rem;cursor:pointer}.checkbox-label input[type="checkbox"]{width:1.125rem;height:1.125rem;margin-top:0.125rem;accent-color:var(--purple-600);cursor:pointer;flex-shrink:0}.checkbox-text{font-size:0.9rem;color:var(--text-main);line-height:1.4}.checkbox-text a{color:var(--purple-600);text-decoration:underline}.checkbox-text a:hover{color:var(--purple-700)}