@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";
:root{--primary:#3632b7;--primary-light:#504ed0;--primary-lighter:#7c7aff;--primary-lightest:#eff4ff;--primary-dark:#2d2994;--primary-border:#c7d7fd;--accent:#f472b6;--accent-light:#f9a8d4;--accent-lighter:#fce7f3;--ai-gradient:linear-gradient(135deg, #3632b7, #504ed0);--ai-shadow:0 6px 16px -6px #3632b773;--auth-gradient:linear-gradient(135deg, #003d9b 0%, #6d28d9 55%, #db2777 100%);--auth-gradient-shadow:0 6px 16px -6px #6d28d973;--brand-gradient:linear-gradient(135deg, #8cc63f 0%, #5a9e42 55%, #b56a45 100%);--brand-gradient-shadow:0 6px 16px -6px #5a9e4273;--text-heading:#0b1c30;--text-body:#464555;--text-secondary:#64748b;--text-muted:#94a3b8;--text-disabled:#c7c4d8;--surface:#fff;--surface-subtle:#f8f9fb;--surface-page:#f8f9ff;--surface-overlay:#0b1c3080;--border:#e2e8f0;--border-light:#f1f5f9;--white:#fff;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--success:#10b981;--success-fg:#15803d;--success-bg:#f0fdf4;--success-bg-alt:#e2f0e8;--success-light:#d1fae5;--danger:#ef4444;--danger-fg:#be123c;--danger-dark:#9f1239;--danger-bg:#fff1f2;--danger-light:#fee2e2;--warning:#f59e0b;--warning-fg:#92400e;--warning-fg-alt:#c2410c;--warning-bg:#fff7ed;--warning-bg-alt:#fef3c7;--warning-light:#fef3c7;--info:#3b82f6;--info-fg:#0369a1;--info-bg:#f0f9ff;--info-light:#dbeafe;--purple-fg:#7e22ce;--purple-bg:#fdf4ff;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -1px #0000000a;--shadow-lg:0 10px 15px -3px #00000012, 0 4px 6px -2px #00000008;--shadow-xl:0 20px 25px -5px #00000012, 0 10px 10px -5px #00000008;--shadow-card:0 4px 16px -4px #0b1c3012;--shadow-primary:0 4px 12px -4px #3632b766;--radius-xs:4px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.35s ease;--sidebar-width:260px;--sidebar-collapsed-width:72px;--header-height:64px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display:"Manrope", "Inter", -apple-system, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;max-width:100vw;font-size:16px;overflow-x:hidden}body{font-family:var(--font-sans);color:var(--text-body);background:var(--surface-page);max-width:100vw;min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:var(--primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--primary-dark)}img{max-width:100%;height:auto}h1,h2,h3,h4,h5,h6{color:var(--text-heading);font-weight:700;line-height:1.3;font-family:var(--font-display)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-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}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-muted{color:var(--gray-500)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.w-full{width:100%}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.hidden{display:none}.card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-100);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base);padding:1.5rem}.card:hover{box-shadow:var(--shadow-md)}.card-body{padding:1.5rem}.card-header{border-bottom:1px solid var(--gray-100);padding:1.25rem 1.5rem;font-weight:600}.btn{font-size:.875rem;font-weight:600;font-family:var(--font-sans);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;line-height:1.4;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--white);border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--white);color:var(--gray-700);border-color:var(--gray-200)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.btn-danger{background:var(--danger);color:var(--white);border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger-fg);transform:translateY(-1px)}.btn-ghost{color:var(--gray-600);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--gray-800)}.btn-sm{padding:.375rem .875rem;font-size:.8125rem}.btn-lg{padding:.75rem 1.75rem;font-size:1rem}.btn-icon{border-radius:var(--radius-md);padding:.5rem}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-label{color:var(--gray-700);font-size:.875rem;font-weight:500}.form-input,.form-select,.form-textarea{width:100%;font-size:.875rem;font-family:var(--font-sans);border:1.5px solid var(--gray-200);border-radius:var(--radius-md);background:var(--white);color:var(--gray-800);transition:all var(--transition-fast);outline:none;padding:.625rem .875rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-lightest)}.form-input[readonly],.form-select:disabled,.form-input:disabled{background:var(--surface-subtle);color:var(--text-secondary);cursor:not-allowed}.form-input::placeholder{color:var(--gray-400)}.form-textarea{resize:vertical;min-height:80px}.form-error{color:var(--danger);margin-top:.25rem;font-size:.75rem}.form-hint{color:var(--gray-500);font-size:.75rem}.table-container{border-radius:var(--radius-lg);border:1px solid var(--gray-100);background:var(--white);width:100%;overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{background:var(--gray-50);text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);text-align:left;border-bottom:1px solid var(--gray-100);white-space:nowrap;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.table td{border-bottom:1px solid var(--gray-50);color:var(--gray-700);padding:.875rem 1rem;font-size:.875rem}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--primary-lightest)}.badge{border-radius:var(--radius-full);letter-spacing:.02em;text-overflow:ellipsis;white-space:nowrap;align-items:center;max-width:100%;padding:.2rem .375rem;font-size:.6875rem;font-weight:600;display:inline-flex;overflow:hidden}.badge-primary{background:var(--primary-lightest);color:var(--primary-dark)}.badge-success{background:var(--success-bg);color:var(--success-fg)}.badge-warning{background:var(--warning-bg-alt);color:var(--warning-fg)}.badge-danger{background:var(--danger-bg);color:var(--danger-fg)}.badge-info{background:var(--info-bg);color:var(--info-fg)}.badge-purple{background:var(--purple-bg);color:var(--purple-fg)}.modal-overlay{background:var(--surface-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;animation:.25s slideUp;overflow-y:auto}.modal-lg{max-width:720px}.modal-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h3{font-size:1.125rem}.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid var(--gray-100);justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.avatar{border-radius:var(--radius-full);background:var(--primary-lighter);width:40px;height:40px;color:var(--primary-dark);flex-shrink:0;justify-content:center;align-items:center;font-size:.875rem;font-weight:600;display:flex;overflow:hidden}.avatar img{object-fit:cover;object-position:top;width:100%;height:100%}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-lg{width:56px;height:56px;font-size:1.25rem}.avatar-xl{width:80px;height:80px;font-size:1.75rem}.stat-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-100);box-shadow:var(--shadow-xs);transition:all var(--transition-base);padding:1.25rem}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card .stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:.75rem;font-size:1.25rem;display:flex}.stat-card .stat-value{color:var(--gray-900);font-size:1.75rem;font-weight:800;line-height:1}.stat-card .stat-label{color:var(--gray-500);margin-top:.25rem;font-size:.8125rem;font-weight:500}.tab-group{background:var(--gray-100);border-radius:var(--radius-lg);gap:.5rem;width:fit-content;max-width:100%;padding:.375rem;display:flex;overflow-x:auto}.tab-btn{color:var(--gray-600);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-base);font-size:.875rem;font-weight:500;font-family:var(--font-sans);white-space:nowrap;background:0 0;border:none;align-items:center;gap:.5rem;padding:.625rem 1.25rem;display:flex}.tab-btn:hover{color:var(--gray-900);background:#ffffff80}.tab-btn.active{background:var(--white);color:var(--primary);box-shadow:var(--shadow-sm);font-weight:600}.tab-panel{animation:.3s fadeIn;display:none}.tab-panel.active{display:block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.page-title{color:var(--text-heading);font-size:1.5rem;font-weight:800;font-family:var(--font-display);letter-spacing:-.02em}.page-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.8125rem}.page-actions{align-items:center;gap:.75rem;display:flex}.search-bar{position:relative}.search-bar input{padding-left:2.5rem}.search-bar .search-icon{color:var(--gray-400);font-size:1rem;position:absolute;top:50%;left:.875rem;transform:translateY(-50%)}.filter-bar{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.empty-state{text-align:center;color:var(--gray-400);padding:3rem 1.5rem}.empty-state .empty-icon{margin-bottom:1rem;font-size:3rem}.empty-state h3{color:var(--gray-600);margin-bottom:.5rem;font-size:1.125rem}.empty-state p{color:var(--gray-400);font-size:.875rem}.spinner{border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}.spinner-lg{border-width:4px;width:40px;height:40px}.loading-page{justify-content:center;align-items:center;min-height:60vh;display:flex}.toast-container{z-index:2000;flex-direction:column;gap:.5rem;display:flex;position:fixed;top:1.5rem;right:1.5rem}.toast{border-radius:var(--radius-md);box-shadow:var(--shadow-lg);align-items:center;gap:.75rem;min-width:280px;max-width:420px;padding:.875rem 1.25rem;font-size:.875rem;font-weight:500;animation:.3s slideInRight;display:flex}.toast-success{background:var(--success);color:var(--white)}.toast-error{background:var(--danger);color:var(--white)}.toast-info{background:var(--info);color:var(--white)}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-active{border-radius:var(--radius-full);white-space:nowrap;background:var(--success-bg-alt);color:var(--success-fg);padding:.2rem .65rem;font-size:.72rem;font-weight:700;display:inline-block}.status-inactive{border-radius:var(--radius-full);white-space:nowrap;background:var(--gray-100);color:var(--gray-600);padding:.2rem .65rem;font-size:.72rem;font-weight:700;display:inline-block}.status-pending{border-radius:var(--radius-full);white-space:nowrap;background:var(--warning-bg-alt);color:var(--warning-fg);padding:.2rem .65rem;font-size:.72rem;font-weight:700;display:inline-block}.status-approved{border-radius:var(--radius-full);white-space:nowrap;background:var(--success-bg);color:var(--success-fg);padding:.2rem .65rem;font-size:.72rem;font-weight:700;display:inline-block}.status-rejected{border-radius:var(--radius-full);white-space:nowrap;background:var(--danger-bg);color:var(--danger-fg);padding:.2rem .65rem;font-size:.72rem;font-weight:700;display:inline-block}.status-invited{border-radius:var(--radius-full);white-space:nowrap;color:#7b2f00;background:#ffdbcc;padding:.2rem .65rem;font-size:.72rem;font-weight:700;display:inline-block}.section-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-size:.6875rem;font-weight:700}.notice{border-radius:var(--radius-sm);align-items:flex-start;gap:.625rem;padding:.625rem .875rem;font-size:.8125rem;font-weight:500;line-height:1.5;display:flex}.notice-info{background:var(--primary-lightest);border:1px solid var(--primary-border);color:var(--primary)}.notice-success{background:var(--success-bg);color:var(--success-fg);border:1px solid #bbf7d0}.notice-warning{background:var(--warning-bg-alt);color:var(--warning-fg);border:1px solid #fde68a}.notice-danger{background:var(--danger-bg);color:var(--danger-fg);border:1px solid #fecaca}.divider{background:var(--border);border:none;height:1px;margin:0}.code-badge{border-radius:var(--radius-xs);background:var(--surface-subtle);color:var(--text-secondary);border:1px solid var(--border);padding:.15rem .5rem;font-family:monospace;font-size:.72rem;font-weight:700;display:inline-block}.code-badge--brand{background:var(--primary-lightest);color:var(--primary);border-color:var(--primary-border)}.stat-strip{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.stat-strip-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.25rem}.stat-strip-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.68rem;font-weight:700}.stat-strip-value{font-size:1.6rem;font-weight:800;font-family:var(--font-display)}.btn-warning{background:var(--warning);color:var(--white);border-color:var(--warning)}.btn-warning:hover:not(:disabled){background:var(--warning-fg);border-color:var(--warning-fg);transform:translateY(-1px)}.btn-success{background:var(--success);color:var(--white);border-color:var(--success)}.btn-success:hover:not(:disabled){background:var(--success-fg);border-color:var(--success-fg);transform:translateY(-1px)}.btn-info{background:var(--info);color:var(--white);border-color:var(--info)}.btn-info:hover:not(:disabled){background:var(--info-fg);border-color:var(--info-fg);transform:translateY(-1px)}.btn-ai{background:var(--ai-gradient);color:var(--white);box-shadow:var(--ai-shadow);border:none;font-weight:600}.btn-ai:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px -6px #3632b78c}.brand-gradient-bg{background:var(--brand-gradient)}.button{background:var(--brand-gradient);color:var(--white);box-shadow:var(--brand-gradient-shadow);border:none;font-weight:600}.button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px -6px #5a9e428c}.button:disabled{background:var(--gray-300);color:var(--gray-600);box-shadow:none;cursor:not-allowed;opacity:1}.confirm-icon-wrap{border-radius:var(--radius-full);justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1.5rem;display:flex}.confirm-icon-wrap--danger{background:var(--danger-light)}.confirm-icon-wrap--warning{background:var(--warning-light)}.confirm-icon-wrap--success{background:var(--success-light)}.confirm-icon-wrap--info{background:var(--info-light)}.confirm-modal-body{text-align:center;padding:2rem 2rem 1rem}.confirm-modal-message{color:var(--text-secondary);margin:0;font-size:.9375rem;line-height:1.5}.confirm-modal-input-wrap{padding:0 2rem 1rem}.confirm-modal-footer{justify-content:center;gap:.75rem;padding:1rem 2rem 2rem;display:flex}.confirm-cancel-btn{border-radius:var(--radius-md);border:2px solid var(--border);background:var(--white);color:var(--text-body);cursor:pointer;transition:all var(--transition-fast);min-width:120px;font-size:.9rem;font-weight:600;font-family:var(--font-sans);padding:.75rem 1.5rem}.confirm-cancel-btn:hover{background:var(--surface-subtle);border-color:var(--gray-300)}.confirm-confirm-btn{border-radius:var(--radius-md);color:var(--white);cursor:pointer;transition:all var(--transition-fast);min-width:120px;font-size:.9rem;font-weight:600;font-family:var(--font-sans);border:none;padding:.75rem 1.5rem}.confirm-confirm-btn:disabled{opacity:.6;cursor:not-allowed}.confirm-confirm-btn:not(:disabled):hover{transform:translateY(-2px)}.pdf-modal-inner{background:var(--surface);border-radius:var(--radius-md);flex-direction:column;width:90vw;max-width:960px;height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #00000059}.pdf-modal-header{border-bottom:1px solid var(--border);background:var(--surface-subtle);flex-shrink:0;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.pdf-modal-title{color:var(--text-heading);font-size:.875rem;font-weight:700}.pdf-iframe{border:none;flex:1;width:100%}.lock-screen{text-align:center;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:2rem;display:flex}.lock-icon-wrap{border-radius:var(--radius-full);justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:1.5rem;display:flex}.lock-icon-wrap--danger{background:var(--danger-light)}.lock-icon-wrap--expired{background:var(--danger-light);border:4px solid #fecaca;width:96px;height:96px}.lock-title{color:var(--text-heading);margin-bottom:.75rem;font-size:1.5rem;font-weight:700}.lock-title--expired{letter-spacing:-.01em;margin-bottom:.5rem;font-size:1.625rem;font-weight:800}.lock-message{color:var(--text-secondary);max-width:400px;margin-bottom:1.5rem;font-size:.9375rem;line-height:1.6}.break-cell-empty{color:var(--text-disabled)}.break-cell-wrap{align-items:center;gap:.5rem;display:inline-flex;position:relative}.break-show-all-btn{border-radius:var(--radius-full);background:var(--warning-bg-alt);color:var(--warning-fg);cursor:pointer;white-space:nowrap;font-size:.6875rem;font-weight:700;line-height:1.3;font-family:var(--font-sans);border:none;padding:.15rem .55rem}.break-popover{background:var(--surface);border:1px solid var(--primary-border);border-radius:var(--radius-md);z-index:20;min-width:200px;max-width:280px;color:var(--text-heading);padding:.625rem .75rem;position:absolute;top:calc(100% + 6px);box-shadow:0 16px 32px -10px #0b1c302e}.break-popover-title{color:var(--text-body);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.4rem;font-size:.6875rem;font-weight:800}.break-popover-list{flex-direction:column;gap:.3rem;margin:0;padding:0;list-style:none;display:flex}.break-popover-item{justify-content:space-between;gap:.75rem;font-size:.8125rem;display:flex}.break-popover-range{color:var(--text-body)}.break-popover-dur{color:var(--warning-fg);font-weight:700}.reaction-bar{flex-wrap:wrap;display:flex}.reaction-bar--compact{gap:.25rem}.reaction-bar--normal{gap:.375rem}.reaction-btn-wrap{position:relative}.reaction-btn{border-radius:var(--radius-full);background:var(--gray-100);color:var(--text-body);cursor:pointer;transition:transform .1s, background var(--transition-fast);font-weight:600;line-height:1;font-family:var(--font-sans);border:1.5px solid #0000;align-items:center;gap:.3rem;display:inline-flex}.reaction-btn--normal{padding:.35rem .65rem;font-size:.875rem}.reaction-btn--compact{padding:.2rem .5rem;font-size:.8125rem}.reaction-btn--active{border-color:var(--primary);background:var(--primary-lightest);color:var(--primary-dark)}.reaction-btn:active{transform:scale(.94)}.reaction-emoji--normal{font-size:1.05rem}.reaction-emoji--compact{font-size:.95rem}.reaction-tooltip{background:var(--text-heading);color:var(--white);border-radius:var(--radius-md);white-space:nowrap;pointer-events:none;z-index:10;max-width:320px;padding:.5rem .75rem;font-size:.75rem;font-weight:500;line-height:1.45;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 8px 24px -6px #0b1c3059}.reaction-tooltip-label{text-transform:uppercase;letter-spacing:.06em;opacity:.7;margin-bottom:4px;font-size:.6875rem;font-weight:700}.reaction-tooltip-names{flex-direction:column;gap:2px;display:flex}.reaction-tooltip-more{opacity:.7}.reaction-tooltip-arrow{border-left:5px solid #0000;border-right:5px solid #0000;border-top:5px solid var(--text-heading);width:0;height:0;position:absolute;top:100%;left:50%;transform:translate(-50%)}.comments-wrap{flex-direction:column;gap:.75rem;display:flex}.comments-header{color:var(--text-body);text-transform:uppercase;letter-spacing:.08em;font-size:.6875rem;font-weight:800}.comments-count{color:var(--primary)}.comments-list{flex-direction:column;gap:.625rem;max-height:260px;padding-right:4px;display:flex;overflow-y:auto}.comments-loading{color:var(--text-muted);font-size:.8125rem}.comment-item{align-items:flex-start;gap:.625rem;display:flex}.comment-avatar{border-radius:var(--radius-full);object-fit:cover;object-position:top;flex-shrink:0;width:32px;height:32px}.comment-avatar-initials{border-radius:var(--radius-full);background:var(--primary-lightest);width:32px;height:32px;color:var(--primary-dark);flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.comment-body{flex:1;min-width:0}.comment-bubble{background:var(--gray-100);border-radius:var(--radius-md);padding:.5rem .75rem;position:relative}.comment-bubble-top{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.comment-author{color:var(--text-heading);font-size:.8125rem;font-weight:700}.comment-delete-btn{color:var(--danger-dark);cursor:pointer;border-radius:var(--radius-xs);background:0 0;border:none;align-items:center;padding:2px;display:inline-flex}.comment-content{color:var(--text-heading);white-space:pre-wrap;word-break:break-word;margin-top:2px;font-size:.875rem;line-height:1.5}.comment-time{color:var(--text-muted);margin-top:2px;margin-left:.25rem;font-size:.6875rem}.comment-form{flex-direction:column;gap:.5rem;display:flex}.comment-textarea{resize:vertical;border-radius:var(--radius-md);border:1px solid var(--primary-border);background:var(--surface);min-height:40px;max-height:160px;font-size:.875rem;font-family:var(--font-sans);color:var(--text-heading);box-sizing:border-box;outline:none;width:100%;padding:.55rem .75rem}.comment-form-footer{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.comment-counter{color:var(--text-muted);font-size:.6875rem}.comment-submit-btn{border-radius:var(--radius-md);background:var(--ai-gradient);color:var(--white);cursor:pointer;font-size:.8125rem;font-weight:700;font-family:var(--font-sans);border:none;padding:.5rem 1rem;transition:transform .1s}.comment-submit-btn:disabled{background:var(--primary-lighter);cursor:not-allowed}.dashboard-shell{min-height:100vh;display:flex}.dashboard-main{box-sizing:border-box;flex:1;min-width:0;padding:0 2rem 2rem;overflow-x:hidden}.impersonation-banner{height:40px;color:var(--white);z-index:200;letter-spacing:.01em;background:linear-gradient(90deg,#7c3aed,#4f46e5);justify-content:center;align-items:center;gap:1rem;font-size:.8125rem;font-weight:600;display:flex;position:fixed;top:0;left:0;right:0}.impersonation-stop-btn{color:var(--white);border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.02em;font-size:.75rem;font-weight:700;font-family:var(--font-sans);background:#fff3;border:1px solid #fff6;padding:.25rem .75rem}.dashboard-topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:50;height:60px;transition:left var(--transition-base), top var(--transition-base);justify-content:flex-end;align-items:center;padding:0 2rem;display:flex;position:fixed;right:0;box-shadow:0 1px 4px #0000000f}.new-layout-preview-link{color:var(--primary);background:var(--primary-lightest);border:1px solid var(--primary-border);border-radius:var(--radius-full);transition:all var(--transition-fast);align-items:center;margin-right:auto;padding:.375rem .875rem;font-size:.8125rem;font-weight:600;text-decoration:none;display:flex}.new-layout-preview-link:hover{background:var(--primary-lighter);color:var(--white);border-color:var(--primary-lighter)}.pending-approvals-link{align-items:center;gap:.375rem;margin-right:1rem;text-decoration:none;display:flex;position:relative}.pending-approvals-badge{background:var(--warning);min-width:18px;height:18px;color:var(--white);border-radius:var(--radius-full);justify-content:center;align-items:center;padding:0 4px;font-size:.6rem;font-weight:800;line-height:1;display:flex;position:absolute;top:-6px;right:-8px}.unset-salary-link{align-items:center;gap:.375rem;margin-right:1rem;text-decoration:none;display:flex;position:relative}.unset-salary-icon{color:#c2410c;background:#fff7ed;border:1.5px solid #fed7aa;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9375rem;font-weight:800;line-height:1;display:flex}.unset-salary-link:hover .unset-salary-icon{background:#ffedd5;border-color:#fb923c}.unset-salary-badge{color:#fff;background:#dc2626;border-radius:999px;justify-content:center;align-items:center;min-width:17px;height:17px;padding:0 3px;font-size:.6rem;font-weight:800;line-height:1;display:flex;position:absolute;top:-5px;right:-7px}.incomplete-profile-link{align-items:center;gap:.375rem;margin-right:1rem;text-decoration:none;display:flex;position:relative}.incomplete-profile-icon{background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;line-height:1;display:flex}.incomplete-profile-link:hover .incomplete-profile-icon{background:#dbeafe;border-color:#93c5fd}.incomplete-profile-badge{color:#fff;background:#2563eb;border-radius:999px;justify-content:center;align-items:center;min-width:17px;height:17px;padding:0 3px;font-size:.6rem;font-weight:800;line-height:1;display:flex;position:absolute;top:-5px;right:-7px}.timeclock-display{font-family:var(--font-display);font-variant-numeric:tabular-nums;color:var(--text-heading);background:var(--primary-lightest);border-radius:var(--radius-sm);white-space:nowrap;padding:.375rem .75rem;font-size:.9375rem;font-weight:700}.timeclock-btn{background:var(--ai-gradient);border-color:var(--primary);color:var(--white);white-space:nowrap;min-width:90px}.rl-page{background:var(--surface-page);box-sizing:border-box;min-height:100vh;margin:-2rem;padding:2rem}.rl-table-wrap{background:var(--surface);border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-card);overflow:hidden}.rl-table{border-collapse:collapse;width:100%;font-size:.8125rem}.rl-table thead tr{background:var(--gray-300)}.rl-table thead th{background:var(--gray-300);text-align:left;color:var(--gray-800);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;border:none;padding:.5rem .875rem;font-size:.6875rem;font-weight:800}.rl-table tbody tr{transition:background var(--transition-fast);border-bottom:1px solid #c7c4d826}.rl-table tbody tr:last-child{border-bottom:none}.rl-table tbody tr:hover{background:var(--surface-page)}.rl-table tbody td{color:var(--text-heading);vertical-align:middle;padding:.5rem .875rem}.rl-btn{border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;width:30px;height:30px;display:inline-flex}.rl-btn-edit{background:var(--primary-lightest);color:var(--primary-dark)}.rl-btn-edit:hover{background:#c9c5f8}.rl-btn-del{background:var(--danger-light);color:var(--danger-dark)}.rl-btn-del:hover{background:#ffb4aa}.rl-btn-members{background:var(--info-light);color:var(--info-fg)}.rl-btn-members:hover{background:#b8d7ff}.rl-btn-access{background:var(--success-light);color:var(--success-fg)}.rl-btn-access:hover{background:#a7f3d0}.rl-btn-actions{gap:.5rem;display:flex}.rl-member-row{border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:.75rem;padding:.625rem .75rem;display:flex}.rl-member-row:hover{background:var(--primary-lightest)}.rl-member-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.rl-member-row--select-all{background:var(--primary-lightest);font-weight:700}.rl-member-avatar{border-radius:var(--radius-full);background:var(--ai-gradient);width:32px;height:32px;color:var(--white);flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex;overflow:hidden}.rl-member-name{color:var(--text-heading);text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:600;overflow:hidden}.rl-member-meta{color:var(--text-body);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.rl-member-count{color:var(--text-body);margin-left:auto;font-size:.8125rem}.rl-members-scroll{border:1px solid var(--border-light);border-radius:var(--radius-md);flex-direction:column;gap:.25rem;max-height:380px;padding:.5rem;display:flex;overflow-y:auto}.rl-empty-cell{text-align:center;color:var(--text-body);padding:3rem}.rl-permission-tag{background:var(--primary-lightest);color:var(--primary);border-radius:var(--radius-xs);padding:2px 8px;font-size:.75rem;font-weight:600}.rl-access-preview{background:var(--surface-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:.75rem 1rem;font-size:.8125rem}.rl-access-tags{flex-wrap:wrap;gap:.25rem;margin-top:.375rem;display:flex}.rl-access-result--ok{border-radius:var(--radius-sm);background:var(--success-light);color:var(--success-fg);padding:.625rem 1rem;font-size:.875rem;font-weight:600}.rl-access-result--err{border-radius:var(--radius-sm);background:var(--danger-light);color:var(--danger-dark);padding:.625rem 1rem;font-size:.875rem;font-weight:600}.rl-members-count{align-items:center;gap:.375rem;display:flex}.rl-members-icon{color:var(--text-disabled)}@media (max-width:1024px){.rl-page{margin:0;padding:1rem}}.rp-page{background:var(--surface-page);box-sizing:border-box;min-height:100vh;margin:-2rem;padding:2rem}.rp-page .table-container{background:var(--surface);border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-card);overflow:hidden}.rp-page .table{border-collapse:collapse;width:100%;font-size:.8125rem}.rp-page .table thead tr{background:var(--gray-300)}.rp-page .table thead th{background:var(--gray-300);text-align:left;color:var(--gray-800);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;border:none;padding:.5rem .875rem;font-size:.6875rem;font-weight:800}.rp-page .table tbody tr{transition:background var(--transition-fast);border-bottom:1px solid #c7c4d826}.rp-page .table tbody tr:last-child{border-bottom:none}.rp-page .table tbody tr:hover{background:var(--surface-page)}.rp-page .table tbody td{color:var(--text-heading);vertical-align:middle;padding:.5rem .875rem}.rp-actions{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.rp-search{flex:1;min-width:260px}.rp-search-icon{color:var(--text-muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.rp-avatar-cell{align-items:center;gap:.5rem;display:flex}.rp-avatar{border-radius:var(--radius-sm);background:var(--ai-gradient);width:32px;height:32px;color:var(--white);flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex;overflow:hidden}.rp-mono{font-family:monospace}.rp-coe-details{background:var(--surface-subtle);border-radius:var(--radius-sm);flex-direction:column;gap:.75rem;margin-bottom:1.5rem;padding:15px;display:flex}.rp-coe-details h4{color:var(--text-secondary);margin:0;font-size:.875rem}.rp-template-row{align-items:center;gap:.5rem;display:flex}.rp-search-dropdown{border:1px solid var(--border);border-radius:var(--radius-xs);max-height:150px;overflow-y:auto}.rp-search-option{cursor:pointer;border-bottom:1px solid var(--border-light);color:var(--text-heading);padding:8px 12px;font-size:.875rem}.rp-search-option:hover{background:var(--surface-subtle)}.rp-search-option:last-child{border-bottom:none}.rp-col-toggle{flex-direction:column;gap:.75rem;display:flex}.rp-col-toggle label{cursor:pointer;color:var(--text-body);align-items:center;gap:.5rem;font-size:.875rem;display:flex}.rp-col-toggle label[disabled-label]{color:var(--text-muted);cursor:not-allowed}.rp-selected-note{color:var(--primary);margin-top:.5rem;font-size:.85rem}.rp-loading-templates,.rp-placeholders-hint{color:var(--text-muted);margin-top:4px;font-size:.7rem}@media (max-width:1024px){.rp-page{margin:0;padding:1rem}}@media screen{.print-only-header,.print-only-block{display:none!important}.bio-section{background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:20px;padding:20px}.bio-section h3{border-bottom:1px solid var(--border);margin-bottom:15px;padding-bottom:10px;font-size:1.125rem}.bio-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px;display:grid}.table .col-hidden{display:none!important}}@media print{@page{margin:0}body{margin:0;padding:8mm;background:#fff!important}aside,.sidebar,.sidebar-overlay,.mobile-header,.page-header,.filter-bar,button,.hide-print{display:none!important}main{background:#fff!important;flex:none!important;width:100%!important;margin:0!important;padding:0!important}#printable{width:100%;display:block}.print-only-header{text-align:left;border-bottom:2px solid #000;margin-bottom:20px;padding-bottom:10px;display:block!important}.printable-table-container{box-shadow:none;background:0 0;border:none;padding:0;overflow:visible}.printable-table{border-collapse:collapse;page-break-inside:auto;width:100%}.printable-table tr{page-break-inside:avoid;page-break-after:auto}.printable-table th{color:#000;-webkit-print-color-adjust:exact;print-color-adjust:exact;border:1px solid #999;padding:8px;font-size:11pt;background:#f0f0f0!important}.printable-table td{color:#000;border:1px solid #999;padding:6px;font-size:10pt}.printable-table .col-hidden{display:none!important}.badge{padding:0;font-weight:400;color:#000!important;background:0 0!important;border:none!important}.bio-section{page-break-inside:avoid;margin-bottom:25px}.bio-section h3{color:#333;border-bottom:1px solid #ccc;margin-bottom:10px;padding-bottom:5px;font-size:16px}.bio-grid{grid-template-columns:1fr 1fr;gap:10px;font-size:14px;display:grid}}.atn-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a8c;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.atn-modal{background:var(--surface);border-radius:var(--radius-lg);flex-direction:column;width:100%;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 24px 60px -12px #0b1c3059}.atn-modal-header{border-bottom:1px solid var(--border-light);padding:1.25rem 1.5rem}.atn-modal-title{color:var(--text-heading);font-size:1.0625rem;font-weight:800;font-family:var(--font-display);margin:0}.atn-modal-sub{color:var(--text-secondary);margin-top:3px;font-size:.8125rem}.atn-modal-close{border-radius:var(--radius-sm);background:var(--surface-subtle);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.atn-modal-body{flex:1;padding:1.25rem 1.5rem;overflow:auto}.atn-tabs{gap:4px;margin-top:.875rem;display:flex}.atn-tab{border-radius:var(--radius-sm);cursor:pointer;font-size:.8125rem;font-weight:700;font-family:var(--font-sans);color:var(--text-secondary);background:0 0;border:none;padding:.4rem .875rem}.atn-tab--active{background:var(--primary-lightest);color:var(--primary-dark)}.atn-stat-grid{grid-template-columns:repeat(3,1fr);gap:.625rem;margin-bottom:1.25rem;display:grid}.atn-stat{background:var(--surface-subtle);border:1px solid var(--border);border-radius:var(--radius-md);padding:.75rem 1rem}.atn-stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.6875rem;font-weight:700}.atn-stat-value{color:var(--text-heading);font-size:1.125rem;font-weight:800;font-family:var(--font-display)}.atn-stat-sub{color:var(--text-muted);margin-top:2px;font-size:.75rem}.atn-section{margin-bottom:1.25rem}.atn-section-head{align-items:center;gap:.5rem;margin-bottom:.625rem;display:flex}.atn-section-icon{color:var(--primary-dark)}.atn-section-title{color:var(--gray-700);text-transform:uppercase;letter-spacing:.05em;font-size:.8125rem;font-weight:700}.atn-info-card{background:var(--surface-subtle);border:1px solid var(--border);border-radius:var(--radius-md);padding:.75rem 1rem}.atn-info-card--leave{background:var(--info-bg);border-color:#bfdbfe}.atn-info-card--holiday{background:var(--warning-bg-alt);border-color:#fcd34d}.atn-info-card--ot{background:var(--success-bg);border-color:#86efac}.atn-info-card--nsd{background:var(--purple-bg);border-color:#d8b4fe}.atn-time-grid{grid-template-columns:1fr 1fr;gap:.625rem;display:grid}.atn-time-slot-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.6875rem;font-weight:700}.atn-time-slot-value{color:var(--text-heading);font-weight:700}.atn-shift-grid{color:var(--text-secondary);grid-template-columns:repeat(2,1fr);gap:.375rem;font-size:.8125rem;display:grid}.atn-manual-tag{color:var(--primary-dark);background:var(--primary-lightest);border-radius:var(--radius-xs);margin-top:.375rem;padding:4px 10px;font-size:.75rem;display:inline-block}.atn-loading,.atn-empty{text-align:center;color:var(--text-secondary);padding:2rem;font-size:.875rem}.atn-error{color:var(--danger-fg);background:var(--danger-light);border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.875rem}.atn-timeline{position:relative}.atn-timeline-line{background:linear-gradient(180deg, var(--text-disabled), var(--border-light));width:2px;position:absolute;top:8px;bottom:8px;left:19px}.atn-timeline-item{align-items:flex-start;gap:.875rem;display:flex;position:relative}.atn-timeline-item+.atn-timeline-item{margin-top:1.25rem}.atn-timeline-dot{border-radius:var(--radius-full);z-index:1;border:3px solid var(--surface);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative}.atn-timeline-content{flex:1;padding-top:4px}.atn-timeline-header{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:2px;display:flex}.atn-timeline-action{color:var(--text-heading);font-size:.875rem;font-weight:700}.atn-timeline-source{background:var(--border-light);color:var(--primary-dark);border-radius:var(--radius-full);align-items:center;gap:4px;padding:1px 8px;font-size:.6875rem;font-weight:600;display:inline-flex}.atn-timeline-time{color:var(--text-muted);font-size:.75rem}.atn-timeline-actor{color:var(--text-secondary);font-size:.8125rem}.atn-timeline-actor em{color:var(--text-muted)}.atn-timeline-details{background:var(--surface-subtle);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--gray-700);white-space:pre-wrap;margin-top:.5rem;padding:.5rem .75rem;font-size:.8125rem}.atn-header-row{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.atn-badge-row{flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;display:flex}.atn-date-label{color:var(--text-secondary);font-size:.8125rem}.atn-status-badge{border-radius:var(--radius-full);padding:2px 10px;font-size:.75rem;font-weight:700}.atn-holiday-badge{border-radius:var(--radius-full);background:var(--warning-bg-alt);color:var(--warning-fg);padding:2px 10px;font-size:.75rem;font-weight:700}.desktop-timeclock{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.mobile-timeclock{background:var(--surface);border-top:1px solid var(--border);z-index:100;align-items:center;gap:.75rem;padding:.75rem 1rem;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 12px #0000001a}.timeclock-feedback--ok{color:var(--success-fg);white-space:nowrap;font-size:.8125rem;font-weight:600}.timeclock-feedback--err{color:var(--danger);white-space:nowrap;font-size:.8125rem;font-weight:600}.timeclock-spinner{border-width:2px;width:16px;height:16px}.timeclock-spinner--mobile{border-width:2px;width:18px;height:18px;margin:0 auto}@media (max-width:768px){.desktop-timeclock{display:none!important}.mobile-timeclock{display:flex!important}main.dashboard-main{padding-bottom:80px!important}}@media (min-width:769px){.desktop-timeclock{display:flex!important}.mobile-timeclock{display:none!important}}@media (max-width:1024px){h1{font-size:1.5rem}.dashboard-main{padding-top:calc(var(--header-height) + 1.5rem)!important;box-sizing:border-box!important;width:100%!important;max-width:100vw!important;margin-left:0!important;padding-left:1rem!important;padding-right:1rem!important;overflow-x:hidden!important}.mobile-header{display:flex!important}.sidebar-container{transform:translate(-100%);width:260px!important}.sidebar-container.sidebar-open{transform:translate(0)}.sidebar-close-btn{display:flex!important}.collapse-toggle-area{display:none!important}}@media (max-width:768px){.page-header{flex-direction:column!important;align-items:flex-start!important}.page-title,.page-subtitle{text-align:left!important;width:100%!important}.page-actions,.filter-bar{flex-wrap:wrap;width:100%}.dashboard-main [style*="grid-template-columns: repeat(3"],.dashboard-main [style*="grid-template-columns: repeat(4"],.dashboard-main [style*="grid-template-columns: 1fr 1fr 1fr 1fr"],.dashboard-main [style*="grid-template-columns: 1fr 1fr 1fr"]{grid-template-columns:repeat(2,minmax(0,1fr))!important}.stat-card{min-width:0}.stat-card .stat-value{font-size:1.5rem}.table-container{-webkit-overflow-scrolling:touch;max-width:100%;overflow-x:auto!important}.table th,.table td{padding:.625rem .75rem;font-size:.8125rem}.tab-group{width:100%;max-width:100%;overflow-x:auto}.modal{box-sizing:border-box;max-width:calc(100vw - 1rem)!important;margin:.5rem!important}.modal-body{padding:1rem}}@media (max-width:480px){.container{padding:0 1rem}.btn{padding:.5rem 1rem;font-size:.8125rem}.dashboard-main [style*="grid-template-columns: repeat(2"],.dashboard-main [style*="grid-template-columns: 1fr 1fr"],.modal [style*="grid-template-columns: 1fr 1fr"]{grid-template-columns:1fr!important}.card-body{padding:1rem}.card-header{padding:.875rem 1rem}}@media (min-width:769px){.mobile-only{display:none!important}}@media (max-width:768px){.desktop-only{display:none!important}}@keyframes authDriftA{0%,to{transform:translate(0,0)rotate(0)}50%{transform:translate(22px,-28px)rotate(8deg)}}@keyframes authDriftB{0%,to{transform:translate(0,0)rotate(0)}50%{transform:translate(-26px,24px)rotate(-7deg)}}@keyframes authDriftC{0%,to{transform:translate(0,0)rotate(0)}50%{transform:translate(18px,22px)rotate(5deg)}}@keyframes authDriftD{0%,to{transform:translate(0,0)rotate(0)}50%{transform:translate(-20px,-18px)rotate(-10deg)}}@keyframes authFloatUp{0%,to{opacity:.5;transform:translateY(0)rotate(0)}50%{opacity:.8;transform:translateY(-20px)rotate(5deg)}}@keyframes authGradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@media (prefers-reduced-motion:reduce){.auth-drift-shape{animation:none!important}}.auth-layout{align-items:stretch;width:100%;min-height:100vh;display:flex}.auth-form-panel{background:#fff;flex:1;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;overflow-y:auto}.auth-form-inner{width:100%;max-width:440px}.auth-hero-panel{flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:100vh;padding:3rem;display:flex;position:relative;overflow:hidden}.auth-hero-bg{background:linear-gradient(135deg,#1e1b6b 0%,#003d9b 35%,#4f46e5 70%,#6d28d9 100%)}.auth-drift-shape{pointer-events:none;position:absolute}.auth-heading-block{margin-bottom:2.5rem}.auth-heading-block--sm{margin-bottom:2rem}.auth-logo-wrap{align-items:center;gap:.5rem;margin-bottom:1.5rem;display:inline-flex}.auth-logo-wrap--sm{margin-bottom:1.25rem}.auth-heading{font-family:var(--font-display);letter-spacing:-.025em;color:#0b1c30;font-size:clamp(1.625rem,3vw,2rem);font-weight:800;line-height:1.1}.auth-heading--sm{font-size:clamp(1.5rem,3vw,1.875rem)}.gradient-text{-webkit-text-fill-color:transparent;color:#0000;-webkit-background-clip:text;background-clip:text;display:inline-block}.auth-gradient-text{color:var(--primary)}.auth-subtext{color:#475569;margin-top:.5rem;font-size:.9375rem}.auth-subtext--sm{font-size:.875rem}.auth-form-group{margin-bottom:1.5rem}.auth-form-group--sm{margin-bottom:1.25rem}.auth-form-group--lg{margin-bottom:2rem}.auth-field-label{color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em;font-size:.8125rem;font-weight:600}.auth-field-label--sm{font-size:.75rem}.auth-field-wrap{margin-top:.5rem}.auth-field-wrap--sm{margin-top:.25rem}.auth-password-wrap{margin-top:.5rem;position:relative}.auth-password-toggle{cursor:pointer;color:var(--gray-400);background:0 0;border:none;padding:0;font-size:1.25rem;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.auth-underline-input{box-sizing:border-box;width:100%;font-size:.9375rem;font-family:var(--font-sans);border:none;border-bottom:2px solid var(--gray-200);color:var(--gray-800);background:0 0;border-radius:0;outline:none;padding:.875rem .5rem;transition:all .3s;display:block}.auth-underline-input:focus{border-bottom-color:var(--primary);box-shadow:0 2px 0 0 var(--primary-lightest)}.auth-underline-input::placeholder{color:var(--gray-400)}.auth-underline-input--sm{padding:.75rem .5rem;font-size:.875rem}.auth-input-padded{padding-right:2.75rem}.auth-error-banner{border-radius:var(--radius-md);background:var(--danger-light);color:#991b1b;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.8125rem;font-weight:500}.auth-error-banner--sm{margin-bottom:1.25rem}.auth-success-banner{border-radius:var(--radius-md);background:var(--success-light);color:#065f46;border:1px solid var(--success);margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.8125rem;font-weight:500}.auth-device-banner{border-radius:var(--radius-md);align-items:flex-start;gap:.5rem;margin-bottom:1.5rem;padding:.875rem 1rem;font-size:.8125rem;font-weight:500;display:flex}.auth-device-banner__icon{flex-shrink:0;margin-top:1px}.auth-device-banner__message{margin:.25rem 0 0;font-size:.75rem}.auth-cta-btn{color:#fff;width:100%;height:48px;font-size:.9375rem;font-weight:700;font-family:var(--font-display);border:none;border-radius:12px;transition:transform .2s,box-shadow .2s}.auth-cta-btn:hover:not(:disabled){transform:translateY(-2px)}.auth-trust-bar{color:#64748b;flex-wrap:wrap;justify-content:center;gap:.25rem 1.25rem;margin-top:1rem;font-size:.75rem;font-weight:500;display:flex}.auth-trust-check{color:#10b981;font-weight:700}.auth-forgot-link{text-align:right;margin-top:.75rem}.auth-footer-text{text-align:center;color:var(--gray-500);margin-top:2rem;font-size:.875rem}.auth-footer-text--sm{margin-top:1.5rem}.auth-panel-content{z-index:2;text-align:center;max-width:440px;position:relative}.auth-panel-heading{font-family:var(--font-display);color:#fff;letter-spacing:-.025em;margin-bottom:1rem;font-size:clamp(1.625rem,2.6vw,2.125rem);font-weight:800;line-height:1.1}.auth-panel-heading--sm{font-size:clamp(1.5rem,2.4vw,2rem)}.auth-panel-body{color:#e8eefad9;margin-bottom:2rem;font-size:.9375rem;line-height:1.6}.auth-stats-row{flex-wrap:wrap;justify-content:center;display:flex}.auth-stats-row--lg{gap:2rem}.auth-stats-row--sm{gap:1.75rem}.auth-stat-item{text-align:center}.auth-stat-num{font-family:var(--font-display);color:#fff;letter-spacing:-.015em;font-size:1.125rem;font-weight:800}.auth-stat-label{color:#ffffffb3;text-transform:uppercase;letter-spacing:.08em;font-size:.625rem;font-weight:700}.otp-inputs-row{justify-content:center;gap:.5rem;display:flex}.otp-input{text-align:center;border:2px solid var(--gray-300);width:56px;height:64px;font-size:1.75rem;font-weight:700;font-family:var(--font-sans);border-radius:12px;outline:none;transition:all .2s}.otp-input:focus{border-color:var(--primary)}.otp-resend-btn{color:var(--primary);background:0 0;border:none;font-size:.875rem;font-weight:600;text-decoration:underline}.otp-resend-btn:not(:disabled){cursor:pointer}.otp-resend-btn:disabled{cursor:not-allowed}@media (max-width:768px){.auth-hero-panel{display:none!important}.auth-form-panel{flex:1;min-height:100vh}}.auth-centered-page{background:var(--surface-subtle);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:2rem;display:flex}.auth-card{border-radius:var(--radius-lg);background:#fff;width:100%}.auth-card--form{max-width:440px;padding:2.5rem;box-shadow:0 4px 20px #0000000d}.auth-card--success{text-align:center;max-width:440px;padding:3rem 2.5rem;box-shadow:0 4px 20px #00000014}.auth-card--error-state{text-align:center;max-width:440px;padding:2.5rem;box-shadow:0 4px 6px -1px #0000000d}.auth-success-icon{background:var(--success-light);width:64px;height:64px;color:var(--success);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1.5rem;font-size:2rem;display:flex}.auth-card-heading{color:var(--text-heading);margin-bottom:.75rem;font-size:1.5rem;font-weight:800}.auth-card-subtext{color:var(--text-body);margin-bottom:2rem;font-size:.9375rem;line-height:1.6}.auth-card-label{color:var(--text-heading);margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.auth-card-input{border-radius:var(--radius-sm);border:1px solid var(--gray-300);width:100%;font-size:.9375rem;font-family:var(--font-sans);outline:none;padding:.75rem 1rem;transition:border-color .2s}.auth-card-input:focus{border-color:var(--primary)}.auth-card-group{margin-bottom:1.25rem}.auth-card-group--lg{margin-bottom:2rem}.auth-card-btn{border-radius:var(--radius-sm);background:var(--primary);color:#fff;border:none;width:100%;padding:.875rem;font-size:.9375rem;font-weight:700;transition:background .2s;box-shadow:0 4px 12px #003d9b33}.auth-card-btn:disabled{cursor:not-allowed;opacity:.7}.auth-card-footer{text-align:center;color:var(--text-body);margin-top:1.5rem;font-size:.9375rem}.auth-card-error-banner{border-radius:var(--radius-sm);background:var(--danger-light);color:#991b1b;border:1px solid var(--danger);margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500}.auth-card-success-btn{border-radius:var(--radius-sm);background:var(--primary);color:#fff;text-align:center;width:100%;padding:.875rem;font-size:.9375rem;font-weight:700;text-decoration:none;display:block;box-shadow:0 4px 12px #003d9b33}
