@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Zen+Kaku+Gothic+New:wght@500;700;900&family=Noto+Sans+JP:wght@400;500;700&display=swap');
:root{color-scheme:only light;
  
  --bg:#FFF1E5; --surface:#FFF1E5; --surface-2:#F8E7D7;
  --ink:#262A33; --ink-soft:#66605B; --ink-faint:#938A80;
  --primary:#0F5499; --primary-dk:#0A3D72; --accent:#990F3D; --accent-dk:#76082E;
  --line:#E6D6C5; --line-soft:#F0E3D4; --rule:#262A33;
  --advice:#0F5499; --advice-bg:#E7EEF5; --broker:#0D7680; --broker-bg:#E1EEEE; --edu:#7A6E62; --edu-bg:#F2E7DB;
  --serif:"Inter","Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  --sans:"Inter","Noto Sans JP",system-ui,sans-serif;
  --shadow:none; --radius:0px;
  --teal:#0D7680; --chip-bg:#F3DECB; --chip-ink:#33302E;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--serif);line-height:1.78;-webkit-font-smoothing:antialiased;font-feature-settings:"palt";border-top:3px solid var(--rule)}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}
.narrow{max-width:740px}
a{color:inherit}
h1,h2,h3,.serif{font-family:var(--serif);font-weight:700;letter-spacing:.005em}
/* ---------- masthead ---------- */
.site-head{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 94%,transparent);backdrop-filter:blur(6px);border-bottom:2.5px solid var(--rule)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-weight:900;font-size:1.32rem;letter-spacing:-.01em;text-decoration:none;color:var(--ink)}
.brand .mark{width:42px;height:42px;flex:none}
.nav-links{display:flex;gap:20px;align-items:center;font-family:var(--sans);font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.nav-links a{text-decoration:none;color:var(--ink-soft);padding-bottom:2px;border-bottom:1.5px solid transparent}
.nav-links a:hover{color:var(--ink);border-bottom-color:var(--accent)}
.nav-cta{color:var(--ink)!important;border:1.5px solid var(--ink);padding:6px 12px}
.nav-cta:hover{background:var(--ink);color:var(--bg)!important;border-bottom-color:var(--ink)}
.theme-btn{background:none;border:1px solid var(--line);color:var(--ink-soft);border-radius:0;width:34px;height:34px;cursor:pointer;font-size:1rem;display:grid;place-items:center}
.theme-btn:hover{border-color:var(--ink);color:var(--ink)}
@media(max-width:760px){.nav-links a:not(.nav-cta){display:none}}
/* ---------- hero ---------- */
.hero{padding:52px 0 28px;position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--accent)}
.hero h1{font-size:clamp(2rem,5.6vw,3.4rem);font-weight:900;line-height:1.2;letter-spacing:-.01em}
.hero h1 .hl{color:var(--primary);white-space:nowrap}
.hero h1 .num{color:var(--accent)}
.hero p.lead{margin-top:18px;max-width:52ch;color:var(--ink-soft);font-size:1.12rem;line-height:1.75}
.hero-cta{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:0;padding:13px 22px;font-family:var(--sans);font-weight:700;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;cursor:pointer;border:1.5px solid transparent;transition:background .15s ease,color .15s ease}
.btn-primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn-primary:hover{background:var(--primary);border-color:var(--primary);color:#fff}
.btn-ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}
.trail{margin:36px 0 6px;width:100%;padding-top:28px;border-top:1px solid var(--line)}
.trail svg{width:100%;height:auto;display:block;overflow:visible}
.trail .lbl{font-family:var(--serif);font-weight:700;font-size:15px;fill:var(--ink)}
.trail .sub{font-size:11px;fill:var(--ink-faint);font-family:var(--sans)}
/* ---------- callout ---------- */
.callout{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:0;padding:22px 24px;margin-top:8px}
.callout h2{font-size:1.18rem;font-weight:700;display:flex;align-items:center;gap:9px}
.callout p{color:var(--ink-soft);font-size:.95rem;margin-top:8px}
.callout .reg-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.reg-pill{display:inline-flex;align-items:center;gap:7px;background:var(--advice-bg);color:var(--advice);border:1px solid color-mix(in srgb,var(--advice) 36%,transparent);border-radius:0;padding:6px 13px;font-family:var(--sans);font-size:.8rem;font-weight:700}
.reg-pill.broker{background:var(--broker-bg);color:var(--broker);border-color:color-mix(in srgb,var(--broker) 36%,transparent)}
.reg-pill .star{color:var(--accent)}
/* ---------- sections ---------- */
.section{padding:46px 0}
.sec-head{margin-bottom:24px;border-bottom:2px solid var(--rule);padding-bottom:12px}
.sec-head .kicker{font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.sec-head h2{font-size:1.7rem;font-weight:900;margin-top:7px;letter-spacing:-.01em}
.sec-head p{color:var(--ink-soft);font-size:.95rem;margin-top:7px;max-width:64ch}
/* ---------- filters ---------- */
.filters{position:sticky;top:64px;z-index:40;background:color-mix(in srgb,var(--bg) 95%,transparent);backdrop-filter:blur(6px);padding:14px 0;border-bottom:1px solid var(--line);margin-bottom:24px}
.filter-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.filter-row:last-child{margin-bottom:0}
.filter-label{font-family:var(--sans);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);min-width:60px}
.chip{border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);border-radius:0;padding:7px 14px;font-family:var(--sans);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .14s ease;white-space:nowrap}
.chip:hover{border-color:var(--ink);color:var(--ink)}
.chip[aria-pressed="true"]{background:var(--ink);border-color:var(--ink);color:var(--bg);font-weight:700}
.chip.reg[aria-pressed="true"]{background:var(--primary);border-color:var(--primary);color:#fff}
.result-meta{font-family:var(--sans);font-size:.8rem;color:var(--ink-faint);margin-bottom:16px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.sort-sel{font-family:var(--sans);font-size:.8rem;border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:0;padding:6px 10px}
/* ---------- cards ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.card{background:var(--surface);border:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line);border-radius:0;padding:22px;display:flex;flex-direction:column;position:relative;transition:background .15s ease}
.card:hover{background:var(--surface-2)}
.card.featured{box-shadow:inset 0 3px 0 var(--accent)}
.feat-tag{position:absolute;top:0;left:0;background:var(--accent);color:#fff;font-family:var(--sans);font-size:.62rem;font-weight:700;padding:3px 10px;border-radius:0;letter-spacing:.1em;text-transform:uppercase}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-top:4px}
.card h3{font-size:1.2rem;font-weight:700;line-height:1.38;letter-spacing:-.005em}
.card h3 a{text-decoration:none}
.card h3 a:hover{color:var(--primary);text-decoration:underline;text-underline-offset:3px}
.card .op{font-family:var(--sans);font-size:.72rem;color:var(--ink-faint);margin-top:4px;letter-spacing:.02em}
.badge{flex:none;font-family:var(--sans);font-size:.68rem;font-weight:700;padding:5px 9px;border-radius:0;text-align:center;line-height:1.3;border:1px solid currentColor}
.badge.advice{background:var(--advice-bg);color:var(--advice)}
.badge.broker{background:var(--broker-bg);color:var(--broker)}
.badge.edu{background:var(--edu-bg);color:var(--edu)}
.badge small{display:block;font-size:.6rem;font-weight:500;opacity:.8;letter-spacing:0}
.blurb{font-size:.95rem;color:var(--ink-soft);margin:13px 0 0;line-height:1.7}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.tag{font-family:var(--sans);font-size:.68rem;font-weight:600;background:transparent;border:1px solid var(--line);color:var(--ink-soft);border-radius:0;padding:3px 8px;letter-spacing:.02em}
.specs{margin-top:15px;padding-top:14px;border-top:1px solid var(--line-soft);display:grid;grid-template-columns:1fr 1fr;gap:10px 12px}
.spec{font-size:.82rem}
.spec .k{font-family:var(--sans);color:var(--ink-faint);font-size:.66rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;display:block;margin-bottom:1px}
.spec .v{color:var(--ink);font-weight:500}
.card-foot{margin-top:16px;display:flex;gap:8px}
.card-foot a{font-family:var(--sans);font-size:.76rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;text-decoration:none;padding:10px 14px;border-radius:0;flex:1;text-align:center;border:1.5px solid transparent}
.lnk-detail{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.lnk-detail:hover{background:var(--primary);border-color:var(--primary)}
.lnk-official{border-color:var(--line);color:var(--ink-soft)}
.lnk-official:hover{border-color:var(--ink);color:var(--ink)}
.empty{text-align:center;color:var(--ink-faint);padding:48px 0;font-size:.95rem;grid-column:1/-1}
/* ---------- split / mini ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
@media(max-width:720px){.split{grid-template-columns:1fr}}
.mini{background:var(--surface);border:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line);border-radius:0;padding:26px}
.mini h3{font-size:1.24rem;font-weight:700}
.mini p{font-size:.92rem;color:var(--ink-soft);margin-top:8px}
.mini ul{list-style:none;margin-top:16px;display:flex;flex-direction:column;gap:0}
.mini li{font-size:.88rem;display:flex;align-items:center;gap:9px;padding:10px 0;border-bottom:1px solid var(--line-soft)}
.mini li:last-child{border-bottom:none}
.mini li b{font-weight:700}
.mini li span{margin-left:auto;font-family:var(--sans);font-size:.74rem;color:var(--ink-faint)}
.mini .soon{display:inline-block;margin-top:16px;font-family:var(--sans);font-size:.74rem;letter-spacing:.05em;text-transform:uppercase;color:var(--primary);font-weight:700;text-decoration:none;border-bottom:1.5px solid var(--primary);padding-bottom:2px}
/* ---------- faq ---------- */
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:0;margin-bottom:-1px;overflow:hidden}
.faq summary{padding:16px 20px;font-family:var(--serif);font-weight:700;font-size:1rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-size:1.3rem;font-weight:400;flex:none}
.faq details[open] summary::after{content:"\2013"}
.faq .ans{padding:0 20px 18px;color:var(--ink-soft);font-size:.92rem}
/* ---------- footer ---------- */
.site-foot{border-top:3px solid var(--rule);background:var(--surface);margin-top:30px;padding:38px 0 46px}
.foot-grid{display:flex;justify-content:space-between;gap:28px;flex-wrap:wrap}
.foot-brand{font-family:var(--serif);font-weight:900;font-size:1.2rem}
.disclaimer{margin-top:20px;font-size:.76rem;color:var(--ink-faint);line-height:1.85;max-width:80ch}
.foot-links{display:flex;gap:18px;font-family:var(--sans);font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;flex-wrap:wrap}
.foot-links a{color:var(--ink-soft);text-decoration:none}
.foot-links a:hover{color:var(--ink)}
.copy{margin-top:24px;font-family:var(--sans);font-size:.72rem;color:var(--ink-faint)}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}
/* ---------- detail page ---------- */
.crumb{font-family:var(--sans);font-size:.72rem;letter-spacing:.04em;color:var(--ink-faint);padding:20px 0 0;text-transform:uppercase}
.crumb a{color:var(--ink-soft);text-decoration:none}
.crumb a:hover{color:var(--accent)}
.dhero{padding:22px 0 8px;border-bottom:2px solid var(--rule);margin-bottom:4px}
.dhero .op{font-family:var(--sans);font-size:.78rem;color:var(--ink-faint);margin-bottom:10px;letter-spacing:.04em}
.dhero h1{font-size:clamp(1.7rem,4.8vw,2.6rem);font-weight:900;line-height:1.28;letter-spacing:-.01em}
.dhero .badge-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.bigbadge{display:inline-flex;flex-direction:column;font-family:var(--sans);font-size:.78rem;font-weight:700;padding:7px 13px;border-radius:0;border:1px solid currentColor}
.bigbadge small{font-size:.64rem;font-weight:500;opacity:.8}
.bigbadge.advice{background:var(--advice-bg);color:var(--advice)}
.bigbadge.broker{background:var(--broker-bg);color:var(--broker)}
.bigbadge.edu{background:var(--edu-bg);color:var(--edu)}
.bigbadge.tagx{background:var(--surface-2);color:var(--ink-soft);border:1px solid var(--line);flex-direction:row;align-items:center}
.concl{background:var(--surface);border:1px solid var(--line);border-top:3px solid var(--primary);border-radius:0;padding:24px 26px;margin:22px 0}
.concl .lead{font-size:1.08rem;font-weight:500;color:var(--ink);line-height:1.8}
.concl dl{display:grid;grid-template-columns:auto 1fr;gap:10px 16px;margin-top:18px;font-size:.9rem}
.concl dt{font-family:var(--sans);color:var(--ink-faint);font-weight:700;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;padding-top:2px}
.concl dd{color:var(--ink)}
.qa{padding:32px 0;border-bottom:1px solid var(--line-soft)}
.qa h2{font-size:1.4rem;font-weight:800;line-height:1.5;letter-spacing:-.005em}
.qa h2::before{content:"Q. ";color:var(--accent);font-family:var(--serif);font-weight:900}
.qa p{margin-top:13px;color:var(--ink-soft);font-size:.98rem;line-height:1.85}
.qa .factbox{margin-top:16px;background:var(--surface);border:1px solid var(--line);border-radius:0;overflow:hidden}
.qa .factbox dl{display:grid;grid-template-columns:auto 1fr;margin:0}
.qa .factbox dt,.qa .factbox dd{padding:11px 16px;font-size:.88rem;border-bottom:1px solid var(--line-soft)}
.qa .factbox dt{background:var(--surface-2);font-family:var(--sans);color:var(--ink-faint);font-weight:700;font-size:.74rem;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border-right:1px solid var(--line-soft)}
.qa .factbox dd{color:var(--ink)}
.qa .factbox>dl>div:last-child dt,.qa .factbox>dl>div:last-child dd{border-bottom:none}
.flist{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:9px}
.flist li{position:relative;padding-left:22px;font-size:.96rem;color:var(--ink-soft);line-height:1.75}
.flist li::before{content:"";position:absolute;left:0;top:.62em;width:9px;height:9px;background:var(--accent);border-radius:0}
.note-inline{background:var(--surface-2);border-left:3px solid var(--accent);border-radius:0;padding:12px 16px;font-size:.88rem;color:var(--ink-soft);margin-top:16px}
.reg-explain{background:var(--surface-2);border:1px solid var(--line);border-left:3px solid var(--primary);border-radius:0;padding:16px 18px;font-size:.92rem;color:var(--ink-soft);margin-top:14px;line-height:1.8}
.reg-explain b{color:var(--ink)}
.related{padding:36px 0;border-top:1px solid var(--line)}
.related h2{font-size:1.32rem;font-weight:800;margin-bottom:18px}
.back-link{display:inline-flex;align-items:center;gap:7px;margin:24px 0 0;font-family:var(--sans);font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--primary);text-decoration:none}
.back-link:hover{color:var(--accent)}


