﻿/* ===== Shared Styles — Calcify ===== */
:root {
  --pri: #2563eb; --pri-dark: #1d4ed8; --pri-light: #eff6ff; --pri-glow: rgba(37,99,235,.08);
  --green: #16a34a; --green-light: #f0fdf4;
  --bg: #f8fafc; --card: #fff; --text: #0f172a; --muted: #64748b;
  --border: #e2e8f0; --shadow: 0 1px 3px rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.03);
  --radius: 12px; --radius-sm: 8px; --gap: 20px; --max: 960px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:68px}
body{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.7;font-size:15px}

/* Nav */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.94);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.nav-in{max-width:var(--max);margin:0 auto;padding:0 20px;height:60px;display:flex;align-items:center;gap:28px}
.nav-in .logo{font-weight:800;font-size:18px;color:var(--pri);text-decoration:none;letter-spacing:-.3px}
.nav-in .logo span{color:var(--text)}
.nav-in a{text-decoration:none;color:var(--muted);font-size:13.5px;white-space:nowrap;transition:color .15s;margin-left:auto}
.nav-in a:first-of-type{margin-left:0}
.nav-in a:hover,.nav-in a.active{color:var(--pri)}

/* Layout */
.main{max-width:var(--max);margin:0 auto;padding:0 20px 80px}
section{margin-top:52px}

/* Typography */
.sec-title{font-size:22px;font-weight:700;letter-spacing:-.3px;margin-bottom:6px}
.sec-desc{color:var(--muted);font-size:14px;margin-bottom:24px;line-height:1.6}

/* Hero */
.hero{text-align:center;padding:72px 0 56px;background:linear-gradient(170deg,var(--pri-light) 0%,#fafbff 50%,var(--bg) 100%);border-radius:0 0 36px 36px;margin:0 -20px}
.hero .badge{display:inline-block;background:var(--pri);color:#fff;font-size:12.5px;padding:4px 14px;border-radius:20px;margin-bottom:16px;font-weight:600;letter-spacing:.5px}
.hero h1{font-size:34px;font-weight:800;letter-spacing:-.5px;margin-bottom:8px;line-height:1.2}
.hero .sub{color:var(--muted);font-size:16px;max-width:520px;margin:0 auto}

/* Tool Grid */
.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--gap);margin-top:24px}
.tool-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s, border-color .15s;text-decoration:none;color:inherit;display:block}
.tool-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.06);border-color:var(--pri)}
.tool-card .tool-icon{font-size:36px;margin-bottom:12px}
.tool-card h3{font-size:17px;font-weight:700;margin-bottom:4px}
.tool-card p{color:var(--muted);font-size:13px;line-height:1.6}

/* Card */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);margin-bottom:var(--gap)}
.card h3{font-size:16px;margin-bottom:6px}
.card p{color:var(--muted);font-size:13.5px;line-height:1.7}
.card .tag{display:inline-block;font-size:11px;padding:3px 10px;border-radius:4px;margin-bottom:8px;background:var(--pri-light);color:var(--pri);font-weight:600}

/* Article Card */
.article-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px 26px;box-shadow:var(--shadow);margin-bottom:14px;transition:border-color .15s;text-decoration:none;color:inherit;display:block}
.article-card:hover{border-color:var(--pri)}
.article-card .art-cat{font-size:11px;color:var(--pri);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.article-card h4{font-size:15px;font-weight:600;margin-bottom:3px}
.article-card .art-date{font-size:12px;color:var(--muted)}

/* Form */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:13px;font-weight:600;color:var(--text)}
.form-group input,.form-group select{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:var(--bg);color:var(--text);transition:border-color .15s,box-shadow .15s}
.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 3px var(--pri-glow)}

.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;background:var(--pri);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;font-family:inherit}
.btn:hover{background:var(--pri-dark)}
.btn:active{transform:scale(.98)}
.btn-block{width:100%}

