/* ============================================
   基礎テスト — IT & ビジネス常識
   セージグリーン × ボタニカル
   ============================================ */
:root {
  --sage-50:#F4F7F1; --sage-100:#E5EDDF; --sage-200:#C9D9BD; --sage-300:#AEC59B;
  --sage-400:#9CAF88; --sage-500:#7E956A; --sage-600:#607851; --sage-700:#4A5E40;
  --cream-50:#FAF8EE; --cream-100:#F4F2E8; --cream-200:#ECE9D8;
  --text:#4A5240; --text-mute:#8A9080; --text-light:#B5B8A8; --text-dark:#2C3328;
  --bg:#F4F2E8; --card:#FFFFFC; --card-soft:#F8F6EC; --border:#E5E2D2; --border-soft:#EFEDE0;
  --shadow-sm:0 1px 3px rgba(74,82,64,.04);
  --shadow:0 2px 12px rgba(74,82,64,.05),0 1px 3px rgba(74,82,64,.04);
  --shadow-lg:0 8px 28px rgba(74,82,64,.08);
  --danger:#C97474; --danger-bg:#FBEEEE; --ok:#7E956A; --ok-bg:#EDF3E6;
  --gold:#C9A86A;
  --it:#6E8FA8; --it-bg:#EAF1F5;
  --biz:#A88B6E; --biz-bg:#F5EEE6;
  --font-jp:'Noto Serif JP','Hiragino Mincho ProN','Yu Mincho',serif;
  --font-en:'Cormorant Garamond',Georgia,serif;
  --font-ui:-apple-system,BlinkMacSystemFont,'Hiragino Sans','Yu Gothic UI','Meiryo',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;overscroll-behavior:none;}
body{font-family:var(--font-ui);background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;letter-spacing:.01em;}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;}
svg{display:block;}
ul{list-style:none;}

