:root{--primary-color: #4a6fa5;--primary-light: #6286c0;--primary-dark: #345385;--accent-color: #47b39d;--accent-light: #63d4bd;--accent-dark: #379382;--text-primary: #333333;--text-secondary: #666666;--text-light: #999999;--bg-light: #f9f9f9;--bg-white: #ffffff;--border-color: #e0e0e0;--shadow-color: rgba(0, 0, 0, .1);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2.5rem;--spacing-xxl: 4rem;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;--breakpoint-sm: 576px;--breakpoint-md: 768px;--breakpoint-lg: 992px;--breakpoint-xl: 1200px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);color:var(--text-primary);background-color:var(--bg-light);margin:0;padding:0;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{width:100%;padding:var(--spacing-md);margin:0 auto}@media (min-width: 576px){.container{max-width:540px}}@media (min-width: 768px){.container{max-width:720px}}@media (min-width: 992px){.container{max-width:960px}}@media (min-width: 1200px){.container{max-width:1140px}}.card{background-color:var(--bg-white);border-radius:8px;box-shadow:0 2px 10px var(--shadow-color);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}@media (min-width: 768px){.card{padding:var(--spacing-lg)}}.navbar{background-color:var(--bg-white);box-shadow:0 2px 4px var(--shadow-color);padding:var(--spacing-sm) 0;margin-bottom:var(--spacing-lg);position:relative}.navbar-inner{display:flex;flex-direction:column;align-items:center;padding:0 var(--spacing-md)}.navbar-brand{font-size:1.25rem;font-weight:600;color:var(--primary-color);text-decoration:none;margin-bottom:var(--spacing-sm)}.navbar-links{display:flex;flex-direction:column;width:100%;gap:var(--spacing-sm)}@media (min-width: 768px){.navbar{padding:var(--spacing-md) 0;margin-bottom:var(--spacing-xl)}.navbar-inner{flex-direction:row;justify-content:space-between;max-width:1200px;margin:0 auto}.navbar-brand{font-size:1.5rem;margin-bottom:0}.navbar-links{flex-direction:row;width:auto;gap:var(--spacing-md)}}.navbar-link{color:var(--text-secondary);text-decoration:none;padding:var(--spacing-sm);border-radius:4px;transition:all .2s ease;text-align:center}.navbar-link:hover{color:var(--primary-color);background-color:#4a6fa51a}.navbar-link.active{color:var(--primary-color);font-weight:500;background-color:#4a6fa51a}.navbar-toggle{display:block;position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:none;border:none;cursor:pointer}@media (min-width: 768px){.navbar-toggle{display:none}}.btn{display:inline-block;padding:var(--spacing-sm) var(--spacing-md);border-radius:4px;font-weight:500;text-align:center;cursor:pointer;transition:all .2s ease;border:none;margin-right:var(--spacing-sm);font-size:.875rem}@media (min-width: 768px){.btn{padding:var(--spacing-sm) var(--spacing-lg);font-size:1rem}}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-dark)}.btn-secondary{background-color:var(--accent-color);color:#fff}.btn-secondary:hover{background-color:var(--accent-dark)}.btn-outline{background-color:transparent;color:var(--primary-color);border:1px solid var(--primary-color)}.btn-outline:hover{background-color:#4a6fa51a}.btn:disabled{opacity:.6;cursor:not-allowed}.form-group{margin-bottom:var(--spacing-md)}@media (min-width: 768px){.form-group{margin-bottom:var(--spacing-lg)}}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:4px;font-size:.875rem;transition:all .2s ease}@media (min-width: 768px){.form-input{font-size:1rem}}.form-hint{margin-top:var(--spacing-xs);font-size:.75rem;color:var(--text-light)}@media (min-width: 768px){.form-hint{font-size:.85rem}}.alert{padding:var(--spacing-sm);border-radius:4px;margin-bottom:var(--spacing-md);font-size:.875rem}@media (min-width: 768px){.alert{padding:var(--spacing-md);margin-bottom:var(--spacing-lg);font-size:1rem}}.alert-success{background-color:#47b39d1a;border-left:4px solid var(--accent-color);color:var(--accent-dark)}.alert-error{background-color:#e553531a;border-left:4px solid #e55353;color:#c14343}.page-header{margin-bottom:var(--spacing-lg);position:relative}@media (min-width: 768px){.page-header{margin-bottom:var(--spacing-xl)}}.page-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);margin-top:0}@media (min-width: 768px){.page-title{font-size:1.8rem;margin-bottom:var(--spacing-sm)}}.page-subtitle{color:var(--text-light);font-size:.875rem;font-weight:400;margin-top:0}@media (min-width: 768px){.page-subtitle{font-size:1rem}}.settings-section{margin-bottom:var(--spacing-lg)}@media (min-width: 768px){.settings-section{margin-bottom:var(--spacing-xl)}}.settings-section-title{font-size:1.1rem;font-weight:500;color:var(--text-primary);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-color);margin-bottom:var(--spacing-md)}@media (min-width: 768px){.settings-section-title{font-size:1.2rem;padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-lg)}}.grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}@media (min-width: 576px){.grid-2{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.grid{gap:var(--spacing-lg)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}.flex{display:flex}.flex-column{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--spacing-xs)}.gap-2{gap:var(--spacing-sm)}.gap-3{gap:var(--spacing-md)}.gap-4{gap:var(--spacing-lg)}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.p-1{padding:var(--spacing-xs)}.p-2{padding:var(--spacing-sm)}.p-3{padding:var(--spacing-md)}.p-4{padding:var(--spacing-lg)}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.font-bold{font-weight:700}.font-medium{font-weight:500}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.logs-panel,.log-toggle-button{display:none!important}.payroll-dashboard-page{min-height:100vh;background-color:var(--bg-light)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-md);color:var(--text-light)}@media (min-width: 768px){.loading-state{padding:var(--spacing-xl)}}.spinner{width:30px;height:30px;border:2px solid rgba(0,0,0,.1);border-radius:50%;border-top-color:var(--primary-color);animation:spin 1s ease-in-out infinite;margin-bottom:var(--spacing-sm)}@media (min-width: 768px){.spinner{width:40px;height:40px;border-width:3px;margin-bottom:var(--spacing-md)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:150px;background-color:var(--bg-light);border-radius:8px;text-align:center;color:var(--text-light);padding:var(--spacing-md)}@media (min-width: 768px){.empty-state{height:200px;padding:var(--spacing-lg)}}.chart-controls{display:flex;flex-direction:column;margin-bottom:var(--spacing-md)}@media (min-width: 768px){.chart-controls{flex-direction:row;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}}.chart-type-selector{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}@media (min-width: 768px){.chart-type-selector{margin-bottom:0}}.chart-type-button{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-white);cursor:pointer;transition:all .2s ease}@media (min-width: 768px){.chart-type-button{padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem}}.chart-wrapper{height:400px;margin-bottom:var(--spacing-md)}@media (min-width: 1024px){.chart-wrapper{min-height:500px}}@media (min-width: 1440px){.chart-wrapper{min-height:600px}}@media (min-width: 768px){.chart-wrapper{height:600px;margin-bottom:var(--spacing-lg)}}.payslip-summary{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}@media (min-width: 768px){.payslip-summary{gap:var(--spacing-lg)}}.payslip-summary-item{border-bottom:1px solid var(--border-color);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md)}.payslip-title{font-size:1.1rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--primary-color)}@media (min-width: 768px){.payslip-title{font-size:1.2rem;margin-bottom:var(--spacing-md)}}.payslip-section{margin-bottom:var(--spacing-md)}.payslip-section-title{font-size:1rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-color)}.payslip-items{display:grid;grid-template-columns:1fr;gap:var(--spacing-xs)}@media (min-width: 576px){.payslip-items{grid-template-columns:repeat(2,1fr);column-gap:4rem}}.payslip-item{display:flex;justify-content:space-between;padding:var(--spacing-xs) 0;border-bottom:1px solid rgba(0,0,0,.05)}.payslip-item-label{font-weight:500;color:var(--text-secondary)}.payslip-item-value{font-weight:600;color:var(--text-primary)}.payslip-aggregates{margin-top:var(--spacing-md);padding-top:var(--spacing-sm);border-top:1px solid var(--border-color)}@media (min-width: 768px){.payslip-aggregates{margin-top:var(--spacing-lg);padding-top:var(--spacing-md)}}.date-range-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}@media (min-width: 576px){.date-range-section{flex-direction:row;align-items:flex-end}}.date-range-field{flex:1}.date-range-input{width:100%;padding:var(--spacing-sm);border:1px solid var(--border-color);border-radius:4px}.date-range-input:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 3px #4a6fa51a}.date-range-presets{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.date-range-preset-btn{font-size:.75rem;padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-white);cursor:pointer;transition:all .2s ease}.date-range-preset-btn:hover{background-color:#4a6fa51a}@media (min-width: 768px){.date-range-preset-btn{font-size:.875rem}}.test-result-card{margin-bottom:var(--spacing-md)}.test-result-card h3{font-size:1.1rem;margin-bottom:var(--spacing-sm)}@media (min-width: 768px){.test-result-card{margin-bottom:var(--spacing-lg)}.test-result-card h3{font-size:1.2rem;margin-bottom:var(--spacing-md)}}.test-details summary{cursor:pointer;padding:var(--spacing-xs) 0;color:var(--primary-color);font-weight:500}.test-details-content{background-color:#00000008;padding:var(--spacing-sm);border-radius:4px;margin-top:var(--spacing-xs);font-size:.75rem;overflow-x:auto}.chart-scroll-container{scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--primary-light) var(--bg-light)}.chart-scroll-container::-webkit-scrollbar{height:8px}.chart-scroll-container::-webkit-scrollbar-track{background:var(--bg-light);border-radius:4px}.chart-scroll-container::-webkit-scrollbar-thumb{background-color:var(--primary-light);border-radius:4px;border:2px solid var(--bg-light)}.chart-scroll-container::-webkit-scrollbar-thumb:hover{background-color:var(--primary-color)}.spinner-sm{width:16px;height:16px;border:2px solid rgba(74,111,165,.2);border-radius:50%;border-top-color:var(--primary-color);animation:spin 1s ease-in-out infinite}.date-range-preset-btn{font-size:.75rem;padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-white);cursor:pointer;transition:all .2s ease;margin-right:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.date-range-preset-btn:hover:not(:disabled){background-color:#4a6fa51a;border-color:var(--primary-color)}.date-range-preset-btn:disabled{opacity:.6;cursor:not-allowed}.date-range-preset-btn.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.chart-type-button{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-white);cursor:pointer;transition:all .2s ease;margin-right:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.chart-type-button:hover{background-color:#4a6fa51a;border-color:var(--primary-color)}.chart-type-button.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}@media (max-width: 1024px){.date-range-presets{gap:.25rem}.date-range-preset-btn{font-size:.75rem;padding:.375rem .625rem;margin-right:0;margin-bottom:0}.card{padding:.75rem!important}.page-header,.settings-section-title{margin-bottom:.5rem}.flex.justify-between.items-center.mb-4{margin-bottom:.75rem!important}}@media (min-width: 768px){.date-range-preset-btn,.chart-type-button{font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md)}}.data-points-info{font-size:.8rem;color:var(--text-secondary);padding-left:.5rem;border-left:3px solid var(--primary-color);background-color:#4a6fa50d;padding:var(--spacing-xs) var(--spacing-sm);border-radius:4px}@media (min-width: 768px){.data-points-info{font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md)}}.chart-wrapper{border-radius:8px;overflow:hidden}@media (hover: none) and (pointer: coarse){.chart-scroll-container{-webkit-overflow-scrolling:touch;transform:translateZ(0)}.date-range-preset-btn,.chart-type-button{padding:var(--spacing-sm) var(--spacing-md);min-height:44px}}@media (min-width: 768px){.test-details-content{font-size:.875rem;padding:var(--spacing-md)}}.hidden-sm{display:none}@media (min-width: 576px){.hidden-sm{display:block}.hidden-md-up{display:none}}@media (max-width: 767px){.hidden-mobile{display:none}}@media (max-width: 991px){.hidden-tablet{display:none}}.gradient-btn{position:relative;padding:.5rem 1rem;font-weight:500;border-radius:4px;transition:all .2s ease;cursor:pointer;border:1px solid transparent;font-size:.875rem;margin-right:0;line-height:1.5}@media (min-width: 768px){.gradient-btn{padding:.5rem 1.5rem;font-size:1rem}}.gradient-btn-grey{background:#706d65;color:#fff;border-color:#706d65}.gradient-btn-grey:hover{background:#5a5854;border-color:#5a5854}.gradient-btn-teal{background:#00c4cc;color:#fff;border-color:#00c4cc}.gradient-btn-teal:hover{background:#00a8af;border-color:#00a8af}.gradient-btn-primary{background:#4a6fa5;color:#fff;border-color:#4a6fa5}.gradient-btn-primary:hover{background:#3a5a85;border-color:#3a5a85}.gradient-btn-inactive{background:#fff;color:#23221d;border:1px solid #D6D3D0}.gradient-btn-inactive:hover{background:#f9f8f6;border-color:#c1bcb7}.control-panel{display:flex;flex-direction:column;padding:0}.control-divider{width:1px;height:1.5rem;background-color:#d6d3d0;margin:0 .5rem}.control-label{font-size:.875rem;font-weight:500;color:#706d65;margin-right:.5rem}.pagination-btn{min-width:2rem;height:2rem;padding:0 .5rem;font-size:.875rem;font-weight:500;border-radius:4px;border:1px solid #D6D3D0;background:#fff;color:#23221d;cursor:pointer;transition:all .15s ease;display:inline-flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){background:#f9f8f6;border-color:#c1bcb7}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn.active{background:#00c4cc;color:#fff;border-color:#00c4cc}.pagination-btn.active:hover{background:#00a8af;border-color:#00a8af}.pagination-nav-btn{min-width:2rem;height:2rem;padding:0;font-size:1rem;font-weight:600;border-radius:4px;border:1px solid #D6D3D0;background:#fff;color:#706d65;cursor:pointer;transition:all .15s ease;display:inline-flex;align-items:center;justify-content:center}.pagination-nav-btn:hover:not(:disabled){background:#f9f8f6;border-color:#c1bcb7;color:#23221d}.pagination-nav-btn:disabled{opacity:.3;cursor:not-allowed}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#00c4cc,#0099a8);padding:1rem}.login-container{width:100%;max-width:480px}.login-card{background-color:#fff;border-radius:20px;padding:3rem 2rem;box-shadow:0 20px 60px #0000004d;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-card .app-logo{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:2rem}.login-card .app-logo-icon{color:#00c4cc}.login-card .app-logo-text{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#00c4cc,#0099a8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.login-content{display:flex;flex-direction:column;align-items:center}.login-message{text-align:center;color:#4a5568;font-size:1.1rem;line-height:1.6;margin-bottom:2rem}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;width:100%;margin-bottom:2rem}@media (max-width: 480px){.features-grid{grid-template-columns:1fr;gap:1rem}}.feature-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem;font-size:.85rem;color:#718096}.feature-icon{color:#00c4cc}.btn-smarthr{width:100%;padding:1rem 2rem;font-size:1.1rem;font-weight:600;color:#fff;background:#00c4cc;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00c4cc4d;margin-bottom:1rem}.btn-smarthr:hover:not(:disabled){background:#00a8ae;transform:translateY(-1px);box-shadow:0 6px 16px #00c4cc66}.btn-smarthr:disabled{opacity:.7;cursor:not-allowed;transform:none}.spinner-sm{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite;margin-right:.5rem}.login-info{text-align:center;color:#a0aec0;font-size:.9rem}.login-info strong{color:#00c4cc}:root{--primary-color: #00c4cc;--primary-light: #33d4da;--primary-dark: #0099a8;--accent-color: #ff9900;--accent-light: #ffad33;--accent-dark: #cc7a00;--text-primary: #23221f;--text-secondary: #666666;--text-light: #999999;--bg-light: #f9f9f9;--bg-white: #ffffff;--border-color: #e0e0e0;--shadow-color: rgba(0, 0, 0, .1);--spacing-xxs: .25rem;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-xxl: 3rem;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic UI", Meiryo, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-bold: 700;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .1)}body{font-family:var(--font-family);font-size:var(--font-size-md);color:var(--text-primary);background-color:var(--bg-light);margin:0;padding:0;line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.card{background-color:var(--bg-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);transition:box-shadow .2s ease}.card:hover{box-shadow:var(--shadow-md)}.navbar{background-color:var(--bg-white);box-shadow:0 2px 10px #0000000d;padding:.75rem 0;position:sticky;top:0;z-index:100;width:100%}.navbar-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 1rem;width:100%}.logo-container{display:flex;align-items:center;justify-content:space-between;width:100%}@media (min-width: 768px){.logo-container{width:auto}}.app-logo{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-sm);text-decoration:none;position:relative}.app-logo-icon{color:var(--primary-color)}.app-logo-text{font-size:1.5rem;font-weight:600;margin:0;color:var(--primary-color);letter-spacing:-.5px}.app-logo:after,.app-logo:before{display:none!important}.navbar-links{display:flex;gap:var(--spacing-md)}.navbar-link{position:relative;padding:.5rem 1rem;color:var(--text-secondary);font-weight:500;text-decoration:none;transition:all .2s ease;border-radius:4px;background:transparent;border:none;cursor:pointer;font-size:1rem}.navbar-link:hover{color:var(--primary-color);background-color:#4a6fa50d}.navbar-link.active{color:var(--primary-color);font-weight:600}.navbar-link.active:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:30px;height:3px;background-color:var(--primary-color);border-radius:3px}.navbar-link.feedback-button,.mobile-link.feedback-button{display:flex;align-items:center;gap:.5rem}.navbar-link.feedback-button:hover{color:var(--primary-color)}.desktop-menu{display:none}.mobile-menu-button{display:block;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s ease;float:right}.mobile-menu-button:hover{background-color:#0000000d;color:var(--primary-color)}.mobile-menu{display:none;background-color:var(--bg-white);border-top:1px solid var(--border-color);width:100%;box-shadow:0 4px 6px #0000001a}.mobile-menu.open{display:block;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mobile-menu-content{padding:.5rem 0}.mobile-link{display:block;padding:.75rem 1rem;border-bottom:1px solid rgba(0,0,0,.05);width:100%;text-align:left;color:var(--text-secondary);font-weight:500;text-decoration:none;transition:all .2s ease;background:transparent;border:none;cursor:pointer;font-size:1rem}.mobile-link:last-child{border-bottom:none}.mobile-link.active{color:var(--primary-color);background-color:#4a6fa51a;border-left:3px solid var(--primary-color)}.logout-button{width:100%;text-align:left}@media (min-width: 768px){.desktop-menu{display:flex;gap:var(--spacing-md)}.mobile-menu-button{display:none}.mobile-menu{display:none!important}.navbar-inner{flex-direction:row}}@media (max-width: 767px){.navbar-inner{flex-direction:column;padding:.5rem}.app-logo-text{font-size:1.25rem}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);text-align:center;cursor:pointer;transition:all .2s ease;border:none;line-height:var(--line-height-tight);white-space:nowrap}.btn-primary{background-color:var(--primary-color);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background-color:var(--accent-color);color:#fff;box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background-color:var(--accent-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-outline{background-color:transparent;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-outline:hover:not(:disabled){background-color:#00c4cc1a}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-secondary)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:4px;font-size:1rem;transition:all .2s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 3px #4a6fa51a}.form-hint{margin-top:var(--spacing-xs);font-size:.85rem;color:var(--text-light)}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.alert-success{background-color:#00c4cc1a;border-left:4px solid var(--primary-color);color:var(--primary-dark)}.alert-error{background-color:#ff99001a;border-left:4px solid var(--accent-color);color:var(--accent-dark)}.chart-container{height:400px;margin:var(--spacing-lg) 0}.page-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.page-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--spacing-xs);margin-top:0;line-height:var(--line-height-tight)}.page-subtitle{color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);margin-top:0;line-height:var(--line-height-normal)}.settings-section{margin-bottom:var(--spacing-xl)}.settings-section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-md);margin-top:0;line-height:var(--line-height-tight)}.date-range-preset-btn{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-white);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all .2s ease;color:var(--text-secondary)}.date-range-preset-btn:hover:not(:disabled){background-color:#00c4cc0d;border-color:var(--primary-color);color:var(--primary-color)}.date-range-preset-btn.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-dark);box-shadow:var(--shadow-sm)}.date-range-preset-btn:disabled{opacity:.5;cursor:not-allowed}.date-range-presets{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.chart-type-button{padding:8px 16px;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-light);cursor:pointer;transition:all .2s ease}.chart-type-button.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-dark)}.border-left-primary{border-left:4px solid var(--primary-color)}.payslip-detail-content{padding:var(--spacing-md)}.payslip-memo{background-color:#4a6fa51a;border-radius:4px;padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.summary-item{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md);background-color:var(--bg-white);transition:all .2s ease}.summary-item:hover{box-shadow:var(--shadow-sm);border-color:var(--primary-light)}.spinner{display:inline-block;width:24px;height:24px;border:3px solid rgba(0,196,204,.2);border-radius:50%;border-top-color:var(--primary-color);animation:spin 1s ease-in-out infinite}.spinner-sm{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state,.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--text-light)}.auth-callback-page,.auth-loading-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:var(--bg-light)}.large-spinner{width:48px;height:48px;border-width:4px;margin-bottom:1.5rem}.loading-text{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.loading-subtext{color:var(--text-secondary);margin-top:.5rem}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background-color:#fff;border-radius:12px;box-shadow:0 8px 30px #00000014;text-align:center;max-width:90%;width:400px}.error-message{color:#c14343;margin:1rem 0 1.5rem}.date-range-section{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.date-range-field{flex:1;min-width:200px}.date-range-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:4px;font-size:1rem}.recharts-tooltip-item-name{margin-right:8px}.recharts-tooltip-item-value{font-weight:700}.recharts-tooltip-item[data-tooltip-type=特別]{color:var(--primary-color);font-weight:700}.recharts-tooltip-item[data-tooltip-type=支給]{color:var(--accent-color)}.recharts-tooltip-item[data-tooltip-type=控除]{color:#e55353}.month-list{display:flex;flex-direction:column;gap:8px;max-height:500px;overflow-y:auto}.month-list-item{cursor:pointer;padding:var(--spacing-md);border-radius:var(--radius-sm);transition:all .2s ease;border:1px solid transparent}.month-list-item:hover{background-color:#00c4cc0d;border-color:var(--primary-light)}.month-list-item.selected{background-color:#00c4cc1a;border-left:4px solid var(--primary-color);box-shadow:var(--shadow-sm)}.month-list-item-title{font-weight:500;margin-bottom:4px}.month-list-item-date{font-size:.85rem;color:var(--text-secondary)}.token-input-container{position:relative;display:flex;align-items:center}.token-input{flex:1}.token-display{position:absolute;left:12px;pointer-events:none;color:var(--text-primary)}.token-toggle-btn{position:absolute;right:10px;background:none;border:none;cursor:pointer;opacity:.6;transition:opacity .2s}.token-toggle-btn:hover{opacity:1}.token-toggle-btn .icon{font-size:18px}.month-list-container{max-height:300px;overflow-y:auto;margin-top:1rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--primary-light) var(--bg-light);padding-right:4px}.month-list-container::-webkit-scrollbar{width:4px}.month-list-container::-webkit-scrollbar-track{background:var(--bg-light)}.month-list-container::-webkit-scrollbar-thumb{background-color:var(--primary-light);border-radius:4px}.month-list-pagination{display:flex;justify-content:center;margin-top:1rem;flex-wrap:wrap;gap:.25rem}.page-button{background-color:var(--bg-white);border:1px solid var(--border-color);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);transition:all .2s ease;min-width:2rem;text-align:center;color:var(--text-secondary)}.page-button:hover:not(:disabled){background-color:#00c4cc0d;border-color:var(--primary-color);color:var(--primary-color)}.page-button.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-dark);box-shadow:var(--shadow-sm)}.page-button:disabled{opacity:.5;cursor:not-allowed}.payroll-dashboard-page .grid{margin-top:1rem}.page-header,.settings-section-title{margin-bottom:1rem}.payroll-dashboard-page .container>*{margin-left:auto;margin-right:auto}.chart-wrapper{height:450px;display:flex;flex-direction:column;margin-bottom:1.5rem}.chart-data-container{flex:1;min-height:400px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--primary-light) var(--bg-light)}.chart-data-container::-webkit-scrollbar{height:6px}.chart-data-container::-webkit-scrollbar-track{background:var(--bg-light)}.chart-data-container::-webkit-scrollbar-thumb{background-color:var(--primary-light);border-radius:6px}.chart-content{height:100%;min-width:100%}.data-points-info{font-size:.8rem;color:var(--text-secondary);margin-bottom:.5rem;padding-left:.5rem}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.navbar+.navbar,.navbar~.navbar{display:none!important}@media (max-width: 767px){.date-range-section{flex-direction:column;align-items:stretch}.date-range-field{width:100%}.grid{grid-template-columns:1fr!important}.chart-wrapper{height:350px}.month-list-container{max-height:250px}}@media (min-width: 768px){.month-list-container{max-height:400px}.chart-wrapper{height:400px;margin-bottom:1.5rem}.summary-item{transition:transform .2s ease}.summary-item:hover{transform:translateY(-2px)}}.app-logo:after,.app-logo:before{content:none!important;display:none!important;opacity:0!important;visibility:hidden!important}button,a{-webkit-tap-highlight-color:transparent}img,svg{-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;user-drag:none}@media (hover: none) and (pointer: coarse){.navbar-link,.mobile-link,.btn,.date-range-preset-btn{padding-top:.75rem;padding-bottom:.75rem}.chart-data-container,.month-list-container{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}@media (min-width: 768px) and (max-width: 991px){.container{padding:0 1.5rem}.card{padding:1.25rem}}#root{width:100%;margin:0 auto}.app-container{width:100%;min-height:100vh;display:flex;flex-direction:column}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}.content-area{flex:1;padding-top:1rem;padding-bottom:2rem}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.app-logo svg{display:block}body{margin:0;padding:0}.auth-loading-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:var(--bg-light)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background-color:#fff;border-radius:12px;box-shadow:0 8px 30px #00000014;text-align:center;max-width:90%;width:400px;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.chart-container{margin-bottom:1rem}.card{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000000d;padding:1rem;margin-bottom:1rem;overflow:hidden}.grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 768px){.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}}.gradient-btn{position:relative;padding:.625rem 1.5rem;font-weight:600;border-radius:.5rem;transition:all .2s ease;cursor:pointer;border:none;font-size:1rem}.gradient-btn-blue{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 10px 25px -5px #2563eb80,0 8px 10px -6px #2563eb80}.gradient-btn-blue:hover{transform:translateY(-2px);box-shadow:0 15px 30px -5px #2563eb99,0 10px 15px -6px #2563eb99}.gradient-btn-teal{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;box-shadow:0 10px 25px -5px #14b8a680,0 8px 10px -6px #14b8a680}.gradient-btn-teal:hover{transform:translateY(-2px);box-shadow:0 15px 30px -5px #14b8a699,0 10px 15px -6px #14b8a699}.gradient-btn-indigo{background:linear-gradient(135deg,#4f46e5,#4338ca);color:#fff;box-shadow:0 10px 25px -5px #4f46e580,0 8px 10px -6px #4f46e580}.gradient-btn-indigo:hover{transform:translateY(-2px);box-shadow:0 15px 30px -5px #4f46e599,0 10px 15px -6px #4f46e599}.gradient-btn-inactive{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;box-shadow:none}.gradient-btn-inactive:hover{background:#e5e7eb;box-shadow:0 1px 3px #0000001a}.control-panel{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.control-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.control-divider{width:1px;height:2rem;background-color:#d1d5db;margin:0 .25rem}.control-label{font-size:.875rem;font-weight:500;color:#6b7280;margin-right:.25rem}
