/* 무브노트 디자인 시스템 — 색상은 config.json 기반으로 build.js가 :root 변수를 주입합니다 */
:root{
  --main:#157A6E; --main-d:#0f5d54; --sub:#E8A33D;
  --ink:#1f2a2e; --body:#384450; --muted:#6b7785; --line:#e6eaed;
  --bg:#ffffff; --bg-soft:#f6f8f8; --bg-tint:#eef5f3;
  --radius:14px; --shadow:0 1px 3px rgba(20,40,40,.06),0 6px 20px rgba(20,40,40,.05);
  --wrap:1120px; --read:720px;
  --sans:'Pretendard','Apple SD Gothic Neo','Malgun Gothic',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--body);background:var(--bg);line-height:1.75;-webkit-font-smoothing:antialiased;font-size:16.5px}
img{max-width:100%;height:auto;display:block}
a{color:var(--main);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{color:var(--ink);line-height:1.35;font-weight:700;letter-spacing:-.01em}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* 헤더 / 네비 */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:18px;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--ink);font-size:20px}
.brand .mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--main),var(--main-d));color:#fff;display:grid;place-items:center;font-size:15px;font-weight:800}
.brand:hover{text-decoration:none}
.nav-links{display:flex;gap:4px;margin-left:auto;align-items:center}
.nav-links a{padding:9px 13px;border-radius:9px;color:var(--body);font-weight:600;font-size:15px}
.nav-links a:hover{background:var(--bg-soft);text-decoration:none;color:var(--ink)}
.nav-cta{background:var(--main);color:#fff!important}
.nav-cta:hover{background:var(--main-d)}
.nav-toggle{display:none;margin-left:auto;background:none;border:1px solid var(--line);border-radius:9px;width:42px;height:40px;font-size:20px;cursor:pointer}

/* 히어로 */
.hero{background:linear-gradient(180deg,var(--bg-tint),var(--bg));border-bottom:1px solid var(--line)}
.hero-inner{padding:56px 0 48px;max-width:760px}
.eyebrow{display:inline-block;background:#fff;border:1px solid var(--line);color:var(--main);font-weight:700;font-size:13px;padding:6px 12px;border-radius:999px;margin-bottom:16px}
.hero h1{font-size:clamp(28px,5vw,42px);margin:0 0 14px}
.hero p{font-size:18px;color:var(--muted);margin:0 0 24px}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap}

/* 버튼 */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:10px;font-weight:700;font-size:15px;cursor:pointer;border:1px solid transparent}
.btn-primary{background:var(--main);color:#fff}
.btn-primary:hover{background:var(--main-d);text-decoration:none}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{background:var(--bg-soft);text-decoration:none}

/* 섹션 */
section.block{padding:48px 0}
.block-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:22px}
.block-head h2{font-size:24px;margin:0}
.block-head p{margin:6px 0 0;color:var(--muted);font-size:15px}
.block-soft{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* 카테고리 카드 */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.cat-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;transition:transform .15s,box-shadow .15s}
.cat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);text-decoration:none}
.cat-card .ic{font-size:26px}
.cat-card h3{margin:12px 0 6px;font-size:17px}
.cat-card p{margin:0;color:var(--muted);font-size:14px;line-height:1.6}