/* 背景装飾 */
.bg-decor{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;}
.bg-leaf{position:absolute;background-repeat:no-repeat;background-size:contain;opacity:.15;}
.bg-leaf-tr{width:62vw;height:62vw;max-width:560px;max-height:560px;top:-13vw;right:-13vw;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 400'><g fill='none' stroke='%237E956A' stroke-width='1.2' stroke-linecap='round'><path d='M50 350 Q 200 200 380 50'/><path d='M70 360 Q 110 280 80 240'/><path d='M120 320 Q 160 250 130 220'/><path d='M170 280 Q 210 220 180 195'/><path d='M220 235 Q 260 180 230 160'/><ellipse cx='90' cy='250' rx='6' ry='14' fill='%23AEC59B' stroke='none' transform='rotate(-30 90 250)'/><ellipse cx='140' cy='230' rx='6' ry='14' fill='%23AEC59B' stroke='none' transform='rotate(-25 140 230)'/><ellipse cx='190' cy='200' rx='6' ry='14' fill='%23AEC59B' stroke='none' transform='rotate(-22 190 200)'/></g></svg>");}
.bg-leaf-br{width:42vw;height:42vw;max-width:420px;max-height:420px;bottom:-9vw;left:-9vw;opacity:.11;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 400'><g fill='none' stroke='%237E956A' stroke-width='1.2' stroke-linecap='round'><path d='M20 380 Q 150 250 320 80'/><path d='M60 380 Q 80 320 120 300'/><ellipse cx='100' cy='320' rx='6' ry='14' fill='%23AEC59B' stroke='none' transform='rotate(-40 100 320)'/></g></svg>");}
.bg-glow{position:absolute;width:80vw;height:80vw;top:-30vw;left:-20vw;background:radial-gradient(circle,rgba(255,250,220,.5) 0%,rgba(255,250,220,0) 60%);}

/* レイアウト */
#app{position:relative;min-height:100vh;z-index:1;display:flex;flex-direction:column;}
.screen{position:relative;z-index:2;flex:1;width:100%;max-width:540px;margin:0 auto;
  padding:calc(env(safe-area-inset-top) + 20px) 20px calc(env(safe-area-inset-bottom) + 28px);}
.fade{animation:fade .35s ease;}
@keyframes fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* ブランド見出し */
.brand{font-family:var(--font-en);font-size:34px;font-weight:600;color:var(--sage-600);letter-spacing:.02em;line-height:1;}
.brand-dot{color:var(--sage-400);}
.brand-sub{font-family:var(--font-jp);font-size:13px;color:var(--text-mute);margin-top:7px;letter-spacing:.06em;}
.lead{font-family:var(--font-jp);font-size:14px;color:var(--text-mute);margin:26px 2px 14px;letter-spacing:.03em;}
.section-em{font-family:var(--font-en);font-size:13px;color:var(--text-light);font-weight:500;letter-spacing:.1em;display:block;margin-bottom:3px;text-transform:uppercase;}

/* 戻る/トップバー */
.appbar{position:relative;z-index:2;display:flex;align-items:center;gap:10px;
  max-width:540px;margin:0 auto;width:100%;
  padding:calc(env(safe-area-inset-top) + 14px) 18px 6px;}
.back{display:inline-flex;align-items:center;gap:5px;color:var(--text-mute);font-family:var(--font-jp);font-size:13px;padding:6px 4px;}
.back svg{width:17px;height:17px;}
.appbar-title{font-family:var(--font-jp);font-size:14px;font-weight:600;color:var(--text-dark);margin-left:auto;}

/* 科目カード(ホーム) */
.subject-grid{display:flex;flex-direction:column;gap:16px;margin-top:6px;}
.subject-card{position:relative;display:flex;align-items:center;gap:16px;text-align:left;width:100%;
  background:var(--card);border:1px solid var(--border-soft);border-radius:22px;padding:22px 20px;
  box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease;overflow:hidden;}
.subject-card:active{transform:scale(.98);box-shadow:var(--shadow-sm);}
.subject-icon{width:56px;height:56px;border-radius:18px;flex:none;display:flex;align-items:center;justify-content:center;}
.subject-icon svg{width:30px;height:30px;}
.subject-icon.it{background:var(--it-bg);color:var(--it);}
.subject-icon.biz{background:var(--biz-bg);color:var(--biz);}
.subject-meta{flex:1;min-width:0;}
.subject-name{font-family:var(--font-jp);font-size:18px;font-weight:600;color:var(--text-dark);letter-spacing:.02em;}
.subject-desc{font-family:var(--font-jp);font-size:12.5px;color:var(--text-mute);margin-top:4px;}
.subject-count{font-family:var(--font-en);font-size:13px;color:var(--text-light);margin-top:7px;letter-spacing:.05em;}
.subject-arrow{color:var(--sage-300);}
.subject-arrow svg{width:20px;height:20px;}
.accent-bar{position:absolute;left:0;top:0;bottom:0;width:5px;}
.accent-bar.it{background:linear-gradient(var(--it),#9bb6c9);}
.accent-bar.biz{background:linear-gradient(var(--biz),#cbb499);}

/* モード選択 */
.mode-hero{background:var(--card);border:1px solid var(--border-soft);border-radius:22px;padding:20px;box-shadow:var(--shadow);margin-bottom:24px;display:flex;align-items:center;gap:14px;}
.mode-hero .ic{width:48px;height:48px;border-radius:15px;flex:none;display:flex;align-items:center;justify-content:center;}
.mode-hero .ic svg{width:26px;height:26px;}
.mode-hero .t{font-family:var(--font-jp);font-size:17px;font-weight:600;color:var(--text-dark);}
.mode-hero .s{font-family:var(--font-jp);font-size:12px;color:var(--text-mute);margin-top:3px;}

.mode-full{display:flex;align-items:center;gap:14px;width:100%;text-align:left;
  background:var(--sage-500);color:#fff;border-radius:20px;padding:20px;box-shadow:var(--shadow-lg);
  transition:transform .18s ease;}
.mode-full:active{transform:scale(.98);}
.mode-full .num{font-family:var(--font-en);font-size:30px;font-weight:600;line-height:1;}
.mode-full .lab{font-family:var(--font-jp);font-size:15px;font-weight:600;}
.mode-full .sub{font-family:var(--font-jp);font-size:11.5px;opacity:.85;margin-top:3px;}
.mode-full .arrow{margin-left:auto;opacity:.9;}
.mode-full .arrow svg{width:22px;height:22px;}

.divider{display:flex;align-items:center;gap:12px;margin:24px 2px 16px;color:var(--text-light);font-family:var(--font-jp);font-size:12px;letter-spacing:.06em;}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--border);}

.block-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:11px;}
.block-card{display:flex;flex-direction:column;align-items:flex-start;gap:2px;
  background:var(--card);border:1px solid var(--border-soft);border-radius:16px;padding:15px 16px;
  box-shadow:var(--shadow-sm);transition:transform .15s ease,border-color .15s ease;}
.block-card:active{transform:scale(.97);border-color:var(--sage-300);}
.block-card .bnum{font-family:var(--font-en);font-size:12px;color:var(--sage-400);letter-spacing:.08em;font-weight:600;}
.block-card .brange{font-family:var(--font-jp);font-size:16px;font-weight:600;color:var(--text-dark);}
.block-card .bq{font-family:var(--font-jp);font-size:11px;color:var(--text-light);margin-top:1px;}

/* ===== クイズ画面 ===== */
.q-top{margin-bottom:18px;}
.q-progressrow{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px;}
.q-counter{font-family:var(--font-en);font-size:15px;color:var(--text-mute);letter-spacing:.04em;}
.q-counter b{color:var(--sage-600);font-size:20px;font-weight:600;}
.q-badge{font-family:var(--font-jp);font-size:11px;font-weight:600;padding:4px 11px;border-radius:999px;}
.q-badge.it{background:var(--it-bg);color:var(--it);}
.q-badge.biz{background:var(--biz-bg);color:var(--biz);}
.progress-track{height:6px;background:var(--cream-200);border-radius:999px;overflow:hidden;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--sage-300),var(--sage-500));border-radius:999px;transition:width .4s ease;}

.q-card{background:var(--card);border:1px solid var(--border-soft);border-radius:22px;padding:22px 20px;box-shadow:var(--shadow);}
.q-no{font-family:var(--font-en);font-size:13px;color:var(--text-light);letter-spacing:.1em;font-weight:600;margin-bottom:8px;}
.q-text{font-family:var(--font-jp);font-size:16px;font-weight:500;color:var(--text-dark);line-height:1.7;letter-spacing:.01em;white-space:pre-wrap;}
.q-hint{font-family:var(--font-jp);font-size:11.5px;color:var(--biz);background:var(--biz-bg);display:inline-block;padding:3px 10px;border-radius:999px;margin-top:12px;}

.options{display:flex;flex-direction:column;gap:11px;margin-top:18px;}
.opt{display:flex;align-items:flex-start;gap:13px;width:100%;text-align:left;
  background:var(--card);border:1.5px solid var(--border);border-radius:16px;padding:15px 16px;
  box-shadow:var(--shadow-sm);transition:border-color .15s,background .15s,transform .12s;}
.opt:active{transform:scale(.99);}
.opt .mark{width:26px;height:26px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-en);font-size:14px;font-weight:600;
  background:var(--cream-100);color:var(--text-mute);border:1.5px solid var(--border);transition:all .15s;}
