/* ============================================================
   QUIZ, LOGIN, PRINT — Module-specific styles
   ============================================================ */

/* LOGIN */
#login-view{background:var(--paper);display:flex;align-items:center;justify-content:center;min-height:100vh;position:fixed;inset:0;z-index:500;background-image:repeating-linear-gradient(45deg,transparent,transparent 40px,rgba(0,0,0,.015) 40px,rgba(0,0,0,.015) 41px)}
.login-box{width:400px;background:#fff;border:1px solid var(--paper3);border-radius:16px;padding:40px;box-shadow:var(--shadow2)}
.login-logo{font-family:'Fraunces',serif;font-size:28px;font-weight:700;color:var(--ink);margin-bottom:3px}
.login-logo span{color:var(--gold)}
.login-tag{font-size:13px;color:var(--ink3);margin-bottom:28px}
.tab-row{display:flex;gap:6px;margin-bottom:20px;background:var(--paper2);padding:4px;border-radius:8px}
.tab-btn{flex:1;padding:7px;border-radius:5px;font-size:13px;font-weight:500;cursor:pointer;transition:all .18s;border:none;background:none;font-family:'Outfit',sans-serif;color:var(--ink2)}
.tab-btn.active{background:#fff;color:var(--ink);box-shadow:var(--shadow)}
.role-row{display:flex;gap:8px;margin-bottom:14px}
.role-pick{flex:1;padding:10px 8px;border:1.5px solid var(--paper3);border-radius:var(--r2);text-align:center;cursor:pointer;transition:all .18s}
.role-pick:hover,.role-pick.sel{border-color:var(--gold);background:var(--gold-a)}
.role-pick .ri{font-size:20px;margin-bottom:4px}
.role-pick .rn{font-size:12px;font-weight:600;color:var(--ink)}
.register-note{font-size:12px;color:var(--ink3);background:var(--blue-a);border-radius:var(--r2);padding:10px 12px;margin-top:8px;border-left:3px solid var(--blue)}

/* QUIZ */
.quiz-wrap{max-width:640px;margin:0 auto;padding:24px}
.q-num{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--gold);font-weight:500;letter-spacing:.5px;margin-bottom:6px}
.q-type-tag{display:inline-flex;align-items:center;gap:5px;background:var(--paper2);border-radius:20px;padding:3px 10px;font-size:11px;color:var(--ink2);margin-bottom:14px}
.q-text{font-size:17px;font-weight:500;line-height:1.6;color:var(--ink);margin-bottom:20px}
.opt{display:flex;align-items:center;gap:12px;padding:12px 16px;border:1.5px solid var(--paper3);border-radius:var(--r);margin-bottom:9px;cursor:pointer;transition:all .18s;background:#fff}
.opt:hover{border-color:var(--gold);background:var(--gold-a)}
.opt.osel{border-color:var(--gold);background:var(--gold-a)}
.opt.ook{border-color:var(--green)!important;background:var(--green-a)!important}
.opt.obad{border-color:var(--red)!important;background:var(--red-a)!important}
.opt-l{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--paper3);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0;font-family:'JetBrains Mono',monospace;transition:all .18s}
.opt.osel .opt-l{border-color:var(--gold);color:var(--gold);background:var(--gold-a)}
.opt.ook .opt-l{border-color:var(--green);color:var(--green);background:var(--green-a)}
.opt.obad .opt-l{border-color:var(--red);color:var(--red)}
.opt-t{font-size:14px;line-height:1.5}
.tf-row{display:flex;gap:12px}
.tf-btn{flex:1;padding:16px;border:2px solid var(--paper3);border-radius:var(--r);text-align:center;cursor:pointer;transition:all .18s;font-size:15px;font-weight:600;background:#fff}
.tf-btn:hover,.tf-btn.osel{border-color:var(--gold);background:var(--gold-a);color:var(--gold)}
.tf-btn.ook{border-color:var(--green)!important;background:var(--green-a)!important;color:var(--green)!important}
.tf-btn.obad{border-color:var(--red)!important;background:var(--red-a)!important;color:var(--red)!important}
.ans-ta{width:100%;background:var(--paper);border:1.5px solid var(--paper3);color:var(--ink);padding:14px;border-radius:var(--r);font-size:14px;font-family:'Outfit',sans-serif;outline:none;resize:vertical;min-height:100px;line-height:1.65;transition:border .18s}
.ans-ta:focus{border-color:var(--gold);background:#fff}
.blank-inp{background:transparent;border:none;border-bottom:2px solid var(--gold);color:var(--gold);font-size:16px;font-weight:600;font-family:'JetBrains Mono',monospace;padding:2px 8px;outline:none;min-width:90px;text-align:center}
.blank-txt{font-size:17px;line-height:2.4}
.ai-fb{background:linear-gradient(135deg,#fffdf5,#fefcf3);border:1.5px solid #e8d5a3;border-radius:var(--r);padding:16px;margin-top:16px;animation:pop .35s ease}
.ai-fb-hd{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.ai-fb-icon{width:28px;height:28px;border-radius:50%;background:var(--gold-a);border:1px solid rgba(212,130,10,.2);display:flex;align-items:center;justify-content:center;font-size:13px}
.ai-fb p{font-size:13px;line-height:1.75;color:var(--ink2);white-space:pre-line}
.ai-score-row{display:flex;align-items:center;gap:12px;margin-top:10px;padding-top:10px;border-top:1px solid #e8d5a3}
.ai-score-n{font-family:'Fraunces',serif;font-size:22px;font-weight:700}
.quiz-topbar{background:#fff;border-bottom:1px solid var(--paper3);padding:10px 24px;display:flex;align-items:center;gap:18px;flex-shrink:0;flex-wrap:wrap}
.res-big{font-family:'Fraunces',serif;font-size:68px;font-weight:700;line-height:1}

/* PRINT */
@media print {
  body * { visibility: hidden !important; }
  #print-area, #print-area * { visibility: visible !important; }
  #print-area { position: absolute; top: 0; left: 0; width: 100%; display: block !important; }
  .print-q { page-break-inside: avoid; margin-bottom: 20px; border: 1px solid #ddd; border-radius: 6px; padding: 14px; }
  .print-header { text-align: center; margin-bottom: 28px; border-bottom: 2px solid #1a1a1a; padding-bottom: 14px; }
  .print-space { border-bottom: 1px dotted #aaa; margin: 6px 0; height: 22px; }
}
#print-area { display: none; }
