/* 生活計算所 — 共用樣式（極簡編輯風） */
:root{
  --paper:#f7f3ea; --card:#fffdf8; --ink:#1e241f; --sub:#68716a; --faint:#9a9f96;
  --line:#e3ded1; --line-soft:#eee8dc;
  --accent:#174b38; --accent2:#2f7660; --gold:#b9852d; --sky:#dfeaf1; --soft:#eaf2ec;
  --pos:#1f6f4f; --neg:#a23a2c; --warn:#8a6311;
  --serif:"Fraunces","Noto Serif TC",Georgia,serif;
  --sans:"Noto Sans TC","Inter",-apple-system,system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:
  linear-gradient(180deg,#fbf8f1 0,#f7f3ea 520px,#f4f0e7 100%);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.num{font-feature-settings:"tnum" 1,"lnum" 1}
a{color:inherit;text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}
.ic{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;display:block}

header{border-bottom:1px solid rgba(37,43,36,.08);background:rgba(247,243,234,.86);position:sticky;top:0;z-index:30;backdrop-filter:blur(14px)}
.bar{display:flex;align-items:center;height:72px}
.logo{font-family:var(--serif);font-weight:700;font-size:22px;letter-spacing:.02em;cursor:pointer;display:flex;align-items:center;gap:12px}
.logo::before{content:"";flex:none;width:40px;height:40px;border-radius:12px;background:url("favicon.svg") center/contain no-repeat;box-shadow:0 10px 24px rgba(23,75,56,.16)}
.logo .en{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--faint);font-family:var(--sans);font-weight:700}
.bar .spacer{flex:1}
.ghost{font-size:13px;color:var(--accent);font-weight:700;border:1px solid rgba(23,75,56,.18);background:rgba(255,253,248,.64);border-radius:999px;padding:8px 14px}
.ghost:hover{background:#fffdf8;border-color:rgba(23,75,56,.34)}

.hero{padding:76px 0 54px;border-bottom:1px solid var(--line);margin-bottom:10px}
.hero-copy{max-width:720px}
.kicker{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent2);font-weight:800;margin-bottom:18px}
.hero h1{font-family:var(--serif);font-weight:600;font-size:54px;line-height:1.1;letter-spacing:0;max-width:14ch}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero p{color:var(--sub);font-size:18px;margin-top:20px;max-width:34em}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.hero .primary,.hero .secondary{display:inline-flex;align-items:center;justify-content:center;min-height:46px;border-radius:8px;padding:0 20px;font-size:14px;font-weight:800}
.hero .primary{background:var(--accent);color:#fff;box-shadow:0 12px 26px rgba(23,75,56,.18)}
.hero .primary:hover{background:#103d2d}
.hero .secondary{border:1px solid var(--line);background:#fffdf8;color:var(--ink)}
.hero .secondary:hover{border-color:#d4c8b5}
.hero-proof{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px;color:var(--sub);font-size:12px;font-weight:700}
.hero-proof span{border:1px solid rgba(47,118,96,.18);background:rgba(234,242,236,.72);border-radius:999px;padding:5px 12px;white-space:nowrap}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));border:1px solid var(--line);border-radius:10px;
  margin:24px 0 64px;overflow:hidden;background:var(--line);gap:1px}
@media(max-width:760px){.hero{padding:48px 0 36px}.hero h1{font-size:42px}}
@media(max-width:560px){.grid{grid-template-columns:1fr}.wrap{padding:0 18px}.logo{font-size:19px}.logo .en{display:none}.hero h1{font-size:36px}}
.cat{font-family:var(--serif);font-size:17px;font-weight:700;letter-spacing:.04em;color:var(--accent);margin:42px 0 0;display:flex;align-items:baseline;gap:10px}
.cat .cn{color:var(--faint);font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase}
.catgrid{margin:14px 0 4px}
.tile{position:relative;background:var(--card);padding:28px 24px;cursor:pointer;transition:background .2s,transform .2s;display:block;min-height:178px}
.tile:hover{background:#fbfaf4;transform:translateY(-2px)}
.tile .idx{position:absolute;top:22px;right:24px;font-family:var(--serif);font-size:14px;color:var(--faint)}
.tile .ico{color:var(--accent);margin-bottom:16px;background:var(--soft);width:42px;height:42px;border-radius:10px;padding:10px}
.tile h3{font-family:var(--serif);font-weight:700;font-size:19px;letter-spacing:0;margin-bottom:5px}
.tile p{font-size:13px;color:var(--sub);line-height:1.55;max-width:26ch}
.tile .go{margin-top:14px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent2);
  font-weight:700;display:inline-flex;align-items:center;gap:6px;opacity:0;transform:translateX(-4px);transition:.2s}
.tile:hover .go{opacity:1;transform:none}

.crumb{font-size:12px;color:var(--faint);margin:22px 0 18px;letter-spacing:.02em}
.crumb a:hover{color:var(--accent)}
.crumb span{margin:0 7px}

.tool{padding:0 0 56px;max-width:820px;margin:0 auto}
.tool .head{display:flex;align-items:center;gap:14px;padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:6px}
.tool .head .ico{color:var(--accent)}
h1.title{font-family:var(--serif);font-weight:600;font-size:30px;letter-spacing:-.01em}
.lead{color:var(--sub);font-size:15px;margin:14px 0 26px}

.panel{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:26px;margin-bottom:18px}
.panel h4{font-family:var(--serif);font-weight:600;font-size:17px;margin-bottom:16px}
.field{margin-bottom:18px}.field:last-child{margin-bottom:0}
label{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--sub);margin-bottom:9px;font-weight:700}
input[type=number],input[type=date],select{width:100%;padding:13px 15px;font-size:16px;font-family:var(--sans);
  border:1px solid var(--line);border-radius:7px;background:#fffdf8;color:var(--ink);transition:border-color .15s}
input:focus,select:focus{outline:none;border-color:var(--accent)}
.row{display:flex;gap:16px}.row .field{flex:1}
@media(max-width:560px){.row{flex-direction:column;gap:18px}}
.seg{display:flex;gap:0;flex-wrap:wrap;border:1px solid var(--line);border-radius:7px;overflow:hidden}
.seg button{flex:1;min-width:84px;padding:12px 10px;border:0;border-right:1px solid var(--line);background:#fffdf8;
  font-size:13.5px;cursor:pointer;color:var(--sub);font-family:var(--sans);font-weight:600;transition:.15s}
.seg button:last-child{border-right:0}
.seg button:hover{background:#faf8f1}
.seg button.on{background:var(--accent);color:#fff}
.hint{font-size:12.5px;color:var(--faint);margin-top:9px}

.result{background:var(--card);border:1px solid var(--line);border-top:2px solid var(--accent);border-radius:8px;padding:30px;margin-bottom:18px}
.result.alt{border-top-color:var(--accent2)}
.cap{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);font-weight:700}
.big{font-family:var(--serif);font-weight:600;font-size:46px;line-height:1.06;letter-spacing:-.02em;color:var(--accent);margin-top:12px}
.big small{font-family:var(--sans);font-size:15px;font-weight:500;color:var(--sub);letter-spacing:0;margin-left:6px}
.result .hint{color:var(--sub);margin-top:10px}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:1px;margin-top:26px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.stat{background:var(--card);padding:14px 16px}
.stat .k{font-size:11px;color:var(--sub);letter-spacing:.02em}
.stat .v{font-size:19px;font-weight:700;margin-top:4px;color:var(--ink)}
.panel .stats{margin-top:0}

.badge{display:inline-block;padding:3px 12px;border-radius:999px;font-size:13px;font-weight:700;vertical-align:middle;letter-spacing:.02em}
.b-good{background:#e7f0ea;color:var(--pos)}
.b-warn{background:#f4eddc;color:var(--warn)}
.b-bad{background:#f4e7e2;color:var(--neg)}
.meter{height:6px;border-radius:999px;background:var(--line);overflow:hidden;margin:16px 0 4px}
.meter i{display:block;height:100%;border-radius:999px;transition:width .4s ease}

.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:7px;margin-top:4px}
table{width:100%;border-collapse:collapse;font-size:13px;min-width:440px}
th,td{padding:11px 15px;text-align:right;border-bottom:1px solid var(--line-soft);white-space:nowrap}
th{background:#f3efe6;color:var(--sub);font-weight:600;font-size:11px;letter-spacing:.06em;text-transform:uppercase}
td:first-child,th:first-child{text-align:center;color:var(--faint)}
tr:last-child td{border-bottom:none}

.note{font-size:13px;color:var(--sub);background:var(--soft);border:1px solid #dde7e0;border-left:2px solid var(--accent2);border-radius:7px;padding:14px 16px;margin-top:14px}
.note b{color:var(--accent)}
.applybtn{all:unset;cursor:pointer;background:var(--accent);color:#fff;padding:10px 18px;border-radius:7px;font-size:12px;letter-spacing:.06em;font-weight:700;font-family:var(--sans)}

/* 推薦 / 聯盟區塊 */
.sponsor{border:1px dashed #c8cfca;background:#f3f7f4;border-radius:9px;padding:16px 18px;margin:18px 0;display:flex;
  align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.sponsor .label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);font-weight:700}
.sponsor h5{font-family:var(--serif);font-size:16px;font-weight:600;margin-top:3px}
.sponsor p{font-size:13px;color:var(--sub);margin-top:2px}
.sponsor a{background:var(--accent2);color:#fff;padding:10px 16px;border-radius:7px;font-size:13px;font-weight:700;white-space:nowrap}

/* 內容（文章）區 */
.content{max-width:860px;margin-top:38px;padding-top:30px;border-top:1px solid var(--line)}
.content h2{font-family:var(--serif);font-weight:600;font-size:21px;margin:30px 0 12px;letter-spacing:-.01em}
.content h2:first-child{margin-top:0}
.content h3{font-size:15.5px;font-weight:700;margin:20px 0 6px;color:var(--ink)}
.content p{color:#3c3a34;font-size:15px;margin-bottom:12px}
.content ul{color:#3c3a34;font-size:15px;margin:0 0 12px 1.2em}
.content li{margin-bottom:6px}
.content .tablewrap{margin:6px 0 14px}
.content table th{text-transform:none;letter-spacing:0;font-size:12.5px}
.content table td:first-child,.content table th:first-child{text-align:left}
.content table td:first-child{color:var(--ink);font-weight:500}

.cta{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;background:var(--soft);border:1px solid #dde7e0;border-radius:10px;padding:18px 20px;margin:24px 0}
.cta b{font-family:var(--serif);font-size:16px;font-weight:600;color:var(--ink)}
.cta p{font-size:13px;color:var(--sub);margin-top:2px}
.cta a{background:var(--accent);color:#fff;padding:11px 18px;border-radius:8px;font-size:14px;font-weight:700;white-space:nowrap}
.cta a:hover{background:var(--brand-ink,#15392e)}
.artmeta{font-size:12.5px;color:var(--faint);margin:-6px 0 18px}
.guidecard{display:block;border:1px solid var(--line);border-radius:10px;padding:20px 22px;margin-bottom:14px;background:var(--card);transition:.15s}
.guidecard:hover{background:#fbfaf4;border-color:#d8d2c4}
.guidecard h3{font-family:var(--serif);font-size:18px;font-weight:600;margin-bottom:5px}
.guidecard p{font-size:13.5px;color:var(--sub);line-height:1.6}

/* 相關工具 */
.related{margin-top:40px;padding-top:26px;border-top:1px solid var(--line)}
.related h2{font-family:var(--serif);font-size:16px;font-weight:600;margin-bottom:16px}
.rgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.rcard{border:1px solid var(--line);border-radius:8px;padding:14px 16px;background:var(--card);transition:.15s}
.rcard:hover{background:#fbfaf4;border-color:#d8d2c4}
.rcard b{font-family:var(--serif);font-weight:600;font-size:14.5px}
.rcard span{display:block;font-size:12px;color:var(--sub);margin-top:2px}

footer{border-top:1px solid var(--line);padding:64px 0 38px;margin-top:24px;color:var(--faint);font-size:12px;letter-spacing:.04em;text-align:left}
footer b{color:var(--sub);font-family:var(--serif);font-weight:600}
footer .fnav{margin-bottom:10px}
footer .fnav a{margin:0 18px 0 0;color:var(--sub)}
footer .fnav a:hover{color:var(--accent)}
footer .footlinks{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:7px 18px;margin:0 0 16px;padding-bottom:14px;border-bottom:1px solid var(--line)}
footer .footlinks a{font-size:12.5px;color:var(--sub)}
footer .footlinks a:hover{color:var(--accent)}
footer .fabout{max-width:640px;margin:0 0 22px;text-align:left}
footer .fabout .fname{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--ink);margin-bottom:10px;display:flex;align-items:center;gap:10px}
footer .fabout .fname::before{content:"";width:34px;height:34px;border-radius:10px;background:url("favicon.svg") center/contain no-repeat;box-shadow:0 8px 18px rgba(23,75,56,.12);flex:none}
footer .fabout .fname span{font-family:var(--sans);font-size:10px;letter-spacing:.26em;color:var(--faint);text-transform:uppercase;margin-left:7px}
footer .fabout p{font-size:13px;color:var(--sub);line-height:1.75}
