*{box-sizing:border-box}html{min-height:100%}body{margin:0;min-height:100%;font-family:Tahoma,"Noto Sans Thai",Arial,sans-serif;background:#eef3f5;color:#17242b;font-size:15px;line-height:1.55}a{color:inherit}.app-shell{display:flex;min-height:100vh}.sidebar{position:fixed;left:0;top:0;bottom:0;width:276px;background:#103846;color:#fff;padding:18px;display:flex;flex-direction:column;gap:18px;box-shadow:8px 0 28px rgba(16,56,70,.18);z-index:20}.school-card{display:flex;gap:12px;align-items:center;padding:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:8px}.school-card img,.logo-fallback{width:54px;height:54px;object-fit:contain;background:#fff;border-radius:8px;padding:5px;color:#103846;display:grid;place-items:center;font-weight:bold}.school-card strong{display:block;font-size:16px;line-height:1.35}.school-card span{display:block;font-size:12px;opacity:.78;margin-top:2px}.login-side-copy{margin-top:auto;color:#d7e9ee;background:rgba(255,255,255,.06);border-radius:8px;padding:14px}.side-nav{display:flex;flex-direction:column;gap:6px}.side-nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;text-decoration:none;color:#dcecf0;border:1px solid transparent}.side-nav a:hover,.side-nav a.active{background:#e9f6f8;color:#103846;border-color:#d5edf1}.side-nav span{width:22px;text-align:center}.nav-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#96bdc7;margin:10px 10px 2px}.user-card{margin-top:auto;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:14px}.user-card span,.user-card em{display:block;color:#c5dce3;font-style:normal;font-size:12px}.user-card strong{display:block;margin:3px 0;font-size:16px}.user-card a{display:inline-block;margin-top:10px;color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.45)}.main-area{width:100%;padding-left:276px}.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:22px 30px;background:rgba(255,255,255,.9);border-bottom:1px solid #dce7eb;position:sticky;top:0;z-index:10;backdrop-filter:blur(10px)}.topbar p{margin:0;color:#657983;font-size:13px}.topbar h1{margin:2px 0 0;color:#123c4a;font-size:24px}.quick-add{background:#1f7188;color:#fff;border-radius:8px;padding:10px 14px;text-decoration:none;white-space:nowrap}.container{width:min(1160px,94vw);margin:22px auto 72px}.panel,.card{background:#fff;border:1px solid #dce7eb;border-radius:8px;padding:20px;margin-bottom:18px;box-shadow:0 10px 26px rgba(18,60,74,.06)}.page-hero{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;background:#fff;border:1px solid #dce7eb;border-radius:8px;padding:22px;margin-bottom:18px;box-shadow:0 10px 26px rgba(18,60,74,.06)}.page-hero h1,.panel h1,.panel h2,.panel h3,.card h2{margin:0 0 8px;color:#123c4a}.page-hero p,.panel p{margin:0;color:#657983}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#2f7b8d;font-weight:bold}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.field label{display:block;font-weight:bold;margin-bottom:6px;color:#20353e}.field small{display:block;color:#6c7d85;margin-top:6px}.field input,.field select,.field textarea{width:100%;padding:10px 12px;border:1px solid #c9d7dd;border-radius:8px;font:inherit;background:#fff;color:#17242b;transition:border .15s,box-shadow .15s}.field textarea{min-height:92px;resize:vertical}.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:#23808f;box-shadow:0 0 0 3px rgba(35,128,143,.14)}.actions,.toolbar-actions,.bottom-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.actions{margin-top:16px}.btn,button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:8px;background:#1f7188;color:#fff;padding:10px 14px;text-decoration:none;font:inherit;cursor:pointer;min-height:42px}.btn:hover,button:hover,.quick-add:hover{filter:brightness(.97)}.btn.secondary{background:#536b75}.btn.danger{background:#b94646}.btn.light{background:#e8f0f3;color:#173845}.notice,.error{padding:12px 14px;border-radius:8px;margin-bottom:14px}.notice{background:#eaf8ef;border:1px solid #b7e1c5;color:#245e35}.error{background:#fff0f0;border:1px solid #e3bbbb;color:#8f2e2e}.table-wrap{overflow:auto;border:1px solid #dce7eb;border-radius:8px;background:#fff}.table{width:100%;border-collapse:collapse;background:#fff}.table th,.table td{border-bottom:1px solid #e7eef1;padding:12px;text-align:left;vertical-align:middle;white-space:nowrap}.table th{background:#f3f8fa;color:#49616b;font-size:13px}.table tr:hover td{background:#fbfdfe}.badge{display:inline-block;border-radius:999px;padding:4px 9px;font-size:12px;background:#e8f0f3;color:#214451}.badge.good{background:#e8f8ee;color:#23623b}.badge.muted{background:#f1f3f4;color:#6c7377}.stat{background:#fff;border:1px solid #dce7eb;border-radius:8px;padding:18px;box-shadow:0 10px 26px rgba(18,60,74,.05)}.stat b{display:block;font-size:34px;color:#1f7188;line-height:1}.stat span{display:block;margin-top:8px;color:#627680}.menu-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.menu-card{display:block;text-decoration:none;background:#fff;border:1px solid #dce7eb;border-radius:8px;padding:18px;box-shadow:0 10px 26px rgba(18,60,74,.05)}.menu-card strong{display:block;color:#123c4a;font-size:18px;margin-bottom:6px}.menu-card span{color:#657983}.menu-card:hover{border-color:#9ccbd5;transform:translateY(-1px)}.login-page{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:22px;align-items:stretch}.login-welcome{background:#fff;border:1px solid #dce7eb;border-radius:8px;padding:28px;box-shadow:0 10px 26px rgba(18,60,74,.06)}.login-welcome h1{font-size:32px;color:#123c4a;margin:0 0 10px}.login-panel{background:#fff;border:1px solid #dce7eb;border-radius:8px;padding:24px;box-shadow:0 10px 26px rgba(18,60,74,.06)}.photo-preview{max-width:180px;max-height:120px;border:1px solid #ddd;border-radius:8px;margin-top:8px}.settings-preview{display:flex;align-items:center;gap:14px;border:1px solid #dce7eb;border-radius:8px;padding:14px;background:#fbfdfe}.settings-preview img{width:86px;height:86px;object-fit:contain;background:#fff;border:1px solid #dce7eb;border-radius:8px;padding:6px}footer{position:fixed;left:276px;right:0;bottom:0;text-align:center;background:rgba(255,255,255,.94);border-top:1px solid #d9e2e7;padding:10px;color:#52616a;z-index:8}.print-only{display:none}

.visit-shell{max-width:1120px;margin:0 auto}.visit-hero{display:flex;justify-content:space-between;gap:20px;align-items:flex-end;background:#fff;color:#17242b;border:1px solid #dce7eb;border-radius:8px;padding:24px;margin-bottom:18px;box-shadow:0 10px 26px rgba(18,60,74,.06)}.visit-hero h1{color:#123c4a;margin:2px 0 8px;font-size:30px}.visit-hero p{margin:0;color:#657983}.hero-meta{min-width:220px;background:#f3f8fa;border:1px solid #dce7eb;border-radius:8px;padding:14px}.hero-meta span,.hero-meta em{display:block;font-style:normal;color:#657983}.hero-meta strong{display:block;font-size:18px;margin:4px 0}.visit-form{display:block}.form-toolbar{position:sticky;top:91px;z-index:5;display:flex;justify-content:space-between;align-items:center;gap:14px;background:#fff;border:1px solid #d9e5ea;border-radius:8px;padding:12px 14px;margin-bottom:16px;box-shadow:0 8px 22px rgba(20,48,61,.08)}.form-toolbar span{display:block;color:#667984;font-size:13px}.form-section{background:#fff;border:1px solid #dce7eb;border-radius:8px;padding:20px;margin-bottom:16px;box-shadow:0 10px 26px rgba(18,60,74,.05)}.section-title{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px;border-bottom:1px solid #edf2f4;padding-bottom:14px}.section-title>span{display:grid;place-items:center;width:38px;height:38px;border-radius:8px;background:#e7f3f5;color:#15566a;font-weight:bold}.section-title h2{margin:0 0 4px;font-size:21px;color:#123c4a}.section-title p{margin:0;color:#6a7a83}.form-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.field-wide{grid-column:span 2}.form-grid .field-wide textarea{min-height:112px}.choice-field{grid-column:1/-1;border:1px solid #edf2f4;border-radius:8px;padding:12px;background:#fbfdfe}.choice-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.choice{display:flex!important;align-items:center;gap:8px;margin:0!important;padding:10px 11px;border:1px solid #d7e3e8;border-radius:8px;background:#fff;font-weight:normal!important;min-height:42px}.choice input,.risk-item input{width:auto!important}.choice:has(input:checked),.risk-item:has(input:checked){border-color:#23808f;background:#eef9fb;color:#15566a}.risk-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px}.risk-item{display:flex;align-items:center;gap:8px;border:1px solid #d7e3e8;background:#fff;border-radius:8px;padding:11px 12px;min-height:44px}.photo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.photo-card{border:1px solid #d9e5ea;border-radius:8px;padding:14px;background:#fbfdfe}.photo-card label{display:block;font-weight:bold;margin-bottom:10px}.photo-card img,.photo-empty{width:100%;height:180px;border-radius:8px;border:1px solid #dce7eb;object-fit:cover;background:#eef4f6}.photo-empty{display:grid;place-items:center;color:#71838c}.photo-card input{margin-top:12px;width:100%}.bottom-actions{justify-content:flex-end;background:#fff;border:1px solid #d9e5ea;border-radius:8px;padding:14px;margin-bottom:20px}

.report-paper{background:#fff;border:1px solid #dce7eb;border-radius:8px;padding:28px;box-shadow:0 10px 26px rgba(18,60,74,.06)}.report-paper h2{text-align:center;margin-top:0;color:#123c4a}.report-paper ol{padding-left:28px}.report-paper li{margin-bottom:10px}.summary-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}.summary-strip .stat{padding:14px}.summary-strip b{font-size:28px}

@media(max-width:1100px){.sidebar{position:static;width:100%;border-radius:0}.app-shell{display:block}.main-area{padding-left:0}.side-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.user-card{margin-top:0}footer{left:0}.form-toolbar{top:0}.menu-grid{grid-template-columns:1fr 1fr}}
@media(max-width:780px){.topbar{align-items:flex-start;flex-direction:column;padding:18px}.quick-add{width:100%;text-align:center}.container{width:94vw;margin-top:16px}.grid,.grid-3,.menu-grid,.login-page,.summary-strip{grid-template-columns:1fr}.page-hero{align-items:flex-start;flex-direction:column}.form-grid,.choice-grid,.risk-grid{grid-template-columns:1fr}.field-wide{grid-column:span 1}.photo-grid{grid-template-columns:1fr}.visit-hero{align-items:flex-start;flex-direction:column;padding:20px}.hero-meta{width:100%}.visit-hero h1{font-size:24px}.form-toolbar{position:static;align-items:stretch;flex-direction:column}.toolbar-actions,.bottom-actions{display:grid;grid-template-columns:1fr;width:100%}.toolbar-actions .btn,.toolbar-actions button,.bottom-actions .btn,.bottom-actions button{width:100%;text-align:center}.form-section{padding:16px}.side-nav{grid-template-columns:1fr}}
@media print{body{background:#fff;font-size:14px}.sidebar,.topbar,.actions,.no-print,footer,.form-toolbar,.bottom-actions{display:none!important}.main-area{padding-left:0}.container{width:100%;margin:0}.panel,.card,.report-paper{box-shadow:none;border:0;padding:0}.print-page{page-break-after:always}.print-only{display:block}.table th,.table td{border:1px solid #222;padding:6px}.photo-preview{max-width:210px;max-height:150px}.print-lines{line-height:2}.dotted{border-bottom:1px dotted #333;display:inline-block;min-width:120px}.print-footer{position:fixed;bottom:0;left:0;right:0;text-align:center;font-size:12px}}

.field input::placeholder,.field textarea::placeholder{color:#8a9aa3;opacity:1}

body{--theme-dark:#103846;--theme-main:#1f7188;--theme-soft:#e7f3f5;--theme-border:#9ccbd5;--theme-text:#123c4a;--theme-focus:rgba(35,128,143,.14)}
body.theme-blue{--theme-dark:#193b70;--theme-main:#2563eb;--theme-soft:#eaf1ff;--theme-border:#9bbcff;--theme-text:#153468;--theme-focus:rgba(37,99,235,.14)}
body.theme-green{--theme-dark:#1f4f38;--theme-main:#2f855a;--theme-soft:#eaf7ef;--theme-border:#9ad3b2;--theme-text:#1c4932;--theme-focus:rgba(47,133,90,.14)}
body.theme-purple{--theme-dark:#44306b;--theme-main:#7c3aed;--theme-soft:#f1eafd;--theme-border:#c2a5f5;--theme-text:#3c2a60;--theme-focus:rgba(124,58,237,.14)}
body.theme-rose{--theme-dark:#71324a;--theme-main:#d9467d;--theme-soft:#fff0f5;--theme-border:#f3a9c4;--theme-text:#693047;--theme-focus:rgba(217,70,125,.14)}
body.theme-slate{--theme-dark:#25313d;--theme-main:#475569;--theme-soft:#eef2f5;--theme-border:#b7c2cc;--theme-text:#24313f;--theme-focus:rgba(71,85,105,.14)}
.sidebar{background:var(--theme-dark);box-shadow:8px 0 28px color-mix(in srgb,var(--theme-dark) 28%,transparent)}.logo-fallback{color:var(--theme-dark)}.side-nav a:hover,.side-nav a.active{background:var(--theme-soft);color:var(--theme-dark);border-color:var(--theme-border)}.nav-label{color:var(--theme-border)}.topbar h1,.page-hero h1,.panel h1,.panel h2,.panel h3,.card h2,.visit-hero h1,.section-title h2,.report-paper h2,.menu-card strong{color:var(--theme-text)}.quick-add,.btn,button{background:var(--theme-main)}.btn.secondary{background:var(--theme-dark)}.btn.light{background:var(--theme-soft);color:var(--theme-text)}.eyebrow,.stat b{color:var(--theme-main)}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--theme-main);box-shadow:0 0 0 3px var(--theme-focus)}.menu-card:hover{border-color:var(--theme-border)}.section-title>span{background:var(--theme-soft);color:var(--theme-main)}.choice:has(input:checked),.risk-item:has(input:checked){border-color:var(--theme-main);background:var(--theme-soft);color:var(--theme-text)}
.theme-picker{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.theme-option{display:flex;align-items:center;gap:10px;border:1px solid #d7e3e8;border-radius:8px;background:#fff;padding:11px 12px;cursor:pointer}.theme-option input{width:auto!important}.theme-option .swatch{width:30px;height:30px;border-radius:8px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.5)}.theme-option:has(input:checked){border-color:var(--theme-main);background:var(--theme-soft)}.theme-swatch-teal .swatch{background:linear-gradient(135deg,#103846,#1f7188)}.theme-swatch-blue .swatch{background:linear-gradient(135deg,#193b70,#2563eb)}.theme-swatch-green .swatch{background:linear-gradient(135deg,#1f4f38,#2f855a)}.theme-swatch-purple .swatch{background:linear-gradient(135deg,#44306b,#7c3aed)}.theme-swatch-rose .swatch{background:linear-gradient(135deg,#71324a,#d9467d)}.theme-swatch-slate .swatch{background:linear-gradient(135deg,#25313d,#475569)}.theme-preview{display:grid;grid-template-columns:92px 1fr;gap:0;margin-top:14px;border:1px solid #dce7eb;border-radius:8px;overflow:hidden;background:#fff}.preview-sidebar{background:var(--theme-dark);min-height:130px}.preview-content{padding:18px}.preview-content span,.preview-content strong{display:block;border-radius:999px;background:var(--theme-soft);height:12px;margin-bottom:12px}.preview-content span{width:70%}.preview-content strong{width:45%}.preview-content button{margin-top:8px}
