:root{--primary-color: #2383e2;--primary-dark: #1a6fc2;--primary-light: #e8f3fc;--success-color: #0f7b6c;--success-light: #dbedea;--warning-color: #cf9f23;--warning-light: #faf3dd;--danger-color: #e03e3e;--danger-light: #fce4e4;--gray-50: #ffffff;--gray-100: #f7f6f3;--gray-200: #e8e8e5;--gray-300: #d6d6d3;--gray-400: #9b9a97;--gray-500: #6b6b6b;--gray-600: #4b4b4b;--gray-700: #37352f;--gray-800: #2d2d2a;--gray-900: #1f1f1f;--bg-color: #ffffff;--bg-secondary: #f7f6f3;--radius-sm: 4px;--radius-md: 4px;--radius-lg: 6px;--radius-xl: 8px;--transition: all .15s ease}body{color:var(--gray-700);font-size:14px;line-height:1.5;background-color:var(--bg-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans JP,sans-serif}.btn{padding:0 .75rem;height:32px;border:none;border-radius:var(--radius-md);font-size:.8125rem;font-weight:500;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:.375rem;text-decoration:none;white-space:nowrap}.btn:hover:not(:disabled){filter:brightness(.92)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark)}.btn-success{background-color:var(--success-color);color:#fff}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-secondary{background-color:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200)}.btn-secondary:hover:not(:disabled){background-color:var(--gray-200);border-color:var(--gray-300)}.btn-sm{height:28px;padding:0 .625rem;font-size:.75rem;border-radius:var(--radius-sm)}.btn-icon{width:32px;height:32px;padding:0;border-radius:var(--radius-md)}.form-group{margin-bottom:.75rem}.form-label{display:block;margin-bottom:.25rem;font-size:.75rem;font-weight:500;color:var(--gray-500)}.form-input,.form-select,.form-textarea{width:100%;padding:.375rem .5rem;border:1px solid var(--gray-200);border-radius:var(--radius-md);font-size:.875rem;transition:var(--transition);background-color:transparent;color:var(--gray-700)}.form-input:hover,.form-select:hover,.form-textarea:hover{background:var(--gray-100);border-color:var(--gray-300)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color);background-color:#fff}.form-input::placeholder{color:var(--gray-400)}.form-textarea{resize:vertical;min-height:80px}.form-input-sm{padding:.25rem .5rem;font-size:.75rem;border-radius:var(--radius-sm)}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:none;padding:.75rem;border:1px solid var(--gray-200);transition:var(--transition)}.card-header{font-size:.875rem;font-weight:600;margin-bottom:.5rem;color:var(--gray-700)}.table-container{overflow-x:auto;background:#fff;border-radius:var(--radius-lg);box-shadow:none;border:1px solid var(--gray-200)}table{width:100%;border-collapse:collapse}thead{background-color:transparent}th{padding:.375rem .5rem;text-align:left;font-size:.6875rem;font-weight:500;color:var(--gray-400);border-bottom:1px solid var(--gray-200);text-transform:uppercase;letter-spacing:.04em}td{padding:.375rem .5rem;border-bottom:1px solid var(--gray-100);font-size:.875rem;color:var(--gray-700)}tbody tr{transition:var(--transition)}tbody tr:hover{background-color:var(--gray-100)}tbody tr:last-child td{border-bottom:none}.clickable{cursor:pointer;color:var(--primary-color);transition:var(--transition)}.clickable:hover{color:var(--primary-dark)}.badge{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:.6875rem;font-weight:500;line-height:1.4;border-radius:3px}.badge-success{background-color:var(--success-light);color:var(--success-color)}.badge-warning{background-color:var(--warning-light);color:#8c6d1f}.badge-danger{background-color:var(--danger-light);color:var(--danger-color)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0f0f0f99;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.modal{background:#fff;border-radius:var(--radius-xl);box-shadow:0 0 0 1px #0f0f0f0d,0 3px 6px #0f0f0f1a,0 9px 24px #0f0f0f33;max-width:900px;width:90%;max-height:90vh;overflow-y:auto;scrollbar-gutter:stable}.modal-header{padding:.75rem 1rem;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:10;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.modal-title{font-size:1rem;font-weight:600;color:var(--gray-800)}.modal-body{padding:1rem}.modal-close{background:none;border:none;padding:.25rem;cursor:pointer;color:var(--gray-400);border-radius:var(--radius-sm);font-size:1.25rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:color .15s,background-color .15s}.modal-close:hover{color:var(--gray-600);background-color:var(--gray-100)}.modal-footer{padding:.75rem 1rem;border-top:1px solid var(--gray-200);display:flex;gap:.5rem;justify-content:flex-end;position:sticky;bottom:0;background:#fff;border-radius:0 0 var(--radius-xl) var(--radius-xl)}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:.75rem;box-shadow:none;border:1px solid var(--gray-200);transition:var(--transition)}.stat-label{font-size:.6875rem;color:var(--gray-400);margin-bottom:.25rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:1.5rem;font-weight:600;color:var(--gray-800);line-height:1.2}.text-center{text-align:center}.text-right{text-align:right}.mt-4{margin-top:.75rem}.mb-4{margin-bottom:.75rem}.flex{display:flex}.gap-2{gap:.375rem}.gap-4{gap:.75rem}.items-center{align-items:center}.justify-between{justify-content:space-between}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.alert{padding:.5rem .75rem;border-radius:var(--radius-md);margin-bottom:.75rem;display:flex;align-items:center;gap:.75rem;font-size:.8125rem}.alert-success{background-color:var(--success-light);color:var(--success-color)}.alert-danger{background-color:var(--danger-light);color:var(--danger-color)}.alert-warning{background-color:#fef3c7;color:#92400e}.alert-sm{padding:.25rem .5rem;font-size:.75rem;margin-top:4px;margin-bottom:0}.toggle-btn-group{display:flex;border-radius:6px;overflow:hidden;border:1px solid var(--gray-300)}.toggle-btn{flex:1;padding:0 .5rem;height:32px;border:none;border-right:1px solid var(--gray-300);background:#fff;cursor:pointer;font-size:.8125rem;color:var(--gray-600);transition:all .15s;white-space:nowrap}.toggle-btn:last-child{border-right:none}.toggle-btn:hover:not(.active){background:var(--gray-50)}.toggle-btn.active{background:var(--primary-color);color:#fff}.toggle-btn-group.sm .toggle-btn{height:28px;font-size:.75rem}.toggle-btn.with-select{display:inline-flex;align-items:center;gap:.25rem}.toggle-btn.active .day-select{background:#fff3;color:#fff;border-color:#ffffff4d}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent;border-radius:4px}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b6b6b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;padding-right:2rem}@media (max-width: 768px){body{font-size:13px;line-height:1.5}.flex.justify-between{flex-direction:column;gap:.5rem;align-items:stretch}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.card{padding:.625rem;border-radius:var(--radius-md)}.card-header{font-size:.8125rem;margin-bottom:.375rem}.modal-overlay{align-items:flex-start;padding-top:48px;padding-bottom:1rem}.modal{width:95%;max-height:calc(100vh - 60px);border-radius:var(--radius-lg)}.modal-header{padding:.625rem .75rem;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-body{padding:.75rem}.modal-footer{padding:.625rem .75rem;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.modal-title{font-size:.9375rem}.btn{height:30px;padding:0 .625rem;font-size:.75rem}.form-group{margin-bottom:.5rem}.form-label{font-size:.6875rem;margin-bottom:.125rem}.form-input,.form-select,.form-textarea{padding:.3125rem .5rem;font-size:.8125rem}.form-textarea{min-height:60px}th{padding:.3125rem .375rem;font-size:.625rem}td{padding:.3125rem .375rem;font-size:.8125rem}.stat-card{padding:.625rem}.stat-label{font-size:.625rem;margin-bottom:.125rem}.stat-value{font-size:1.25rem}h1{font-size:1.25rem!important}h2{font-size:1rem!important}h3{font-size:.875rem!important}.badge{padding:.0625rem .375rem;font-size:.625rem}.alert{padding:.375rem .625rem;font-size:.75rem}}@media (max-width: 480px){body{font-size:12px}.card{padding:.5rem;border-radius:var(--radius-md)}.card-header{font-size:.75rem}th{padding:.25rem .3125rem;font-size:.5625rem}td{padding:.25rem .3125rem;font-size:.75rem}.btn{height:26px;padding:0 .5rem;font-size:.6875rem;gap:.25rem}.btn-sm{height:24px;padding:0 .4375rem;font-size:.625rem}.modal-header{padding:.5rem .625rem}.modal-body{padding:.625rem}.modal-footer{padding:.5rem .625rem}.modal-title{font-size:.875rem}.form-label{font-size:.625rem}.form-input,.form-select,.form-textarea{padding:.25rem .375rem;font-size:.75rem}.stat-card{padding:.5rem}.stat-label{font-size:.5625rem}.stat-value{font-size:1rem}h1{font-size:1.125rem!important}h2{font-size:.9375rem!important}h3{font-size:.8125rem!important}.flex.gap-4{flex-direction:column;gap:.5rem}.badge{padding:.0625rem .3125rem;font-size:.5625rem}.alert{padding:.3125rem .5rem;font-size:.6875rem;margin-bottom:.5rem}}
