:root{--bg: #F6D64A;--surface: #FFF7E6;--ink: #111111;--muted: #6B6B6B;--red: #E53935;--blue: #2F6FE4;--teal: #2BB7A7;--orange: #FF8A3D;--purple: #6F4EF6;--radius: 20px;--stroke: 3px;--shadow: 6px 6px 0 var(--ink);--bounce: cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100dvh;overflow:hidden}body{font-family:Noto Sans JP,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}#root{height:100dvh;overflow:hidden}.app-layout{position:relative;display:flex;flex-direction:column;height:100dvh;max-width:520px;margin:0 auto;background:var(--bg);overflow:hidden}.doodle-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.doodle-layer:before{content:"★";position:absolute;top:120px;right:18px;font-size:32px;color:var(--red);opacity:.25;transform:rotate(15deg)}.doodle-layer:after{content:none}.header{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);color:var(--ink);font-family:"M PLUS Rounded 1c",sans-serif;font-weight:800;font-size:15px;flex-shrink:0;border-bottom:var(--stroke) solid var(--ink)}.header-back{background:var(--surface);border:var(--stroke) solid var(--ink);color:var(--ink);font-size:13px;font-weight:700;padding:6px 14px;border-radius:10px;cursor:pointer;font-family:"M PLUS Rounded 1c",sans-serif;box-shadow:3px 3px 0 var(--ink);transition:all .12s ease}.header-back:hover{background:var(--ink);color:var(--surface)}.header-back:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.header-home{background:var(--surface);color:var(--ink);justify-content:space-between;border-bottom:var(--stroke) solid var(--ink)}.header-home .header-back{border-color:var(--ink);color:var(--ink)}.header-home .header-back:hover{background:var(--ink);color:var(--surface)}.header-title{font-family:Yusei Magic,sans-serif;font-size:17px;font-weight:400;color:var(--ink);transform:rotate(-3deg);display:inline-block}.header-right{display:flex;align-items:center;gap:8px}.header-logo{height:56px;object-fit:contain}.home-logo{width:200px;object-fit:contain}.login-area{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:8px}.login-skip{background:none;border:none;font-family:Noto Sans JP,sans-serif;font-size:13px;color:var(--muted);cursor:pointer;text-decoration:underline;padding:8px}.login-skip:hover{color:var(--ink)}.login-notice{font-size:13px;color:var(--muted);padding:12px 20px;background:var(--surface);border-radius:12px;border:var(--stroke) solid var(--ink);box-shadow:var(--shadow)}.header-user{display:flex;align-items:center;gap:8px}.header-avatar{width:28px;height:28px;border-radius:50%;border:var(--stroke) solid var(--ink)}.home-greeting{font-size:14px;font-weight:700;font-family:"M PLUS Rounded 1c",sans-serif;color:var(--ink)}.home{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:32px 24px;overflow-y:auto}.home-title{font-family:"M PLUS Rounded 1c",sans-serif;font-size:30px;font-weight:900;text-align:center;line-height:1.3;color:var(--ink);letter-spacing:-.04em}.home-subtitle{font-size:14px;color:var(--muted);text-align:center}.qr-area{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 0}.qr-hint{font-size:13px;color:var(--muted)}.upload-zone{width:100%;max-width:360px;border:var(--stroke) dashed var(--ink);border-radius:var(--radius);padding:40px 24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:var(--surface)}.upload-zone:hover,.upload-zone.drag-over{border-style:solid;background:#fff}.upload-zone-icon{font-size:48px;margin-bottom:12px}.upload-zone-text{font-size:14px;font-weight:700;font-family:"M PLUS Rounded 1c",sans-serif;color:var(--ink)}.upload-zone-hint{font-size:12px;color:var(--muted);margin-top:8px}.home-actions{width:100%;max-width:360px;display:flex;flex-direction:column;gap:12px}.home-action-btn{width:100%;padding:18px 20px;border:var(--stroke) solid var(--ink);border-radius:16px;background:var(--surface);cursor:pointer;display:flex;align-items:center;gap:16px;text-align:left;font-family:Noto Sans JP,sans-serif;box-shadow:var(--shadow);transition:all .12s ease}.home-action-btn:hover{transform:translateY(-2px);box-shadow:8px 8px 0 var(--ink)}.home-action-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}.home-action-icon{font-size:28px;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:var(--bg);border:2px solid var(--ink)}.home-action-label{font-family:"M PLUS Rounded 1c",sans-serif;font-size:16px;font-weight:800;color:var(--ink);display:block}.home-action-text{flex:1;display:flex;flex-direction:column}.home-action-desc{font-size:12px;color:var(--muted);display:block;margin-top:2px}.home-action-badge{background:var(--red);color:#fff;font-family:"M PLUS Rounded 1c",sans-serif;font-size:13px;font-weight:800;min-width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 8px;flex-shrink:0;border:2px solid var(--ink)}.subject-tabs{position:relative;z-index:1;display:flex;gap:0;padding:0 16px;overflow-x:auto;flex-shrink:0;border-bottom:var(--stroke) solid var(--ink);background:var(--surface)}.subject-tab{padding:10px 16px;border-radius:0;border:none;border-bottom:3px solid transparent;background:transparent;font-family:"M PLUS Rounded 1c",sans-serif;font-weight:700;font-size:13px;cursor:pointer;color:var(--muted);white-space:nowrap;transition:all .15s}.subject-tab.active{border-bottom-color:var(--red);color:var(--ink);background:transparent}.subject-tab:not(.active):hover{color:var(--ink)}.empty-state{text-align:center;padding:48px 24px;color:var(--muted);font-size:14px;font-weight:600}.review-screen{position:relative;z-index:1;flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}.review-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px}.review-empty-icon{font-size:48px}.review-empty-text{font-family:"M PLUS Rounded 1c",sans-serif;font-size:17px;font-weight:800;color:var(--ink)}.review-empty-sub{font-size:13px;color:var(--muted);text-align:center}.review-card{width:100%;padding:16px 18px;border:var(--stroke) solid var(--ink);border-radius:14px;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-family:Noto Sans JP,sans-serif;box-shadow:var(--shadow);transition:all .12s ease;animation:fade-in .3s ease}.review-card:hover{transform:translateY(-2px);box-shadow:8px 8px 0 var(--ink)}.review-card:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}.review-card.all{border-color:var(--red);box-shadow:6px 6px 0 var(--red)}.review-card-left{display:flex;align-items:center;gap:12px}.review-card-icon{font-size:24px}.review-card-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:2px solid var(--ink)}.review-card-text{display:flex;flex-direction:column}.review-card-title{font-family:"M PLUS Rounded 1c",sans-serif;font-size:15px;font-weight:800;color:var(--ink)}.review-card-desc{font-size:12px;color:var(--muted);margin-top:2px}.review-card-count{font-family:"M PLUS Rounded 1c",sans-serif;font-size:14px;font-weight:800;color:var(--ink)}.tab-btn{padding:8px 16px;border-radius:10px;border:var(--stroke) solid var(--ink);background:var(--surface);font-family:"M PLUS Rounded 1c",sans-serif;font-weight:700;font-size:13px;cursor:pointer;color:var(--ink);box-shadow:3px 3px 0 var(--ink);transition:all .12s}.tab-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.tab-btn.active{background:var(--blue);color:#fff;border-color:var(--ink)}.create-tabs{display:flex;gap:8px;margin-bottom:4px}.create-text-area{width:100%;max-width:360px;display:flex;flex-direction:column;gap:12px}.create-textarea{width:100%;height:160px;padding:14px;border-radius:14px;border:var(--stroke) solid var(--ink);background:var(--surface);color:var(--ink);font-family:Noto Sans JP,sans-serif;font-size:14px;line-height:1.7;resize:none;outline:none;box-shadow:var(--shadow)}.create-textarea:focus{border-color:var(--blue);box-shadow:6px 6px 0 var(--blue)}.select-screen{position:relative;z-index:1;flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.quiz-card{width:100%;padding:16px 18px;border:var(--stroke) solid var(--ink);border-radius:14px;background:var(--surface);cursor:pointer;display:flex;align-items:center;gap:12px;text-align:left;font-family:Noto Sans JP,sans-serif;box-shadow:var(--shadow);transition:all .12s ease;animation:fade-in .3s ease}.quiz-card.no-hover{cursor:default}.quiz-card.no-hover:hover{transform:none;box-shadow:var(--shadow)}.quiz-card:hover{transform:translateY(-2px);box-shadow:8px 8px 0 var(--ink)}.quiz-card:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}.quiz-card-badge{font-family:"M PLUS Rounded 1c",sans-serif;font-size:11px;font-weight:800;color:#fff;padding:4px 10px;border-radius:6px;flex-shrink:0;border:2px solid var(--ink)}.quiz-card-title{flex:1;font-family:"M PLUS Rounded 1c",sans-serif;font-size:15px;font-weight:800;color:var(--ink)}.quiz-card-meta{font-size:12px;color:var(--muted);flex-shrink:0}.select-section-divider{display:flex;align-items:center;gap:10px;margin:8px 0 0;font-size:13px;font-weight:700;color:var(--muted);letter-spacing:.05em}.select-section-divider:before,.select-section-divider:after{content:"";flex:1;height:1px;background:var(--ink);opacity:.15}.quiz-card-wrapper{display:flex;gap:8px;align-items:stretch;animation:fade-in .3s ease}.quiz-card-wrapper .quiz-card{flex:1;min-width:0;animation:none}.quiz-card-publish-btn{flex-shrink:0;padding:0 14px;border:var(--stroke) solid var(--ink);border-radius:14px;background:var(--blue);color:#fff;font-family:"M PLUS Rounded 1c",sans-serif;font-size:13px;font-weight:800;cursor:pointer;box-shadow:4px 4px 0 var(--ink);transition:all .12s ease;white-space:nowrap}.quiz-card-publish-btn:hover{transform:translateY(-1px);box-shadow:5px 5px 0 var(--ink)}.quiz-card-publish-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.quiz-card-publish-btn.unpublish{background:var(--muted)}.quiz-card-public-tag{display:inline-block;margin-left:6px;padding:2px 8px;border-radius:4px;background:var(--teal);color:#fff;font-size:10px;font-weight:800;vertical-align:middle;border:1.5px solid var(--ink)}.quiz-card-author{display:inline-block;margin-left:6px;font-size:11px;font-weight:600;color:var(--muted);vertical-align:middle}.publish-modal{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:520px;background:var(--surface);border-top:var(--stroke) solid var(--ink);border-radius:20px 20px 0 0;padding:24px 20px 32px;z-index:100;display:flex;flex-direction:column;gap:16px;box-shadow:0 -4px 0 var(--ink);animation:slide-up .2s var(--bounce)}.publish-modal-title{font-family:"M PLUS Rounded 1c",sans-serif;font-size:16px;font-weight:800;color:var(--ink);text-align:center}.publish-subject-picker{display:grid;grid-template-columns:1fr 1fr;gap:10px}.publish-subject-btn{padding:14px;border:var(--stroke) solid var(--ink);border-radius:12px;background:var(--surface);font-family:"M PLUS Rounded 1c",sans-serif;font-size:15px;font-weight:800;color:var(--ink);cursor:pointer;box-shadow:4px 4px 0 var(--ink);transition:all .12s ease}.publish-subject-btn:hover{transform:translateY(-1px);box-shadow:5px 5px 0 var(--ink)}.publish-subject-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.publish-subject-btn.active{border-color:var(--ink);box-shadow:2px 2px 0 var(--ink);transform:translate(2px,2px)}.publish-confirm-btn{width:100%;padding:14px;border:var(--stroke) solid var(--ink);border-radius:14px;background:var(--red);color:#fff;font-family:"M PLUS Rounded 1c",sans-serif;font-size:15px;font-weight:800;cursor:pointer;box-shadow:var(--shadow);transition:all .12s}.publish-confirm-btn:hover{transform:translateY(-1px);box-shadow:7px 7px 0 var(--ink)}.publish-confirm-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}.publish-confirm-btn:disabled{opacity:.4;cursor:default;transform:none;box-shadow:var(--shadow)}.publish-questions{max-height:180px;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding:8px 4px;border:2px solid var(--ink);border-radius:10px;background:#fff}.publish-question-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--ink);transition:background .1s}.publish-question-item:hover{background:var(--bg)}.publish-question-item input[type=checkbox]{width:18px;height:18px;flex-shrink:0;accent-color:var(--blue)}.publish-question-num{font-family:"M PLUS Rounded 1c",sans-serif;font-weight:800;font-size:12px;flex-shrink:0;min-width:28px}.publish-question-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;color:var(--muted)}.publish-subject-row{display:flex;gap:10px;align-items:stretch}.publish-subject-row .publish-subject-picker{flex:1;min-width:0}.publish-ai-btn{flex-shrink:0;padding:10px 14px;border:var(--stroke) solid var(--ink);border-radius:12px;background:var(--purple);color:#fff;font-family:"M PLUS Rounded 1c",sans-serif;font-size:13px;font-weight:800;cursor:pointer;box-shadow:4px 4px 0 var(--ink);transition:all .12s ease;white-space:nowrap}.publish-ai-btn:hover{transform:translateY(-1px);box-shadow:5px 5px 0 var(--ink)}.publish-ai-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.publish-ai-btn:disabled{opacity:.5;cursor:default;transform:none}.quiz-screen{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;overflow-y:auto}.quiz-progress{padding:8px 16px;display:flex;align-items:center;gap:10px;flex-shrink:0}.quiz-progress-bar{flex:1;height:10px;background:var(--surface);border-radius:5px;overflow:hidden;border:2px solid var(--ink)}.quiz-progress-fill{height:100%;background:var(--teal);border-radius:3px;transition:width .4s var(--bounce)}.quiz-progress-text{font-family:"M PLUS Rounded 1c",sans-serif;font-size:13px;font-weight:800;color:var(--ink);white-space:nowrap}.quiz-question-area{flex-shrink:0;display:flex;flex-direction:column;justify-content:center;padding:20px 20px 12px;overflow-y:auto}.quiz-question-text{font-family:"M PLUS Rounded 1c",sans-serif;font-size:18px;font-weight:800;line-height:1.7;text-align:center;color:var(--ink)}.quiz-choices{padding:12px 16px 24px;display:flex;flex-direction:column;gap:10px;flex-shrink:0}.quiz-choice{width:100%;padding:14px 16px;border:var(--stroke) solid var(--ink);border-radius:14px;background:var(--surface);font-family:Noto Sans JP,sans-serif;font-size:15px;font-weight:600;color:var(--ink);text-align:left;cursor:pointer;display:flex;align-items:center;gap:12px;box-shadow:4px 4px 0 var(--ink);transition:all .12s ease}.quiz-choice:hover{transform:translateY(-1px);box-shadow:5px 5px 0 var(--ink)}.quiz-choice:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.quiz-choice-label{width:30px;height:30px;border-radius:8px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:"M PLUS Rounded 1c",sans-serif;font-size:14px;font-weight:800;flex-shrink:0}.quiz-choice.correct{border-color:var(--teal);background:#e0f7f2;box-shadow:4px 4px 0 var(--teal);animation:pop-in .3s var(--bounce)}.quiz-choice.correct .quiz-choice-label{background:var(--teal);color:#fff}.quiz-choice.wrong{border-color:var(--orange);background:#fff0e5;box-shadow:4px 4px 0 var(--orange);animation:shake .4s ease}.quiz-choice.wrong .quiz-choice-label{background:var(--orange);color:#fff}.quiz-choice.disabled{pointer-events:none;opacity:.4}.quiz-choice.disabled.correct{opacity:1}.quiz-explanation{padding:12px 20px calc(40px + env(safe-area-inset-bottom,0px));flex-shrink:0}.quiz-explanation-box{background:var(--surface);border-radius:0 12px 12px 0;padding:14px 16px;font-size:13px;line-height:1.7;color:var(--ink);border:var(--stroke) solid var(--ink);border-left:4px solid var(--blue);box-shadow:var(--shadow);animation:fade-in .3s ease}.difficulty-feedback{margin-top:12px;display:flex;flex-direction:column;align-items:center;gap:8px;animation:fade-in .3s ease}.difficulty-feedback-label{font-family:"M PLUS Rounded 1c",sans-serif;font-size:13px;font-weight:700;color:var(--muted)}.difficulty-feedback-buttons{display:flex;gap:8px;width:100%}.difficulty-btn{flex:1;padding:10px 4px;border:var(--stroke) solid var(--ink);border-radius:12px;background:var(--surface);font-family:"M PLUS Rounded 1c",sans-serif;font-size:13px;font-weight:700;color:var(--ink);cursor:pointer;box-shadow:3px 3px 0 var(--ink);transition:all .12s ease;text-align:center;white-space:nowrap}.difficulty-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.difficulty-btn.selected{background:var(--blue);color:#fff;border-color:var(--ink);transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.difficulty-btn.dimmed{opacity:.35;pointer-events:none}.difficulty-btn:disabled{cursor:default}.quiz-explanation-box strong{color:var(--blue)}.quiz-next-btn{display:block;width:100%;margin-top:12px;padding:14px;border:var(--stroke) solid var(--ink);border-radius:14px;background:var(--red);color:#fff;font-family:"M PLUS Rounded 1c",sans-serif;font-size:15px;font-weight:800;cursor:pointer;box-shadow:var(--shadow);transition:all .12s}.quiz-next-btn:hover{transform:translateY(-1px);box-shadow:7px 7px 0 var(--ink)}.quiz-next-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}.quiz-question-tag{display:inline-block;background:var(--purple);color:#fff;font-family:"M PLUS Rounded 1c",sans-serif;font-size:12px;font-weight:800;padding:3px 12px;border-radius:6px;border:2px solid var(--ink);margin-bottom:8px;align-self:center}.mode-select-screen{align-items:center;justify-content:center;gap:28px;padding:32px 24px}.mode-select-title{font-family:"M PLUS Rounded 1c",sans-serif;font-size:22px;font-weight:900;color:var(--ink);text-align:center}.mode-selector{display:flex;gap:16px;justify-content:center;animation:fade-in .3s ease}.mode-btn{flex:1;max-width:170px;padding:28px 16px;border:var(--stroke) solid var(--ink);border-radius:20px;background:var(--surface);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:10px;box-shadow:var(--shadow);transition:all .12s ease}.mode-btn:hover{transform:translateY(-3px);box-shadow:8px 8px 0 var(--ink)}.mode-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}.mode-btn.writing:hover{border-color:var(--purple);box-shadow:8px 8px 0 var(--purple)}.mode-btn.choice:hover{border-color:var(--blue);box-shadow:8px 8px 0 var(--blue)}.mode-btn-icon{font-size:32px;font-weight:900;font-family:"M PLUS Rounded 1c",sans-serif;color:var(--ink)}.mode-btn-label{font-family:"M PLUS Rounded 1c",sans-serif;font-size:16px;font-weight:800;color:var(--ink)}.mode-btn-desc{font-size:12px;color:var(--muted)}.writing-area{padding:12px 16px 24px;display:flex;flex-direction:column;align-items:center;flex-shrink:0}.writing-canvas-container{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:320px}.writing-canvas{width:100%;max-width:280px;aspect-ratio:1;border:var(--stroke) solid var(--ink);border-radius:16px;box-shadow:var(--shadow);background:#fff;touch-action:none;cursor:crosshair}.writing-canvas-actions{display:flex;gap:10px}.writing-action-btn{padding:8px 20px;border:var(--stroke) solid var(--ink);border-radius:10px;background:var(--surface);font-family:"M PLUS Rounded 1c",sans-serif;font-size:13px;font-weight:700;color:var(--ink);cursor:pointer;box-shadow:3px 3px 0 var(--ink);transition:all .12s}.writing-action-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.writing-action-btn:disabled{opacity:.4;cursor:default}.writing-submit-btn{width:100%;max-width:280px;padding:14px;border:var(--stroke) solid var(--ink);border-radius:14px;background:var(--blue);color:#fff;font-family:"M PLUS Rounded 1c",sans-serif;font-size:15px;font-weight:800;cursor:pointer;box-shadow:var(--shadow);transition:all .12s}.writing-submit-btn:hover{transform:translateY(-1px);box-shadow:7px 7px 0 var(--ink)}.writing-submit-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}.writing-submit-btn:disabled{opacity:.4;cursor:default;transform:none;box-shadow:var(--shadow)}.writing-checking{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 0;font-family:"M PLUS Rounded 1c",sans-serif;font-size:14px;font-weight:700;color:var(--ink)}.writing-feedback{width:100%;max-width:320px;padding:20px;border-radius:16px;border:var(--stroke) solid var(--ink);box-shadow:var(--shadow);animation:pop-in .3s var(--bounce)}.writing-feedback.correct{background:#e0f7f2;border-color:var(--teal);box-shadow:6px 6px 0 var(--teal)}.writing-feedback.wrong{background:#fff0e5;border-color:var(--orange);box-shadow:6px 6px 0 var(--orange)}.writing-correct-display,.writing-wrong-display{display:flex;align-items:center;gap:12px}.writing-result-icon{font-size:36px;font-weight:900;flex-shrink:0}.writing-feedback.correct .writing-result-icon{color:var(--teal)}.writing-feedback.wrong .writing-result-icon{color:var(--orange)}.writing-result-answer{font-family:"M PLUS Rounded 1c",sans-serif;font-size:32px;font-weight:900;color:var(--ink)}.writing-result-detail{display:flex;flex-direction:column;gap:4px;font-size:14px;font-weight:600;color:var(--ink)}.result-screen{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:32px 24px}.result-score{font-family:"M PLUS Rounded 1c",sans-serif;font-size:64px;font-weight:900;color:var(--red)}.result-score-label{font-size:14px;color:var(--muted)}.result-message{font-family:"M PLUS Rounded 1c",sans-serif;font-size:22px;font-weight:900;text-align:center;color:var(--ink)}.result-detail{font-size:14px;color:var(--muted);text-align:center;line-height:1.8}.result-actions{display:flex;gap:12px}.result-btn{padding:14px 32px;border:var(--stroke) solid var(--ink);border-radius:14px;font-family:"M PLUS Rounded 1c",sans-serif;font-size:15px;font-weight:800;cursor:pointer;box-shadow:var(--shadow);transition:all .12s}.result-btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}.result-btn.primary{background:var(--red);color:#fff}.result-btn.primary:hover{transform:translateY(-1px);box-shadow:7px 7px 0 var(--ink)}.result-btn.secondary{background:var(--surface);color:var(--ink)}.result-btn.secondary:hover{transform:translateY(-1px);box-shadow:7px 7px 0 var(--ink)}.loading{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.loading-spinner{width:40px;height:40px;border:4px solid var(--ink);border-top-color:var(--red);border-radius:50%;animation:spin .8s linear infinite}.loading-text{font-family:"M PLUS Rounded 1c",sans-serif;font-size:14px;font-weight:700;color:var(--ink)}.id-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;background:var(--surface);color:var(--ink);font-family:"M PLUS Rounded 1c",sans-serif;font-size:13px;font-weight:700;border:var(--stroke) solid var(--ink);cursor:pointer;white-space:nowrap;box-shadow:3px 3px 0 var(--ink);transition:all .12s}.id-badge:hover{transform:translateY(-1px);box-shadow:4px 4px 0 var(--ink)}.id-badge:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.id-badge-none{background:var(--surface);color:var(--muted)}.id-badge-none:hover{color:var(--ink)}.id-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90}.id-menu-dropdown{position:fixed;top:50px;right:12px;background:var(--surface);border:var(--stroke) solid var(--ink);border-radius:16px;padding:6px;box-shadow:8px 8px 0 var(--ink);min-width:180px;z-index:100;display:flex;flex-direction:column;gap:2px;animation:drop-in .15s var(--bounce)}.id-menu-item{display:block;width:100%;padding:8px 12px;border:none;background:transparent;border-radius:10px;font-size:13px;color:var(--ink);cursor:pointer;text-align:left;font-weight:500;font-family:Noto Sans JP,sans-serif;transition:background .15s}.id-menu-item:hover{background:var(--bg)}.id-menu-item:disabled{opacity:.5;cursor:default}.id-menu-item.danger{color:var(--red)}.id-menu-confirm{display:flex;gap:6px;align-items:center;justify-content:center;padding:4px 0}.id-menu-confirm-label{font-size:12px;color:var(--muted)}.id-menu-btn-yes{font-size:12px;padding:3px 12px;border-radius:6px;border:2px solid var(--ink);background:var(--red);color:#fff;cursor:pointer;font-weight:600;font-family:Noto Sans JP,sans-serif}.id-menu-btn-yes:disabled{opacity:.5;cursor:default}.id-menu-btn-no{font-size:12px;padding:3px 12px;border-radius:6px;border:2px solid var(--ink);background:transparent;color:var(--ink);cursor:pointer;font-family:Noto Sans JP,sans-serif}.id-menu-restore{display:flex;flex-direction:column;gap:6px;padding:4px 6px}.id-menu-restore input{font-size:13px;padding:6px 10px;border-radius:8px;border:2px solid var(--ink);background:#fff;color:var(--ink);text-align:center;font-family:Noto Sans JP,sans-serif;outline:none}.id-menu-restore input:focus{border-color:var(--blue)}.id-menu-restore-actions{display:flex;gap:6px;justify-content:center}.id-menu-error{font-size:11px;color:var(--red);text-align:center}.section-divider{width:100%;height:4px;background:repeating-linear-gradient(-45deg,var(--ink),var(--ink) 4px,transparent 4px,transparent 8px);margin:8px 0}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes drop-in{0%{opacity:0;transform:scale(.9) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes pop-in{0%{transform:scale(.95)}50%{transform:scale(1.02)}to{transform:scale(1)}}@keyframes slide-up{0%{transform:translate(-50%,100%)}to{transform:translate(-50%)}}
