/* ===== Career Aptitude Compass — shared styles ===== */
:root{
  --ink:#0F2742;
  --ink-soft:#46607F;
  --paper:#EAEEF3;
  --card:#FFFFFF;
  --line:#D5DCE7;
  --accent:#F2B134;
  --accent-deep:#B9760F;
  --type:#4C6FA5;            /* overridden per result page */
  --radius:14px;
  --maxw:680px;
  --shadow:0 1px 2px rgba(15,39,66,.04),0 12px 30px -18px rgba(15,39,66,.35);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:"Noto Sans JP",system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.8;
  font-size:16px;
  letter-spacing:.01em;
  /* faint coordinate grid in the background — the wayfinding motif */
  background-image:
    linear-gradient(rgba(15,39,66,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(15,39,66,.035) 1px,transparent 1px);
  background-size:34px 34px;
}
h1,h2,h3{font-family:"Shippori Mincho B1","Noto Sans JP",serif;font-weight:700;line-height:1.4;letter-spacing:.02em}
a{color:inherit}
.mono{font-family:"Space Mono",ui-monospace,monospace}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.site{min-height:100dvh;display:flex;flex-direction:column}

/* ---- header ---- */
.top{padding:18px 0 6px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.nav{display:flex;gap:18px}
.nav a{text-decoration:none;font-size:13.5px;font-weight:700;color:var(--ink-soft);white-space:nowrap}
.nav a:hover{color:var(--ink)}
.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none}
.brand .glyph{
  width:26px;height:26px;border:2px solid var(--ink);border-radius:50%;
  position:relative;flex:0 0 auto;
}
.brand .glyph::before,.brand .glyph::after{content:"";position:absolute;background:var(--accent-deep)}
.brand .glyph::before{left:50%;top:3px;bottom:3px;width:2px;transform:translateX(-50%)}
.brand .glyph::after{top:50%;left:3px;right:3px;height:2px;transform:translateY(-50%)}
.brand b{font-family:"Shippori Mincho B1",serif;font-size:16px;letter-spacing:.06em}

/* ---- hero (index) ---- */
.hero{padding:30px 0 8px;text-align:center}
.eyebrow{font-family:"Space Mono",monospace;font-size:12px;letter-spacing:.28em;color:var(--ink-soft);text-transform:uppercase;margin:0 0 16px}
.hero h1{font-size:clamp(28px,7vw,42px);margin:0 0 14px}
.hero h1 .am{color:var(--accent-deep)}
.hero p.lede{color:var(--ink-soft);font-size:16px;margin:0 auto 26px;max-width:30em}

/* axis legend on the hero — names the three coordinates */
.axes-legend{display:grid;gap:10px;margin:0 auto 30px;max-width:440px;text-align:left}
.axis-row{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 14px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;box-shadow:var(--shadow)}
.axis-row .pole{font-size:13px;font-weight:700}
.axis-row .pole.r{text-align:right}
.axis-row .vs{font-family:"Space Mono",monospace;font-size:11px;color:var(--ink-soft);border:1px solid var(--line);border-radius:20px;padding:2px 9px}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:"Noto Sans JP",sans-serif;font-weight:700;font-size:16px;
  padding:15px 26px;border-radius:999px;border:0;cursor:pointer;text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease;
}
.btn-primary{background:var(--accent);color:var(--ink);box-shadow:0 10px 24px -10px var(--accent-deep)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px var(--accent-deep)}
.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink);font-size:14px;padding:11px 18px}
.btn-ghost:hover{border-color:var(--ink-soft)}
.btn-block{display:flex;width:100%}
.note{font-size:12px;color:var(--ink-soft);margin-top:12px}

