*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}button{cursor:pointer;font-family:inherit}input,textarea{font-family:inherit}@keyframes notifSlideIn{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}:root{--bg:#f1f5f9;--surface:#fff;--border:#e2e8f0;--border-hover:#cbd5e1;--text-1:#1e293b;--text-2:#64748b;--text-3:#94a3b8;--header-bg:#0f172a;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000001a, 0 2px 4px #0000000a;--shadow-lg:0 8px 32px #00000024, 0 4px 8px #0000000f;--shadow-xl:0 20px 48px #0003;--r-sm:6px;--r-md:10px;--r-lg:14px;--brand:#16a34a;--brand-light:#22c55e;--brand-dark:#14532d;--brand-bg:#f0fdf4;--brand-border:#bbf7d0}.app{background:var(--bg);height:100%;color:var(--text-1);flex-direction:column;display:flex}.app-header{background:var(--header-bg);z-index:10;flex-shrink:0;align-items:center;height:58px;padding:0 20px;display:flex;box-shadow:0 2px 8px #00000040}.header-inner{justify-content:space-between;align-items:center;width:100%;display:flex}.header-logo-link{align-items:center;gap:10px;text-decoration:none;display:flex}.header-brand{align-items:center;gap:10px;display:flex}.header-logo{color:#fff;background:linear-gradient(135deg,#16a34a 0%,#059669 100%);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.header-logo svg{width:17px;height:17px}.header-name{color:#f8fafc;letter-spacing:-.2px;font-size:17px;font-weight:700}.header-nav{gap:2px;display:flex}.nav-link{border-radius:var(--r-sm);color:#94a3b8;padding:6px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.nav-link:hover{color:#f8fafc;background:#ffffff12}.nav-link--active{color:#f8fafc;background:#16a34a40}.save-status{border:1px solid #0000;border-radius:100px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:600;animation:.15s fade-in;display:inline-flex}@keyframes fade-in{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.save-status--saving{color:#93c5fd;background:#3b82f626;border-color:#3b82f64d}.save-status--saved{color:#6ee7b7;background:#10b98126;border-color:#10b9814d}.save-status--error{color:#fca5a5;background:#ef444426;border-color:#ef44444d}.save-status__icon{flex-shrink:0;width:12px;height:12px}.save-status__spinner{border:2px solid #93c5fd4d;border-top-color:#93c5fd;border-radius:50%;flex-shrink:0;width:12px;height:12px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.stat-chip{background:#ffffff12;border:1px solid #ffffff1a;border-radius:100px;align-items:center;gap:6px;padding:4px 12px;display:flex}.stat-chip--blue{background:#3b82f626;border-color:#3b82f640}.stat-chip--green{background:#10b98126;border-color:#10b98140}.stat-chip__value{color:#f8fafc;font-size:14px;font-weight:700}.stat-chip__label{color:#94a3b8;font-size:12px}.app-main{flex-direction:column;flex:1;min-height:0;padding-bottom:64px;display:flex;overflow-y:auto}.board-page{flex-direction:column;flex:1;height:100%;display:flex;overflow:hidden}.board-toolbar{background:var(--header-bg);border-bottom:1px solid #ffffff0f;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 20px;display:flex}.board-stats{gap:8px;display:flex}.kanban-board{flex:1;align-items:flex-start;gap:16px;padding:20px;display:flex;overflow-x:auto}.kanban-board::-webkit-scrollbar{height:6px}.kanban-board::-webkit-scrollbar-track{background:0 0}.kanban-board::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.column{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);width:310px;min-width:310px;max-height:calc(100vh - 142px);box-shadow:var(--shadow-sm);flex-direction:column;transition:border-color .15s,box-shadow .15s;display:flex}.column--over{border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f61f}.column__header{border-bottom:1px solid var(--border);flex-shrink:0;padding:14px 14px 12px}.column__header-top{align-items:center;gap:8px;margin-bottom:10px;display:flex}.column__dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.column__title{color:var(--text-1);letter-spacing:.1px;text-transform:uppercase;flex:1;font-size:13px;font-weight:700}.column__count{color:var(--text-3);background:var(--bg);border:1px solid var(--border);text-align:center;border-radius:100px;min-width:20px;padding:1px 7px;font-size:11px;font-weight:700}.btn-add-task{border:1.5px dashed var(--border);border-radius:var(--r-sm);width:100%;color:var(--text-3);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:7px 10px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.btn-add-task svg{width:13px;height:13px}.btn-add-task:hover{color:#3b82f6;background:#eff6ff;border-color:#93c5fd}.column__tasks{border-radius:0 0 var(--r-lg) var(--r-lg);flex-direction:column;flex:1;gap:8px;min-height:64px;padding:10px;display:flex;overflow-y:auto}.column__tasks::-webkit-scrollbar{width:5px}.column__tasks::-webkit-scrollbar-track{background:0 0}.column__tasks::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.column__tasks--empty{min-height:80px}.empty-placeholder{color:var(--text-3);border:1.5px dashed var(--border);border-radius:var(--r-sm);flex:1;justify-content:center;align-items:center;min-height:60px;font-size:13px;display:flex}.task-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:grab;box-shadow:var(--shadow-sm);-webkit-user-select:none;user-select:none;padding:12px;transition:box-shadow .15s,border-color .15s,transform .1s;position:relative}.task-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}.task-card:active{cursor:grabbing}.task-card--overlay{box-shadow:var(--shadow-xl);cursor:grabbing;transform:rotate(2deg)scale(1.02)}.task-card__header{justify-content:space-between;align-items:center;gap:6px;margin-bottom:8px;display:flex}.priority-badge{letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;border-radius:100px;padding:3px 8px;font-size:10px;font-weight:700}.task-actions{opacity:0;flex-shrink:0;gap:2px;transition:opacity .15s;display:flex}.task-card:hover .task-actions{opacity:1}.task-action-btn{border-radius:var(--r-sm);width:26px;height:26px;color:var(--text-3);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .1s,color .1s;display:flex}.task-action-btn svg{width:13px;height:13px}.task-action-btn:hover{background:var(--bg);color:var(--text-2)}.task-action-btn--delete:hover{color:#ef4444;background:#fef2f2}.task-card__title{color:var(--text-1);margin-bottom:5px;font-size:14px;font-weight:600;line-height:1.4}.task-card__description{color:var(--text-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:8px;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.task-card__due{color:var(--text-3);align-items:center;gap:5px;margin-top:8px;font-size:12px;display:flex}.task-card__due svg{flex-shrink:0;width:12px;height:12px}.task-card__due--overdue{color:#dc2626}.assignee-chip{border-top:1px solid var(--border);align-items:center;gap:6px;margin-top:10px;padding-top:9px;display:flex}.assignee-chip__avatar{color:#fff;letter-spacing:0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;font-weight:700;display:flex}.assignee-chip__name{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a8c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--r-lg);width:100%;max-width:500px;box-shadow:var(--shadow-xl);animation:.18s pop-in}@keyframes pop-in{0%{opacity:0;transform:scale(.95)translateY(6px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal__header{justify-content:space-between;align-items:center;padding:20px 20px 0;display:flex}.modal__header h2{color:var(--text-1);font-size:17px;font-weight:700}.modal__close{border-radius:var(--r-sm);width:30px;height:30px;color:var(--text-3);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .1s,color .1s;display:flex}.modal__close svg{width:15px;height:15px}.modal__close:hover{background:var(--bg);color:var(--text-1)}.modal__form{flex-direction:column;gap:14px;padding:18px 20px 20px;display:flex}.form-field{flex-direction:column;gap:5px;display:flex}.form-field label{color:var(--text-2);text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:700}.required{color:#ef4444}.form-field input[type=text],.form-field input[type=date],.form-field input[type=search],.form-field textarea{border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text-1);background:var(--surface);box-sizing:border-box;padding:9px 11px;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-field input:focus,.form-field textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61f}.form-field textarea{resize:vertical;min-height:78px}.form-field--error input,.form-field--error textarea{border-color:#ef4444}.field-error{color:#ef4444;font-size:12px}.form-row{grid-template-columns:1fr 1fr;align-items:start;gap:14px;display:grid}.priority-selector{flex-wrap:wrap;gap:6px;display:flex}.priority-option{background:var(--bg);color:var(--text-2);cursor:pointer;border:1.5px solid #0000;border-radius:100px;align-items:center;gap:5px;padding:5px 11px;font-size:13px;font-weight:500;transition:all .12s;display:flex}.priority-option:hover{background:var(--surface);border-color:var(--border)}.priority-option--active{background:var(--surface);font-weight:600}.priority-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.modal__footer{justify-content:flex-end;gap:8px;margin-top:2px;display:flex}.btn{border-radius:var(--r-sm);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 18px;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.btn--ghost{color:var(--text-2);border:1.5px solid var(--border);background:0 0}.btn--ghost:hover{background:var(--bg);color:var(--text-1)}.btn--primary{color:#fff;background:#3b82f6}.btn--primary:hover{background:#2563eb}.btn--brand{background:var(--brand);color:#fff}.btn--brand:hover{background:#15803d}.btn--danger{color:#fff;background:#ef4444}.btn--danger:hover{background:#dc2626}.confirm-dialog{background:var(--surface);border-radius:var(--r-lg);width:100%;max-width:340px;box-shadow:var(--shadow-xl);text-align:center;padding:24px;animation:.18s pop-in}.confirm-dialog__icon{color:#ef4444;background:#fef2f2;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;margin:0 auto 14px;display:flex}.confirm-dialog__icon svg{width:20px;height:20px}.confirm-dialog h3{color:var(--text-1);margin-bottom:6px;font-size:16px;font-weight:700}.confirm-dialog p{color:var(--text-2);margin-bottom:20px;font-size:14px}.confirm-dialog__actions{justify-content:center;gap:8px;display:flex}.header-user{flex-shrink:0;align-items:center;gap:10px;display:flex}.header-user__email{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;max-width:200px;font-size:13px;overflow:hidden}.header-signout-btn{border-radius:var(--r-sm);color:#94a3b8;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;align-items:center;gap:6px;padding:5px 12px;font-size:13px;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.header-signout-btn svg{flex-shrink:0;width:14px;height:14px}.header-signout-btn:hover{color:#fca5a5;background:#ef444426;border-color:#ef44444d}.login-page{background:#0b1120;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{border-radius:var(--r-lg);background:#111827;border:1px solid #ffffff14;width:100%;max-width:400px;padding:40px 36px;animation:.2s pop-in;box-shadow:0 24px 64px #00000080}.login-logo{align-items:center;gap:10px;margin-bottom:28px;display:flex}.login-logo__icon{color:#fff;background:linear-gradient(135deg,#16a34a 0%,#059669 100%);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.login-logo__icon svg{width:18px;height:18px}.login-logo__name{color:#f8fafc;letter-spacing:-.2px;font-size:18px;font-weight:700}.login-heading{color:#f8fafc;letter-spacing:-.3px;margin:0 0 6px;font-size:22px;font-weight:700}.login-subheading{color:#64748b;margin:0 0 28px;font-size:14px}.login-form{flex-direction:column;gap:16px;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-field label{color:#94a3b8;font-size:13px;font-weight:600}.login-field input{border-radius:var(--r-sm);color:#f1f5f9;box-sizing:border-box;background:#1e293b;border:1.5px solid #ffffff1a;width:100%;padding:10px 13px;font-size:14px;transition:border-color .15s,box-shadow .15s}.login-field input::placeholder{color:#475569}.login-field input:focus{border-color:#16a34a;outline:none;box-shadow:0 0 0 3px #16a34a2e}.login-field input:disabled{opacity:.5;cursor:not-allowed}.login-error{color:#fca5a5;border-radius:var(--r-sm);background:#ef44441a;border:1px solid #ef444440;margin:0;padding:9px 13px;font-size:13px}.login-btn{background:var(--brand);color:#fff;border-radius:var(--r-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:4px;padding:11px;font-size:15px;font-weight:600;transition:background .15s,opacity .15s;display:flex}.login-btn:hover:not(:disabled){background:#15803d}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-btn__spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin}.login-password-wrap{align-items:center;display:flex;position:relative}.login-password-wrap input{padding-right:40px}.login-password-toggle{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;line-height:0;transition:color .15s;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.login-password-toggle:hover{color:#94a3b8}.login-password-toggle svg{width:16px;height:16px}@media (width<=400px){.login-card{padding:28px 20px}.login-heading{font-size:18px}.login-logo__name{font-size:15px}}.loading-screen{color:var(--text-3);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;font-size:14px;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:var(--brand);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.home-page{flex:1;padding-bottom:60px;overflow-y:auto}.home-hero{background:linear-gradient(160deg,#0f172a 0%,#0f2820 50%,#0f172a 100%);padding:64px 40px 72px;position:relative;overflow:hidden}.home-hero__glow{pointer-events:none;background:radial-gradient(#16a34a2e 0%,#0000 70%);width:600px;height:400px;position:absolute;top:-80px;left:50%;transform:translate(-50%)}.home-hero__content{text-align:center;max-width:640px;margin:0 auto;position:relative}.home-hero__badge{color:#86efac;letter-spacing:.3px;background:#16a34a26;border:1px solid #16a34a59;border-radius:100px;align-items:center;gap:7px;margin-bottom:28px;padding:5px 14px;font-size:12px;font-weight:600;display:inline-flex}.home-hero__badge-dot{background:#22c55e;border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}.home-hero__title{color:#f8fafc;letter-spacing:-1px;margin-bottom:16px;font-size:clamp(32px,5vw,52px);font-weight:800;line-height:1.1}.home-hero__title-accent{color:#22c55e}.home-hero__subtitle{color:#94a3b8;max-width:480px;margin:0 auto;font-size:17px;line-height:1.65}.home-features{max-width:900px;margin:0 auto;padding:48px 40px 64px}.home-features__heading{text-transform:uppercase;letter-spacing:1px;color:var(--text-3);margin-bottom:20px;font-size:13px;font-weight:700}.home-feature-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=640px){.home-feature-grid{grid-template-columns:1fr}.home-hero{padding:48px 24px 56px}.home-features{padding:36px 24px 48px}}.feature-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);color:var(--text-1);box-shadow:var(--shadow-sm);align-items:flex-start;gap:16px;padding:24px;text-decoration:none;transition:box-shadow .2s,border-color .2s,transform .15s;display:flex;position:relative;overflow:hidden}.feature-card:before{content:"";opacity:0;height:3px;transition:opacity .2s;position:absolute;top:0;left:0;right:0}.feature-card--board:before{background:linear-gradient(90deg,#3b82f6,#8b5cf6)}.feature-card--employees:before{background:linear-gradient(90deg,#16a34a,#22c55e)}.feature-card--finance:before{background:linear-gradient(90deg,#d97706,#f59e0b)}.feature-card--roles:before{background:linear-gradient(90deg,#7c3aed,#a78bfa)}.feature-card__icon-wrap--amber{color:#d97706;background:#d977061a;border:1px solid #d9770633}.feature-card__icon-wrap--purple{color:#7c3aed;background:#7c3aed1a;border:1px solid #7c3aed33}.feature-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover);transform:translateY(-2px)}.feature-card:hover:before{opacity:1}.feature-card__icon-wrap{border-radius:var(--r-md);flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.feature-card__icon-wrap svg{width:22px;height:22px}.feature-card__icon-wrap--blue{color:#3b82f6;background:#3b82f61a;border:1px solid #3b82f633}.feature-card__icon-wrap--green{color:#16a34a;background:#16a34a1a;border:1px solid #16a34a33}.feature-card__body{flex:1;min-width:0}.feature-card__title{color:var(--text-1);margin-bottom:6px;font-size:17px;font-weight:700}.feature-card__desc{color:var(--text-2);margin-bottom:12px;font-size:13px;line-height:1.55}.feature-card__meta{flex-wrap:wrap;gap:6px;display:flex}.feature-card__tag{background:var(--bg);border:1px solid var(--border);color:var(--text-2);border-radius:100px;padding:2px 8px;font-size:11px;font-weight:600}.feature-card__arrow{color:var(--text-3);flex-shrink:0;align-self:center;transition:color .15s,transform .15s}.feature-card__arrow svg{width:18px;height:18px}.feature-card:hover .feature-card__arrow{color:var(--text-2);transform:translate(3px)}.emp-page{flex-direction:column;flex:1;gap:24px;padding:28px 28px 80px;display:flex;overflow-y:auto}.emp-page__header{flex-direction:column;gap:12px;display:flex}.emp-page__title-row{align-items:baseline;gap:12px;display:flex}.emp-page__title{color:var(--text-1);letter-spacing:-.4px;font-size:24px;font-weight:800}.emp-count{color:var(--text-3);font-size:13px;font-weight:500}.emp-page__controls{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.search-wrap{flex:1;max-width:360px;position:relative}.search-icon{width:15px;height:15px;color:var(--text-3);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-input{border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text-1);background:var(--surface);box-sizing:border-box;padding:8px 12px 8px 34px;font-size:14px;transition:border-color .15s,box-shadow .15s}.search-input:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #16a34a1f}.search-input::placeholder{color:var(--text-3)}.emp-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.emp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:20px;transition:box-shadow .15s,border-color .15s;position:relative}.emp-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}.emp-card__actions{opacity:0;gap:2px;transition:opacity .15s;display:flex;position:absolute;top:12px;right:12px}.emp-card:hover .emp-card__actions{opacity:1}.emp-card__top{justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex}.emp-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:18px;font-weight:700;display:flex}.emp-avatar--photo{object-fit:cover}.status-badge{letter-spacing:.2px;white-space:nowrap;border-radius:100px;padding:3px 10px;font-size:11px;font-weight:700}.status-badge--active{color:#15803d;background:#dcfce7;border:1px solid #bbf7d0}.status-badge--remote{color:#1d4ed8;background:#dbeafe;border:1px solid #bfdbfe}.status-badge--leave{color:#b45309;background:#fef3c7;border:1px solid #fde68a}.status-badge--inactive{color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0}.emp-card__info{margin-bottom:12px}.emp-card__name{color:var(--text-1);margin-bottom:3px;font-size:16px;font-weight:700;line-height:1.3}.emp-card__role{color:var(--text-2);margin-bottom:4px;font-size:13px}.emp-card__dept{color:var(--text-3);align-items:center;gap:5px;font-size:12px;display:flex}.emp-card__dept svg{flex-shrink:0;width:12px;height:12px}.emp-card__contact{border-top:1px solid var(--border);flex-direction:column;gap:5px;padding-top:10px;display:flex}.emp-contact-row{color:var(--text-2);align-items:center;gap:7px;font-size:12px;text-decoration:none;transition:color .12s;display:flex;overflow:hidden}.emp-contact-row svg{width:13px;height:13px;color:var(--text-3);flex-shrink:0}.emp-contact-row span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.emp-contact-row:hover,.emp-contact-row:hover svg{color:var(--brand)}.emp-empty{color:var(--text-3);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:60px 20px;font-size:15px;display:flex}.emp-empty strong{color:var(--text-2)}.assignee-wrap{position:relative}.assignee-dropdown{border:1px solid var(--border);z-index:9999;background:#fff;border-radius:10px;max-height:260px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden auto;box-shadow:0 8px 24px #0000002e}.assignee-option{cursor:pointer;text-align:left;color:#1e293b;background:#fff;border:none;align-items:center;gap:10px;width:100%;padding:8px 12px;transition:background .1s;display:flex}.assignee-option:hover,.assignee-option:focus,.assignee-option--active{background:#f1f5f9;outline:none}.assignee-no-match{color:var(--text-3);padding:10px 14px;font-size:13px}.assignee-option__avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex;overflow:hidden}.assignee-option__avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.assignee-option__info{flex-direction:column;min-width:0;display:flex}.assignee-option__name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.assignee-option__meta{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:11px;overflow:hidden}.fin-page{width:100%;max-width:1100px;margin:0 auto;padding:28px 24px 80px}.fin-loading{text-align:center;color:#64748b;padding:40px}.fin-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.fin-header__left{align-items:center;gap:14px;display:flex}.fin-title{color:#0f172a;margin:0;font-size:26px;font-weight:700}.fin-header__actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.save-status{color:#94a3b8;font-size:12px}.save-status--error{color:#ef4444}.fin-tabs{border-bottom:2px solid #e2e8f0;gap:2px;margin-bottom:24px;display:flex}.fin-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:4px 4px 0 0;margin-bottom:-2px;padding:9px 18px;font-size:14px;font-weight:500;transition:color .15s,border-color .15s}.fin-tab:hover{color:#0f172a}.fin-tab--active{color:#16a34a;border-bottom-color:#16a34a;font-weight:600}.fin-stats-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;margin-bottom:28px;display:grid}.fin-stat-card{border:1px solid #e2e8f0;border-top:3px solid var(--stat-color,#16a34a);background:#fff;border-radius:10px;padding:16px;box-shadow:0 1px 4px #0000000f}.fin-stat-card__value{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;font-size:22px;font-weight:700;line-height:1.1;overflow:hidden}.fin-stat-card__label{color:#64748b;text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px;font-size:12px;font-weight:600}.fin-stat-card__sub{color:#94a3b8;font-size:11px}.fin-chart-controls{flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:16px;display:flex}.fin-chart-tabs{background:#f1f5f9;border-radius:8px;gap:2px;padding:3px;display:flex}.fin-chart-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.fin-chart-tab:hover{color:#0f172a}.fin-chart-tab--active{color:#16a34a;background:#fff;font-weight:600;box-shadow:0 1px 3px #0000001a}.fin-year-select{color:#374151;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:6px 10px;font-size:13px}.fin-chart-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:18px;padding:20px;box-shadow:0 1px 4px #0000000d}.fin-chart-card--half{width:100%;max-width:520px}.fin-chart-title{color:#0f172a;margin:0 0 14px;font-size:15px;font-weight:600}.fin-recent{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px;box-shadow:0 1px 4px #0000000d}.fin-recent-row{border-bottom:1px solid #f1f5f9;align-items:center;gap:10px;padding:9px 0;font-size:13px;display:flex}.fin-recent-row:last-child{border-bottom:none}.fin-recent-type{text-align:center;border-radius:99px;min-width:60px;padding:2px 8px;font-size:11px;font-weight:600}.fin-recent-type--bill{color:#991b1b;background:#fee2e2}.fin-recent-type--invoice{color:#1d4ed8;background:#dbeafe}.fin-recent-type--salary{color:#166534;background:#dcfce7}.fin-recent-name{color:#374151;flex:1;font-weight:500}.fin-recent-amount{color:#0f172a;font-weight:600}.fin-empty-hint{color:#94a3b8;text-align:center;margin:0;padding:24px 0;font-size:14px}.fin-list{flex-direction:column;gap:10px;display:flex}.fin-row{background:#fff;border:1px solid #e2e8f0;border-radius:10px;justify-content:space-between;align-items:flex-start;gap:12px;padding:14px 16px;transition:box-shadow .15s;display:flex;box-shadow:0 1px 3px #0000000d}.fin-row:hover{box-shadow:0 2px 8px #0000001a}.fin-row__main{flex:1;min-width:0}.fin-row__name{color:#0f172a;align-items:center;gap:8px;margin-bottom:4px;font-size:15px;font-weight:600;display:flex}.fin-row__inv-num{color:#1d4ed8;background:#eff6ff;border-radius:99px;padding:1px 7px;font-size:11px;font-weight:600}.fin-row__meta{color:#64748b;flex-wrap:wrap;gap:6px;margin-bottom:5px;font-size:12px;display:flex}.fin-row__tag{color:#475569;background:#f1f5f9;border-radius:99px;padding:2px 8px;font-size:11px;font-weight:500}.fin-row__tag--green{color:#166534;background:#dcfce7}.fin-row__parties{color:#475569;flex-wrap:wrap;gap:10px;font-size:12px;display:flex}.fin-row__party-label{color:#94a3b8;margin-right:2px;font-weight:600}.fin-row__right{flex-direction:column;align-items:flex-end;gap:5px;min-width:130px;display:flex}.fin-row__amount{color:#0f172a;font-size:17px;font-weight:700}.fin-row__date{color:#94a3b8;font-size:12px}.fin-row__status{text-transform:capitalize;border:1.5px solid;border-radius:99px;padding:2px 9px;font-size:11px;font-weight:600}.fin-row__actions{gap:4px;margin-top:4px;display:flex}.fin-board-section{flex-direction:column;gap:20px;display:flex}.fin-board-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.fin-board-title{color:#0f172a;margin:0 0 4px;font-size:20px;font-weight:700}.fin-board-sub{color:#94a3b8;margin:0;font-size:13px}.fin-quick-add{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-wrap:wrap;align-items:center;gap:10px;padding:14px 16px;display:flex;box-shadow:0 1px 4px #0000000d}.fin-quick-input{color:#1e293b;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:6px;flex:1;min-width:140px;padding:8px 11px;font-size:14px;transition:border-color .15s,box-shadow .15s}.fin-quick-input:focus{background:#fff;border-color:#16a34a;outline:none;box-shadow:0 0 0 3px #16a34a1f}.fin-quick-input--amount{max-width:160px}.fin-board{grid-template-columns:repeat(3,1fr);align-items:flex-start;gap:16px;display:grid}@media (width<=840px){.fin-board{grid-template-columns:1fr}}.fin-board-col{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;min-height:160px;display:flex}.fin-board-col__header{border-bottom:1px solid #e2e8f0;align-items:center;gap:8px;padding:12px 14px 10px;display:flex}.fin-board-col__dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.fin-board-col__title{text-transform:uppercase;letter-spacing:.3px;color:#475569;flex:1;font-size:13px;font-weight:700}.fin-board-col__count{color:#374151;text-align:center;border-radius:99px;min-width:22px;padding:2px 8px;font-size:11px;font-weight:700}.fin-board-col__cards{flex-direction:column;gap:10px;padding:10px;display:flex}.fin-board-empty{text-align:center;color:#94a3b8;border:1.5px dashed #e2e8f0;border-radius:8px;padding:24px 12px;font-size:13px}.fin-emp-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px;transition:box-shadow .15s,border-color .15s;position:relative;box-shadow:0 1px 3px #0000000d}.fin-emp-card:hover{border-color:#cbd5e1;box-shadow:0 3px 10px #0000001a}.fin-emp-card__actions{opacity:0;gap:2px;transition:opacity .15s;display:flex;position:absolute;top:10px;right:10px}.fin-emp-card:hover .fin-emp-card__actions{opacity:1}.fin-emp-card__top{align-items:center;gap:10px;margin-bottom:10px;display:flex}.fin-emp-card__avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;font-weight:700;display:flex}.fin-emp-card__header-info{flex:1;min-width:0}.fin-emp-card__name{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;padding-right:48px;font-size:14px;font-weight:700;overflow:hidden}.fin-emp-card__role{color:#64748b;white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:12px;overflow:hidden}.fin-emp-card__amount{color:#0f172a;letter-spacing:-.3px;margin-bottom:8px;font-size:20px;font-weight:700}.fin-emp-card__meta{flex-wrap:wrap;gap:5px;margin-bottom:8px;display:flex}.fin-emp-card__date{color:#94a3b8;align-items:center;gap:5px;margin-bottom:10px;font-size:12px;display:flex}.fin-emp-card__footer{border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding-top:8px;display:flex}.fin-emp-card__approved{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;max-width:100px;font-size:11px;overflow:hidden}.modal--wide{width:96vw;max-width:680px}.modal--sm{width:92vw;max-width:380px}.modal__section{margin-bottom:18px}.modal__section-title{text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;border-bottom:1px solid #f1f5f9;margin:0 0 12px;padding-bottom:8px;font-size:12px;font-weight:700}.emp-ac-wrap{position:relative}.emp-ac-dropdown{z-index:9999;background:#fff;border:1px solid #e2e8f0;border-radius:8px;max-height:220px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #00000024}.emp-ac-option{text-align:left;cursor:pointer;background:#fff;border:none;align-items:center;gap:10px;width:100%;padding:9px 12px;transition:background .1s;display:flex}.emp-ac-option:hover{background:#f8fafc}.emp-ac-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:700;display:flex;overflow:hidden}.emp-ac-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.emp-ac-name{color:#1e293b;font-size:13px;font-weight:500}.emp-ac-meta{color:#94a3b8;margin-top:1px;font-size:11px}.roles-page{width:100%;max-width:1100px;margin:0 auto;padding:28px 28px 80px}.roles-section{margin-bottom:40px}.roles-section__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:18px;display:flex}.roles-section__title{color:var(--text-1);font-size:18px;font-weight:700}.roles-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.role-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:20px;transition:box-shadow .15s,border-color .15s;display:flex}.role-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}.role-card__header{align-items:center;gap:10px;display:flex}.role-badge{color:#fff;letter-spacing:.2px;border-radius:100px;align-items:center;padding:3px 12px;font-size:12px;font-weight:700;display:inline-flex}.role-system-tag{background:var(--bg);border:1px solid var(--border);color:var(--text-2);letter-spacing:.3px;text-transform:uppercase;border-radius:100px;padding:2px 8px;font-size:10px;font-weight:600}.role-card__desc{color:var(--text-2);margin:0;font-size:13px;line-height:1.5}.role-card__perms{flex-wrap:wrap;flex:1;align-content:flex-start;align-items:flex-start;gap:6px 8px;display:flex}.perm-chip{white-space:nowrap;color:#3b82f6;background:#3b82f614;border:1px solid #3b82f633;border-radius:100px;align-items:center;padding:2px 9px;font-size:11px;font-weight:500;display:inline-flex}.perm-chip--empty{background:var(--bg);border-color:var(--border);color:var(--text-3)}.role-card__footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:8px;display:flex}.role-card__user-count{color:var(--text-3);font-size:12px}.role-card__actions{gap:6px;display:flex}.btn--icon{justify-content:center;align-items:center;width:28px;height:28px;padding:4px;display:inline-flex}.btn--icon svg{width:14px;height:14px}.users-table-wrap{border-radius:var(--r-lg);border:1.5px solid var(--border);box-shadow:var(--shadow-sm);overflow-x:auto}.users-table{border-collapse:collapse;background:var(--surface);width:100%;font-size:13px}.users-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);background:var(--bg);border-bottom:1px solid var(--border);padding:11px 16px;font-size:11px;font-weight:700}.users-table td{border-bottom:1px solid var(--border);color:var(--text-1);vertical-align:middle;padding:12px 16px}.users-table tbody tr:last-child td{border-bottom:none}.users-table tbody tr:hover td{background:#f1f5f980}.user-row__avatar-cell{align-items:center;gap:10px;display:flex}.user-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;display:flex}.user-row__name{color:var(--text-1);font-weight:600}.user-row__email{color:var(--text-2);font-size:12px}.user-role-select-wrap{align-items:center;gap:8px;display:flex}.user-role-select{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text-1);cursor:pointer;padding:5px 10px;font-size:13px}.user-role-select:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #16a34a26}.saving-indicator{color:var(--text-3);font-size:12px}.password-cell{align-items:center;gap:6px;display:flex}.password-mask{color:var(--text-2);letter-spacing:2px;font-family:monospace;font-size:13px}.icon-btn{border-radius:var(--r-sm);cursor:pointer;width:26px;height:26px;color:var(--text-3);background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.icon-btn:hover{background:var(--bg);color:var(--text-1)}.icon-btn svg{width:14px;height:14px}.perm-checklist{flex-direction:column;gap:2px;margin-top:4px;display:flex}.perm-check-item{border-radius:var(--r-sm);cursor:pointer;grid-template-rows:auto auto;grid-template-columns:18px 1fr;align-items:center;gap:0 10px;padding:8px 10px;transition:background .12s;display:grid}.perm-check-item:hover{background:var(--bg)}.perm-check-item input[type=checkbox]{cursor:pointer;width:15px;height:15px;accent-color:var(--brand);grid-row:1/3;align-self:center}.perm-check-label{color:var(--text-1);font-size:13px;font-weight:600}.perm-check-desc{color:var(--text-3);grid-column:2;font-size:11px}.modal-text-input,.modal-select{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface);width:100%;color:var(--text-1);box-sizing:border-box;padding:8px 11px;font-size:14px;transition:border-color .15s,box-shadow .15s}.modal-text-input:focus,.modal-select:focus{border-color:var(--brand);outline:none;box-shadow:0 0 0 3px #16a34a26}.password-reveal-box{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-md);align-items:center;gap:10px;padding:12px 14px;display:flex}.password-reveal-code{color:var(--text-1);letter-spacing:1px;word-break:break-all;flex:1;font-family:Courier New,monospace;font-size:15px;font-weight:700}.nav-hamburger{cursor:pointer;color:#94a3b8;border-radius:var(--r-sm);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:4px;transition:color .15s;display:none}.nav-hamburger svg{width:22px;height:22px}.nav-hamburger:hover{color:#f8fafc}@media (width<=768px){.header-user__email{display:none}.header-signout-btn{padding:5px 8px;font-size:0}.header-signout-btn svg{width:16px;height:16px}.nav-hamburger{display:flex}.app-header{position:relative}.header-nav{background:var(--header-bg);z-index:200;border-top:1px solid #ffffff14;flex-direction:column;gap:2px;padding:8px 12px 12px;display:none;position:absolute;top:58px;left:0;right:0;box-shadow:0 6px 16px #00000059}.header-nav--open{display:flex}.nav-link{border-radius:var(--r-sm);padding:10px 14px;font-size:14px}}@media (width<=480px){.app-header{padding:0 12px}.header-name{display:none}}.board-stats{flex-wrap:nowrap;overflow-x:auto}.stat-chip__value,.stat-chip__label{white-space:nowrap}.fin-stat-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px;display:grid}@media (width<=900px){.fin-stat-row{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.fin-stat-row{grid-template-columns:1fr}}.oploan-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:4px 0;display:grid}.oploan-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);flex-direction:column;gap:8px;padding:16px;transition:box-shadow .15s,border-color .15s;display:flex}.oploan-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}.oploan-card__header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.oploan-card__borrower{color:var(--text-1);font-size:15px;font-weight:700;line-height:1.3}.oploan-card__badges{flex-wrap:wrap;gap:5px;display:flex}.oploan-badge{white-space:nowrap;border-radius:99px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.oploan-card__amount{color:var(--text-1);letter-spacing:-.5px;font-size:22px;font-weight:800}.oploan-card__rate{color:var(--text-2);font-size:13px}.oploan-card__dates{color:var(--text-2);align-items:center;gap:6px;font-size:12px;display:flex}.oploan-card__dates-sep{color:var(--text-3)}.oploan-card__next{color:var(--text-2);background:#f0fdf4;border-radius:6px;padding:4px 8px;font-size:12px}.oploan-card__phone{color:var(--text-3);font-size:12px}.oploan-card__actions{flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;display:flex}.oploan-admin-card{background:#faf5ff;border:1.5px solid #7c3aed;border-radius:10px;margin-bottom:20px;overflow:hidden}.oploan-admin-card__header{color:#5b21b6;background:#ede9fe;align-items:center;gap:8px;padding:10px 16px;font-size:.85rem;font-weight:600;display:flex}.oploan-admin-card__badge{letter-spacing:.05em;color:#fff;background:#7c3aed;border-radius:4px;margin-left:auto;padding:2px 7px;font-size:.7rem;font-weight:700}.oploan-admin-card__body{padding:12px 16px}.oploan-admin-breakdown{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px;display:grid}.oploan-admin-row{background:var(--row-bg);border:1px solid color-mix(in srgb, var(--row-color) 30%, transparent);cursor:pointer;text-align:left;border-radius:8px;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;transition:filter .15s;display:flex}.oploan-admin-row:hover{filter:brightness(.95)}.oploan-admin-row__label{color:var(--row-color);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.oploan-admin-row__count{color:var(--row-color);font-size:1.4rem;font-weight:700;line-height:1}.oploan-admin-row__principal{color:#6b7280;font-size:.75rem}.oploan-admin-alert{color:#92400e;background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;align-items:flex-start;gap:8px;padding:8px 12px;font-size:.8rem;display:flex}@media (width<=640px){.oploan-admin-breakdown{grid-template-columns:repeat(2,1fr)}}.oploan-filters{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:16px;display:flex}.filter-group{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.filter-label{color:var(--text-2);white-space:nowrap;font-size:12px;font-weight:600}.filter-chip{border:1.5px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer;border-radius:99px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .12s}.filter-chip:hover{border-color:var(--brand);color:var(--brand)}.filter-chip--active{background:var(--brand);border-color:var(--brand);color:#fff}.oploan-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 20px;display:flex}.oploan-empty-icon{font-size:48px}.oploan-empty-title{color:var(--text-2);font-size:18px;font-weight:600}.oploan-empty-sub{color:var(--text-3);font-size:13px}.modal--tall{max-height:90vh;overflow-y:auto}.oploan-detail-body{flex-direction:column;gap:20px;display:flex}.oploan-detail-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.oploan-detail-item{flex-direction:column;gap:3px;display:flex}.oploan-detail-item--full{grid-column:1/-1}.oploan-detail-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.oploan-detail-value{color:var(--text-1);font-size:14px}.oploan-detail-value--large{letter-spacing:-.5px;font-size:22px;font-weight:800}.oploan-section{flex-direction:column;gap:10px;display:flex}.oploan-section-header{justify-content:space-between;align-items:center;display:flex}.oploan-section-header h3{color:var(--text-1);margin:0;font-size:14px;font-weight:700}.oploan-payments-table{border-collapse:collapse;width:100%;font-size:13px}.oploan-payments-table th{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);padding:6px 10px;font-size:11px;font-weight:600}.oploan-payments-table td{border-bottom:1px solid var(--border);color:var(--text-1);padding:8px 10px}.oploan-payments-table tr:last-child td{border-bottom:none}.oploan-attachments-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;display:grid}.oploan-attachment-card{border:1.5px solid var(--border);border-radius:var(--r-sm);color:var(--text-2);text-align:center;flex-direction:column;align-items:center;gap:6px;padding:10px;font-size:11px;text-decoration:none;transition:border-color .12s;display:flex;overflow:hidden}.oploan-attachment-card:hover{border-color:var(--brand);color:var(--brand)}.oploan-attachment-thumb{aspect-ratio:1;object-fit:cover;border-radius:4px;width:100%}.oploan-attachment-icon{width:40px;height:40px;color:var(--text-3)}.oploan-attachment-icon svg{width:100%;height:100%}.oploan-attachment-name{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:11px;overflow:hidden}.oploan-attachments{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.oploan-attachment-chip{color:var(--text-1);background:#f1f5f9;border-radius:6px;align-items:center;gap:6px;padding:4px 8px;font-size:12px;display:flex}.oploan-attachment-remove{cursor:pointer;color:var(--text-3);background:0 0;border:none;padding:0;font-size:16px;line-height:1}.oploan-attachment-remove:hover{color:#dc2626}.oploan-upload-btn{cursor:pointer}.oploan-payment-hint{color:var(--text-2);border:1px solid var(--border);background:#f8fafc;border-radius:6px;margin:0 0 12px;padding:8px 14px;font-size:13px}.btn--sm{padding:5px 12px;font-size:12px}.btn--loading{opacity:.7;pointer-events:none}.oploan-groups{flex-direction:column;gap:12px;display:flex}.oploan-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);overflow:hidden}.oploan-group-header{background:var(--surface-2,#f8fafc);border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;flex-wrap:wrap;align-items:center;gap:12px;width:100%;padding:12px 16px;font-family:inherit;transition:background .12s;display:flex}.oploan-group-header:hover{background:var(--surface-3,#f1f5f9)}.oploan-group-chevron{color:var(--text-3);min-width:12px;font-size:11px}.oploan-group-name{color:var(--text-1);flex:1;min-width:120px;font-size:15px;font-weight:700}.oploan-group-badge{color:#4338ca;white-space:nowrap;background:#e0e7ff;border-radius:99px;padding:2px 9px;font-size:11px;font-weight:600}.oploan-group-stat{color:var(--text-2);white-space:nowrap;font-size:13px;font-weight:600}.oploan-group-stat--outstanding{color:#b45309}.oploan-group-stat--interest{color:#d97706}.oploan-group-cards{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:16px;display:grid}.oploan-card__interest{background:#fffbeb;border:1px solid #fde68a;border-radius:6px;flex-direction:column;gap:4px;padding:8px 10px;display:flex}.oploan-interest-row{align-items:center;gap:8px;font-size:12px;display:flex}.oploan-interest-row--owed{border-top:1px solid #fde68a;margin-top:2px;padding-top:4px}.oploan-interest-label{color:var(--text-3);flex-shrink:0;min-width:88px}.oploan-interest-value{color:var(--text-1);flex:1;font-weight:600}.oploan-interest-owed{color:#d97706}.oploan-autocomplete{background:var(--surface);border:1.5px solid var(--brand);border-radius:0 0 var(--r-sm) var(--r-sm);z-index:100;box-shadow:var(--shadow-md);border-top:none;max-height:200px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.oploan-autocomplete-item{text-align:left;width:100%;color:var(--text-1);cursor:pointer;border:none;border-bottom:1px solid var(--border);background:0 0;padding:8px 12px;font-family:inherit;font-size:13px;transition:background .1s;display:block}.oploan-autocomplete-item:last-child{border-bottom:none}.oploan-autocomplete-item:hover{background:var(--surface-2,#f8fafc);color:var(--brand)}.oploan-header-row{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.oploan-header-row .page-title{margin:0}.oploan-header-actions{align-items:center;gap:10px;display:flex}.oploan-btn-print{color:#6366f1;cursor:pointer;background:#fff;border:1.5px solid #6366f1;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:600;transition:background .15s,color .15s}.oploan-btn-print:hover{color:#fff;background:#6366f1}.oploan-print-header{display:none}@media print{.app-header,.oploan-header-actions,.oploan-filters,.oploan-card__actions,.oploan-group-chevron{display:none!important}.app-main,.oploan-groups,.oploan-group,.oploan-group-cards,.oploan-card{height:auto!important;max-height:none!important;overflow:visible!important}body,.app-main{color:#000!important;background:#fff!important}.oploan-groups{display:block!important}.oploan-group{page-break-inside:avoid;break-inside:avoid;border:1px solid #ccc!important;border-radius:0!important;margin-bottom:20px!important;display:block!important}.oploan-group-header{pointer-events:none;cursor:default;background:#f0f0f0!important;border-bottom:1px solid #ccc!important}.oploan-group-cards{padding:12px 16px!important;display:block!important}.oploan-card{page-break-inside:avoid;break-inside:avoid;color:#000!important;background:#fff!important;border:1px solid #ddd!important;border-radius:4px!important;margin-bottom:12px!important;display:block!important}.oploan-print-header{display:block!important}}.task-id-badge{color:var(--text-3);background:var(--bg);border:1px solid var(--border);letter-spacing:.2px;border-radius:4px;margin-bottom:4px;padding:1px 5px;font-family:Courier New,monospace;font-size:10px;font-weight:600;display:inline-block}.column--done{opacity:.85;border-style:dashed}.column--done-over{opacity:1;border-color:#10b981;box-shadow:0 0 0 3px #10b98126}.column__header--done{background:var(--bg)}.column__done-icon{color:#94a3b8;flex-shrink:0;justify-content:center;align-items:center;width:9px;height:9px;font-size:11px;display:flex}.column__title--done{color:var(--text-3)}.column__count--done{color:#166534;background:#dcfce7;border-color:#bbf7d0}.column__done-badge{border-radius:var(--r-sm);color:#166534;letter-spacing:.1px;background:#dcfce7;border:1px solid #bbf7d0;justify-content:center;align-items:center;padding:6px 10px;font-size:13px;font-weight:600;display:flex}.column__tasks--done-zone{flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:80px;padding:12px;display:flex}.done-drop-hint{color:var(--text-3);text-align:center;border:1.5px dashed var(--border);border-radius:var(--r-sm);flex-direction:column;align-items:center;gap:6px;width:100%;padding:16px 12px;font-size:12px;display:flex}.done-drop-hint__icon{color:#94a3b8;font-size:20px}.board-reports-btn{border-radius:var(--r-sm);color:#cbd5e1;cursor:pointer;background:#ffffff0f;border:1.5px solid #ffffff26;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.board-reports-btn:hover{color:#a5b4fc;background:#6366f126;border-color:#6366f166}.board-reports-btn__count{color:#fff;background:#6366f1;border-radius:100px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;display:inline-flex}.modal--reports{flex-direction:column;width:96vw;max-width:900px;max-height:90vh;display:flex}.reports-modal__header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.reports-modal__header h2{color:var(--text-1);margin:0;font-size:17px;font-weight:700}.reports-modal__header-actions{align-items:center;gap:8px;display:flex}.reports-modal__body{flex-direction:column;flex:1;gap:14px;padding:16px 20px 20px;display:flex;overflow:hidden}.reports-search-wrap{flex-shrink:0;position:relative}.reports-search-icon{width:15px;height:15px;color:var(--text-3);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.reports-search-input{border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text-1);background:var(--surface);box-sizing:border-box;padding:9px 12px 9px 34px;font-size:14px;transition:border-color .15s,box-shadow .15s}.reports-search-input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f11f}.reports-search-input::placeholder{color:var(--text-3)}.reports-empty{color:var(--text-3);flex:1;justify-content:center;align-items:center;padding:40px 0;font-size:14px;display:flex}.reports-table-wrap{border:1px solid var(--border);border-radius:var(--r-md);flex:1;overflow-y:auto}.reports-table{border-collapse:collapse;width:100%;font-size:13px}.reports-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap;z-index:1;padding:10px 14px;font-size:11px;font-weight:700;position:sticky;top:0}.reports-table td{border-bottom:1px solid var(--border);color:var(--text-1);vertical-align:middle;padding:11px 14px}.reports-table tbody tr:last-child td{border-bottom:none}.reports-table tbody tr:hover td{background:#f1f5f980}.reports-td--num{color:var(--text-3);width:36px;font-size:12px}.reports-td--title{max-width:220px;font-weight:600}.reports-td--date{white-space:nowrap;color:var(--text-2)}.reports-taskid{color:#6366f1;white-space:nowrap;background:#6366f114;border:1px solid #6366f133;border-radius:4px;padding:2px 6px;font-family:Courier New,monospace;font-size:12px;font-weight:600}.reports-empty-cell{color:var(--text-3)}.reports-priority{letter-spacing:.3px;text-transform:capitalize;white-space:nowrap;border-radius:100px;padding:2px 8px;font-size:11px;font-weight:700}.reports-priority--low{color:#059669;background:#ecfdf5}.reports-priority--medium{color:#d97706;background:#fffbeb}.reports-priority--high{color:#dc2626;background:#fef2f2}.reports-priority--critical{color:#7c3aed;background:#f5f3ff}
