/* =========================================================================
   Kami Editorial - 공유 디자인 시스템
   한지 캔버스 · 잉크블루 단일 강조 · 명조 헤드라인 + 산세리프 본문
   구조 장치(Figma 참고): 색면 섹션 리듬 · 알약 CTA · 모노 대문자 표식 · 굵기 위계
   ========================================================================= */
:root{
  --paper:#f5efe1; --paper-2:#efe6d3; --surface:#fbf7ee; --line:#ddd1b8; --line-soft:#e7ddc8;
  --ink:#241f17; --ink-soft:#5d5544;
  --accent:#1d4067; --accent-2:#2d5a8a;
  --block-sky:#dde7ec; --block-sage:#dde3d1; --block-clay:#ecdcc7; --block-rose:#ecd8d0; --block-navy:#1e2c3b;
  --serif:"Nanum Myeongjo","Iowan Old Style",Georgia,serif;
  --sans:"Pretendard","Pretendard Variable",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --maxw:1120px; --radius:14px; --radius-lg:24px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
h1,h2,h3,h4,.kowrap{word-break:keep-all;overflow-wrap:break-word}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.serif{font-family:var(--serif)}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600}
.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;gap:8px;height:62px;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.brand{font-family:var(--serif);font-weight:700;font-size:21px;color:var(--ink);letter-spacing:-.01em;margin-right:auto;display:flex;align-items:center;gap:9px}
.brand .mark{width:26px;height:26px;border-radius:7px;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:14px;font-family:var(--serif)}
.nav-links{display:flex;gap:2px;align-items:center}
.nav-links a{color:var(--ink-soft);font-size:14.5px;font-weight:600;padding:7px 12px;border-radius:9px;white-space:nowrap}
.nav-links a:hover{color:var(--ink);background:var(--paper-2);text-decoration:none}
.nav-links a.active{color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}
.nav-toggle{display:none;border:1px solid var(--line);background:var(--surface);border-radius:9px;width:42px;height:38px;font-size:18px;cursor:pointer;color:var(--ink)}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-size:15px;font-weight:700;padding:11px 22px;border-radius:999px;cursor:pointer;border:1px solid transparent;transition:transform .12s ease,background .15s ease;line-height:1.2}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-2);color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--surface)}
.hero{padding:84px 0 64px}
.hero h1{font-family:var(--serif);font-size:clamp(38px,6vw,66px);line-height:1.12;letter-spacing:-.02em;font-weight:700;margin:18px 0 0}
.hero .lead{font-size:clamp(17px,2.2vw,21px);color:var(--ink-soft);max-width:60ch;margin:22px 0 30px;line-height:1.7}
.hero-accent{color:var(--accent)}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px;box-shadow:0 18px 40px rgba(31,44,59,.08)}
.hero-card .doc-line{height:11px;border-radius:6px;background:var(--paper-2);margin:0 0 12px}
.hero-card .doc-line.short{width:55%}
.hero-card .doc-line.accent{background:color-mix(in srgb,var(--accent) 30%,var(--paper-2))}
.section{padding:60px 0}
.section-head{max-width:64ch;margin-bottom:34px}
.section-head h2{font-family:var(--serif);font-size:clamp(26px,3.4vw,38px);line-height:1.22;font-weight:700;margin:10px 0 0;position:relative}
.section-head h2::after{content:"";display:block;width:54px;height:3px;background:var(--accent);margin-top:14px;border-radius:2px}
.section-head p{color:var(--ink-soft);margin-top:16px;font-size:17px}
.block{border-radius:var(--radius-lg);padding:clamp(28px,5vw,56px);margin:18px 0}
.block.sky{background:var(--block-sky)}
.block.sage{background:var(--block-sage)}
.block.clay{background:var(--block-clay)}
.block.rose{background:var(--block-rose)}
.block.navy{background:var(--block-navy);color:#eef2f6}
.block.navy .eyebrow{color:#9bc1e6}
.block.navy h2,.block.navy h3{color:#fff}
.block h2{font-family:var(--serif);font-size:clamp(24px,3.2vw,34px);line-height:1.25;font-weight:700;margin:10px 0 0}
.block p{margin-top:16px;font-size:17px;max-width:62ch}
.block.navy p{color:#cdd9e4}
.grid{display:grid;gap:18px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}
.card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(31,44,59,.08);border-color:var(--accent-2)}
.card .k{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.card h3{font-family:var(--serif);font-size:21px;font-weight:700;margin:12px 0 8px;line-height:1.3}
.card p{color:var(--ink-soft);font-size:15.5px}
.card .go{margin-top:16px;font-weight:700;font-size:14.5px;color:var(--accent);display:inline-flex;gap:6px}
.corner-num{font-family:var(--serif);font-size:15px;color:#fff;background:var(--accent);width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-weight:700}
.archive-tools{position:sticky;top:62px;z-index:20;background:color-mix(in srgb,var(--paper) 92%,transparent);backdrop-filter:blur(8px);padding:18px 0;border-bottom:1px solid var(--line-soft);margin-bottom:8px}
.searchbar{position:relative;display:flex;align-items:center}
.searchbar input{width:100%;font-family:var(--sans);font-size:16px;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:13px 44px}
.searchbar input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 16%,transparent)}
.searchbar .ico{position:absolute;left:15px;color:var(--ink-soft);font-size:16px;pointer-events:none}
.searchbar .clear{position:absolute;right:10px;border:none;background:var(--paper-2);color:var(--ink-soft);width:26px;height:26px;border-radius:50%;cursor:pointer;font-size:14px;display:none;line-height:1}
.searchbar .clear.show{display:grid;place-items:center}
.filter-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px}
.chip{font-family:var(--sans);font-size:13.5px;font-weight:600;color:var(--ink-soft);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:7px 14px;cursor:pointer;transition:all .13s ease;display:inline-flex;gap:7px;align-items:center}
.chip:hover{border-color:var(--accent-2);color:var(--ink)}
.chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.chip .cnt{font-family:var(--mono);font-size:11px;opacity:.8}
.toolbar-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:14px}
.result-count{font-family:var(--mono);font-size:12.5px;color:var(--ink-soft);letter-spacing:.02em}
.result-count b{color:var(--accent)}
.collect-toggle{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:700;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:7px 14px;cursor:pointer}
.collect-toggle:hover{border-color:var(--accent-2)}
.collect-toggle.active{background:color-mix(in srgb,var(--accent) 12%,transparent);border-color:var(--accent);color:var(--accent)}
.collect-toggle .badge{font-family:var(--mono);font-size:11px;background:var(--accent);color:#fff;border-radius:999px;padding:1px 7px;min-width:18px;text-align:center}
.article-list{display:grid;gap:14px;margin-top:24px}
.article{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px 56px 22px 22px;cursor:pointer;transition:transform .13s ease,box-shadow .13s ease,border-color .13s ease}
.article:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(31,44,59,.08);border-color:var(--accent-2)}
.article:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.article .a-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:9px}
.article .a-cat{font-family:var(--mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);font-weight:600}
.article .a-src{font-size:12.5px;color:var(--ink-soft)}
.article .a-read{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--ink-soft);border-radius:999px;padding:2px 8px;display:none}
.article.is-read{opacity:.66}
.article.is-read .a-read{display:inline-block}
.article h3{font-family:var(--serif);font-size:19px;font-weight:700;line-height:1.35;margin:0 0 6px}
.article p{color:var(--ink-soft);font-size:14.5px;line-height:1.6}
.article .a-tags{margin-top:11px;display:flex;gap:7px;flex-wrap:wrap}
.article .a-tags span{font-size:11.5px;color:var(--ink-soft);background:var(--paper-2);border-radius:6px;padding:2px 8px}
.star{position:absolute;top:18px;right:16px;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:var(--paper);cursor:pointer;font-size:16px;color:var(--ink-soft);display:grid;place-items:center;transition:all .13s ease;line-height:1}
.star:hover{border-color:var(--accent);color:var(--accent);transform:scale(1.08)}
.star.on{background:var(--accent);border-color:var(--accent);color:#fff}
.empty{text-align:center;padding:56px 20px;color:var(--ink-soft)}
.empty .big{font-family:var(--serif);font-size:22px;color:var(--ink);margin-bottom:8px}
.feed-item{display:grid;grid-template-columns:88px 1fr;gap:20px;padding:22px 0;border-bottom:1px solid var(--line-soft)}
.feed-item .when{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.04em;padding-top:3px}
.feed-item h3{font-family:var(--serif);font-size:20px;font-weight:700;line-height:1.35;margin:0 0 8px}
.feed-item .sum{color:var(--ink-soft);font-size:15.5px}
.feed-item .three{margin:12px 0 0;padding-left:18px}
.feed-item .three li{font-size:14.5px;color:var(--ink-soft);margin:4px 0}
.feed-item .sofar{margin-top:12px;font-size:13.5px;background:var(--block-sky);border-radius:9px;padding:10px 13px;color:var(--ink)}
.feed-item .sofar b{color:var(--accent)}
.timeline{position:relative;margin-top:10px;padding-left:30px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--line)}
.stage{position:relative;padding:0 0 30px}
.stage::before{content:"";position:absolute;left:-26px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--surface);border:3px solid var(--accent)}
.stage.done::before{background:var(--accent)}
.stage h3{font-family:var(--serif);font-size:20px;font-weight:700;margin:0 0 6px}
.stage .meta{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.stage p{color:var(--ink-soft);font-size:15px;max-width:60ch}
.stage .items{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}
.stage .items span{font-size:12.5px;background:var(--paper-2);border-radius:7px;padding:4px 10px;color:var(--ink)}
.progress-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;margin-bottom:8px}
.progress-wrap .row{display:flex;justify-content:space-between;font-size:14px;font-weight:700;margin-bottom:10px}
.bar{height:10px;background:var(--paper-2);border-radius:999px;overflow:hidden}
.bar i{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .5s ease}
.prose{max-width:68ch}
.prose p{margin:0 0 18px;font-size:17px;line-height:1.8;color:var(--ink)}
.prose .q{font-family:var(--serif);font-size:clamp(22px,3vw,30px);line-height:1.4;color:var(--accent);border-left:3px solid var(--accent);padding-left:22px;margin:30px 0}
.fact-list{list-style:none;margin:8px 0 0;display:grid;gap:10px}
.fact-list li{display:grid;grid-template-columns:30px 1fr;gap:12px;align-items:start;font-size:16px}
.fact-list .n{font-family:var(--mono);font-size:12px;color:#fff;background:var(--accent);width:24px;height:24px;border-radius:50%;display:grid;place-items:center;margin-top:3px}
.footer{border-top:1px solid var(--line);margin-top:40px;padding:48px 0 60px;color:var(--ink-soft)}
.footer-inner{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer .brand{font-size:18px;margin:0 0 6px}
.footer .fnote{font-size:13.5px;max-width:42ch}
.footer-links{display:flex;gap:28px;flex-wrap:wrap}
.footer-links a{color:var(--ink-soft);font-size:14px;font-weight:600}
.footer .cap{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-top:18px;color:var(--ink-soft)}
@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-card{order:-1}
  .grid.cols-3{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .nav-links.open{display:flex;position:absolute;top:62px;left:0;right:0;flex-direction:column;background:var(--paper);border-bottom:1px solid var(--line);padding:12px 24px;gap:4px}
  .nav-links.open a{padding:11px 12px}
  .nav-toggle{display:block}
}
@media(max-width:560px){
  body{font-size:16px}
  .grid.cols-3,.grid.cols-2{grid-template-columns:1fr}
  .hero{padding:54px 0 44px}
  .feed-item{grid-template-columns:1fr;gap:6px}
  .feed-item .when{padding-top:0}
  .block{padding:24px}
  .article{padding:20px 52px 20px 18px}
}

/* =========================================================================
   ENHANCEMENTS v2 — zip 레퍼런스(idea-to-html · manual-production · vibelabs) 반영
   비개발자 콜아웃 · 하이라이트 마커 · focus 캐러셀 · workflow 캔버스 · reveal
   ========================================================================= */

/* ---- reveal on scroll ---- */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ---- highlight markers (밑줄 형광펜) ---- */
.hl{background-image:linear-gradient(transparent 58%,var(--hl,#cfe0ef) 58%);background-repeat:no-repeat;background-size:100% 100%;padding:0 3px;border-radius:3px;box-decoration-break:clone;-webkit-box-decoration-break:clone;font-weight:600}
.hl-y{--hl:#f3e3a3}.hl-blue{--hl:#cfe0ef}.hl-rose{--hl:#ecd0cf}.hl-sage{--hl:#d6e0c2}
.hl.anim{background-size:0% 100%}
.reveal.in .hl.anim{animation:hlin .7s cubic-bezier(.4,0,.2,1) .2s forwards}
@keyframes hlin{to{background-size:100% 100%}}

/* ---- beginner callouts ---- */
.primer{background:var(--block-sky);border-radius:14px;padding:18px 22px;margin:0 0 22px}
.primer .lbl,.why .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);font-weight:600;display:block;margin-bottom:7px}
.primer p{font-size:15.5px;color:var(--ink);line-height:1.65}
.primer .model{font-family:var(--serif);font-size:18px;color:var(--ink);margin-top:6px;line-height:1.5}
.why{border-left:3px solid var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--surface));border-radius:0 12px 12px 0;padding:13px 18px;margin:16px 0;font-size:14.5px;color:var(--ink-soft)}
.why b{color:var(--accent)}
.terms{display:grid;grid-template-columns:auto 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden;margin:16px 0}
.terms dt,.terms dd{background:var(--surface);padding:10px 15px;font-size:14px}
.terms dt{font-family:var(--mono);font-size:12.5px;color:var(--accent);font-weight:600;white-space:nowrap}
.terms dd{color:var(--ink-soft)}
.dg{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:18px 0}
.dg .cell{border-radius:12px;padding:15px 17px;font-size:14.5px;line-height:1.6}
.dg .bad{background:var(--block-rose)}
.dg .good{background:var(--block-sage)}
.dg .t{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;display:block;margin-bottom:6px}
.dg .bad .t{color:#a8463a}.dg .good .t{color:#4a6b3a}

/* ---- meta grid · action list · pull · sw ---- */
.meta-grid{display:grid;grid-template-columns:auto 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden;margin:14px 0}
.meta-grid dt,.meta-grid dd{background:var(--surface);padding:9px 14px;font-size:13.5px}
.meta-grid dt{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap}
.meta-grid dd{color:var(--ink)}
.action-list{list-style:none;counter-reset:al;display:grid;gap:10px;margin:16px 0 0}
.action-list li{counter-increment:al;position:relative;padding:13px 16px 13px 52px;background:var(--surface);border:1px solid var(--line);border-radius:12px;font-size:14.5px;line-height:1.55}
.action-list li::before{content:counter(al);position:absolute;left:13px;top:12px;width:27px;height:27px;border-radius:50%;background:var(--accent);color:#fff;font-family:var(--serif);font-weight:700;display:grid;place-items:center;font-size:13px}
.pull{border-left:3px solid var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--surface));border-radius:0 12px 12px 0;padding:18px 22px;font-family:var(--serif);font-size:19px;line-height:1.55;color:var(--ink);margin:18px 0}
.sw{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:14px 0 0}
.sw .col{border-radius:12px;padding:15px 17px}
.sw .pro{background:var(--block-sage)}.sw .con{background:var(--block-clay)}
.sw .t{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:700;display:block;margin-bottom:6px}
.sw h4{font-family:var(--serif);font-size:15px;margin:0 0 6px;font-weight:700}
.sw p{font-size:14px;color:var(--ink-soft);line-height:1.55}

/* ---- home hub: 2 big start-here cards ---- */
.hub{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.hub-feature{position:relative;overflow:hidden;background:var(--block-sky);border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px 28px;transition:transform .15s ease,box-shadow .15s ease}
.hub-feature.alt{background:var(--block-sage)}
.hub-feature:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(31,44,59,.1)}
.hub-feature .k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:600}
.hub-feature h3{font-family:var(--serif);font-size:clamp(22px,3vw,28px);font-weight:700;margin:12px 0 8px;line-height:1.25}
.hub-feature p{color:var(--ink-soft);font-size:15px;max-width:40ch}
.hub-feature .go{margin-top:18px;font-weight:700;font-size:14.5px;color:var(--accent);display:inline-flex;gap:6px}
.hub-feature .blob{position:absolute;right:-40px;bottom:-40px;width:150px;height:150px;border-radius:50%;background:color-mix(in srgb,var(--accent) 12%,transparent);pointer-events:none}

/* ---- system map (mental model diagram) ---- */
.sysmap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin:8px 0}
.sysmap .flow-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}
.sysmap .node{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:11px 16px;font-size:14px;font-weight:600;color:var(--ink);text-align:center}
.sysmap .node .sub{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);font-weight:400;margin-top:3px}
.sysmap .arrow{color:var(--accent);font-size:18px;font-weight:700}
.sysmap .roles{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}
.sysmap .role{border:1px dashed var(--line);border-radius:10px;padding:14px}
.sysmap .role b{font-family:var(--serif);font-size:15px;color:var(--ink)}
.sysmap .role p{font-size:13px;color:var(--ink-soft);margin-top:5px}
.selfcheck{counter-reset:sc;list-style:none;display:grid;gap:8px;margin:14px 0 0}
.selfcheck li{counter-increment:sc;position:relative;padding:11px 14px 11px 44px;background:var(--surface);border:1px solid var(--line);border-radius:10px;font-size:14.5px}
.selfcheck li::before{content:"Q" counter(sc);position:absolute;left:12px;top:11px;font-family:var(--mono);font-size:11px;font-weight:700;color:#fff;background:var(--accent);border-radius:6px;padding:3px 6px}

/* ---- focus carousel (feed · perspective) ---- */
.fc{margin-top:10px}
.fc-stage{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:clamp(22px,4vw,34px);box-shadow:0 14px 30px rgba(31,44,59,.06)}
.fc-card{display:none}
.fc-card.on{display:block;animation:fcin .38s ease}
@keyframes fcin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.fc-card .a-cat{font-family:var(--mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);font-weight:600}
.fc-card h3{font-family:var(--serif);font-size:clamp(21px,3vw,27px);font-weight:700;line-height:1.3;margin:10px 0 0}
.fc-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:16px;flex-wrap:wrap}
.fc-dots{display:flex;gap:8px;flex-wrap:wrap}
.fc-dot{width:32px;height:32px;border-radius:50%;border:1px solid var(--line);background:var(--surface);font-family:var(--mono);font-size:12px;color:var(--ink-soft);cursor:pointer;transition:all .12s ease}
.fc-dot:hover{border-color:var(--accent)}
.fc-dot.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.fc-ctrl{display:flex;gap:10px;align-items:center}
.fc-btn{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:var(--surface);font-size:18px;cursor:pointer;color:var(--ink);transition:all .12s ease}
.fc-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.fc-btn:disabled{opacity:.32;cursor:default}
.fc-count{font-family:var(--mono);font-size:13px;color:var(--ink-soft);letter-spacing:.04em}
.fc-count b{color:var(--accent)}

