/* pages.css - 各頁面專屬樣式 */

/* Report */
.report-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:20px}
.report-toolbar{margin-bottom:16px}
.report-toolbar-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.report-toolbar-actions{display:flex;gap:6px;margin-left:auto}
.report-toolbar-actions .btn-label{display:inline}
.report-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px}
.report-stat{text-align:center;padding:16px;border-radius:var(--radius-sm);border:1px solid var(--gray-200);background:#fff}
.report-stat .val{font-size:30px;font-weight:700;line-height:1.2}
.report-stat .lbl{font-size:14px;color:var(--gray-500);margin-top:4px}
.progress-bar{height:12px;background:var(--gray-200);border-radius:6px;overflow:hidden;margin-top:8px}
.progress-fill{height:100%;border-radius:6px;transition:width .5s}

/* Report Toggle */
.report-toggle{display:inline-flex;background:var(--gray-100);border-radius:var(--radius-sm);padding:3px;gap:2px}
.report-toggle-btn{padding:6px 16px;border-radius:6px;border:none;font-size:13px;font-weight:500;cursor:pointer;background:transparent;color:var(--gray-500);transition:.15s}
.report-toggle-btn.active{background:#fff;color:var(--primary);box-shadow:var(--shadow)}

/* Multi-day Report Table */
.weekly-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:16px;border:1px solid var(--gray-200);border-radius:var(--radius-sm)}
.weekly-table{width:100%;border-collapse:collapse;font-size:14px;min-width:600px}
.weekly-table th,.weekly-table td{padding:8px 10px;text-align:center;border:1px solid var(--gray-200);white-space:nowrap}
.weekly-table th{background:var(--gray-50);font-weight:600;color:var(--gray-600);position:sticky;top:0;z-index:1}
.sortable-th{cursor:pointer;user-select:none;transition:background .15s}
.sortable-th:hover{background:var(--primary-light)!important;color:var(--primary-dark)}
.sort-active{color:var(--primary)!important}
.sort-arrow{font-size:10px;margin-left:2px;opacity:.7}
.filter-row td{padding:3px 4px!important;background:var(--gray-50)!important;border-bottom:2px solid var(--gray-300)!important}
.filter-row .sticky-col{background:var(--gray-50)!important}
.tbl-filter{width:100%;padding:3px 6px;border:1px solid var(--gray-200);border-radius:4px;font-size:11px;background:#fff;box-sizing:border-box}
.tbl-filter:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px rgba(14,165,233,.15)}
.weekly-table th.sticky-col,.weekly-table td.sticky-col{position:sticky;left:0;z-index:2;background:#fff;min-width:80px;text-align:left;font-weight:500;box-shadow:2px 0 4px rgba(0,0,0,.06)}
.weekly-table th.sticky-col{z-index:3;background:var(--gray-50);box-shadow:2px 0 4px rgba(0,0,0,.06)}
.weekly-table tr:hover td{background:var(--gray-50)}
.weekly-table tr:hover td.sticky-col{background:var(--primary-light)}
.cell-present{background:var(--success-light)!important;color:#059669;font-weight:600}
.cell-leave{background:var(--warning-light)!important;color:#d97706;font-weight:600}
.cell-absent{background:var(--danger-light)!important;color:#dc2626;font-weight:600}
.cell-none{background:var(--gray-50)!important;color:var(--gray-300)}
.weekly-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px}
.weekly-summary .report-stat .val.perfect{color:var(--success)}
.weekly-summary .report-stat .val.zero{color:var(--danger)}

/* Schedule Editor */
.schedule-grid{display:flex;flex-direction:column;gap:8px}
.schedule-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-sm);flex-wrap:wrap}
.schedule-row:hover{border-color:var(--primary)}
.schedule-row input[type="date"]{padding:6px 10px;border:1px solid var(--gray-200);border-radius:6px;font-size:14px;font-family:inherit;color:var(--gray-700)}
.schedule-row .topics{flex:1;min-width:150px;font-size:13px;color:var(--gray-600)}
.schedule-row .topics-edit{flex:1;min-width:150px;padding:6px 10px;border:1px solid var(--gray-200);border-radius:6px;font-size:13px;font-family:inherit}
.add-date-row{display:flex;gap:8px;align-items:center;padding:12px 0;flex-wrap:wrap}
.add-date-row input{padding:8px 12px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:14px;font-family:inherit}
.month-group{margin-bottom:16px}
.month-label{font-size:13px;font-weight:600;color:var(--gray-500);padding:8px 0;border-bottom:1px solid var(--gray-100);margin-bottom:8px}
.inline-edit{border:none;border-bottom:1px dashed var(--gray-300);background:transparent;font-size:inherit;font-family:inherit;color:inherit;padding:2px 0;outline:none;width:100%}
.inline-edit:focus{border-bottom-color:var(--primary)}

/* Student Editor */
.student-edit-row{display:grid;grid-template-columns:80px 1fr 1fr 80px 100px 60px;gap:8px;align-items:center;padding:8px 12px;border-bottom:1px solid var(--gray-100);font-size:13px}
.student-edit-row.header{font-weight:600;color:var(--gray-500);font-size:12px;background:var(--gray-50);border-radius:var(--radius-sm) var(--radius-sm) 0 0;position:sticky;top:0}
.student-edit-row input,.student-edit-row select{padding:5px 8px;border:1px solid var(--gray-200);border-radius:6px;font-size:13px;font-family:inherit;width:100%}
.student-edit-list{max-height:500px;overflow-y:auto;border:1px solid var(--gray-200);border-radius:var(--radius-sm)}

/* Temple Management */
.temple-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.temple-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;transition:.2s}
.temple-card:hover{box-shadow:var(--shadow-md);border-color:var(--gray-300)}
.temple-card-header{padding:16px 20px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.temple-card-name{font-size:17px;font-weight:600;color:var(--gray-800)}
.temple-class-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:500;background:var(--primary-light);color:var(--primary-dark);white-space:nowrap}
.temple-card-body{padding:0 20px 12px;display:flex;flex-direction:column;gap:6px}
.temple-card-row{display:flex;align-items:flex-start;gap:8px;font-size:14px;color:var(--gray-600);line-height:1.5}
.temple-card-row svg{flex-shrink:0;margin-top:2px;color:var(--gray-400)}
.temple-card-footer{padding:12px 20px;border-top:1px solid var(--gray-100);display:flex;gap:8px;justify-content:flex-end}

/* Temple Form */
.temple-form{display:flex;flex-direction:column;gap:14px}
.temple-form .form-group{display:flex;flex-direction:column;gap:4px;flex:1}
.temple-form .form-label{font-size:13px;font-weight:500;color:var(--gray-600)}
.temple-form .form-input{padding:8px 12px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--gray-700);transition:.15s}
.temple-form .form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(14,165,233,.1)}
.temple-form .form-row{display:flex;gap:12px}
.temple-form textarea.form-input{resize:vertical;min-height:60px}

