@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Noto+Sans+JP:wght@400;500;600;700&family=Outfit:wght@700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#6366f1;--color-primary-hover:#4f46e5;--color-primary-light:#eef2ff;--color-primary-end:#9b7aed;--color-primary-gradient:linear-gradient(135deg, #6366f1 0%, #9b7aed 100%);--color-primary-gradient-hover:linear-gradient(135deg, #4f46e5 0%, #8b6ad5 100%);--color-brand-start:#6366f1;--color-brand-mid:#a78bfa;--color-brand-end:#7dd3fc;--color-brand-sub-start:#a78bfa;--color-brand-sub-end:#7dd3fc;--brand-gap-xs:8px;--brand-gap-sm:13px;--brand-gap-md:21px;--brand-gap-lg:34px;--color-danger:#d94f4f;--color-danger-hover:#c43c3c;--color-danger-light:#fef2f2;--color-danger-text:#8b2525;--color-danger-border:#fecaca;--color-success:#10b981;--color-success-light:#dcfce7;--color-success-text:#166534;--color-success-border:#bbf7d0;--color-success-gradient:linear-gradient(135deg, #10b981 0%, #059669 100%);--color-warning:#f59e0b;--color-warning-light:#fef3c7;--color-warning-text:#92400e;--color-warning-border:#fde68a;--color-secondary:#7c3aed;--color-secondary-light:#ede9fe;--color-secondary-subtle:#f5f3ff;--color-secondary-text:#6d28d9;--color-disabled-bg:#f3f4f6;--color-disabled-text:#9ca3af;--color-bg:#f8fafc;--color-surface:#fff;--color-surface-hover:#f1f5f9;--color-border:#e2e8f0;--color-text:#334155;--color-text-secondary:#475569;--color-text-muted:#64748b;--color-text-light:#94a3b8;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-pill:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000000d, 0 2px 4px -2px #0000000d;--shadow-lg:0 12px 48px -8px #6366f114, 0 4px 16px #00000008;--shadow-card:0 10px 40px -10px #0000000f;--text-2xs:10px;--text-xs:11px;--text-sm:13px;--text-base:14px;--text-md:16px;--text-lg:18px;--text-xl:24px;--text-2xl:28px;--icon-sm:16px;--icon-md:20px;--icon-lg:24px;--shadow-primary:0 4px 12px #6366f140;--shadow-primary-lg:0 8px 16px -4px #6366f14d;--shadow-glow:0 12px 32px -4px #6366f166;--shadow-elevated:0 20px 60px -10px #6366f126, 0 4px 20px #0000000a;--bg-gradient-subtle:linear-gradient(135deg, #f5f3ff 0%, #e0e7ff 50%, #ede9fe 100%);--glass-bg:#ffffffd9;--glass-border:#fff9;--glass-backdrop:blur(20px);--font-heading:"Outfit", "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif;--font-body:"Inter", "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--color-heading:#1e293b;--header-height:72px;--sidebar-width:260px}body{font-family:var(--font-body);background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-width:320px;line-height:1.6}a{color:var(--color-primary);text-decoration:none;transition:color .2s}a:hover{color:var(--color-primary-hover)}button{cursor:pointer;outline:none;font-family:inherit;transition:all .2s}button:focus-visible{box-shadow:0 0 0 3px var(--color-primary-light)}input,select,textarea{font-family:inherit;font-size:inherit;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);color:var(--color-text);outline:none;transition:all .2s}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px var(--color-primary-light);background-color:#fff}input::placeholder,textarea::placeholder{color:var(--color-text-light)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-light)}.mobile-menu-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);background-color:var(--color-surface);cursor:pointer;outline:none;justify-content:center;align-items:center;padding:8px;display:flex}@media (width>=1024px){.mobile-menu-btn{display:none!important}}@media (width<=639px){.desktop-only{display:none!important}}@media (width>=640px){.mobile-only{display:none!important}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ui-card{background-color:var(--color-surface);border-radius:var(--radius-xl);min-width:0;max-width:100%;box-shadow:var(--shadow-card);padding:var(--space-6);border:1px solid #e2e8f099;transition:transform .25s,box-shadow .25s,border-color .25s}.ui-card:hover{transform:translateY(-2px);box-shadow:0 15px 45px -10px #6366f11a}@media (width>=640px){.ui-card{border-radius:var(--radius-2xl);padding:var(--space-8)}}.ui-card.glass{-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-sm);background-color:#fffc;border:1px solid #ffffff80}.ui-card.flat{border:1px solid var(--color-border);box-shadow:none}.ui-card.no-padding{padding:0!important}.ui-button{border-radius:var(--radius-pill);cursor:pointer;border:none;outline:none;justify-content:center;align-items:center;font-weight:500;transition:all .2s;display:inline-flex}.ui-button:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.ui-button.size-sm{height:36px;padding:0 16px;font-size:14px}.ui-button.size-md{height:44px;padding:0 24px;font-size:16px}.ui-button.size-lg{height:56px;padding:0 32px;font-size:18px}.ui-button.full-width{width:100%}.ui-button.primary{background:var(--color-primary-gradient);color:#fff;box-shadow:0 8px 16px -4px #6366f14d}.ui-button.primary:hover{background:var(--color-primary-gradient-hover);transform:translateY(-1px);box-shadow:0 12px 24px -4px #6366f166}.ui-button.primary:active{transform:scale(.98)}.ui-button.secondary{background-color:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.ui-button.secondary:hover{background-color:var(--color-surface-hover)}.ui-button.danger{color:#fff;box-shadow:var(--shadow-md);background:linear-gradient(135deg,#d94f4f 0%,#c44040 100%)}.ui-button.danger:hover{box-shadow:var(--shadow-lg);background:linear-gradient(135deg,#c43c3c 0%,#b33535 100%)}.ui-button.danger:active{transform:scale(.98)}.ui-button.ghost{color:var(--color-text-muted);background-color:#0000}.ui-button.ghost:hover{background-color:var(--color-bg);color:var(--color-text)}.ui-badge{border-radius:var(--radius-pill);white-space:nowrap;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.ui-badge.success{background-color:var(--color-success-light);color:var(--color-success-text)}.ui-badge.danger{background-color:var(--color-danger-light);color:var(--color-danger-text)}.ui-badge.warning{background-color:var(--color-warning-light);color:var(--color-warning-text)}.ui-badge.info{background-color:var(--color-primary-light);color:var(--color-primary)}.ui-badge.neutral{background-color:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.ui-input{width:100%;color:var(--color-text);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);outline:none;font-size:1rem;transition:all .2s;display:block}.ui-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px var(--color-primary-light);background-color:#fff}.ui-input::placeholder{color:var(--color-text-light)}.ui-input-wrap{width:100%;position:relative}.ui-input-icon{color:var(--color-text-light);pointer-events:none;display:flex;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.ui-input-with-icon{padding-left:40px!important}.ui-input-error{border-color:var(--color-danger)!important}.ui-input-error:focus{box-shadow:0 0 0 4px var(--color-danger-light)!important}.app-layout{background-color:var(--color-bg);min-width:320px;min-height:100vh;display:flex}.app-sidebar{width:var(--sidebar-width);background-color:var(--color-surface);border-right:1px solid var(--color-border);z-index:40;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:2px 0 16px #6366f10a}.app-main-wrapper{min-width:0;margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;transition:margin-left .3s;display:flex;overflow-x:hidden}@media (width<=1023px){.app-sidebar{transform:translate(-100%)}.app-sidebar.open{transform:translate(0)}.app-main-wrapper{margin-left:0}}.app-overlay{-webkit-backdrop-filter:blur(4px);z-index:30;opacity:0;visibility:hidden;background-color:#0f172a66;transition:all .3s;position:fixed;inset:0}.app-overlay.open{opacity:1;visibility:visible}.app-header{height:var(--header-height);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);z-index:20;background-color:#fffc;justify-content:space-between;align-items:center;padding:0 2rem;display:flex;position:sticky;top:0}@media (width<=639px){.app-header{padding:0 1rem}.app-main-content{padding:1rem .5rem 3rem!important}}.app-main-content{flex:1;width:100%;min-width:0;max-width:1400px;margin:0 auto;padding:2rem 2.5rem 4rem}.d-flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.w-full{width:100%}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-0{margin-bottom:0!important}.mb-6{margin-bottom:24px}.text-muted{color:var(--color-text-muted)}.select-none{-webkit-user-select:none;user-select:none}.page-fade-in,.worker-holiday-page{animation:.35s ease-out fadeInUp}.tc-search-row{flex-wrap:wrap;align-items:flex-end;gap:16px;display:flex}.tc-field{flex-direction:column;gap:6px;display:flex}.tc-field-label{color:var(--color-text-muted);letter-spacing:.02em;font-size:12px;font-weight:600}.tc-date-input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);height:44px;color:var(--color-text);outline:none;min-width:160px;padding:0 16px;font-size:15px;transition:all .2s}.tc-date-input:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 4px #6366f126}.tc-select-input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);height:44px;color:var(--color-text);cursor:pointer;outline:none;min-width:200px;padding:0 16px;font-size:15px;transition:all .2s}.tc-select-input:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 4px #6366f126}.tc-separator{color:var(--color-text-light);-webkit-user-select:none;user-select:none;padding-bottom:10px;font-size:16px}.tc-search-btn-wrap{gap:12px;margin-left:auto;display:flex}.tc-summary-grid{gap:var(--space-5);margin-bottom:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.tc-summary-card{transition:transform .25s,box-shadow .25s!important}.tc-summary-card:hover{transform:translateY(-3px)!important;box-shadow:0 16px 48px -10px #6366f11f!important}.tc-summary-inner{align-items:center;gap:var(--space-3);display:flex}.tc-stat-label{font-size:var(--text-xs);color:var(--color-text-light);letter-spacing:.06em;text-transform:uppercase;margin-bottom:2px;font-weight:600;display:block}.tc-stat-value{font-family:var(--font-heading);font-size:var(--text-xl);color:var(--color-heading);letter-spacing:-.02em;font-weight:700;line-height:1.1}.tc-stat-unit{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-muted);margin-left:2px;font-weight:500}.tc-section-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-5);display:flex}.tc-section-icon{border-radius:var(--radius-sm);background:var(--color-primary-light);width:32px;height:32px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.tc-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.tc-table{border-collapse:collapse;width:100%;font-size:14px}.tc-table thead th{text-align:left;color:var(--color-text-light);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border-bottom:1px solid var(--color-border);background:var(--color-bg);padding:12px 16px;font-size:11px;font-weight:600}.tc-table tbody tr{transition:background-color .15s}.tc-table tbody tr:hover{background-color:#6366f108}.tc-table tbody td{white-space:nowrap;color:var(--color-text-muted);vertical-align:middle;border-bottom:1px solid #e2e8f080;padding:12px 16px}.tc-table tbody tr:last-child td{border-bottom:none}.tc-th-center{text-align:center!important}.tc-th-right{text-align:right!important}.tc-td-center{text-align:center!important}.tc-td-right{text-align:right!important}.tc-paper-list{background:#f3f4f6;flex-wrap:wrap;justify-content:flex-start;gap:28px;padding:24px;display:flex}.tc-paper-card{color:#0f172a;background:#fff;border:1px solid #cbd5e1;width:380px;font-family:Hiragino Mincho ProN,Yu Mincho,MS Mincho,serif;position:relative;overflow:hidden;box-shadow:0 12px 32px -12px #0f172a40,0 4px 10px -4px #0f172a1f}.tc-paper-card:before{content:"";background:linear-gradient(#4a7fb8 0%,#6ea0d4 100%);border-bottom:1px solid #2f5e96;height:18px;display:block}.tc-paper-header{background:#fff;border-bottom:1px solid #d1d5db;align-items:baseline;gap:16px;padding:14px 18px 8px;font-size:14px;display:flex}.tc-paper-header .tc-paper-no{letter-spacing:.05em;color:#1e3a5f;font-size:15px;font-weight:700}.tc-paper-header .tc-paper-name-label{color:#475569;margin-right:2px;font-size:12px}.tc-paper-header .tc-paper-name{letter-spacing:.08em;color:#0f172a;font-size:18px;font-weight:700}.tc-paper-shozoku{color:#1e3a5f;letter-spacing:.4em;background:#cfe1f3;border-bottom:1px solid #9bbcde;padding:6px 18px;font-size:12px}.tc-paper-title-block{text-align:right;background:#fff;padding:10px 18px 4px}.tc-paper-title-jp{color:#2f5e96;letter-spacing:.08em;font-size:22px;font-weight:700;line-height:1.1}.tc-paper-title-en{color:#4a7fb8;letter-spacing:.18em;margin-top:2px;font-size:11px}.tc-paper-month{color:#1e3a5f;letter-spacing:.05em;margin-top:6px;font-size:14px;font-weight:700}.tc-paper-table{border-collapse:collapse;color:#0f172a;table-layout:fixed;width:100%;font-family:Courier New,Menlo,Consolas,MS Gothic,monospace;font-size:12px}.tc-paper-table th,.tc-paper-table td{text-align:center;vertical-align:middle;white-space:nowrap;border:1px solid #9bbcde;padding:4px}.tc-paper-table thead th{color:#fff;letter-spacing:.05em;background:#2f5e96;border-color:#1e3a5f;padding:6px 2px;font-family:Hiragino Mincho ProN,Yu Mincho,MS Mincho,serif;font-size:11px;font-weight:700}.tc-paper-table tbody td{background:#fff;height:22px}.tc-paper-col-date{width:12%}.tc-paper-col-sched,.tc-paper-col-in,.tc-paper-col-out,.tc-paper-col-sched2{width:14%}.tc-paper-col-ot,.tc-paper-col-sub{width:16%}.tc-paper-day-cell{color:#1e3a5f;text-align:left;padding-left:6px;font-weight:700}.tc-paper-day-num{text-align:right;min-width:18px;margin-right:2px;display:inline-block}.tc-paper-day-dow{color:#4a7fb8;font-size:10px}.tc-paper-stamp{color:#1e3a5f;letter-spacing:.02em;font-family:Courier New,Menlo,monospace;font-weight:700}.tc-paper-remarks-row{background:#f8fafc}.tc-paper-remarks-row td{color:#475569;text-align:left;border-top:2px solid #2f5e96;padding:4px 6px;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:11px}.tc-paper-empty{text-align:center;color:#64748b;padding:24px;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:13px}.tc-paper-holiday td{background:#fff7ed}.tc-paper-absent td{color:#991b1b;background:#fef2f2}.tc-paper-leave td{color:#065f46;background:#ecfdf5}.tc-paper-card:after{content:"";background:#fff;border-top:1px solid #cbd5e1;height:14px;display:block;position:relative}@media (width<=1023px){.tc-paper-list{justify-content:center;gap:20px;padding:16px}}@media (width<=639px){.tc-paper-card{width:100%}.tc-paper-list{gap:16px;padding:12px}}.paper-tc-wrapper{flex-direction:column;align-items:center;gap:12px;display:flex}.paper-tc-toggle{border-radius:var(--radius-md,8px);background:#fff;border:1px solid #cbd5e1;display:inline-flex;overflow:hidden;box-shadow:0 1px 3px #0f172a14}.paper-tc-toggle-btn{appearance:none;color:#475569;cursor:pointer;letter-spacing:.04em;background:0 0;border:none;padding:8px 18px;font-family:inherit;font-size:12px;font-weight:600;transition:background .15s,color .15s}.paper-tc-toggle-btn:hover{background:#f1f5f9}.paper-tc-toggle-btn.is-active{color:#fff;background:#1e3a5f}.paper-tc-toggle-btn+.paper-tc-toggle-btn{border-left:1px solid #cbd5e1}.paper-tc-flip{width:380px;max-width:100%}.paper-tc-card{border:1px solid var(--paper-tc-border,#cbd5e1);color:#0f172a;clip-path:polygon(0 28px,28px 0,calc(100% - 28px) 0,100% 28px,100% 100%,0 100%);background:#fcfcfc;flex-direction:column;height:100%;font-family:Hiragino Mincho ProN,Yu Mincho,MS Mincho,serif;display:flex;position:relative;box-shadow:0 12px 32px -12px #0f172a40,0 4px 10px -4px #0f172a1f}.paper-tc-card--front{--paper-tc-color:#2f5e96;--paper-tc-color-light:#cfe1f3;--paper-tc-color-mid:#9bbcde;--paper-tc-band-from:#4a7fb8;--paper-tc-band-to:#6ea0d4;--paper-tc-border:#9bbcde}.paper-tc-card--back{--paper-tc-color:#b04a52;--paper-tc-color-light:#fbe1e2;--paper-tc-color-mid:#e2a4a8;--paper-tc-band-from:#d97373;--paper-tc-band-to:#e6a09e;--paper-tc-border:#e2a4a8}.paper-tc-band{background:linear-gradient(180deg, var(--paper-tc-band-from) 0%, var(--paper-tc-band-to) 100%);border-bottom:1px solid var(--paper-tc-color);height:22px}.paper-tc-header{background:#fff;align-items:baseline;gap:16px;padding:12px 18px 8px;font-size:14px;display:flex}.paper-tc-header--back{border-bottom:none}.paper-tc-no{letter-spacing:.05em;color:var(--paper-tc-color);font-family:Courier New,Menlo,monospace;font-size:15px;font-weight:700}.paper-tc-name-label{color:#475569;margin-right:6px;font-size:12px}.paper-tc-name{letter-spacing:.08em;color:#0f172a;font-size:18px;font-weight:700}.paper-tc-header-name-block{align-items:baseline;display:inline-flex}.paper-tc-shozoku{background:var(--paper-tc-color-light);color:var(--paper-tc-color);letter-spacing:.4em;border-top:1px solid var(--paper-tc-color-mid);border-bottom:1px solid var(--paper-tc-color-mid);justify-content:space-between;align-items:center;padding:6px 18px;font-size:12px;display:flex}.paper-tc-inkan-row{letter-spacing:normal;gap:4px;display:inline-flex}.paper-tc-inkan-cell{border:1px solid var(--paper-tc-color-mid);width:42px;height:20px;color:var(--paper-tc-color);letter-spacing:.05em;background:#fff;justify-content:center;align-items:center;font-family:Hiragino Mincho ProN,serif;font-size:9px;display:inline-flex}.paper-tc-title-block{text-align:right;background:#fff;padding:40px 18px 36px}.paper-tc-title-jp{color:var(--paper-tc-color);letter-spacing:.18em;font-size:30px;font-weight:700;line-height:1.15}.paper-tc-title-en{color:var(--paper-tc-color);letter-spacing:.22em;opacity:.75;margin-top:4px;font-size:12px}.paper-tc-month{color:var(--paper-tc-color);letter-spacing:.08em;margin-top:16px;font-size:15px;font-weight:700}.paper-tc-period{color:var(--paper-tc-color);opacity:.65;letter-spacing:.02em;margin-top:2px;font-size:11px;font-weight:400}.paper-tc-table{border-collapse:collapse;color:#0f172a;table-layout:fixed;width:100%;font-family:monospace,Courier New,Courier,MS Gothic;font-size:12px}.paper-tc-table th,.paper-tc-table td{border:1px solid var(--paper-tc-color-mid);text-align:center;vertical-align:middle;white-space:nowrap;padding:4px}.paper-tc-table thead th{background:var(--paper-tc-color);color:#fff;letter-spacing:.05em;border-color:var(--paper-tc-color);padding:6px 2px;font-family:Hiragino Mincho ProN,Yu Mincho,MS Mincho,serif;font-size:11px;font-weight:700}.paper-tc-table tbody td{background:#fcfcfc;height:20px}.paper-tc-col-date,.paper-tc-col-sub{width:10%}.paper-tc-col-sched,.paper-tc-col-in,.paper-tc-col-out,.paper-tc-col-sched2,.paper-tc-col-ot,.paper-tc-col-remarks{width:13.33%}.paper-tc-remarks{color:var(--paper-tc-color);text-align:center;letter-spacing:.02em;text-overflow:ellipsis;white-space:nowrap;max-width:0;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:11px;overflow:hidden}.paper-tc-day-cell{color:var(--paper-tc-color);text-align:center;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-weight:700}.paper-tc-stamp{color:var(--paper-tc-color);letter-spacing:.05em;text-align:center;font-family:monospace,Courier New,Courier;font-size:11px;font-weight:700}.paper-tc-summary-grid{border-collapse:collapse;table-layout:fixed;width:100%;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:9px}.paper-tc-summary-bottom{margin-top:auto}.paper-tc-summary-grid th,.paper-tc-summary-grid td{border:1px solid var(--paper-tc-color-mid);text-align:center;vertical-align:middle;height:18px;color:var(--paper-tc-color);background:#fff;padding:2px 3px}.paper-tc-summary-label{letter-spacing:.05em;text-align:center;background:#fff;width:11%;font-weight:600}.paper-tc-cell-val{background:#fff;width:12%}.paper-tc-cell-unit{width:6%;color:var(--paper-tc-color);text-align:center;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:8px;line-height:1.1;display:table-cell}.paper-tc-vertical-th{writing-mode:vertical-rl;-webkit-writing-mode:vertical-rl;letter-spacing:.4em;background:var(--paper-tc-color-light);width:16px;color:var(--paper-tc-color);font-size:10px;font-weight:700}.paper-tc-footer{color:var(--paper-tc-color);background:#fff;justify-content:space-between;padding:4px 14px;font-size:9px;display:flex}.paper-tc-footer-left{letter-spacing:.05em;font-family:Courier New,monospace}.paper-tc-footer-right{letter-spacing:.05em;font-family:Hiragino Mincho ProN,serif}.paper-tc-notch{border-top:1px solid var(--paper-tc-color-mid);background:#fff;height:14px;margin-top:auto;position:relative}.paper-tc-notch:after{content:"";border:1px solid var(--paper-tc-color-mid);background:#f3f4f6;border-top:none;border-radius:0 0 6px 6px;width:30px;height:8px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.paper-tc-spread{flex-flow:row;justify-content:center;align-items:stretch;gap:16px;width:100%;display:flex}.paper-tc-side{display:block}@media (width<=639px){.paper-tc-flip{width:100%;max-width:380px}}@media (width<=899px){.paper-tc-spread{flex-wrap:wrap}.paper-tc-side{display:none}.paper-tc-side.is-active{display:block}}@media (width>=900px){.paper-tc-toggle{display:none}}.tc-paper-group{flex-direction:column;align-items:center;gap:8px;display:flex}.tc-paper-group+.tc-paper-group{margin-top:32px}.tc-print-action{justify-content:flex-end;width:100%;max-width:800px;margin-bottom:4px;display:flex}.tc-list-toolbar{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;margin-bottom:20px;padding:12px 20px;display:flex;box-shadow:0 1px 3px #0000000a}.tc-list-toolbar__title{color:var(--color-text);letter-spacing:-.01em;align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.printable-tc-page{display:none}@media print{@page{size:A4 portrait;margin:10mm}html,body{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#fff!important;margin:0!important;padding:0!important}.page-fade-in>:not(.printable-tc-page),.no-print,.app-header,.app-sidebar{display:none!important}.app-layout,.app-main-wrapper,.app-main-content,.page-fade-in{background:#fff!important;width:100%!important;max-width:none!important;min-height:0!important;margin:0!important;padding:0!important;overflow:visible!important}.printable-tc-page{break-inside:avoid;page-break-inside:avoid;justify-content:center;align-items:flex-start;width:100%;padding-top:15mm;background:#fff!important;display:flex!important}.printable-tc-page+.printable-tc-page{break-before:page;page-break-before:always}.printable-tc-pair{transform-origin:top;width:max-content;transform:scale(.92);flex-flow:row!important;justify-content:center!important;align-items:stretch!important;gap:6mm!important;display:flex!important}.printable-tc-side{break-inside:avoid;page-break-inside:avoid;flex:0 0 380px;width:380px;flex-direction:column!important;display:flex!important}.printable-tc-page .paper-tc-card{box-shadow:none!important}}.sc-sort-btn{font:inherit;color:var(--color-text-light);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;white-space:nowrap;background:0 0;border:none;align-items:center;gap:4px;padding:0;font-size:11px;font-weight:600;transition:color .15s;display:inline-flex}.sc-sort-btn:hover{color:var(--color-text)}.sc-sort-btn.sc-sort-active{color:var(--color-primary)}.tc-calendar-wrapper{align-items:flex-start;gap:24px;display:flex}.tc-detail-panel{flex:0 0 360px}.tc-calendar-cell{min-height:100px}@media (width<=1023px){.tc-summary-grid{grid-template-columns:repeat(2,1fr);gap:16px}.tc-calendar-wrapper{flex-direction:column}.tc-detail-panel{flex:none;width:100%}}@media (width<=639px){.tc-search-row{flex-direction:column;align-items:stretch;gap:12px}.tc-separator{display:none}.tc-date-input,.tc-select-input{width:100%}.tc-search-btn-wrap{flex-direction:column;width:100%;margin-top:4px;margin-left:0}.tc-search-btn-wrap .ui-button{width:100%}.tc-summary-grid{grid-template-columns:1fr;gap:12px}.tc-list-toolbar{flex-direction:column;gap:12px;padding:12px 16px}.tc-calendar-cell{min-height:70px}.tc-table thead th,.tc-table tbody td{padding:10px 12px;font-size:13px}}.admin-page{animation:.35s ease-out fadeInUp}.admin-page-title{color:var(--color-heading);letter-spacing:-.02em;margin-bottom:2rem;font-size:1.75rem;font-weight:700}.admin-actions{flex-wrap:wrap;gap:12px;margin-bottom:24px;display:flex}.ui-button.success{color:#fff;background:linear-gradient(135deg,#059669 0%,#10b981 100%);box-shadow:0 8px 16px -4px #0596694d}.ui-button.success:hover{background:linear-gradient(135deg,#047857 0%,#059669 100%);transform:translateY(-1px);box-shadow:0 12px 24px -4px #05966966}.ui-button.success:active{transform:scale(.98)}.ui-button.info{background-color:var(--color-primary-light);color:var(--color-primary)}.ui-button.info:hover{color:var(--color-primary-hover);background-color:#ddd6fe}.ui-button.danger-light{background-color:var(--color-danger-light);color:var(--color-danger-text)}.ui-button.danger-light:hover{background-color:var(--color-danger-border);color:var(--color-danger-hover)}.admin-msg{border-radius:var(--radius-md);margin-bottom:16px;padding:12px 16px;font-size:.875rem;font-weight:500;animation:.25s ease-out fadeInUp}.admin-msg.error{background:var(--color-danger-light);color:var(--color-danger-text);border:1px solid var(--color-danger-border)}.admin-msg.success{background:var(--color-success-light);color:var(--color-success-text);border:1px solid var(--color-success-border)}.loading-indicator{border-radius:var(--radius-lg);background:var(--color-primary-light);color:var(--color-primary);align-items:center;gap:10px;margin-bottom:24px;padding:16px 20px;font-size:.875rem;font-weight:500;animation:.25s ease-out fadeInUp;display:flex}.loading-spinner{flex-shrink:0;width:18px;height:18px;animation:1s linear infinite spin}.loading-bar{border-radius:var(--radius-pill);background:linear-gradient(90deg, transparent 0%, var(--color-primary) 50%, transparent 100%);background-size:200% 100%;height:3px;margin-bottom:24px;animation:1.2s ease-in-out infinite loadingSlide}@keyframes loadingSlide{0%{background-position:100% 0}to{background-position:-100% 0}}.admin-table-section{background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-card);border:1px solid #e2e8f099;margin-bottom:40px;padding:24px;overflow:hidden}.admin-table-section:last-of-type{margin-bottom:0}.admin-section-title{color:var(--color-text);align-items:center;gap:10px;margin-bottom:20px;font-size:1rem;font-weight:600;display:flex}.admin-section-icon-box{border-radius:var(--radius-sm);background:var(--color-primary-light);width:32px;height:32px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.admin-filter-bar{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;display:flex}.admin-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.875rem}.admin-table thead th{text-align:left;color:var(--color-text-light);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border-bottom:2px solid var(--color-border);background:var(--color-bg);padding:12px 16px;font-size:.6875rem;font-weight:600}.admin-table tbody tr{transition:background-color .15s}.admin-table tbody tr:hover{background-color:#6366f108}.admin-table tbody td{white-space:nowrap;vertical-align:middle;border-bottom:1px solid #e2e8f080;padding:10px 16px}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table .td-right{text-align:right!important}.admin-table .td-center{text-align:center!important}.admin-table .td-bold{font-weight:700}.admin-table .td-actions{gap:8px;display:flex}.admin-table .td-empty{text-align:center;color:var(--color-text-muted);padding:32px 16px}.admin-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#0f172a80;justify-content:center;align-items:center;animation:.2s ease-out fadeInUp;display:flex;position:fixed;inset:0}.admin-modal{background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid #e2e8f099;width:90%;max-width:720px;max-height:85vh;padding:32px;animation:.3s ease-out fadeInUp;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040}.admin-modal-title{color:var(--color-text);margin-bottom:24px;font-size:1.125rem;font-weight:700}.admin-form-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.admin-form-label{color:var(--color-text-muted);flex-direction:column;gap:6px;font-size:.8125rem;font-weight:600;display:flex}.admin-form-label .required{color:var(--color-danger)}.admin-modal-actions{justify-content:flex-end;gap:12px;display:flex}@media (width<=639px){.admin-page-title{font-size:1.375rem}.admin-actions{flex-direction:column}.admin-actions .ui-button{width:100%}.admin-table-section{border-radius:var(--radius-xl);margin-bottom:28px;padding:16px}.admin-table thead th,.admin-table tbody td{padding:8px 12px;font-size:13px}.admin-modal{width:95%;padding:24px 20px}.admin-form-grid{grid-template-columns:1fr}}.admin-tabs{border-bottom:2px solid var(--color-border);gap:0;margin-bottom:24px;display:flex}.admin-tab{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:8px;margin-bottom:-2px;padding:12px 24px;font-size:.9375rem;font-weight:600;transition:all .2s;display:flex}.admin-tab:hover{color:var(--color-primary);background-color:#6366f108}.admin-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}@media (width<=639px){.admin-tab{padding:10px 16px;font-size:.8125rem}}.slip-detail-modal{background:var(--color-surface);border-radius:var(--radius-2xl);border:1px solid #e2e8f099;width:90%;max-width:800px;max-height:90vh;padding:0;animation:.3s ease-out fadeInUp;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040}.slip-detail-header{border-bottom:2px solid var(--color-primary);justify-content:space-between;align-items:center;padding:24px 32px 16px;display:flex}.slip-detail-title{color:var(--color-text);letter-spacing:-.01em;font-size:1.25rem;font-weight:700}.slip-detail-close{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);width:36px;height:36px;color:var(--color-text-muted);cursor:pointer;justify-content:center;align-items:center;transition:all .2s;display:flex}.slip-detail-close:hover{background:var(--color-bg);color:var(--color-text)}.slip-detail-meta{background:var(--color-bg);border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:24px;padding:16px 32px;display:flex}.slip-detail-meta-item{color:var(--color-text);flex-direction:column;gap:2px;font-size:14px;display:flex}.slip-detail-meta-label{color:var(--color-text-light);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:600}.slip-detail-body{padding:24px 32px 32px}.slip-detail-section{margin-bottom:24px}.slip-detail-section:last-child{margin-bottom:0}.slip-detail-section-title{color:var(--color-primary);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--color-border);margin-bottom:8px;padding-bottom:8px;font-size:13px;font-weight:700}.slip-detail-grid{grid-template-columns:repeat(2,1fr);gap:0;display:grid}.slip-detail-row{border-bottom:1px solid #e2e8f066;justify-content:space-between;align-items:center;padding:6px 12px;font-size:14px;display:flex}.slip-detail-row:nth-child(odd){background:#f8fafc80}.slip-detail-row-total{grid-column:1/-1;font-weight:600;background:var(--color-primary-light)!important;border-bottom:2px solid var(--color-primary)!important}.slip-detail-label{color:var(--color-text-muted);font-size:13px}.slip-detail-value{color:var(--color-text);text-align:right;font-variant-numeric:tabular-nums;font-weight:600}.slip-detail-value-accent{color:var(--color-primary);font-weight:700}.slip-detail-value-danger{color:var(--color-danger-text);font-weight:700}.slip-pagination{border-top:1px solid var(--color-border);justify-content:center;align-items:center;gap:8px;padding:16px 24px;display:flex}.slip-pagination-pages{gap:4px;display:flex}.slip-pagination-page{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;justify-content:center;align-items:center;font-size:13px;font-weight:500;transition:all .2s;display:flex}.slip-pagination-page:hover{background:var(--color-bg);color:var(--color-text)}.slip-pagination-page.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}@media (width<=639px){.slip-detail-modal{width:95%;max-height:95vh}.slip-detail-header{padding:16px 20px 12px}.slip-detail-meta{gap:16px;padding:12px 20px}.slip-detail-body{padding:16px 20px 24px}.slip-detail-grid{grid-template-columns:1fr}.slip-pagination{padding:12px 16px}}@media (width<=767px){.tc-table-wrapper,.admin-table-wrap{-webkit-overflow-scrolling:touch;width:100%;margin-bottom:0;overflow-x:auto}.tc-table,.admin-table{white-space:nowrap;min-width:max-content}.tc-table th:first-child,.tc-table td:first-child,.admin-table th:first-child,.admin-table td:first-child{z-index:10;background-color:var(--color-surface);position:sticky;left:0}.tc-table th:first-child:after,.tc-table td:first-child:after,.admin-table th:first-child:after,.admin-table td:first-child:after{content:"";pointer-events:none;background:linear-gradient(90deg,#0000000d,#0000);width:4px;position:absolute;top:0;bottom:0;right:0;transform:translate(100%)}.tc-search-row,.d-flex{flex-wrap:wrap}}.iwd-mobile-cards{display:none}.iwd-desktop-table{display:block}.iwd-detail-grid{flex-direction:column;gap:8px;display:flex}.iwd-detail-item{justify-content:space-between;align-items:center;display:flex}.iwd-detail-label{color:var(--color-text-muted);font-size:13px}.iwd-detail-value{color:var(--color-text);font-variant-numeric:tabular-nums;font-size:14px}@media (width<=768px){.iwd-desktop-table{display:none}.iwd-mobile-cards{display:block}}.ac-print-only{display:none}@media print{.app-sidebar,.app-header{display:none!important}.app-main-wrapper,.app-main-content{margin:0!important;padding:0!important}.ac-screen-only{display:none!important}.ac-print-only{display:block!important}.pac-wrapper{width:100%;margin:0;padding:0;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important}.pac-header{flex-direction:row;justify-content:center;align-items:baseline;margin-bottom:4mm;display:flex;position:relative}.pac-title{color:#000;text-align:center;letter-spacing:.5pt;font-size:14pt;font-weight:700}.pac-company{color:#000;font-size:10pt;font-weight:600;position:absolute;right:0}.pac-columns{gap:0;width:100%;display:flex}.pac-column{flex-direction:column;flex:1;min-width:0;display:flex}.pac-table{border-collapse:collapse;table-layout:fixed;page-break-inside:avoid;border:2px solid #000;width:100%}.pac-column:first-child .pac-table,.pac-column:first-child .pac-th:last-child,.pac-column:first-child .pac-td-count-work{border-right:none}.pac-th{text-align:center;color:#333;vertical-align:middle;white-space:nowrap;background:#f0f0f0;border:2px solid #000;border-left:1px solid #999;border-right:1px solid #999;padding:2px;font-size:8.5pt;font-weight:600}.pac-th.pac-sun{color:#c00}.pac-th.pac-sat{color:#05c}.pac-th-month{border-left:2px solid #000;width:9.5%}.pac-th-day{width:9.5%}.pac-th-summary{white-space:nowrap;letter-spacing:-.2px;font-size:6pt;line-height:1.15}.pac-th-summary-holiday{color:#c00;width:12%}.pac-th-summary-work{width:12%}.pac-td{text-align:center;vertical-align:middle;color:#000;border:.5pt solid #ccc;height:6.8mm;padding:2px;font-size:9pt}.pac-td-empty{background:#fff}.pac-td-holiday{font-weight:700;color:#fff!important;background:#ef4444!important}.pac-td.pac-sun{color:#c00}.pac-td.pac-sat{color:#05c}.pac-asterisk{color:#aaa;font-size:5pt}.pac-month-first-row>td{border-top:1.5pt solid #000}.pac-td-month{background:#f5f5f5;border-left:2px solid #000;border-right:1.5pt solid #000;padding:0;font-size:8pt;font-weight:700;line-height:1}.pac-month-num{font-size:10pt;font-weight:700;display:block}.pac-month-unit{margin-top:1px;font-size:6.5pt;font-weight:400;display:block}.pac-td-count{white-space:nowrap;letter-spacing:-.2px;background:#fafafa;border-left:1.5pt solid #000;font-size:9pt;font-weight:700}.pac-td-count-holiday{color:#c00}.pac-td-count-work{color:#000;border-right:2px solid #000}.pac-footer-row>td{border-top:2px solid #000!important}.pac-footer-row .pac-td-footer{white-space:nowrap;background:#e8e8e8;border:2px solid #000;border-left:1px solid #999;border-right:1px solid #999;padding:2px 4px;font-size:9pt;font-weight:700}.pac-td-footer-holiday{color:#c00;text-align:center;font-size:9pt;font-weight:700}.pac-td-footer-work{color:#000;text-align:center;font-size:9pt;font-weight:700}.pac-note{color:#333;white-space:pre-wrap;margin-top:2px;font-size:6.5pt;line-height:1.3}.pac-note-left{text-align:left}}.leave-section-label{color:var(--color-text-muted);letter-spacing:.1em;text-transform:uppercase;margin-top:8px;margin-bottom:12px;font-size:11px;font-weight:700}.leave-alert.ui-card{margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:500}.leave-alert--error.ui-card{background:var(--color-danger-light,#fef2f2);color:#b91c1c;border-color:var(--color-danger-border)}.leave-alert--success.ui-card{background:var(--color-success-light,#f0fdf4);color:#166534;border-color:var(--color-success-border)}.leave-form-card.ui-card{margin-bottom:2rem}.leave-form-grid{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.leave-form-memo{grid-column:1/-1}.leave-history-card.ui-card{overflow:hidden}.leave-history-table{border-collapse:collapse;width:100%;font-size:.875rem}.leave-history-table thead th{text-align:left;color:var(--color-text-muted);border-bottom:2px solid var(--color-border);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;background:#f8f9fb;padding:.875rem 1rem;font-size:.75rem;font-weight:600}.leave-history-table tbody td{border-bottom:1px solid var(--color-border);white-space:nowrap;padding:.875rem 1rem}.leave-history-table tbody tr.even{background:var(--color-bg)}@media (hover:hover){.leave-history-table tbody tr:hover{background:#6366f10a}}@media (width<=639px){.leave-form-grid{grid-template-columns:1fr}}.text-2xs{font-size:var(--text-2xs)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-md{font-size:var(--text-md)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.color-secondary{color:var(--color-text-secondary)}.color-muted{color:var(--color-text-muted)}.color-light{color:var(--color-text-light)}.color-primary{color:var(--color-primary)}.color-danger{color:var(--color-danger)}.color-success{color:var(--color-success)}.tracking-tight{letter-spacing:-.02em}.tracking-wide{letter-spacing:.04em}.tracking-wider{letter-spacing:.1em}.page-header{margin-bottom:var(--space-8)}.page-header__title{color:var(--color-heading);letter-spacing:-.02em;font-size:1.75rem;font-weight:700}.page-header__subtitle{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.5}.heading-1{font-family:var(--font-heading);font-weight:700;font-size:var(--text-xl);letter-spacing:-.02em;color:var(--color-heading);margin:0;line-height:1.2}.heading-2{font-family:var(--font-heading);font-weight:700;font-size:var(--text-lg);letter-spacing:-.01em;color:var(--color-heading);margin:0;line-height:1.3}.heading-3{font-family:var(--font-body);font-weight:600;font-size:var(--text-md);letter-spacing:-.01em;color:var(--color-heading);margin:0;line-height:1.4}.section-label{font-size:var(--text-xs);color:var(--color-text-light);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-5);padding-left:var(--space-1);font-weight:700}.card-grid{gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.form-fieldset{border-radius:var(--radius-xl);box-shadow:var(--shadow-card);background:var(--color-surface);border:none;margin-bottom:2rem;padding:2rem}.form-fieldset__legend{color:var(--color-text);padding:0 .5rem;font-size:.875rem;font-weight:600}.form-row{flex-wrap:wrap;gap:1rem;margin-bottom:.75rem;display:flex}.form-label{font-size:var(--text-sm);color:var(--color-text);flex-direction:column;flex:1;gap:.25rem;min-width:140px;font-weight:500;display:flex}.alert{border-radius:var(--radius-sm);margin-bottom:1.25rem;padding:.875rem 1rem;font-size:.875rem}.alert--success{background:var(--color-success-light);border:1px solid var(--color-success-border);color:var(--color-success-text)}.alert--error{background:var(--color-danger-light);border:1px solid var(--color-danger-border);color:var(--color-danger-text)}.alert--warning{background:var(--color-warning-light);border:1px solid var(--color-warning-border);color:var(--color-warning-text)}.logo-mark{border-radius:var(--radius-md);background:var(--color-primary-gradient);color:#fff;width:38px;height:38px;font-weight:700;font-size:var(--text-md);flex-shrink:0;justify-content:center;align-items:center;display:flex}.logo-mark--lg{border-radius:var(--radius-xl);width:64px;height:64px;box-shadow:var(--shadow-glow);font-size:var(--text-xl);font-weight:800}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-backdrop);border-radius:var(--radius-2xl);box-shadow:var(--shadow-elevated);border:1px solid var(--glass-border)}.stat-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.stat-icon--primary{background:var(--color-primary-gradient);color:#fff;box-shadow:var(--shadow-primary-lg)}.stat-icon--success{background:var(--color-success-gradient);color:#fff}.stat-icon--outline{background:var(--color-bg);color:var(--color-primary);border:1px solid var(--color-border)}.stat-icon--sm{border-radius:var(--radius-md);width:40px;height:40px}.stat-icon--md{border-radius:var(--radius-md);width:44px;height:44px}.stat-icon--danger{color:#fff;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%)}.stat-icon--warning{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%)}.stat-icon--info{background:var(--color-primary-light);color:var(--color-primary)}.stat-icon--teal{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0d9488 100%)}.stat-icon--slate{color:#fff;background:linear-gradient(135deg,#94a3b8 0%,#64748b 100%)}.login-page{background:var(--bg-gradient-subtle);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{text-align:center;width:100%;max-width:420px;padding:3rem 2.5rem;animation:.4s ease-out fadeInUp}.login-card__logo-area{margin-bottom:0}.login-card__subtitle{color:var(--color-text-muted);margin-bottom:var(--brand-gap-lg);font-size:12px;line-height:1.5}.login-btn{border-radius:var(--radius-pill);cursor:pointer;border:none;justify-content:center;align-items:center;width:100%;height:48px;font-size:.9375rem;font-weight:600;transition:transform .15s,box-shadow .15s;display:flex}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-btn:not(:disabled):hover{transform:translateY(-1px)}.login-btn:not(:disabled):active{transform:scale(.98)}.login-btn--lw{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);margin-bottom:1rem;box-shadow:0 2px 8px #0000000f}.login-btn--lw:not(:disabled):hover{background:#f8f9fa;box-shadow:0 4px 12px #0000001a}.login-btn--google-primary{background:var(--color-primary-gradient);color:#fff;box-shadow:0 8px 20px -4px #6366f159}.login-btn--google-primary:not(:disabled):hover{box-shadow:0 12px 28px -4px #6366f173}.login-btn--google-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);box-shadow:0 2px 8px #0000000f}.login-btn--google-secondary:not(:disabled):hover{box-shadow:0 8px 20px -4px #0000001f}.login-divider{color:var(--color-text-light);font-size:var(--text-sm);align-items:center;gap:1rem;margin:1rem 0;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.timeclock-time{font-family:var(--font-heading);color:var(--color-heading);letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:56px;font-weight:700;line-height:1}.timeclock-date{font-family:var(--font-heading);font-size:var(--text-lg);color:var(--color-text-muted);font-weight:500}.timeclock-status{border-radius:var(--radius-pill);font-size:var(--text-sm);align-items:center;gap:.5rem;padding:.5rem 1rem;font-weight:600;display:inline-flex}.timeclock-record{align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-bg);border-radius:var(--radius-md);font-size:var(--text-sm);display:flex}.timeclock-record__label{color:var(--color-text-muted);min-width:48px;font-weight:500}.timeclock-record__value{color:var(--color-text);font-variant-numeric:tabular-nums;font-weight:600}.timeclock-location{font-size:var(--text-xs);color:var(--color-text-light);align-items:center;gap:.375rem;display:flex}.dashboard-card{transition:transform .2s,box-shadow .2s,border-color .2s}@media (hover:hover){.dashboard-card:hover{border-color:#6366f133;transform:translateY(-4px);box-shadow:0 20px 50px -10px #6366f11f}}.dashboard-menu-card{cursor:pointer;flex-direction:column;height:100%;display:flex}.dashboard-menu-card__header{margin-bottom:var(--space-5);justify-content:space-between;align-items:flex-start;display:flex}.dashboard-menu-card__sublabel{font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-1);letter-spacing:.04em;font-weight:500}.dashboard-menu-card__label{font-family:var(--font-heading);color:var(--color-heading);margin-bottom:var(--space-2);letter-spacing:-.01em;font-size:17px;font-weight:700}.dashboard-menu-card__desc{font-size:var(--text-sm);color:var(--color-text-light);flex:1;line-height:1.55}.dashboard-admin-entry{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);cursor:pointer;display:flex}.dashboard-admin-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.dashboard-admin-icon--active{background:var(--color-primary-gradient);color:#fff}.dashboard-admin-icon--inactive{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.sidebar-header{height:var(--header-height);padding:0 var(--space-5);align-items:center;gap:var(--space-3);border-bottom:1px solid var(--color-border);flex-shrink:0;display:flex}.sidebar-brand{flex-direction:column;display:flex}.sidebar-brand__name{font-size:var(--text-md);color:var(--color-heading);letter-spacing:-.01em;font-weight:700;line-height:1.2}.sidebar-brand__sub{font-size:var(--text-xs);color:var(--color-text-light);letter-spacing:.04em;margin-top:1px;font-weight:500}.sidebar-nav{padding:var(--space-5) var(--space-3);flex:1;overflow-y:auto}.sidebar-nav__label{font-size:var(--text-2xs);color:var(--color-text-light);letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--space-2);padding-left:var(--space-3);font-weight:700;display:block}.sidebar-nav-item{border-radius:var(--radius-md);font-size:var(--text-base);align-items:center;gap:10px;margin-bottom:2px;padding:9px 12px;text-decoration:none;transition:background-color .18s,color .18s;display:flex}.sidebar-nav-item--default{color:var(--color-text-muted);background-color:#0000;font-weight:400}.sidebar-nav-item--active{color:var(--color-primary);background-color:var(--color-primary-light);font-weight:600}@media (hover:hover){.sidebar-nav-item--default:hover{background-color:var(--color-bg);color:var(--color-text)}}.sidebar-footer{padding:var(--space-3) var(--space-4) var(--space-4);border-top:1px solid var(--color-border);flex-shrink:0}.sidebar-user{padding:10px var(--space-3);border-radius:var(--radius-md);background-color:var(--color-bg);align-items:center;gap:10px;margin-bottom:10px;display:flex}.sidebar-avatar{border-radius:var(--radius-pill);background:var(--color-primary);width:34px;height:34px;color:var(--color-surface);font-weight:700;font-size:var(--text-base);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logout{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius-md);border:1px solid var(--color-border);width:100%;color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;background-color:#0000;outline:none;padding:9px;font-weight:500;transition:background-color .2s,border-color .2s,color .2s;display:flex}@media (hover:hover){.sidebar-logout:hover{background-color:var(--color-danger-light);border-color:var(--color-danger-light);color:var(--color-danger)}}.page-title-bar{align-items:center;gap:var(--space-4);margin-bottom:var(--space-8);display:flex}.page-title-icon{border-radius:var(--radius-md);background:var(--color-primary-light);width:40px;height:40px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.page-title-text h1{font-family:var(--font-heading);color:var(--color-heading);letter-spacing:-.02em;margin:0;font-size:22px;font-weight:700;line-height:1.2}.page-title-text p{color:var(--color-text-muted);font-size:var(--text-sm);letter-spacing:.01em;margin:4px 0 0;font-weight:400}.admin-badge{font-size:var(--text-xs);color:var(--color-primary);background:var(--color-primary-light);padding:var(--space-1) 10px;border-radius:var(--radius-pill);font-weight:600}.sidebar-back{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius-md);border:1px solid var(--color-border);width:100%;color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;background-color:#0000;outline:none;margin-bottom:6px;padding:9px;font-weight:500;transition:background-color .2s,border-color .2s,color .2s;display:flex}@media (hover:hover){.sidebar-back:hover{background-color:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}}.step-indicator{justify-content:center;gap:var(--space-2);margin-bottom:var(--space-6);padding:var(--space-4) 0;display:flex}.step-indicator__item{align-items:center;gap:var(--space-1);flex-direction:column;flex:1;max-width:100px;display:flex;position:relative}.step-indicator__circle{width:32px;height:32px;font-size:var(--text-sm);border:2px solid var(--color-border);color:var(--color-text-light);background:var(--color-surface);border-radius:50%;justify-content:center;align-items:center;font-weight:600;transition:all .2s;display:flex}.step-indicator__label{font-size:var(--text-2xs);color:var(--color-text-light);text-align:center;font-weight:500;transition:color .2s}.step-indicator__item--active .step-indicator__circle{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.step-indicator__item--active .step-indicator__label{color:var(--color-primary);font-weight:600}.step-indicator__item--completed .step-indicator__circle{border-color:var(--color-success);background:var(--color-success);color:#fff}.step-indicator__item--completed .step-indicator__label{color:var(--color-success-text)}.step-nav{gap:var(--space-3);margin-top:var(--space-6);padding:var(--space-4) 0;display:flex}.member-chip{font-size:var(--text-sm);border-radius:var(--radius-pill);border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;-webkit-user-select:none;user-select:none;padding:.375rem .875rem;transition:all .15s}.member-chip--selected{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.upload-area{margin-top:var(--space-2);border:2px dashed var(--color-border);border-radius:var(--radius-sm);padding:var(--space-5);cursor:pointer;text-align:center;transition:border-color .2s}.upload-area:hover{border-color:var(--color-primary)}.confirm-summary{gap:var(--space-3);flex-direction:column;display:flex}.confirm-summary__row{padding:var(--space-3) var(--space-4);background:var(--color-bg);border-radius:var(--radius-sm);font-size:var(--text-sm);justify-content:space-between;align-items:center;display:flex}.confirm-summary__row span{color:var(--color-text-muted)}.confirm-summary__row strong{color:var(--color-text)}.ui-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.ui-input--error{border-color:var(--color-danger)}.ui-input--error:focus{box-shadow:0 0 0 3px #ef44441a}select.ui-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M2.5 4.5L6 8l3.5-3.5'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.toast{bottom:var(--space-6);align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-radius:var(--radius-md);box-shadow:var(--shadow-elevated);font-size:var(--text-sm);z-index:2000;opacity:0;max-width:90vw;font-weight:500;transition:transform .3s,opacity .3s;display:flex;position:fixed;left:50%;transform:translate(-50%)translateY(100px)}.toast--visible{opacity:1;transform:translate(-50%)translateY(0)}.toast--success{background:var(--color-success);color:#fff}.toast--error{background:var(--color-danger);color:#fff}.toast__icon{font-size:var(--text-md);font-weight:700}.toast__message{line-height:1.4}.action-icon-btn{background:var(--color-surface);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;padding:3px 6px;line-height:1;transition:opacity .15s;display:inline-flex}.action-icon-btn:hover{opacity:.75}.action-icon-btn:disabled{opacity:.4;cursor:not-allowed}.action-icon-btn.delete{border:1px solid var(--color-danger-border)}.action-icon-btn.restore{border:1px solid var(--color-success-border)}.animate-spin{animation:1s linear infinite spin}
