*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green-dark: #231815;--green: #d4a017;--green-light: #f0c040;--green-pale: #fff8dc;--sidebar-w: 240px;--sidebar-w-mobile: 64px;--bg: #F5F5F5;--white: #fff;--gray: #6b7280;--light-gray: #f3f4f6}html,body,#root{height:100%}body{font-family:Noto Sans JP,sans-serif;background:var(--bg);font-size:16px}textarea,input,button,select{font-family:Noto Sans JP,sans-serif}button{cursor:pointer}a{text-decoration:none;color:inherit}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);background:#fff;border-right:1px solid #eaeaea;display:flex;flex-direction:column;flex-shrink:0;transition:width .25s;overflow:hidden;z-index:100}.sidebar-logo{padding:18px 16px 14px;border-bottom:1px solid #eaeaea;display:flex;flex-direction:column;align-items:flex-start;gap:4px;color:#231815;flex-shrink:0}.sidebar-logo .logo-img{width:160px;height:auto;display:block}.sidebar-logo .logo-sub{font-size:16px;color:#231815;white-space:nowrap;letter-spacing:1px}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:10px;color:#231815b3;cursor:pointer;transition:all .15s;border:none;background:none;width:100%;text-align:left;white-space:nowrap;overflow:hidden;font-size:16px;font-weight:600}.nav-item:hover{background:#f7f7f7;color:#231815}.nav-item.active{background:#fce62f;color:#231815}.nav-item .nav-icon{font-size:22px;flex-shrink:0}.nav-item .nav-label{font-size:16px;font-weight:600}.nav-item .nav-badge{margin-left:auto;background:#231815;color:#fce62f;font-size:12px;font-weight:700;padding:3px 8px;border-radius:10px;flex-shrink:0}.sidebar-divider{height:1px;background:#eaeaea;margin:6px 8px}.sidebar-user{padding:18px 16px;border-top:1px solid #eaeaea;color:#231815;font-size:16px;font-weight:600;display:flex;align-items:center;gap:10px;white-space:nowrap;overflow:hidden;flex-shrink:0}.sidebar-user .user-dot{width:9px;height:9px;border-radius:50%;background:#231815;flex-shrink:0}.sidebar-user .logout-btn{margin-left:auto;background:none;border:none;color:#231815;font-size:16px;cursor:pointer}.sidebar-user .logout-btn:hover{color:#231815;opacity:.6}.main-content{flex:1;overflow:hidden;display:flex;flex-direction:column;background:var(--bg)}.panel{display:none;flex-direction:column;height:100%;overflow:hidden}.panel.active{display:flex}.panel-header{color:#231815;padding:14px 20px;border-bottom:1px solid #eaeaea;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.panel-header-left{display:flex;align-items:center;gap:10px}.panel-header-title{font-weight:800;font-size:20px}.panel-header-sub{font-size:14px;opacity:.7}.back-btn{background:#0000000f;border:none;color:#231815;border-radius:8px;padding:8px 14px;font-size:14px;cursor:pointer;margin-right:8px}.progress-bar-wrap{height:5px;background:#ddd;flex-shrink:0}.progress-bar-fill{height:100%;background:var(--green-light);transition:width .4s}.login-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--green-dark),var(--green))}.login-card{background:#fff;border-radius:16px;padding:40px 32px;max-width:400px;width:90%;text-align:center;box-shadow:0 8px 40px #0000004d}.login-card .login-logo{width:220px;height:auto;display:block;margin:0 auto 10px}.login-card .subtitle{font-size:13px;color:#888;margin-bottom:28px}.login-card input{width:100%;padding:12px 14px;border-radius:10px;border:2px solid #e5e7eb;font-size:14px;margin-bottom:12px;outline:none;transition:border-color .15s}.login-card input:focus{border-color:var(--green)}.login-card .login-btn{width:100%;padding:13px;border-radius:10px;border:none;background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff;font-size:15px;font-weight:700;cursor:pointer;margin-top:4px;transition:opacity .15s}.login-card .login-btn:disabled{opacity:.5;cursor:default}.login-card .error{color:#dc2626;font-size:12px;margin-bottom:8px}.lesson-section{margin-bottom:20px}.section-header{color:#fff;border-radius:12px 12px 0 0;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;margin-bottom:0}.section-header-left{display:flex;align-items:center;gap:12px}.section-header-title{font-weight:800;font-size:18px}.section-header-sub{font-size:14px;opacity:.85}.lesson-list{background:#fff;border-radius:0 0 12px 12px;overflow:hidden;box-shadow:0 2px 8px #0000000f;margin-top:0}.lesson-row{padding:12px 16px;display:flex;align-items:center;gap:8px;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background .1s}.lesson-row>.lesson-row-main{flex:1;min-width:0;display:flex;align-items:center;gap:8px}.lesson-row>.lesson-chevron{flex-shrink:0;color:#ccc;font-size:22px}.lesson-row:last-child{border-bottom:none}.lesson-row:hover{background:#fafafa}.lesson-row.done{background:#f6faf8}.lesson-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.lesson-title{font-size:16px;font-weight:600;color:#222}.lesson-title.done{font-weight:400;color:#888}.lesson-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:5px}.badge{font-size:12px;padding:3px 8px;border-radius:8px}.content-frame{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #00000014;margin-bottom:14px}.content-empty{height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#ccc}.tab-row{display:flex;gap:8px;margin-bottom:12px}.tab-btn{flex:1;padding:12px;border-radius:10px;border:none;font-size:15px;font-weight:700;cursor:pointer;transition:all .15s}.action-btn{width:100%;padding:16px;border-radius:12px;border:none;font-size:16px;font-weight:700;cursor:pointer;color:#fff}.quiz-wrap{padding:16px;max-width:620px;margin:0 auto}.quiz-card{background:#fff;border-radius:12px;padding:22px;box-shadow:0 2px 8px #0000000f}.quiz-question{font-weight:700;font-size:18px;line-height:1.6;margin-bottom:20px}.quiz-option{padding:14px 16px;border-radius:10px;margin-bottom:10px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .15s;font-size:16px;border:1px solid #ddd}.quiz-radio{width:24px;height:24px;border-radius:50%;border:2px solid #ccc;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.quiz-submit,.quiz-next{width:100%;padding:15px;border-radius:10px;border:none;font-size:16px;font-weight:700;cursor:pointer;color:#fff}.quiz-result{text-align:center;padding:14px;border-radius:10px;margin-bottom:12px}.rp-scenario-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-bottom:24px}.rp-sc-card{position:relative;text-align:left;border:3px solid transparent;border-radius:16px;padding:22px 22px 24px;cursor:pointer;transition:all .15s;color:#fff;font-family:inherit;box-shadow:0 2px 10px #00000014}.rp-sc-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000026}.rp-sc-card.selected{border-color:#231815;box-shadow:0 0 0 3px #2318152e,0 6px 18px #00000026}.rp-sc-card .rp-sc-icon{font-size:36px;margin-bottom:12px;line-height:1}.rp-sc-card .rp-sc-title{font-size:19px;font-weight:800;margin-bottom:6px;color:#fff}.rp-sc-card .rp-sc-desc{font-size:14px;color:#fff;opacity:.9;line-height:1.5}.rp-sc-card .rp-sc-tag{position:absolute;top:12px;right:12px;background:#00000040;color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:10px}.diff-row{display:flex;gap:8px;margin-bottom:24px}.diff-btn{flex:1;padding:14px;border-radius:10px;border:2px solid #e5e7eb;background:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s}.diff-btn.sel-easy{border-color:#16a34a;background:#f0faf5;color:#16a34a}.diff-btn.sel-normal{border-color:#d97706;background:#fffbeb;color:#d97706}.diff-btn.sel-hard{border-color:#dc2626;background:#fef2f2;color:#dc2626}.rp-start-btn{width:100%;padding:18px;border-radius:12px;border:none;background:#fce62f;color:#231815;font-size:17px;font-weight:800;cursor:pointer;opacity:.5;transition:all .15s}.rp-start-btn.ready{opacity:1}.rp-start-btn.ready:hover{background:gold;transform:translateY(-1px)}.rp-start-btn:disabled{cursor:not-allowed}.chat-scroll{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;background:var(--bg)}.chat-msg{display:flex;gap:8px;align-items:flex-end;max-width:80%}.chat-msg.customer{align-self:flex-start}.chat-msg.staff{align-self:flex-end;flex-direction:row-reverse}.chat-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}.chat-bubble{padding:9px 13px;border-radius:14px;font-size:13px;line-height:1.6}.chat-msg.customer .chat-bubble{background:#fff;border-radius:4px 14px 14px;box-shadow:0 1px 3px #0000000f}.chat-msg.staff .chat-bubble{background:var(--green);color:#fff;border-radius:14px 4px 14px 14px}.chat-sys{text-align:center;font-size:11px;color:#bbb;padding:4px 0}.customer-strip{padding:14px 18px;display:flex;align-items:center;gap:14px;flex-shrink:0}.cust-avatar{width:52px;height:52px;border-radius:50%;background:#ffffff26;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;border:2px solid rgba(255,255,255,.25);position:relative}.speak-ring{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:3px solid var(--green-light);opacity:0}.speaking .speak-ring{opacity:1;animation:sring 1s ease-in-out infinite}@keyframes sring{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:.2}}.typing-ind{display:flex;align-items:center;gap:5px;padding:9px 13px;background:#fff;border-radius:4px 14px 14px;box-shadow:0 1px 3px #0000000f}.tdot{width:6px;height:6px;border-radius:50%;background:#aaa;animation:tbounce 1.2s ease-in-out infinite}.tdot:nth-child(2){animation-delay:.2s}.tdot:nth-child(3){animation-delay:.4s}@keyframes tbounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-5px);opacity:1}}.mic-btn{width:52px;height:52px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;background:var(--green-pale);transition:all .2s}.mic-btn.rec{background:#dc2626;animation:mpulse 1s ease-in-out infinite}.mic-btn:disabled{opacity:.35;cursor:default;animation:none}@keyframes mpulse{0%,to{box-shadow:0 0 #dc262666}50%{box-shadow:0 0 0 10px #dc262600}}.rp-controls{background:#fff;padding:12px 14px;border-top:1px solid #e5e7eb;flex-shrink:0}.rp-controls-row{display:flex;gap:10px;align-items:center}.rp-status{flex:1;font-size:12px;color:#888;line-height:1.5}.fb-header{text-align:center;margin-bottom:20px}.fb-emoji{font-size:50px;margin-bottom:10px}.fb-title{font-size:20px;font-weight:800;color:var(--green-dark)}.fb-sub{font-size:12px;color:#888;margin-top:4px}.fb-card{background:#fff;border-radius:14px;padding:18px;margin-bottom:12px;box-shadow:0 1px 6px #0000000f}.fb-card h3{font-size:13px;font-weight:700;margin-bottom:10px;color:var(--green-dark)}.score-row{display:flex;gap:10px}.score-box{flex:1;background:#f3f4f6;border-radius:10px;padding:12px;text-align:center}.score-val{font-size:22px;font-weight:800;color:var(--green)}.score-label{font-size:11px;color:#888;margin-top:2px}.fb-btn{width:100%;padding:13px;border-radius:12px;border:none;font-size:14px;font-weight:700;cursor:pointer;margin-top:8px}.fb-btn.primary{background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff}.fb-btn.secondary{background:#fff;border:2px solid var(--green);color:var(--green-dark)}.manual-chat-layout{display:flex;flex-direction:column;height:100%;overflow:hidden}.manual-body{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:16px 16px 0}.manual-quickq-wrap{flex-shrink:0;margin-bottom:16px}.manual-quickq-label{font-size:14px;font-weight:700;color:#666;margin-bottom:10px;letter-spacing:.5px}.manual-quickq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.manual-quickq-card{display:flex;align-items:center;gap:16px;padding:20px 22px;border-radius:14px;border:none;color:#fff;cursor:pointer;text-align:left;font-family:inherit;transition:all .15s;box-shadow:0 2px 8px #00000014}.manual-quickq-card:hover{transform:translateY(-2px);box-shadow:0 6px 14px #00000026}.manual-quickq-card:disabled{opacity:.6;cursor:not-allowed}.manual-quickq-icon{font-size:32px;line-height:1;flex-shrink:0}.manual-quickq-text{font-size:17px;font-weight:800;color:#fff}.manual-chat-scroll{flex:1;overflow-y:auto;padding:12px 4px 4px;border-top:1px solid #eaeaea;display:flex;flex-direction:column}.manual-chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#aaa;padding:20px}.manual-chat-empty-icon{font-size:64px;margin-bottom:14px;line-height:1}.manual-chat-empty-title{font-size:18px;font-weight:800;color:#555;margin-bottom:6px}.manual-chat-empty-sub{font-size:14px;color:#888;line-height:1.6}.manual-chat-input{padding:14px 16px;border-top:1px solid #eaeaea;background:#fff;display:flex;gap:10px;flex-shrink:0}.manual-chat-input textarea{flex:1;padding:12px 16px;border-radius:12px;border:2px solid #e5e7eb;font-size:16px;resize:none;outline:none;min-height:48px;max-height:140px;font-family:inherit}.manual-chat-input textarea:focus{border-color:#f5b800}.manual-chat-input button{padding:0 26px;border-radius:12px;border:none;background:#fce62f;color:#231815;font-weight:800;font-size:16px;flex-shrink:0;cursor:pointer;transition:all .15s}.manual-chat-input button:hover:not(:disabled){background:gold}.manual-chat-input button:disabled{opacity:.4;cursor:not-allowed}.ai-msg{display:flex;gap:10px;margin-bottom:14px;max-width:85%}.ai-msg.user{flex-direction:row-reverse;align-self:flex-end;margin-left:auto}.ai-msg .ai-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;overflow:hidden}.ai-msg.assistant .ai-avatar{background:transparent}.ai-msg.user .ai-avatar{background:#f0e8dc}.ai-msg .ai-bubble{padding:12px 16px;border-radius:16px;font-size:15px;line-height:1.7}.ai-msg.assistant .ai-bubble{background:#fff;border-radius:4px 16px 16px;box-shadow:0 1px 4px #00000014;color:#222}.ai-msg.user .ai-bubble{background:#1a4a6b;color:#fff;border-radius:16px 4px 16px 16px}.admin-wrap{padding:16px;max-width:900px;margin:0 auto}.admin-card{background:#fff;border-radius:12px;padding:18px;margin-bottom:14px;box-shadow:0 1px 6px #0000000f}.admin-card h3{font-size:14px;font-weight:700;margin-bottom:10px}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:20px}.stat-card{background:#fff;border-radius:12px;padding:16px;text-align:center;box-shadow:0 1px 6px #0000000f}.stat-val{font-size:28px;font-weight:800;color:#1a4a6b}.stat-label{font-size:11px;color:#888;margin-top:4px}.staff-table{width:100%;border-collapse:collapse;font-size:13px}.staff-table th{text-align:left;padding:10px 12px;background:#f9fafb;font-weight:700;color:#555;border-bottom:2px solid #e5e7eb}.staff-table td{padding:10px 12px;border-bottom:1px solid #f0f0f0}.staff-table tr:hover td{background:#fafafa}.progress-mini{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden;width:80px}.progress-mini-fill{height:100%;background:var(--green-light);border-radius:3px}.cert-card{background:#fff;border:2px solid var(--green-pale);border-radius:16px;padding:24px;margin-bottom:14px;text-align:center;box-shadow:0 2px 12px #0000000f}.cert-card .cert-icon{font-size:40px;margin-bottom:8px}.cert-card .cert-title{font-size:16px;font-weight:800;color:var(--green-dark)}.cert-card .cert-number{font-size:11px;color:#aaa;margin-top:4px}.cert-card .cert-date{font-size:12px;color:#888;margin-top:8px}.scroll-area{flex:1;overflow-y:auto}.scroll-inner{padding:16px}@media(max-width:640px){.sidebar{width:var(--sidebar-w-mobile)}.sidebar-logo .logo-sub,.nav-item .nav-label,.nav-item .nav-badge,.sidebar-user span,.sidebar-user .logout-btn{display:none}.sidebar-logo{align-items:center;padding:16px 4px}.sidebar-logo .logo-img{width:48px}.nav-item{justify-content:center;padding:12px}.rp-scenario-grid,.manual-quickq-grid{grid-template-columns:1fr}}.admin-textarea{width:100%;padding:10px 12px;border-radius:8px;border:1px solid #ddd;font-size:12px;resize:vertical;line-height:1.5;outline:none}.admin-input{width:100%;padding:8px 10px;border-radius:8px;border:1px solid #ddd;font-size:13px;outline:none;margin-bottom:8px}.save-btn{width:100%;padding:13px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff;font-size:15px;font-weight:700;cursor:pointer}.add-link{width:100%;padding:10px;border:2px dashed var(--green);border-radius:10px;background:none;color:var(--green);font-size:13px;font-weight:700;cursor:pointer;margin-top:6px}
