/* ================================================================
   IMM Report – Shared Design System
   Used by all reports under /IMM-eBook/
   Each report may keep a local <style> block for unique components.
   ================================================================ */

/* ── Reset & Variables ─────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#08101e;
  --bg2:#0e1929;
  --surface:#111f35;
  --card:#162238;
  --card2:#1a2a44;
  --border:#1e3050;
  --border2:#264166;
  --accent:#4f9eff;
  --accent2:#7bc3ff;
  --gold:#f5b84b;
  --gold2:#fdd888;
  --green:#34d399;
  --red:#f87171;
  --purple:#a78bfa;
  --text:#e8f1fc;
  --text2:#a8bed8;
  --text3:#6b8aaa;
  --font:-apple-system,BlinkMacSystemFont,"Inter","PingFang TC","Noto Sans TC",sans-serif;
  --serif:"Playfair Display","Georgia",serif;
  --mono:"JetBrains Mono","Fira Code",monospace;
  --r:10px;
  --r2:16px;
  --shadow:0 4px 24px rgba(0,0,0,.45);
  --shadow2:0 8px 48px rgba(0,0,0,.6);
  --trans:.2s cubic-bezier(.4,0,.2,1);
}

html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.75;overflow-x:hidden}

/* ── Scrollbar ─────────────────────────────────────── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* ── Typography ────────────────────────────────────── */
h1,h2,h3,h4{line-height:1.3;font-weight:700}
h2{font-family:var(--serif);font-size:2rem;margin-bottom:1.5rem}
h3{font-size:1.2rem;color:var(--accent2);margin:2rem 0 .8rem;padding-left:1rem;border-left:3px solid var(--accent);font-weight:700}
h4{font-size:.85rem;color:var(--gold);margin:1.5rem 0 .6rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700}
p{margin-bottom:1rem;color:var(--text2)}
strong{color:var(--text);font-weight:600}
em{color:var(--gold2);font-style:normal;font-weight:500}
code{font-family:var(--mono);background:var(--card2);color:var(--accent2);padding:.15em .45em;border-radius:4px;font-size:.85em}
a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color var(--trans)}
a:hover{border-color:var(--accent)}

/* ── Layout ────────────────────────────────────────── */
.page-wrap{display:grid;grid-template-columns:260px 1fr;min-height:100vh;max-width:1440px;margin:0 auto;padding-top:56px}
main{padding:0 3rem 6rem;max-width:900px;width:100%}

/* ── Sidebar / TOC ─────────────────────────────────── */
aside{position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto;padding:2rem 1.5rem;border-right:1px solid var(--border);background:var(--bg2)}
.toc-logo{display:flex;align-items:center;gap:.6rem;margin-bottom:2.5rem;text-decoration:none;border:none}
.toc-logo-icon{width:44px;height:44px;min-width:44px;display:grid;place-items:center}
.toc-logo-icon img{width:44px;height:44px;object-fit:contain;filter:invert(1) brightness(2);opacity:.9}
.toc-logo-text{font-weight:700;font-size:.95rem;line-height:1.2;color:var(--text)}
.toc-logo-sub{font-size:.7rem;color:var(--text3);font-weight:400}
nav ul{list-style:none}
nav li{margin:.2rem 0}
nav a{display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border-radius:6px;font-size:.82rem;color:var(--text2);transition:all var(--trans);text-decoration:none;border:none;line-height:1.4}
nav a:hover{background:var(--surface);color:var(--text)}
nav a.active{background:var(--surface);color:var(--accent);font-weight:600}
nav .toc-num{font-size:.7rem;color:var(--text3);font-family:var(--mono);min-width:1.4rem}
nav .toc-group{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);padding:.75rem .75rem .25rem;margin-top:.5rem}

