@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Noto+Sans+Bengali:wght@300;400;500;600;700&display=swap";
:root{--brand-primary:#4f46e5;--brand-primary-light:#6366f1;--brand-primary-dark:#4338ca;--brand-accent:#059669;--brand-accent-light:#10b981;--bg-base:#f0f2f5;--bg-surface:#fff;--bg-card:#fff;--bg-muted:#f8f9fb;--border-subtle:#e5e7eb;--border-medium:#d1d5db;--border-accent:#4f46e540;--text-primary:#111827;--text-secondary:#4b5563;--text-muted:#9ca3af;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000012;--shadow-lg:0 10px 30px #0000001a;--shadow-glow:0 4px 20px #4f46e51f;--shadow-card:0 1px 3px #0000000f, 0 1px 2px #0000000a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--ease-out:cubic-bezier(.16, 1, .3, 1)}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-base);color:var(--text-primary);min-height:100vh;font-family:Inter,Noto Sans Bengali,sans-serif;line-height:1.6;overflow-x:hidden}body:before{content:"";background:linear-gradient(90deg, var(--brand-primary) 0%, var(--brand-accent) 50%, var(--brand-primary-light) 100%);z-index:100;height:4px;position:fixed;top:0;left:0;right:0}.bg-effects{z-index:0;pointer-events:none;position:fixed;inset:0}.bg-effects:before{content:"";background:radial-gradient(circle,#4f46e50a 0%,#0000 70%);border-radius:50%;width:700px;height:700px;animation:20s ease-in-out infinite floatOrb;position:absolute;top:-30%;left:-15%}.bg-effects:after{content:"";background:radial-gradient(circle,#05966908 0%,#0000 70%);border-radius:50%;width:600px;height:600px;animation:25s ease-in-out infinite reverse floatOrb;position:absolute;bottom:-15%;right:-15%}@keyframes floatOrb{0%,to{transform:translate(0)scale(1)}25%{transform:translate(50px,-30px)scale(1.05)}50%{transform:translate(-20px,40px)scale(.95)}75%{transform:translate(30px,20px)scale(1.02)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.login-page{z-index:1;background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative}.login-container{border-radius:var(--radius-xl);width:100%;max-width:960px;min-height:560px;box-shadow:var(--shadow-lg);animation:fadeInUp .6s var(--ease-out);display:flex;overflow:hidden}.login-branding{color:#fff;background:linear-gradient(145deg,#1e1b4b 0%,#312e81 50%,#1e1b4b 100%);flex-direction:column;flex:1;justify-content:space-between;padding:48px 40px;display:flex;position:relative;overflow:hidden}.login-branding:before{content:"";background:radial-gradient(circle,#6366f126 0%,#0000 70%);border-radius:50%;width:100%;height:100%;position:absolute;top:-50%;right:-50%}.brand-content{z-index:1;position:relative}.brand-icon{justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:24px;display:flex}.brand-title{letter-spacing:-.5px;margin-bottom:4px;font-size:28px;font-weight:800}.brand-subtitle{color:#fff9;font-size:15px;font-weight:400}.brand-divider{background:linear-gradient(90deg,#818cf8,#34d399);border-radius:2px;width:40px;height:3px;margin:24px 0}.brand-description{color:#ffffffb3;margin-bottom:28px;font-size:14px;line-height:1.7}.brand-features{flex-direction:column;gap:10px;display:flex}.brand-feature{color:#ffffffbf;align-items:center;gap:10px;font-size:13px;display:flex}.feature-dot{background:#34d399;border-radius:50%;flex-shrink:0;width:6px;height:6px}.brand-footer{color:#ffffff59;z-index:1;font-size:11px;position:relative}.login-form-section{background:var(--bg-surface);flex:1;justify-content:center;align-items:center;padding:48px 40px;display:flex}.login-form-wrapper{width:100%;max-width:340px}.form-header{margin-bottom:32px}.form-header h2{color:var(--text-primary);margin-bottom:6px;font-size:24px;font-weight:700}.form-header p{color:var(--text-muted);font-size:14px}.login-form .form-group{margin-bottom:20px}.login-form label{letter-spacing:.5px;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:600;display:block}.login-form .input-wrapper{align-items:center;display:flex;position:relative}.login-form .input-icon{color:var(--text-muted);pointer-events:none;z-index:1;position:absolute;left:14px}.login-form input{border:1.5px solid var(--border-subtle);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:var(--bg-muted);outline:none;padding:12px 14px 12px 42px;font-family:inherit;font-size:14px;transition:all .2s}.login-form input:focus{border-color:var(--brand-primary);background:var(--bg-surface);box-shadow:0 0 0 3px #4f46e514}.login-form input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef444414}.password-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;right:12px}.password-toggle:hover{color:var(--text-secondary)}.form-error{color:#ef4444;align-items:center;gap:8px;margin-bottom:16px;font-size:13px;font-weight:500;animation:.3s fadeIn;display:flex}.login-submit-btn{border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-light) 100%);color:#fff;cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:flex}.login-submit-btn:hover{background:linear-gradient(135deg, var(--brand-primary-dark) 0%, var(--brand-primary) 100%);transform:translateY(-1px);box-shadow:0 4px 16px #4f46e559}.login-submit-btn:active{transform:translateY(0)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-footer-text{color:var(--text-muted);text-align:center;margin-top:28px;font-size:12px}@media (max-width:768px){.login-container{flex-direction:column;min-height:auto}.login-branding,.login-form-section{padding:32px 24px}.brand-features{display:none}}.app-wrapper{z-index:1;max-width:1440px;margin:0 auto;padding:20px;position:relative}.page-header{text-align:center;animation:fadeInDown .6s var(--ease-out);margin-bottom:4px;padding:44px 20px 24px}.company-badge{background:linear-gradient(135deg,#4f46e514,#0596690f);border:1px solid #4f46e526;border-radius:50px;align-items:center;gap:8px;margin-bottom:18px;padding:8px 20px;display:inline-flex}.company-badge .dot{background:var(--brand-accent);border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse}.company-badge span{letter-spacing:1.5px;text-transform:uppercase;color:var(--brand-primary);font-size:12px;font-weight:600}.page-header h1{background:linear-gradient(135deg, var(--text-primary) 0%, var(--brand-primary) 60%, var(--brand-accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:clamp(26px,3.5vw,38px);font-weight:800}.page-header .subtitle{color:var(--text-secondary);max-width:600px;margin:0 auto;font-size:15px}.logout-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;transition:all .2s;display:flex;position:absolute;top:52px;right:24px}.logout-btn:hover{color:#ef4444;background:#ef44440d;border-color:#ef4444}.stats-bar{animation:fadeInUp .8s var(--ease-out) .2s both;flex-wrap:wrap;justify-content:center;gap:14px;margin-bottom:24px;padding:8px 20px;display:flex}.stat-item{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-card);transition:all .3s var(--ease-out);align-items:center;gap:12px;padding:14px 22px;display:flex}.stat-item:hover{border-color:var(--border-accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.stat-value{color:var(--text-primary);font-size:20px;font-weight:700}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.tab-nav{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);width:fit-content;box-shadow:var(--shadow-sm);animation:fadeInUp .8s var(--ease-out) .3s both;justify-content:center;gap:4px;margin-bottom:28px;margin-left:auto;margin-right:auto;padding:5px;display:flex}.tab-btn{color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all .3s var(--ease-out);white-space:nowrap;background:0 0;border:none;padding:10px 22px;font-family:inherit;font-size:13px;font-weight:500}.tab-btn:hover{color:var(--text-primary);background:var(--bg-muted)}.tab-btn.active{color:#fff;background:var(--brand-primary);box-shadow:0 2px 8px #4f46e54d}.dept-grid{animation:fadeInUp .5s var(--ease-out);grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;margin-bottom:40px;display:grid}.dept-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:all .4s var(--ease-out);flex-direction:column;display:flex;overflow:hidden}.dept-card .dept-card-body{flex:1}.dept-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-4px)}.dept-card-header{border-bottom:1px solid var(--border-subtle);background:var(--bg-muted);align-items:center;gap:14px;padding:18px 22px;display:flex}.dept-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.dept-name{color:var(--text-primary);font-size:16px;font-weight:700}.dept-count{color:var(--text-muted);margin-top:2px;font-size:12px}.dept-card-body{padding:12px 22px 18px}.emp-mini-list{list-style:none}.emp-mini-item{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:10px 0;transition:all .2s;display:flex}.emp-mini-item:last-child{border-bottom:none}.emp-mini-item:hover{padding-left:6px}.emp-mini-left{align-items:center;gap:10px;display:flex}.emp-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}.emp-mini-name{color:var(--text-primary);font-size:14px;font-weight:500}.emp-mini-role{color:var(--text-muted);font-size:11px}.emp-mini-salary{color:var(--brand-accent);white-space:nowrap;font-size:13px;font-weight:600}.table-container{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);animation:fadeInUp .5s var(--ease-out);overflow:hidden}.table-header-bar{border-bottom:1px solid var(--border-subtle);background:var(--bg-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 22px;display:flex}.table-title{color:var(--text-primary);font-size:15px;font-weight:700}.search-box{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:8px 16px;transition:all .3s;display:flex}.search-box:focus-within{border-color:var(--brand-primary);box-shadow:0 0 0 3px #4f46e51a}.search-box input{color:var(--text-primary);background:0 0;border:none;outline:none;width:200px;font-family:inherit;font-size:13px}.search-box input::placeholder{color:var(--text-muted)}.emp-table{border-collapse:collapse;width:100%}.emp-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);background:var(--bg-muted);border-bottom:1px solid var(--border-subtle);padding:11px 18px;font-size:11px;font-weight:600;position:sticky;top:0}.emp-table tbody tr{transition:all .2s}.emp-table tbody tr:hover{background:#4f46e508}.emp-table tbody td{border-bottom:1px solid var(--border-subtle);vertical-align:middle;padding:13px 18px;font-size:14px}.emp-table tbody tr:last-child td{border-bottom:none}.table-emp-info{align-items:center;gap:10px;display:flex}.table-emp-info .emp-avatar{width:36px;height:36px;font-size:13px}.table-emp-name{color:var(--text-primary);font-weight:600}.dept-badge{border-radius:50px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-flex}.dept-badge .badge-dot{border-radius:50%;width:6px;height:6px}.designation-text{color:var(--text-primary);font-weight:500}.salary-text{color:var(--brand-accent);font-size:14px;font-weight:600}.resp-tags{flex-wrap:wrap;gap:4px;display:flex}.resp-tag{color:var(--brand-primary);white-space:nowrap;background:#4f46e514;border:1px solid #4f46e526;border-radius:50px;padding:3px 10px;font-size:11px;font-weight:500}.resp-tag.service{color:var(--brand-accent);background:#05966914;border-color:#05966926}.salary-note{color:var(--text-muted);font-size:12px;font-style:italic;font-weight:500}.emp-note{color:var(--text-muted);margin-top:2px;font-size:10px;font-style:italic}.acting-badge{color:#b45309;cursor:help;background:#f59e0b1f;border:1px solid #f59e0b4d;border-radius:50px;align-items:center;gap:3px;margin-top:5px;padding:2px 10px;font-size:10px;font-weight:600;transition:all .2s;display:inline-flex;position:relative}.designation-text{align-items:inherit;color:#6366f1;flex-direction:column;font-size:13px;font-weight:500;display:flex}.org-emp-card .designation-text,.org-emp-card.compact .designation-text{align-items:center}.acting-badge:hover{background:#f59e0b38;border-color:#f59e0b80;transform:scale(1.05)}.acting-info-icon{opacity:.6;font-size:10px}.acting-badge:after{content:attr(data-tooltip);color:#374151;white-space:normal;text-align:left;z-index:1000;opacity:0;visibility:hidden;pointer-events:none;background:#fff;border:1px solid #e5e7eb;border-radius:12px;width:300px;padding:14px 18px;font-size:12.5px;font-weight:400;line-height:1.7;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%)translateY(6px);box-shadow:0 10px 40px #0000001f,0 2px 8px #0000000f}.acting-badge:before{content:"";filter:drop-shadow(0 2px 2px #0000000f);z-index:1001;opacity:0;visibility:hidden;border:7px solid #0000;border-top-color:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;bottom:calc(100% + 5px);left:50%;transform:translate(-50%)}.acting-badge:hover:after,.acting-badge:hover:before{opacity:1;visibility:visible;transform:translate(-50%)translateY(0)}.org-tree-wrapper{animation:fadeInUp .5s var(--ease-out);flex-direction:column;align-items:center;padding:40px 20px 60px;display:flex;overflow-x:auto}.org-root{justify-content:center;display:flex}.org-root-card{background:linear-gradient(135deg, var(--brand-primary), var(--brand-primary-dark));color:#fff;border-radius:var(--radius-lg);text-align:center;z-index:2;transition:all .3s var(--ease-out);padding:22px 40px;position:relative;box-shadow:0 8px 30px #4f46e54d}.org-root-card:hover{transform:translateY(-3px)scale(1.02);box-shadow:0 12px 40px #4f46e566}.org-root-logo{margin-bottom:8px;font-size:28px}.org-root-name{letter-spacing:.3px;font-size:18px;font-weight:800}.org-root-sub{opacity:.8;margin-top:4px;font-size:12px;font-weight:500}.org-connector-v{background:linear-gradient(to bottom, var(--brand-primary), var(--border-medium));flex-shrink:0;width:2px;height:35px;margin:0 auto}.org-connector-v.short{background:var(--border-medium);height:24px}.org-connector-v.tiny{background:var(--border-medium);height:16px}.org-connector-h,.org-emp-connector-h{background:var(--border-medium);border-radius:1px;height:2px;margin:0 auto}.org-branches{flex-wrap:wrap;justify-content:center;gap:50px;display:flex}.org-branch{flex-direction:column;align-items:center;display:flex}.org-dept-node{background:var(--bg-card);border:1px solid var(--border-subtle);border-top:3px solid var(--brand-primary);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-md);transition:all .3s var(--ease-out);min-width:180px;padding:18px 28px;position:relative}.org-dept-node:hover{box-shadow:var(--shadow-glow);border-color:var(--border-accent);transform:translateY(-4px)}.org-dept-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:42px;height:42px;margin:0 auto 10px;font-size:20px;display:flex}.org-dept-name{color:var(--text-primary);font-size:16px;font-weight:700}.org-dept-count{color:var(--text-muted);margin-top:3px;font-size:12px}.org-emp-row{flex-wrap:wrap;justify-content:center;align-items:stretch;gap:24px;display:flex}.org-emp-branch{flex-direction:column;align-items:center;display:flex}.org-emp-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-card);transition:all .4s var(--ease-out);flex-direction:column;justify-content:center;align-items:center;width:280px;min-height:240px;padding:24px 28px;display:flex;position:relative}.org-emp-card:hover{border-color:var(--border-accent);transform:translateY(-5px);box-shadow:0 12px 30px #4f46e51f}.org-emp-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 12px;font-size:16px;font-weight:700;transition:transform .3s;display:flex;box-shadow:0 4px 12px #00000026}.org-emp-card:hover .org-emp-avatar{transform:scale(1.1)}.org-emp-name{color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:700;line-height:1.3}.org-emp-designation{color:#6366f1;margin-bottom:8px;font-size:12px;font-weight:500;line-height:1.3}.org-emp-salary{color:var(--brand-accent);font-size:13px;font-weight:700}.org-emp-salary.note{color:var(--text-muted);font-size:11px;font-style:italic;font-weight:500}.org-emp-tags{flex-wrap:wrap;justify-content:center;gap:4px;margin-top:10px;display:flex}.org-emp-tag{color:var(--brand-primary);background:#4f46e512;border:1px solid #4f46e51f;border-radius:50px;padding:2px 8px;font-size:10px;font-weight:500}.org-tree{animation:fadeInUp .5s var(--ease-out);padding:30px 20px}.org-child-depts-row{justify-content:center;gap:24px;margin-top:0;display:flex}.org-sub-dept{flex-direction:column;align-items:center;margin-top:0;display:flex}.org-sub-emp{flex-direction:column;align-items:center;display:flex}.org-sub-dept-badge{background:var(--bg-card);border:1px solid var(--border-subtle);border-left:3px solid var(--brand-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);align-items:center;gap:8px;padding:8px 18px;transition:all .3s;display:flex}.org-sub-dept-badge:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.org-sub-dept-icon{font-size:16px}.org-sub-dept-name{color:var(--text-primary);font-size:13px;font-weight:700}.org-emp-card.compact{width:280px;min-height:240px;padding:24px 28px}.org-emp-avatar.small{width:38px;height:38px;margin-bottom:10px;font-size:13px}.ps-grid{animation:fadeInUp .5s var(--ease-out);grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;display:grid}.ps-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:all .4s var(--ease-out);overflow:hidden}.ps-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-3px)}.ps-card-header{border-bottom:1px solid var(--border-subtle);background:var(--bg-muted);align-items:center;gap:12px;padding:16px 22px;display:flex}.ps-type-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:50px;padding:4px 12px;font-size:11px;font-weight:600}.ps-type-badge.product{color:var(--brand-primary);background:#4f46e51a}.ps-type-badge.service-badge{color:var(--brand-accent);background:#0596691a}.ps-card-name{color:var(--text-primary);font-size:16px;font-weight:700}.ps-card-body{padding:14px 22px 18px}.ps-member-list{list-style:none}.ps-member-item{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.ps-member-item:last-child{border-bottom:none}.ps-member-left{align-items:center;gap:10px;display:flex}.ps-member-name{color:var(--text-primary);font-size:14px;font-weight:500}.ps-responsibility-tag{color:#d97706;background:#d9770614;border:1px solid #d9770626;border-radius:50px;padding:3px 10px;font-size:11px;font-weight:500}.no-data{text-align:center;color:var(--text-muted);grid-column:1/-1;padding:60px 20px}.no-data-icon{opacity:.4;margin-bottom:16px;font-size:48px}.no-data-text{color:var(--text-secondary);margin-bottom:6px;font-size:16px}.no-data-sub{font-size:13px}.page-footer{text-align:center;border-top:1px solid var(--border-subtle);margin-top:40px;padding:36px 20px}.page-footer p{color:var(--text-muted);font-size:13px}.page-footer .heart{color:#ef4444}.footer-sub{margin-top:6px}.resp-details-btn{color:var(--brand-primary);cursor:pointer;white-space:nowrap;background:#4f46e50f;border:1px solid #4f46e533;border-radius:50px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:600;transition:all .2s}.resp-details-btn:hover{background:var(--brand-primary);color:#fff;transform:scale(1.05);box-shadow:0 2px 8px #4f46e54d}.resp-empty{color:var(--text-muted);font-size:12px}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0006;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:80vh;animation:fadeInUp .3s var(--ease-out);overflow:hidden;box-shadow:0 20px 60px #00000026}.modal-header{border-bottom:1px solid var(--border-subtle);background:linear-gradient(135deg,#4f46e50a,#05966905);justify-content:space-between;align-items:flex-start;padding:24px 28px 18px;display:flex}.modal-title{color:var(--text-primary);margin:0 0 4px;font-size:20px;font-weight:700}.modal-subtitle{color:var(--text-muted);margin:0;font-size:13px;font-weight:500}.modal-close{border:1px solid var(--border-subtle);background:var(--bg-surface);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex}.modal-close:hover{color:#fff;background:#ef4444;border-color:#ef4444}.modal-body{max-height:calc(80vh - 100px);padding:20px 28px 28px;overflow-y:auto}.resp-section{border-bottom:1px solid var(--border-subtle);padding:18px 0}.resp-section:last-child{border-bottom:none;padding-bottom:0}.resp-section:first-child{padding-top:0}.resp-section-header{align-items:center;gap:12px;margin-bottom:14px;display:flex}.resp-section-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.resp-section-icon.service{background:#0596691a}.resp-section-icon.product{background:#4f46e51a}.resp-section-title{color:var(--text-primary);margin:0 0 4px;font-size:15px;font-weight:700}.resp-type-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:50px;padding:2px 10px;font-size:10px;font-weight:600;display:inline-block}.resp-type-badge.service{color:var(--brand-accent);background:#0596691a}.resp-type-badge.product{color:var(--brand-primary);background:#4f46e51a}.resp-detail-list{margin:0;padding:0;list-style:none}.resp-detail-item{color:var(--text-secondary);border-radius:var(--radius-sm);align-items:flex-start;gap:10px;padding:7px 0 7px 12px;font-size:13px;line-height:1.5;transition:all .2s;display:flex}.resp-detail-item:hover{background:#4f46e50a;padding-left:16px}.resp-bullet{color:var(--brand-primary);flex-shrink:0;margin-top:1px;font-weight:700}@media (max-width:768px){.app-wrapper{padding:12px}.stats-bar{gap:8px}.stat-item{padding:10px 14px}.dept-grid,.ps-grid{grid-template-columns:1fr}.tab-nav{flex-wrap:wrap;width:calc(100% - 24px)}.emp-table{font-size:13px}.search-box input{width:140px}.table-header-bar{flex-direction:column}.logout-btn{padding:6px 12px;font-size:12px;top:48px;right:12px}.page-header{padding:44px 16px 20px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.org-tree-wrapper-v2{background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);width:100%;animation:fadeInUp .5s var(--ease-out);flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.org-tree-canvas{cursor:grab;flex:1;width:100%;min-height:0}.org-tree-canvas:active{cursor:grabbing}.org-tree-controls{z-index:10;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-card);align-items:center;gap:6px;padding:6px 10px;display:flex;position:absolute;top:16px;right:16px}.org-tree-controls button{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-primary);width:32px;height:32px;color:var(--text-primary);cursor:pointer;justify-content:center;align-items:center;font-size:16px;font-weight:700;transition:all .2s;display:flex}.org-tree-controls button:hover{background:var(--brand);color:#fff;border-color:var(--brand)}.org-tree-zoom-label{color:var(--text-muted);text-align:center;min-width:36px;font-size:11px;font-weight:600}.org-tree-hint{z-index:10;color:var(--text-muted);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--border-subtle);white-space:nowrap;background:#ffffffeb;border-radius:20px;padding:6px 16px;font-size:11px;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.org-tree-link{fill:none;stroke:var(--border-medium);stroke-width:2px;stroke-dasharray:none}.org-tree-company-node{color:#fff;text-align:center;cursor:pointer;background:linear-gradient(135deg,#4f46e5 0%,#3730a3 100%);border-radius:16px;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:14px 20px;transition:transform .2s;display:flex;box-shadow:0 6px 20px #4f46e54d}.org-tree-company-node:hover{transform:scale(1.03)}.org-tree-company-logo{margin-bottom:4px;font-size:22px}.org-tree-company-name{letter-spacing:-.3px;font-size:16px;font-weight:800}.org-tree-company-sub{opacity:.85;margin-top:2px;font-size:11px}.org-tree-dept-node{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-left:4px solid #4f46e5;border-radius:10px;align-items:center;gap:8px;width:100%;height:100%;padding:10px 16px;transition:all .2s;display:flex;box-shadow:0 1px 4px #0000000f}.org-tree-dept-node:hover{border-color:#818cf8;transform:scale(1.04);box-shadow:0 4px 16px #4f46e51f}.org-tree-dept-icon{font-size:16px}.org-tree-dept-name{color:#1e293b;flex:1;font-size:13px;font-weight:700}.org-tree-dept-expand{color:#fff;background:#4f46e5;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:14px;font-weight:700;line-height:1;display:flex}.org-tree-emp-card{text-align:center;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:100%;height:100%;padding:16px 20px;transition:all .3s ease-out;display:flex;box-shadow:0 1px 4px #0000000f}.org-tree-emp-card:hover{border-color:#818cf8;transform:scale(1.04);box-shadow:0 10px 28px #4f46e524}.org-tree-avatar{color:#fff;letter-spacing:-.5px;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:6px;font-size:14px;font-weight:800;display:flex;box-shadow:0 3px 8px #00000026}.org-tree-emp-name{color:#1e293b;font-size:13px;font-weight:700;line-height:1.3}.org-tree-emp-designation{color:#6366f1;font-size:11px;font-weight:500;line-height:1.3}.org-tree-acting-row{justify-content:center;margin-top:2px;display:flex}.org-tree-acting-badge{color:#b45309;cursor:default;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf24;border-radius:12px;padding:2px 10px;font-size:10px;font-weight:600}.org-tree-salary{color:#059669;margin-top:2px;font-size:12px;font-weight:700}.org-tree-salary.note{color:#94a3b8;font-size:10px;font-style:italic;font-weight:500}.org-tree-tags{flex-wrap:wrap;justify-content:center;gap:4px;margin-top:4px;display:flex}.org-tree-tag{color:#475569;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:10px;padding:2px 8px;font-size:9px;font-weight:500}.org-tree-expand-hint{color:#4f46e5;margin-top:4px;font-size:9px;font-weight:500;animation:1.5s ease-in-out infinite pulse-hint}@keyframes pulse-hint{0%,to{opacity:.5}50%{opacity:1}}.orgchart-fullpage{background:var(--bg-secondary);flex-direction:column;height:100vh;display:flex;overflow:hidden}.orgchart-topbar{background:var(--bg-card);border-bottom:1px solid var(--border-subtle);z-index:20;flex-shrink:0;align-items:center;gap:16px;padding:10px 20px;display:flex;box-shadow:0 1px 4px #0000000f}.orgchart-back-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;padding:6px 14px;font-size:13px;font-weight:600;transition:all .2s}.orgchart-back-btn:hover{background:var(--brand);color:#fff;border-color:var(--brand)}.orgchart-title{color:var(--text-primary);flex:1;font-size:15px;font-weight:700}.orgchart-topbar-spacer{flex-shrink:0;width:100px}.orgchart-main{flex:1;overflow:hidden}.orgchart-link-btn{border-left:2px solid var(--border-subtle)!important;margin-left:4px!important}.orgchart-link-btn:hover{background:var(--brand)!important;color:#fff!important}@media print{.bg-effects,.tab-nav,.search-box,body:before,.logout-btn{display:none!important}body{color:#1a1a1a;background:#fff}.dept-card,.table-container,.ps-card,.org-node{box-shadow:none;background:#fff;border:1px solid #ddd}}.reports-container{max-width:1400px;margin:0 auto}.reports-header{text-align:center;margin-bottom:28px}.reports-header h2{color:var(--text-main);margin-bottom:6px;font-size:24px;font-weight:700}.reports-header p{color:var(--text-muted);font-size:14px}.report-summary-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.report-summary-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-card);align-items:center;gap:14px;padding:18px 20px;transition:all .3s;display:flex}.report-summary-card:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.rsc-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.rsc-value{color:var(--text-main);font-size:18px;font-weight:700}.rsc-label{color:var(--text-muted);margin-top:2px;font-size:12px}.reports-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.report-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:24px;transition:all .3s}.report-card:hover{box-shadow:var(--shadow-glow)}.report-card.wide{grid-column:span 1}.report-card-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;display:flex}.report-card-header h3{color:var(--text-main);font-size:15px;font-weight:600}.report-badge{color:#6366f1;background:#6366f114;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:500}.bar-chart{flex-direction:column;gap:10px;display:flex}.bar-row{align-items:center;gap:10px;display:flex}.bar-label{width:160px;color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:12px;font-weight:500;overflow:hidden}.bar-track{background:var(--bg-subtle);border-radius:11px;flex:1;height:22px;position:relative;overflow:hidden}.bar-fill{opacity:.85;border-radius:11px;min-width:4px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.bar-value{text-align:right;white-space:nowrap;flex-shrink:0;width:145px;font-size:12px;font-weight:700}.donut-container{align-items:center;gap:24px;display:flex}.donut-svg{flex-shrink:0;width:160px;height:160px;transform:rotate(-90deg)}.donut-center-text{fill:var(--text-main);transform-origin:50%;font-size:6px;font-weight:700;transform:rotate(90deg)}.donut-center-label{fill:var(--text-muted);transform-origin:50%;font-size:2.5px;transform:rotate(90deg)}.donut-legend{flex-direction:column;flex:1;gap:6px;display:flex}.donut-legend-item{align-items:center;gap:8px;font-size:12px;display:flex}.donut-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.donut-legend-name{color:var(--text-muted);flex:1}.donut-legend-pct{color:var(--text-main);font-weight:700}.top-earners-list{flex-direction:column;gap:8px;display:flex}.earner-row{border-radius:var(--radius-sm);background:var(--bg-subtle);align-items:center;gap:12px;padding:8px 10px;transition:background .2s;display:flex}.earner-row:hover{background:#6366f10a}.earner-rank{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.earner-info{flex:1}.earner-name{color:var(--text-main);font-size:13px;font-weight:600}.earner-dept{color:var(--text-muted);font-size:11px}.earner-salary{color:#10b981;white-space:nowrap;font-size:13px;font-weight:700}.earner-pct{color:var(--text-muted);font-size:11px;font-weight:500}.headcount-chart{flex-direction:column;gap:8px;display:flex}.hc-row{background:var(--bg-subtle);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:10px 12px;transition:background .2s;display:flex}.hc-row:hover{background:#10b9810a}.hc-left{align-items:center;gap:10px;display:flex}.hc-icon{font-size:18px}.hc-name{color:var(--text-main);font-size:13px;font-weight:600}.hc-avg{color:var(--text-muted);font-size:11px}.hc-right{text-align:right}.hc-count{color:#6366f1;font-size:14px;font-weight:700}.hc-total{color:var(--text-muted);font-size:11px}.budget-breakdown{flex-direction:column;gap:16px;display:flex}.budget-meter{background:var(--bg-subtle);border-radius:16px;height:32px;position:relative;overflow:hidden}.budget-meter-fill{background:linear-gradient(90deg,#10b981,#6366f1);border-radius:16px;justify-content:center;align-items:center;height:100%;transition:width 1.5s;display:flex}.budget-meter-fill span{color:#fff;white-space:nowrap;font-size:12px;font-weight:600}.budget-details{flex-direction:column;gap:8px;display:flex}.bd-item{color:var(--text-muted);align-items:center;gap:8px;font-size:13px;display:flex}.bd-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.bd-dot.assigned{background:#10b981}.bd-dot.pending{background:#f59e0b}.bd-dot.total{background:#6366f1}.bd-val{color:var(--text-main);margin-left:auto;font-weight:700}.budget-dept-breakdown{margin-top:8px}.budget-dept-breakdown h4{color:var(--text-main);margin-bottom:10px;font-size:13px;font-weight:600}.bdb-row{align-items:center;gap:10px;margin-bottom:6px;display:flex}.bdb-name{width:140px;color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:11px;overflow:hidden}.bdb-bar-track{background:var(--bg-subtle);border-radius:5px;flex:1;height:10px;overflow:hidden}.bdb-bar-fill{border-radius:5px;min-width:2px;height:100%;transition:width 1s}.bdb-pct{width:44px;color:var(--text-main);text-align:right;font-size:11px;font-weight:700}@media (max-width:768px){.report-summary-row{grid-template-columns:repeat(2,1fr)}.reports-grid{grid-template-columns:1fr}.report-card.wide{grid-column:span 1}.donut-container{flex-direction:column}.bar-label{width:100px}}.footer-logout-btn{color:#ef4444;cursor:pointer;letter-spacing:.3px;background:linear-gradient(135deg,#ef444414,#ef44440a);border:1px solid #ef444433;border-radius:50px;align-items:center;gap:8px;margin-top:16px;padding:10px 28px;font-family:inherit;font-size:13px;font-weight:600;transition:all .3s;display:inline-flex}.footer-logout-btn:hover{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;transform:translateY(-2px);box-shadow:0 6px 20px #ef44444d}.footer-logout-btn .logout-icon{font-size:16px;transition:transform .3s}.footer-logout-btn:hover .logout-icon{transform:scale(1.15)}.kb-layout{background:#f8fafc;height:100vh;font-family:Inter,Noto Sans Bengali,-apple-system,BlinkMacSystemFont,sans-serif;display:flex;overflow:hidden}.kb-sidebar{z-index:100;background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;width:240px;height:100vh;display:flex;position:sticky;top:0}.kb-sidebar-brand{border-bottom:1px solid #f1f5f9;align-items:center;gap:10px;height:56px;padding:0 16px;display:flex}.kb-brand-logo{color:#fff;background:#10b981;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;font-weight:800;display:flex}.kb-brand-text{flex-direction:column;min-width:0;display:flex}.kb-brand-name{color:#0f172a;white-space:nowrap;font-size:14px;font-weight:700;line-height:1.2}.kb-brand-sub{color:#94a3b8;font-size:10px;line-height:1.2}.kb-sidebar-nav{flex-direction:column;flex:1;gap:0;padding:8px 10px;display:flex;overflow-y:auto}.kb-nav-group+.kb-nav-group{margin-top:0}.kb-nav-group-title{color:#3b82f6;text-transform:uppercase;letter-spacing:.08em;cursor:default;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:8px 12px 4px;font-family:inherit;font-size:11.5px;font-weight:700;display:flex}.kb-nav-group-title.expandable{cursor:pointer;border-radius:6px;transition:color .15s}.kb-nav-group-title.expandable:hover{color:#2563eb}.kb-chevron{color:#cbd5e1;font-size:14px;transition:transform .2s}.kb-chevron.open{transform:rotate(90deg)}.kb-nav-list{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex}.kb-nav-link{color:#475569;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:7px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.kb-nav-link:hover{color:#0f172a;background:#f1f5f9}.kb-nav-link.active{color:var(--brand-primary);background:linear-gradient(135deg,#4f46e51a 0%,#6366f114 100%);border:1px solid #4f46e526;font-weight:600}.kb-nav-icon{opacity:.65;text-align:center;flex-shrink:0;width:20px;font-size:15px}.kb-nav-link.active .kb-nav-icon{opacity:1;color:var(--brand-primary)}.kb-main{flex-direction:column;flex:1;min-width:0;height:100vh;display:flex;overflow-y:auto}.kb-header{-webkit-backdrop-filter:blur(12px);z-index:90;background:#ffffffd9;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.kb-header-left{align-items:center;display:flex}.kb-header-right{align-items:center;gap:12px;display:flex}.kb-search{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;width:240px;padding:7px 14px;transition:border-color .2s;display:flex}.kb-search:focus-within{border-color:#94a3b8}.kb-search-icon{color:#94a3b8;flex-shrink:0;font-size:13px}.kb-search input{color:#334155;background:0 0;border:none;outline:none;width:100%;font-family:inherit;font-size:13px}.kb-search input::placeholder{color:#94a3b8}.kb-hdr-btn{cursor:pointer;color:#64748b;background:0 0;border:none;padding:4px;font-size:18px;transition:color .2s;position:relative}.kb-hdr-btn:hover{color:#0f172a}.kb-hdr-badge{background:#f97316;border:1.5px solid #fff;border-radius:50%;width:7px;height:7px;position:absolute;top:2px;right:2px}.kb-profile{border-left:1px solid #e2e8f0;align-items:center;gap:10px;margin-left:8px;padding-left:16px;display:flex}.kb-profile-avatar{color:#fff;background:#10b981;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.kb-profile-info{flex-direction:column;display:flex}.kb-profile-name{color:#0f172a;font-size:12px;font-weight:700;line-height:1.2}.kb-profile-role{color:#64748b;font-size:11px;line-height:1.2}.kb-profile-dropdown{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:4px;font-size:9px}.kb-content{flex:1;overflow-y:auto}.kb-content:has(.hrm-page){padding:0}.kb-page-title{color:#0f172a;margin-bottom:4px;font-size:22px;font-weight:700}.kb-page-subtitle{color:#64748b;margin-bottom:24px;font-size:13px}.hrm-page{background:#f8fafc;flex-direction:column;min-height:100%;display:flex}.hrm-page-header{background:#fff;border-bottom:1px solid #f1f5f9;padding:26px 32px 0}.hrm-eyebrow{color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px;font-size:11px;font-weight:700}.hrm-h1{color:#0f172a;letter-spacing:-.02em;margin:0 0 3px;font-size:21px;font-weight:700}.hrm-subtitle{color:#64748b;margin:0 0 20px;font-size:13.5px;font-weight:400}.hrm-tab-bar{display:flex}.hrm-tab{cursor:pointer;color:#94a3b8;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 18px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.hrm-tab:hover{color:#475569}.hrm-tab.active{color:#4f46e5;border-bottom-color:#4f46e5;font-weight:700}.hrm-body{flex:1;padding:28px 32px}.hrm-stat-strip{background:#fff;border-bottom:1px solid #f1f5f9;align-items:center;gap:36px;padding:14px 32px;display:flex}.hrm-stat-item{flex-direction:column;gap:2px;display:flex}.hrm-stat-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:700}.hrm-stat-value{color:#0f172a;font-size:20px;font-weight:700;line-height:1.1}.hrm-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.hrm-table-head{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.hrm-table-head-title{color:#0f172a;font-size:13px;font-weight:700}table.hrm-table{border-collapse:collapse;width:100%}table.hrm-table thead th{text-align:left;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:9px 16px;font-size:10.5px;font-weight:700}table.hrm-table tbody tr{border-bottom:1px solid #f8fafc;transition:background .1s}table.hrm-table tbody tr:last-child{border-bottom:none}table.hrm-table tbody tr:hover{background:#fafafa}table.hrm-table tbody td{color:#475569;vertical-align:middle;padding:11px 16px;font-size:13.5px}table.hrm-table tfoot td{background:#f8fafc;border-top:1px solid #e2e8f0;padding:12px 16px}.hrm-badge{text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border-radius:5px;align-items:center;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.hrm-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:11px;font-weight:700;display:flex}.hrm-metric-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:14px;padding:20px;transition:box-shadow .15s;display:flex}.hrm-metric-card:hover{box-shadow:0 4px 16px #0000000f}.hrm-metric-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:19px;display:flex}.hrm-metric-value{color:#0f172a;font-size:22px;font-weight:700;line-height:1.1}.hrm-metric-label{color:#64748b;text-transform:uppercase;letter-spacing:.04em;margin-top:1px;font-size:11px;font-weight:600}.hrm-btn-ghost{cursor:pointer;color:#64748b;background:0 0;border:1px solid #e2e8f0;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:11px;font-weight:600;transition:all .1s}.hrm-btn-ghost:hover{color:#0f172a;background:#f8fafc;border-color:#cbd5e1}.hrm-btn-primary{cursor:pointer;color:#fff;background:linear-gradient(135deg,#4f46e5,#6366f1);border:none;border-radius:8px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.hrm-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #4f46e54d}.hrm-btn-secondary{cursor:pointer;color:#475569;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:600}.hrm-btn-secondary:hover{background:#f8fafc}.hrm-progress-bar{background:#f1f5f9;border-radius:99px;height:5px;overflow:hidden}.hrm-progress-fill{border-radius:99px;height:100%;transition:width .5s}.hrm-info-block{flex-direction:column;gap:1px;display:flex}.hrm-info-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:700}.hrm-info-value{color:#475569;font-size:13px;font-weight:500}.hrm-drawer-overlay{z-index:500;background:#0f172a66;justify-content:flex-end;display:flex;position:fixed;inset:0}.hrm-drawer{background:#fff;width:400px;height:100%;overflow-y:auto;box-shadow:-8px 0 40px #0000001f}.hrm-drawer-header{z-index:10;background:#fff;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:sticky;top:0}.hrm-drawer-body{flex-direction:column;gap:22px;padding:24px;display:flex}.hrm-filter-pill{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .12s}.hrm-filter-pill:hover,.hrm-filter-pill.active{color:#fff;background:#0f172a;border-color:#0f172a}.hrm-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;transition:box-shadow .15s,border-color .15s;overflow:hidden}.hrm-card:hover{border-color:#cbd5e1;box-shadow:0 4px 20px #00000012}.emp-card{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:14px;transition:box-shadow .18s,border-color .18s,transform .18s;position:relative;overflow:hidden}.emp-card:hover{border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 8px 32px #00000017}.emp-card-accent{height:4px}.emp-card-body{padding:20px}.emp-card-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:12px;font-size:18px;font-weight:700;display:flex;position:relative}.emp-card-name{color:#0f172a;margin-bottom:2px;font-size:14px;font-weight:700;line-height:1.3}.emp-card-role{color:#64748b;margin-bottom:10px;font-size:11px}.emp-card-footer{background:#f8fafc;border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:10px 20px;display:flex}.hrm-wizard-stepper{align-items:center;gap:0;padding:20px 28px 0;display:flex}.hrm-wizard-step{flex:1;align-items:center;display:flex;position:relative}.hrm-wizard-step:last-child{flex:0}.hrm-step-circle{color:#94a3b8;z-index:1;background:#fff;border:2px solid #e2e8f0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:700;transition:all .2s;display:flex}.hrm-wizard-step.done .hrm-step-circle{color:#fff;background:#10b981;border-color:#10b981}.hrm-wizard-step.active .hrm-step-circle{color:#fff;background:#0f172a;border-color:#0f172a}.hrm-step-line{background:#e2e8f0;flex:1;height:2px;margin:0 6px;transition:background .2s}.hrm-wizard-step.done .hrm-step-line{background:#10b981}.hrm-step-label{white-space:nowrap;color:#94a3b8;font-size:10px;font-weight:600;position:absolute;top:34px;left:50%;transform:translate(-50%)}.hrm-wizard-step.active .hrm-step-label{color:#0f172a}.hrm-wizard-step.done .hrm-step-label{color:#10b981}.hrm-drawer-tabs{z-index:9;background:#fff;border-bottom:1px solid #f1f5f9;gap:0;padding:0 24px;display:flex;position:sticky;top:65px;overflow-x:auto}.hrm-drawer-tab{color:#94a3b8;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:9px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.hrm-drawer-tab:hover{color:#475569}.hrm-drawer-tab.active{color:#0f172a;border-bottom-color:#0f172a}.hrm-bulk-bar{color:#fff;z-index:300;background:#0f172a;border-radius:12px;align-items:center;gap:14px;padding:12px 20px;animation:.2s slideUp;display:flex;position:fixed;bottom:28px;left:50%;transform:translate(-50%);box-shadow:0 8px 40px #00000040}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.hrm-bulk-count{color:#94a3b8;font-size:13px;font-weight:700}.hrm-bulk-divider{background:#ffffff26;width:1px;height:20px}.hrm-bulk-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:7px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:background .12s}.hrm-bulk-btn:hover{background:#ffffff2e}.hrm-bulk-btn.danger{background:#ef444433;border-color:#ef44444d}.hrm-bulk-btn.danger:hover{background:#ef44444d}.hrm-view-toggle{border:1px solid #e2e8f0;border-radius:8px;display:flex;overflow:hidden}.hrm-view-btn{cursor:pointer;color:#94a3b8;background:#fff;border:none;padding:6px 10px;font-size:14px;transition:all .12s}.hrm-view-btn.active{color:#fff;background:#0f172a}.hrm-modal-overlay{z-index:600;background:#0f172a80;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.hrm-modal{background:#fff;border-radius:16px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 80px #0003}.hrm-modal-header{justify-content:space-between;align-items:flex-start;padding:24px 28px 0;display:flex}.hrm-modal-body{padding:24px 28px}.hrm-modal-footer{background:#fafafa;border-top:1px solid #f1f5f9;border-radius:0 0 16px 16px;justify-content:space-between;align-items:center;padding:16px 28px;display:flex}.hrm-form-row{gap:14px;display:grid}.hrm-form-group{flex-direction:column;gap:5px;display:flex}.hrm-form-label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.hrm-form-input{color:#1e293b;box-sizing:border-box;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:9px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.hrm-form-input:focus{border-color:#6366f1}.hrm-form-select{color:#1e293b;cursor:pointer;box-sizing:border-box;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:9px 12px;font-family:inherit;font-size:13px}.hrm-timeline{padding-left:20px;position:relative}.hrm-timeline:before{content:"";background:#f1f5f9;width:2px;position:absolute;top:6px;bottom:6px;left:6px}.hrm-timeline-item{padding-bottom:18px;position:relative}.hrm-timeline-dot{border:2px solid #fff;border-radius:50%;width:10px;height:10px;position:absolute;top:4px;left:-17px;box-shadow:0 0 0 2px #e2e8f0}.hrm-ring-label{text-anchor:middle;dominant-baseline:middle;font-size:18px;font-weight:800}.portal-root{background:#f8fafc;min-height:100vh;display:flex}.portal-main{flex:1;max-width:100%;padding:16px 16px 80px;overflow-x:hidden}.portal-mobile-bar{z-index:900;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:flex;position:fixed;top:4px;left:0;right:0}.portal-hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:4px;padding:6px;display:flex}.portal-hamburger span{background:#334155;border-radius:2px;width:20px;height:2px;transition:all .2s;display:block}.portal-mobile-title{color:#0f172a;align-items:center;gap:8px;font-size:15px;font-weight:700;display:flex}.portal-mobile-logo{color:#6366f1;font-size:18px}.portal-mobile-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:11px;font-weight:700;display:flex}.portal-overlay{z-index:950;background:#0006;animation:.2s fadeIn;position:fixed;inset:0}.portal-sidebar{z-index:999;background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;width:260px;transition:left .3s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:0;bottom:0;left:-280px;box-shadow:4px 0 24px #0000001a}.portal-sidebar.open{left:0}.portal-profile-card{border-bottom:1px solid #f1f5f9;align-items:center;gap:12px;padding:24px 20px 18px;display:flex}.portal-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:14px;font-weight:800;display:flex}.portal-profile-name{color:#0f172a;font-size:14px;font-weight:700;line-height:1.2}.portal-profile-role{color:#94a3b8;font-size:11px;font-weight:500}.portal-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex;overflow-y:auto}.portal-nav-item{color:#475569;border-radius:10px;align-items:center;gap:10px;padding:10px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:flex;position:relative}.portal-nav-item:hover{color:#1e293b;background:#f8fafc}.portal-nav-item.active{color:#6366f1;background:#6366f114;font-weight:600}.portal-nav-icon{text-align:center;width:24px;font-size:16px}.portal-nav-indicator{background:#6366f1;border-radius:4px;width:4px;height:20px;position:absolute;right:8px}.portal-sidebar-bottom{border-top:1px solid #f1f5f9;flex-direction:column;gap:6px;padding:12px 14px 20px;display:flex}.portal-admin-link{color:#d97706;background:#d977060f;border-radius:8px;align-items:center;gap:8px;padding:9px 14px;font-size:12px;font-weight:600;text-decoration:none;transition:all .15s;display:flex}.portal-admin-link:hover{background:#d977061f}.portal-logout-btn{color:#dc2626;cursor:pointer;background:#ef44440f;border:none;border-radius:8px;align-items:center;gap:8px;padding:9px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s;display:flex}.portal-logout-btn:hover{background:#ef44441f}.portal-bottom-nav{z-index:800;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;border-top:1px solid #e2e8f0;justify-content:space-around;align-items:center;height:64px;padding:0 8px;display:flex;position:fixed;bottom:0;left:0;right:0}.portal-bottom-item{color:#94a3b8;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;font-size:10px;font-weight:600;text-decoration:none;transition:all .15s;display:flex}.portal-bottom-item.active{color:#6366f1}.portal-bottom-icon{font-size:20px}.portal-bottom-label{letter-spacing:.02em;font-size:9px}.p-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;transition:all .2s;overflow:hidden}.p-card:hover{box-shadow:0 4px 16px #0000000f}.p-card-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.p-card-title{color:#0f172a;font-size:14px;font-weight:700}.p-card-body{padding:16px 18px}.p-page-header{padding:68px 0 16px}.p-page-title{color:#0f172a;letter-spacing:-.02em;font-size:22px;font-weight:800}.p-page-subtitle{color:#64748b;margin-top:2px;font-size:13px}.p-metrics{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px;display:grid}.p-metric{background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:12px;padding:14px 16px;display:flex}.p-metric-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.p-metric-value{letter-spacing:-.02em;font-size:22px;font-weight:800;line-height:1}.p-metric-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;margin-top:2px;font-size:10px;font-weight:600}.p-btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 20px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.p-btn-primary{color:#fff;background:linear-gradient(135deg,#6366f1,#4f46e5)}.p-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px #6366f14d}.p-btn-success{color:#fff;background:linear-gradient(135deg,#10b981,#059669)}.p-btn-ghost{color:#475569;background:#f8fafc;border:1px solid #e2e8f0}.p-badge{border-radius:6px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.p-progress{background:#f1f5f9;border-radius:3px;height:6px;overflow:hidden}.p-progress-fill{border-radius:3px;height:100%;transition:width .5s}.p-empty{text-align:center;padding:40px 20px}.p-empty-icon{margin-bottom:12px;font-size:48px}.p-empty-title{color:#1e293b;margin-bottom:4px;font-size:16px;font-weight:700}.p-empty-desc{color:#94a3b8;font-size:13px}.p-toast{color:#fff;z-index:5000;background:#1e293b;border-radius:12px;padding:12px 24px;font-size:13px;font-weight:600;animation:.3s slideUp;position:fixed;bottom:80px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0003}@media (min-width:769px){.portal-mobile-bar,.portal-bottom-nav,.portal-overlay{display:none}.portal-sidebar{width:240px;box-shadow:none;border-right:1px solid #e2e8f0;position:fixed;top:4px;left:0}.portal-main{max-width:1200px;margin-left:240px;padding:24px 32px 32px}.p-page-header{padding:12px 0 20px}.p-page-title{font-size:28px}.p-metrics{grid-template-columns:repeat(4,1fr);gap:14px}}@media (min-width:1024px){.p-metrics{grid-template-columns:repeat(4,1fr);gap:16px}}