/* Result */
.result{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px 28px;margin-top:20px;display:none}
.result.show{display:block}
.result-num{font-size:42px;font-weight:800;color:var(--pri);line-height:1.1}
.result-label{font-size:14px;color:var(--muted);margin-top:4px}
.result-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-top:18px}
.result-item{background:var(--bg);border-radius:var(--radius-sm);padding:14px;text-align:center}
.result-item .ri-val{font-size:20px;font-weight:700}
.result-item .ri-label{font-size:12px;color:var(--muted);margin-top:2px}

/* Table of Contents */
.toc{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;margin-bottom:28px}
.toc h4{font-size:14px;margin-bottom:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.toc ol{padding-left:20px;font-size:13.5px;line-height:2}
.toc ol a{color:var(--pri);text-decoration:none}
.toc ol a:hover{text-decoration:underline}

/* Table */
.data-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:16px}
.data-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--border);font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.data-table td{padding:10px 12px;border-bottom:1px solid var(--border)}
.data-table tr:hover td{background:var(--pri-light)}

/* Article Content */
.article-body{max-width:720px;margin:40px auto 0}
.article-body h2{font-size:20px;font-weight:700;margin:32px 0 12px}
.article-body h3{font-size:16px;font-weight:600;margin:24px 0 8px}
.article-body p{color:var(--muted);font-size:14px;line-height:1.8;margin-bottom:14px}
.article-body ul{margin:10px 0 16px 20px;color:var(--muted);font-size:14px;line-height:1.8}

/* Footer */
footer{text-align:center;padding:40px 20px;color:var(--muted);font-size:13px;border-top:1px solid var(--border);margin-top:56px}
footer a{color:var(--pri);text-decoration:none}
footer a:hover{text-decoration:underline}
.footer-links{display:flex;justify-content:center;gap:20px;margin-bottom:12px}

/* Highlight Box */
.highlight-box{background:var(--green-light);border:1px solid #bbf7d0;border-radius:var(--radius);padding:20px 24px;margin:16px 0}
.highlight-box h4{color:var(--green);font-size:15px;margin-bottom:4px}
.highlight-box p{color:var(--muted);font-size:13px;line-height:1.6}

/* Breadcrumb */
.breadcrumb{font-size:13px;color:var(--muted);padding:16px 0}
.breadcrumb a{color:var(--pri);text-decoration:none}


/* Dark Mode */
[data-theme="dark"] {
  --bg:#0f1117; --card:#1a1d27; --text:#e2e4e9; --muted:#8b8fa3;
  --border:#2a2d3a; --shadow:0 1px 3px rgba(0,0,0,.2);
  --pri-light:rgba(37,99,235,.12); --pri-glow:rgba(37,99,235,.15);
  --green-light:rgba(22,163,74,.1);
}
[data-theme="dark"] .nav{background:rgba(15,17,23,.94)}
[data-theme="dark"] .hero{background:linear-gradient(170deg,rgba(37,99,235,.08) 0%,rgba(15,17,23,.5) 50%,var(--bg) 100%)}
[data-theme="dark"] .form-group input,[data-theme="dark"] .form-group select{background:var(--bg)}
[data-theme="dark"] .highlight-box{border-color:#1a4a2a}
[data-theme="dark"] .result-item{background:var(--bg)}
[data-theme="dark"] .data-table tr:hover td{background:rgba(37,99,235,.06)}

/* Theme Toggle */
.theme-btn{background:none;border:1px solid var(--border);border-radius:8px;padding:6px 10px;cursor:pointer;font-size:16px;line-height:1;color:var(--text);transition:border-color .15s}
.theme-btn:hover{border-color:var(--pri)}
@media(max-width:600px){
  .hero h1{font-size:24px}
  .form-row{grid-template-columns:1fr}
  .result-grid{grid-template-columns:1fr 1fr}
  .tool-grid{grid-template-columns:1fr}
  .nav-in{gap:14px;overflow-x:auto}
}