/* ── Top Nav ────────────────────────────────────────── */
#topnav{position:fixed;top:0;left:0;width:100%;z-index:300;background:rgba(14,25,41,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.8rem;height:56px}
.nav-brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--text);border:none}
.nav-brand img{height:28px;filter:invert(1) brightness(2);opacity:.85}
.nav-brand-text{font-weight:700;font-size:.85rem;line-height:1.2}
.nav-brand-sub{font-size:.63rem;color:var(--text3);font-weight:400}
.nav-links{display:flex;align-items:center;gap:.2rem}
.nav-links a{color:var(--text2);text-decoration:none;font-size:.78rem;padding:.36rem .78rem;border-radius:var(--r);border:1px solid transparent;transition:all var(--trans);white-space:nowrap}
.nav-links a:hover{color:var(--text);border-color:var(--border2);background:rgba(79,158,255,.07)}
.nav-links a.cta{color:var(--accent);border-color:rgba(79,158,255,.35);background:rgba(79,158,255,.08)}
.nav-links a.cta:hover{background:rgba(79,158,255,.18)}
#ham-top{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:4px;padding:.3rem}
#ham-top span{display:block;width:22px;height:2px;background:var(--text2);border-radius:2px}
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:99;backdrop-filter:blur(2px)}
.sidebar-backdrop.open{display:block}

/* ── Hero ──────────────────────────────────────────── */
.hero{position:relative;padding:5rem 3rem 4rem;margin-bottom:0;overflow:hidden;border-bottom:1px solid var(--border)}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(79,158,255,.12) 0%,transparent 70%)}
.hero-tag{display:inline-flex;align-items:center;gap:.5rem;background:rgba(79,158,255,.1);border:1px solid rgba(79,158,255,.25);border-radius:20px;padding:.3rem .9rem;font-size:.78rem;color:var(--accent2);letter-spacing:.05em;margin-bottom:1.5rem}
.hero-tag::before{content:'●';color:var(--green);font-size:.55rem}
.hero h1{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);background:linear-gradient(135deg,#fff 30%,var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}
.hero-sub{font-size:1.05rem;color:var(--text3);margin-bottom:.5rem}
.hero-date{font-size:.82rem;color:var(--text3);font-family:var(--mono)}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2.5rem}

/* ── Stat Card ─────────────────────────────────────── */
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:1.2rem 1.4rem;position:relative;overflow:hidden;transition:border-color var(--trans)}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent-bar,var(--accent))}
.stat-card:hover{border-color:var(--border2)}
.stat-num{font-size:2rem;font-weight:700;font-family:var(--mono);color:var(--text);line-height:1}
.stat-label{font-size:.75rem;color:var(--text3);margin-top:.35rem}

/* ── Section ───────────────────────────────────────── */
section{padding:4rem 0 1rem;border-bottom:1px solid var(--border)}
section:last-child{border-bottom:none}
.section-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}
.section-num{font-size:.8rem;font-family:var(--mono);color:var(--accent);background:rgba(79,158,255,.1);border:1px solid rgba(79,158,255,.2);padding:.25rem .6rem;border-radius:4px;white-space:nowrap}
.section-title{font-family:var(--serif);font-size:1.9rem;color:var(--text)}

/* ── Executive Summary Cards ───────────────────────── */
.insight-grid{display:grid;gap:1rem}
.insight-card{display:flex;gap:1.2rem;background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:1.4rem 1.6rem;transition:all var(--trans)}
.insight-card:hover{border-color:var(--border2);transform:translateY(-1px);box-shadow:var(--shadow)}
.insight-n{width:2.5rem;height:2.5rem;min-width:2.5rem;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:1rem;font-family:var(--mono)}
.insight-body h4{color:var(--text);font-size:.95rem;text-transform:none;letter-spacing:0;margin:0 0 .35rem;font-family:var(--font)}
.insight-body p{font-size:.9rem;margin:0;color:var(--text2)}

