:root{color:#141923;background:#f3f5f8;font-family:Microsoft YaHei,PingFang SC,Inter,system-ui,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--bg: #f3f5f8;--surface: #ffffff;--surface-soft: #f8fafc;--line: #dfe5ee;--line-strong: #cbd5e1;--text: #141923;--subtle: #667085;--muted: #8a94a6;--brand: #2357c6;--brand-deep: #163f9c;--brand-soft: #eef4ff;--green: #14805e;--green-soft: #e8f7f1;--amber: #946200;--amber-soft: #fff4d9;--red: #b42318;--red-soft: #ffe9e7;--shadow: 0 12px 30px rgba(15, 23, 42, .08);--shadow-soft: 0 6px 18px rgba(15, 23, 42, .06)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg)}button,input,select,textarea{font:inherit}button,select,input[type=file]{-webkit-tap-highlight-color:transparent}.app{width:min(1200px,calc(100% - 40px));margin:0 auto;padding:30px 0 56px}.app-narrow{width:min(500px,calc(100% - 24px))}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;padding:18px 20px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-soft)}.topbar svg{flex:0 0 auto;color:var(--brand)}.eyebrow{margin:0 0 5px;color:var(--subtle);font-size:13px;font-weight:700}h1,h2{margin:0;letter-spacing:0}h1{color:var(--text);font-size:26px;font-weight:800;line-height:1.2}h2{margin-bottom:14px;color:var(--text);font-size:17px;font-weight:800}.panel{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:20px;margin-bottom:16px;box-shadow:var(--shadow-soft)}.admin-tabs,.sub-tabs{display:flex;gap:8px;margin-bottom:16px;padding:6px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-soft)}.admin-tabs button,.sub-tabs button{min-height:42px;border:0;border-radius:6px;background:transparent;color:var(--subtle);padding:0 18px;cursor:pointer;font-weight:800}.admin-tabs button.active,.sub-tabs button.active{background:var(--brand);color:#fff;box-shadow:0 8px 18px #2357c62e}.sub-tabs{width:fit-content}.mobile-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:14px;padding:6px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-soft)}.mobile-tabs button{min-height:42px;border:0;border-radius:6px;background:transparent;color:var(--subtle);cursor:pointer;font-weight:900}.mobile-tabs button.active{background:var(--brand);color:#fff}.profile-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:14px 16px;margin-bottom:14px;box-shadow:var(--shadow-soft)}.profile-bar span{min-width:0;font-weight:800;overflow-wrap:anywhere}.profile-bar button{flex:0 0 auto;border:1px solid var(--line-strong);border-radius:6px;background:var(--surface);color:#344054;padding:8px 12px;cursor:pointer}.profile-bar button:hover,.actions button:hover,.category-tabs button:hover,.summary-card:hover{border-color:#9eb3d7}.form{display:grid;gap:16px}label{display:grid;gap:8px;color:#344054;font-size:14px;font-weight:700}input,select,textarea{width:100%;border:1px solid var(--line-strong);border-radius:7px;background:#fff;color:var(--text);padding:12px 13px;outline:none}select{cursor:pointer}textarea{min-height:140px;resize:vertical;line-height:1.65}input::placeholder,textarea::placeholder{color:#98a2b3}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 4px #2357c61f}input[type=file]{padding:10px;background:var(--surface-soft)}input[type=file]::file-selector-button{margin-right:12px;border:0;border-radius:6px;background:var(--brand-soft);color:var(--brand-deep);padding:8px 12px;font-weight:800;cursor:pointer}.switches{display:flex;gap:10px;flex-wrap:wrap}.check{display:flex;align-items:center;gap:8px;width:fit-content;min-height:36px;border:1px solid var(--line);border-radius:999px;background:var(--surface-soft);padding:0 12px}.check input{width:17px;height:17px;accent-color:var(--brand)}.image-grid,.record-images{display:flex;gap:10px;flex-wrap:wrap}.image-preview{border:1px solid var(--line);border-radius:7px;background:var(--surface-soft)}.image-preview{width:108px;overflow:hidden;box-shadow:0 3px 8px #0f172a0d}.image-preview img,.record-images img{display:block;width:100%;height:82px;object-fit:cover}.image-preview button{width:100%;border:0;border-top:1px solid var(--line);background:#fff;color:#475467;padding:8px 0;cursor:pointer;font-weight:700}.record-images{margin-top:12px}.record-image{width:78px;height:78px;padding:0;overflow:hidden;border:1px solid var(--line);border-radius:7px;background:var(--surface-soft);cursor:pointer}.record-image img{display:block;width:100%;height:100%;border:0;border-radius:0;object-fit:cover}.image-viewer{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#000000eb;padding:20px}.image-viewer img{display:block;max-width:100%;max-height:92vh;object-fit:contain;-webkit-touch-callout:default}.image-viewer-close{position:fixed;top:14px;right:14px;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:0;border-radius:999px;background:#ffffff29;color:#fff;cursor:pointer}.primary,.secondary,.actions button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:7px;cursor:pointer;text-decoration:none;font-weight:800;transition:transform .12s ease,border-color .12s ease,background .12s ease,box-shadow .12s ease}.primary{min-height:48px;background:var(--brand);color:#fff;box-shadow:0 8px 18px #2357c638}.primary:hover{background:var(--brand-deep)}.primary:active,.secondary:active,.actions button:active{transform:translateY(1px)}.primary:disabled{opacity:.65;cursor:not-allowed}.secondary{min-height:42px;padding:0 16px;background:#121826;color:#fff}.toolbar{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr)) auto;gap:10px;margin-bottom:16px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-soft)}.summary-grid{display:grid;grid-template-columns:repeat(6,minmax(120px,1fr));gap:12px;margin-bottom:16px}.summary-card{display:grid;gap:10px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:#344054;padding:16px;text-align:left;cursor:pointer;box-shadow:var(--shadow-soft)}.summary-card.readonly{cursor:default}.summary-card.active{border-color:#2357c673;background:var(--brand-soft);box-shadow:0 0 0 4px #2357c614}.summary-card span{color:var(--subtle);font-size:13px;font-weight:800}.summary-card strong{color:var(--text);font-size:30px;line-height:1}.category-tabs{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 12px;margin-bottom:6px}.category-tabs button{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;border:1px solid var(--line);border-radius:999px;background:var(--surface);color:#344054;padding:9px 13px;cursor:pointer;font-weight:800}.category-tabs button.active{border-color:#2357c673;background:var(--brand-soft);color:var(--brand-deep)}.category-tabs span{min-width:22px;border-radius:999px;background:#e7ecf5;color:#536078;padding:2px 7px;font-size:12px;text-align:center}.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.section-head h2{margin:0}.section-head span{color:var(--muted);font-size:14px;font-weight:700}.report-list{display:grid;gap:12px}.report-card{display:grid;grid-template-columns:minmax(0,1fr) 190px;gap:18px;border:1px solid var(--line);border-radius:8px;padding:16px;background:#fff;box-shadow:0 2px 6px #0f172a0a}.report-card:hover{border-color:#c9d5e8}.report-meta,.report-foot{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.report-meta b{border-radius:999px;background:var(--brand-soft);color:var(--brand-deep);padding:3px 9px;font-size:13px}.report-meta span,.report-foot span{color:var(--subtle);font-size:13px;font-weight:600}.report-card-main p{margin:12px 0;color:#1d2939;line-height:1.7}.report-foot{margin-top:12px}.report-side{display:flex;flex-direction:column;justify-content:space-between;gap:12px;align-items:flex-start}.status-pill{display:inline-flex;border-radius:999px;padding:4px 10px;margin:0 6px 6px 0;font-size:12px;font-weight:800}.status-pill.open{background:var(--red-soft);color:var(--red)}.status-pill.processing{background:var(--amber-soft);color:var(--amber)}.status-pill.done{background:var(--green-soft);color:var(--green)}.tag{display:inline-block;margin:0 6px 6px 0;border-radius:999px;padding:3px 8px;font-size:12px;font-weight:800}.danger{background:var(--red-soft);color:var(--red)}.warn{background:var(--amber-soft);color:var(--amber)}.actions{display:flex;gap:8px;flex-wrap:wrap}.actions button{min-height:34px;padding:0 11px;border:1px solid var(--line);background:var(--surface-soft);color:#344054}.actions button.danger-action{color:var(--red)}.config-panel{margin-top:18px}.config-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.config-card{display:flex;flex-direction:column;gap:10px;min-width:0;padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.config-card h3{margin:0 0 2px;color:#101828;font-size:15px}.config-card label{display:grid;gap:6px;color:var(--subtle);font-size:13px;font-weight:700}.config-card textarea{min-height:184px;resize:vertical}.inline-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.compact{width:fit-content;min-height:38px;padding:0 13px;font-size:14px}.config-list{display:grid;gap:8px;max-height:210px;overflow:auto;padding-top:4px}.config-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;min-height:36px;padding:7px 9px;border:1px solid var(--line);border-radius:7px;background:#fff}.config-row span{overflow:hidden;color:#344054;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.config-row button{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--line);background:var(--surface);color:var(--red)}.people-layout{display:grid;grid-template-columns:360px minmax(0,1fr);gap:16px;align-items:start}.group-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px}.group-tabs button{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:58px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:#344054;padding:0 16px;box-shadow:var(--shadow-soft);cursor:pointer}.group-tabs button.active{border-color:#2357c673;background:var(--brand-soft);color:var(--brand-deep);box-shadow:0 0 0 4px #2357c614}.group-tabs strong{font-size:17px}.group-tabs span{color:var(--subtle);font-size:13px;font-weight:800}.people-form{display:grid;gap:14px;position:sticky;top:16px}.people-form textarea{min-height:86px}.form-actions{display:grid;gap:8px}.ghost-button{min-height:42px;border:1px solid var(--line);border-radius:7px;background:#fff;color:#344054;cursor:pointer;font-weight:800}.form-block,.split-form-block{display:grid;gap:10px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.split-form-block{gap:0;padding:0;overflow:hidden;background:#fff}.split-form-section{display:grid;gap:10px;padding:12px}.split-form-section+.split-form-section{border-top:1px solid var(--line)}.form-block b,.split-form-section b{color:#101828;font-size:14px}.people-list-panel{min-width:0}.people-search{margin-bottom:12px}.people-table{display:grid;gap:8px;overflow-x:auto;padding-bottom:4px}.people-row{display:grid;grid-template-columns:minmax(110px,1fr) minmax(130px,1fr) 74px;gap:10px;align-items:center;min-height:58px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#fff}.staff-roster-table .people-row,.participant-table .people-row{width:max-content}.staff-roster-table .people-row{grid-template-columns:70px 100px minmax(90px,1fr) minmax(180px,1.4fr) 70px minmax(120px,1fr) 122px;min-width:940px}.people-row.head{min-height:38px;background:var(--surface-soft);color:var(--subtle);font-size:13px;font-weight:800}.people-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.participant-table-wrap{overflow-x:auto;padding-bottom:4px}.participant-roster-table{width:2120px;border-collapse:separate;border-spacing:0 10px;table-layout:fixed}.participant-roster-table th,.participant-roster-table td{padding:14px 12px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;color:#141923;text-align:left;vertical-align:middle}.participant-roster-table th{padding-top:12px;padding-bottom:12px;background:var(--surface-soft);color:var(--subtle);font-size:13px;font-weight:800}.participant-roster-table th:first-child,.participant-roster-table td:first-child{border-left:1px solid var(--line);border-radius:8px 0 0 8px}.participant-roster-table th:last-child,.participant-roster-table td:last-child{border-right:1px solid var(--line);border-radius:0 8px 8px 0}.participant-roster-table .col-sequence{width:64px}.participant-roster-table .col-type{width:86px}.participant-roster-table .col-name{width:164px}.participant-roster-table .col-id-card{width:226px}.participant-roster-table .col-phone{width:146px}.participant-roster-table .col-gender{width:70px}.participant-roster-table .col-metric{width:78px}.participant-roster-table .col-room{width:82px}.participant-roster-table .col-note{width:360px}.participant-roster-table .col-action{width:128px}.multi-line-cell{display:grid;grid-template-columns:minmax(0,1fr);gap:5px;padding:0;min-height:42px;align-content:center;white-space:normal}.multi-line-cell>span{display:block;min-width:0}.multi-line-cell b,.multi-line-cell small{min-width:0;overflow:visible;text-overflow:clip;white-space:nowrap}.id-cell span,.phone-cell span{color:#344054;font-size:13px;font-weight:750;line-height:22px;white-space:nowrap}.multi-line-cell b{color:#1d2939;font-size:15px}.multi-line-cell small{color:var(--subtle);font-size:13px;font-weight:700}.metric-cell b{display:flex;align-items:center;justify-content:flex-start;min-height:22px;font-size:15px;font-weight:800}.metric-cell b+b{border-top:0}.note-cell{display:block;min-height:58px;max-height:112px;overflow:auto;padding:9px 10px;border-radius:7px;background:var(--surface-soft);color:#344054;line-height:1.55;white-space:normal;overflow-wrap:anywhere}.sequence-cell{display:inline-flex;align-items:center;justify-content:center;width:32px;height:28px;border-radius:6px;background:var(--brand-soft);color:var(--brand-deep);font-weight:900}.people-row button,.row-actions button{min-height:32px;border:1px solid var(--line);border-radius:6px;background:#fff;color:var(--red);cursor:pointer;font-weight:800}.row-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.row-actions button:first-child{color:var(--brand-deep)}.view-switch{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;width:min(360px,100%);margin:0 0 20px;padding:4px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.view-switch button{min-width:0;min-height:34px;border:0;border-radius:6px;background:transparent;color:#667085;cursor:pointer;font-weight:900}.view-switch button.active{background:#fff;color:var(--brand-deep);box-shadow:0 1px 4px #10182814}.attendance-layout{display:grid;grid-template-columns:minmax(320px,380px) minmax(0,1fr);gap:24px;align-items:start;min-width:0}.attendance-layout.family-mode{grid-template-columns:minmax(0,1fr)}.attendance-points{position:sticky;top:16px;min-width:0}.attendance-point-list{display:grid;gap:8px}.attendance-day-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px;min-width:0}.attendance-day-list button{min-width:0;min-height:36px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#344054;cursor:pointer;font-weight:900}.attendance-day-list button.active{border-color:#2357c673;background:var(--brand-soft);color:var(--brand-deep)}.attendance-point-list button{display:grid;grid-template-columns:34px minmax(0,1fr);align-items:center;gap:10px;min-height:48px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#344054;padding:8px 10px;text-align:left;cursor:pointer;min-width:0}.attendance-point-list button.active{border-color:#2357c673;background:var(--brand-soft);color:var(--brand-deep)}.attendance-point-list span{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;background:#eef2f7;font-weight:900}.attendance-point-list b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attendance-panel{min-width:0}.attendance-table-wrap{overflow-x:auto}.attendance-dashboard{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:12px}.attendance-metric{display:grid;gap:4px;min-height:96px;border:1px solid #dce4ef;border-radius:8px;background:linear-gradient(180deg,#fff,#f8fbff);padding:14px;box-shadow:var(--shadow-hairline)}.attendance-metric span{color:#667085;font-size:13px;font-weight:850}.attendance-metric strong{color:#172033;font-size:30px;line-height:1;font-weight:950}.attendance-metric small{color:#7b8797;font-size:12px;font-weight:800}.attendance-metric.danger{border-color:#f0c5c0;background:linear-gradient(180deg,#fff,#fff7f5)}.attendance-metric.danger strong,.attendance-metric.danger span{color:#9b251c}.absence-board,.family-overview-board{display:grid;gap:12px;margin-bottom:14px;border:1px solid #dce4ef;border-radius:8px;background:#f8fafc;padding:14px}.absence-board-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.absence-board-head b{display:block;color:#172033;font-size:15px;font-weight:950}.absence-board-head span{display:block;margin-top:2px;color:#667085;font-size:12px;font-weight:850}.absence-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px}.absence-card{display:grid;gap:12px;border:1px solid #f0c5c0;border-radius:8px;background:#fff;padding:12px;box-shadow:var(--shadow-hairline)}.absence-card-top{display:grid;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:10px}.absence-card-top b,.absence-card-top small{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.absence-card-top b{color:#172033;font-size:16px;font-weight:950}.absence-card-top small{margin-top:3px;color:#667085;font-size:12px;font-weight:850}.absence-members{display:flex;flex-wrap:wrap;gap:6px}.absence-members span{border:1px solid #f0c5c0;border-radius:999px;background:#fff4f2;color:#9b251c;padding:4px 8px;font-size:12px;font-weight:900}.absence-card dl{display:grid;gap:7px;margin:0}.family-exception-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:10px}.family-exception-card{display:grid;gap:10px;border:1px solid #f0c5c0;border-radius:8px;background:#fff;padding:12px;box-shadow:var(--shadow-hairline)}.family-exception-events{display:grid;gap:7px}.family-exception-events span{display:grid;gap:2px;border-radius:8px;background:#fff4f2;color:#9b251c;padding:8px;font-size:12px;font-weight:850;line-height:1.45}.family-exception-events b{color:#344054;font-weight:950}.absence-card dl div{display:grid;grid-template-columns:42px minmax(0,1fr);gap:8px}.absence-card dt,.absence-card dd{margin:0;min-width:0;overflow-wrap:anywhere;line-height:1.45}.absence-card dt{color:#7b8797;font-size:12px;font-weight:900}.absence-card dd{color:#344054;font-size:13px;font-weight:760}.empty-state{border:1px dashed #ccd6e3;border-radius:8px;background:#fff;color:#667085;padding:18px;text-align:center;font-weight:850}.absent-summary{display:grid;gap:6px;margin-bottom:12px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.absent-summary b{color:var(--red)}.absent-summary p,.absent-summary span{margin:0;color:#344054;line-height:1.55}.absent-chip-list{display:flex;flex-wrap:wrap;gap:8px}.absent-chip-list span{display:inline-flex;align-items:center;gap:6px;border:1px solid #f0c5c0;border-radius:999px;background:#fff;padding:5px 9px;color:#344054;font-size:13px;font-weight:850}.absent-chip-list em{max-width:260px;overflow:hidden;color:#9b251c;font-style:normal;text-overflow:ellipsis;white-space:nowrap}.attendance-table{width:1040px;border-collapse:separate;border-spacing:0 8px;table-layout:fixed}.attendance-table th,.attendance-table td{padding:12px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;text-align:left;vertical-align:middle}.attendance-table th{background:var(--surface-soft);color:var(--subtle);font-size:13px;font-weight:800}.attendance-table th:first-child,.attendance-table td:first-child{border-left:1px solid var(--line);border-radius:8px 0 0 8px}.attendance-table th:last-child,.attendance-table td:last-child{border-right:1px solid var(--line);border-radius:0 8px 8px 0}.att-sequence{width:70px}.att-parent,.att-phone,.att-child{width:150px}.att-status{width:240px}.att-note{width:280px}.attendance-status{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.attendance-status button{min-height:34px;border:1px solid var(--line);border-radius:6px;background:#fff;color:#344054;cursor:pointer;font-weight:800}.attendance-status button.active.pending{background:#eef2f7;color:#475467}.attendance-status button.active.present{border-color:#14805e4d;background:var(--green-soft);color:var(--green)}.attendance-status button.active.absent{border-color:#b423184d;background:var(--red-soft);color:var(--red)}.attendance-member-picker{display:grid;gap:8px;border:1px solid rgba(180,35,24,.16);border-radius:8px;background:#fff8f7;padding:10px}.attendance-member-picker>span{color:#8f2d23;font-size:12px;font-weight:900}.attendance-member-picker>div{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.attendance-member-picker button{display:grid;gap:2px;min-height:48px;border:1px solid #f0c5c0;border-radius:8px;background:#fff;color:#344054;padding:7px 9px;text-align:left;cursor:pointer}.attendance-member-picker button.active{border-color:#b423186b;background:#ffe9e6;color:#9b251c;box-shadow:0 0 0 3px #b4231812}.attendance-member-picker small,.attendance-member-picker b{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attendance-member-picker small{color:#7a3440;font-size:11px;font-weight:800}.attendance-member-picker b{color:inherit;font-size:14px;font-weight:900}.attendance-member-readout{margin-top:8px;border-radius:7px;background:#fff4f2;color:#9b251c;padding:6px 8px;font-size:12px;font-weight:850;line-height:1.45;overflow-wrap:anywhere}.attendance-note{min-height:62px;max-height:120px;resize:vertical;line-height:1.5}.family-summary-list{display:grid;gap:12px}.family-summary-card{border:1px solid var(--line);border-radius:8px;background:#fff;overflow:hidden}.family-summary-head{display:grid;grid-template-columns:48px minmax(110px,.8fr) minmax(180px,1.2fr) auto;align-items:center;gap:12px;width:100%;min-height:60px;border:0;border-bottom:1px solid var(--line);background:#fff;padding:12px;text-align:left;cursor:pointer}.family-summary-head strong,.family-summary-head small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.family-summary-head strong{color:#101828;font-size:16px}.family-summary-head small{color:var(--muted);font-weight:800}.family-summary-head b{justify-self:end;border-radius:999px;padding:5px 10px;background:var(--green-soft);color:var(--green);white-space:nowrap}.family-alert-strip{display:flex;flex-wrap:wrap;gap:8px;border-bottom:1px solid #f1d4cf;background:#fff8f7;padding:10px 12px}.family-alert-strip span,.family-alert-strip em{display:inline-flex;align-items:center;gap:6px;border:1px solid #f0c5c0;border-radius:999px;background:#fff;color:#9b251c;padding:4px 8px;font-size:12px;font-style:normal;font-weight:850}.family-alert-strip b{color:#344054;font-weight:950}.family-attendance-grid{display:grid;grid-template-columns:repeat(7,minmax(92px,1fr));gap:8px;padding:12px;overflow-x:auto}.family-attendance-day{display:grid;gap:8px;min-width:92px}.family-attendance-day span{color:var(--subtle);font-size:12px;font-weight:900}.family-attendance-day div{display:grid;grid-template-columns:repeat(4,18px);gap:5px}.status-dot{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:5px;background:#eef2f7;color:#667085;font-size:11px;font-style:normal;font-weight:900}.status-dot.present,.family-detail-row b.present{background:var(--green-soft);color:var(--green)}.status-dot.absent,.family-detail-row b.absent{background:var(--red-soft);color:var(--red)}.status-dot.pending,.family-detail-row b.pending{background:#eef2f7;color:#667085}.family-detail{display:grid;gap:6px;padding:0 12px 12px}.family-detail-row{display:grid;grid-template-columns:minmax(150px,1fr) 62px minmax(160px,1.4fr);align-items:start;gap:10px;padding:8px 0;border-top:1px solid var(--line)}.family-detail-row span{color:#344054;font-weight:800}.family-detail-row b{justify-self:start;border-radius:999px;padding:3px 8px;font-size:12px}.family-detail-row p{margin:0;color:var(--muted);line-height:1.45;overflow-wrap:anywhere}.family-detail-row p strong{display:block;margin-bottom:4px;color:#9b251c;font-size:12px}.mini-record{border-top:1px solid var(--line);padding-top:14px;margin-top:14px}.mini-record strong{display:inline-flex;border-radius:999px;background:var(--brand-soft);color:var(--brand-deep);padding:3px 9px;font-size:13px}.mini-record span{display:block;margin:7px 0;color:var(--muted);font-size:13px}.mini-record p{margin:0;color:#1d2939;line-height:1.65}.mobile-attendance-shell{display:grid;grid-template-columns:128px minmax(0,1fr);gap:10px;align-items:start}.mobile-attendance-sidebar{position:sticky;top:10px;display:grid;gap:10px;max-height:calc(100vh - 84px);overflow-y:auto;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-soft)}.mobile-side-title{color:#101828;font-size:14px;font-weight:900}.mobile-process-list{display:grid;gap:8px}.mobile-process-list button{display:grid;grid-template-columns:24px minmax(0,1fr);align-items:start;gap:7px;min-height:48px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#344054;padding:0 8px;cursor:pointer;text-align:left}.mobile-process-list button.active{border-color:#2357c673;background:var(--brand-soft);color:var(--brand-deep)}.mobile-process-list span{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;background:#eef2f7;font-weight:900}.mobile-process-list b{font-size:13px;line-height:1.25;white-space:normal;overflow-wrap:anywhere}.mobile-attendance-content{min-width:0}.mobile-day-tabs-top{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:12px;padding:8px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-soft)}.mobile-day-tabs-top button{min-height:38px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#344054;cursor:pointer;font-weight:900}.mobile-day-tabs-top button.active{border-color:#2357c673;background:var(--brand);color:#fff}.mobile-attendance-head{padding:14px}.mobile-attendance-head h2{margin-bottom:4px;font-size:16px}.mobile-attendance-head span{display:block;margin-bottom:12px;color:var(--subtle);font-size:13px;font-weight:800}.mobile-attendance-group{margin-bottom:10px}.mobile-attendance-list{display:grid;gap:10px}.mobile-attendance-card{display:grid;gap:10px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:var(--shadow-soft)}.mobile-attendance-main{display:grid;grid-template-columns:34px minmax(0,1fr);align-items:start;gap:8px}.mobile-attendance-main b,.mobile-attendance-main small{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-attendance-main b{color:#101828;font-size:16px}.mobile-attendance-main small{margin-top:4px;color:var(--subtle);font-size:12px;font-weight:700}.mobile-attendance-submit{position:sticky;bottom:12px;width:100%;z-index:5}.loading{display:flex;align-items:center;gap:10px;min-height:180px;color:var(--subtle)}.muted{color:var(--muted)}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1180px){.summary-grid{grid-template-columns:repeat(3,1fr)}.toolbar{grid-template-columns:repeat(2,1fr)}.config-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.secondary{min-height:44px}.attendance-layout{grid-template-columns:1fr}.attendance-points{position:static}.attendance-point-list{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.app{width:min(100% - 24px,560px);padding:14px 0 34px}.topbar{padding:16px;margin-bottom:14px}.topbar svg{display:none}.toolbar{grid-template-columns:1fr;padding:10px}.summary-grid{grid-template-columns:repeat(2,1fr);gap:10px}.summary-card{padding:14px}.report-card{grid-template-columns:1fr;gap:12px}.people-layout{grid-template-columns:1fr}.view-switch{width:100%}.view-switch button{min-width:0}.family-summary-head{grid-template-columns:42px minmax(0,1fr)}.family-summary-head small,.family-summary-head b{grid-column:2;justify-self:start;max-width:100%}.family-attendance-grid{grid-template-columns:repeat(7,96px)}.family-detail-row{grid-template-columns:1fr}.group-tabs{grid-template-columns:repeat(2,1fr)}.people-form{position:static}.people-table{overflow-x:auto}.people-row{min-width:520px}.staff-roster-table .people-row{min-width:880px}.participant-table .people-row{min-width:1260px}.report-side{border-top:1px solid var(--line);padding-top:12px}h1{font-size:23px}.panel{padding:16px}.config-grid,.inline-fields{grid-template-columns:1fr}}@media(max-width:430px){.mobile-attendance-shell{grid-template-columns:112px minmax(0,1fr);gap:8px}.mobile-attendance-sidebar{padding:8px}.mobile-process-list button{grid-template-columns:22px minmax(0,1fr);padding:0 6px}.mobile-process-list b{font-size:12px}.mobile-day-tabs-top{grid-template-columns:repeat(3,minmax(0,1fr))}.attendance-status{gap:4px}.attendance-status button{font-size:13px}}:root{--bg: #f4f6f9;--surface: #ffffff;--surface-soft: #f7f9fc;--surface-muted: #eef2f6;--line: #dde4ee;--line-strong: #c6d0dd;--text: #111827;--subtle: #596579;--muted: #8a95a6;--brand: #1f5eff;--brand-deep: #1647c7;--brand-soft: #edf4ff;--green: #08785f;--green-soft: #e7f6f1;--amber: #9a5b00;--amber-soft: #fff3d7;--red: #bd2b22;--red-soft: #ffe9e6;--shadow: 0 18px 45px rgba(17, 24, 39, .08);--shadow-soft: 0 8px 22px rgba(17, 24, 39, .055);--shadow-hairline: 0 1px 2px rgba(17, 24, 39, .04)}body{background:linear-gradient(180deg,#f8fafc,#f4f6f9 260px),var(--bg);color:var(--text)}.app{width:min(1360px,calc(100% - 56px));padding:24px 0 64px}.app-narrow{width:min(540px,calc(100% - 28px))}.topbar{min-height:82px;margin-bottom:18px;padding:20px 24px;border-color:#c6d0ddd1;border-radius:8px;background:#fffffff5;box-shadow:var(--shadow-soft)}.topbar svg{width:36px;height:36px;padding:7px;border-radius:8px;background:var(--brand-soft);color:var(--brand)}.eyebrow{color:var(--brand-deep);font-size:12px;font-weight:900;letter-spacing:0}h1{color:#0f172a;font-size:27px;font-weight:900}h2{color:#182233;font-size:16px;font-weight:900}.panel,.toolbar,.profile-bar,.admin-tabs,.mobile-tabs,.sub-tabs,.group-tabs button,.summary-card,.mobile-day-tabs-top,.mobile-attendance-sidebar,.mobile-attendance-card{border-color:#c6d0dddb;border-radius:8px;background:#fffffffa;box-shadow:var(--shadow-soft)}.panel{padding:22px}.admin-tabs,.mobile-tabs,.sub-tabs,.view-switch{gap:4px;padding:5px;background:#edf1f7;border-color:#d5deea}.admin-tabs button,.mobile-tabs button,.sub-tabs button,.view-switch button{min-height:40px;border-radius:6px;color:#526074;font-size:14px;font-weight:900}.admin-tabs button.active,.mobile-tabs button.active,.sub-tabs button.active,.view-switch button.active{background:#fff;color:var(--brand-deep);box-shadow:0 1px 2px #1118270f,0 7px 18px #11182714}label{color:#445166;font-size:13px;font-weight:850}input,select,textarea{min-height:42px;border-color:#cbd5e1;border-radius:7px;background:#fff;color:#111827;padding:10px 12px;box-shadow:var(--shadow-hairline)}textarea{min-height:124px}input:hover,select:hover,textarea:hover{border-color:#aab7ca}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px #1f5eff21}.primary{min-height:44px;border-radius:7px;background:linear-gradient(180deg,#2d6bff,#1f5eff);box-shadow:0 9px 22px #1f5eff3d}.primary:hover{background:linear-gradient(180deg,#245ff0,#174bce)}.secondary,.ghost-button,.actions button,.row-actions button,.config-row button,.profile-bar button{border-radius:7px;border-color:#cbd5e1;background:#fff;color:#344054;box-shadow:var(--shadow-hairline)}.secondary{background:#172033;color:#fff}.toolbar{padding:14px}.summary-grid{gap:14px}.summary-card{min-height:106px;padding:18px;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}.summary-card:hover{transform:translateY(-1px);border-color:#b8c5d8;box-shadow:var(--shadow)}.summary-card.active{border-color:#1f5eff61;background:linear-gradient(180deg,#f8fbff,#edf4ff);box-shadow:0 0 0 3px #1f5eff14}.summary-card span,.section-head span,.report-meta span,.report-foot span,.group-tabs span{color:#667085}.summary-card strong{font-size:32px;font-weight:950}.category-tabs{padding-bottom:14px}.category-tabs button,.status-pill,.tag,.check{border-radius:999px}.category-tabs button{border-color:#d5deea;background:#fff;box-shadow:var(--shadow-hairline)}.category-tabs button.active{border-color:#1f5eff5c;background:var(--brand-soft);color:var(--brand-deep)}.section-head{min-height:34px;padding-bottom:12px;border-bottom:1px solid #edf1f6}.report-list,.family-summary-list,.mobile-attendance-list{gap:14px}.report-card,.family-summary-card{border-color:#dce4ef;border-radius:8px;background:#fff;box-shadow:var(--shadow-hairline)}.report-card{padding:18px}.report-card:hover,.family-summary-card:hover,.mobile-attendance-card:hover{border-color:#b9c7db;box-shadow:var(--shadow-soft)}.report-meta b{background:#eef4ff;color:var(--brand-deep)}.report-card-main p{color:#253044;font-size:14px}.status-pill{padding:5px 10px}.config-grid{gap:16px}.config-card,.form-block,.split-form-block,.absent-summary{border-color:#dce4ef;background:#f8fafc;box-shadow:inset 0 1px #ffffffb8}.config-row{border-color:#dce4ef;border-radius:7px}.people-layout{grid-template-columns:minmax(360px,400px) minmax(0,1fr);gap:20px}.people-form{gap:16px}.group-tabs{gap:12px;margin-bottom:16px}.group-tabs button{min-height:64px;padding:0 18px;transition:transform .14s ease,box-shadow .14s ease}.group-tabs button:hover{transform:translateY(-1px)}.group-tabs button.active{border-color:#1f5eff61;background:linear-gradient(180deg,#f8fbff,#edf4ff)}.participant-roster-table,.attendance-table{border-spacing:0}.participant-roster-table th,.participant-roster-table td,.attendance-table th,.attendance-table td{border-color:#dce4ef;border-left:0;border-right:0}.participant-roster-table th,.attendance-table th{position:sticky;top:0;z-index:1;background:#f4f7fb;color:#5b687b}.participant-roster-table tbody tr:hover td,.attendance-table tbody tr:hover td{background:#fbfdff}.participant-roster-table th:first-child,.participant-roster-table td:first-child,.attendance-table th:first-child,.attendance-table td:first-child{border-left:1px solid #dce4ef;border-radius:0}.participant-roster-table th:last-child,.participant-roster-table td:last-child,.attendance-table th:last-child,.attendance-table td:last-child{border-right:1px solid #dce4ef;border-radius:0}.participant-roster-table thead th:first-child,.attendance-table thead th:first-child{border-radius:8px 0 0}.participant-roster-table thead th:last-child,.attendance-table thead th:last-child{border-radius:0 8px 0 0}.participant-roster-table tbody tr:last-child td:first-child,.attendance-table tbody tr:last-child td:first-child{border-radius:0 0 0 8px}.participant-roster-table tbody tr:last-child td:last-child,.attendance-table tbody tr:last-child td:last-child{border-radius:0 0 8px}.multi-line-cell b,.mobile-attendance-main b,.family-summary-head strong{color:#172033;font-weight:900}.note-cell{border:1px solid #edf1f6;background:#f8fafc}.sequence-cell,.attendance-point-list span,.mobile-process-list span,.status-dot{border-radius:7px;background:#eef4ff;color:var(--brand-deep)}.row-actions button:first-child,.people-row button:first-child{color:var(--brand-deep)}.row-actions button:last-child,.actions button.danger-action{color:var(--red)}.attendance-layout{gap:22px}.attendance-point-list button,.attendance-day-list button,.mobile-process-list button,.mobile-day-tabs-top button{border-color:#dce4ef;border-radius:8px;box-shadow:var(--shadow-hairline)}.attendance-point-list button.active,.attendance-day-list button.active,.mobile-process-list button.active{border-color:#1f5eff6b;background:#eef4ff;color:var(--brand-deep);box-shadow:0 0 0 3px #1f5eff14}.attendance-status button{border-color:#d5deea;border-radius:7px;box-shadow:var(--shadow-hairline)}.attendance-status button.active.pending{background:#edf1f7}.attendance-status button.active.present{border-color:#08785f52}.attendance-status button.active.absent{border-color:#bd2b224d}.family-summary-head{min-height:66px;padding:14px}.family-attendance-grid{padding:14px}.profile-bar{padding:14px 16px}.mobile-attendance-card{padding:14px}.mobile-attendance-submit{bottom:14px;min-height:48px}.loading{justify-content:center;border:1px solid #dce4ef;border-radius:8px;background:#fff}@media(max-width:760px){.app{width:min(100% - 20px,560px);padding-top:12px}.topbar{min-height:72px}.panel{padding:16px}.people-layout{grid-template-columns:1fr}.admin-tabs,.mobile-tabs,.sub-tabs{overflow-x:auto}}.participant-roster-table .multi-line-cell,.participant-roster-table .multi-line-cell b,.participant-roster-table .multi-line-cell small,.participant-roster-table .multi-line-cell span{min-width:0;max-width:none;overflow:visible;text-overflow:clip;white-space:nowrap}.participant-roster-table .id-cell span,.participant-roster-table .phone-cell span{display:block;letter-spacing:0;overflow:visible;text-overflow:clip;white-space:nowrap}