/* ---- workflow canvas (roadmap) ---- */
.flow{position:relative;margin-top:10px}
.flow-board{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;position:relative;z-index:2}
.flow-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:visible}
.flow-path{stroke:var(--accent);stroke-width:2;fill:none;stroke-dasharray:6 6;opacity:.4}
.flow-path.done{opacity:1;stroke-dasharray:none}
.flow-badge-c{fill:var(--surface);stroke:var(--accent);stroke-width:2}
.flow-badge-c.done{fill:var(--accent)}
.flow-badge-t{fill:var(--accent);font-family:var(--mono);font-size:12px;font-weight:600}
.flow-badge-t.done{fill:#fff}
.flow-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}
.flow-card:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(31,44,59,.08);border-color:var(--accent-2)}
.flow-card.active{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 14%,transparent)}
.flow-card.done{background:color-mix(in srgb,var(--block-sage) 55%,var(--surface))}
.flow-card .ph{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:600}
.flow-card h3{font-family:var(--serif);font-size:18px;font-weight:700;margin:9px 0 6px;line-height:1.3}
.flow-card .mini{font-size:13px;color:var(--ink-soft);line-height:1.5}
.flow-card .check{margin-top:11px;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.flow-card.done .check{color:#4a6b3a}
.flow-card.done .check::before{content:"\2713 "}
.flow-detail{background:var(--block-sky);border-radius:16px;padding:22px 24px;margin-top:20px}
.flow-detail .ph{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:600}
.flow-detail h3{font-family:var(--serif);font-size:22px;font-weight:700;margin:8px 0 10px}
.flow-detail p{font-size:15px;color:var(--ink);line-height:1.65;max-width:62ch}
.flow-hint{font-size:13px;color:var(--ink-soft);margin-top:12px;text-align:center}

@media(max-width:880px){
  .hub{grid-template-columns:1fr}
  .dg,.sw{grid-template-columns:1fr}
  .flow-board{grid-template-columns:1fr 1fr}
  .sysmap .roles{grid-template-columns:1fr}
}
@media(max-width:560px){
  .flow-board{grid-template-columns:1fr}
  .terms,.meta-grid{grid-template-columns:1fr}
  .terms dt,.meta-grid dt{border-bottom:0}
  .fc-bar{flex-direction:column;align-items:stretch}
  .fc-ctrl{justify-content:space-between}
}

/* ---- export collected to HTML (수집함 내보내기) ---- */
.tool-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.export-btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12.5px;font-weight:600;color:var(--accent);background:var(--surface);border:1px solid var(--accent);border-radius:999px;padding:7px 14px;cursor:pointer;transition:background .15s,color .15s}
.export-btn:hover{background:var(--accent);color:#fff}
.export-btn:disabled{opacity:.45;cursor:not-allowed;border-color:var(--line);color:var(--ink-soft)}
.export-btn:disabled:hover{background:var(--surface);color:var(--ink-soft)}
@media(max-width:560px){
  .toolbar-meta{flex-direction:column;align-items:stretch;gap:10px}
  .tool-actions{justify-content:space-between}
  .tool-actions .collect-toggle,.tool-actions .export-btn{flex:1;justify-content:center}
}
/* =======================================================================
   v4 추가 — 히어로 한지 질감 · 잉크 엠블럼 · 모바일 도구막대 정렬
   ======================================================================= */
.hero{position:relative}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:140px 140px;mix-blend-mode:multiply}
.hero .wrap{position:relative;z-index:1}
.hero-emblem{display:block;margin-bottom:14px}
@media (max-width:560px){
  .tool-actions{flex-wrap:wrap;gap:8px}
  .tool-actions .collect-toggle,.tool-actions .export-btn{flex:1 1 auto;justify-content:center}
}

/* ===== 상세 보기 리더 모달 ===== */
.reader{position:fixed;inset:0;z-index:200;display:none}
.reader.open{display:block}
.reader-backdrop{position:absolute;inset:0;background:rgba(36,31,23,.46);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.reader-panel{position:relative;max-width:680px;margin:6vh auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px 38px 30px;box-shadow:0 26px 64px rgba(31,44,59,.30);max-height:84vh;overflow:auto;animation:readerUp .22s ease}
@keyframes readerUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.reader-x{position:absolute;top:16px;right:18px;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);font-size:22px;line-height:1;cursor:pointer;display:grid;place-items:center}
.reader-x:hover{background:var(--paper-2);color:var(--ink)}
.reader-meta{display:flex;gap:10px;align-items:center;font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase}
.reader-meta .r-cat{color:#fff;background:var(--accent);padding:3px 10px;border-radius:999px;font-weight:600}
.reader-meta .r-src{color:var(--ink-soft)}
.reader-panel h2{font-family:var(--serif);font-size:clamp(24px,3.4vw,32px);line-height:1.32;margin:16px 0 4px;color:var(--ink);word-break:keep-all}
.reader-tags{display:flex;flex-wrap:wrap;gap:7px;margin:12px 0 20px}
.reader-tags span{font-family:var(--mono);font-size:12px;color:var(--accent);background:color-mix(in srgb,var(--accent) 9%,transparent);padding:3px 9px;border-radius:7px}
.reader-body{border-top:1px solid var(--line-soft);padding-top:20px}
.reader-body p{font-size:16.5px;line-height:1.8;color:var(--ink);margin:0 0 16px;word-break:keep-all}
.reader-foot{margin-top:22px;padding-top:18px;border-top:1px solid var(--line-soft)}
.reader-note{font-size:14px;color:var(--ink-soft)}
@media (max-width:560px){.reader-panel{margin:0;min-height:100vh;border-radius:0;padding:30px 20px}}