/* ── Tables ────────────────────────────────────────── */
.table-wrap{overflow-x:auto;margin:1.5rem 0;border-radius:var(--r);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;font-size:.875rem}
thead tr{background:var(--surface)}
thead th{padding:.8rem 1rem;text-align:left;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-weight:600;border-bottom:1px solid var(--border)}
tbody tr{border-bottom:1px solid var(--border)}
tbody tr:last-child{border-bottom:none}
tbody tr:nth-child(even){background:rgba(255,255,255,.018)}
tbody td{padding:.75rem 1rem;vertical-align:top;color:var(--text2)}
tbody td:first-child{color:var(--text);font-weight:500}
tbody tr:hover td{background:rgba(79,158,255,.04)}
.vs-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--r);overflow:hidden;border:1px solid var(--border)}
.vs-table thead th:nth-child(2){color:var(--accent2)}
.vs-table thead th:nth-child(3){color:var(--gold2)}
.vs-table thead th:first-child{width:22%}
.vs-table tbody tr:nth-child(odd) td{background:var(--card)}
.vs-table tbody tr:nth-child(even) td{background:var(--card2)}

/* ── Info Blocks ───────────────────────────────────── */
.info-block{background:var(--card);border-left:3px solid var(--accent);border-radius:0 var(--r) var(--r) 0;padding:1rem 1.4rem;margin:1.2rem 0;font-size:.9rem;color:var(--text2)}
.info-block.gold{border-color:var(--gold)}
.info-block.green{border-color:var(--green)}
.info-block.red{border-color:var(--red)}
.info-block.purple{border-color:var(--purple)}
.info-block strong{display:block;color:var(--text);margin-bottom:.3rem}

/* ── Big Stat ──────────────────────────────────────── */
.big-stat-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin:1.5rem 0}
.big-stat{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:1.5rem;text-align:center}
.big-stat .num{font-size:2.8rem;font-weight:700;font-family:var(--mono);color:var(--gold);line-height:1}
.big-stat .denom{font-size:1rem;color:var(--text3)}
.big-stat .desc{font-size:.8rem;color:var(--text3);margin-top:.5rem}

/* ── Stage Grid ────────────────────────────────────── */
.stage-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin:1.5rem 0}
.stage-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:1.6rem;position:relative;overflow:hidden;transition:all var(--trans)}
.stage-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:var(--shadow)}
.stage-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--stage-color,var(--accent))}
.stage-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;font-family:var(--mono);color:var(--stage-color,var(--accent));background:rgba(79,158,255,.1);border:1px solid currentColor;padding:.2rem .6rem;border-radius:4px;margin-bottom:.8rem;opacity:.8}
.stage-name{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:.25rem}
.stage-en{font-size:.8rem;color:var(--text3);margin-bottom:.9rem;font-style:italic}
.stage-card ul{padding-left:1.1rem;font-size:.85rem;color:var(--text2)}
.stage-card ul li{margin:.3rem 0}
.stage-tool{margin-top:.9rem;padding-top:.9rem;border-top:1px solid var(--border);font-size:.8rem;color:var(--text3)}
.stage-tool span{color:var(--accent);font-weight:500}

/* ── Strategy Steps ────────────────────────────────── */
.strategy-steps{display:flex;flex-direction:column;gap:.6rem;margin:1.2rem 0}
.strategy-step{display:flex;align-items:flex-start;gap:1rem;background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1rem 1.2rem;transition:border-color var(--trans)}
.strategy-step:hover{border-color:var(--border2)}
.step-rank{width:2rem;height:2rem;min-width:2rem;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:.85rem;font-family:var(--mono)}
.step-content{flex:1}
.step-title{font-weight:600;color:var(--text);font-size:.92rem;margin-bottom:.2rem}
.step-desc{font-size:.83rem;color:var(--text2)}

/* ── Timeline ──────────────────────────────────────── */
.timeline{position:relative;margin:1.5rem 0}
.timeline::before{content:'';position:absolute;left:1.4rem;top:0;bottom:0;width:2px;background:var(--border)}
.tl-item{display:flex;gap:1.4rem;margin-bottom:1.5rem;position:relative}
.tl-dot{width:2.8rem;height:2.8rem;min-width:2.8rem;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:.8rem;font-family:var(--mono);position:relative;z-index:1}
.tl-body{padding-top:.3rem;flex:1}
.tl-title{font-weight:600;color:var(--text);margin-bottom:.3rem;font-size:.95rem}
.tl-desc{font-size:.85rem;color:var(--text2)}

