:root{--navy: #13335f;--navy-700: #0e2748;--teal: #0d9488;--teal-600: #0f766e;--bg: #f4f6fa;--surface: #ffffff;--border: #e3e8ef;--text: #1f2a37;--muted: #6b7785;--ok: #15803d;--ok-bg: #ecfdf3;--err: #b42318;--err-bg: #fef3f2;--warn-bg: #fffaeb;--warn-bd: #fde68a;--radius: 12px;--shadow: 0 1px 3px rgba(16, 24, 40, .08), 0 1px 2px rgba(16, 24, 40, .04);--shadow-lg: 0 8px 24px rgba(16, 24, 40, .1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,BIZ UDPGothic,Meiryo,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}a{color:var(--teal-600)}.app{display:flex;flex-direction:column;min-height:100%}.topbar{background:var(--navy);color:#fff;padding:14px 24px;position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between}.topbar-user{display:flex;align-items:center;gap:12px;font-size:14px}.user-name{display:flex;align-items:center;gap:8px}.admin-tag{background:var(--teal);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}.logout-btn{background:#ffffff24;color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:8px;padding:7px 14px;font-size:13px}.logout-btn:hover{background:#ffffff3d}.auth-loading{display:grid;place-items:center;height:100vh;color:var(--muted)}.login-screen{display:grid;place-items:center;min-height:100vh;background:linear-gradient(135deg,var(--navy),#1c4a86);padding:20px}.login-card{background:#fff;border-radius:16px;padding:32px;width:100%;max-width:380px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:20px}.field-label{font-size:13px;font-weight:600;color:var(--muted);margin:10px 0 4px}.login-btn{margin-top:18px;width:100%}.login-note{margin-top:16px;text-align:center}.members-table{width:100%;border-collapse:collapse;font-size:14px}.members-table th,.members-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}.members-table th{color:var(--muted);font-size:13px}.role-chip{font-size:12px;font-weight:600;padding:2px 10px;border-radius:999px}.role-chip.admin{background:#eef3fb;color:var(--navy)}.role-chip.trainee{background:#f0fdfa;color:var(--teal-600)}.brand{display:flex;align-items:center;gap:12px}.brand-mark{font-size:28px;background:#ffffff1f;width:46px;height:46px;border-radius:12px;display:grid;place-items:center}.brand-title{font-weight:700;font-size:18px}.brand-sub{font-size:12px;opacity:.8}.layout{display:flex;flex:1;align-items:flex-start}.sidebar{width:220px;flex-shrink:0;padding:18px 12px;display:flex;flex-direction:column;gap:4px;position:sticky;top:74px}.nav-item{display:flex;align-items:center;gap:10px;padding:11px 14px;border:none;background:transparent;border-radius:10px;color:var(--text);font-size:15px;text-align:left;transition:background .15s}.nav-item:hover{background:#e9eef6}.nav-item.active{background:var(--navy);color:#fff;font-weight:600}.nav-emoji{font-size:18px}.content{flex:1;padding:28px 32px;min-width:0}.view{max-width:920px}.view-title{font-size:22px;margin:0 0 6px}.muted{color:var(--muted);font-size:14px}.btn-primary{background:var(--navy);color:#fff;border:none;padding:11px 20px;border-radius:10px;font-size:15px;font-weight:600;transition:background .15s,transform .05s}.btn-primary:hover{background:var(--navy-700)}.btn-primary:active{transform:translateY(1px)}.btn-primary:disabled{background:#aab4c2;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--navy);border:1.5px solid var(--border);padding:10px 18px;border-radius:10px;font-size:14px;font-weight:600}.btn-secondary:hover{border-color:var(--navy)}.btn-secondary:disabled{color:#aab4c2;cursor:not-allowed}.row-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.hero{background:linear-gradient(135deg,var(--navy),#1c4a86);color:#fff;padding:30px;border-radius:16px;margin-bottom:24px}.hero h1{margin:0 0 10px;font-size:26px}.hero p{margin:0 0 14px;opacity:.92}.badge{display:inline-block;background:#ffffff29;padding:6px 12px;border-radius:999px;font-size:13px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;margin:8px 0 24px}.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:left;box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s,border-color .12s}.feature-card:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--teal)}.feature-card:disabled{opacity:.55;cursor:not-allowed}.feature-emoji{font-size:30px}.feature-card h3{margin:8px 0 6px;font-size:17px}.feature-card p{margin:0;font-size:14px;color:var(--muted)}.goal-line{margin-top:8px!important;color:var(--teal-600)!important;font-weight:600}.note-box{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--teal);border-radius:10px;padding:16px 18px;margin:16px 0}.note-box strong{display:block;margin-bottom:4px}.note-box p{margin:4px 0 10px;font-size:14px;color:var(--muted)}.warn-block{border-left-color:var(--warn-bd);background:var(--warn-bg)}.two-col{display:flex;gap:24px;max-width:1100px;align-items:flex-start}.list{width:280px;flex-shrink:0}.list-item{width:100%;display:flex;justify-content:space-between;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:8px;text-align:left;font-size:14px}.list-item.active{border-color:var(--navy);background:#eef3fb;font-weight:600}.done-chip{background:var(--ok-bg);color:var(--ok);font-size:11px;padding:2px 8px;border-radius:999px}.detail{flex:1;min-width:0}.lesson h2{margin:0 0 4px}.lesson-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin:14px 0}.lesson-section h3{margin:0 0 8px;color:var(--navy)}.points{margin:8px 0;padding-left:20px}.points li{margin:4px 0}.script{margin-top:12px;display:flex;flex-direction:column;gap:8px}.script-line{display:flex;gap:10px;align-items:flex-start}.script-who{flex-shrink:0;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;background:#eef3fb;color:var(--navy)}.script-line.customer .script-who{background:#f0fdfa;color:var(--teal-600)}.script-line.note .script-who{background:#f3f4f6;color:var(--muted)}.script-text{font-size:14px}.script-line.note .script-text{color:var(--muted);font-style:italic}.quiz-progress,.rp-progress{font-size:13px;color:var(--muted);margin:8px 0}.quiz-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}.quiz-question{font-size:17px;font-weight:600;margin:0 0 16px}.choices{display:flex;flex-direction:column;gap:10px}.choice{text-align:left;background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:13px 16px;font-size:15px;transition:border-color .12s,background .12s}.choice:hover:not(:disabled){border-color:var(--navy)}.choice.correct{border-color:var(--ok);background:var(--ok-bg)}.choice.wrong{border-color:var(--err);background:var(--err-bg)}.explanation{margin-top:16px;padding-top:16px;border-top:1px dashed var(--border)}.explanation p{font-size:14px;color:var(--muted);margin:6px 0 14px}.result-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px;text-align:center;box-shadow:var(--shadow)}.result-card.pass{border-top:4px solid var(--ok)}.result-card.fail{border-top:4px solid var(--warn-bd)}.result-score{font-size:34px;font-weight:800;color:var(--navy)}.result-judge{font-size:20px;font-weight:700;margin:6px 0}.link-back{background:none;border:none;color:var(--teal-600);font-size:14px;padding:0;margin-bottom:8px}.rp-customer{display:flex;gap:10px;align-items:flex-start;background:#f0fdfa;border:1px solid #ccfbf1;border-radius:10px;padding:14px 16px;margin:10px 0;font-size:15px}.rp-hint{font-size:13px;color:var(--muted);margin:6px 0}.rp-input,.composer-input,.text-input{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:12px 14px;font-size:15px;font-family:inherit;resize:vertical}.rp-input:focus,.composer-input:focus,.text-input:focus{outline:none;border-color:var(--navy)}.rp-input{margin:8px 0 12px}.rp-model{margin-top:14px;background:#eef3fb;border-radius:10px;padding:16px}.rp-model strong{color:var(--navy)}.settings-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin:14px 0}.settings-block h3{margin:0 0 6px}.key-row{display:flex;gap:8px;margin-top:10px}.key-row .text-input{flex:1}.model-options{display:flex;flex-direction:column;gap:8px;margin-top:10px}.model-option{display:flex;align-items:center;gap:10px;border:1.5px solid var(--border);border-radius:10px;padding:12px 14px;cursor:pointer}.model-option.active{border-color:var(--navy);background:#eef3fb}.model-label{font-weight:600}.model-note{margin-left:auto;font-size:13px;color:var(--muted)}.saved-msg{margin-left:12px;color:var(--ok);font-weight:600}.call-view{max-width:760px;display:flex;flex-direction:column}.call-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.call-title{font-weight:700}.call-tools{margin-left:auto}.chip-toggle{border:1.5px solid var(--border);background:#fff;border-radius:999px;padding:6px 12px;font-size:13px}.chip-toggle.on{border-color:var(--teal);background:#f0fdfa;color:var(--teal-600);font-weight:600}.turn-meter{font-size:12px;color:var(--muted);margin:8px 0}.countdown{background:#eef3fb;border:1px solid #d6e2f3;border-radius:10px;padding:10px 14px;margin-bottom:10px}.countdown.low{background:var(--err-bg);border-color:#fecdca}.countdown-head{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:600;margin-bottom:6px}.countdown-num{color:var(--navy)}.countdown.low .countdown-num{color:var(--err)}.countdown-bar{height:8px;background:#e0e8f3;border-radius:999px;overflow:hidden}.countdown-fill{height:100%;background:var(--navy);border-radius:999px;transition:width 1s linear}.countdown.low .countdown-fill{background:var(--err)}.chat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;height:52vh;min-height:320px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.bubble{max-width:80%;padding:10px 14px;border-radius:14px;font-size:15px;display:flex;flex-direction:column;gap:3px}.bubble-who{font-size:11px;opacity:.7}.bubble.assistant{align-self:flex-start;background:#eef3fb;border-bottom-left-radius:4px}.bubble.user{align-self:flex-end;background:var(--navy);color:#fff;border-bottom-right-radius:4px}.caret{animation:blink 1s steps(1) infinite}@keyframes blink{50%{opacity:0}}.typing{font-size:13px;color:var(--muted);align-self:flex-start}.error-bar{background:var(--err-bg);color:var(--err);border:1px solid #fecdca;border-radius:10px;padding:10px 14px;margin:10px 0;font-size:14px}.composer{display:flex;gap:8px;align-items:flex-end;margin-top:12px}.composer-input{flex:1}.mic-btn{border:1.5px solid var(--border);background:#fff;border-radius:10px;padding:0 14px;height:46px;font-size:16px;white-space:nowrap}.mic-btn.listening{border-color:var(--err);color:var(--err);background:var(--err-bg)}.send-btn{height:46px}.feedback{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.fb-overall{display:flex;gap:18px;align-items:center;padding-bottom:18px;border-bottom:1px solid var(--border)}.fb-score-big{font-size:46px;font-weight:800;color:var(--navy);background:#eef3fb;width:96px;height:96px;border-radius:50%;display:grid;place-items:center;flex-shrink:0}.fb-overall-label{font-size:13px;color:var(--muted)}.fb-scores{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:18px 0}.fb-score-head{display:flex;justify-content:space-between;font-weight:600}.fb-num{color:var(--navy)}.fb-bar{background:#e8edf4;border-radius:999px;height:8px;margin:6px 0;overflow:hidden}.fb-bar-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--navy));border-radius:999px}.fb-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:8px 0}.fb-cols h3{font-size:16px;margin:0 0 6px}.sub-head{margin:22px 0 10px;font-size:16px}.mode-pills{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0}.pill{border:1.5px solid var(--border);background:#fff;border-radius:999px;padding:9px 16px;font-size:14px;font-weight:600}.pill.active{border-color:var(--navy);background:#eef3fb;color:var(--navy)}.pill:disabled{opacity:.5;cursor:not-allowed}.check-row{display:flex;align-items:center;gap:8px;font-size:14px;margin-top:10px;cursor:pointer}.link-inline{background:none;border:none;color:var(--teal-600);padding:0 2px;font-size:inherit;text-decoration:underline}.feature-card.accent{border-color:var(--teal);background:#f0fdfa}.qa-q-card{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--navy);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:14px}.qa-question{font-size:18px;font-weight:600;margin:0}.qa-composer{margin-bottom:12px}.qa-reveal{margin-top:8px}.verdict-badge{display:inline-block;font-weight:700;padding:6px 14px;border-radius:999px;margin-bottom:10px}.verdict-badge.correct{background:var(--ok-bg);color:var(--ok)}.verdict-badge.partial{background:var(--warn-bg);color:#b45309}.verdict-badge.incorrect{background:var(--err-bg);color:var(--err)}.qa-feedback{font-size:15px;margin:0 0 12px}.qa-talk{margin-top:8px;font-size:14px}.qa-talk-label{display:inline-block;font-size:11px;font-weight:700;color:var(--teal-600);background:#f0fdfa;border-radius:6px;padding:2px 8px;margin-right:8px}.self-mark-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px}.mark-btn{border:1.5px solid var(--border);background:#fff;border-radius:10px;padding:10px 16px;font-size:15px;font-weight:600}.mark-btn.ok:hover{border-color:var(--ok);background:var(--ok-bg)}.mark-btn.mid:hover{border-color:var(--warn-bd);background:var(--warn-bg)}.mark-btn.ng:hover{border-color:var(--err);background:var(--err-bg)}.qa-tally{display:flex;gap:14px;justify-content:center;margin:10px 0;flex-wrap:wrap}.tally{font-weight:700;font-size:15px}.tally.correct{color:var(--ok)}.tally.partial{color:#b45309}.tally.incorrect{color:var(--err)}.review-list{display:flex;flex-direction:column;gap:10px}.review-item{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.review-q{font-weight:600;margin-bottom:4px}.review-a{font-size:14px;color:var(--text)}.review-talk{font-size:13px;color:var(--teal-600);margin-top:4px}.hero-cta-row{margin-top:16px}.btn-cta{background:#fff;color:var(--navy);border:none;padding:12px 22px;border-radius:10px;font-size:15px;font-weight:700;box-shadow:var(--shadow)}.btn-cta:hover{background:#f0f4fa}.pass-banner{display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-left:5px solid var(--teal);border-radius:var(--radius);padding:18px 20px;margin:14px 0 20px;box-shadow:var(--shadow)}.pass-banner.passed{border-left-color:var(--ok);background:var(--ok-bg)}.pass-emoji{font-size:34px}.pass-title{font-size:18px;font-weight:700}.pass-progress{margin-left:auto;min-width:200px}.progress-track{background:#e8edf4;border-radius:999px;height:10px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--navy));border-radius:999px;transition:width .4s}.progress-label{font-size:13px;color:var(--muted);margin-top:6px;text-align:right}.step-list{display:flex;flex-direction:column;gap:12px}.step-card{display:flex;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.step-card.cleared{border-color:#bbf7d0;background:#f6fef9}.step-card.current{border-color:var(--navy);box-shadow:0 0 0 2px #13335f26}.step-num{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:#eef3fb;color:var(--navy);font-weight:800;display:grid;place-items:center}.step-card.cleared .step-num{background:var(--ok);color:#fff}.step-body{flex:1;min-width:0}.step-head{display:flex;align-items:center;gap:10px}.step-head h3{margin:0;font-size:17px}.now-tag{background:var(--navy);color:#fff;font-size:11px;font-weight:700;padding:2px 10px;border-radius:999px}.step-todo{margin:6px 0 10px;font-size:14px;color:var(--text)}.step-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:12px}.step-crit{font-size:13px;color:var(--muted)}.step-status{font-size:13px;font-weight:700;padding:2px 10px;border-radius:999px}.step-status.ok{background:var(--ok-bg);color:var(--ok)}.step-status.ng{background:#f3f4f6;color:var(--muted)}@media(max-width:800px){.layout{flex-direction:column}.sidebar{width:100%;position:static;flex-direction:row;flex-wrap:wrap;padding:10px}.nav-item{flex:1 1 auto}.content{padding:20px 16px}.two-col{flex-direction:column}.list{width:100%}.fb-cols{grid-template-columns:1fr}}