/* ---- quiz ---- */
.quiz{padding:20px 0 40px;flex:1}
.progress{display:flex;align-items:center;gap:12px;margin:6px 0 26px}
.progress .bar{flex:1;height:7px;background:var(--line);border-radius:99px;overflow:hidden}
.progress .bar i{display:block;height:100%;width:0;background:var(--accent);border-radius:99px;transition:width .35s ease}
.progress .count{font-family:"Space Mono",monospace;font-size:13px;color:var(--ink-soft);white-space:nowrap}
.qcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px 22px;box-shadow:var(--shadow);text-align:center}
.qcard .qaxis{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.2em;color:var(--ink-soft);text-transform:uppercase}
.qcard .qtext{font-family:"Shippori Mincho B1",serif;font-size:clamp(20px,5vw,26px);margin:10px 0 26px}
.opts{display:grid;gap:14px}
.opt{
  background:var(--paper);border:1.5px solid var(--line);border-radius:12px;padding:18px 18px;
  font-size:16px;font-weight:500;cursor:pointer;text-align:left;color:var(--ink);
  transition:border-color .12s,background .12s,transform .08s;line-height:1.6;
}
.opt:hover{border-color:var(--accent);background:#fff}
.opt:active{transform:scale(.99)}
.fade-in{animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.qback{margin-top:18px;text-align:center}
.qback button{background:none;border:0;color:var(--ink-soft);font-size:13px;cursor:pointer;text-decoration:underline;font-family:inherit}

/* ---- result ---- */
.result{padding:14px 0 30px;flex:1}
.rhero{background:var(--card);border:1px solid var(--line);border-top:5px solid var(--type);border-radius:var(--radius);padding:30px 22px;text-align:center;box-shadow:var(--shadow)}
.rcode{font-family:"Space Mono",monospace;font-weight:700;letter-spacing:.18em;font-size:clamp(34px,11vw,60px);color:var(--type);line-height:1}
.rkind{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.24em;color:var(--ink-soft);text-transform:uppercase;margin-bottom:10px}
.rname{font-size:clamp(24px,6.5vw,34px);margin:14px 0 8px}
.rcatch{color:var(--ink-soft);margin:0;font-size:15px}

/* coordinate read-out: the signature element */
.coords{display:grid;gap:14px;margin:24px 0 4px}
.coord{display:grid;grid-template-columns:1fr;gap:6px}
.coord .clabels{display:flex;justify-content:space-between;font-size:12px;color:var(--ink-soft)}
.coord .clabels .on{color:var(--ink);font-weight:700}
.track{position:relative;height:8px;background:var(--paper);border:1px solid var(--line);border-radius:99px}
.track .dot{position:absolute;top:50%;width:16px;height:16px;border-radius:50%;background:var(--type);transform:translate(-50%,-50%);box-shadow:0 0 0 4px color-mix(in srgb,var(--type) 20%,transparent)}

.block{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;margin-top:18px;box-shadow:var(--shadow)}
.block h2{font-size:18px;margin:0 0 14px;display:flex;align-items:center;gap:10px}
.block h2::before{content:"";width:8px;height:18px;background:var(--type);border-radius:3px;flex:0 0 auto}
.block p{margin:0 0 0;color:#1d3556}
.tags{display:flex;flex-wrap:wrap;gap:9px;margin:2px 0 0}
.tag{background:var(--paper);border:1px solid var(--line);border-radius:99px;padding:7px 14px;font-size:13.5px;font-weight:500}
.list{margin:0;padding:0;list-style:none;display:grid;gap:10px}
.list li{padding-left:22px;position:relative;color:#1d3556}
.list li::before{content:"";position:absolute;left:2px;top:11px;width:8px;height:8px;border-radius:50%;background:var(--type)}
.list.warn li::before{background:none;width:auto;height:auto;left:0;top:0;content:"!";font-family:"Space Mono",monospace;font-weight:700;color:var(--accent-deep)}

/* CTA / next step */
.cta-wrap{margin-top:18px;background:linear-gradient(180deg,#102844,#0c1f36);border-radius:var(--radius);padding:26px 22px;color:#eaf0f8;box-shadow:var(--shadow)}
.cta-wrap .pr{font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.2em;color:#8aa2c2;border:1px solid #2c456a;border-radius:5px;padding:1px 6px}
.cta-wrap h2{color:#fff;font-size:19px;margin:12px 0 10px}
.cta-wrap p{color:#c4d3e6;margin:0 0 18px;font-size:14.5px}
.cta-wrap .btn-primary{margin-bottom:10px}
.cta-wrap .btn-ghost{color:#dce6f3;border-color:#33507a}
.cta-wrap .btn-ghost:hover{border-color:#5e7aa3}

/* share + related */
.share{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.share a{flex:1;min-width:140px;text-align:center;background:var(--card);border:1.5px solid var(--line);border-radius:999px;padding:13px;text-decoration:none;font-weight:700;font-size:14px}
.share a:hover{border-color:var(--ink-soft)}
.related{margin-top:26px}
.related h2{font-size:15px;font-family:"Space Mono",monospace;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 12px}
.relgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.relcard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px;text-decoration:none;color:var(--ink);transition:border-color .12s,transform .1s}
.relcard:hover{border-color:var(--accent);transform:translateY(-2px)}
.relcard .rc-code{font-family:"Space Mono",monospace;font-weight:700;font-size:13px}
.relcard .rc-name{font-family:"Shippori Mincho B1",serif;font-size:15px;display:block;margin-top:4px}

/* disclaimer + footer */
.disclaimer{font-size:12.5px;color:var(--ink-soft);background:transparent;border:1px dashed var(--line);border-radius:10px;padding:14px 16px;margin-top:22px;line-height:1.7}
footer{margin-top:auto;padding:30px 0;text-align:center;color:var(--ink-soft);font-size:12px}
footer a{color:var(--ink-soft)}

@media (max-width:420px){
  .relgrid{grid-template-columns:1fr}
  .axis-row{grid-template-columns:1fr auto 1fr}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}
:focus-visible{outline:3px solid var(--accent-deep);outline-offset:2px;border-radius:6px}

/* ---- column index + article ---- */
.section-head{margin:26px 0 14px}
.section-head .eyebrow{margin-bottom:6px}
.section-head h1{font-size:clamp(24px,6vw,34px);margin:0}
.col-list{display:grid;gap:14px;margin-top:8px}
.col-card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px 18px;text-decoration:none;color:var(--ink);display:block;transition:border-color .12s,transform .1s;box-shadow:var(--shadow)}
.col-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.col-card h3{font-size:17px;margin:0 0 6px;line-height:1.5}
.col-card p{font-size:13.5px;color:var(--ink-soft);margin:0}
.col-card .date{font-family:"Space Mono",monospace;font-size:11px;color:var(--ink-soft);display:block;margin-bottom:7px}

.article{padding:10px 0 24px;flex:1}
.article .meta{font-family:"Space Mono",monospace;font-size:12px;letter-spacing:.1em;color:var(--ink-soft);margin:6px 0 0}
.article h1{font-size:clamp(24px,6vw,33px);margin:8px 0 16px;line-height:1.5}
.article .lead{font-size:16.5px;color:#1d3556;margin:0 0 8px;font-weight:500}
.article-body h2{font-size:19px;margin:30px 0 12px;display:flex;align-items:flex-start;gap:10px}
.article-body h2::before{content:"";width:6px;height:22px;background:var(--accent);border-radius:3px;flex:0 0 auto;margin-top:3px}
.article-body p{margin:0 0 14px;color:#1d3556}
.article-body ul{margin:0 0 14px;padding:0;list-style:none;display:grid;gap:9px}
.article-body ul li{padding-left:20px;position:relative;color:#1d3556}
.article-body ul li::before{content:"";position:absolute;left:2px;top:11px;width:7px;height:7px;border-radius:50%;background:var(--accent-deep)}
.article-end{margin-top:30px}
