/* 계산기허브 공통 스타일 — Pretendard 기반 정돈된 디자인 (폰트는 각 페이지 head의 preconnect+link로 로드) */

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --accent:#0e7c66; --accent-d:#0a5f4e; --accent-soft:#e8f3ef;
  --bg:#f7f6f2; --card:#ffffff; --line:#e9e6df; --line-2:#f1efe9;
  --ink:#1c1b18; --sub:#6c6a63; --warn:#c2410c; --ok:#0e7c66;
  --radius:16px; --shadow:0 1px 2px rgba(28,27,24,.04),0 6px 20px rgba(28,27,24,.04);
}
html{scroll-behavior:smooth}
body{font-family:'Pretendard Variable',Pretendard,-apple-system,'Malgun Gothic',sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased;letter-spacing:-.01em}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* 네비 */
.nav{background:rgba(255,255,255,.85);backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.nav-in{max-width:920px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;gap:6px 18px;flex-wrap:wrap}
.nav .logo{font-weight:800;font-size:19px;color:var(--ink);letter-spacing:-.03em}
.nav .logo span{color:var(--accent)}
.nav a.lnk{font-size:14.5px;color:var(--sub);font-weight:500}
.nav a.lnk:hover{color:var(--accent);text-decoration:none}
.nav .sp{flex:1}

main{max-width:920px;margin:0 auto;padding:32px 20px 72px}
.crumb{font-size:13px;color:var(--sub);margin-bottom:18px}
.crumb a{color:var(--sub)}
h1{font-size:30px;line-height:1.25;margin-bottom:10px;letter-spacing:-.035em;font-weight:800}
h2{font-size:20px;margin:30px 0 12px;letter-spacing:-.03em;font-weight:700}
.lead{color:var(--sub);font-size:16px;margin-bottom:26px;max-width:60ch}

/* 카드/입력 */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;margin-bottom:22px;box-shadow:var(--shadow)}
label{display:block;font-size:13px;font-weight:600;margin:16px 0 7px;color:#43413b}
input,select,textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;font-size:15.5px;font-family:inherit;background:#fcfbf9;color:var(--ink);transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:#fff}
textarea{min-height:120px;resize:vertical;font-family:ui-monospace,monospace;font-size:13px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.row{grid-template-columns:1fr}}

.btn{width:100%;margin-top:20px;padding:14px;border:none;border-radius:12px;background:var(--accent);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:transform .08s,background .15s;letter-spacing:-.02em}
.btn:hover{background:var(--accent-d)}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:#fff;color:var(--accent);border:1.5px solid var(--accent)}
.btn.ghost:hover{background:var(--accent-soft)}
.btn.sm{width:auto;padding:9px 14px;font-size:13px;margin:0}

/* 결과 */
.result{margin-top:22px;padding:22px;background:var(--accent-soft);border:1px solid #d4e9e1;border-radius:14px;display:none}
.result.show{display:block;animation:pop .25s ease}
@keyframes pop{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.result .big{font-size:32px;font-weight:800;color:var(--accent-d);letter-spacing:-.03em}
.result .lab{font-size:13px;color:var(--sub);font-weight:600;margin-bottom:2px}
.breakdown{margin-top:16px;font-size:14.5px}
.breakdown div{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid #dcebe5}
.breakdown div:last-child{border:none;font-weight:800;font-size:16px;padding-top:12px}

/* 카테고리 + 카드 그리드 */
.cat{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:700;color:var(--ink);margin:30px 0 14px;letter-spacing:-.02em}
.cat::after{content:"";flex:1;height:1px;background:var(--line)}
.cat .chip{font-size:18px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}
@media(max-width:720px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:430px){.cards{grid-template-columns:1fr}}
.tool{display:flex;align-items:center;gap:13px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;transition:transform .14s,border-color .14s,box-shadow .14s}
.tool:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 10px 24px rgba(14,124,102,.12);text-decoration:none}
.tool .ico{flex:none;width:42px;height:42px;border-radius:11px;background:var(--accent-soft);display:grid;place-items:center;font-size:21px}
.tool .t{font-weight:700;color:var(--ink);font-size:14.5px;letter-spacing:-.02em;line-height:1.3}
.tool .d{font-size:12.5px;color:var(--sub);margin-top:3px;line-height:1.35}

/* 히어로 */
.hero{background:linear-gradient(180deg,#fff,#fbfaf7);border:1px solid var(--line);border-radius:20px;padding:40px 30px;margin-bottom:14px;box-shadow:var(--shadow)}
.hero h1{font-size:32px;margin-bottom:12px}
.hero .lead{margin-bottom:0}

/* 본문 글 */
.prose{margin-top:8px}
.prose p{margin:12px 0;color:#3a3833}
.prose h2{font-size:19px}
.prose ul{margin:12px 0 12px 20px;color:#3a3833}
.prose li{margin:5px 0}

.note{font-size:13px;color:var(--sub);margin-top:16px;padding:14px 16px;background:#fbfaf7;border-radius:11px;border-left:3px solid var(--accent)}
.muted{color:var(--sub)}
.empty{text-align:center;padding:60px 20px;color:var(--sub)}
.empty .big{font-size:42px;margin-bottom:12px}
details{margin-top:10px}
summary{cursor:pointer;font-size:13px;color:var(--accent);font-weight:600}
.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.pill{font-size:11.5px;padding:3px 10px;border-radius:20px;background:var(--accent-soft);color:var(--accent-d);font-weight:600}

/* 푸터 */
footer{border-top:1px solid var(--line);background:#fff;margin-top:50px}
.foot-in{max-width:920px;margin:0 auto;padding:28px 20px;font-size:13px;color:var(--sub);display:flex;gap:8px 18px;flex-wrap:wrap;align-items:center}
.foot-in a{color:var(--sub)}
.foot-in a:hover{color:var(--accent)}

/* ===== 다크모드 ===== */
:root[data-theme="dark"]{
  --bg:#141519; --card:#1d1f26; --line:#2c2f39; --line-2:#23262e;
  --ink:#ecebe7; --sub:#9b9ea8; --accent:#2dd4a7; --accent-d:#27c098; --accent-soft:#16312a;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 8px 24px rgba(0,0,0,.4);
}
:root[data-theme="dark"] input,:root[data-theme="dark"] select,:root[data-theme="dark"] textarea{background:#15161b;color:var(--ink)}
:root[data-theme="dark"] .hero{background:linear-gradient(180deg,#1f222a,#191b21)}
:root[data-theme="dark"] .result{border-color:#1f4d40}
:root[data-theme="dark"] .breakdown div{border-color:#2c2f39}
:root[data-theme="dark"] .note,:root[data-theme="dark"] .card[style]{background:#191b21 !important}
:root[data-theme="dark"] .tool:hover{box-shadow:0 10px 24px rgba(0,0,0,.45)}

/* 테마 토글 버튼 */
.theme-btn{background:none;border:1px solid var(--line);color:var(--sub);width:36px;height:36px;border-radius:10px;cursor:pointer;font-size:15px;display:grid;place-items:center;transition:.15s;flex:none}
.theme-btn:hover{border-color:var(--accent);color:var(--accent)}

/* 검색 박스 */
.search{position:relative;margin:6px 0 10px}
.search input{padding-left:44px;font-size:15px}
.search-ico{position:absolute;left:15px;top:50%;transform:translateY(-50%);font-size:15px;opacity:.55;pointer-events:none}
.no-result{display:none;text-align:center;color:var(--sub);padding:30px;font-size:14px}
:root[data-theme="dark"] .nav{background:rgba(20,21,25,.85)}
:root[data-theme="dark"] footer{background:#1a1c22}
:root[data-theme="dark"] label{color:#c3c5cc}
:root[data-theme="dark"] .prose p,:root[data-theme="dark"] .prose ul{color:#c3c5cc}
:root[data-theme="dark"] input:focus,:root[data-theme="dark"] select:focus,:root[data-theme="dark"] textarea:focus{background:#15161b}
:root[data-theme="dark"] .btn.ghost{background:transparent}