/* Report Summary (Class Type Summary) */
.summary-toggle-btn{padding:6px 16px;border-radius:6px;border:none;font-size:13px;font-weight:500;cursor:pointer;background:transparent;color:var(--gray-500);transition:.15s}
.summary-toggle-btn.active{background:#fff;color:var(--primary);box-shadow:var(--shadow)}
.summary-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-bottom:20px}
.summary-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:16px;border:1px solid var(--gray-200);border-radius:var(--radius-sm)}
.summary-table{width:100%;border-collapse:collapse;font-size:14px}
.summary-table th,.summary-table td{padding:8px 12px;text-align:center;border:1px solid var(--gray-200);white-space:nowrap}
.summary-table th{background:var(--gray-50);font-weight:600;color:var(--gray-600);position:sticky;top:0;z-index:1}
.summary-table th:first-child,.summary-table td:first-child{text-align:left;font-weight:500;position:sticky;left:0;z-index:2;background:#fff;box-shadow:2px 0 4px rgba(0,0,0,.06)}
.summary-table th:first-child{z-index:3;background:var(--gray-50);box-shadow:2px 0 4px rgba(0,0,0,.06)}

/* Screenshot capture container */
.screenshot-wrap{width:1080px;background:#F3F4F6;padding:32px;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
.screenshot-wrap .screenshot-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--gray-300)}
.screenshot-wrap .screenshot-header h2{font-size:22px;font-weight:700;color:var(--gray-800)}
.screenshot-wrap .screenshot-header .screenshot-date{font-size:14px;color:var(--gray-500)}
.screenshot-wrap .screenshot-body{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 4px rgba(0,0,0,.08)}
.screenshot-wrap .screenshot-footer{margin-top:16px;text-align:right;font-size:12px;color:var(--gray-400)}
.screenshot-wrap .report-stat .val{font-size:34px}
.screenshot-wrap .report-stat .lbl{font-size:15px}
.screenshot-wrap .weekly-table{font-size:15px}
.screenshot-wrap .weekly-table td.sticky-col{font-size:16px}
.screenshot-wrap .stat-value{font-size:34px}
.screenshot-wrap .stat-label{font-size:15px}

