:root{font-family:Arial,Helvetica,sans-serif;color:#162033;background:#eef3f8}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;background:#edf2f7}button,input,select,textarea{font:inherit}h1,h2,h3,p{margin-top:0}.muted{color:#5f6f85}.muted-light{color:#ffffffb8}.small{font-size:13px}.eyebrow{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.7px;color:#456aa0}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;background:linear-gradient(#0c172a61,#0c172a7a),url(/login-background.jpg) center/cover no-repeat}.login-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0f172a1f,#1e40af38)}.login-card{position:relative;z-index:1;width:100%;max-width:520px;background:#fffffff0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:24px;padding:30px;box-shadow:0 22px 55px #0f172a38;display:grid;gap:20px}.login-brand-row{display:grid;grid-template-columns:86px 1fr;gap:16px;align-items:center}.login-logo{width:86px;height:86px;object-fit:contain}.login-form,.report-form{display:grid;gap:14px}label{display:grid;gap:6px;font-weight:600}input,select,textarea{width:100%;border:1px solid #cbd7e5;border-radius:14px;padding:12px 14px;background:#fff}textarea{resize:vertical}.primary-btn,.secondary-btn,.nav-item,.logout-btn{border:none;border-radius:14px;padding:12px 16px;cursor:pointer;font-weight:700}.primary-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}.secondary-btn{background:#e8eff8;color:#1f3456}.error-banner,.alert-box,.danger-box,.demo-box,.note-box{border-radius:16px;padding:14px}.error-banner{background:#fff1f1;color:#9d2b2b}.demo-box,.note-box,.alert-box{background:#f3f7fb}.danger-box{background:#ffe6e6;color:#7f1d1d;margin-bottom:18px}.app-layout{min-height:100vh;display:grid;grid-template-columns:280px 1fr}.sidebar{background:linear-gradient(180deg,#0f172a,#172554);color:#fff;padding:24px 20px;display:flex;flex-direction:column;gap:18px}.brand-block{display:flex;gap:14px;align-items:center}.brand-logo{width:56px;height:56px;object-fit:contain;background:#ffffff14;border-radius:14px;padding:6px}.sidebar-title{font-size:22px;font-weight:800}.sidebar-version{color:#ffffffad;font-size:13px}.card-lite{background:#ffffff14;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:14px;display:grid;gap:6px}.sidebar-nav{display:grid;gap:10px}.nav-item{text-align:left;background:#ffffff0f;color:#fff}.nav-item.active{background:linear-gradient(135deg,#3b82f6,#2563eb)}.sidebar-footer{margin-top:auto;display:grid;gap:14px}.sidebar-note{color:#ffffffbf;font-size:13px;line-height:1.5}.logout-btn{background:#ffffff1f;color:#fff}.workspace{padding:24px;background:linear-gradient(180deg,#f4f7fb,#ebf1f7)}.workspace-header.hero-card{margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;gap:16px}.user-summary{text-align:right;display:grid;gap:4px}.stats-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:20px}.hero-stat,.card,.stat-box{background:#fff;border-radius:20px;box-shadow:0 10px 26px #16203314}.hero-stat{padding:18px;display:grid;gap:8px}.hero-stat span,.stat-box span{color:#5f6f85;font-size:14px}.hero-stat strong,.stat-box strong{font-size:28px}.main-grid{display:grid;grid-template-columns:1.02fr 1.38fr;gap:20px}.left-column,.right-column{display:grid;gap:20px}.card{padding:20px}.card-header{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:14px}.search-input{margin-bottom:14px}.student-list,.report-list,.detail-grid,.stats-grid,.report-form{display:grid;gap:12px}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:14px}.stat-box{padding:16px}.student-row{width:100%;display:flex;justify-content:space-between;gap:12px;text-align:left;border:1px solid #d8e3f0;border-radius:16px;background:#fbfdff;padding:14px;cursor:pointer}.student-row.selected{background:#eaf2ff;border-color:#8fb1e6}.report-item{border:1px solid #d9e4ef;border-radius:16px;padding:16px;background:#fbfdff}.report-top{display:flex;justify-content:space-between;gap:12px;margin-bottom:6px}.report-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.serious-pill,.type-pill{display:inline-flex;padding:7px 12px;border-radius:999px;font-size:12px;font-weight:700}.serious-pill{background:#ffe1e1;color:#9a2020}.type-pill{background:#e9f3ff;color:#1d4ed8}.note-box p{margin-bottom:0}.full-width{grid-column:1 / -1}@media (max-width: 1100px){.app-layout{grid-template-columns:1fr}.sidebar{min-height:auto}.stats-row,.main-grid{grid-template-columns:1fr}}.report-meta-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:10px 0}.open-pill,.resolved-pill{display:inline-flex;padding:7px 12px;border-radius:999px;font-size:12px;font-weight:700}.open-pill{background:#fff3cd;color:#8a5a00}.resolved-pill{background:#ddf7e7;color:#17603a}.danger-btn{border:none;border-radius:14px;padding:12px 16px;cursor:pointer;font-weight:700;background:#ffe3e3;color:#a12323}.header-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.checklist-box{border:1px solid #d8e3f0;border-radius:16px;background:#fbfdff;padding:14px}.checklist-title{font-weight:700;margin-bottom:10px}.checklist-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 14px}.checkbox-row{display:flex;align-items:flex-start;gap:10px;font-weight:500}.checkbox-row input{width:18px;margin-top:2px}.compact-list{line-height:1.5}@media (max-width: 800px){.checklist-grid{grid-template-columns:1fr}}.search-controls{display:grid;gap:12px;margin-bottom:14px}.class-pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.class-pill{border:1px solid #c8d7ea;background:#f7fbff;color:#244264;padding:10px 14px;border-radius:999px;cursor:pointer;font-weight:700}.class-pill.active{background:#eaf2ff;border-color:#7aa4df}.roster-list{display:grid;gap:12px}.roster-row{display:flex;justify-content:space-between;gap:12px;border:1px solid #d8e3f0;border-radius:16px;background:#fbfdff;padding:14px}.seating-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.desk-card{border:1px solid #d8e3f0;border-radius:18px;background:linear-gradient(180deg,#fbfdff,#f3f8ff);padding:14px;display:grid;gap:6px}.desk-seat{font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#456aa0}.button-reset{border:none;text-align:left;cursor:pointer}.seating-page-grid{display:grid;grid-template-columns:340px 1fr;gap:20px}.classroom-card{min-height:720px}.classroom-shell{border:1px solid #d8e3f0;border-radius:22px;padding:18px;background:linear-gradient(180deg,#f6f8fb,#edf2f8)}.teacher-area{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px}.teacher-desk,.board-area{border-radius:18px;padding:14px 18px;font-weight:700}.teacher-desk{min-width:180px;background:linear-gradient(180deg,#a67c52,#8a6341);color:#fff;box-shadow:0 8px 20px #8a634138}.board-area{flex:1;text-align:center;background:#dfe7f2;color:#29405f;border:1px solid #c6d5e6}.fixed-seat-grid{display:grid;gap:18px}.seat-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:18px}.seat-desk{position:relative;min-height:138px;border-radius:20px;border:1px solid #cfdae7;background:#fff;padding:14px 12px 12px;cursor:pointer;box-shadow:0 8px 20px #16203314;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.seat-desk:hover{transform:translateY(-3px);box-shadow:0 16px 28px #1620331f}.seat-desk.empty{background:#f8fbff}.seat-desk.move-source{border:2px solid #1d4ed8;box-shadow:0 0 0 4px #2563eb1f}.seat-desk.move-target{border-style:dashed;border-color:#5b86c5}.desk-top{width:56px;height:26px;margin:0 auto 6px;border-radius:10px;background:linear-gradient(180deg,#a67c52,#8c6543)}.desk-chair{width:30px;height:30px;border-radius:12px;margin:0 auto 10px;background:linear-gradient(180deg,#4d77a8,#355d8a)}.desk-meta{display:grid;gap:4px;text-align:center}.desk-meta strong{font-size:14px;line-height:1.2}.desk-meta span{color:#5f6f85;font-size:12px}.desk-seat-label{font-size:11px!important;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#456aa0!important}.seat-badge{min-width:46px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#e8f0fb;color:#1f4672;font-size:12px;font-weight:700}.compact-roster{margin-top:14px;max-height:420px;overflow:auto}.move-banner{margin-top:14px;display:grid;gap:12px;border-radius:18px;padding:14px;background:#eaf2ff;color:#1d3d63}.seat-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;display:flex;align-items:center;justify-content:center;padding:24px;z-index:40}.seat-modal{width:min(100%,500px);background:#fff;border-radius:24px;padding:22px;box-shadow:0 26px 70px #0f172a38}.action-menu{width:min(100%,420px)}.compact-header{margin-bottom:18px}.icon-close{width:40px;height:40px;border:none;border-radius:999px;background:#edf2f8;color:#274365;font-size:24px;cursor:pointer}.action-menu-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px}.action-chip{border:none;border-radius:18px;padding:18px 14px;font-weight:800;cursor:pointer}.action-chip.talk{background:#e8f0fb;color:#1d4f89}.action-chip.warning{background:#fff3d8;color:#8b5a00}.action-chip.serious{background:#ffe2e2;color:#962626}.action-chip.move{background:#e8f7ef;color:#17603a}.modal-actions{display:flex;justify-content:flex-end;gap:12px;grid-column:1 / -1}.quick-report-modal .report-form{grid-template-columns:repeat(2,minmax(0,1fr))}@media (max-width: 1100px){.seating-page-grid{grid-template-columns:1fr}}@media (max-width: 780px){.teacher-area,.seat-row,.quick-report-modal .report-form,.action-menu-grid{grid-template-columns:1fr}.teacher-area{display:grid}.seat-row{gap:12px}}.hero-title-row{display:flex;align-items:center;gap:18px}.hero-logo{width:84px;height:84px;object-fit:contain}.large-login-logo{width:104px;height:104px}.brand-logo{width:78px;height:78px;padding:8px}.header-actions,.report-actions,.branding-button-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.tiny-btn{padding:9px 12px;border-radius:12px}.danger-btn{border:none;border-radius:14px;padding:12px 16px;cursor:pointer;font-weight:700;background:#fee2e2;color:#9f1239}.report-item{border:1px solid #d8e3f0;border-radius:18px;padding:16px;background:#fbfdff;display:grid;gap:12px}.report-top,.report-meta-row,.roster-row,.branding-preview-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.report-snippet{color:#31435f;line-height:1.5}.type-pill,.serious-pill,.open-pill,.resolved-pill{display:inline-flex;align-items:center;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700}.type-pill{background:#e8f0fb;color:#1d4f89}.serious-pill{background:#ffe2e2;color:#962626}.open-pill{background:#eef2ff;color:#3730a3}.resolved-pill{background:#e8f7ef;color:#17603a}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a7a;display:flex;align-items:center;justify-content:center;padding:24px;z-index:50}.modal-card{width:min(100%,760px);background:#fff;border-radius:24px;padding:22px;box-shadow:0 26px 70px #0f172a3d}.large-modal{max-height:90vh;overflow:auto}.review-grid,.branding-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.review-item,.review-block,.branding-preview{background:#f8fbff;border:1px solid #d9e4f2;border-radius:18px;padding:14px}.review-item span{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.8px;color:#667892;margin-bottom:6px}.review-block,.full-width{grid-column:1 / -1}.school-logo-preview{max-width:88px;max-height:88px;object-fit:contain;border-radius:14px;background:#fff;padding:8px;border:1px solid #d8e3f0}.school-logo-placeholder{min-width:88px;min-height:88px;display:flex;align-items:center;justify-content:center;text-align:center;border-radius:14px;background:#edf2f8;color:#607188;padding:8px;font-size:12px}.preview-sheet-line{margin:14px 0 8px;font-weight:800;font-size:18px}.file-upload-btn{display:inline-flex;align-items:center}.branding-upload-row{display:flex;justify-content:space-between;gap:14px;align-items:center}.roster-list,.roster-manager-list{display:grid;gap:10px;margin-top:16px}@media (max-width: 780px){.hero-title-row,.review-grid,.branding-grid,.branding-upload-row,.report-actions,.header-actions,.report-top,.report-meta-row,.roster-row,.branding-preview-header{grid-template-columns:1fr;display:grid}.brand-block{align-items:flex-start}}.mode-toggle{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0}.toggle-btn{border:1px solid #c8d3e1;background:#f3f6fb;color:#233247;border-radius:12px;padding:12px 14px;font-weight:700;cursor:pointer}.toggle-btn.active{background:#233247;color:#fff;border-color:#233247}.split-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.success-banner{background:#e8f7ea;color:#1c6b32;border:1px solid #bfe3c8;border-radius:12px;padding:12px 14px}.inactive-pill{background:#f1f3f7;color:#617084;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700;text-transform:capitalize}.compact-stats-row{grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 780px){.split-grid,.compact-stats-row,.mode-toggle{grid-template-columns:1fr}}.assign-seat-row{gap:12px;align-items:center}.assign-seat-controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.assign-seat-select{min-width:160px;margin-bottom:0}
