/* GoodFormat — 라이트 테마 재설계. 흰 배경 + 고대비 잉크 텍스트 + 카드 + 다크 에디터 */
.gf-wrap{
  max-width:1060px;margin:0 auto;padding:28px 16px 72px;
  --ink:#14161f;          /* 제목 */
  --ink2:#363b47;         /* 본문 */
  --mut:#69707d;          /* 보조 */
  --line:#e4e8ee;         /* 보더 */
  --soft:#f6f8fb;         /* 연카드 배경 */
  --soft2:#eef2f7;        /* 더 진한 연배경(바) */
  --accent:#15a34a;       /* 그린 */
  --accent2:#22c55e;
  --accent-soft:#e7f7ee;  /* 그린 연배경 */
  --code-bg:#0d1117;      /* 다크 에디터 */
  --code-fg:#d8dee9;
  --c-key:#7ee787;--c-str:#a5d6ff;--c-num:#79c0ff;--c-bool:#ff7b72;
  --shadow:0 1px 2px rgba(20,22,31,.04),0 4px 16px rgba(20,22,31,.06);
  --shadow-h:0 4px 12px rgba(20,22,31,.08),0 12px 32px rgba(21,163,74,.12);
  --mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace;
  color:var(--ink2);
}
.gf-wrap *{box-sizing:border-box}

/* ===== 헤더 ===== */
.gf-head{margin-bottom:22px}
.gf-title{font-size:40px;font-weight:800;margin:0 0 10px;letter-spacing:-1px;color:var(--ink);line-height:1.1}
.gf-title::after{content:"";display:block;width:54px;height:4px;border-radius:3px;background:linear-gradient(90deg,var(--accent2),var(--accent));margin-top:12px}
.gf-sub{margin:14px 0 8px;color:var(--ink2);font-size:16px;line-height:1.55}
.gf-sub b{color:var(--ink);font-weight:700}
.gf-priv{display:inline-block;margin:0;font-size:13px;color:var(--accent);background:var(--accent-soft);
  border:1px solid #c8ecd6;padding:6px 12px;border-radius:20px;font-weight:600}

/* ===== 탭 ===== */
.gf-tabs{display:flex;gap:7px;margin-bottom:16px;flex-wrap:wrap}
.gf-tab{background:#fff;border:1px solid var(--line);color:var(--mut);
  padding:9px 18px;border-radius:9px;cursor:pointer;font-size:14px;font-weight:600;transition:.13s}
.gf-tab:hover{color:var(--ink);border-color:#cfd6df;background:var(--soft)}
.gf-tab.is-active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(21,163,74,.28)}

/* ===== 에디터 (다크 코드 박스) ===== */
.gf-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:760px){.gf-grid{grid-template-columns:1fr}}
.gf-pane{background:var(--code-bg);border:1px solid #1f2530;border-radius:14px;overflow:hidden;
  display:flex;flex-direction:column;min-height:360px;box-shadow:var(--shadow)}