/* Member Management */
.member-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--gray-200);border-radius:var(--radius-sm)}
.member-table{width:100%;border-collapse:collapse;font-size:14px;min-width:700px}
.member-table th,.member-table td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--gray-100)}
.member-table th{background:var(--gray-50);font-weight:600;color:var(--gray-600);position:sticky;top:0;z-index:1;white-space:nowrap}
.member-table tr:hover td{background:var(--gray-50)}
.member-pagination{display:flex;gap:4px;align-items:center;justify-content:center;margin-top:16px;flex-wrap:wrap}
.member-pagination button{padding:6px 12px;border:1px solid var(--gray-200);border-radius:6px;background:#fff;font-size:13px;cursor:pointer;transition:.15s}
.member-pagination button:hover{border-color:var(--primary);color:var(--primary)}
.member-pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.member-pagination button:disabled{opacity:.4;cursor:not-allowed}
.member-form{display:flex;flex-direction:column;gap:16px}
.member-form fieldset{border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:12px 16px;margin:0}
.member-form fieldset legend{font-size:13px;font-weight:600;color:var(--primary);padding:0 6px}
.member-form .form-row{display:flex;gap:12px;flex-wrap:wrap}
.member-form .form-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:180px}
.member-form .form-label{font-size:12px;font-weight:500;color:var(--gray-600)}
.member-form .form-input{padding:7px 10px;border:1px solid var(--gray-200);border-radius:6px;font-size:13px;font-family:inherit;color:var(--gray-700);transition:.15s}
.member-form .form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(14,165,233,.1)}
.member-form select.form-input{appearance:auto}
.enrollment-row{display:flex;gap:8px;align-items:center;padding:6px 0;flex-wrap:wrap}
.enrollment-row select,.enrollment-row input{padding:6px 8px;border:1px solid var(--gray-200);border-radius:6px;font-size:13px}