.opt .otext{flex:1;font-family:var(--font-jp);font-size:14.5px;line-height:1.6;color:var(--text);padding-top:1px;}
.opt.selected{border-color:var(--sage-400);background:var(--sage-50);}
.opt.selected .mark{background:var(--sage-400);color:#fff;border-color:var(--sage-400);}
/* 採点後 */
.opt.correct{border-color:var(--ok);background:var(--ok-bg);}
.opt.correct .mark{background:var(--ok);color:#fff;border-color:var(--ok);}
.opt.wrong{border-color:var(--danger);background:var(--danger-bg);}
.opt.wrong .mark{background:var(--danger);color:#fff;border-color:var(--danger);}
.opt.dim{opacity:.5;}
.opt[disabled]{cursor:default;}

/* 自由記述 */
.text-input{width:100%;font-family:var(--font-jp);font-size:17px;color:var(--text-dark);
  background:var(--card);border:1.5px solid var(--border);border-radius:16px;padding:15px 16px;margin-top:18px;
  box-shadow:var(--shadow-sm);outline:none;transition:border-color .15s;text-align:center;letter-spacing:.08em;}
.text-input:focus{border-color:var(--sage-400);}

/* 採点フィードバック */
.verdict{display:flex;align-items:center;gap:11px;margin-top:20px;padding:14px 16px;border-radius:16px;}
.verdict.ok{background:var(--ok-bg);}
.verdict.ng{background:var(--danger-bg);}
.verdict .vic{width:30px;height:30px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;color:#fff;}
.verdict .vic svg{width:18px;height:18px;}
.verdict.ok .vic{background:var(--ok);}
.verdict.ng .vic{background:var(--danger);}
.verdict .vt{font-family:var(--font-jp);font-size:15px;font-weight:700;}
.verdict.ok .vt{color:var(--sage-700);}
.verdict.ng .vt{color:var(--danger);}
.verdict .va{font-family:var(--font-jp);font-size:12px;color:var(--text-mute);margin-top:2px;}

.explain{margin-top:14px;background:var(--card-soft);border:1px solid var(--border-soft);border-radius:16px;padding:16px;}
.explain .elabel{display:flex;align-items:center;gap:6px;font-family:var(--font-en);font-size:12px;color:var(--sage-500);letter-spacing:.12em;font-weight:600;text-transform:uppercase;margin-bottom:8px;}
.explain .elabel svg{width:15px;height:15px;}
.explain .etext{font-family:var(--font-jp);font-size:13.5px;line-height:1.75;color:var(--text);white-space:pre-wrap;}

/* 覚え方ボックス */
.memo{margin-top:11px;background:#FBF6E9;border:1px solid #ECDFBE;border-radius:16px;padding:16px;}
.memo .elabel.memo-label{color:var(--gold);}
.memo .etext{font-family:var(--font-jp);font-size:13.5px;line-height:1.8;color:var(--text);white-space:pre-wrap;}

/* 下部固定アクション */
.q-actions{position:sticky;bottom:0;margin-top:22px;padding:14px 0 calc(env(safe-area-inset-bottom) + 6px);
  background:linear-gradient(transparent,var(--bg) 26%);}
.btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;
  background:var(--sage-500);color:#fff;font-family:var(--font-jp);font-size:15.5px;font-weight:600;
  border-radius:16px;padding:16px;box-shadow:var(--shadow-lg);transition:transform .15s,opacity .15s;letter-spacing:.04em;}
.btn-primary:active{transform:scale(.98);}
.btn-primary:disabled{opacity:.4;box-shadow:none;}
.btn-primary svg{width:19px;height:19px;}
.btn-ghost{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;
  color:var(--text-mute);font-family:var(--font-jp);font-size:13.5px;padding:13px;margin-top:4px;}

/* ===== 結果画面 ===== */
.result-hero{text-align:center;margin:14px 0 26px;}
.score-ring{position:relative;width:172px;height:172px;margin:0 auto 18px;}
.score-ring svg{width:100%;height:100%;transform:rotate(-90deg);}
.score-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.score-center .pct{font-family:var(--font-en);font-size:46px;font-weight:600;color:var(--sage-600);line-height:1;}
.score-center .frac{font-family:var(--font-jp);font-size:13px;color:var(--text-mute);margin-top:5px;}
.result-title{font-family:var(--font-jp);font-size:20px;font-weight:700;color:var(--text-dark);}
.result-sub{font-family:var(--font-jp);font-size:13px;color:var(--text-mute);margin-top:6px;}

.review-title{font-family:var(--font-jp);font-size:14px;font-weight:600;color:var(--text-dark);margin:6px 2px 12px;display:flex;align-items:center;gap:7px;}
.review-title .em{font-family:var(--font-en);font-size:12px;color:var(--text-light);letter-spacing:.1em;font-weight:500;}
.review-list{display:flex;flex-direction:column;gap:10px;}
.review-item{background:var(--card);border:1px solid var(--border-soft);border-radius:16px;padding:14px 16px;box-shadow:var(--shadow-sm);}
.review-head{display:flex;align-items:center;gap:10px;}
.review-head .ri{width:24px;height:24px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;color:#fff;}
.review-head .ri svg{width:14px;height:14px;}
.review-head .ri.ok{background:var(--ok);}
.review-head .ri.ng{background:var(--danger);}
.review-head .rno{font-family:var(--font-en);font-size:12px;color:var(--text-light);letter-spacing:.06em;font-weight:600;}
.review-q{font-family:var(--font-jp);font-size:13px;color:var(--text-dark);line-height:1.55;margin-top:8px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.review-ans{font-family:var(--font-jp);font-size:12px;color:var(--sage-600);margin-top:7px;}
.review-ans b{color:var(--text-mute);font-weight:500;}
.review-item.open .review-q{-webkit-line-clamp:unset;}
.review-detail{display:none;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-soft);}
.review-item.open .review-detail{display:block;}
.rd-block{font-family:var(--font-jp);font-size:12.5px;line-height:1.75;color:var(--text-mute);white-space:pre-wrap;}
.rd-block+.rd-block{margin-top:9px;}
.rd-tag{display:inline-block;font-size:10.5px;font-weight:600;padding:1px 8px;border-radius:999px;margin-right:7px;background:var(--sage-100);color:var(--sage-600);vertical-align:1px;}
.rd-tag.memo{background:#F3E8C8;color:var(--gold);}

.result-actions{display:flex;flex-direction:column;gap:10px;margin-top:28px;}

.spacer-sm{height:8px;}

/* ===== パスワードロック ===== */
.lock-screen{display:flex;align-items:center;justify-content:center;min-height:88vh;}
.lock-card{width:100%;max-width:340px;text-align:center;
  background:var(--card);border:1px solid var(--border-soft);border-radius:26px;
  padding:34px 26px 28px;box-shadow:var(--shadow-lg);}
.lock-icon{width:60px;height:60px;margin:0 auto 16px;border-radius:50%;
  background:var(--sage-50);color:var(--sage-500);display:flex;align-items:center;justify-content:center;}
.lock-icon svg{width:30px;height:30px;}
.lock-title{font-family:var(--font-en);font-size:26px;font-weight:600;color:var(--sage-600);letter-spacing:.02em;}
.lock-sub{font-family:var(--font-jp);font-size:13px;color:var(--text-mute);margin-top:6px;}
.lock-input{width:100%;font-family:var(--font-en);font-size:26px;letter-spacing:.5em;text-align:center;
  color:var(--text-dark);background:var(--card-soft);border:1.5px solid var(--border);border-radius:16px;
  padding:14px 16px;margin-top:22px;outline:none;transition:border-color .15s;}
.lock-input::placeholder{letter-spacing:.4em;color:var(--text-light);}
.lock-input:focus{border-color:var(--sage-400);}
.lock-hint{font-family:var(--font-jp);font-size:11px;color:var(--text-light);margin-top:10px;letter-spacing:.04em;}
.lock-error{font-family:var(--font-jp);font-size:12px;color:var(--danger);min-height:18px;margin-top:8px;}
.lock-btn{margin-top:6px;}
.shake{animation:shake .4s;}
@keyframes shake{0%,100%{transform:translateX(0);}20%,60%{transform:translateX(-7px);}40%,80%{transform:translateX(7px);}}