/* ── Research Card ─────────────────────────────────── */
.research-grid{display:grid;gap:1rem;margin:1.2rem 0}
.research-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:1.4rem;transition:all var(--trans)}
.research-card:hover{border-color:var(--border2);transform:translateY(-1px)}
.research-journal{font-size:.72rem;font-family:var(--mono);color:var(--accent);opacity:.8;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}
.research-title{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:.6rem}
.research-title a{color:inherit;border-bottom:1px solid rgba(232,241,252,.35)}
.research-title a:hover{border-color:var(--text)}
.research-findings{display:flex;flex-direction:column;gap:.35rem}
.research-finding{display:flex;gap:.6rem;font-size:.83rem;color:var(--text2)}
.research-finding::before{content:'→';color:var(--accent);flex-shrink:0}

/* ── Inline Citations ──────────────────────────────── */
sup.cite{font-size:.72em;color:var(--accent);font-weight:700;margin-left:.15rem;white-space:nowrap;letter-spacing:-.01em}

/* ── Reference List ────────────────────────────────── */
.ref-group{margin-bottom:2rem}
.ref-group-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text3);margin-bottom:.8rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}
.ref-item{display:flex;gap:1rem;padding:.8rem 0;border-bottom:1px dashed var(--border)}
.ref-item:last-child{border-bottom:none}
.ref-num{font-family:var(--mono);font-size:.75rem;color:var(--accent);min-width:1.8rem;padding-top:.1rem}
.ref-content{flex:1}
.ref-title{font-size:.88rem;color:var(--text);font-weight:500;margin-bottom:.2rem}
.ref-title a{color:inherit;border-bottom:1px solid rgba(232,241,252,.35)}
.ref-title a:hover{border-color:var(--text)}
.ref-meta{font-size:.78rem;color:var(--text3)}

/* ── Content List ──────────────────────────────────── */
.content-list{padding-left:1.3rem;margin:.8rem 0}
.content-list li{margin:.4rem 0;color:var(--text2);font-size:.92rem}
.content-list li strong{color:var(--text)}

/* ── Keyword Pill ──────────────────────────────────── */
.kw{display:inline;background:rgba(79,158,255,.12);color:var(--accent2);border-radius:4px;padding:.1em .4em;font-size:.85em;font-weight:500}

/* ── Footer ────────────────────────────────────────── */
footer{background:var(--bg2);border-top:1px solid var(--border);padding:2.5rem 3rem;grid-column:1/-1}
.footer-inner{max-width:900px;margin:0 auto;display:flex;gap:2rem;align-items:flex-start}
.footer-note{font-size:.82rem;color:var(--text3);line-height:1.7;flex:1}
.footer-badge{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:.7rem 1.2rem;font-size:.75rem;color:var(--text3);white-space:nowrap;font-family:var(--mono)}

/* ── Responsive ────────────────────────────────────── */
@media(max-width:900px){
  .nav-links{display:none}
  #ham-top{display:flex}
  .page-wrap{grid-template-columns:1fr;padding-top:56px}
  aside{
    position:fixed;top:56px;left:-280px;height:calc(100vh - 56px);width:260px;
    z-index:100;transition:left .28s cubic-bezier(.4,0,.2,1);
    border-right:1px solid var(--border2);box-shadow:var(--shadow2);
  }
  aside.open{left:0}
  main{padding:0 1.5rem 4rem}
  .hero{padding:2.5rem 1.5rem 2rem}
  .hero-stats{grid-template-columns:1fr 1fr}
  .stage-grid{grid-template-columns:1fr}
  .big-stat-row{grid-template-columns:1fr}
  footer{padding:2rem 1.5rem}
  .footer-inner{flex-direction:column}
}