/* User Management */
.user-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.user-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;transition:.2s}
.user-card:hover{box-shadow:var(--shadow-md);border-color:var(--gray-300)}
.user-card-header{padding:16px 20px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.user-card-name{font-size:16px;font-weight:600;color:var(--gray-800)}
.user-role-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:500;color:#fff;white-space:nowrap}
.user-card-body{padding:0 20px 12px;display:flex;flex-direction:column;gap:4px}
.user-card-row{font-size:13px;color:var(--gray-600);line-height:1.5}
.user-card-footer{padding:12px 20px;border-top:1px solid var(--gray-100);display:flex;gap:8px;justify-content:flex-end}

/* Organization Sub-tabs */
.org-subtabs{display:flex;gap:4px;border-bottom:2px solid var(--gray-200);padding-bottom:0}
.org-subtab{padding:8px 20px;border:none;background:transparent;font-size:14px;font-weight:500;color:var(--gray-500);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:.15s;border-radius:var(--radius-sm) var(--radius-sm) 0 0}
.org-subtab:hover{color:var(--gray-700);background:var(--gray-50)}
.org-subtab.active{color:var(--primary);border-bottom-color:var(--primary);background:var(--primary-light)}
.org-group-header{font-size:15px;font-weight:600;color:var(--gray-600);padding:12px 0 8px;border-bottom:1px solid var(--gray-200);margin-bottom:12px;margin-top:8px}
.org-group-header:first-child{margin-top:0}

/* Checkin Date Bar */
.checkin-date-bar{display:flex;flex-direction:column;gap:6px;padding:10px 0;margin-bottom:8px}
.checkin-date-bar:empty{display:none}
.checkin-month-tabs{display:flex;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}
.checkin-month-tabs::-webkit-scrollbar{display:none}
.checkin-month-tab{flex-shrink:0;padding:4px 12px;border:1px solid var(--gray-200);border-radius:16px;font-size:12px;font-weight:500;color:var(--gray-500);background:#fff;cursor:pointer;transition:.15s;white-space:nowrap;display:inline-flex;align-items:center;gap:4px}
.checkin-month-tab:hover{border-color:var(--primary);color:var(--primary)}
.checkin-month-tab.active{background:var(--gray-800);color:#fff;border-color:var(--gray-800);font-weight:600}
.checkin-month-tab .month-count{font-size:10px;opacity:.7}
.checkin-date-chips{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.checkin-date-chips::-webkit-scrollbar{display:none}
.checkin-date-chip{flex-shrink:0;padding:6px 14px;border:1px solid var(--gray-200);border-radius:20px;font-size:13px;font-weight:500;color:var(--gray-600);background:#fff;cursor:pointer;transition:.15s;white-space:nowrap}
.checkin-date-chip:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}
.checkin-date-chip.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}
.checkin-date-chip.today{box-shadow:0 0 0 2px rgba(14,165,233,.2)}
.checkin-date-chip.active.today{box-shadow:0 0 0 2px rgba(14,165,233,.4)}
.checkin-date-empty{padding:12px 16px;font-size:13px;color:var(--warning);background:var(--warning-light);border-radius:var(--radius-sm);text-align:center}

/* Report Date Bar (horizontal chip list inside report header) */
.report-date-bar{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 0}
.report-date-bar::-webkit-scrollbar{display:none}
.report-date-bar:empty{display:none}

/* Today Topics Bar (checkin page) */
.today-topics-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:10px 16px;margin-bottom:8px;background:var(--primary-light);border-radius:var(--radius-sm);border:1px solid rgba(14,165,233,.15)}
.topic-chip{display:inline-block;padding:3px 10px;background:#fff;border-radius:12px;font-size:12px;color:var(--primary-dark);border:1px solid rgba(14,165,233,.2)}

/* Lecturer Picker (schedule-mgmt) */
.lecturer-picker{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:8px;box-shadow:var(--shadow)}
.lecturer-picker-results{border:1px solid var(--gray-100);border-radius:6px;overflow:hidden}
.lecturer-picker-item:hover{background:var(--primary-light)!important}

/* Class Overview Table */
.overview-table th{font-size:13px}
.overview-table td{font-size:14px}
.overview-type-row td{border-top:2px solid var(--gray-200)}

/* Officer Grid (class-mgmt) */
.officer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.officer-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;transition:.2s}
.officer-card:hover{border-color:var(--gray-300);box-shadow:var(--shadow)}
.officer-card-header{padding:12px 16px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--gray-100);background:var(--gray-50)}
.officer-role-label{font-size:14px;font-weight:600;color:var(--gray-700)}
.officer-card-body{padding:12px 16px}

/* Tag Chips (shared) */
.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--primary-light);color:var(--primary-dark);border-radius:16px;font-size:13px;font-weight:500;white-space:nowrap}
.tag-chip .remove{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border:none;background:rgba(0,0,0,.1);color:inherit;border-radius:50%;cursor:pointer;font-size:14px;line-height:1;padding:0}
.tag-chip .remove:hover{background:rgba(0,0,0,.2)}