.gf-pane-bar{display:flex;align-items:center;justify-content:space-between;
  padding:11px 14px;border-bottom:1px solid #1f2530;background:#11161e}
.gf-pane-label{font-size:13px;font-weight:700;color:#9aa4b2}
.gf-pane-label em{color:var(--accent2);font-style:normal;font-weight:600;margin-left:5px}
.gf-pane-actions{display:flex;gap:6px}
.gf-btn-mini{background:#1a212c;border:1px solid #2b3340;color:#9aa4b2;
  padding:5px 11px;border-radius:7px;cursor:pointer;font-size:12px;font-weight:500;transition:.13s}
.gf-btn-mini:hover{color:#fff;border-color:#3d4654;background:#222a36}
.gf-btn-mini.is-active{background:var(--accent);border-color:var(--accent);color:#fff}
.gf-btn-mini.gf-copy:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.gf-input{flex:1;width:100%;border:0;resize:vertical;background:transparent;color:var(--code-fg);
  padding:15px;font-family:var(--mono);font-size:13px;line-height:1.65;outline:none;min-height:320px}
.gf-input::placeholder{color:#566072}
.gf-output{flex:1;padding:15px;overflow:auto;font-family:var(--mono);font-size:13px;
  line-height:1.65;white-space:pre;color:var(--code-fg);tab-size:2}
.gf-placeholder{color:#566072;white-space:normal}

/* 트리 */
.gf-tree{white-space:normal}
.gf-tn{padding-left:2px}
.gf-tn-body{padding-left:18px;border-left:1px solid #232b37;margin-left:5px}
.gf-tn-head{cursor:pointer;user-select:none;border-radius:5px;padding:1px 4px}
.gf-tn-head:hover{background:#1a212c}
.gf-tog{display:inline-block;width:14px;color:var(--accent2);font-size:11px}
.gf-tn.is-collapsed>.gf-tn-body{display:none}
.gf-k{color:var(--c-key)}
.gf-count{color:#566072;font-size:11px}
.gf-v-string{color:var(--c-str)}.gf-v-number{color:var(--c-num)}
.gf-v-boolean{color:var(--c-bool)}.gf-v-null{color:var(--c-bool);font-style:italic}

/* ===== 툴바 ===== */
.gf-toolbar{display:flex;align-items:center;gap:12px;margin-top:16px;flex-wrap:wrap}
.gf-btn{background:#fff;border:1px solid var(--line);color:var(--ink);
  padding:11px 22px;border-radius:10px;cursor:pointer;font-size:14px;font-weight:700;transition:.13s;box-shadow:var(--shadow)}
.gf-btn:hover{border-color:#cfd6df;background:var(--soft)}
.gf-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 10px rgba(21,163,74,.3)}
.gf-btn-primary:hover{background:#138a3f;border-color:#138a3f}
.gf-indent{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--mut);font-weight:600}
.gf-chip{background:#fff;border:1px solid var(--line);color:var(--mut);
  padding:6px 13px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600;transition:.13s}
.gf-chip:hover{color:var(--ink);background:var(--soft)}
.gf-chip.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}
.gf-status{font-size:13px;color:var(--accent);margin-left:auto;font-weight:600}
.gf-status.is-err{color:#dc2626}

/* ===== 공통 섹션/카드 ===== */
.gf-section{margin-top:44px}
.gf-section-h{display:flex;align-items:baseline;gap:10px;margin:0 0 18px}
.gf-section-h h2{font-size:22px;color:var(--ink);margin:0;font-weight:800;letter-spacing:-.4px}
.gf-h-sub{font-size:13px;color:var(--mut);font-weight:500}
.gf-card{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}

/* 사용법 카드 */
.gf-about{margin-top:44px}
.gf-about .gf-card-inner{padding:22px 24px}
.gf-about h2{font-size:22px;color:var(--ink);margin:0 0 14px;font-weight:800;letter-spacing:-.4px}
.gf-about p{margin:0 0 14px;font-size:14.5px;line-height:1.75;color:var(--ink2)}
.gf-about ul{margin:0;padding:0;list-style:none;display:grid;gap:10px}
.gf-about li{font-size:14px;line-height:1.6;color:var(--ink2);background:var(--soft);
  border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.gf-about li b{color:var(--accent);font-weight:700}
.gf-about code,.gf-glyph-card code,.gf-acc-a code{background:var(--soft2);border:1px solid var(--line);
  padding:1px 6px;border-radius:5px;font-family:var(--mono);font-size:12.5px;color:#0a5c2c}

/* ===== 기호 도감 ===== */
.gf-glyph-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.gf-glyph-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;
  box-shadow:var(--shadow);transition:.16s}
.gf-glyph-card:hover{border-color:var(--accent2);transform:translateY(-3px);box-shadow:var(--shadow-h)}
.gf-sym{font-family:var(--mono);font-size:28px;font-weight:800;color:var(--accent);line-height:1;
  background:var(--accent-soft);display:inline-block;padding:8px 14px;border-radius:10px;margin-bottom:12px}
.gf-sym-name{font-size:12px;color:var(--mut);margin:0 0 10px;font-family:var(--mono);font-weight:600;letter-spacing:.3px}
.gf-glyph-card p{margin:0;font-size:13.5px;line-height:1.7;color:var(--ink2)}
.gf-glyph-card b{color:var(--ink);font-weight:700}
.gf-glyph-note{margin:18px 0 0;font-size:13.5px;line-height:1.75;color:var(--mut);
  background:var(--soft);border:1px solid var(--line);border-radius:12px;padding:16px 18px}

/* ===== FAQ ===== */
.gf-acc{border:1px solid var(--line);border-radius:12px;margin-bottom:11px;overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.gf-acc.is-open{border-color:var(--accent2)}
.gf-acc-q{width:100%;text-align:left;background:transparent;border:0;color:var(--ink);
  padding:17px 50px 17px 18px;font-size:15px;font-weight:700;cursor:pointer;position:relative}
.gf-acc-q::after{content:"+";position:absolute;right:18px;top:50%;transform:translateY(-50%);
  color:var(--accent);font-size:22px;font-weight:400;transition:.18s}
.gf-acc.is-open .gf-acc-q::after{transform:translateY(-50%) rotate(45deg)}
.gf-acc-q:hover{color:var(--accent)}
.gf-acc-a{max-height:0;overflow:hidden;transition:max-height .24s ease}
.gf-acc.is-open .gf-acc-a{max-height:360px}
.gf-acc-a p{margin:0;padding:0 18px 18px;font-size:14px;line-height:1.75;color:var(--ink2)}
.gf-acc-a b{color:var(--ink);font-weight:700}

/* ===== 댓글 ===== */
.gf-cform{background:var(--soft);border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:20px}
.gf-cform-row{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.gf-c-nick{flex:0 0 190px;background:#fff;border:1px solid var(--line);color:var(--ink);
  padding:10px 12px;border-radius:9px;font-size:13.5px;outline:none;transition:.13s}
.gf-c-nick:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(34,197,94,.12)}
.gf-c-count{font-size:12px;color:var(--mut);margin-left:auto}
.gf-c-count em{color:var(--ink2);font-style:normal;font-weight:600}
.gf-c-body{width:100%;background:#fff;border:1px solid var(--line);color:var(--ink);
  padding:11px 12px;border-radius:9px;font-size:13.5px;line-height:1.55;resize:vertical;outline:none;min-height:54px;transition:.13s}
.gf-c-body:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(34,197,94,.12)}
.gf-cform-bar{display:flex;align-items:center;gap:12px;margin-top:10px}
.gf-c-msg{font-size:13px;color:var(--accent);font-weight:600}
.gf-c-msg.is-err{color:#dc2626}
.gf-c-submit{margin-left:auto;padding:9px 20px;font-size:13.5px}
.gf-clist{list-style:none;margin:0;padding:0}
.gf-citem{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow)}
.gf-citem-head{display:flex;align-items:baseline;gap:10px;margin-bottom:5px}
.gf-citem-head b{color:var(--ink);font-size:14px;font-weight:700}
.gf-citem-head time{font-size:12px;color:var(--mut)}
.gf-citem p{margin:0;font-size:14px;line-height:1.65;color:var(--ink2);white-space:pre-wrap;word-break:break-word}
.gf-cempty{color:var(--mut);font-size:13.5px;padding:18px;text-align:center;
  background:var(--soft);border:1px dashed var(--line);border-radius:12px}

/* ===== 형식 열전 ===== */
.gf-fmt-grid{display:grid;gap:14px}
.gf-fmt-card{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.gf-fmt-card.is-json{border-top:4px solid #f7df1e}
.gf-fmt-card.is-xml{border-top:4px solid #e87f3a}
.gf-fmt-card.is-py{border-top:4px solid #3776ab}
.gf-fmt-card.is-cousin{border-top:4px solid var(--accent2)}
.gf-fmt-inner{padding:20px 22px}
.gf-fmt-top{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:6px}
.gf-fmt-name{font-size:19px;font-weight:800;color:var(--ink);letter-spacing:-.3px}
.gf-fmt-full{font-size:12.5px;color:var(--mut);font-family:var(--mono)}
.gf-fmt-lead{margin:0 0 14px;font-size:14px;line-height:1.7;color:var(--ink2)}
.gf-fmt-rows{display:grid;gap:8px;margin-bottom:14px}
.gf-fmt-row{display:grid;grid-template-columns:96px 1fr;gap:12px;font-size:13.5px;line-height:1.65;align-items:start}
.gf-fmt-row dt{color:var(--accent);font-weight:700}
.gf-fmt-row dd{margin:0;color:var(--ink2)}
.gf-fmt-row dd b{color:var(--ink);font-weight:700}
.gf-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.gf-tag{font-size:12px;background:var(--soft2);border:1px solid var(--line);color:var(--ink2);
  padding:3px 10px;border-radius:20px;font-weight:600}
.gf-fmt-tmi{margin:0;font-size:13px;line-height:1.65;color:var(--mut);background:var(--soft);
  border-left:3px solid var(--accent2);border-radius:0 8px 8px 0;padding:10px 14px}
.gf-fmt-tmi b{color:var(--ink2)}
.gf-fmt-card code,.gf-fmt-tmi code,.gf-tmi-card code,.gf-disclaimer code{
  background:var(--soft2);border:1px solid var(--line);padding:1px 6px;border-radius:5px;
  font-family:var(--mono);font-size:12px;color:#0a5c2c}

/* ===== 잡학 TMI ===== */
.gf-tmi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.gf-tmi-card{background:var(--soft);border:1px solid var(--line);border-radius:12px;padding:15px 16px;transition:.15s}
.gf-tmi-card:hover{background:#fff;border-color:var(--accent2);box-shadow:var(--shadow)}
.gf-tmi-card h3{margin:0 0 6px;font-size:13.5px;font-weight:700;color:var(--ink)}
.gf-tmi-card h3::before{content:"›";color:var(--accent);font-weight:800;margin-right:6px}
.gf-tmi-card p{margin:0;font-size:13px;line-height:1.65;color:var(--ink2)}

/* ===== 면책 ===== */
.gf-disclaimer{margin-top:40px;background:var(--soft);border:1px solid var(--line);
  border-radius:12px;padding:18px 20px}
.gf-disclaimer h3{margin:0 0 8px;font-size:14px;font-weight:700;color:var(--ink2);display:flex;align-items:center;gap:7px}
.gf-disclaimer p{margin:0;font-size:13px;line-height:1.75;color:var(--mut)}
.gf-disclaimer b{color:var(--ink2);font-weight:700}

/* ===== JSON 에러 사전 ===== */
.gf-err-intro{margin:0 0 18px;font-size:14px;line-height:1.7;color:var(--ink2);
  background:var(--soft);border:1px solid var(--line);border-radius:12px;padding:14px 18px}
.gf-err-intro b{color:var(--ink)}
.gf-err-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}
.gf-err-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow);transition:.15s}
.gf-err-card:hover{border-color:#fca5a5;box-shadow:0 4px 12px rgba(20,22,31,.08),0 12px 28px rgba(220,38,38,.1)}
.gf-err-badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 9px;border-radius:20px;margin-bottom:10px;letter-spacing:.3px}
.gf-err-badge.py{background:#eaf1fb;color:#2f5fa3;border:1px solid #cfdef5}
.gf-err-badge.js{background:#fdf6e3;color:#9a7d1a;border:1px solid #f0e3b8}
.gf-err-msg{display:block;font-family:var(--mono);font-size:12.5px;line-height:1.5;color:#b91c1c;
  background:#fef2f2;border:1px solid #fecaca;border-left:3px solid #ef4444;border-radius:0 8px 8px 0;
  padding:9px 12px;margin-bottom:12px;word-break:break-word}
.gf-err-rows{display:grid;gap:7px}
.gf-err-row{display:grid;grid-template-columns:54px 1fr;gap:10px;font-size:13px;line-height:1.6;align-items:start}
.gf-err-row dt{font-weight:700;font-size:12px;padding-top:1px}
.gf-err-row.cause dt{color:#dc2626}
.gf-err-row.fix dt{color:var(--accent)}
.gf-err-row dd{margin:0;color:var(--ink2)}
.gf-err-row dd b{color:var(--ink);font-weight:700}
.gf-err-card code{background:var(--soft2);border:1px solid var(--line);padding:1px 5px;border-radius:4px;
  font-family:var(--mono);font-size:11.5px;color:#0a5c2c}
