@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Noto+Sans+Bengali:wght@400;500;600;700&display=swap";:root{--color-primary: #1A1A2E;--color-primary-light: #2D2D44;--color-primary-hover: #F0F0EC;--color-accent: #2D6A4F;--color-accent-hover: #1B4D3E;--color-accent-glow: rgba(45, 106, 79, .1);--color-accent-light: #D8F3DC;--color-secondary: #52796F;--color-secondary-light: #74A89A;--color-success: #2D6A4F;--color-success-bg: rgba(45, 106, 79, .08);--color-warning: #E09F3E;--color-warning-bg: rgba(224, 159, 62, .08);--color-danger: #E63946;--color-danger-bg: rgba(230, 57, 70, .08);--color-info: #457B9D;--color-info-bg: rgba(69, 123, 157, .08);--surface-bg: #F4F4F0;--surface-card: #FFFFFF;--surface-card-hover: #FAFAF8;--surface-elevated: #F8F8F6;--surface-border: #E8E8E4;--surface-border-strong: #D4D4CF;--text-primary: #1A1A2E;--text-secondary: #6B7280;--text-muted: #9CA3AF;--text-inverse: #FFFFFF;--font-sans: "Inter", "Noto Sans Bengali", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--shadow-glow: 0 0 0 3px rgba(45, 106, 79, .12);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 260px;--sidebar-collapsed: 72px;--header-height: 64px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--surface-bg);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast),outline var(--transition-fast)}a:hover{color:var(--color-accent-hover)}a:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px;border-radius:2px}img{max-width:100%;display:block}button{font-family:var(--font-sans);cursor:pointer;border:none;background:none;color:inherit}button:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-md)}input,select,textarea{font-family:var(--font-sans);background:var(--surface-card);color:var(--text-primary);border:1px solid var(--surface-border-strong);border-radius:var(--radius-md);padding:10px 14px;font-size:.9rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),outline var(--transition-fast);width:100%}input:focus,select:focus,textarea:focus{border-color:var(--color-accent);box-shadow:var(--shadow-glow);outline:none}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.container{max-width:1280px;margin:0 auto;padding:0 var(--space-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.card{background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--surface-border-strong)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 20px;border-radius:var(--radius-md);font-weight:600;font-size:.875rem;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:var(--color-accent);color:var(--text-inverse);box-shadow:0 1px 3px #2d6a4f33}.btn-primary:hover{background:var(--color-accent-hover);box-shadow:0 2px 8px #2d6a4f40;transform:translateY(-1px)}.btn-secondary{background:var(--surface-card);border:1px solid var(--surface-border-strong);color:var(--text-primary)}.btn-secondary:hover{background:var(--surface-elevated);border-color:var(--color-accent)}.btn-ghost{color:var(--text-secondary);padding:8px 12px}.btn-ghost:hover{background:var(--surface-elevated);color:var(--text-primary)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{opacity:.9}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-md)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;letter-spacing:.02em}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:#b07d2e}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-neutral{background:#6b728014;color:var(--text-secondary)}.stat-card{background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-accent)}.stat-card .stat-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:var(--color-accent-glow);color:var(--color-accent)}.stat-card .stat-value{font-size:1.75rem;font-weight:800;letter-spacing:-.02em;line-height:1.2;color:var(--text-primary)}.stat-card .stat-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.stat-card .stat-change{font-size:.75rem;font-weight:600}.stat-card .stat-change.positive{color:var(--color-success)}.stat-card .stat-change.negative{color:var(--color-danger)}.table-container{background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.table-container table{width:100%;border-collapse:collapse}.table-container th{background:var(--surface-elevated);padding:12px 16px;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--surface-border)}.table-container td{padding:14px 16px;font-size:.875rem;border-bottom:1px solid var(--surface-border);color:var(--text-secondary)}.table-container tr:last-child td{border-bottom:none}.table-container tr:hover td{background:var(--surface-elevated)}.modal-overlay{position:fixed;inset:0;background:#1a1a2e4d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-fast) ease-out}.modal-content{background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-xl);padding:var(--space-xl);max-width:560px;width:90%;max-height:85vh;overflow-y:auto;animation:slideUp var(--transition-base) ease-out;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.modal-header h2{font-size:1.25rem;font-weight:700}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.tabs{display:flex;gap:var(--space-xs);background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:4px}.tab{padding:8px 18px;border-radius:var(--radius-md);font-size:.85rem;font-weight:500;color:var(--text-muted);transition:all var(--transition-fast);cursor:pointer}.tab:hover{color:var(--text-primary);background:var(--surface-elevated)}.tab.active{background:var(--color-accent);color:var(--text-inverse);font-weight:600}.avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-lg{width:56px;height:56px;font-size:1.2rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);color:var(--text-muted);text-align:center;gap:var(--space-md)}.empty-state svg{opacity:.3}.empty-state h3{font-size:1.1rem;color:var(--text-secondary)}.empty-state p{font-size:.85rem;max-width:320px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-slide-up{animation:slideUp var(--transition-base) ease-out}.animate-slide-in-left{animation:slideInLeft var(--transition-base) ease-out}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.page-header h1{font-size:1.6rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary)}.page-header p{font-size:.85rem;color:var(--text-secondary);margin-top:2px}.page-actions{display:flex;gap:var(--space-sm);align-items:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}@media(max-width:900px){.content-grid,.form-row{grid-template-columns:1fr}}.star-rating{display:flex;gap:2px}.star-rating .star{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast)}.star-rating .star.filled,.star-rating .star:hover{color:var(--color-warning)}.progress-bar{width:100%;height:6px;background:var(--surface-elevated);border-radius:var(--radius-full);overflow:hidden}.progress-bar .progress-fill{height:100%;border-radius:var(--radius-full);background:var(--color-accent);transition:width var(--transition-slow)}.toast-container{position:fixed;bottom:var(--space-lg);right:var(--space-lg);z-index:2000;display:flex;flex-direction:column;gap:var(--space-sm)}.toast{background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-md);padding:12px 20px;font-size:.875rem;display:flex;align-items:center;gap:var(--space-sm);animation:slideUp var(--transition-base) ease-out;box-shadow:var(--shadow-lg);min-width:280px}.toast.success{border-left:3px solid var(--color-success)}.toast.error{border-left:3px solid var(--color-danger)}.toast.info{border-left:3px solid var(--color-info)}@media(max-width:768px){.sidebar{display:none}body{overflow-x:hidden}.stats-grid{grid-template-columns:1fr 1fr;gap:var(--space-sm);margin-bottom:var(--space-md)}.stat-card{padding:var(--space-md)}.stat-card .stat-value{font-size:1.35rem}.stat-card .stat-label{font-size:.7rem}.stat-card .stat-icon{width:36px;height:36px}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-md)}.table-container table{min-width:600px}.modal-content{width:95%;max-width:100%;max-height:90vh;border-radius:var(--radius-lg);padding:var(--space-lg);margin:var(--space-md)}.modal-header h2{font-size:1.1rem}.form-row{grid-template-columns:1fr}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:2px;padding:3px}.tab{padding:6px 14px;font-size:.78rem;white-space:nowrap;flex-shrink:0}.page-header{margin-bottom:var(--space-md)}.page-header h1{font-size:1.25rem}.page-header p{font-size:.8rem}.page-actions{width:100%;flex-wrap:wrap}.page-actions .btn{flex:1;min-width:0;font-size:.8rem;padding:8px 14px}.card{padding:var(--space-md);border-radius:var(--radius-md)}.content-grid{grid-template-columns:1fr;gap:var(--space-sm)}.toast-container{left:var(--space-md);right:var(--space-md);bottom:80px}.toast{min-width:auto}.empty-state{padding:var(--space-xl)}.btn-lg{padding:12px 20px;font-size:.9rem}}.sidebar{width:var(--sidebar-width);height:100vh;position:fixed;left:0;top:0;background:var(--surface-card);border-right:1px solid var(--surface-border);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-base);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);border-bottom:1px solid var(--surface-border);min-height:var(--header-height)}.brand-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-accent);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.brand-text{display:flex;flex-direction:column}.brand-name{font-size:1.1rem;font-weight:800;color:var(--text-primary);line-height:1.2}.brand-sub{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;font-weight:600}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-md) var(--space-sm)}.nav-section{display:flex;flex-direction:column;gap:2px}.nav-section-label{font-size:.65rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;padding:var(--space-sm) var(--space-md);margin-bottom:4px;margin-top:var(--space-sm)}.nav-item{display:flex;align-items:center;gap:var(--space-md);padding:10px var(--space-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;text-decoration:none;position:relative}.nav-item:hover{background:var(--surface-elevated);color:var(--text-primary)}.nav-item.active{background:var(--color-accent-glow);color:var(--color-accent);font-weight:600}.nav-indicator{position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--color-accent);border-radius:var(--radius-full)}.sidebar-footer{padding:var(--space-sm);border-top:1px solid var(--surface-border);display:flex;flex-direction:column;gap:2px}.collapse-btn{width:100%}.sidebar.collapsed .nav-item{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-brand{justify-content:center;padding:var(--space-md)}.app-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-xl);background:var(--surface-card);border-bottom:1px solid var(--surface-border);position:sticky;top:0;z-index:50;gap:var(--space-lg)}.header-search{position:relative;flex:1;max-width:480px}.header-search .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.header-search input{padding-left:42px;background:var(--surface-elevated);border:1px solid var(--surface-border);border-radius:var(--radius-full);height:40px;font-size:.85rem}.header-search input:focus{background:var(--surface-card);border-color:var(--color-accent)}.header-actions{display:flex;align-items:center;gap:var(--space-md)}.role-switcher{display:flex;align-items:center;gap:var(--space-sm);padding:8px 16px;border-radius:var(--radius-full);border:1px solid var(--surface-border-strong);background:var(--surface-card);font-size:.8rem;font-weight:600;color:var(--text-primary);transition:all var(--transition-fast);cursor:pointer}.role-switcher:hover{border-color:var(--color-accent);box-shadow:var(--shadow-glow)}.role-badge{font-size:.7rem;padding:2px 8px;border-radius:var(--radius-full);background:var(--color-accent-glow);color:var(--color-accent)}.header-icon-btn{position:relative;width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.header-icon-btn:hover{background:var(--surface-elevated);color:var(--text-primary)}.notification-dot{position:absolute;top:8px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--color-danger);border:2px solid var(--surface-card)}.notification-wrapper,.profile-wrapper{position:relative}.dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:slideUp var(--transition-fast) ease-out;overflow:hidden;z-index:200}.notification-dropdown{width:380px;max-height:420px;overflow-y:auto}.dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--surface-border)}.dropdown-header h3{font-size:.9rem;font-weight:700}.notification-item{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--surface-border);cursor:pointer;transition:background var(--transition-fast)}.notification-item:hover{background:var(--surface-elevated)}.notification-item:last-child{border-bottom:none}.notification-item p{font-size:.85rem;color:var(--text-primary);margin-bottom:4px}.notification-time{font-size:.7rem;color:var(--text-muted)}.notification-item.success{border-left:3px solid var(--color-success)}.notification-item.warning{border-left:3px solid var(--color-warning)}.notification-item.info{border-left:3px solid var(--color-info)}.profile-trigger{display:flex;align-items:center;gap:var(--space-sm);padding:6px 8px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.profile-trigger:hover{background:var(--surface-elevated)}.profile-info{display:flex;flex-direction:column;text-align:left}.profile-name{font-size:.85rem;font-weight:600;color:var(--text-primary)}.profile-role{font-size:.7rem;color:var(--text-muted)}.profile-dropdown{width:240px;padding:var(--space-xs)}.dropdown-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:10px var(--space-md);border-radius:var(--radius-md);font-size:.85rem;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast);border:none;background:none;font-family:var(--font-sans)}.dropdown-item:hover{background:var(--surface-elevated);color:var(--text-primary)}.dropdown-item.danger{color:var(--color-danger)}.dropdown-divider{border:none;border-top:1px solid var(--surface-border);margin:4px 0}.mobile-appbar{display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 12px;background:var(--surface-card);border-bottom:1px solid var(--surface-border);position:sticky;top:0;z-index:90}.mobile-appbar-btn{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-primary);background:none;border:none;cursor:pointer;transition:background var(--transition-fast)}.mobile-appbar-btn:active{background:var(--surface-elevated)}.mobile-appbar-brand{display:flex;align-items:center;gap:8px}.mobile-appbar-logo{width:30px;height:30px;border-radius:var(--radius-sm);background:var(--color-accent);display:flex;align-items:center;justify-content:center;color:#fff}.mobile-appbar-title{font-size:1.05rem;font-weight:800;color:var(--text-primary)}.mobile-appbar-actions{display:flex;align-items:center;gap:4px}.mobile-notif-btn{position:relative}.mobile-notif-dot{position:absolute;top:8px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--color-danger);border:1.5px solid var(--surface-card)}.mobile-appbar-avatar{width:34px;height:34px;border-radius:50%;background:var(--color-accent);color:#fff;font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;letter-spacing:.02em}.drawer-backdrop{position:fixed;inset:0;background:#1a1a2e73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:998;opacity:0;pointer-events:none;transition:opacity .3s ease}.drawer-backdrop.visible{opacity:1;pointer-events:auto}.mobile-drawer{position:fixed;top:0;left:0;width:300px;max-width:85vw;height:100vh;height:100dvh;background:var(--surface-card);z-index:999;display:flex;flex-direction:column;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 24px #0000001f;overflow:hidden}.mobile-drawer.open{transform:translate(0)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:20px 16px 16px;border-bottom:1px solid var(--surface-border);background:linear-gradient(135deg,var(--color-accent) 0%,#1B4D3E 100%);color:#fff;min-height:80px}.drawer-profile{display:flex;align-items:center;gap:12px}.drawer-avatar{width:42px;height:42px;border-radius:50%;background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;flex-shrink:0;border:2px solid rgba(255,255,255,.3)}.drawer-user-info{display:flex;flex-direction:column}.drawer-user-name{font-size:.95rem;font-weight:700;color:#fff}.drawer-user-role{font-size:.72rem;color:#ffffffbf;font-weight:500}.drawer-close-btn{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffff26;border:none;color:#fff;cursor:pointer;transition:background .15s ease}.drawer-close-btn:active{background:#ffffff4d}.drawer-nav{flex:1;overflow-y:auto;padding:8px;-webkit-overflow-scrolling:touch}.drawer-nav-section{display:flex;flex-direction:column;gap:2px}.drawer-section-label{font-size:.62rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;padding:8px 12px 4px}.drawer-nav-item{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:var(--radius-md);font-size:.88rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:all .15s ease}.drawer-nav-item:active{background:var(--surface-elevated)}.drawer-nav-item.active{background:var(--color-accent-glow);color:var(--color-accent);font-weight:600}.drawer-footer{padding:8px;border-top:1px solid var(--surface-border);display:flex;flex-direction:column;gap:2px}.drawer-action-btn{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-md);font-size:.85rem;font-weight:500;color:var(--text-secondary);background:none;border:none;cursor:pointer;transition:background .15s ease;text-decoration:none;font-family:var(--font-sans);width:100%;text-align:left}.drawer-action-btn:active{background:var(--surface-elevated)}.drawer-divider{height:1px;background:var(--surface-border);margin:4px 0}.drawer-logout{color:var(--color-danger)}.bottom-tab-bar{position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--surface-card);border-top:1px solid var(--surface-border);display:flex;align-items:stretch;justify-content:space-around;z-index:80;padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -2px 12px #0000000f}.bottom-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px 0;color:var(--text-muted);text-decoration:none;font-size:.65rem;font-weight:500;transition:color .15s ease;background:none;border:none;cursor:pointer;position:relative;font-family:var(--font-sans);-webkit-tap-highlight-color:transparent}.bottom-tab:active{color:var(--color-accent)}.bottom-tab.active{color:var(--color-accent);font-weight:700}.bottom-tab.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:var(--color-accent);border-radius:0 0 var(--radius-full) var(--radius-full)}.bottom-tab-label{line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:64px}.notif-drawer-backdrop{position:fixed;inset:0;background:#1a1a2e59;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:998;opacity:0;pointer-events:none;transition:opacity .3s ease}.notif-drawer-backdrop.visible{opacity:1;pointer-events:auto}.notif-drawer{position:fixed;top:0;right:0;width:420px;max-width:90vw;height:100vh;height:100dvh;background:var(--surface-card);z-index:999;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 24px #0000001f;overflow:hidden}.notif-drawer.open{transform:translate(0)}.notif-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--surface-border)}.notif-drawer-title-row{display:flex;align-items:center;gap:10px}.notif-drawer-title-row h2{font-size:1.15rem;font-weight:800;color:var(--text-primary)}.notif-unread-badge{background:var(--color-danger);color:#fff;font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);line-height:1.4}.notif-drawer-close{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background .15s ease}.notif-drawer-close:hover{background:var(--surface-elevated)}.notif-drawer-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid var(--surface-border)}.notif-filter-tabs{display:flex;gap:4px;background:var(--surface-elevated);border-radius:var(--radius-md);padding:3px}.notif-filter-tab{padding:5px 14px;border-radius:var(--radius-sm);font-size:.78rem;font-weight:500;color:var(--text-muted);transition:all .15s ease;font-family:var(--font-sans)}.notif-filter-tab.active{background:var(--surface-card);color:var(--text-primary);font-weight:600;box-shadow:var(--shadow-sm)}.notif-mark-all{display:flex;align-items:center;gap:5px;font-size:.75rem;font-weight:500;color:var(--color-accent);font-family:var(--font-sans);transition:opacity .15s ease}.notif-mark-all:hover{opacity:.7}.notif-drawer-list{flex:1;overflow-y:auto;padding:8px 12px;-webkit-overflow-scrolling:touch}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:60px 20px;color:var(--text-muted)}.notif-empty p{font-size:.85rem}.notif-card{display:flex;gap:12px;padding:14px 12px;border-radius:var(--radius-md);transition:background .15s ease;cursor:pointer;border-left:3px solid transparent}.notif-card:hover{background:var(--surface-elevated)}.notif-card:not(.read){background:#2d6a4f08}.notif-card.read{opacity:.7}.notif-card-icon{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-card-icon.success{background:var(--color-success-bg);color:var(--color-success)}.notif-card-icon.warning{background:var(--color-warning-bg);color:#b07d2e}.notif-card-icon.danger{background:var(--color-danger-bg);color:var(--color-danger)}.notif-card-icon.info{background:var(--color-info-bg);color:var(--color-info)}.notif-card-body{flex:1;min-width:0}.notif-card-header{display:flex;align-items:center;gap:6px;margin-bottom:2px}.notif-card-title{font-size:.82rem;font-weight:700;color:var(--text-primary)}.notif-card-dot{width:7px;height:7px;border-radius:50%;background:var(--color-accent);flex-shrink:0}.notif-card-message{font-size:.78rem;color:var(--text-secondary);line-height:1.45;margin-bottom:4px}.notif-card-time{font-size:.68rem;color:var(--text-muted);font-weight:500}.skeleton{background:linear-gradient(90deg,var(--surface-elevated, #f0f0ec) 25%,rgba(255,255,255,.6) 50%,var(--surface-elevated, #f0f0ec) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md, 8px)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-line{height:14px;margin-bottom:8px}.skeleton-line:last-child{margin-bottom:0}.skeleton-line.w-25{width:25%}.skeleton-line.w-40{width:40%}.skeleton-line.w-50{width:50%}.skeleton-line.w-60{width:60%}.skeleton-line.w-75{width:75%}.skeleton-line.w-100{width:100%}.skeleton-line.h-sm{height:10px}.skeleton-line.h-lg{height:20px}.skeleton-line.h-xl{height:32px}.skeleton-circle{border-radius:50%}.skeleton-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0}.skeleton-table{width:100%;padding:var(--space-md, 16px)}.skeleton-table-header{display:grid;gap:16px;padding:12px 0;border-bottom:2px solid var(--surface-border, #e8e8e4);margin-bottom:8px}.skeleton-table-row{display:grid;gap:16px;padding:14px 0;border-bottom:1px solid var(--surface-border, #e8e8e4);align-items:center}.skeleton-table-row:last-child{border-bottom:none}.skeleton-stat-card{padding:20px;border-radius:var(--radius-lg, 12px);border:1px solid var(--surface-border, #e8e8e4);background:var(--surface-card, #fff)}.skeleton-stat-icon{width:44px;height:44px;border-radius:var(--radius-md, 8px);margin-bottom:14px}.skeleton-stat-label{height:10px;width:80%;margin-bottom:10px}.skeleton-stat-value{height:28px;width:50%;margin-bottom:6px}.skeleton-stat-sub{height:10px;width:60%}.skeleton-payment-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--surface-border, #e8e8e4)}.skeleton-payment-row:last-child{border-bottom:none}.skeleton-payment-info{flex:1;display:flex;flex-direction:column;gap:6px}.skeleton-payment-amount{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:6px}.dashboard-card .card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.dashboard-card .card-header h3{font-size:.95rem;font-weight:700;color:var(--text-primary)}.payment-list{display:flex;flex-direction:column}.payment-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--surface-border)}.payment-item:last-child{border-bottom:none}.payment-info{flex:1;display:flex;flex-direction:column}.payment-name{font-size:.875rem;font-weight:600;color:var(--text-primary)}.payment-flat{font-size:.75rem;color:var(--text-muted);margin-top:2px}.payment-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:4px}.payment-amount{font-size:.9rem;font-weight:700;color:var(--text-primary)}.task-list{display:flex;flex-direction:column}.task-item{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--surface-border)}.task-item:last-child{border-bottom:none}.task-icon{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.task-icon.warning{background:var(--color-warning-bg);color:var(--color-warning)}.task-icon.info{background:var(--color-info-bg);color:var(--color-info)}.task-icon.success{background:var(--color-success-bg);color:var(--color-success)}.task-info{flex:1}.task-text{font-size:.85rem;color:var(--text-primary);display:block}.task-time{font-size:.7rem;color:var(--text-muted);margin-top:2px;display:block}.chart-card .card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.chart-card .card-header h3{font-size:.95rem;font-weight:700;color:var(--text-primary)}.chart-placeholder{height:260px;display:flex;align-items:flex-end;padding:var(--space-md) 0}.chart-bars{display:flex;align-items:flex-end;gap:var(--space-sm);width:100%;height:100%}.chart-bar-container{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);height:100%;justify-content:flex-end}.chart-bar{width:100%;max-width:44px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:linear-gradient(180deg,var(--color-accent),rgba(45,106,79,.25));transition:height .6s cubic-bezier(.4,0,.2,1);position:relative;cursor:pointer;min-height:4px}.chart-bar:hover{background:linear-gradient(180deg,var(--color-accent-hover),rgba(45,106,79,.4))}.chart-tooltip{position:absolute;top:-28px;left:50%;transform:translate(-50%);background:var(--surface-card);border:1px solid var(--surface-border);padding:3px 8px;border-radius:var(--radius-sm);font-size:.65rem;font-weight:600;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition-fast);box-shadow:var(--shadow-md);color:var(--text-primary)}.chart-bar:hover .chart-tooltip{opacity:1}.chart-label{font-size:.65rem;color:var(--text-muted);font-weight:500}.detail-list{display:flex;flex-direction:column}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--surface-border);font-size:.85rem}.detail-row:last-child{border-bottom:none}.detail-row span{color:var(--text-muted)}.detail-row strong{color:var(--text-primary);font-weight:600}@media(max-width:768px){.dashboard{overflow-x:hidden;width:100%}.dashboard .stats-grid{grid-template-columns:1fr 1fr;gap:8px}.dashboard .stat-card{padding:12px;min-width:0}.dashboard .stat-card .stat-value{font-size:1.2rem}.dashboard .stat-card .stat-label{font-size:.65rem}.dashboard .stat-card .stat-change{font-size:.68rem}.dashboard .stat-card .stat-icon{width:32px;height:32px}.dashboard-card{padding:12px!important}.dashboard-card .card-header{margin-bottom:8px}.dashboard-card .card-header h3{font-size:.88rem}.payment-item{gap:10px;padding:10px 0}.payment-item .avatar{width:32px;height:32px;font-size:.7rem}.payment-name{font-size:.8rem}.payment-flat{font-size:.68rem}.payment-amount{font-size:.8rem}.task-item{gap:10px;padding:10px 0}.task-icon{width:30px;height:30px}.task-text{font-size:.78rem}.task-time{font-size:.65rem}.chart-card{padding:12px!important;overflow:hidden}.chart-card .card-header{flex-direction:column;align-items:flex-start;gap:8px}.chart-card .card-header h3{font-size:.85rem}.chart-placeholder{height:180px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:8px 0}.chart-bars{min-width:500px;gap:4px}.chart-bar{max-width:32px}.chart-label{font-size:.6rem}.dashboard .content-grid{grid-template-columns:1fr;gap:8px}.detail-row{font-size:.8rem;padding:8px 0}.dashboard .card[style*=borderLeft]{flex-direction:column;align-items:flex-start}}.property-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:var(--space-md)}.property-card{cursor:pointer}.property-card-header{display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md)}.property-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--color-accent);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.property-meta{flex:1}.property-meta h3{font-size:1.05rem;font-weight:700;margin-bottom:2px;color:var(--text-primary)}.property-location{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-muted)}.property-stats{display:flex;gap:var(--space-lg);margin-bottom:var(--space-md)}.p-stat{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-secondary)}.occupancy-bar{margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-md)}.occupancy-text{font-size:.7rem;color:var(--text-secondary);white-space:nowrap}.property-amenities{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--space-md)}.amenity-tag{background:var(--surface-elevated);border:1px solid var(--surface-border);border-radius:var(--radius-full);font-size:.7rem;padding:2px 10px;color:var(--text-secondary)}.property-footer{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-md);border-top:1px solid var(--surface-border)}.revenue-label{display:block;font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.revenue-value{font-size:1.1rem;font-weight:800;color:var(--color-success)}.property-card-actions{display:flex;gap:var(--space-xs)}.unit-grid-section{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--surface-border);animation:slideUp var(--transition-base) ease-out}.unit-grid-section h4{font-size:.85rem;font-weight:600;margin-bottom:var(--space-md);color:var(--text-secondary)}.unit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm)}.unit-cell{border:1px solid var(--surface-border);border-radius:var(--radius-md);padding:var(--space-sm);text-align:center;transition:all var(--transition-fast);background:var(--surface-card)}.unit-cell.occupied{background:#2d6a4f0d;border-color:#2d6a4f33}.unit-cell.vacant{background:#e639460a;border-color:#e6394633}.unit-name{display:block;font-weight:700;font-size:.9rem;color:var(--text-primary)}.unit-status{display:block;font-size:.65rem;color:var(--text-muted);margin:2px 0}.unit-meter-select{width:100%;padding:3px 6px;font-size:.65rem;border-radius:var(--radius-sm);margin-top:4px;background-position:right 4px center;background-size:10px}.add-property-form{display:flex;flex-direction:column;gap:var(--space-md)}.form-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;margin-top:var(--space-md)}@media(max-width:768px){.properties-page{overflow-x:hidden}.property-grid{grid-template-columns:1fr;gap:10px}.property-card{padding:14px!important}.property-card-header{gap:10px;margin-bottom:10px}.property-icon{width:40px;height:40px}.property-meta h3{font-size:.95rem}.property-location{font-size:.7rem}.property-stats{gap:var(--space-md);margin-bottom:10px;flex-wrap:wrap}.p-stat{font-size:.75rem;gap:4px}.occupancy-bar{margin-bottom:10px;gap:8px}.property-amenities{gap:4px;margin-bottom:10px}.amenity-tag{font-size:.65rem;padding:2px 8px}.property-footer{padding-top:10px;flex-wrap:wrap;gap:8px}.revenue-value{font-size:.95rem}.property-card-actions{gap:4px}.property-card-actions .btn{font-size:.75rem;padding:5px 10px}.unit-grid{grid-template-columns:repeat(3,1fr);gap:6px}.unit-cell{padding:6px}.unit-name{font-size:.8rem}.unit-status{font-size:.6rem}.add-property-form .form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.add-property-form [role=group]{flex-direction:column!important;gap:10px!important}}.pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-top:1px solid var(--surface-border);background:var(--surface-card)}.pagination-info{font-size:.8rem;color:var(--text-muted)}.pagination-controls{display:flex;align-items:center;gap:4px}.pagination-btn{display:flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 8px;border:1px solid var(--surface-border);border-radius:var(--radius-md);background:var(--surface-card);color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--surface-elevated);border-color:var(--color-accent);color:var(--text-primary)}.pagination-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff;font-weight:600}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-ellipsis{display:flex;align-items:center;justify-content:center;width:34px;height:34px;font-size:.8rem;color:var(--text-muted)}.utility-grid input[type=number]{background:var(--surface-card);border:1px solid var(--surface-border-strong)}.utility-grid input[type=number]:focus{border-color:var(--color-accent);box-shadow:var(--shadow-glow)}.utility-grid tfoot td{border-top:2px solid var(--surface-border-strong);padding:14px 16px}.utility-tab-bar{display:flex;gap:0;margin-bottom:var(--space-lg);border-bottom:2px solid var(--surface-border)}.utility-tab{padding:12px 28px;font-size:.9rem;font-weight:600;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all .2s ease;letter-spacing:.01em}.utility-tab:hover{color:var(--text-primary);background:var(--surface-elevated)}.utility-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.utility-tab-content{animation:fadeIn .25s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.notifications-page{max-width:100%}.notif-page-header{display:flex;align-items:center;gap:12px;margin-bottom:var(--space-md)}.notif-back-btn{width:38px;height:38px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:background .15s ease}.notif-back-btn:active{background:var(--surface-elevated)}.notif-page-title{display:flex;align-items:center;gap:10px}.notif-page-title h1{font-size:1.3rem;font-weight:800;color:var(--text-primary)}.notif-page-badge{background:var(--color-danger);color:#fff;font-size:.65rem;font-weight:700;padding:2px 10px;border-radius:var(--radius-full)}.notif-page-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);gap:8px}.notif-page-filters{display:flex;gap:4px;background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-md);padding:3px}.notif-page-filter{padding:6px 16px;border-radius:var(--radius-sm);font-size:.8rem;font-weight:500;color:var(--text-muted);transition:all .15s ease;font-family:var(--font-sans)}.notif-page-filter.active{background:var(--color-accent);color:#fff;font-weight:600}.notif-page-mark-all{display:flex;align-items:center;gap:5px;font-size:.75rem;font-weight:500;color:var(--color-accent);font-family:var(--font-sans);white-space:nowrap}.notif-page-list{display:flex;flex-direction:column;gap:2px}.notif-page-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:60px 20px;color:var(--text-muted);text-align:center}.notif-page-empty h3{font-size:1rem;color:var(--text-secondary)}.notif-page-empty p{font-size:.85rem}.notif-page-card{display:flex;gap:12px;padding:14px;border-radius:var(--radius-md);background:var(--surface-card);border:1px solid var(--surface-border);transition:background .15s ease}.notif-page-card:not(.read){background:#2d6a4f08;border-left:3px solid var(--color-accent)}.notif-page-card.read{opacity:.65}.notif-page-card-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-page-card-icon.success{background:var(--color-success-bg);color:var(--color-success)}.notif-page-card-icon.warning{background:var(--color-warning-bg);color:#b07d2e}.notif-page-card-icon.danger{background:var(--color-danger-bg);color:var(--color-danger)}.notif-page-card-icon.info{background:var(--color-info-bg);color:var(--color-info)}.notif-page-card-body{flex:1;min-width:0}.notif-page-card-top{display:flex;align-items:center;gap:6px;margin-bottom:3px}.notif-page-card-title{font-size:.85rem;font-weight:700;color:var(--text-primary)}.notif-page-card-dot{width:7px;height:7px;border-radius:50%;background:var(--color-accent);flex-shrink:0}.notif-page-card-msg{font-size:.8rem;color:var(--text-secondary);line-height:1.45;margin-bottom:4px}.notif-page-card-time{font-size:.7rem;color:var(--text-muted);font-weight:500}@media(max-width:768px){.notif-page-header{gap:8px}.notif-page-title h1{font-size:1.15rem}.notif-page-card{padding:12px 10px}.notif-page-card-icon{width:36px;height:36px}.notif-page-card-title{font-size:.82rem}.notif-page-card-msg{font-size:.78rem}.notif-page-mark-all span{display:none}}.auth-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:#f4f4f0;padding:var(--space-lg)}.auth-container{width:100%;max-width:440px}.auth-brand{text-align:center;margin-bottom:var(--space-xl)}.auth-brand-icon{width:56px;height:56px;border-radius:var(--radius-lg);background:var(--color-accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--space-md)}.auth-brand h1{font-size:1.6rem;font-weight:800;color:var(--text-primary);font-family:var(--font-sans)}.auth-brand p{font-size:.85rem;color:var(--text-muted);margin-top:4px}.auth-card{background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.auth-card-header{margin-bottom:var(--space-lg)}.auth-card-header h2{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.auth-card-header p{font-size:.82rem;color:var(--text-muted)}.auth-form{display:flex;flex-direction:column;gap:var(--space-md)}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.auth-input-wrapper{position:relative;display:flex;align-items:center}.auth-input-wrapper .auth-input-icon{position:absolute;left:12px;color:var(--text-muted);pointer-events:none}.auth-input-wrapper input{width:100%;padding:10px 12px 10px 40px;border:1.5px solid var(--surface-border);border-radius:var(--radius-md);font-size:.88rem;font-family:var(--font-sans);color:var(--text-primary);background:var(--surface-elevated);transition:border-color .2s ease,box-shadow .2s ease;outline:none}.auth-input-wrapper input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow)}.auth-input-wrapper input::placeholder{color:var(--text-muted)}.auth-password-toggle{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;display:flex;align-items:center}.auth-password-toggle:hover{color:var(--text-secondary)}.auth-extras{display:flex;align-items:center;justify-content:space-between;font-size:.8rem}.auth-remember{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-secondary);cursor:pointer;white-space:nowrap}.auth-remember input[type=checkbox]{accent-color:var(--color-accent)}.auth-link{color:var(--color-accent);font-weight:600;font-size:.8rem;text-decoration:none;transition:opacity .15s ease}.auth-link:hover{opacity:.7}.auth-submit{width:100%;padding:11px;border:none;border-radius:var(--radius-md);background:var(--color-accent);color:#fff;font-size:.9rem;font-weight:700;font-family:var(--font-sans);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s ease,transform .1s ease}.auth-submit:hover{background:var(--color-accent-hover)}.auth-submit:active{transform:scale(.98)}.auth-divider{display:flex;align-items:center;gap:12px;margin:var(--space-md) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--surface-border)}.auth-divider span{font-size:.72rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.auth-footer{text-align:center;margin-top:var(--space-lg);font-size:.82rem;color:var(--text-muted)}.auth-footer a{color:var(--color-accent);font-weight:600;text-decoration:none}.auth-footer a:hover{opacity:.7}.auth-role-tabs{display:flex;gap:4px;background:var(--surface-elevated);border:1px solid var(--surface-border);border-radius:var(--radius-md);padding:3px;margin-bottom:var(--space-md)}.auth-role-tab{flex:1;padding:8px;border-radius:var(--radius-sm);font-size:.8rem;font-weight:500;font-family:var(--font-sans);color:var(--text-muted);text-align:center;cursor:pointer;transition:all .15s ease;border:none;background:none}.auth-role-tab.active{background:var(--surface-card);color:var(--text-primary);font-weight:700;box-shadow:var(--shadow-sm)}.auth-success{text-align:center;padding:var(--space-lg) 0}.auth-success-icon{width:56px;height:56px;border-radius:50%;background:var(--color-success-bg);color:var(--color-success);display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--space-md)}.auth-success h3{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin-bottom:6px}.auth-success p{font-size:.82rem;color:var(--text-muted);line-height:1.5}.auth-error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid rgba(230,57,70,.2);border-radius:var(--radius-md);padding:10px 14px;font-size:.82rem;font-weight:500;margin-bottom:var(--space-sm)}.auth-spinner{animation:auth-spin .8s linear infinite}@keyframes auth-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-sso-buttons{display:flex;flex-direction:column;gap:10px}.auth-sso-btn{width:100%;padding:10px;border:1.5px solid var(--surface-border);border-radius:var(--radius-md);background:var(--surface-card);color:var(--text-primary);font-size:.85rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .15s ease,border-color .15s ease}.auth-sso-btn:hover{background:var(--surface-elevated);border-color:var(--surface-border-strong)}.auth-sso-btn:active{transform:scale(.98)}@media(max-width:768px){.auth-page{padding:var(--space-md);align-items:flex-start;padding-top:60px}.auth-brand h1{font-size:1.35rem}.auth-card{padding:20px 16px}.auth-card-header h2{font-size:1.05rem}}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-base)}.app-content{flex:1;padding:var(--space-xl);overflow-y:auto}.sidebar.collapsed~.app-main,body:has(.sidebar.collapsed) .app-main{margin-left:var(--sidebar-collapsed)}@media(max-width:768px){.app-main{margin-left:0}.app-content{padding:var(--space-md);padding-bottom:80px;overflow-x:hidden;max-width:100vw}}.app-main.mobile{margin-left:0;max-width:100vw;overflow-x:hidden}