/* Group Cards (class-mgmt) */
.group-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.group-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;transition:.2s}
.group-card:hover{border-color:var(--gray-300);box-shadow:var(--shadow)}
.group-card-header{padding:10px 16px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--gray-100);background:var(--gray-50)}
.group-name-input{flex:1;border:none;background:transparent;font-size:14px;font-weight:600;color:var(--gray-700);padding:2px 4px;border-bottom:1px dashed var(--gray-300);outline:none}
.group-name-input:focus{border-bottom-color:var(--primary)}
.group-card-body{padding:12px 16px}

/* Duty Table (class-mgmt) */
.duty-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--gray-200);border-radius:var(--radius-sm)}
.duty-table{width:100%;border-collapse:collapse;font-size:14px}
.duty-table th,.duty-table td{padding:8px 12px;text-align:left;border:1px solid var(--gray-200);white-space:nowrap}
.duty-table th{background:var(--gray-50);font-weight:600;color:var(--gray-600);position:sticky;top:0}
.duty-table tr:hover td{background:var(--gray-50)}

/* Course Cards (課程庫) */
.course-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.course-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-sm);overflow:hidden;transition:.2s;display:flex;flex-direction:column}
.course-card:hover{border-color:var(--primary);box-shadow:var(--shadow)}
.course-card-body{padding:12px 16px;flex:1}
.course-card-name{font-size:15px;font-weight:600;color:var(--gray-800)}
.course-category-badge{display:inline-block;margin-top:4px;padding:1px 8px;background:var(--gray-100);color:var(--gray-500);border-radius:10px;font-size:11px}
.course-card-footer{padding:8px 16px;border-top:1px solid var(--gray-100);display:flex;gap:6px;justify-content:flex-end}

/* Schedule Period Rows (排課增強) */
.schedule-day-card{border:1px solid var(--gray-200);border-radius:var(--radius-sm);margin-bottom:8px;overflow:hidden;transition:.15s}
.schedule-day-card:hover{border-color:var(--primary)}
.schedule-day-header{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--gray-50);cursor:pointer;flex-wrap:wrap}
.schedule-day-header:hover{background:var(--primary-light)}
.schedule-day-body{padding:0 14px 12px;border-top:1px solid var(--gray-100)}
.period-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--gray-50);flex-wrap:wrap}
.period-row:last-child{border-bottom:none}
.period-num{min-width:40px;font-size:12px;font-weight:600;color:var(--gray-400)}
.period-course-input{flex:1;min-width:120px;padding:5px 10px;border:1px solid var(--gray-200);border-radius:6px;font-size:13px;font-family:inherit;position:relative}
.period-location-input{width:80px;padding:5px 8px;border:1px solid var(--gray-200);border-radius:6px;font-size:12px;font-family:inherit}
.location-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;background:var(--gray-100);color:var(--gray-600);border-radius:10px;font-size:11px}
.time-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;background:var(--primary-light);color:var(--primary-dark);border-radius:10px;font-size:11px}

/* Autocomplete Dropdown */
.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--gray-200);border-radius:0 0 var(--radius-sm) var(--radius-sm);box-shadow:var(--shadow-md);max-height:200px;overflow-y:auto;z-index:100}
.autocomplete-item{padding:8px 12px;font-size:13px;cursor:pointer;border-bottom:1px solid var(--gray-50)}
.autocomplete-item:hover{background:var(--primary-light)}

