:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#333;background:#f0f7fa;font-family:Hiragino Kaku Gothic Pro,Meiryo,sans-serif}a{color:inherit;text-decoration:none}.app-container{flex-direction:column;min-height:100vh;display:flex}.app-header{color:#fff;background:#126c81;justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.app-header-right{align-items:center;gap:8px;display:flex}.app-user{color:#9dd6e5;font-size:.85rem}.app-header-btn{color:#126c81;background:#fff;border:none;border-radius:6px;padding:5px 14px;font-size:.82rem;font-weight:600}.app-header-btn:hover:not(:disabled){opacity:1;background:#e6f6fa}.app-title{color:#fff;flex-direction:column;align-items:flex-start;font-size:1.1rem;font-weight:700;line-height:1.2;display:flex}.app-by{color:#9dd6e5;margin-top:2px;font-size:.65rem;font-weight:400}.app-main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:24px}.btn{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;padding:8px 20px;font-size:.95rem;transition:opacity .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:hover:not(:disabled){opacity:.85}.btn-primary{color:#fff;background:#1baac8}.btn-secondary{color:#333;background:#ecf0f1;border:1px solid #bdc3c7}.btn-lg{padding:12px 32px;font-size:1.05rem}.btn-sm{padding:4px 12px;font-size:.85rem}.btn-remove{color:#e74c3c;cursor:pointer;background:0 0;border:none;font-size:.85rem}.home-page{flex-direction:column;align-items:center;padding-top:80px;display:flex}.no-company-box{text-align:center;background:#fff;border-radius:14px;max-width:440px;padding:52px 60px;box-shadow:0 2px 12px #00000014}.no-company-icon{margin-bottom:16px;font-size:3rem}.no-company-box h2{color:#2c3e50;margin-bottom:12px;font-size:1.2rem}.no-company-box p{color:#666;font-size:.92rem;line-height:1.6}.settings-page{max-width:680px;margin:0 auto}.page-header{margin-bottom:24px}.page-header h1{color:#2c3e50;font-size:1.4rem}.company-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#555;font-size:.9rem;font-weight:700}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.form-group input[type=text],.form-group input[type=date],.form-group select{background:#fff;border:1px solid #ccc;border-radius:6px;padding:8px 12px;font-size:.95rem}.form-group input:focus,.form-group select:focus{border-color:#1baac8;outline:none;box-shadow:0 0 0 3px #1baac81f}.weekday-checkboxes{flex-wrap:wrap;gap:12px;display:flex}.checkbox-label{cursor:pointer;align-items:center;gap:6px;font-weight:400;display:flex}.special-holiday-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;display:flex}.special-name{flex:1;min-width:140px}.form-error{color:#c0392b;background:#fdf2f2;border:1px solid #e74c3c;border-radius:6px;padding:10px 14px}.calendar-page{flex-direction:column;gap:24px;display:flex}.page-actions{justify-content:flex-end;gap:12px;display:flex}.summary-panel{background:#fff;border-radius:10px;padding:20px 24px;box-shadow:0 1px 4px #00000014}.summary-panel h1{color:#2c3e50;font-size:1.5rem}.fiscal-year{color:#666;margin:4px 0 16px}.summary-stats{gap:32px;display:flex}.stat{flex-direction:column;gap:4px;display:flex}.stat-label{color:#666;font-size:.85rem}.stat-value{color:#2c3e50;font-size:1.6rem;font-weight:700}.year-calendar{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=900px){.year-calendar{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.year-calendar{grid-template-columns:1fr}}.calendar-month{background:#fff;border-radius:8px;padding:12px;box-shadow:0 1px 3px #00000012}.month-title{color:#2c3e50;text-align:center;margin-bottom:8px;font-size:1rem;font-weight:700}.calendar-month table{border-collapse:collapse;width:100%}.calendar-month th,.calendar-month td{text-align:center;vertical-align:top;padding:4px 2px;font-size:.85rem}.calendar-month th{color:#555;border-bottom:1px solid #eee;padding-bottom:6px;font-weight:700}.calendar-month th.sat{color:#1baac8}.calendar-month th.sun{color:#e74c3c}td.holiday{color:#8b2218;background:#f4ada8;border-radius:4px;font-weight:700}td.saturday{color:#0d6678;background:#c2eaf3;border-radius:4px;font-weight:700}td.workday{color:#333}td.empty{background:0 0}td:hover:not(.empty){filter:brightness(.92)}.summary-and-hours{align-items:flex-start;gap:16px;display:flex}.summary-and-hours .monthly-summary{flex:1}.working-hours-panel{background:#fff;border-radius:10px;min-width:280px;padding:20px 24px;box-shadow:0 1px 4px #00000014}.working-hours-panel h2{color:#2c3e50;margin-bottom:12px;font-size:1rem}.working-hours-panel table{border-collapse:collapse;width:100%}.working-hours-panel th,.working-hours-panel td{text-align:left;border-bottom:1px solid #eee;padding:8px 10px;font-size:.9rem}.working-hours-panel th{color:#666;white-space:nowrap;width:60%;font-weight:400}.working-hours-panel td{color:#2c3e50;text-align:right;white-space:nowrap;font-weight:700}.working-hours-panel tr.divider-row th,.working-hours-panel tr.divider-row td{border-top:2px solid #bdc3c7}.working-hours-note{color:#999;margin-top:12px;font-size:.8rem}.form-section-title{color:#2c3e50;border-bottom:2px solid #ecf0f1;margin-top:8px;padding-bottom:6px;font-size:.9rem;font-weight:700}@media (width<=700px){.summary-and-hours{flex-direction:column}}.monthly-summary{background:#fff;border-radius:10px;padding:20px 24px;box-shadow:0 1px 4px #00000014}.monthly-summary h2{color:#2c3e50;margin-bottom:12px;font-size:1rem}.monthly-summary table{border-collapse:collapse;width:100%}.monthly-summary th,.monthly-summary td{text-align:center;border-bottom:1px solid #eee;padding:8px 12px}.monthly-summary th{color:#555;background:#f7f8fa;font-weight:700}.monthly-summary tfoot tr.summary-total td{color:#2c3e50;background:#f0f4f8;border-top:2px solid #bdc3c7;font-weight:700}.export-buttons{gap:8px;display:flex}.disclaimer{color:#7a6700;background:#fffbea;border:1px solid #f0e6a0;border-radius:8px;padding:14px 18px;font-size:.85rem;line-height:1.7}.loading{text-align:center;color:#888;padding:60px}.error-page{text-align:center;color:#e74c3c;padding:60px}.success-box{background:#eafaf1;border:1px solid #a9dfbf;border-radius:8px;flex-direction:column;gap:12px;max-width:400px;padding:20px 24px;display:flex}.login-page{justify-content:center;align-items:center;min-height:70vh;padding:24px;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:420px;padding:48px 52px;box-shadow:0 8px 40px #2c3e501f}.login-logo{flex-direction:column;align-items:center;margin-bottom:36px;display:flex}.login-logo-icon{background:linear-gradient(135deg,#126c81 0%,#1baac8 100%);border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:14px;display:flex}.login-logo-icon svg{fill:#fff;width:28px;height:28px}.login-title{color:#2c3e50;text-align:center;margin-bottom:4px;font-size:1.25rem;font-weight:700}.login-subtitle{color:#a0b4c4;text-align:center;font-size:.8rem}.login-form{flex-direction:column;gap:18px;display:flex}.login-form .form-group label{color:#555;margin-bottom:6px;font-size:.85rem;font-weight:600}.login-form input[type=text],.login-form input[type=password]{background:#f9fafb;border:1.5px solid #dde3ea;border-radius:8px;padding:11px 14px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.login-form input:focus{background:#fff;border-color:#1baac8;outline:none;box-shadow:0 0 0 3px #1baac826}.login-btn{letter-spacing:.02em;background:linear-gradient(135deg,#126c81 0%,#1baac8 100%);border-radius:8px;justify-content:center;width:100%;margin-top:6px;padding:13px;font-size:1rem;font-weight:600}.admin-page{flex-direction:column;gap:20px;display:flex}.admin-header-row{justify-content:space-between;align-items:center;display:flex}.admin-header-row h1{color:#126c81;font-size:1.4rem}.admin-tabs{border-bottom:2px solid #e0ecef;gap:0;margin-bottom:4px;display:flex}.admin-tab{cursor:pointer;color:#888;background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;padding:10px 28px;font-size:.95rem;transition:color .15s}.admin-tab:hover{color:#1baac8}.admin-tab.active{color:#1baac8;border-bottom-color:#1baac8;font-weight:700}.admin-section{background:#fff;border-radius:12px;padding:24px 28px;box-shadow:0 1px 6px #00000012}.admin-section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.admin-section-header h2{color:#126c81;font-size:1.05rem;font-weight:700}.admin-table{border-collapse:collapse;width:100%;font-size:.9rem}.admin-table th{text-align:left;color:#126c81;background:#e9f6fa;border-bottom:2px solid #c5e8f0;padding:10px 14px;font-size:.85rem;font-weight:600}.admin-table td{border-bottom:1px solid #f0f0f0;padding:12px 14px}.admin-table tbody tr:hover{background:#f5fbfd}.admin-table tr.row-inactive td{color:#bbb}.admin-form-box{background:#f0f8fb;border:1px solid #c5e8f0;border-radius:10px;margin-bottom:20px;padding:20px 24px}.admin-form-box h3{color:#126c81;border-bottom:1px solid #c5e8f0;margin-bottom:16px;padding-bottom:10px;font-size:.95rem;font-weight:700}.admin-inline-form{flex-direction:column;gap:14px;display:flex}.admin-inline-form input[type=text],.admin-inline-form input[type=password],.admin-inline-form select{background:#fff;border:1.5px solid #c5d8e0;border-radius:7px;width:100%;padding:9px 12px;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.admin-inline-form input:focus,.admin-inline-form select:focus{border-color:#1baac8;outline:none;box-shadow:0 0 0 3px #1baac81f}.admin-inline-form .form-group label{color:#555;font-size:.82rem;font-weight:600}.admin-form-actions{gap:8px;padding-top:4px;display:flex}.badge{border-radius:20px;padding:3px 12px;font-size:.8rem;font-weight:700;display:inline-block}.badge-active{color:#1a7a40;background:#d5f5e3}.badge-inactive{color:#c0392b;background:#fdecea}.btn-danger{color:#fff;background:#e74c3c}.holiday-list-panel{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 1px 4px #00000014}.holiday-list-toggle{cursor:pointer;color:#2c3e50;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:14px 20px;font-size:.95rem;font-weight:700;transition:background .12s;display:flex}.holiday-list-toggle:hover{background:#f5fbfd}.holiday-list-toggle-label{align-items:center;gap:10px;display:flex}.holiday-list-count{color:#126c81;background:#e6f6fa;border-radius:20px;padding:2px 10px;font-size:.8rem;font-weight:400}.holiday-list-chevron{color:#888;font-size:.75rem}.holiday-list-body{border-top:1px solid #eef4f7;padding:4px 20px 20px}.holiday-list-empty{color:#999;padding:12px 0;font-size:.9rem}.holiday-list{grid-template-columns:repeat(2,1fr);gap:2px 24px;margin-top:8px;list-style:none;display:grid}@media (width<=600px){.holiday-list{grid-template-columns:1fr}}.holiday-list-item{border-bottom:1px solid #f3f3f3;align-items:center;gap:8px;padding:7px 4px;font-size:.88rem;display:flex}.holiday-item-date{color:#555;flex-shrink:0;min-width:110px}.holiday-item-name{color:#2c3e50;white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:500;overflow:hidden}.holiday-item-badge{border-radius:4px;flex-shrink:0;padding:2px 7px;font-size:.72rem;font-weight:700}.hbadge-national{color:#c0392b;background:#fdecea}.hbadge-manual{color:#126c81;background:#e6f6fa}.hbadge-special{color:#1a7a55;background:#e8f8f5}.dialog-backdrop{z-index:10000;background:#00000073;justify-content:center;align-items:center;animation:.15s backdrop-in;display:flex;position:fixed;inset:0}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.dialog-box{background:#fff;border-radius:14px;width:100%;max-width:420px;padding:32px 36px;animation:.18s dialog-in;box-shadow:0 12px 48px #00000038}@keyframes dialog-in{0%{opacity:0;transform:scale(.94)translateY(-8px)}to{opacity:1;transform:scale(1)translateY(0)}}.dialog-title{color:#2c3e50;margin-bottom:12px;font-size:1.1rem;font-weight:700}.dialog-message{color:#555;margin-bottom:28px;font-size:.92rem;line-height:1.6}.dialog-actions{justify-content:flex-end;gap:10px;display:flex}.copy-notice{background:#e6f6fa;border:1.5px solid #1baac8;border-radius:10px;align-items:flex-start;gap:14px;margin-bottom:24px;padding:14px 18px;display:flex}.copy-notice-icon{flex-shrink:0;font-size:1.4rem;line-height:1.2}.copy-notice strong{color:#0d6678;margin-bottom:4px;font-size:.9rem;display:block}.copy-notice p{color:#1a7d90;margin:0;font-size:.82rem;line-height:1.5}.forced-pw-notice{background:#fff8e1;border:1.5px solid #f0c040;border-radius:10px;align-items:flex-start;gap:14px;max-width:400px;margin-bottom:24px;padding:16px 20px;display:flex}.forced-pw-icon{flex-shrink:0;font-size:1.5rem;line-height:1}.forced-pw-notice strong{color:#7a5c00;margin-bottom:4px;font-size:.95rem;display:block}.forced-pw-notice p{color:#8a6e00;margin:0;font-size:.85rem;line-height:1.5}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:28px;right:28px}.toast{pointer-events:auto;cursor:pointer;border-radius:10px;align-items:center;gap:10px;min-width:220px;max-width:400px;padding:13px 20px;font-size:.9rem;font-weight:500;line-height:1.4;animation:.22s toast-slide-in;display:flex;box-shadow:0 6px 24px #0000002e}@keyframes toast-slide-in{0%{opacity:0;transform:translate(60px)}to{opacity:1;transform:translate(0)}}.toast-success{color:#fff;background:#1a7a40}.toast-error{color:#fff;background:#c0392b}.toast-info{color:#fff;background:#126c81}.toast-icon{flex-shrink:0;font-size:1.05rem;font-weight:700}
