:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#15201b;font-synthesis:none;text-rendering:optimizelegibility;background:#f5f7f2;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0}html,body,#root{height:100%;overflow:hidden}button,input,select,textarea{font:inherit}button{color:#15201b;cursor:pointer;background:#fff;border:1px solid #bfcbc4;border-radius:6px;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:11px 14px;font-weight:800;display:inline-flex}button:hover,button.active{background:#e8f7f3;border-color:#155e63}button.primary{color:#fff;background:#155e63;border-color:#155e63}.app{flex-direction:column;height:100vh;min-height:0;display:flex;overflow:hidden}.topbar{z-index:5;background:#fff;border-bottom:1px solid #d7dfda;flex:none;justify-content:space-between;align-items:center;gap:16px;min-height:68px;padding:12px 24px;display:flex;position:relative}.teacher-login{align-items:center;gap:12px;display:flex}.brand{text-align:left;background:0 0;border:0;justify-content:flex-start;align-items:center;gap:12px;min-height:0;padding:0;display:flex}.brand:hover{background:0 0;border-color:#0000}.brand-logo{width:300px;max-width:min(48vw,320px);height:auto;display:block}.storage-pill{color:#586860;white-space:nowrap;background:#f7faf8;border:1px solid #c5d4cc;border-radius:999px;margin-left:auto;padding:8px 12px;font-size:13px;font-weight:800}.storage-pill.d1{color:#126537;background:#e7f8ef;border-color:#9dd9b2}.storage-pill.error{color:#704b00;background:#fff3d6;border-color:#f7c653}.alert-bell{border-radius:999px;min-width:52px;position:relative}.alert-bell.has-alerts{color:#991b1b;background:#fee2e2;border-color:#ef4444}.alert-bell span{color:#fff;background:#dc2626;border:2px solid #fff;border-radius:999px;place-items:center;min-width:24px;min-height:24px;font-size:12px;font-weight:900;display:grid;position:absolute;top:-8px;right:-6px}.brand span,.teacher-login span{color:#64736c;margin-top:2px;font-size:13px;display:block}.brand strong{font-size:20px;display:block}.login-screen{background:linear-gradient(#e7f8fb 0%,#f7faf8 58%,#fff7df 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:#ffffffeb;border:2px solid #15201b;border-radius:8px;grid-template-columns:minmax(240px,.9fr) minmax(260px,1.1fr);align-items:center;gap:28px;width:min(980px,100%);padding:clamp(22px,4vw,42px);display:grid;box-shadow:10px 10px #15201b}.login-logo{width:100%;max-width:420px}.login-copy h1{margin:0 0 12px;font-size:clamp(36px,6vw,66px);line-height:.98}.login-copy p:not(.eyebrow),.login-note{color:#52635b;font-size:18px;line-height:1.45}.login-actions{grid-column:1/-1;grid-template-columns:repeat(4,minmax(160px,1fr));gap:10px;display:grid}.login-note{grid-column:1/-1;margin:0;font-size:14px}.auth-message{color:#5b4300;background:#fff7df;border:1px solid #f7c653;border-radius:8px;grid-column:1/-1;margin:0;padding:12px 14px;font-size:15px;line-height:1.4}.mark{background:#ffd166;border:2px solid #15201b;border-radius:8px;place-items:center;width:42px;height:42px;display:grid;box-shadow:4px 4px #15201b}.mode-switch{gap:8px;display:flex}.teacher{flex:1;grid-template-columns:250px minmax(0,1fr);min-height:0;display:grid;overflow:hidden}.sidebar{background:#fbfcfa;border-right:1px solid #d7dfda;flex-direction:column;gap:10px;min-height:0;max-height:100%;padding:18px;display:flex;overflow:auto}.sidebar>button{justify-content:flex-start}.account-panel{background:#fff;border:1px solid #d7dfda;border-radius:8px;gap:8px;padding:10px;display:grid}.account-panel p{color:#64736c;margin:0;font-size:12px;line-height:1.35}.teacher-main{min-height:0;padding:24px;overflow:auto}.stack{gap:18px;display:grid}.panel{background:#fff;border:1px solid #d7dfda;border-radius:8px;padding:20px}.hero-panel{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:24px;display:grid}.hero-panel h1{margin:0 0 10px;font-size:clamp(30px,4vw,52px);line-height:1}.workspace-head h1{margin:0 0 10px;font-size:clamp(30px,3vw,42px);line-height:1}.hero-panel p,.workspace-head p{color:#52635b;max-width:760px}.retention-note{color:#5f4b11;background:#fff7df;border:1px solid #f3c85f;border-radius:8px;padding:10px 12px;font-size:14px;line-height:1.35}.eyebrow{color:#155e63;text-transform:uppercase;margin:0 0 6px;font-size:12px;font-weight:900}.stats,.summary-grid{gap:8px;display:grid}.stats span,.summary-grid span{color:#52635b;background:#f7faf8;border:1px solid #d7dfda;border-radius:8px;min-width:150px;padding:12px}.stats strong,.summary-grid strong{color:#15201b;font-size:22px;display:block}.form-grid{grid-template-columns:minmax(220px,1.4fr) minmax(140px,.7fr) minmax(110px,.4fr) auto;align-items:end;gap:12px;display:grid}label{color:#52635b;gap:6px;font-weight:800;display:grid}input,select,textarea{color:#15201b;background:#fff;border:1px solid #bfcbc4;border-radius:6px;width:100%;min-height:48px;padding:12px 14px}.section-title{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.section-title h2,.panel h2{margin:0}.table{gap:8px;display:grid}.row{border:1px solid #d7dfda;border-radius:8px;grid-template-columns:1fr 1.1fr .7fr .7fr auto auto auto auto;align-items:center;gap:10px;padding:10px;display:grid}.row.selected{background:#f0faf7;border-color:#155e63}.alert-pill,.ok-pill{border-radius:999px;justify-self:start;padding:5px 10px;font-size:13px;font-weight:900}.alert-pill{color:#991b1b;background:#fee2e2}.alert-link{border:0;min-height:0;display:inline-flex}.alert-link:hover{color:#7f1d1d;background:#fecaca}.ok-pill{color:#166534;background:#dcfce7}.cards-list,.log-list,.evidence-list{gap:12px;display:grid}.alert-card,.log{border:1px solid #d7dfda;border-left:6px solid #155e63;border-radius:8px;padding:14px}.alert-card.high{border-left-color:#b91c1c}.alert-card.medium{border-left-color:#d97706}.alert-card.focused{background:#fff7f7;border-color:#991b1b;box-shadow:0 0 0 2px #dc26261f}.alert-card span,.log span{color:#64736c;margin-top:3px;font-size:13px;display:block}.actions{flex-wrap:wrap;gap:8px;display:flex}button.danger{color:#991b1b;border-color:#fecaca}button.danger:hover{background:#fee2e2}.small-field{width:92px}.small-field input{min-height:48px}.qr-preview-panel{background:#f7faf8;border:1px solid #d7dfda;border-radius:8px;margin-bottom:18px;padding:14px}.section-title.compact{margin-bottom:10px}.section-title h3{margin:0}.qr-grid{grid-template-columns:repeat(auto-fill,minmax(116px,1fr));gap:10px;display:grid}.qr-tile{background:#fff;flex-direction:column;gap:8px;min-height:150px}.qr-tile img{width:92px;height:92px;image-rendering:pixelated}.qr-modal{text-align:center}.qr-modal img{width:min(72vw,360px);height:min(72vw,360px);image-rendering:pixelated}.log.pupil{background:#eef7ff}.log.assistant{background:#f7faf8}.evidence-panel{background:#fff;border:1px solid #d7dfda;border-radius:8px;margin-top:16px;padding:14px}.project-viewer{grid-template-columns:260px minmax(0,1fr);gap:18px;display:grid}.project-list{align-self:start;gap:10px;display:grid}.project-list button{flex-direction:column;justify-content:flex-start;align-items:flex-start}.project-list span{color:#64736c;font-size:13px}.workspace{flex:auto;grid-template-columns:minmax(320px,430px) minmax(0,1fr);height:auto;min-height:0;display:grid;overflow:hidden}.chat-panel{overscroll-behavior:contain;background:#fbfcfa;border-right:1px solid #d7dfda;grid-template-rows:auto minmax(180px,1fr) auto;gap:16px;height:100%;min-height:0;padding:20px;display:grid;overflow:hidden}.workspace-head{min-height:0;max-height:min(42vh,390px);padding-right:4px;overflow:auto}.rules{background:#fff;border:1px solid #d7dfda;border-radius:8px;padding:12px}.messages{overscroll-behavior:contain;flex-direction:column;gap:10px;min-height:0;max-height:100%;padding:0 4px 8px 0;scroll-padding-bottom:16px;display:flex;overflow:auto}.pupil-bubble,.assistant-bubble{border-radius:8px;max-width:92%;padding:12px 14px;line-height:1.45}.aiyo-bubble{align-items:flex-start;gap:10px;max-width:96%;display:flex}.aiyo-bubble img{object-fit:contain;flex:none;width:58px;height:58px}.aiyo-bubble .assistant-bubble{max-width:none}.pupil-bubble{color:#fff;background:#155e63;align-self:flex-end}.assistant-bubble{background:#fff;border:1px solid #d7dfda;align-self:flex-start}.chat-panel form{z-index:2;background:#fbfcfa;gap:10px;margin:0;padding:0;display:grid}.chat-panel textarea{resize:none;min-height:104px}.preview-panel{grid-template-rows:auto minmax(0,1fr);gap:14px;min-width:0;min-height:0;padding:18px;display:grid;position:relative;overflow:hidden}.preview-toolbar{justify-content:space-between;align-items:center;gap:14px;display:flex}.preview-toolbar h2{margin:0}.preview-toolbar .voice-control{width:min(420px,100%)}.toolbar-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.preview{background:#fff;border:1px solid #bfcbc4;border-radius:8px;width:100%;height:100%;min-height:0}.empty-preview,.empty{color:#64736c;background:#fff;border:1px dashed #bfcbc4;border-radius:8px;place-items:center;min-height:300px;display:grid}.code-view{background:#111827;border:1px solid #d7dfda;border-radius:8px;min-height:0;overflow:hidden}.code-tabs{background:#1f2937;gap:6px;padding:8px;display:flex}.code-tabs button{color:#d1d5db;background:#111827;border-color:#374151;min-height:44px;padding:5px 10px}.code-tabs button.active{color:#111827;background:#ffd166}pre{color:#e5e7eb;white-space:pre-wrap;word-break:break-word;max-height:280px;margin:0;padding:14px;font-size:12px;line-height:1.5;overflow:auto}.footer{color:#64736c;background:#fff;border-top:1px solid #d7dfda;flex-wrap:wrap;flex:none;justify-content:center;align-items:center;gap:16px;min-height:48px;padding:10px 18px;font-size:13px;display:flex}.footer button{min-height:44px;padding:4px 10px}.voice-control{display:grid;position:relative}.voice-control textarea,.voice-control input{padding-right:62px}.voice-control .mic{width:42px;min-height:42px;padding:0;font-size:20px;position:absolute;bottom:6px;right:6px}.voice-control .mic.listening{color:#b91c1c;background:#dcfce7;border-color:#16a34a}.planning-card{gap:12px;max-width:100%;display:grid}.aiyo-card-art{object-fit:contain;justify-self:start;width:86px;height:86px}.choice-row{gap:8px;display:grid}.choice-row>span{color:#52635b;font-weight:900}.choice-row>div,.confirm-row,.brainstorm-grid{flex-wrap:wrap;gap:8px;display:flex}.choice-row button{background:#f7faf8;min-height:44px}.choice-row .explain-option{color:#155e63;background:#fff;border-color:#155e63}.idea-summary{background:#fff7df;border:1px solid #f3c85f;border-radius:8px;margin:0;padding:12px}.brainstorm-grid button{text-align:left;justify-content:flex-start;max-width:100%;line-height:1.3}.brainstorm-grid button.selected-idea{color:#14532d;background:#dcfce7;border-color:#16a34a}button:disabled{cursor:not-allowed;opacity:.55}.project-shelf{background:#fff;border:1px solid #d7dfda;border-radius:8px;gap:8px;padding:12px;display:grid}.project-shelf .muted{margin:0}.project-chips{flex-wrap:wrap;gap:8px;display:flex}.project-chips button{justify-content:flex-start;max-width:100%;min-height:42px}.build-overlay{z-index:4;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#f5f7f2c2;border-radius:8px;place-items:center;display:grid;position:absolute;inset:18px}.build-card{text-align:center;background:#fff;border:2px solid #15201b;border-radius:8px;width:min(420px,90%);padding:22px;box-shadow:8px 8px #15201b}.build-card h2{margin:12px 0 6px}.build-card p{color:#52635b;margin:0}.build-steps{text-align:left;gap:8px;margin:16px 0 0;padding:0;list-style:none;display:grid}.build-steps li{color:#33443b;background:#f7faf8;border:1px solid #d7dfda;border-radius:8px;padding:9px 12px 9px 34px;font-weight:800;position:relative}.build-steps li:before{content:"";background:#155e63;border-radius:50%;width:10px;height:10px;animation:1.4s ease-in-out infinite pulse;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.build-steps li:nth-child(2):before{animation-delay:.14s}.build-steps li:nth-child(3):before{animation-delay:.28s}.build-steps li:nth-child(4):before{animation-delay:.42s}.build-steps li:nth-child(5):before{animation-delay:.56s}.build-aiyo{width:118px;height:118px;margin:0 auto;animation:1s ease-in-out infinite bob;position:relative}.build-aiyo img{object-fit:contain;opacity:0;width:118px;height:118px;animation:4.8s ease-in-out infinite aiyoFade;position:absolute;inset:0}.build-aiyo img:nth-child(2){animation-delay:1.2s}.build-aiyo img:nth-child(3){animation-delay:2.4s}.build-aiyo img:nth-child(4){animation-delay:3.6s}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes blink{0%,to{opacity:.55;transform:scale(.7)}50%{opacity:1;transform:scale(1.1)}}@keyframes aiyoFade{0%,to{opacity:0;transform:scale(.96)}8%,25%{opacity:1;transform:scale(1)}34%{opacity:0;transform:scale(1.02)}}@keyframes pulse{0%,to{opacity:.35;transform:translateY(-50%)scale(.8)}50%{opacity:1;transform:translateY(-50%)scale(1.2)}}.touch-tip{z-index:50;pointer-events:none;color:#fff;background:#111827;border-radius:8px;max-width:min(320px,100vw - 28px);padding:10px 12px;font-size:13px;line-height:1.35;position:fixed;transform:translate(-50%,-100%);box-shadow:0 10px 28px #00000038}.modal-backdrop{z-index:20;background:#1018147a;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal{color:#15201b;background:#fff;border:1px solid #d7dfda;border-radius:8px;width:min(680px,100%);max-height:88vh;padding:22px;overflow:auto}.play-backdrop{z-index:30;background:#f5f7f2;padding:18px;position:fixed;inset:0}.play-modal{grid-template-rows:auto minmax(0,1fr);gap:12px;width:100%;height:100%;display:grid}.play-modal .preview{min-height:0}.muted{color:#64736c}@media (width<=920px){.teacher,.workspace,.project-viewer,.hero-panel{grid-template-columns:1fr}.sidebar{border-bottom:1px solid #d7dfda;border-right:0;flex-direction:row;max-height:none;overflow:auto}.teacher-login{min-width:220px}.form-grid,.row{grid-template-columns:1fr}.workspace{overflow:auto}.chat-panel{border-bottom:1px solid #d7dfda;border-right:0;grid-template-rows:auto minmax(170px,1fr) auto;height:auto;max-height:62vh}.workspace-head{max-height:26vh}.preview-panel{grid-template-rows:auto minmax(360px,1fr);min-height:52vh}.preview-toolbar{flex-direction:column;align-items:stretch}.toolbar-actions{justify-content:stretch}.toolbar-actions button{flex:1}.login-card{grid-template-columns:1fr}.login-actions{grid-template-columns:1fr 1fr}}@media (width<=620px){.topbar,.section-title{flex-direction:column;align-items:stretch}.mode-switch{width:100%}.storage-pill{text-align:center;white-space:normal;margin-left:0}.mode-switch button{flex:1}.teacher-main{padding:14px}.login-actions{grid-template-columns:1fr}}