/* Seating Grid (座位表) */
.seating-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:16px;padding:12px;background:var(--gray-50);border-radius:var(--radius-sm)}
.seating-toolbar label{font-size:12px;color:var(--gray-500)}
.seating-toolbar input[type="number"]{width:60px;padding:4px 8px;border:1px solid var(--gray-200);border-radius:6px;font-size:13px;text-align:center}
.seating-grid{display:inline-grid;gap:6px;margin:0 auto}
.seat-cell{width:76px;height:76px;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:.15s;font-size:12px;user-select:none;border:2px solid transparent;position:relative}
.seat-cell.empty{background:var(--gray-100);color:var(--gray-400);border:2px dashed var(--gray-300)}
.seat-cell.empty:hover{border-color:var(--primary);background:var(--primary-light)}
.seat-cell.occupied{background:var(--primary-light);color:var(--primary-dark);border:2px solid rgba(14,165,233,.3);font-weight:500}
.seat-cell.occupied:hover{border-color:var(--primary);box-shadow:var(--shadow)}
.seat-cell.occupied.seat-male{background:#dbeafe;color:#1e40af;border-color:#93c5fd}
.seat-cell.occupied.seat-male:hover{border-color:#2563eb}
.seat-cell.occupied.seat-female{background:#fce7f3;color:#9d174d;border-color:#f9a8d4}
.seat-cell.occupied.seat-female:hover{border-color:#db2777}
.seat-cell .seat-gender-badge{position:absolute;top:2px;right:4px;font-size:9px;font-weight:700;opacity:.6}
.seat-cell.aisle{background:var(--gray-200);cursor:default;border:none}
.seat-cell.aisle-mode-active{cursor:crosshair}
.seat-cell.dragging{opacity:.5}
.seat-cell .seat-name{font-size:13px;font-weight:600;max-width:68px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.seat-cell .seat-label{font-size:10px;color:var(--gray-400)}

/* Calendar */
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--gray-200);border:1px solid var(--gray-200);border-radius:var(--radius-sm);overflow:hidden}
.calendar-header-cell{padding:8px 4px;text-align:center;font-size:12px;font-weight:600;color:var(--gray-500);background:var(--gray-50)}
.calendar-cell{min-height:90px;padding:6px;background:#fff;cursor:pointer;transition:.15s;position:relative}
.calendar-cell:hover{background:var(--primary-light)}
.calendar-cell.empty{background:var(--gray-50);cursor:default}
.calendar-cell.empty:hover{background:var(--gray-50)}
.calendar-cell.today{background:#eff6ff}
.calendar-cell.today .calendar-day-num{background:var(--primary);color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center}
.calendar-cell.selected{outline:2px solid var(--primary);outline-offset:-2px}
.calendar-cell.conflict{background:#fef2f2}
.calendar-day-num{font-size:13px;font-weight:500;color:var(--gray-700);margin-bottom:4px}
.calendar-event{padding:1px 6px;border-radius:4px;font-size:10px;font-weight:500;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.calendar-event-more{font-size:10px;color:var(--gray-400);padding:1px 4px}
.calendar-conflict-badge{position:absolute;top:4px;right:4px;width:16px;height:16px;background:var(--danger);color:#fff;border-radius:50%;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}

/* Chart Grid Responsive */
@media(max-width:768px){
  #chartGrid{grid-template-columns:1fr!important}
  .calendar-cell{min-height:60px}
  .calendar-event{font-size:9px}
}

/* Dev Tools Card */
.dev-tools-card{margin-top:16px;border:2px dashed var(--gray-300);border-radius:var(--radius)}
.dev-tools-card .card-header{background:var(--gray-50)}
.dev-tools-card .card-header h2{color:var(--gray-500);font-size:14px}

/* 斑馬紋 */
.weekly-table tbody tr:nth-child(even) td,
.member-table tbody tr:nth-child(even) td,
.summary-table tbody tr:nth-child(even) td { background: var(--gray-50); }
/* hover 高亮 */
.weekly-table tbody tr:hover td,
.member-table tbody tr:hover td { background: rgba(14,165,233,.06); }
/* 加大行距 */
.weekly-table th, .weekly-table td { padding: 10px 12px; }
.member-table th, .member-table td { padding: 10px 14px; }

/* ===== Report Toolbar ===== */
.report-toolbar{margin-bottom:12px}
.report-toolbar-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.report-toolbar-actions{display:flex;gap:6px;margin-left:auto;flex-shrink:0}
.report-toolbar-actions .btn-label{display:inline}