/* ===== FT.com match ===== */
body{font-family:var(--sans);font-weight:400;line-height:1.55}
.blurb,.hero p.lead,.qa p,.concl .lead,.flist li,.reg-explain,.note-inline,.callout p,.faq .ans,.mini p,.sec-head p,.disclaimer,.spec .v,.crumb{font-family:var(--sans)}
h1,h2,h3,.serif,.brand,.foot-brand,.card h3,.sec-head h2,.hero h1,.dhero h1,.mini h3,.related h2,.qa h2{font-family:var(--serif)}
.hero h1,.dhero h1{font-weight:700;color:var(--ink);letter-spacing:-.006em;line-height:1.12}
.hero h1 .hl{color:var(--accent)}
.card h3{font-weight:600}
/* kickers = claret, nav active = teal */
.eyebrow,.sec-head .kicker{color:var(--accent);font-weight:700}
.eyebrow::before{background:var(--accent)}
.nav-links a{color:var(--ink-soft);border-bottom:2px solid transparent}
.nav-links a:hover{color:var(--ink);border-bottom-color:var(--teal)}
.qa h2::before{color:var(--accent)}
.back-link{color:var(--primary)}
.back-link:hover{color:var(--teal)}
.card h3 a:hover{color:var(--primary)}
/* tags / EXCLUSIVE-style chips = wheat bg, dark text */
.tag{background:var(--chip-bg);border:0;color:var(--chip-ink);border-radius:2px;font-weight:600}
.feat-tag{background:var(--chip-bg);color:var(--chip-ink);border-radius:2px;letter-spacing:.08em;font-weight:700}
.card.featured{box-shadow:inset 0 3px 0 var(--accent)}
/* buttons (FT web feel: small radius, claret primary) */
.btn{border-radius:3px;text-transform:none;letter-spacing:.005em;font-weight:600}
.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dk);border-color:var(--accent-dk)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}
.chip{border-radius:3px}
.chip[aria-pressed="true"]{background:var(--accent);border-color:var(--accent);color:#fff}
.nav-cta{border-radius:3px;background:var(--accent);color:#fff!important;border-color:var(--accent);text-transform:none;letter-spacing:0;font-weight:600}
.nav-cta:hover{background:var(--accent-dk);border-color:var(--accent-dk)}
.lnk-detail{background:var(--primary);border-color:var(--primary)}
.lnk-detail:hover{background:var(--primary-dk);border-color:var(--primary-dk)}
.faq summary{font-family:var(--serif)}
.faq summary::after,.faq details[open] summary::after{color:var(--accent)}
.callout{border-left-color:var(--accent)}
.concl{border-top-color:var(--accent)}
.reg-explain{border-left-color:var(--primary)}
.note-inline{border-left-color:var(--accent)}
.brand{letter-spacing:-.01em}
body{border-top:3px solid var(--rule)}
.site-head{border-bottom:1px solid var(--rule)}
/* FT: light only, no dark, no toggle */
.theme-btn{display:none}
html{background:#FFF1E5!important;min-height:100%}
body{background:#FFF1E5!important;min-height:100vh}

/* ===== FT link & action colors ===== */
.lnk-detail{background:var(--accent);border-color:var(--accent);color:#fff;border-radius:3px}
.lnk-detail:hover{background:var(--accent-dk);border-color:var(--accent-dk);color:#fff}
.lnk-official{border-color:var(--primary);color:var(--primary);border-radius:3px}
.lnk-official:hover{background:var(--primary);border-color:var(--primary);color:#fff}
.card-foot a{text-transform:none;letter-spacing:.01em;font-weight:700}
.back-link{color:var(--primary)}
.crumb a:hover,.back-link:hover,.foot-links a:hover,.nav-links a:hover{color:var(--primary)}
.back-link:hover,.crumb a:hover{text-decoration:underline;text-underline-offset:2px}
/* inline text links in body = oxford blue, underlined (FT) */
main a:not(.btn):not(.chip):not(.card):not(.nav-cta):not(.lnk-detail):not(.lnk-official):not(.back-link):not(.feat-tag):not(.brand){color:var(--primary)}
.qa a,.flist a,.concl a,.reg-explain a,.note-inline a,.callout a,.blurb a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}
.qa a:hover,.flist a:hover,.concl a:hover{color:var(--primary-dk)}
/* keep related "chips" as wheat tags but link-blue on hover */
.related .chip:hover,.tags .chip:hover{border-color:var(--primary);color:var(--primary)}

/* sans (non-mincho) headline tuning */
.hero h1,.dhero h1{font-weight:800;letter-spacing:-.022em;line-height:1.14}
.sec-head h2,.card h3,.mini h3,.related h2,.qa h2{font-weight:700;letter-spacing:-.012em}
.brand,.foot-brand{font-weight:800;letter-spacing:-.01em}

.checklist{list-style:none;margin:14px 0 4px;padding:0;display:grid;gap:9px}
.checklist li{position:relative;padding-left:28px;line-height:1.5}
.checklist li::before{content:"\2715";position:absolute;left:4px;top:0;color:var(--accent);font-weight:800}
.callout .eyebrow{margin-bottom:8px}
.callout h2{margin:.1rem 0 .6rem}

.rank-list{display:grid;gap:14px;margin-top:18px}
.rank-card{display:flex;border:1px solid var(--line);background:#FFF7EE;border-radius:6px;overflow:hidden}
.rank-no{flex:none;width:52px;display:flex;align-items:center;justify-content:center;font-family:var(--latin);font-weight:800;font-size:1.6rem;color:#fff;background:var(--accent)}
.rank-card:nth-child(n+4) .rank-no{background:var(--ink)}
.rank-body{flex:1;padding:15px 17px;min-width:0}
.rank-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.rank-head h3{font-family:var(--jp);font-weight:900;font-size:1.06rem;margin:0}
.rank-head h3 a{color:var(--ink);text-decoration:none}
.rank-score{flex:none;font-family:var(--latin);white-space:nowrap}
.rank-score .sc{font-weight:800;font-size:1.45rem;color:var(--accent)}
.rank-score .of{font-size:.78rem;color:var(--soft)}
.rank-chips{display:flex;flex-wrap:wrap;gap:6px;margin:9px 0}
.rank-why{font-size:.9rem;color:var(--soft);margin:6px 0 12px;line-height:1.55}
.rank-why strong{color:var(--ink)}
.rank-cta{display:flex;gap:10px;flex-wrap:wrap}
.rank-cta .btn{padding:7px 14px;font-size:.85rem}
.purpose-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-top:18px}
@media(max-width:820px){.purpose-grid{grid-template-columns:1fr}}
.purpose{border:1px solid var(--line);background:#FFF7EE;border-radius:6px;padding:16px 18px}
.purpose h3{font-family:var(--jp);font-weight:900;font-size:1rem;margin:0 0 12px;line-height:1.4}
.purpose-list{list-style:none;margin:0;padding:0;display:grid;gap:11px}
.purpose-list li{display:flex;gap:10px;align-items:flex-start}
.pno{flex:none;width:22px;height:22px;border-radius:50%;background:var(--ink);color:#fff;font-family:var(--latin);font-weight:700;font-size:.78rem;display:grid;place-items:center;margin-top:1px}
.purpose-list a{color:var(--primary);text-decoration:none;font-weight:700;display:block;line-height:1.35}
.pwhy{display:block;font-size:.8rem;color:var(--soft);margin-top:2px}

.chip.hyo{background:transparent;border:1px solid var(--accent);color:var(--accent);font-weight:700}

.eval10{margin:6px 0 0;border:1px solid var(--line);border-radius:6px;overflow:hidden}
.eval10 .row{display:grid;grid-template-columns:150px 46px 1fr;border-top:1px solid var(--line)}
.eval10 .row:first-child{border-top:none}
.eval10 .it{padding:11px 12px;font-weight:700;font-size:.86rem;background:#FBEFE2}
.eval10 .mk{padding:11px 6px;text-align:center;font-weight:800;font-size:1.05rem}
.eval10 .cm{padding:11px 12px;font-size:.85rem;color:var(--soft);line-height:1.55}
.m-good{color:var(--accent)}.m-ok{color:var(--primary)}.m-cau{color:#B8860B}.m-no{color:#A08}
@media(max-width:560px){.eval10 .row{grid-template-columns:104px 34px 1fr}.eval10 .it{font-size:.78rem;padding:9px 8px}.eval10 .cm{padding:9px 8px;font-size:.8rem}}

.cmptable-wrap{overflow-x:auto;margin-top:18px;border:1px solid var(--line);border-radius:6px;-webkit-overflow-scrolling:touch}
.cmptable{border-collapse:collapse;width:100%;min-width:720px;font-size:.85rem}
.cmptable th,.cmptable td{padding:9px 10px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);text-align:center;white-space:nowrap}
.cmptable thead th{background:#FBEFE2;font-weight:800}
.cmptable th.nm,.cmptable td.nm{text-align:left;position:sticky;left:0;background:#FFF7EE;min-width:196px;max-width:230px;z-index:1;vertical-align:top}
.cmptable thead th.nm{background:#FBEFE2}
.cmptable td.nm a{color:var(--primary);text-decoration:none;font-weight:700}
.cmptable .sc{font-weight:800;color:var(--accent)}
.cmptable .reg-a{color:var(--accent);font-weight:700}.cmptable .reg-b{color:var(--primary);font-weight:700}.cmptable .reg-e{color:var(--soft)}
.cmptable .g{color:var(--accent);font-weight:800}.cmptable .o{color:var(--primary);font-weight:700}.cmptable .c{color:#B8860B;font-weight:700}.cmptable .x{color:#A0306B;font-weight:700}

.cmptable td.nm a{display:block}
.cmptable .cmt{display:block;font-weight:400;font-size:.73rem;color:var(--soft);white-space:normal;line-height:1.4;margin-top:3px}

.scorebox{display:flex;gap:18px;align-items:center;margin:8px 0 4px;flex-wrap:wrap}
.bigscore{flex:none}.bigscore .bs{font-family:var(--latin);font-weight:800;font-size:2.4rem;color:var(--accent)}.bigscore .bo{color:var(--soft);font-size:.9rem}
.bars{flex:1;min-width:240px;display:grid;gap:6px}
.bar-row{display:grid;grid-template-columns:66px 1fr 34px;align-items:center;gap:8px;font-size:.82rem}
.bar-row .bl{color:var(--soft)}.bar-row .bt{height:8px;background:var(--line);border-radius:4px;overflow:hidden}.bar-row .bf{display:block;height:100%;background:var(--accent)}.bar-row .bv{text-align:right;font-weight:700;font-family:var(--latin)}
.pc{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
@media(max-width:560px){.pc{grid-template-columns:1fr}}
.pc-col{border:1px solid var(--line);border-radius:6px;padding:13px 15px;background:#FFF7EE}
.pc-col h3{font-family:var(--jp);font-size:.95rem;margin:0 0 8px}
.pc-col.pros h3{color:var(--accent)}.pc-col.cons h3{color:var(--primary)}
.pc-col ul{margin:0;padding-left:18px}.pc-col li{margin:5px 0;font-size:.88rem;line-height:1.5}
.pc-col p{font-size:.88rem;margin:0;color:var(--ink);line-height:1.55}

/* about: contact form */
.cform{display:flex;flex-direction:column;gap:14px;margin-top:14px;max-width:560px}
.cform label{display:flex;flex-direction:column;gap:6px;font-size:.86rem;font-weight:600;color:var(--ink)}
.cform input,.cform select,.cform textarea{font:inherit;font-weight:400;color:var(--ink);background:var(--card,#fff);border:1px solid var(--line,#e7d8c9);border-radius:10px;padding:11px 13px;width:100%}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--claret,#990F3D);box-shadow:0 0 0 3px rgba(153,15,61,.12)}
.cform textarea{resize:vertical;min-height:120px}
.cform-btn{align-self:flex-start;font:inherit;font-weight:700;color:#fff;background:var(--claret,#990F3D);border:none;border-radius:999px;padding:12px 28px;cursor:pointer;transition:opacity .15s}
.cform-btn:hover{opacity:.9}
.cform .hp{position:absolute;left:-9999px}
.form-ok{background:rgba(40,150,90,.1);border:1px solid rgba(40,150,90,.4);color:#1d6b42;border-radius:10px;padding:12px 14px;font-size:.9rem;font-weight:600;margin-top:10px}

/* listing badge: creator has a related school */
.tag.tag-school{background:var(--claret,#990F3D);color:#fff;border-color:transparent;font-weight:700}

/* --- refined card-foot links (cleaner than blocky/uppercase) --- */
.card-foot{align-items:center}
.card-foot a.lnk-detail{background:var(--accent);border:1.5px solid var(--accent);color:#fff;border-radius:8px;text-transform:none;letter-spacing:.01em;font-weight:600;font-size:.8rem;padding:10px 16px}
.card-foot a.lnk-detail:hover{background:var(--accent-dk);border-color:var(--accent-dk);color:#fff}
.card-foot a.lnk-official{background:none;border:1.5px solid var(--line);color:var(--ink-soft);border-radius:8px;text-transform:none;letter-spacing:.01em;font-weight:600;font-size:.8rem;padding:10px 16px}
.card-foot a.lnk-official:hover{border-color:var(--ink);color:var(--ink)}
.card-foot span.lnk-detail{background:none;border:none;padding:0;flex:none;color:var(--primary);font-weight:600;font-size:.85rem;letter-spacing:.01em;text-transform:none;text-align:left;display:inline-flex;align-items:center;gap:5px;transition:transform .16s ease,color .16s ease}
.card-foot span.lnk-detail:hover{color:var(--primary-dk)}
.card:hover span.lnk-detail{transform:translateX(3px);color:var(--primary-dk)}
