.notice__scrim{position:fixed;inset:0;z-index:1000;background:#00000073;display:grid;place-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.notice__card{width:min(720px,92vw);background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 10px 30px #0000002e;padding:20px 22px;text-align:center}.notice__title{margin:0 0 8px;font-size:clamp(18px,3.2vw,22px);font-weight:800;color:#0f172a}.notice__text{margin:6px 0;font-size:14px;line-height:1.7;color:#374151}.notice__actions{margin-top:12px;display:flex;justify-content:center}.notice__btnPrimary{background:#0b1733;color:#fff;border:0;border-radius:10px;padding:10px 16px;font-weight:800;cursor:pointer}.notice__btnPrimary:focus{outline:3px solid rgba(2,6,23,.12);outline-offset:2px}*,*:before,*:after{box-sizing:border-box}:root{--bg: #f5f7fb;--paper: #ffffff;--ink: #101828;--muted: #667085;--primary: #ffd400;--primary-ink: #1a1a1a;--ring: rgba(17, 24, 39, .08);--radius: 16px;--shadow: 0 1px 2px rgba(16,24,40,.06), 0 8px 24px rgba(16,24,40,.08)}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Noto Sans Thai,sans-serif;background:#0b1733}.labboy{min-height:100%;background:var(--paper);max-width:1120px;margin:0 auto;box-shadow:0 0 0 24px #0b1733}.topbar{position:relative;z-index:15;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 16px 0 20px;border-bottom:1px solid #eef2f6;background:var(--paper)}.topbar__brand{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--ink)}.brand__icon{font-size:18px}.brand__name{font-size:18px;letter-spacing:.2px}.hamburger{width:40px;height:40px;display:grid;place-items:center;border:0;background:transparent;cursor:pointer;z-index:20}.hamburger span{display:block;width:22px;height:2px;background:#111;margin:3px 0;border-radius:2px;transition:.25s ease}.hamburger.active span:nth-child(1){transform:translateY(5px) rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}.dropdown-menu{position:absolute;top:64px;right:0;width:200px;background:#e0e0e0;border-left:2px solid #0b174a;border-bottom:2px solid #0b174a;display:flex;flex-direction:column;box-shadow:0 8px 20px #0000001f;animation:slideIn .16s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.dropdown-menu a{padding:12px 20px;text-align:center;font-size:20px;color:#111;text-decoration:none;border-bottom:2px solid #0b174a}.dropdown-menu a:last-child{border-bottom:0}.dropdown-menu a:hover{background:#ffd400}.scrim{position:fixed;inset:0;background:transparent;border:0;padding:0;z-index:12}.intro{background:var(--primary);color:var(--primary-ink);padding:18px 20px;border-bottom:1px solid #f0c500;max-width:1000px;margin:16px auto 24px;text-align:center}.intro__title{margin:0 0 6px;font-size:22px;line-height:1.2}.intro__text{margin:0;font-size:14px;line-height:1.6}.cards{padding:20px;display:grid;gap:18px}.card{background:var(--paper);border:1px solid #e5e7eb;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card__media{position:relative;aspect-ratio:16 / 9;background:#e5e7eb}.card__media img{width:100%;height:100%;object-fit:cover;display:block}.card__headline{position:absolute;inset:auto 0 10px;padding:0 16px;text-align:left}.card__headlineMain{display:inline-block;font-weight:900;font-size:clamp(22px,6vw,36px);letter-spacing:.5px;color:#ffe900;text-shadow:0 2px 6px rgba(0,0,0,.55);background:#00000059;padding:4px 8px;border-radius:8px}.card__body{padding:14px 16px 18px}.card__title{margin:0 0 6px;font-size:16px;color:var(--ink)}.card__subtitle{color:var(--muted);font-weight:600}.card__desc{margin:0 0 12px;color:var(--muted);font-size:14px;line-height:1.6}.card__button{appearance:none;border:0;background:#111827;color:#fff;padding:10px 14px;border-radius:10px;font-weight:600;box-shadow:0 1px 2px #0000001a;cursor:pointer}.card__button:focus{outline:2px solid transparent;box-shadow:0 0 0 3px var(--ring)}.card__button:hover{filter:brightness(1.05)}@media (min-width: 1024px){.intro{padding:14px 40px}.cards{padding:40px;grid-template-columns:repeat(3,1fr);gap:22px;place-items:start}.card{border-radius:12px}.card__media{aspect-ratio:1 / 1}.card__headlineMain{font-size:22px}.card__body{padding:12px 12px 16px}.card__title{font-size:14px;margin-bottom:6px}.card__desc{font-size:12px;line-height:1.5}.card__button{width:100%;padding:8px 10px;font-size:14px}}.card__media--clickable{cursor:pointer;position:relative}.card__media--clickable:after{content:"";position:absolute;inset:0}.card__media--clickable:hover img{filter:brightness(.92);transition:filter .2s ease}.card__media--clickable:focus{outline:none}.card__media--clickable:focus-visible{outline:3px solid #2563eb;outline-offset:2px}.footer{text-align:center;color:#9aa4b2;font-size:12px;padding:28px 16px 40px}:root{--card: #ffffff;--ink: #0f172a;--muted: #64748b;--brand: #0b1733;--chip: #0b174a;--ok: #16a34a;--no: #ef4444;--ring: rgba(2,6,23,.12);--radius: 14px;--shadow-md: 0 2px 6px rgba(2,6,23,.08), 0 8px 24px rgba(2,6,23,.08);--shadow-sm: 0 1px 3px rgba(2,6,23,.08), 0 1px 2px rgba(2,6,23,.06)}.equip__wrap{background:var(--card);max-width:1200px;margin:0 auto;box-shadow:0 0 0 24px #0b1733;min-height:100vh}.equip__container{padding:18px 20px 36px}.equip__title{text-align:center;font-weight:700;color:var(--ink);margin-top:4px;margin-bottom:4px}.equip__progress{font-size:12px;color:var(--muted);margin:6px 2px 12px}.equip__grid{display:grid;grid-template-columns:1fr;gap:18px}@media (min-width: 1024px){.equip__grid{grid-template-columns:2fr 1fr;align-items:start}}.equip__left{background:#f8fafc;border:1px solid #e5e7eb;border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px}.equip__image{width:clamp(220px,40vw,320px);margin:8px auto 14px;border-radius:12px;overflow:hidden;background:#e5e7eb;box-shadow:var(--shadow-sm)}.equip__image img{display:block;width:100%;height:auto;object-fit:cover}.equip__question,.equip__question2{color:var(--ink);font-weight:600;margin:10px 2px 8px}.equip__choices{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:8px}.equip__chip{border:0;background:var(--chip);color:#fff;padding:8px 14px;border-radius:12px;font-weight:700;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .05s ease}.equip__chip:hover{transform:translateY(-1px)}.equip__chip.is-picked{outline:3px solid var(--ring)}.equip__feedback{margin-top:10px;padding:12px 14px;border-radius:12px;font-size:14px;box-shadow:var(--shadow-sm)}.equip__feedback--right{background:#d1fae5;color:#065f46}.equip__feedback--wrong{background:#fee2e2;color:#7f1d1d}.equip__buttons{margin-top:14px;display:flex;justify-content:flex-end}.equip__next{background:var(--brand);color:#fff;border:0;padding:10px 16px;border-radius:12px;font-weight:800;cursor:pointer;box-shadow:var(--shadow-md)}.equip__next[disabled]{opacity:.5;cursor:not-allowed;filter:grayscale(.2)}.equip__aside{background:#f8fafc;border:1px solid #e5e7eb;border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px;min-width:260px}.equip__legend{display:flex;align-items:center;gap:12px;color:var(--ink);font-weight:600;margin-bottom:10px}.dot,.equip__dot{width:12px;height:12px;border-radius:3px;display:inline-block}.dot--right{background:var(--ok)}.dot--wrong{background:var(--no)}.dot--unk{background:#e2e8f0}.equip__table{display:grid;gap:10px}.equip__row{display:flex;justify-content:space-between;align-items:center;gap:8px}.equip__name{color:var(--ink);font-size:14px}.equip__table{display:grid;gap:6px}.equip__thead,.equip__row{display:grid;grid-template-columns:1fr 80px 80px;align-items:center;column-gap:12px}.equip__thead{font-weight:600;color:#0f172a;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:10px;padding:8px 10px}.equip__thCenter,.equip__qtyCell,.equip__statusCell{text-align:center}.equip__row{padding:6px 8px;border-radius:8px;border:1px solid #eef2f7;background:#fff}.equip__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.equip__qtyBadge{font-size:12px;padding:2px 8px;border-radius:999px;background:#eef6ff;border:1px solid #b6d4fe;display:inline-block;line-height:1.6}.equip__qtyDash{color:#9ca3af}.topbar{height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 16px 0 20px;background:#fff;border-bottom:1px solid #eef2f6}.topbar__brand{display:flex;align-items:center;gap:8px}.brand__icon{width:28px;height:28px;object-fit:contain}.brand__name{font-weight:700;letter-spacing:.2px;color:var(--ink)}.content__wrap{background:#fff;max-width:900px;margin:0 auto;box-shadow:0 0 0 24px #0b1733;min-height:100vh}.content__container{padding:16px 18px 40px}.content__title{text-align:center;font-size:20px;margin:6px 0 10px;color:#0f172a}.content__subtitle{font-size:14px;color:#475569;margin-top:4px}.content__card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:14px;padding:14px 16px;box-shadow:0 1px 3px #0206170f;margin-bottom:12px}.content__card h3{margin:0 0 6px;font-size:16px;color:#0f172a}.content__theory{margin-bottom:6px}.content__link{display:inline-block;color:#b91c1c;text-decoration:underline;font-weight:600}.content__steps{margin:0 0 0 18px;padding:0;line-height:1.7}.content__video{position:relative;width:100%;padding-top:56.25%;background:#e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0206170f}.content__video iframe,.content__video video{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}.content__actions{display:flex;justify-content:flex-end;margin-top:10px}.content__quizbtn{background:#0b1733;color:#fff;font-weight:800;border:0;border-radius:12px;padding:10px 16px;cursor:pointer;box-shadow:0 2px 6px #0206171f}:root{--ink:#0f172a;--muted:#64748b;--panel:#f8fafc;--border:#e5e7eb;--shadow:0 2px 6px rgba(2,6,23,.08), 0 8px 24px rgba(2,6,23,.06);--brand:#0b1733;--ok:#22c55e;--no:#ef4444;--warn:#f59e0b;--radius:14px}.quiz__wrap{background:#fff;max-width:900px;margin:0 auto;min-height:100vh;box-shadow:0 0 0 24px #0b1733}.quiz__container{padding:18px 20px 40px}.quiz__title{text-align:center;margin:8px 0 14px;color:var(--ink);font-weight:800;letter-spacing:.2px}.quiz__qhead{margin-bottom:14px}.quiz__qnum{font-size:14px;color:var(--muted);margin-bottom:8px}.quiz__qbar{height:8px;background:#eceff5;border-radius:999px;overflow:hidden;box-shadow:inset 0 1px 2px #0206170d}.quiz__qbar span{display:block;height:100%;width:0%;background:linear-gradient(90deg,#ef4444,#fb7185);transition:width .25s ease;border-radius:999px}.quiz__question{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px;min-height:90px;display:flex;align-items:center;box-shadow:var(--shadow);color:var(--ink);margin-bottom:14px}.quiz__choices{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}@media (max-width:560px){.quiz__choices{grid-template-columns:1fr}}.quiz__btn{border:1px solid var(--border);background:#fff;color:var(--ink);border-radius:12px;padding:12px 14px;font-weight:600;cursor:pointer;box-shadow:0 1px 3px #0206170f;transition:transform .06s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease}.quiz__btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.quiz__btn:focus{outline:3px solid rgba(2,6,23,.08);outline-offset:2px}.quiz__btn.correct{background:#dcfce7;border-color:#86efac}.quiz__btn.wrong{background:#fee2e2;border-color:#fecaca}.quiz__panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:0 1px 3px #0206170f;margin-bottom:18px}.quiz__panelTitle{font-weight:700;margin-bottom:6px;color:var(--ink)}.quiz__hint{color:var(--muted)}.quiz__state{font-weight:800;margin-bottom:8px}.quiz__state.ok{color:var(--ok)}.quiz__state.no{color:var(--no)}.quiz__scorebar{height:12px;background:#eef2f7;border-radius:8px;overflow:hidden;margin-bottom:10px}.quiz__scorebar .ok{display:block;height:100%;width:0;background:linear-gradient(90deg,#22c55e,#16a34a);transition:width .25s ease}.quiz__stats{display:flex;gap:18px;color:#334155;font-size:14px}.quiz__nextWrap{display:flex;justify-content:flex-end}.quiz__next{background:var(--brand);color:#fff;border:0;border-radius:12px;padding:10px 16px;font-weight:800;cursor:pointer;box-shadow:var(--shadow)}.quiz__next:disabled{opacity:.5;cursor:not-allowed}.quiz__summary{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:0 1px 3px #0206170f}.quiz__actions{display:flex;gap:10px;margin-top:12px}.quiz__btnPrimary{background:var(--brand);color:#fff;border:0;border-radius:10px;padding:10px 14px;cursor:pointer;box-shadow:var(--shadow);font-weight:800}.quiz__btnOutline{background:#fff;color:var(--brand);border:1px solid var(--brand);border-radius:10px;padding:10px 14px;cursor:pointer;font-weight:700}@media (prefers-reduced-motion: reduce){.quiz__qbar span,.quiz__scorebar .ok,.quiz__btn{transition:none}}.quiz__actions button{margin:.25rem}.login__wrap{min-height:100vh;background:#0b1733;display:grid;place-items:center;padding:24px}.login__card{background:#fff;border-radius:20px;padding:36px 32px;width:min(400px,100%);text-align:center;box-shadow:0 20px 60px #00000059}.login__logo{width:64px;height:64px;object-fit:contain;margin-bottom:8px}.login__title{margin:0 0 4px;font-size:28px;font-weight:900;color:#0f172a}.login__subtitle{color:#64748b;font-size:14px;line-height:1.6;margin:0 0 24px}.login__error{background:#fee2e2;color:#7f1d1d;border-radius:8px;padding:10px;font-size:13px;margin-bottom:12px}.login__googleBtn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 16px;background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;font-size:15px;font-weight:600;color:#0f172a;cursor:pointer;transition:background .15s,box-shadow .15s;box-shadow:0 1px 3px #0000000f}.login__googleBtn:hover{background:#f9fafb;box-shadow:0 2px 8px #0000001a}.login__googleBtn:disabled{opacity:.6;cursor:not-allowed}.login__googleSvg{width:20px;height:20px;flex-shrink:0}.login__roles{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.login__roleBtn{background:#f8fafc;border:2px solid #e5e7eb;border-radius:16px;padding:20px 12px;cursor:pointer;transition:border-color .15s,background .15s;text-align:center}.login__roleBtn:hover{border-color:#0b1733;background:#f0f4ff}.login__roleBtn--teacher:hover{border-color:#f59e0b;background:#fffbeb}.login__roleBtn:disabled{opacity:.6;cursor:not-allowed}.login__roleIcon{font-size:32px;margin-bottom:6px}.login__roleLabel{font-weight:800;font-size:15px;color:#0f172a}.login__roleDesc{font-size:12px;color:#64748b;margin-top:2px}.login__note{color:#94a3b8;font-size:12px;margin:0}.topbar__right{display:flex;align-items:center;gap:8px;margin-left:auto;margin-right:8px}.topbar__avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid #e5e7eb;flex-shrink:0}.topbar__username{font-size:13px;font-weight:600;color:#0f172a;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 480px){.topbar__username{display:none}}.topbar__dashBtn{background:#ffd400;color:#1a1a1a;border:0;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}.topbar__dashBtn:hover{filter:brightness(.95)}.topbar__logout{background:transparent;border:1px solid #e5e7eb;border-radius:8px;padding:6px 10px;font-size:12px;color:#64748b;cursor:pointer;white-space:nowrap}.topbar__logout:hover{background:#f1f5f9}.dashboard__wrap{background:#fff;max-width:1200px;margin:0 auto;min-height:100vh;box-shadow:0 0 0 24px #0b1733}.dashboard__main{padding:24px 20px 48px}.dashboard__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:8px}.dashboard__title{font-size:22px;font-weight:800;color:#0f172a;margin:0}.dashboard__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.stat__card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:14px;padding:16px;text-align:center}.stat__num{font-size:28px;font-weight:900;color:#0b1733}.stat__label{font-size:13px;color:#64748b;margin-top:2px}.dashboard__toolbar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.dashboard__filter{padding:8px 12px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;color:#0f172a;background:#fff;flex:1;min-width:180px}.dashboard__exportBtn{background:#0b1733;color:#fff;border:0;border-radius:10px;padding:8px 16px;font-size:14px;font-weight:700;cursor:pointer}.dashboard__exportBtn:hover{filter:brightness(1.15)}.dashboard__homeBtn{background:transparent;color:#0b1733;border:1px solid #0b1733;border-radius:10px;padding:8px 16px;font-size:14px;font-weight:700;cursor:pointer}.dashboard__homeBtn:hover{background:#f0f4ff}.dashboard__msg{text-align:center;color:#64748b;padding:48px}.dashboard__tableWrap{overflow-x:auto;border:1px solid #e5e7eb;border-radius:14px}.dashboard__table{width:100%;border-collapse:collapse;font-size:14px}.dashboard__table th{text-align:left;padding:10px 14px;background:#f8fafc;border-bottom:2px solid #e5e7eb;font-weight:700;color:#0f172a}.dashboard__table td{padding:10px 14px;border-bottom:1px solid #f1f5f9;color:#334155;vertical-align:top}.dashboard__table tr:last-child td{border-bottom:0}.dashboard__table tr:hover td{background:#f9fafb}.dashboard__student{font-weight:600;color:#0f172a}.dashboard__email{font-size:12px;color:#94a3b8;margin-top:2px}.dashboard__score{font-weight:700;padding:2px 8px;border-radius:6px;font-size:13px}.dashboard__score.pass{background:#dcfce7;color:#16a34a}.dashboard__score.fail{background:#fee2e2;color:#dc2626}.dashboard__addLabBtn{background:#ffd400;color:#1a1a1a;border:0;border-radius:10px;padding:8px 16px;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap}.dashboard__addLabBtn:hover{filter:brightness(.95)}.addlab__wrap{background:#fff;max-width:860px;margin:0 auto;min-height:100vh;box-shadow:0 0 0 24px #0b1733}.addlab__main{padding:24px 20px 60px}.addlab__title{font-size:22px;font-weight:800;color:#0f172a;margin:0 0 16px}.addlab__error{background:#fee2e2;color:#7f1d1d;border-radius:8px;padding:10px 14px;font-size:14px;margin-bottom:16px}.addlab__form{display:grid;gap:24px}.addlab__section{background:#f8fafc;border:1px solid #e5e7eb;border-radius:14px;padding:18px}.addlab__sectionHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.addlab__sectionTitle{font-size:16px;font-weight:800;color:#0f172a;margin:0 0 14px}.addlab__sectionHeader .addlab__sectionTitle{margin:0}.addlab__qcount{background:#0b1733;color:#fff;border-radius:999px;padding:2px 10px;font-size:13px;font-weight:700}.addlab__field{display:grid;gap:6px;margin-bottom:12px}.addlab__field:last-child{margin-bottom:0}.addlab__field label{font-size:13px;font-weight:600;color:#374151}.addlab__field input,.addlab__field textarea{width:100%;padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#0f172a;background:#fff;font-family:inherit;resize:vertical}.addlab__field input:focus,.addlab__field textarea:focus{outline:none;border-color:#0b1733;box-shadow:0 0 0 3px #0b173314}.addlab__hint{font-size:11px;color:#94a3b8;margin:0}.addlab__field .addlab__hint{display:inline;font-weight:400}.addlab__qCard{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:14px;margin-bottom:12px}.addlab__qHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.addlab__qNum{font-weight:700;font-size:14px;color:#0b1733}.addlab__qRemove{background:#fee2e2;color:#dc2626;border:0;border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer}.addlab__choices{display:grid;gap:8px;margin-bottom:6px}.addlab__choiceRow{display:flex;align-items:center;gap:8px}.addlab__choiceRow input[type=radio]{flex-shrink:0;width:16px;height:16px;cursor:pointer;accent-color:#0b1733}.addlab__choiceRow input[type=text],.addlab__choiceRow input:not([type=radio]){flex:1;padding:7px 10px;border:1px solid #d1d5db;border-radius:8px;font-size:13px;background:#fff;font-family:inherit}.addlab__choiceLabel{font-weight:700;font-size:13px;color:#374151;min-width:16px}.addlab__addQBtn{width:100%;padding:10px;border:2px dashed #d1d5db;border-radius:10px;background:transparent;color:#64748b;font-size:14px;font-weight:600;cursor:pointer}.addlab__addQBtn:hover{border-color:#0b1733;color:#0b1733}.addlab__submit{display:flex;gap:12px;justify-content:flex-end}.addlab__submitBtn{background:#0b1733;color:#fff;border:0;border-radius:12px;padding:12px 24px;font-size:15px;font-weight:700;cursor:pointer}.addlab__submitBtn:disabled{opacity:.6;cursor:not-allowed}.addlab__cancelBtn{background:#fff;color:#64748b;border:1px solid #e5e7eb;border-radius:12px;padding:12px 20px;font-size:15px;font-weight:600;cursor:pointer}
