:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#18372e;background:#f3f1e9;font-synthesis:none;--ink: #18372e;--green: #1f5b48;--green-2: #2e7d62;--cream: #f8f6ef;--line: #d8ded7;--orange: #ef7e4b;--red: #c94e45;--shadow: 0 14px 40px rgba(22, 61, 49, .09)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f3f1e9}button,input,select,textarea{font:inherit}button{cursor:pointer}.shell{min-height:100vh;padding-bottom:calc(92px + env(safe-area-inset-bottom))}.topbar{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;padding:calc(14px + env(safe-area-inset-top)) clamp(18px,5vw,56px) 14px;color:#fff;background:#163d31f5;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.brand{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:-.03em}.brand>span:last-child{display:flex;flex-direction:column}.brand small{margin-top:2px;color:#c7d9d1;font-size:10px;font-weight:600;letter-spacing:0}.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:12px;background:#f6c85f;color:var(--ink)}.school-pill{font-size:12px;color:#d6e5de;border:1px solid #4b7164;padding:7px 10px;border-radius:999px}.content{width:min(1080px,calc(100% - 32px));margin:0 auto;padding:28px 0}.install-banner{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;padding:15px 18px;border:1px solid #cbd9d2;border-radius:16px;background:#e7f0eb}.install-banner p{margin:3px 0 0;color:#617169;font-size:13px}.hero{display:grid;grid-template-columns:1.3fr .7fr;gap:20px;margin-bottom:28px}.hero-main{padding:clamp(24px,5vw,48px);border-radius:28px;color:#fff;background:var(--green);position:relative;overflow:hidden}.hero-main:after{content:"";position:absolute;width:210px;height:210px;right:-55px;bottom:-90px;border-radius:50%;border:42px solid rgba(255,255,255,.08)}.eyebrow{margin:0 0 12px;text-transform:uppercase;letter-spacing:.13em;font-size:12px;font-weight:800;color:#f6c85f}h1,h2,h3,p{margin-top:0}h1{max-width:620px;margin-bottom:14px;font-size:clamp(34px,6vw,60px);line-height:.98;letter-spacing:-.055em}.hero p{color:#dbe9e3;max-width:560px;line-height:1.6}.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}.hero-side{padding:26px;border-radius:28px;background:#f6c85f;display:flex;flex-direction:column;justify-content:space-between}.hero-side .number{font-size:62px;font-weight:900;letter-spacing:-.06em;line-height:1}.hero-side p{color:#4f4a32;margin-bottom:0}.btn{border:0;border-radius:13px;padding:12px 17px;font-weight:750;display:inline-flex;justify-content:center;align-items:center;gap:8px;transition:transform .15s,opacity .15s}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{color:#fff;background:var(--green)}.btn-light{color:var(--ink);background:#fff}.btn-orange{color:#fff;background:var(--orange)}.btn-ghost{color:var(--ink);background:#e8ece7}.btn-danger{color:var(--red);background:#f9e5e2}.btn-wide{width:100%}.section-head{display:flex;justify-content:space-between;align-items:end;gap:16px;margin:34px 0 16px}.section-head h2{margin:0;font-size:25px;letter-spacing:-.035em}.section-head p{margin:5px 0 0;color:#65766f;font-size:14px}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}.card{padding:20px;background:var(--cream);border:1px solid #e1e3dc;border-radius:20px;box-shadow:var(--shadow)}.exam-card{display:flex;min-height:188px;flex-direction:column;justify-content:space-between}.card-top{display:flex;justify-content:space-between;align-items:start;gap:10px}.tag{display:inline-flex;border-radius:999px;padding:5px 9px;background:#e3eee9;color:var(--green);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.muted{color:#728078}.exam-card h3{font-size:20px;margin:12px 0 6px;letter-spacing:-.03em}.card-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:18px}.empty{padding:45px 24px;text-align:center;border:1px dashed #bfc9c2;border-radius:20px;color:#66766e;grid-column:1 / -1}.empty-icon{font-size:36px;margin-bottom:10px}.bottom-nav{position:fixed;bottom:calc(14px + env(safe-area-inset-bottom));left:50%;z-index:30;transform:translate(-50%);display:flex;gap:4px;padding:6px;border-radius:18px;background:#fffffff0;box-shadow:0 12px 35px #00000029;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.nav-btn{min-width:90px;border:0;background:transparent;color:#718078;border-radius:13px;padding:9px 13px;font-size:12px;font-weight:750}.nav-btn.active{color:#fff;background:var(--green)}.nav-icon{display:block;font-size:18px;margin-bottom:2px}.page-title{margin:5px 0 24px}.page-title h1{color:var(--ink);font-size:clamp(34px,6vw,48px)}.page-title p{color:#68776f}.panel{padding:clamp(20px,4vw,32px);border-radius:24px;background:var(--cream);border:1px solid #e0e3dc;box-shadow:var(--shadow)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.field{display:flex;flex-direction:column;gap:7px}.field.full{grid-column:1 / -1}.field label{font-size:13px;font-weight:800}.field input,.field select,.field textarea{width:100%;border:1px solid #cfd7d1;border-radius:12px;background:#fff;padding:12px 13px;color:var(--ink);outline:none}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--green-2);box-shadow:0 0 0 3px #2e7d621f}.field input[readonly]{color:#62716a;background:#edf0ec}.field small{color:#78847e;font-size:11px}.question-summary{display:flex;justify-content:space-between;gap:12px;margin-top:22px;padding:15px 17px;border-radius:14px;color:var(--green);background:#e3eee9}.question-summary span{color:#62716a;font-size:13px}.answers-editor{margin-top:24px}.answers-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.answer-item{padding:12px;border:1px solid var(--line);border-radius:14px;background:#fff}.answer-item b{display:block;margin-bottom:8px;font-size:12px;color:#6d7973}.choice-row{display:flex;gap:4px}.choice{flex:1;min-width:0;width:28px;height:28px;padding:0;border:1px solid #bdc9c2;border-radius:50%;background:#fff;font-size:11px;font-weight:800;color:#64736c}.choice.selected{color:#fff;background:var(--green);border-color:var(--green)}.form-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:26px}.student-row{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;margin-bottom:10px;align-items:end}.students-list{margin-top:20px;display:grid;gap:10px}.student-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:13px 15px;border:1px solid var(--line);border-radius:14px;background:#fff}.student-meta{display:flex;align-items:center;gap:12px}.avatar{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;color:#fff;background:var(--green-2);font-size:13px;font-weight:800}.class-tools{margin-bottom:26px;padding:20px;border-radius:18px;background:#fff1d0}.class-tools h2{margin-bottom:5px}.class-tools>div:first-child p{color:#766d4e}.class-picker{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:end;margin-top:16px}.inline-import{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-top:12px;color:#766d4e;font-size:13px}.batch-actions{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;padding:17px;color:#fff;border-radius:16px;background:var(--green)}.batch-actions p{margin:4px 0 0;color:#d9e8e1;font-size:13px}.class-import{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:26px;padding:16px;border-radius:16px;background:#fff1d0}.class-import p{margin:4px 0 0;color:#766d4e;font-size:13px}.import-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}.import-grid p{line-height:1.55}.roster-class{margin-top:16px;overflow:hidden;border:1px solid var(--line);border-radius:16px;background:#fff}.roster-class-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:#eaf0ec}.roster-class-head h3{margin:0}.roster-line{display:flex;justify-content:space-between;gap:16px;padding:10px 16px;border-top:1px solid #edf0ed;font-size:14px}.scanner-page{width:min(700px,calc(100% - 24px))}.scanner-wrap{position:relative;overflow:hidden;aspect-ratio:3 / 4;background:#10241e;border-radius:26px;box-shadow:var(--shadow)}.scanner-wrap video,.scanner-wrap canvas{position:absolute;width:100%;height:100%;object-fit:cover}.scan-frame{position:absolute;inset:7%;border:3px solid #f6c85f;border-radius:12px;box-shadow:0 0 0 999px #0615105c;pointer-events:none}.scan-corner{position:absolute;width:34px;height:34px;border-color:#fff}.scan-corner.tl{top:-3px;left:-3px;border-top:6px solid;border-left:6px solid;border-radius:10px 0 0}.scan-corner.tr{top:-3px;right:-3px;border-top:6px solid;border-right:6px solid;border-radius:0 10px 0 0}.scan-corner.bl{bottom:-3px;left:-3px;border-bottom:6px solid;border-left:6px solid;border-radius:0 0 0 10px}.scan-corner.br{bottom:-3px;right:-3px;border-bottom:6px solid;border-right:6px solid;border-radius:0 0 10px}.scanner-help{text-align:center;color:#64746d;margin:14px auto;max-width:520px}.scanner-actions{position:sticky;bottom:92px;z-index:8;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px;margin-inline:-10px;border-radius:18px;background:#f3f1e9eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.file-input{display:none}.scan-status{margin:14px 0;padding:12px 14px;border-radius:13px;text-align:center;font-weight:700;background:#e5eee9}.scan-status.error{color:#922f29;background:#f8e2df}.batch-status{margin:10px 0 12px;padding:12px 14px;border-radius:13px;background:#fff1d0;color:#51462a;font-weight:750}.batch-status small{display:block;margin-top:6px;line-height:1.45;font-weight:600;overflow-wrap:anywhere}.result-card{text-align:center}.grade-ring{width:150px;height:150px;margin:10px auto 22px;display:grid;place-items:center;border-radius:50%;background:conic-gradient(var(--green-2) var(--grade),#dfe6e1 0);position:relative}.grade-ring:after{content:"";position:absolute;inset:13px;border-radius:50%;background:var(--cream)}.grade-number{position:relative;z-index:1;font-size:42px;font-weight:900;letter-spacing:-.05em}.result-name{font-size:25px;margin-bottom:4px}.result-details{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:24px 0}.metric{padding:14px 8px;border-radius:14px;background:#eaf0ec}.metric b{display:block;font-size:23px}.metric span{font-size:11px;color:#68766f;text-transform:uppercase;font-weight:800}.review-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;text-align:left}.review-q{padding:9px;border-radius:10px;background:#e4f0e9;font-size:12px}.review-q.wrong{background:#f7dfdc}.manual-grade-box{display:grid;grid-template-columns:1fr 160px auto;align-items:end;gap:14px;margin-top:24px;padding:18px;border-radius:16px;text-align:left;background:#fff1d0}.manual-grade-box h3{margin-bottom:4px}.manual-grade-box p{margin:0;color:#6f684e;font-size:13px}.pending{display:inline-block;margin-left:4px;padding:3px 6px;border-radius:999px;color:#985426;background:#ffead5;font-size:9px;text-transform:uppercase}.history-table{width:100%;border-collapse:collapse}.history-table th,.history-table td{padding:13px 10px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}.history-table th{color:#6b7972;font-size:11px;text-transform:uppercase;letter-spacing:.06em}.score{font-weight:900;color:var(--green)}.history-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px;margin-bottom:14px}.toast{position:fixed;z-index:100;left:50%;top:calc(82px + env(safe-area-inset-top));transform:translate(-50%);padding:12px 18px;color:#fff;background:#18372e;border-radius:12px;box-shadow:var(--shadow);animation:toast .25s ease}@keyframes toast{0%{opacity:0;transform:translate(-50%,-8px)}}.sheet-modal{position:fixed;inset:0;z-index:80;overflow:auto;padding:calc(20px + env(safe-area-inset-top)) 20px calc(20px + env(safe-area-inset-bottom));background:#0c1f19c7}.modal-toolbar{position:sticky;top:env(safe-area-inset-top);z-index:3;width:min(820px,100%);margin:0 auto 12px;display:flex;justify-content:space-between;gap:8px;padding:10px;border-radius:15px;background:#fff}.modal-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.export-info{width:min(820px,100%);margin:0 auto 12px;padding:14px;border-radius:16px;color:#18372e;background:#fff7dc;box-shadow:var(--shadow)}.export-info b{display:block;margin-bottom:8px}.export-info p{margin:4px 0;font-size:13px;overflow-wrap:anywhere}.export-info span{font-weight:900}.export-info small{display:block;margin:8px 0 12px;color:#6f684e;line-height:1.45}.answer-sheet{width:794px;min-width:794px;min-height:1123px;margin:0 auto 20px;padding:52px;color:#111;background:#fff;font-family:Arial,sans-serif;position:relative}.sheet-school{margin-bottom:13px;text-align:center;text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:800}.registration{position:absolute;width:28px;height:28px;background:#000}.registration.tl{top:22px;left:22px}.registration.tr{top:22px;right:22px}.registration.bl{bottom:22px;left:22px}.registration.br{bottom:22px;right:22px}.sheet-head{display:grid;grid-template-columns:1fr 130px;gap:22px;border-bottom:3px solid #111;padding-bottom:16px}.sheet-head h2{font-size:28px;margin-bottom:7px}.sheet-head p{margin:4px 0;font-size:14px}.qr-box img,.qr-box canvas{width:126px!important;height:126px!important}.sheet-instructions{margin:18px 0;padding:12px;border:1px solid #777;font-size:12px;line-height:1.5}.bubbles-sheet{display:grid;grid-template-columns:1fr 1fr;column-gap:36px}.bubble-column{min-width:0}.bubble-question{height:39px;display:grid;grid-template-columns:30px repeat(5,1fr);align-items:center;border-bottom:1px dotted #bbb;font-size:12px}.bubble-question>b{font-size:13px}.bubble-opt{display:flex;align-items:center;gap:4px;justify-content:center}.bubble-circle{display:inline-grid;width:24px;height:24px;place-items:center;border:2.4px solid #111;border-radius:50%;font-size:10px;font-weight:700}.sheet-code{position:absolute;bottom:28px;left:52px;right:52px;display:flex;justify-content:space-between;font-size:9px;color:#555}.app-footer{width:min(1080px,calc(100% - 32px));margin:16px auto 34px;padding:16px;text-align:center;color:#64746d;border-top:1px solid #d7ddd8;font-size:12px}@media(max-width:760px){.topbar{gap:10px;padding-inline:14px}.brand{min-width:0;gap:9px}.brand>span:last-child{min-width:0}.brand small{font-size:9px;line-height:1.25}.brand-mark{width:34px;height:34px;border-radius:11px;flex:0 0 auto}.school-pill{max-width:132px;padding:6px 9px;line-height:1.2;text-align:center}.hero{grid-template-columns:1fr}.install-banner{align-items:stretch;flex-direction:column}.hero-side{min-height:180px}.cards,.form-grid{grid-template-columns:1fr}.field.full{grid-column:auto}.answers-grid{grid-template-columns:repeat(2,1fr)}.student-row,.class-picker{grid-template-columns:1fr}.inline-import,.batch-actions{align-items:stretch;flex-direction:column}.import-grid{grid-template-columns:1fr}.class-import{align-items:stretch;flex-direction:column}.question-summary{flex-direction:column}.manual-grade-box{grid-template-columns:1fr}.bottom-nav{width:calc(100% - 24px)}.nav-btn{min-width:0;flex:1}.nav-btn{padding-inline:5px;font-size:10px}.review-grid{grid-template-columns:repeat(4,1fr)}.history-table th:nth-child(2),.history-table td:nth-child(2){display:none}.modal-toolbar{align-items:stretch;flex-direction:column}.modal-actions{justify-content:stretch}.modal-actions .btn{flex:1}.sheet-modal{padding-inline:20px}.scanner-actions{grid-template-columns:1fr;bottom:82px}.history-actions{align-items:stretch;flex-direction:column}}@media print{@page{size:A4 portrait;margin:0}html,body{width:210mm!important;height:auto!important;margin:0!important;padding:0!important;overflow:visible!important;background:#fff!important}.shell{display:block!important;height:auto!important;min-height:0!important;overflow:visible!important}body *{visibility:hidden!important}.sheet-modal,.answer-sheet,.answer-sheet *{visibility:visible!important}.sheet-modal{display:block!important;position:static!important;inset:auto!important;width:210mm!important;height:auto!important;max-height:none!important;overflow:visible!important;padding:0!important;margin:0!important;background:#fff!important}.modal-toolbar,.export-info{display:none!important}.answer-sheet{display:block!important;position:relative!important;width:210mm!important;min-width:210mm!important;height:297mm!important;min-height:297mm!important;max-height:297mm!important;margin:0!important;padding:14mm!important;box-shadow:none!important;overflow:hidden!important;break-after:page;page-break-after:always;break-inside:avoid;page-break-inside:avoid}.answer-sheet:last-child{break-after:auto;page-break-after:auto}}