/* 글 카드 */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .15s,box-shadow .15s}
.post-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);text-decoration:none}
.post-card .thumb{height:120px;background:linear-gradient(135deg,var(--bg-tint),#fff);display:grid;place-items:center;font-size:34px;border-bottom:1px solid var(--line)}
.post-card .pc-body{padding:18px;display:flex;flex-direction:column;gap:8px;flex:1}
.tag{align-self:flex-start;font-size:12px;font-weight:700;color:var(--main);background:var(--bg-tint);padding:4px 9px;border-radius:999px}
.post-card h3{font-size:17px;margin:2px 0;color:var(--ink)}
.post-card p{margin:0;color:var(--muted);font-size:14px;flex:1}
.post-card .meta{font-size:12.5px;color:var(--muted);margin-top:6px}

/* 미니 박스(운영자/편집원칙) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.panel h3{margin:0 0 12px;font-size:18px}
.principle-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.principle-list li{padding-left:26px;position:relative;color:var(--body)}
.principle-list li:before{content:"✓";position:absolute;left:0;color:var(--main);font-weight:800}
.owner-mini{display:flex;gap:16px;align-items:flex-start}
.avatar{flex:none;width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--main),var(--main-d));color:#fff;display:grid;place-items:center;font-weight:800;font-size:20px}

/* 브레드크럼 */
.crumb{font-size:13.5px;color:var(--muted);padding:18px 0 0}
.crumb a{color:var(--muted)}
.crumb a:hover{color:var(--main)}
.crumb span{margin:0 6px}

/* 본문(아티클) */
.article{max-width:var(--read);margin:0 auto;padding:8px 0 56px}
.article-head h1{font-size:clamp(26px,4.5vw,34px);margin:14px 0 10px}
.article-head .sub{font-size:18px;color:var(--muted);margin:0 0 16px}
.article-meta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;font-size:14px;color:var(--muted);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 0;margin-bottom:28px}
.article-meta .by a{color:var(--main);font-weight:700}
.article-body{font-size:17px}
.article-body h2{font-size:23px;margin:36px 0 12px;padding-top:8px}
.article-body h3{font-size:19px;margin:26px 0 10px}
.article-body p{margin:0 0 16px}
.article-body ul,.article-body ol{margin:0 0 18px;padding-left:22px}
.article-body li{margin:6px 0}
.article-body strong{color:var(--ink)}

/* 목차 */
.toc{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:18px 20px;margin:0 0 28px}
.toc strong{display:block;margin-bottom:8px;color:var(--ink)}
.toc ol{margin:0;padding-left:20px;color:var(--body)}
.toc a{color:var(--body)}

/* 정보 박스 */
.box{border-radius:12px;padding:18px 20px;margin:24px 0;border:1px solid var(--line)}
.box h4{margin:0 0 10px;font-size:16px;display:flex;align-items:center;gap:8px}
.box ul{margin:0;padding-left:20px}
.box.summary{background:var(--bg-tint);border-color:#cfe4df}
.box.mistakes{background:#fff7ec;border-color:#f3dcb4}
.box.checklist{background:#fff;border-style:dashed}
.box.checklist li{list-style:none;padding-left:26px;position:relative}
.box.checklist ul{padding-left:0}
.box.checklist li:before{content:"☑";position:absolute;left:0;color:var(--main)}

/* FAQ */
.faq{margin:30px 0}
.faq details{border:1px solid var(--line);border-radius:10px;padding:4px 16px;margin-bottom:10px;background:#fff}
.faq summary{cursor:pointer;font-weight:700;color:var(--ink);padding:12px 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary:before{content:"Q. ";color:var(--main)}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq p{padding:12px 0;margin:0;color:var(--body)}

/* 운영자 박스(글 하단) */
.author-box{display:flex;gap:16px;align-items:flex-start;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin:36px 0}
.author-box .info h4{margin:0 0 6px}
.author-box .info p{margin:0 0 8px;color:var(--muted);font-size:14.5px}
.author-box a{font-weight:700}

/* 관련 글 */
.related{margin:34px 0 0}
.related h3{font-size:18px;margin:0 0 14px}

/* 칼럼 구분 스타일 */
.column-badge{background:var(--sub);color:#3a2a08}
.article.column .article-head{border-left:4px solid var(--sub);padding-left:18px;margin-left:-22px}
.column-note{background:#fdf6ea;border:1px solid #f0ddb8;border-radius:10px;padding:12px 16px;font-size:14px;color:#6b5a36;margin:20px 0}

/* 작성자 허브 / 칼럼 작성 분기 */
.author-hero{background:linear-gradient(180deg,var(--bg-tint),var(--bg));border-bottom:1px solid var(--line);padding:44px 0}
.author-hero .owner-mini{align-items:center}
.admin-cta{margin-top:18px;padding:16px 18px;border:1px dashed var(--main);border-radius:12px;background:#fff;display:none}
body.is-admin .admin-cta{display:block}
.reader-note{margin-top:14px;color:var(--muted)}
body.is-admin .reader-note{display:none}

/* 문의 폼 */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.field{margin-bottom:14px}
.field label{display:block;font-weight:600;margin-bottom:6px;font-size:14.5px;color:var(--ink)}
.field input,.field textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font:inherit;font-size:15px}
.field textarea{min-height:130px;resize:vertical}
.note{font-size:13.5px;color:var(--muted);background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:12px 14px}

/* 사이트맵 페이지 */
.sitemap-cols{columns:2;gap:30px}
.sitemap-cols section{break-inside:avoid;margin-bottom:18px}
.sitemap-cols h3{font-size:16px;margin:0 0 8px}
.sitemap-cols ul{margin:0;padding-left:18px}

/* 404 */
.center-pad{text-align:center;padding:80px 20px}
.center-pad .big{font-size:64px;font-weight:800;color:var(--main)}

/* 푸터 */
.site-footer{background:#10211f;color:#cdd8d5;margin-top:40px;padding:40px 0 28px;font-size:14.5px}
.site-footer a{color:#cdd8d5}
.site-footer a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px;margin-bottom:24px}
.site-footer h4{color:#fff;font-size:15px;margin:0 0 12px}
.site-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.foot-brand p{color:#9fb0ac;margin:8px 0 0;max-width:320px}
.foot-bottom{border-top:1px solid #233834;padding-top:18px;color:#8ea29d;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}

/* 반응형 */
@media(max-width:820px){
  .split,.contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .sitemap-cols{columns:1}
}
@media(max-width:680px){
  .nav-links{position:fixed;top:64px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);flex-direction:column;align-items:stretch;padding:8px;gap:2px;display:none;box-shadow:var(--shadow)}
  .nav-links.open{display:flex}
  .nav-links a{padding:13px}
  .nav-toggle{display:block}
  .foot-grid{grid-template-columns:1fr}
  body{font-size:16px}
  .article-body{font-size:16.5px}
}
