*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html,body,#root{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}ul,ol{list-style:none}img,svg{display:block;max-width:100%}button{font-family:inherit;cursor:pointer}a{color:inherit;text-decoration:none}input,select,textarea{font-family:inherit;font-size:inherit}:root{--color-primary: #ec0044;--color-primary-hover: #c6003a;--color-primary-light: #fef0f4;--color-primary-alpha-25: rgba(236, 0, 68, .25);--color-primary-alpha-10: rgba(236, 0, 68, .1);--sidebar-bg: #26272a;--sidebar-text: rgba(255, 255, 255, .7);--sidebar-text-active: #ffffff;--sidebar-active-bg: rgba(236, 0, 68, .25);--sidebar-hover-bg: rgba(255, 255, 255, .08);--sidebar-border: rgba(255, 255, 255, .1);--color-success: #16a34a;--color-warning: #d97706;--color-error: #dc2626;--n-50: #fafafa;--n-100: #f5f5f5;--n-200: #e5e5e5;--n-300: #d4d4d4;--n-400: #a3a3a3;--n-500: #737373;--n-600: #525252;--n-700: #404040;--n-800: #262626;--n-900: #171717;--bg-page: #ffffff;--bg-surface: var(--n-50);--text-primary: var(--n-900);--text-secondary: var(--n-500);--border-color: var(--n-200);--font-family: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .875rem;--font-size-lg: 1rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--header-height: 56px;--sidebar-width: 210px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--ease-enter: cubic-bezier(.16, 1, .3, 1);--transition-fast: .15s var(--ease-enter);--transition-normal: .25s var(--ease-enter)}[data-theme=dark]{--bg-page: #0f172a;--bg-surface: #1e293b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--border-color: #334155;--n-50: #1e293b;--n-100: #334155;--n-200: #475569;--n-300: #64748b;--n-400: #94a3b8;--n-500: #cbd5e1;--n-600: #e2e8f0;--n-700: #f1f5f9;--n-800: #f8fafc;--n-900: #ffffff;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .5);--color-primary-light: rgba(236, 0, 68, .15);--color-primary-alpha-25: rgba(236, 0, 68, .3);--color-primary-alpha-10: rgba(236, 0, 68, .15)}html,body{overflow-x:hidden;width:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary);background:var(--bg-surface);line-height:1.5}input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;min-width:18px;border:2px solid var(--color-primary, #0ea5e9);border-radius:4px;background:#fff;cursor:pointer;position:relative;flex-shrink:0;vertical-align:middle;margin:0 8px 0 0;transition:background .15s ease}input[type=checkbox]:checked{background:var(--color-primary, #0ea5e9);border-color:var(--color-primary, #0ea5e9)}input[type=checkbox]:checked:after{content:"";position:absolute;left:5px;top:1px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:14px;padding-right:32px!important}.layout{display:flex;flex-direction:row;height:100vh}.layout-main{display:flex;flex-direction:column;flex:1;min-width:0}.layout-header{height:var(--header-height);background:var(--bg-page);display:flex;align-items:center;justify-content:space-between;padding:0 20px;flex-shrink:0;border-bottom:1px solid var(--border-color)}.header-left{display:flex;align-items:center;gap:12px}.topbar-breadcrumb{font-size:var(--font-size-sm);color:var(--n-400);display:flex;align-items:center;gap:6px}.topbar-breadcrumb svg{opacity:.4}.topbar-breadcrumb-current{color:var(--n-800);font-weight:600}.topbar-mobile-logo{display:none}.topbar-breadcrumb-app{color:var(--n-400)}.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:transparent;cursor:pointer;color:var(--n-500);transition:color var(--transition-fast),background var(--transition-fast)}.theme-toggle-btn:hover{background:var(--bg-surface);color:var(--text-primary)}.notif-wrapper{position:relative}.notif-btn{position:relative;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:transparent;cursor:pointer;color:var(--n-500);transition:color var(--transition-fast),background var(--transition-fast)}.notif-btn:hover{background:var(--n-100);color:var(--n-800)}.notif-badge{position:absolute;top:-4px;right:-4px;width:16px;height:16px;background:var(--color-error);border-radius:9999px;font-size:10px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center}.notif-drop{width:380px}.notif-drop-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--n-500);border-bottom:1px solid var(--n-100);margin-bottom:4px}.notif-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;color:var(--n-400);font-size:var(--font-size-sm)}.notif-empty svg{color:var(--n-300)}.notif-mark-all{background:none;border:none;color:var(--color-primary);font-size:var(--font-size-xs);cursor:pointer;padding:0;font-weight:600}.notif-mark-all:hover{text-decoration:underline}.notif-list{max-height:360px;overflow-y:auto}.notif-item{display:flex;align-items:flex-start;gap:8px;width:100%;padding:10px 12px;border:none;background:none;text-align:left;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--n-100)}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--n-50)}.notif-item-read{opacity:.55}.notif-item-dot{flex-shrink:0;width:8px;height:8px;margin-top:6px}.notif-item-dot span{display:block;width:8px;height:8px;border-radius:50%;background:var(--color-primary)}.notif-item-content{flex:1;min-width:0}.notif-item-title{font-size:var(--font-size-sm);font-weight:600;color:var(--n-800);line-height:1.3}.notif-item-body{font-size:var(--font-size-xs);color:var(--n-500);margin-top:2px}.notif-item-time{font-size:11px;color:var(--n-400);margin-top:4px}.profile-wrapper{position:relative}.avatar-btn{display:flex;align-items:center;justify-content:center;padding:3px;border:none;border-radius:9999px;background:transparent;cursor:pointer;color:var(--n-600);transition:background var(--transition-fast)}.avatar-btn:hover{opacity:.85}.avatar{width:28px;height:28px;border-radius:9999px;background:var(--color-primary);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-lg{width:36px;height:36px;font-size:13px}.launcher-wrapper{position:relative}.launcher-btn{width:38px;height:38px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:transparent;cursor:pointer;color:var(--n-600);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.launcher-btn:hover{background:var(--n-100)}.launcher-drop{min-width:260px;padding:12px}.launcher-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.launcher-app{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border-radius:var(--radius-md);text-decoration:none;color:var(--text-primary);transition:background var(--transition-fast);cursor:pointer}.launcher-app:hover{background:var(--n-100)}.launcher-app.current{opacity:.45;pointer-events:none}.launcher-app-icon{width:36px;height:36px;border-radius:var(--radius-md);object-fit:contain}.launcher-app-name{font-size:11px;font-weight:500;color:var(--n-700);text-align:center;line-height:1.2}.dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:200px;background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:4px;z-index:200;animation:fadeIn .15s var(--ease-enter)}.topbar-drop{top:calc(100% + 6px);right:0;left:auto;z-index:500;min-width:220px}.dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;color:var(--n-700);border:none;background:none;width:100%;text-align:left;font-family:inherit;transition:background var(--transition-fast)}.dropdown-item:hover{background:var(--n-50)}.dropdown-item.danger{color:var(--color-error)}.dropdown-item.danger:hover{background:#ef444414}.dropdown-item svg{width:16px;height:16px;flex-shrink:0}.dropdown-separator{height:1px;background:var(--n-100);margin:4px 0}.dropdown-profile-header{display:flex;align-items:center;gap:10px;padding:12px}.dropdown-profile-name{font-size:var(--font-size-sm);font-weight:600;color:var(--n-900)}.dropdown-profile-meta{font-size:var(--font-size-xs);color:var(--n-500)}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;flex-shrink:0;transition:width .2s ease}.sidebar-logo{height:var(--header-height);padding:0 20px;display:flex;align-items:center;flex-shrink:0}.sidebar-logo-img{height:28px;width:auto;max-width:160px;object-fit:contain}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffff59;padding:12px 12px 4px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-md);color:var(--sidebar-text);font-size:14px;font-weight:500;text-decoration:none;transition:all var(--transition-fast)}.sidebar-link:hover{background:#ffffff14;color:#fff}.sidebar-link.active{background:var(--sidebar-active-bg);color:#fff}.sidebar-link svg{width:20px;height:20px;flex-shrink:0}.sidebar-footer{margin-top:auto;padding:12px 8px}.powered-by{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 8px;gap:4px}.powered-by-logo{width:100%;max-width:90px;height:auto;opacity:.6}.powered-by-link{font-size:9px;color:#ffffff4d;text-decoration:none;letter-spacing:.3px}.powered-by-link:hover{color:#fff9}.layout-content{flex:1;overflow-y:auto;padding:24px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--n-900)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-md);border:none;transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast);white-space:nowrap}.btn svg{width:16px;height:16px}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{background:var(--n-100);color:var(--n-700);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.btn-ghost{background:transparent;color:var(--n-600)}.btn-ghost:hover{background:var(--n-100)}.btn-play{background:transparent;color:var(--color-success, #16a34a)}.btn-play:hover{background:#16a34a1a;color:var(--color-success, #16a34a)}.btn-stop{background:transparent;color:var(--color-error, #dc2626)}.btn-stop:hover{background:#dc26261a;color:var(--color-error, #dc2626)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-icon{padding:8px}.btn-icon.btn-sm{padding:6px;border-radius:6px;background:var(--n-100);color:var(--n-600);border:1px solid var(--border-color)}.btn-icon.btn-sm:hover{background:var(--n-200);color:var(--text-primary);border-color:var(--n-400)}.btn-sm{padding:4px 10px;font-size:var(--font-size-xs)}.btn-lg{padding:12px 24px;font-size:var(--font-size-lg)}.card{background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:16px 20px;border-bottom:1px solid var(--n-100);display:flex;align-items:center;justify-content:space-between}.card-body{padding:20px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--n-700);margin-bottom:4px}.required{color:var(--color-error)}.form-error-text{font-size:12px;color:var(--color-error);padding-left:2px;margin-top:4px}.form-group input:not([type=checkbox]),.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid var(--n-300);border-radius:var(--radius-md);background:var(--bg-page);color:var(--n-900);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha-10)}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:var(--font-size-xs);font-weight:600;color:var(--n-500);text-transform:uppercase;letter-spacing:.05em;padding:10px 16px;border-bottom:1px solid var(--border-color)}td{padding:12px 16px;border-bottom:1px solid var(--n-100);font-size:var(--font-size-sm);color:var(--n-700)}tr:hover td{background:var(--n-50)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s var(--ease-enter)}.modal{background:var(--bg-page);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:50%;min-width:480px;max-width:720px;max-height:90vh;overflow-y:auto;animation:modalIn .25s var(--ease-enter)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--n-100)}.modal-header h2{font-size:var(--font-size-lg);font-weight:600}.modal-body{padding:20px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--n-100)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-sm)}.badge-primary{background:var(--color-primary-alpha-10);color:var(--color-primary)}.badge-success{background:#16a34a1a;color:var(--color-success)}.badge-warning{background:#d977061a;color:var(--color-warning)}.badge-neutral{background:var(--n-100);color:var(--n-600)}.badge-info{background:#0ea5e91a;color:#0ea5e9}.badge-accent{background:#dc26261a;color:#dc2626}.badge-danger{background:#ef44441a;color:var(--color-danger);display:inline-flex;align-items:center;gap:4px}.topbar-timer{display:flex;align-items:center;gap:10px;margin-left:auto;margin-right:12px}.topbar-timer-start{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:none;background:var(--color-primary);color:#fff;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.topbar-timer-start:hover{background:var(--color-primary-hover);transform:scale(1.08)}.topbar-timer-stop{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:none;background:var(--color-error);color:#fff;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.topbar-timer-stop:hover{background:#b91c1c;transform:scale(1.08)}.topbar-timer-info{display:flex;align-items:center;gap:10px}.topbar-timer-display{font-size:var(--font-size-base);font-weight:600;font-variant-numeric:tabular-nums;color:var(--color-primary)}.topbar-timer-label{font-size:var(--font-size-xs);color:var(--n-500);max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-timer-over{color:#dc2626!important;animation:timer-pulse 2s ease-in-out infinite}.topbar-timer-alert .topbar-timer-display{color:#dc2626;animation:timer-pulse 2s ease-in-out infinite}.topbar-timer-warning-icon{color:#dc2626;flex-shrink:0;animation:timer-pulse 2s ease-in-out infinite}.topbar-timer-warning{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#dc2626;color:#fff;font-size:11px;font-weight:700;flex-shrink:0}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.5}}.timer-bar{background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px 20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);margin-bottom:24px}.timer-display{font-size:2rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--n-900);min-width:140px}.timer-display.running{color:var(--color-primary)}.timer-project{flex:1;min-width:0}.timer-project select{width:100%;padding:8px 12px;border:1px solid var(--n-300);border-radius:var(--radius-md);background:var(--bg-page);color:var(--n-700);font-size:var(--font-size-sm)}.timer-description{flex:2;min-width:0}.timer-description input{width:100%;padding:8px 12px;border:1px solid var(--n-300);border-radius:var(--radius-md);background:var(--bg-page);color:var(--text-primary);font-size:var(--font-size-sm)}.timer-description input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha-10)}.timer-actions{display:flex;gap:8px}.btn-timer-start{background:var(--color-primary);color:#fff;border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),transform var(--transition-fast)}.btn-timer-start:hover{background:var(--color-primary-hover);transform:scale(1.05)}.btn-timer-stop{background:var(--color-error);color:#fff;border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),transform var(--transition-fast)}.btn-timer-stop:hover{background:#b91c1c;transform:scale(1.05)}.timer-selection-label{font-size:var(--font-size-sm);color:var(--n-500);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px;padding:4px 8px;border-radius:var(--radius-md);transition:background var(--transition-fast)}.timer-selection-label:hover{background:var(--n-100);color:var(--n-700)}.entry-list{display:flex;flex-direction:column;gap:2px}.entry-row{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-page);border:1px solid var(--n-100);border-radius:var(--radius-md);transition:box-shadow var(--transition-fast)}.entry-row:hover{box-shadow:var(--shadow-sm)}.entry-color{width:4px;height:32px;border-radius:2px;flex-shrink:0}.entry-info{flex:1;min-width:0}.entry-project{font-size:var(--font-size-xs);font-weight:600;color:var(--n-500)}.entry-activity{font-size:var(--font-size-xs);color:var(--n-400)}.entry-desc{font-size:var(--font-size-sm);color:var(--n-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-time{font-size:var(--font-size-sm);color:var(--n-500);white-space:nowrap}.entry-duration{font-size:var(--font-size-sm);font-weight:600;font-variant-numeric:tabular-nums;color:var(--n-800);min-width:60px;text-align:right}.entry-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.entry-row:hover .entry-actions{opacity:1}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.project-card{background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:12px;transition:box-shadow var(--transition-fast)}.project-card:hover{box-shadow:var(--shadow-md)}.project-card-header{display:flex;align-items:center;gap:10px}.project-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.project-name{font-weight:600;font-size:var(--font-size-base);color:var(--n-900)}.project-card-progress{display:flex;flex-direction:column;gap:4px;margin-top:4px}.project-card-progress-text{font-size:var(--font-size-xs);color:var(--n-500)}.project-stats{display:flex;gap:16px;font-size:var(--font-size-xs);color:var(--n-500)}.project-stat-value{font-weight:600;color:var(--n-700)}.weekly-grid{display:grid;grid-template-columns:160px repeat(7,1fr) 80px;gap:1px;background:var(--border-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.weekly-cell{background:var(--bg-page);padding:10px 12px;font-size:var(--font-size-sm)}.weekly-cell-header{background:var(--n-50);font-weight:600;font-size:var(--font-size-xs);color:var(--n-600);text-align:center}.weekly-cell-project{font-weight:500;color:var(--n-800);display:flex;align-items:center;gap:8px}.weekly-cell-value{text-align:center;font-variant-numeric:tabular-nums;color:var(--n-600)}.weekly-cell-total{font-weight:600;color:var(--n-900);text-align:center}.weekly-row-total{background:var(--n-50);font-weight:600}.list-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px}.search-input-wrap{position:relative;flex:1;max-width:320px}.search-input-wrap svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--n-400);pointer-events:none}.search-input{width:100%;padding:7px 12px 7px 34px;border:1px solid var(--n-300);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--bg-page);color:var(--text-primary)}.search-input::placeholder{color:var(--n-400)}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 20%,transparent)}.view-toggle{display:flex;border:1px solid var(--n-300);border-radius:var(--radius-md);overflow:hidden}.view-toggle-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--bg-page);border:none;color:var(--n-400);cursor:pointer;transition:all .15s}.view-toggle-btn:not(:last-child){border-right:1px solid var(--n-300)}.view-toggle-btn:hover{color:var(--n-600);background:var(--n-50)}.view-toggle-btn.active{color:var(--primary);background:color-mix(in srgb,var(--primary) 8%,transparent)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.empty-state>svg{width:48px;height:48px;color:var(--n-300);margin-bottom:16px}.empty-state h3{font-size:var(--font-size-lg);font-weight:600;color:var(--n-700);margin-bottom:4px}.empty-state p{font-size:var(--font-size-sm);color:var(--n-500);margin-bottom:16px}.skeleton{background:linear-gradient(90deg,var(--n-100) 25%,var(--border-color) 50%,var(--n-100) 75%);background-size:200% 100%;animation:skeleton-pulse 1.5s infinite ease-in-out;border-radius:var(--radius-md)}.week-nav{display:flex;align-items:center;gap:0}.week-nav .btn{border-radius:0}.week-nav .btn:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md)}.week-nav .btn:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0}.week-nav .btn+.btn{margin-left:-1px}.week-nav-current{font-variant-numeric:tabular-nums;white-space:nowrap}.filters-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.filters-bar select,.filters-bar input[type=date]{padding:6px 12px;border:1px solid var(--n-300);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--bg-page);color:var(--text-primary)}.today-summary{display:flex;gap:16px;margin-bottom:24px}.summary-card{background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px 20px;flex:1}.summary-card-label{font-size:var(--font-size-xs);color:var(--n-500);font-weight:500;margin-bottom:4px}.summary-card-value{font-size:var(--font-size-2xl);font-weight:700;font-variant-numeric:tabular-nums;color:var(--n-900)}.weekly-chart{display:flex;padding:16px 16px 8px;gap:0;min-height:200px}.weekly-chart-y-axis{display:flex;flex-direction:column;justify-content:space-between;padding-bottom:28px;min-width:24px;padding-right:8px}.weekly-chart-y-label{font-size:var(--font-size-xs);color:var(--n-400);text-align:right;line-height:1}.weekly-chart-bars{display:flex;flex:1;gap:4px;align-items:flex-end;position:relative}.weekly-chart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}.weekly-chart-bar{width:100%;height:180px;display:flex;flex-direction:column-reverse;border-radius:var(--radius-sm) var(--radius-sm) 0 0;overflow:hidden}.weekly-chart-segment{width:100%;min-height:1px;transition:height .3s ease}.weekly-chart-date{font-size:10px;color:var(--n-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-align:center}.dashboard-top-row{display:flex;gap:16px;margin-bottom:var(--space-6)}.dashboard-chart-card{flex:2;min-width:0}.dashboard-agenda-card{flex:1;min-width:260px;max-height:360px;display:flex;flex-direction:column}.agenda-list{flex:1;overflow-y:auto;padding:4px 8px}.agenda-entry{display:flex;align-items:center;gap:8px;padding:8px 4px;border-bottom:1px solid var(--border-color)}.agenda-entry:last-child{border-bottom:none}.agenda-entry-color{width:4px;height:32px;border-radius:2px;flex-shrink:0}.agenda-entry-info{flex:1;min-width:0}.agenda-entry-name{font-size:var(--font-size-sm);font-weight:600;color:var(--n-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agenda-entry-task{font-size:var(--font-size-xs);color:var(--n-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agenda-entry-desc{font-size:var(--font-size-xs);color:var(--n-400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:italic}.agenda-entry-right{text-align:right;flex-shrink:0}.agenda-entry-time{font-size:var(--font-size-xs);color:var(--n-500);white-space:nowrap}.agenda-entry-duration{font-size:var(--font-size-sm);font-weight:600;color:var(--n-900);font-variant-numeric:tabular-nums}.agenda-entry-check{flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--n-400);padding:0;display:flex;align-items:center;transition:color .15s ease}.agenda-entry-check:hover{color:var(--color-primary)}.agenda-entry-done{opacity:.5}.agenda-entry-done .agenda-entry-name{text-decoration:line-through}.agenda-entry-done .agenda-entry-check{color:var(--color-success, #22c55e)}.agenda-entry-meta{display:flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--n-500);margin-top:2px}.agenda-entry-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.agenda-entry-activity-tag{margin-left:4px;padding:0 4px;background:var(--n-100);border-radius:3px;font-size:11px}@media(max-width:768px){.dashboard-top-row{flex-direction:column}.dashboard-agenda-card{max-height:none}}.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px}.dashboard-stat-card{text-align:center;padding:16px 8px}.dashboard-stat-value{font-size:var(--font-size-2xl);font-weight:700;font-variant-numeric:tabular-nums;color:var(--n-900);margin-bottom:4px}.dashboard-stat-label{font-size:var(--font-size-xs);color:var(--n-500)}.dashboard-count-cards{display:flex;gap:16px;margin-bottom:24px}.dashboard-count-card{display:flex;align-items:center;gap:12px;background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px 20px;flex:1;max-width:300px}.dashboard-count-icon{color:var(--primary)}.dashboard-count-label{font-size:var(--font-size-sm);color:var(--n-500);font-weight:500}.dashboard-count-value{font-size:var(--font-size-xl);font-weight:700;color:var(--n-900)}.spinner{width:28px;height:28px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.inline-loader{display:flex;align-items:center;justify-content:center;padding:40px 0}.callback-page{display:flex;align-items:center;justify-content:center;height:100vh;flex-direction:column;gap:24px;background:var(--sidebar-bg)}.callback-page .page-loader-logo{height:32px;width:auto}.callback-page .page-loader-logo{animation:pulse 2s ease-in-out infinite}.callback-page .spinner{border-color:#ffffff26;border-top-color:#fffc}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes spin{to{transform:rotate(360deg)}}.page-subtitle{font-size:var(--font-size-sm);color:var(--n-500);margin-left:16px}.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px}.settings-grid .card-md{padding:24px}.settings-grid .card-title{font-size:var(--font-size-base);font-weight:600;color:var(--n-900);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--n-100)}.settings-grid .card-body{padding:0}.settings-grid .form-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--n-700);margin-bottom:4px}.settings-grid .input{width:100%;padding:8px 12px;border:1px solid var(--n-300);border-radius:var(--radius-md);background:var(--bg-page);color:var(--n-900);font-size:var(--font-size-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.settings-grid .input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha-10)}.settings-grid .input:disabled{background:var(--n-50);color:var(--n-500);cursor:not-allowed}.settings-grid .input-md{height:40px}.settings-grid .form-helper{display:block;font-size:12px;color:var(--n-500);margin-top:4px}.settings-actions{margin-top:24px;display:flex;justify-content:flex-end}.toggle-wrapper{display:flex;align-items:center;gap:10px;font-size:var(--font-size-sm);color:var(--n-700)}.toggle{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}.toggle input{display:none}.toggle-slider{position:absolute;top:0;left:0;right:0;bottom:0;background:var(--n-300);border-radius:9999px;cursor:pointer;transition:background .2s ease}.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:2px;top:2px;background:#fff;border-radius:50%;transition:transform .2s var(--ease-enter);box-shadow:var(--shadow-sm)}.toggle input:checked+.toggle-slider{background:var(--color-primary)}.toggle input:checked+.toggle-slider:before{transform:translate(16px)}.toggle input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.member-info{display:flex;align-items:center;gap:12px}.member-info-text{display:flex;flex-direction:column}.member-name{font-weight:500;color:var(--text-primary);font-size:var(--font-size-sm)}.member-email{font-size:var(--font-size-xs);color:var(--text-secondary)}.contract-type-picker{display:flex;gap:8px}.custom-indicator{font-size:var(--font-size-xs);color:var(--color-primary);font-weight:500}.btn-edit{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-page);color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.btn-edit:hover{background:var(--n-100);color:var(--text-primary);border-color:var(--n-400)}.day-dots{display:flex;gap:3px}.day-dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:500;color:var(--n-400);background:transparent}.day-dot.active{background:var(--color-primary);color:#fff}.schedule-editor{margin-top:8px}.schedule-day{padding:12px 0;border-bottom:1px solid var(--n-100)}.schedule-day:last-of-type{border-bottom:none}.schedule-day-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.schedule-day-label{font-weight:600;font-size:var(--font-size-sm)}.schedule-day-hours{font-size:var(--font-size-xs);color:var(--n-500);font-variant-numeric:tabular-nums}.schedule-range{display:flex;align-items:center;gap:8px;margin-bottom:6px}.schedule-range .input{max-width:120px}.schedule-range-sep{color:var(--n-400);font-size:var(--font-size-sm)}.schedule-range-remove{color:var(--n-400)}.schedule-range-remove:hover{color:var(--color-danger)}.schedule-add-range{font-size:var(--font-size-xs);color:var(--color-primary);margin-top:4px}.schedule-summary{margin-top:12px;padding:8px 12px;background:var(--n-50);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--n-600);font-weight:500}.day-picker{display:flex;gap:6px}.day-picker-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--n-300);background:var(--bg-page);font-size:var(--font-size-xs);font-weight:500;color:var(--n-600);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.day-picker-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.day-picker-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.day-picker-btn:disabled{opacity:.5;cursor:not-allowed}.member-detail-back{margin-bottom:16px}.member-detail-back .btn{color:var(--n-500);font-size:var(--font-size-sm);text-decoration:none;gap:6px}.member-detail-back .btn:hover{color:var(--text-primary)}.member-detail-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.member-detail-avatar{width:56px;height:56px;border-radius:9999px;background:var(--color-primary);color:#fff;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.member-detail-header-info{flex:1;min-width:0}.member-detail-name{font-size:var(--font-size-2xl);font-weight:600;color:var(--n-900);margin:0}.member-detail-email{font-size:var(--font-size-sm);color:var(--n-500)}.member-detail-info{margin-bottom:24px}.member-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px 32px;padding:20px 24px}.member-detail-field{display:flex;flex-direction:column;gap:6px}.member-detail-field-full{grid-column:1 / -1}.member-detail-label{font-size:var(--font-size-xs);font-weight:600;color:var(--n-500);text-transform:uppercase;letter-spacing:.05em}.member-detail-value{font-size:var(--font-size-sm);color:var(--n-800);font-weight:500}.member-detail-teams{display:flex;flex-direction:column;gap:4px}.member-detail-team-item{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:box-shadow var(--transition-fast)}.member-detail-team-item:hover{box-shadow:var(--shadow-sm)}.member-detail-team-name{font-size:var(--font-size-sm);font-weight:600;color:var(--n-800)}.member-detail-team-desc{font-size:var(--font-size-xs);color:var(--n-500);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-detail-team-item .btn-edit{margin-left:auto}.detail-back{margin-bottom:16px}.detail-back a{display:inline-flex;align-items:center;gap:6px;color:var(--n-500);font-size:var(--font-size-sm);text-decoration:none}.detail-back a:hover{color:var(--text-primary)}.detail-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.detail-dot{width:56px;height:56px;border-radius:9999px;flex-shrink:0}.detail-header-info{flex:1;min-width:0}.detail-header-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.btn-active{background:var(--p-100);color:var(--color-primary)}.detail-name{font-size:var(--font-size-2xl);font-weight:600;color:var(--n-900);margin:0}.detail-subtitle{font-size:var(--font-size-sm);color:var(--n-500)}.detail-subtitle a{color:var(--color-primary);text-decoration:none}.detail-subtitle a:hover{text-decoration:underline}.detail-description{font-size:var(--font-size-sm);color:var(--n-600);margin-top:4px;line-height:1.5}.detail-badges{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.detail-info{margin-bottom:24px}.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px 32px;padding:20px 24px}.detail-field{display:flex;flex-direction:column;gap:6px}.detail-field-full{grid-column:1 / -1}.detail-label{font-size:var(--font-size-xs);font-weight:600;color:var(--n-500);text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:var(--font-size-sm);color:var(--n-800);font-weight:500}.detail-value a{color:var(--color-primary);text-decoration:none}.detail-value a:hover{text-decoration:underline}.detail-section-header{display:flex;align-items:center;justify-content:space-between;margin-top:12px;margin-bottom:12px}.detail-section-header h3{font-size:var(--font-size-lg);font-weight:600;color:var(--n-800);margin:0}.detail-subsection-label{display:flex;align-items:center;gap:6px;font-size:var(--font-size-sm);font-weight:600;color:var(--n-600);margin-bottom:6px}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px}.stats-card{background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px 20px;display:flex;flex-direction:column;gap:4px}.stats-card-label{font-size:var(--font-size-xs);font-weight:600;color:var(--n-500);text-transform:uppercase;letter-spacing:.03em}.stats-card-value{font-size:var(--font-size-xl);font-weight:700;color:var(--n-900);font-variant-numeric:tabular-nums}.stats-card-pct{font-size:var(--font-size-sm);font-weight:400;margin-left:6px}.stats-card-positive .stats-card-value{color:var(--color-success)}.stats-card-negative .stats-card-value{color:var(--color-danger)}.progress-bar-wrap{width:100%;height:6px;background:var(--n-200);border-radius:3px;margin-top:8px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width .3s ease}.progress-bar-over{background:var(--color-danger)}.progress-bar-mini-wrap{width:80px;height:4px;background:var(--n-200);border-radius:2px;overflow:hidden;flex-shrink:0}.detail-list-item-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.task-hours-info{display:flex;align-items:center;gap:8px}.task-hours-text{font-size:var(--font-size-xs);color:var(--n-600);font-variant-numeric:tabular-nums}.stats-table-card{margin-bottom:24px}.stats-table-header{padding:16px 20px 0}.stats-table-header h4{font-size:var(--font-size-sm);font-weight:600;color:var(--n-600);margin:0}.text-right{text-align:right}.text-muted{color:var(--n-400)}.text-danger{color:var(--color-danger)}.text-sm{font-size:var(--font-size-sm)}.text-semibold{font-weight:600}.tabular{font-variant-numeric:tabular-nums}.client-avatar{display:inline-block;border-radius:50%;overflow:hidden;object-fit:cover;flex-shrink:0;vertical-align:middle}.logo-upload-area{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 0}.logo-upload-circle{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;position:relative;overflow:hidden;transition:opacity .15s ease}.logo-upload-circle img{width:100%;height:100%;object-fit:cover}.logo-upload-circle:hover{opacity:.85}.logo-upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;color:#fff;opacity:0;transition:opacity .15s ease}.logo-upload-circle:hover .logo-upload-overlay{opacity:1}.logo-upload-spinner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006}.detail-list{display:flex;flex-direction:column;gap:4px}.detail-list-item{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:box-shadow var(--transition-fast)}.detail-list-item:hover{box-shadow:var(--shadow-sm)}.detail-list-item-dot{width:10px;height:10px;border-radius:9999px;flex-shrink:0}.detail-list-item-name{font-size:var(--font-size-sm);font-weight:600;color:var(--n-800);flex:1}.detail-list-item-meta{font-size:var(--font-size-xs);color:var(--n-500)}.detail-list-item-members{width:100%;font-size:var(--font-size-xs);color:var(--n-500);padding-left:20px;margin-top:2px}.detail-list-item-actions{display:flex;gap:4px;margin-left:auto;flex-shrink:0}.assignee-badge{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--n-600)}.assignee-badge-avatar{width:20px;height:20px;border-radius:50%;background:var(--n-200);color:var(--n-600);display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;flex-shrink:0}.assignee-badge-name{white-space:nowrap}.project-name-link{color:inherit;text-decoration:none}.project-name-link:hover{color:var(--color-primary);text-decoration:underline}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;margin-top:24px}.section-header.section-header-first{margin-top:0}.section-title{font-size:var(--font-size-lg);font-weight:600;color:var(--n-900);display:flex;align-items:center}.group-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.group-card{background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:8px;transition:box-shadow var(--transition-fast)}.group-card:hover{box-shadow:var(--shadow-md)}.group-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.group-card-title{display:flex;align-items:center;gap:8px;min-width:0}.group-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.group-name{font-weight:600;font-size:var(--font-size-base);color:var(--n-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-card-actions{display:flex;gap:4px;flex-shrink:0}.group-card-description{font-size:var(--font-size-xs);color:var(--n-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin:0}.group-card-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:4px}.group-member-count{font-size:var(--font-size-xs);color:var(--n-500)}.group-avatar-stack{display:flex;flex-direction:row-reverse}.group-avatar-stack .avatar-xs{width:22px;height:22px;font-size:9px;border:2px solid var(--bg-page);margin-left:-6px}.group-avatar-stack .avatar-xs:last-child{margin-left:0}.avatar-xs{width:22px;height:22px;border-radius:9999px;background:var(--color-primary);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-sm{width:24px;height:24px;border-radius:9999px;background:var(--color-primary);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-more{background:var(--n-200);color:var(--n-600);font-size:9px}.empty-state-sm{padding:24px;text-align:center;color:var(--n-500);border:1px dashed var(--border-color);border-radius:var(--radius-lg)}.empty-state-sm h3{margin:8px 0 4px;font-size:var(--font-size-base);color:var(--n-600)}.empty-state-sm p{margin:0;font-size:var(--font-size-sm)}.btn-danger-ghost{color:var(--n-500)}.btn-danger-ghost:hover{color:var(--color-error)}.color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-dot{width:28px;height:28px;border-radius:9999px;border:3px solid transparent;cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast)}.color-dot:hover{transform:scale(1.1)}.color-dot.active{border-color:var(--n-900)}.group-member-list{max-height:240px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--radius-md)}.group-member-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-color);-webkit-user-select:none;user-select:none}.group-member-item:last-child{border-bottom:none}.group-member-item:hover,.group-member-item.selected{background:var(--n-50)}.group-member-check{width:18px;height:18px;border-radius:4px;border:2px solid var(--n-300);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast);color:#fff}.group-member-check.checked{border-color:var(--color-primary);background:var(--color-primary)}.group-member-info{display:flex;flex-direction:column;min-width:0}.group-member-name{font-size:var(--font-size-sm);font-weight:500;color:var(--n-800);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-member-email{font-size:var(--font-size-xs);color:var(--n-400);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-member-empty{padding:16px;text-align:center;color:var(--n-400);font-size:var(--font-size-sm)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.form-helper-inline{font-size:var(--font-size-xs);color:var(--n-400);font-weight:400}.agenda-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}.agenda-view-toggle{display:flex;gap:4px}.agenda-nav{display:flex;align-items:center;gap:8px}.agenda-nav-label{font-size:var(--font-size-sm);font-weight:600;color:var(--n-800);min-width:180px;text-align:center;text-transform:capitalize}.agenda-day-list{display:flex;flex-direction:column;gap:4px}.agenda-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:box-shadow var(--transition-fast)}.agenda-item:hover{box-shadow:var(--shadow-sm)}.agenda-item.completed{opacity:.6}.agenda-item.completed .agenda-item-title{text-decoration:line-through;color:var(--n-400)}.agenda-item-check{border:none;background:none;padding:2px;cursor:pointer;color:var(--n-300);flex-shrink:0;transition:color var(--transition-fast)}.agenda-item-check:hover{color:var(--color-primary)}.agenda-item.completed .agenda-item-check{color:var(--color-success)}.agenda-item-body{flex:1;min-width:0}.agenda-item-title{font-size:var(--font-size-sm);font-weight:500;color:var(--n-900);margin-bottom:2px}.agenda-item-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.agenda-item-project{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--n-500);font-weight:500}.agenda-item-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.agenda-item-activity{font-size:var(--font-size-xs);color:var(--n-400)}.agenda-item-desc{font-size:var(--font-size-xs);color:var(--n-400);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge-note{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;font-size:10px;font-weight:500;border-radius:var(--radius-sm);background:var(--n-100);color:var(--n-500)}.badge-assigned{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;font-size:10px;font-weight:500;border-radius:var(--radius-sm);background:#dbeafe;color:#1e40af;margin-left:6px;vertical-align:middle}.badge-delegated{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;font-size:10px;font-weight:500;border-radius:var(--radius-sm);background:#f3e8ff;color:#7c3aed;margin-left:6px;vertical-align:middle}.agenda-item-actions{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:opacity var(--transition-fast)}.agenda-item:hover .agenda-item-actions{opacity:1}.agenda-week{display:flex;gap:1px;background:var(--border-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;min-height:calc(100vh - 220px)}.agenda-week-col{flex:1;display:flex;flex-direction:column;background:var(--bg-page);min-width:0}.agenda-week-col.today{background:var(--n-50)}.agenda-week-header{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;border-bottom:1px solid var(--n-100);cursor:pointer;transition:background var(--transition-fast)}.agenda-week-header:hover{background:var(--n-50)}.agenda-week-day-name{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--n-400)}.agenda-week-day-num{font-size:var(--font-size-sm);font-weight:600;color:var(--n-700);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%}.agenda-week-day-num.today{background:var(--color-primary);color:#fff}.agenda-week-items{flex:1;padding:4px;display:flex;flex-direction:column;gap:2px;min-height:80px}.agenda-week-item{display:flex;align-items:center;gap:4px;padding:3px 4px;border-radius:var(--radius-sm);font-size:11px;transition:background var(--transition-fast)}.agenda-week-item:hover{background:var(--n-100)}.agenda-week-item.completed{opacity:.5}.agenda-week-item.completed .agenda-week-item-title{text-decoration:line-through}.agenda-week-item-check{border:none;background:none;padding:0;cursor:pointer;color:var(--n-300);flex-shrink:0;display:flex}.agenda-week-item.completed .agenda-week-item-check{color:var(--color-success)}.agenda-week-item-title{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--n-700)}.agenda-week-item-play{border:none;background:none;padding:2px;cursor:pointer;color:var(--n-400);flex-shrink:0;display:flex;opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast)}.agenda-week-item:hover .agenda-week-item-play{opacity:1}.agenda-week-item-play:hover{color:var(--color-primary)}.agenda-week-item-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.agenda-week-add{display:flex;align-items:center;justify-content:center;padding:4px;border:none;background:none;color:var(--n-300);cursor:pointer;transition:color var(--transition-fast);border-top:1px solid var(--n-100)}.agenda-week-add:hover{color:var(--color-primary);background:var(--n-50)}.agenda-month{border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.agenda-month-header{display:grid;grid-template-columns:repeat(7,1fr);background:var(--n-50);border-bottom:1px solid var(--border-color)}.agenda-month-day-name{padding:8px 4px;text-align:center;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--n-500)}.agenda-month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border-color)}.agenda-month-cell{background:var(--bg-page);min-height:72px;padding:4px 6px;cursor:pointer;transition:background var(--transition-fast)}.agenda-month-cell:hover{background:var(--n-50)}.agenda-month-cell.other-month{opacity:.4}.agenda-month-cell.today{background:color-mix(in srgb,var(--color-primary) 5%,var(--bg-page))}.agenda-month-num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:var(--font-size-xs);font-weight:500;color:var(--n-700)}.agenda-month-num.today{background:var(--color-primary);color:#fff;font-weight:600}.agenda-month-indicator{margin-top:2px}.agenda-month-count{font-size:10px;color:var(--n-400);font-variant-numeric:tabular-nums}.agenda-month-dots{display:flex;gap:2px;margin-top:2px;flex-wrap:wrap}.agenda-month-dot-item{width:6px;height:6px;border-radius:50%;background:var(--color-primary)}.agenda-month-dot-item.done{background:var(--color-success)}.agenda-month-dot-more{font-size:9px;color:var(--n-400);line-height:1}.sidebar-toggle-btn{display:none;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);border:none;background:transparent;cursor:pointer;color:var(--n-500);transition:color var(--transition-fast),background var(--transition-fast);flex-shrink:0}.sidebar-toggle-btn-visible{display:flex}.sidebar-toggle-btn:hover{background:var(--n-100);color:var(--n-800)}.sidebar.sidebar-collapsed{width:60px;min-width:60px;overflow:hidden}.sidebar.sidebar-collapsed .sidebar-logo{padding:0;justify-content:center}.sidebar.sidebar-collapsed .sidebar-logo-img{max-width:28px}.sidebar.sidebar-collapsed .sidebar-label{height:0;padding:0;opacity:0;overflow:hidden}.sidebar.sidebar-collapsed .sidebar-link{justify-content:center;padding:10px 8px;gap:0}.sidebar.sidebar-collapsed .sidebar-link-label{display:none}.sidebar.sidebar-collapsed .powered-by-logo{width:auto;max-width:none;height:14px}.sidebar.sidebar-collapsed .powered-by-link{display:none}@media(max-width:1023px){.sidebar-toggle-btn{display:flex}.layout-content{padding:16px}.page-header{margin-bottom:16px}.page-title{font-size:var(--font-size-xl)}.settings-grid{grid-template-columns:1fr}.timer-bar{flex-wrap:wrap;gap:12px;padding:12px 16px}}@media(max-width:639px){.layout-header{height:52px;padding:0 14px;background:var(--sidebar-bg);border-bottom-color:var(--sidebar-border)}.topbar-breadcrumb-app,.topbar-breadcrumb>svg,.topbar-breadcrumb-current{display:none}.topbar-mobile-logo{display:block;height:22px;width:auto}.sidebar-toggle-btn{color:var(--sidebar-text)}.sidebar-toggle-btn:hover{color:var(--sidebar-text-active);background:var(--sidebar-hover-bg)}.theme-toggle-btn{color:var(--sidebar-text);border-color:var(--sidebar-border)}.theme-toggle-btn:hover{color:var(--sidebar-text-active);background:var(--sidebar-hover-bg)}.notif-btn{color:var(--sidebar-text);border-color:var(--sidebar-border)}.notif-btn:hover{color:var(--sidebar-text-active);background:var(--sidebar-hover-bg)}.launcher-btn{border-color:var(--sidebar-border);color:var(--sidebar-text)}.launcher-btn:hover{background:var(--sidebar-hover-bg)}.topbar-drop{position:fixed;top:52px;left:12px;right:12px;min-width:auto}.sidebar{display:none}.sidebar-drawer{display:flex;position:fixed;top:0;left:0;bottom:0;width:220px;min-width:220px;z-index:200;transform:translate(-100%);transition:transform .25s var(--ease-enter);overflow-y:auto;box-shadow:none}.sidebar-drawer.open{transform:translate(0);box-shadow:var(--shadow-xl)}.sidebar-drawer .sidebar-section{padding:16px 12px 8px}.sidebar-drawer .sidebar-label{height:auto;margin:0 0 4px;padding:0 8px;opacity:1;overflow:visible}.sidebar-drawer .sidebar-link{justify-content:flex-start;padding:10px 12px;gap:10px;font-size:var(--font-size-sm)}.sidebar-drawer .sidebar-link-label{display:inline}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:150;animation:fadeIn .2s ease}.layout-content{padding:12px 12px 80px}.page-header{margin-bottom:12px;flex-wrap:wrap;gap:8px}.page-title{font-size:var(--font-size-lg)}.timer-bar{flex-direction:column;align-items:stretch;gap:10px;padding:12px}.timer-display{font-size:1.5rem;min-width:auto;text-align:center}.timer-actions{justify-content:center}.entry-row{padding:10px 12px;gap:10px}.entry-actions{opacity:1}.project-grid{grid-template-columns:1fr}.today-summary{flex-direction:column;gap:8px;margin-bottom:16px}.weekly-grid{overflow-x:auto;min-width:600px}.form-row{flex-direction:column;gap:0}.filters-bar{gap:8px}.settings-grid{grid-template-columns:1fr;gap:12px}.settings-grid .card-md{padding:16px;min-width:0;overflow:hidden}.day-picker{flex-wrap:wrap;gap:4px}.day-picker-btn{width:34px;height:34px}.schedule-range .input{max-width:100px}.day-dots{gap:2px}.day-dot{width:18px;height:18px;font-size:9px}.modal{width:calc(100% - 16px);max-width:calc(100% - 16px);min-width:0;border-radius:var(--radius-xl);max-height:calc(100vh - 90px);position:fixed;bottom:76px;left:8px;right:8px}.modal-overlay{align-items:flex-end}.modal-footer{flex-direction:row;border-radius:0 0 var(--radius-xl) var(--radius-xl)}.modal-footer .btn{flex:1}.mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0;height:68px;border-top:1px solid var(--border-color);display:flex;align-items:flex-start;padding-top:8px;background:var(--bg-page);z-index:100}.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:2px;cursor:pointer;font-size:10px;font-weight:500;border:none;background:transparent;font-family:var(--font-family);color:var(--n-500);transition:color var(--transition-fast);text-decoration:none}.mobile-tab:hover{color:var(--n-700)}.mobile-tab.active{color:var(--color-primary)}.mobile-tab svg{width:20px;height:20px}.agenda-toolbar{flex-direction:column;gap:8px}.agenda-week{flex-direction:column}.agenda-week-col{flex-direction:row;align-items:center;gap:8px}.agenda-week-header{min-width:60px}.agenda-week-items{flex:1;flex-direction:row;flex-wrap:wrap;gap:4px}.agenda-week-add{flex-shrink:0}.agenda-month-cell{min-height:48px}.topbar-timer{display:none}.mobile-timer-tab{position:relative}.mobile-timer-tab.active{color:var(--color-primary)}.mobile-timer-display{font-size:11px;font-variant-numeric:tabular-nums;font-weight:600;color:var(--color-primary);line-height:1}.mobile-timer-stop-icon{color:var(--color-error);width:14px!important;height:14px!important}.member-detail-header{flex-wrap:wrap;gap:12px}.member-detail-avatar{width:44px;height:44px;font-size:16px}.member-detail-name{font-size:var(--font-size-xl)}.member-detail-grid{grid-template-columns:1fr 1fr;gap:16px;padding:16px}.detail-header{flex-wrap:wrap;gap:12px}.detail-dot{width:44px;height:44px}.detail-name{font-size:var(--font-size-xl)}.detail-grid{grid-template-columns:1fr 1fr;gap:16px;padding:16px}.stats-cards{grid-template-columns:1fr 1fr}.stats-card-value{font-size:var(--font-size-lg)}}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:2000}.toast{display:flex;align-items:flex-start;gap:12px;width:360px;padding:14px 16px;background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:toast-slide-in .3s ease-out}.toast-icon{flex-shrink:0;margin-top:1px;display:flex}.toast-content{flex:1}.toast-message{font-size:var(--font-size-sm);color:var(--text-primary);line-height:1.4}.toast-close{flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:2px;display:flex;border-radius:var(--radius-sm)}.toast-close:hover{color:var(--text-primary)}.toast-success .toast-icon{color:var(--color-success)}.toast-error .toast-icon{color:var(--color-error)}.toast-warning .toast-icon{color:var(--color-warning)}.toast-info .toast-icon{color:var(--color-primary)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.badge-pending{background:#eab3081f;color:#a16207;display:inline-flex;align-items:center;gap:4px;padding:2px 10px;font-size:.8rem;font-weight:600;border-radius:999px}.badge-approved{background:#16a34a1f;color:#15803d;display:inline-flex;align-items:center;gap:4px;padding:2px 10px;font-size:.8rem;font-weight:600;border-radius:999px}.badge-rejected{background:#ef44441f;color:#dc2626;display:inline-flex;align-items:center;gap:4px;padding:2px 10px;font-size:.8rem;font-weight:600;border-radius:999px}.badge-cancelled{background:#6b72801f;color:#6b7280;display:inline-flex;align-items:center;gap:4px;padding:2px 10px;font-size:.8rem;font-weight:600;border-radius:999px}.btn-success{background:#16a34a;color:#fff}.btn-success:hover{background:#15803d}.review-detail p{margin:0 0 8px;font-size:.95rem}.wh-header{display:flex;align-items:center;justify-content:flex-start;gap:16px;margin-bottom:8px;flex-wrap:wrap}.wh-user-filter{min-width:200px}.wh-year-nav{display:flex;align-items:center;gap:8px}.wh-year{font-size:1.25rem;font-weight:700;min-width:60px;text-align:center}.wh-title-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.wh-title-row .page-title{margin-bottom:0}.wh-counter{background:var(--bg-muted, rgba(100, 116, 139, .12));color:var(--text-secondary);font-size:.8rem;font-weight:600;padding:2px 10px;border-radius:999px}.wh-table-wrapper{overflow-x:auto;border:1px solid var(--border-color);border-radius:var(--radius-lg, 12px);background:var(--bg-card)}.wh-recap-card>.wh-table-wrapper{border:none;border-top:1px solid var(--border-color);border-radius:0}.wh-table{width:max-content;min-width:100%;border-collapse:collapse;font-size:.82rem}.wh-table thead th{position:sticky;top:0;background:var(--bg-card);border-bottom:2px solid var(--border-color);padding:8px 6px;text-align:center;font-weight:600;text-transform:uppercase;font-size:.7rem;letter-spacing:.04em;color:var(--text-secondary);white-space:nowrap}.wh-col-month{text-align:left!important;padding-left:12px!important;min-width:120px}.wh-col-num{min-width:80px}.wh-col-day{min-width:52px}.wh-table tbody tr{border-bottom:1px solid var(--border-color)}.wh-table tbody tr:hover{background:var(--bg-hover, rgba(100, 116, 139, .04))}.wh-table td{padding:8px 6px;text-align:center;white-space:nowrap}.wh-month-name{text-align:left!important;padding-left:12px!important;font-weight:500;display:flex;align-items:center;gap:8px}.wh-lock-icon{color:var(--text-tertiary, rgba(100, 116, 139, .5));flex-shrink:0}.wh-delta{font-weight:600}.wh-positive{color:#16a34a}.wh-negative{color:#ef4444}.wh-target,.wh-actual{color:var(--text-secondary)}.wh-day-cell{font-size:.78rem;font-weight:500}.wh-day-empty{background:var(--bg-muted, rgba(100, 116, 139, .04))}.wh-absence{color:#16a34a;font-weight:500}.wh-totals-row{border-top:2px solid var(--border-color)!important;font-weight:700}.wh-totals-row td{padding:10px 6px}.wh-recap-card{margin-top:24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.wh-recap-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:none;border:none;cursor:pointer;color:var(--text-primary);font-size:1rem;font-weight:600}.wh-recap-header:hover{background:var(--bg-hover)}.wh-recap-label{display:flex;align-items:center;gap:12px}.wh-recap-badge{background:var(--color-primary);color:#fff;padding:4px 14px;border-radius:999px;font-size:.85rem;font-weight:600}.wh-recap-chevron{transition:transform .2s ease;color:var(--text-secondary)}.wh-recap-chevron-closed{transform:rotate(180deg)}.wh-recap-body{padding:8px 20px 24px}.wh-recap-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:16px 12px}.wh-recap-day{display:flex;flex-direction:column;gap:4px}.wh-recap-day-label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.05em}.wh-recap-day-value{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.wh-bottom-cards{display:grid;grid-template-columns:auto 1fr;gap:16px;margin-top:24px}.wh-bottom-cards .wh-recap-card{margin-top:0}.wh-overtime-card{min-width:220px;max-width:360px}.wh-overtime-months{display:flex;flex-direction:column;gap:6px}.wh-overtime-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.wh-overtime-month{font-size:var(--font-size-sm);color:var(--text-secondary);text-transform:capitalize}.wh-overtime-delta{font-size:var(--font-size-sm);font-weight:600;font-variant-numeric:tabular-nums}.wh-overtime-total{display:flex;justify-content:space-between;align-items:center;padding:8px 0 0;margin-top:8px;border-top:1px solid var(--border-color)}.wh-overtime-total .wh-overtime-month{font-weight:600;color:var(--text-primary)}.wh-overtime-total .wh-overtime-delta{font-size:var(--font-size-md);font-weight:700}@media(max-width:600px){.wh-recap-grid{grid-template-columns:repeat(4,1fr)}}.abs-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:12px}.abs-top-row .page-title{margin-bottom:0}.abs-top-actions{display:flex;gap:8px}.abs-cal-nav{display:flex;align-items:center;gap:16px;margin-bottom:12px;flex-wrap:wrap}.abs-cal-year{font-size:1.25rem;font-weight:700;min-width:60px;text-align:center}.abs-cal-legend{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}.abs-legend-item{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-secondary)}.abs-legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.abs-legend-holiday{background:#6366f1}.abs-legend-closure{background:#ef4444}.abs-legend-vacation{background:#16a34a}.abs-legend-personal{background:#3b82f6}.abs-legend-sick{background:#f97316}.abs-legend-recupero{background:#8b5cf6}.abs-legend-pending{background:#eab308}.abs-cal-container{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}@media(max-width:1023px){.abs-cal-container{grid-template-columns:repeat(3,1fr)}}@media(max-width:639px){.abs-cal-container{grid-template-columns:repeat(2,1fr)}}.abs-cal-month{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg, 12px);padding:10px}.abs-cal-month-title{font-weight:600;font-size:.85rem;text-align:center;margin-bottom:6px;color:var(--text-primary)}.abs-cal-day-headers{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.abs-cal-header{text-align:center;font-size:.65rem;font-weight:600;color:var(--text-tertiary, rgba(100, 116, 139, .6));padding:2px 0}.abs-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.abs-cal-cell{text-align:center;font-size:.72rem;padding:3px 0;border-radius:4px;cursor:default;line-height:1.6}.abs-cal-empty{visibility:hidden}.abs-cal-weekend{color:var(--text-tertiary, rgba(100, 116, 139, .4))}.abs-cal-holiday{background:#6366f126;color:#6366f1;font-weight:600}.abs-cal-closure{background:#ef444426;color:#ef4444;font-weight:600}.abs-cal-leave-vacation{background:#16a34a26;color:#16a34a;font-weight:600}.abs-cal-leave-personal{background:#3b82f626;color:#2563eb;font-weight:600}.abs-cal-leave-sick{background:#f9731626;color:#ea580c;font-weight:600}.abs-cal-leave-recupero_ore{background:#8b5cf626;color:#7c3aed;font-weight:600}.abs-cal-leave-pending{opacity:.6;border:1.5px dashed currentColor}.abs-cal-today{outline:2px solid var(--color-primary, #0ea5e9);outline-offset:-1px;font-weight:700}.abs-upcoming-list{display:flex;flex-direction:column;gap:8px}.abs-upcoming-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);font-size:.9rem}.abs-upcoming-date{font-weight:600;min-width:90px}.abs-upcoming-name{color:var(--text-secondary)}.abs-cal-clickable{cursor:pointer;transition:transform .1s ease,box-shadow .1s ease}.abs-cal-clickable:hover{transform:scale(1.15);box-shadow:0 0 0 2px var(--color-primary, #0ea5e9);z-index:2;position:relative}.abs-day-action-modal{max-width:360px}.abs-day-action-title{font-size:.95rem;color:var(--text-secondary);margin-bottom:16px}.abs-day-action-buttons{display:flex;gap:12px}.abs-day-action-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 12px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);cursor:pointer;font-size:.9rem;font-weight:500;transition:background .15s ease,border-color .15s ease}.abs-day-action-btn:hover{background:var(--bg-hover);border-color:var(--color-primary)}.abs-closure-detail-modal{max-width:380px}.abs-closure-detail-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:12px 0}.abs-closure-detail-icon{color:var(--color-danger, #ef4444);margin-bottom:4px}.abs-closure-detail-name{font-size:1.2rem;font-weight:600;margin:0}.abs-closure-detail-date{color:var(--text-secondary);font-size:.95rem;margin:0}.abs-leave-day-list{display:flex;flex-direction:column;gap:8px}.abs-leave-day-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;color:var(--text-primary);font-size:.9rem;transition:background .15s ease,border-color .15s ease;width:100%;text-align:left}.abs-leave-day-item:hover{background:var(--bg-hover);border-color:var(--color-primary)}.abs-leave-day-item-left{display:flex;align-items:center;gap:8px}.cselect{position:relative;width:100%}.cselect-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;border:1px solid var(--n-300);border-radius:var(--radius-md);background:var(--bg-page);color:var(--n-900);cursor:pointer;font-family:inherit;font-size:inherit;text-align:left;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.cselect-trigger:hover{border-color:var(--n-400)}.cselect-trigger:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha-10)}.cselect-open .cselect-trigger{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha-10)}.cselect-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cselect-placeholder{color:var(--n-400)}.cselect-chevron{flex-shrink:0;color:var(--n-400);transition:transform .15s ease;margin-left:8px}.cselect-open .cselect-chevron{transform:rotate(180deg)}.cselect-menu{background:var(--bg-page);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 16px #0000001a,0 1px 4px #0000000f;z-index:9999;max-height:220px;overflow-y:auto;padding:4px;position:fixed}.cselect-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;cursor:pointer;border-radius:var(--radius-sm, 4px);font-family:inherit;font-size:inherit;color:var(--n-700);text-align:left;transition:background .1s ease}.cselect-option:hover{background:var(--n-50);color:var(--n-900)}.cselect-option-selected{background:var(--color-primary-alpha-10, rgba(14, 165, 233, .08));color:var(--color-primary);font-weight:500}.cselect-option-selected:hover{background:var(--color-primary-alpha-10, rgba(14, 165, 233, .12))}.cselect-check{flex-shrink:0}.cselect-disabled .cselect-trigger{background:var(--n-100);color:var(--n-500);cursor:not-allowed}
