/* ─────────────────────────────────────────────────────────────────────────────
   Cosmic Compass — Main Stylesheet
   Color scheme matches original Replit design exactly.
   Default: LIGHT (cream + amber). .dark class enables dark mode (navy + gold).
   ───────────────────────────────────────────────────────────────────────────── */

:root {
  /* Original light scheme (default) */
  --bg:           hsl(40, 30%, 96%);    /* warm cream */
  --bg-card:      hsl(40, 30%, 98%);    /* slightly lighter cream */
  --bg-muted:     hsl(40, 10%, 90%);    /* muted cream */
  --border:       hsl(40, 20%, 85%);    /* warm beige border */
  --text:         hsl(230, 30%, 15%);   /* deep navy text */
  --text-muted:   hsl(230, 15%, 45%);   /* muted blue-gray */
  --text-subtle:  hsl(230, 10%, 55%);   /* even softer */

  --primary:        hsl(42, 70%, 45%);  /* warm amber */
  --primary-light:  hsl(42, 70%, 55%);
  --primary-dark:   hsl(42, 70%, 35%);
  --primary-fg:     hsl(40, 30%, 98%);

  --heading:        hsl(230, 30%, 15%); /* same as text in light mode */
  --accent:         hsl(42, 70%, 45%);  /* amber accent */

  --shadow:    0 4px 24px hsl(230, 30%, 15% / 0.08);
  --shadow-lg: 0 12px 32px hsl(230, 30%, 15% / 0.12);

  --radius:    12px;
  --radius-lg: 20px;
  --header-h:  64px;

  --font-sans:  'Inter', system-ui, -apple-system, sans-serif;
  --font-serif: 'Fraunces', 'Playfair Display', Georgia, serif;

  --transition: 0.18s ease;
}

.dark {
  /* Dark scheme — deep navy + warm gold */
  --bg:           hsl(230, 30%, 8%);    /* deep navy */
  --bg-card:      hsl(230, 30%, 10%);   /* slightly lighter navy */
  --bg-muted:     hsl(230, 20%, 15%);
  --border:       hsl(230, 20%, 20%);
  --text:         hsl(40, 30%, 96%);    /* cream text */
  --text-muted:   hsl(40, 10%, 70%);
  --text-subtle:  hsl(40, 8%, 55%);

  --primary:        hsl(42, 70%, 60%);  /* brighter gold for dark bg */
  --primary-light:  hsl(42, 80%, 70%);
  --primary-dark:   hsl(42, 70%, 50%);
  --primary-fg:     hsl(230, 30%, 8%);

  --heading:        hsl(42, 70%, 60%);  /* gold headings glow on navy */
  --accent:         hsl(42, 70%, 60%);

  --shadow:    0 4px 24px hsl(0 0% 0% / 0.4);
  --shadow-lg: 0 12px 32px hsl(0 0% 0% / 0.5);
}

/* ── Reset ───────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-sans);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  transition: background-color 0.2s, color 0.2s;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--primary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--primary-dark); }
.dark a:hover { color: var(--primary-light); }
button { cursor: pointer; border: none; background: none; font-family: inherit; color: inherit; }

input, textarea, select {
  font-family: inherit; font-size: 1rem;
  background: var(--bg-card); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 0.625rem 0.875rem; width: 100%;
  transition: border-color var(--transition), box-shadow var(--transition);
}
input:focus, textarea:focus, select:focus {
  outline: none; border-color: var(--primary);
  box-shadow: 0 0 0 3px hsl(42 70% 50% / 0.2);
}
label { font-size: 0.875rem; font-weight: 500; display: block; margin-bottom: 0.375rem; }

/* ── Headings — centered + amber/gold color ──────────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--font-serif);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--heading);
}

/* Center main page H1/H2 (as user requested) */
.cc-h1, .cc-section-title, .cc-page-title, .cc-trust-title { text-align: center; }
.cc-h1 .accent { color: var(--primary); }

/* Tool page H1 has emoji prefix - keep left aligned */
.cc-tool-title { text-align: left; }

/* Card titles - kept left for readability */
.cc-tool-name, .cc-blog-title, .cc-cat-name, .cc-post-title,
.cc-footer-col h4, .cc-widget-title { text-align: left; }

/* Prose H2/H3 (legal pages, blog body) - left aligned */
.cc-prose h1, .cc-prose h2, .cc-prose h3,
.cc-post-content h1, .cc-post-content h2, .cc-post-content h3 { text-align: left; }

/* ── Layout ──────────────────────────────────────────────────────────────── */
.cc-container { max-width: 1200px; margin: 0 auto; padding: 0 1rem; }
@media (min-width: 640px)  { .cc-container { padding: 0 1.5rem; } }
@media (min-width: 1024px) { .cc-container { padding: 0 2rem; } }

/* ── Header ──────────────────────────────────────────────────────────────── */
.cc-header {
  height: var(--header-h);
  background: hsl(40 30% 96% / 0.85);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
}
.dark .cc-header { background: hsl(230 30% 10% / 0.85); }
.cc-header--sticky { position: sticky; top: 0; z-index: 100; }
.cc-header-inner { height: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }

.cc-logo {
  display: flex; align-items: center; gap: 0.625rem;
  color: var(--text); font-weight: 700; font-family: var(--font-serif);
  font-size: 1.15rem; letter-spacing: -0.01em; text-decoration: none; white-space: nowrap;
}
.cc-logo:hover { color: var(--text); }
.cc-logo-icon {
  width: 32px; height: 32px; border-radius: 50%;
  background: hsl(42 70% 50% / 0.15);
  border: 1px solid hsl(42 70% 50% / 0.3);
  display: flex; align-items: center; justify-content: center; color: var(--primary);
  flex-shrink: 0;
}

.cc-nav { display: none; align-items: center; gap: 0.25rem; }
@media (min-width: 768px) { .cc-nav { display: flex; } }
.cc-nav-list { list-style: none; display: flex; align-items: center; gap: 0.25rem; margin: 0; padding: 0; }
.cc-nav-item { position: relative; }
.cc-nav-link {
  padding: 0.5rem 0.75rem; border-radius: 8px; font-size: 0.9rem; font-weight: 500;
  color: var(--text-muted); transition: color var(--transition), background var(--transition);
  background: none; display: flex; align-items: center; gap: 0.3rem;
  text-decoration: none;
}
.cc-nav-link:hover, .cc-nav-link.active, .cc-nav-item.current-menu-item > .cc-nav-link {
  color: var(--text); background: hsl(0 0% 0% / 0.04);
}
.dark .cc-nav-link:hover, .dark .cc-nav-link.active,
.dark .cc-nav-item.current-menu-item > .cc-nav-link {
  background: hsl(0 0% 100% / 0.06);
}

.cc-nav-dropdown-toggle { cursor: pointer; }
.cc-dropdown-menu {
  position: absolute; top: calc(100% + 8px); left: 50%; transform: translateX(-50%) translateY(-4px);
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 0.5rem; width: 460px; box-shadow: var(--shadow-lg); z-index: 200;
  display: grid; grid-template-columns: 1fr 1fr; gap: 0.25rem;
  opacity: 0; pointer-events: none;
  transition: opacity 0.15s, transform 0.15s;
}
.cc-nav-has-dropdown:hover .cc-dropdown-menu,
.cc-dropdown-menu.open {
  opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0);
}
.cc-dropdown-item {
  display: flex; flex-direction: column; gap: 0.125rem;
  padding: 0.625rem 0.75rem; border-radius: 8px; color: var(--text);
  transition: background var(--transition); text-decoration: none;
}
.cc-dropdown-item:hover { background: hsl(42 70% 50% / 0.1); color: var(--text); }
.cc-dropdown-item strong { font-size: 0.85rem; font-weight: 600; }
.cc-dropdown-item span { font-size: 0.75rem; color: var(--text-muted); }
.cc-dropdown-all { grid-column: 1 / -1; color: var(--primary); font-size: 0.85rem; font-weight: 600; }

.cc-header-actions { display: flex; align-items: center; gap: 0.5rem; }
.cc-search-btn {
  display: none; align-items: center; gap: 0.5rem; padding: 0.4rem 0.75rem;
  border: 1px solid var(--border); border-radius: 8px; font-size: 0.85rem;
  color: var(--text-muted); background: transparent; transition: border-color var(--transition);
}
@media (min-width: 640px) { .cc-search-btn { display: flex; } }
.cc-search-btn:hover { border-color: var(--primary); color: var(--text); }
.cc-search-label { display: none; }
@media (min-width: 1024px) { .cc-search-label { display: inline; } }
.cc-search-btn kbd {
  display: none; font-size: 0.7rem; padding: 0.1rem 0.3rem;
  border: 1px solid var(--border); border-radius: 4px; background: var(--bg-muted);
  font-family: monospace;
}
@media (min-width: 1024px) { .cc-search-btn kbd { display: inline; } }

.cc-theme-toggle {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: 8px; color: var(--text-muted);
  transition: color var(--transition), background var(--transition);
  position: relative;
}
.cc-theme-toggle:hover { color: var(--primary); background: hsl(42 70% 50% / 0.1); }

/* Theme icon swap — light shows moon, dark shows sun */
.cc-icon-sun  { display: none; }
.cc-icon-moon { display: block; }
.dark .cc-icon-sun  { display: block; }
.dark .cc-icon-moon { display: none; }

.cc-mobile-menu-btn {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: 8px; color: var(--text-muted);
}
@media (min-width: 768px) { .cc-mobile-menu-btn { display: none; } }
.cc-mobile-menu-btn:hover { color: var(--primary); background: hsl(42 70% 50% / 0.1); }

/* ── Mobile drawer ───────────────────────────────────────────────────────── */
.cc-mobile-drawer {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 1000;
  width: min(320px, 90vw); background: var(--bg-card);
  padding: 1.5rem; transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto; border-left: 1px solid var(--border);
}
.cc-mobile-drawer:not([hidden]) { transform: translateX(0); }
.cc-mobile-nav-list { list-style: none; padding: 0; margin: 1rem 0 0; }
.cc-mobile-nav-list li a {
  display: block; padding: 0.75rem 0.875rem; border-radius: 8px;
  color: var(--text-muted); font-weight: 500;
  transition: color var(--transition), background var(--transition);
  text-decoration: none;
}
.cc-mobile-nav-list li a:hover { color: var(--primary); background: hsl(42 70% 50% / 0.1); }

.cc-drawer-close {
  position: absolute; top: 1rem; right: 1rem; width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center; border-radius: 6px;
  color: var(--text-muted);
}
.cc-drawer-close:hover { color: var(--text); background: hsl(0 0% 0% / 0.05); }
.dark .cc-drawer-close:hover { background: hsl(0 0% 100% / 0.05); }

.cc-overlay {
  position: fixed; inset: 0; background: hsl(0 0% 0% / 0.5);
  z-index: 999; opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
}
.cc-overlay.open { opacity: 1; pointer-events: auto; }

/* ── Search modal ────────────────────────────────────────────────────────── */
.cc-search-modal {
  position: fixed; inset: 0; z-index: 2000;
  background: hsl(0 0% 0% / 0.5); backdrop-filter: blur(4px);
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 10vh;
}
.cc-search-modal[hidden] { display: none; }
.cc-search-modal-inner {
  width: min(600px, 90vw); background: var(--bg-card);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; box-shadow: var(--shadow-lg);
}
.cc-search-bar {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.875rem 1rem; border-bottom: 1px solid var(--border);
}
.cc-search-bar svg { color: var(--text-muted); flex-shrink: 0; }
.cc-search-bar input {
  flex: 1; background: transparent; border: none; font-size: 1rem;
  color: var(--text); padding: 0;
}
.cc-search-bar input:focus { outline: none; box-shadow: none; }
.cc-search-bar button {
  font-size: 0.75rem; padding: 0.2rem 0.5rem; border: 1px solid var(--border);
  border-radius: 4px; color: var(--text-muted); background: var(--bg-muted);
}
.cc-search-results { max-height: 60vh; overflow-y: auto; padding: 0.5rem; }
.cc-search-result-item {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.625rem 0.75rem; border-radius: 8px; cursor: pointer;
  transition: background var(--transition); text-decoration: none; color: var(--text);
}
.cc-search-result-item:hover { background: hsl(42 70% 50% / 0.12); }
.cc-search-result-icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: hsl(42 70% 50% / 0.15); display: flex; align-items: center;
  justify-content: center; font-size: 1.25rem; flex-shrink: 0;
}
.cc-search-result-info strong { display: block; font-size: 0.9rem; font-weight: 600; }
.cc-search-result-info span { font-size: 0.8rem; color: var(--text-muted); }
.cc-search-empty { padding: 2rem; text-align: center; color: var(--text-muted); font-size: 0.9rem; }

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.cc-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  font-family: inherit; font-size: 0.9375rem; font-weight: 600;
  padding: 0.625rem 1.25rem; border-radius: var(--radius); cursor: pointer;
  transition: all var(--transition); text-decoration: none; border: 1px solid transparent;
  white-space: nowrap; letter-spacing: -0.01em;
}
.cc-btn-primary { background: var(--primary); color: var(--primary-fg); }
.cc-btn-primary:hover { background: var(--primary-dark); color: var(--primary-fg); transform: translateY(-1px); box-shadow: 0 4px 16px hsl(42 70% 50% / 0.3); }
.dark .cc-btn-primary:hover { background: var(--primary-light); }
.cc-btn-outline { background: transparent; color: var(--text); border-color: var(--border); }
.cc-btn-outline:hover { border-color: var(--primary); color: var(--primary); }
.cc-btn-ghost { background: transparent; color: var(--text-muted); }
.cc-btn-ghost:hover { color: var(--primary); background: hsl(42 70% 50% / 0.08); }
.cc-btn-lg { padding: 0.875rem 1.75rem; font-size: 1.0625rem; }
.cc-btn-sm { padding: 0.375rem 0.875rem; font-size: 0.8125rem; }
.cc-btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* ── Cards ───────────────────────────────────────────────────────────────── */
.cc-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.cc-card:hover { border-color: hsl(42 70% 50% / 0.4); box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.cc-card-body { padding: 1.25rem; }

/* Tool card */
.cc-tool-card { text-decoration: none; display: block; color: inherit; }
.cc-tool-card-inner { padding: 1.25rem; display: flex; flex-direction: column; gap: 0.75rem; height: 100%; }
.cc-tool-card-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 0.75rem; }
.cc-tool-icon {
  width: 48px; height: 48px; border-radius: 12px; flex-shrink: 0;
  background: hsl(42 70% 50% / 0.15); display: flex; align-items: center;
  justify-content: center; font-size: 1.5rem;
}
.cc-tool-badges { display: flex; gap: 0.375rem; flex-wrap: wrap; }
.cc-badge {
  display: inline-flex; align-items: center; gap: 0.25rem;
  font-size: 0.7rem; font-weight: 600; padding: 0.2rem 0.5rem;
  border-radius: 999px; border: 1px solid; letter-spacing: 0.03em; text-transform: uppercase;
}
.cc-badge-popular {  background: hsl(42 70% 50% / 0.15);  border-color: hsl(42 70% 50% / 0.4);  color: hsl(42 70% 35%); }
.dark .cc-badge-popular { color: hsl(42 70% 65%); }
.cc-badge-trending { background: hsl(0 70% 50% / 0.12);  border-color: hsl(0 70% 50% / 0.35); color: hsl(0 70% 45%); }
.dark .cc-badge-trending { color: hsl(0 70% 65%); }
.cc-badge-new      { background: hsl(140 50% 40% / 0.12); border-color: hsl(140 50% 40% / 0.35); color: hsl(140 40% 30%); }
.dark .cc-badge-new { color: hsl(140 40% 60%); }
.cc-badge-category { background: hsl(42 70% 50% / 0.1);  border-color: hsl(42 70% 50% / 0.3);  color: hsl(42 70% 35%); }
.dark .cc-badge-category { color: hsl(42 70% 65%); }

.cc-tool-name { font-family: var(--font-serif); font-size: 1.1rem; font-weight: 700; margin-bottom: 0.25rem; color: var(--text); }
.cc-tool-desc { font-size: 0.85rem; color: var(--text-muted); line-height: 1.5; flex: 1; }
.cc-tool-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 0.75rem; border-top: 1px solid var(--border);
  font-size: 0.8rem; color: var(--text-subtle);
}
.cc-tool-card-cta { font-size: 0.8rem; color: var(--primary); font-weight: 600; }

/* ── Hero ────────────────────────────────────────────────────────────────── */
.cc-hero {
  position: relative; padding: 5rem 0 6rem; text-align: center; overflow: hidden;
}
.cc-hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background: radial-gradient(ellipse 80% 60% at 50% -20%, hsl(42 70% 60% / 0.15) 0%, transparent 70%);
}
.dark .cc-hero-bg {
  background: radial-gradient(ellipse 80% 60% at 50% -20%, hsl(42 70% 60% / 0.2) 0%, transparent 70%),
              radial-gradient(circle at 0% 100%, hsl(230 40% 20% / 0.4) 0%, transparent 50%),
              radial-gradient(circle at 100% 100%, hsl(280 40% 20% / 0.3) 0%, transparent 50%);
}
.cc-hero-content { position: relative; z-index: 1; max-width: 860px; margin: 0 auto; }

.cc-badge-pill {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.375rem 1rem; border-radius: 999px;
  border: 1px solid hsl(42 70% 50% / 0.3);
  background: hsl(42 70% 50% / 0.1); font-size: 0.875rem; font-weight: 500;
  color: var(--primary); margin-bottom: 1.5rem;
}

.cc-h1 {
  font-family: var(--font-serif); font-size: clamp(2.25rem, 6vw, 4.5rem);
  font-weight: 800; line-height: 1.1; letter-spacing: -0.03em;
  margin-bottom: 1.25rem; color: var(--heading);
}
.cc-hero-sub {
  font-size: clamp(1rem, 2.5vw, 1.25rem); color: var(--text-muted);
  max-width: 600px; margin: 0 auto 2.5rem; line-height: 1.65;
}
.cc-hero-ctas { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; margin-bottom: 3rem; }
.cc-hero-stats { display: flex; flex-wrap: wrap; gap: 1.5rem 2.5rem; justify-content: center; }
.cc-hero-stat { display: flex; align-items: center; gap: 0.5rem; color: var(--text-muted); font-size: 0.9rem; }
.cc-hero-stat strong { color: var(--text); font-weight: 700; }

/* ── Sections ────────────────────────────────────────────────────────────── */
.cc-section { margin-bottom: 5rem; padding: 0 1rem; }
.cc-section-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: 2rem; gap: 1rem; flex-wrap: wrap;
}
.cc-section-header--center { flex-direction: column; align-items: center; text-align: center; }
.cc-section-header--center .cc-section-sub { max-width: 560px; }
.cc-section-title { font-family: var(--font-serif); font-size: clamp(1.5rem, 3vw, 2rem); font-weight: 700; margin-bottom: 0.375rem; color: var(--heading); }
.cc-section-sub { color: var(--text-muted); font-size: 0.95rem; max-width: 500px; }

.cc-grid-3 { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 640px)  { .cc-grid-3 { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cc-grid-3 { grid-template-columns: 1fr 1fr 1fr; } }
.cc-grid-4 { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 640px)  { .cc-grid-4 { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cc-grid-4 { grid-template-columns: 1fr 1fr 1fr 1fr; } }
.cc-grid-2 { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 640px)  { .cc-grid-2 { grid-template-columns: 1fr 1fr; } }

/* ── Category card ───────────────────────────────────────────────────────── */
.cc-cat-card {
  padding: 1.75rem; border-radius: var(--radius-lg); border: 1px solid var(--border);
  background: var(--bg-card); text-decoration: none; display: block;
  transition: all var(--transition);
}
.cc-cat-card:hover { border-color: hsl(42 70% 50% / 0.4); transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.cc-cat-icon { font-size: 2.5rem; margin-bottom: 1rem; display: block; }
.cc-cat-name { font-family: var(--font-serif); font-size: 1.125rem; font-weight: 700; margin-bottom: 0.5rem; color: var(--text); }
.cc-cat-desc { font-size: 0.85rem; color: var(--text-muted); line-height: 1.55; margin-bottom: 0.75rem; }
.cc-cat-count { font-size: 0.8rem; color: var(--primary); font-weight: 600; }

/* ── Trust section ───────────────────────────────────────────────────────── */
.cc-trust {
  background: hsl(42 70% 50% / 0.04); border: 1px solid hsl(42 70% 50% / 0.15);
  border-radius: var(--radius-lg); padding: 2.5rem; text-align: center; margin-bottom: 5rem;
}
.cc-trust-title { font-family: var(--font-serif); font-size: 1.75rem; font-weight: 700; margin-bottom: 0.75rem; color: var(--heading); }
.cc-trust-sub { color: var(--text-muted); max-width: 540px; margin: 0 auto 2.5rem; }
.cc-trust-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media (min-width: 640px) { .cc-trust-grid { grid-template-columns: 1fr 1fr 1fr; } }
.cc-trust-item h3 { font-weight: 600; margin-bottom: 0.5rem; font-size: 0.95rem; color: var(--text); }
.cc-trust-item p { font-size: 0.85rem; color: var(--text-muted); line-height: 1.6; }

/* ── Ad slot ─────────────────────────────────────────────────────────────── */
.cc-ad {
  width: 100%; border-radius: var(--radius-lg); overflow: hidden; margin: 2rem 0;
  min-height: 90px; border: 1px dashed var(--border);
  background: hsl(0 0% 0% / 0.02);
  display: flex; align-items: center; justify-content: center;
}
.dark .cc-ad { background: hsl(0 0% 100% / 0.02); }
.cc-ad-label { font-size: 0.65rem; color: var(--text-subtle); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; }
.cc-ad--between-sections { max-width: 900px; margin: 0 auto 2rem; }
.cc-ad--bottom { margin-top: 2rem; }

/* ── Tool page ───────────────────────────────────────────────────────────── */
.cc-tool-page { max-width: 860px; margin: 0 auto; padding: 2rem 1rem 4rem; }
.cc-tool-header { margin-bottom: 2rem; }
.cc-tool-title { font-family: var(--font-serif); font-size: clamp(2rem, 5vw, 3.25rem); font-weight: 800; line-height: 1.15; margin-bottom: 0.75rem; color: var(--heading); }
.cc-tool-subtitle { font-size: 1.1rem; color: var(--text-muted); }
.cc-calculator-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 1.75rem; margin-bottom: 2.5rem;
  box-shadow: var(--shadow);
}
.cc-form-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 640px) { .cc-form-grid { grid-template-columns: 1fr 1fr; } }
.cc-form-group { display: flex; flex-direction: column; gap: 0.375rem; }
.cc-form-group.full { grid-column: 1 / -1; }
.cc-form-hint { font-size: 0.78rem; color: var(--text-subtle); margin-top: 0.25rem; }

/* ── Result display ──────────────────────────────────────────────────────── */
.cc-result { display: none; margin-top: 1.5rem; }
.cc-result.show { display: block; }
.cc-result-header {
  background: linear-gradient(135deg, hsl(42 70% 50% / 0.12), hsl(42 70% 60% / 0.06));
  border: 1px solid hsl(42 70% 50% / 0.25); border-radius: var(--radius-lg);
  padding: 1.75rem; margin-bottom: 1.25rem; position: relative; overflow: hidden;
}
.cc-result-badge {
  display: inline-block; font-size: 0.7rem; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; padding: 0.25rem 0.75rem; border-radius: 999px;
  background: hsl(42 70% 50% / 0.2); color: var(--primary); margin-bottom: 0.875rem;
}
.cc-result-title {
  font-family: var(--font-serif); font-size: clamp(1.5rem, 4vw, 2.25rem);
  font-weight: 800; margin-bottom: 0.5rem; color: var(--heading);
}
.cc-result-subtitle { font-size: 0.9rem; color: var(--text-muted); margin-bottom: 1rem; }
.cc-result-desc { color: var(--text-muted); line-height: 1.7; font-size: 0.95rem; }
.cc-metrics { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 0.75rem; margin-top: 1.25rem; }
.cc-metric { background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px; padding: 0.75rem; }
.cc-metric-label { font-size: 0.7rem; color: var(--text-subtle); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.25rem; }
.cc-metric-value { font-size: 0.9rem; font-weight: 700; color: var(--text); }
.cc-result-sections { display: flex; flex-direction: column; gap: 1rem; }
.cc-result-section { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.cc-result-section-head {
  width: 100%; padding: 0.875rem 1.125rem; font-weight: 600; font-size: 0.9rem;
  border-bottom: 1px solid var(--border); background: transparent;
  cursor: pointer; display: flex; justify-content: space-between; align-items: center;
  text-align: left; color: var(--text);
}
.cc-result-section-head .cc-chevron { transition: transform 0.2s; flex-shrink: 0; }
.cc-result-section-head.open .cc-chevron { transform: rotate(180deg); }
.cc-result-section-body { padding: 1.125rem; font-size: 0.9rem; line-height: 1.7; color: var(--text-muted); }
.cc-result-section-body ul { list-style: none; display: flex; flex-direction: column; gap: 0.5rem; padding: 0; }
.cc-result-section-body li { display: flex; gap: 0.625rem; }
.cc-result-section-body li::before { content: '•'; color: var(--primary); flex-shrink: 0; margin-top: 0.1rem; }
.cc-result-section-body blockquote {
  border-left: 3px solid var(--primary); padding: 0.75rem 1rem;
  background: hsl(42 70% 50% / 0.06); border-radius: 0 8px 8px 0;
  font-style: italic;
}

/* ── Blog ────────────────────────────────────────────────────────────────── */
.cc-blog-card { text-decoration: none; display: block; color: inherit; }
.cc-blog-thumb { height: 200px; overflow: hidden; position: relative; }
.cc-blog-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.cc-blog-card:hover .cc-blog-thumb img { transform: scale(1.05); }
.cc-blog-cat-badge {
  position: absolute; top: 0.75rem; left: 0.75rem;
  background: hsl(0 0% 0% / 0.6); backdrop-filter: blur(4px); color: #fff;
  font-size: 0.7rem; font-weight: 600; padding: 0.25rem 0.625rem; border-radius: 999px;
  text-transform: uppercase; letter-spacing: 0.05em;
}
.cc-blog-body { padding: 1.25rem; }
.cc-blog-meta { font-size: 0.78rem; color: var(--text-subtle); margin-bottom: 0.5rem; }
.cc-blog-title { font-family: var(--font-serif); font-size: 1.125rem; font-weight: 700; margin-bottom: 0.5rem; line-height: 1.4; color: var(--text); }
.cc-blog-card:hover .cc-blog-title { color: var(--primary); }
.cc-blog-excerpt {
  font-size: 0.85rem; color: var(--text-muted); line-height: 1.55; margin-bottom: 0.875rem;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.cc-blog-cta { font-size: 0.82rem; color: var(--primary); font-weight: 600; }

/* ── Single post ─────────────────────────────────────────────────────────── */
.cc-post-header { margin-bottom: 2rem; }
.cc-post-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 0.5rem; font-size: 0.85rem; color: var(--text-muted); margin-bottom: 1rem; }
.cc-post-title { font-family: var(--font-serif); font-size: clamp(2rem, 5vw, 3rem); font-weight: 800; line-height: 1.15; margin-bottom: 1rem; color: var(--heading); }
.cc-post-excerpt { font-size: 1.1rem; color: var(--text-muted); line-height: 1.7; margin-bottom: 1.5rem; }
.cc-post-hero-img { border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 1.5rem; }
.cc-post-hero-img img { width: 100%; height: auto; display: block; }
.cc-post-tags { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--border); }
.cc-post-content { margin-top: 1.5rem; }
.cc-post-nav { display: flex; gap: 1rem; margin-top: 2rem; padding-top: 2rem; border-top: 1px solid var(--border); }
.cc-post-nav a {
  flex: 1; padding: 1rem; border: 1px solid var(--border); border-radius: var(--radius);
  display: flex; flex-direction: column; gap: 0.25rem; transition: border-color var(--transition);
  text-decoration: none; color: var(--text);
}
.cc-post-nav a:hover { border-color: var(--primary); }
.cc-post-nav-label { font-size: 0.75rem; color: var(--text-subtle); text-transform: uppercase; letter-spacing: 0.05em; }
.cc-post-nav-title { font-weight: 600; font-size: 0.95rem; }

/* ── Breadcrumbs ─────────────────────────────────────────────────────────── */
.cc-breadcrumbs {
  display: flex; align-items: center; flex-wrap: wrap; gap: 0.375rem;
  font-size: 0.82rem; color: var(--text-subtle); margin-bottom: 1.5rem; padding-top: 1.5rem;
}
.cc-breadcrumbs a { color: var(--text-subtle); text-decoration: none; }
.cc-breadcrumbs a:hover { color: var(--primary); }
.cc-breadcrumbs-sep { color: var(--border); }

/* ── Accordion (FAQ) ─────────────────────────────────────────────────────── */
.cc-faq-list { margin-top: 1rem; }
.cc-accordion-item { border-bottom: 1px solid var(--border); }
.cc-accordion-trigger {
  width: 100%; text-align: left; padding: 1rem 0; font-weight: 500; font-size: 0.95rem;
  display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  color: var(--text); background: none; border: none; cursor: pointer;
}
.cc-accordion-trigger:hover { color: var(--primary); }
.cc-accordion-trigger .cc-chevron { flex-shrink: 0; transition: transform 0.2s; color: var(--text-subtle); }
.cc-accordion-trigger[aria-expanded="true"] .cc-chevron { transform: rotate(180deg); }
.cc-accordion-content { padding: 0 0 1rem; font-size: 0.9rem; color: var(--text-muted); line-height: 1.7; }
.cc-accordion-content[hidden] { display: none; }

/* ── Prose (blog body, legal pages) ──────────────────────────────────────── */
.cc-prose { max-width: 720px; }
.cc-prose h1 { font-family: var(--font-serif); font-size: clamp(2rem, 5vw, 3rem); font-weight: 800; line-height: 1.15; margin-bottom: 1rem; color: var(--heading); }
.cc-prose h2 { font-family: var(--font-serif); font-size: 1.5rem; font-weight: 700; margin-top: 2.5rem; margin-bottom: 0.875rem; color: var(--heading); }
.cc-prose h3 { font-size: 1.15rem; font-weight: 600; margin-top: 1.75rem; margin-bottom: 0.625rem; color: var(--text); }
.cc-prose p { color: var(--text-muted); line-height: 1.75; margin-bottom: 1.125rem; font-size: 0.975rem; }
.cc-prose ul, .cc-prose ol { color: var(--text-muted); padding-left: 1.5rem; margin-bottom: 1.25rem; display: flex; flex-direction: column; gap: 0.5rem; }
.cc-prose li { line-height: 1.65; font-size: 0.975rem; }
.cc-prose blockquote {
  border-left: 3px solid var(--primary); padding: 1rem 1.25rem;
  background: hsl(42 70% 50% / 0.06); border-radius: 0 8px 8px 0;
  font-style: italic; color: var(--text); margin: 1.5rem 0;
}
.cc-prose a { color: var(--primary); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 2px; }
.cc-prose a:hover { color: var(--primary-dark); }
.dark .cc-prose a:hover { color: var(--primary-light); }
.cc-prose strong { color: var(--text); }
.cc-prose .lead { font-size: 1.125rem; color: var(--text-muted); line-height: 1.75; margin-bottom: 2rem; }

/* ── Page hero ───────────────────────────────────────────────────────────── */
.cc-page-hero { padding: 3rem 0 2rem; text-align: center; margin-bottom: 2rem; }
.cc-page-title { font-family: var(--font-serif); font-size: clamp(2rem, 5vw, 3.25rem); font-weight: 800; margin-bottom: 0.75rem; color: var(--heading); }
.cc-page-subtitle { color: var(--text-muted); font-size: 1.1rem; max-width: 600px; margin: 0 auto; }

/* ── Category page hero ──────────────────────────────────────────────────── */
.cc-cat-hero {
  background: hsl(42 70% 50% / 0.05); border: 1px solid hsl(42 70% 50% / 0.15);
  border-radius: var(--radius-lg); padding: 2.5rem; text-align: center; margin-bottom: 3rem;
}
.cc-cat-hero-icon { font-size: 3rem; margin-bottom: 0.75rem; display: block; }
.cc-cat-hero h1 { font-family: var(--font-serif); font-size: clamp(1.75rem, 5vw, 2.75rem); font-weight: 800; margin-bottom: 0.75rem; color: var(--heading); }
.cc-cat-hero p { color: var(--text-muted); max-width: 600px; margin: 0 auto; line-height: 1.7; }
.cc-cat-hero-count { font-size: 0.85rem; color: var(--text-subtle); margin-top: 0.75rem; }

/* ── Tabs ────────────────────────────────────────────────────────────────── */
.cc-tabs { margin-bottom: 2rem; }
.cc-tabs-list {
  display: flex; gap: 0; overflow-x: auto; scrollbar-width: none;
  border-bottom: 1px solid var(--border); padding-bottom: 0;
  -webkit-overflow-scrolling: touch;
}
.cc-tabs-list::-webkit-scrollbar { display: none; }
.cc-tab-btn {
  padding: 0.75rem 1rem; font-size: 0.9rem; font-weight: 500; white-space: nowrap;
  color: var(--text-muted); background: none; border: none; cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: color var(--transition), border-color var(--transition);
  margin-bottom: -1px;
}
.cc-tab-btn:hover { color: var(--text); }
.cc-tab-btn.active { color: var(--primary); border-bottom-color: var(--primary); }
.cc-tab-panel[hidden] { display: none; }

/* ── Footer ──────────────────────────────────────────────────────────────── */
.cc-footer {
  border-top: 1px solid var(--border);
  background: var(--bg-card);
  margin-top: 5rem; padding: 3.5rem 0 2rem;
}
.cc-footer-grid {
  display: grid; grid-template-columns: 1fr; gap: 2.5rem;
  margin-bottom: 2.5rem;
}
@media (min-width: 640px)  { .cc-footer-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cc-footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; } }
.cc-footer-desc { font-size: 0.875rem; color: var(--text-muted); margin: 0.875rem 0 0.5rem; line-height: 1.6; }
.cc-footer-disclaimer { font-size: 0.78rem; color: var(--text-subtle); }
.cc-footer-col h4 { font-weight: 600; font-size: 0.875rem; margin-bottom: 1rem; color: var(--text); font-family: var(--font-sans); }
.cc-footer-col ul, .cc-footer-links { list-style: none; display: flex; flex-direction: column; gap: 0.625rem; padding: 0; margin: 0; }
.cc-footer-col a, .cc-footer-links a { font-size: 0.875rem; color: var(--text-muted); text-decoration: none; }
.cc-footer-col a:hover, .cc-footer-links a:hover { color: var(--primary); }
.cc-footer-bottom {
  border-top: 1px solid var(--border); padding-top: 1.5rem;
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: 0.5rem;
  font-size: 0.8rem; color: var(--text-subtle);
}

/* ── Page article ────────────────────────────────────────────────────────── */
.cc-page { padding: 0 0 4rem; }
.cc-page-article { margin-top: 1rem; }
.cc-page-content-wrapper { max-width: 820px; margin: 0 auto; }
.cc-page-hero--inline { padding: 2rem 0 1.5rem; text-align: left; margin-bottom: 1rem; }
.cc-page-hero--inline .cc-page-title { text-align: left; }
.cc-page-hero--inline .cc-page-subtitle { color: var(--text-muted); font-size: 1.1rem; line-height: 1.65; max-width: 720px; }
.cc-page-hero-img { border-radius: var(--radius-lg); overflow: hidden; margin: 1.5rem 0 2rem; }

/* ── Contact form ────────────────────────────────────────────────────────── */
.cc-contact-form-wrap { max-width: 640px; margin: 1.5rem auto 0; }
.cc-topic-cards { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0.75rem; margin-bottom: 2rem; }
.cc-topic-card {
  padding: 0.875rem; border: 1px solid var(--border); border-radius: var(--radius);
  text-align: center; background: var(--bg-card);
}
.cc-topic-card svg { color: var(--primary); margin: 0 auto 0.375rem; }
.cc-topic-card span { font-size: 0.78rem; font-weight: 500; color: var(--text-muted); display: block; }
.cc-contact-form { display: flex; flex-direction: column; gap: 1.125rem; margin-top: 1.5rem; }
.cc-form-row { display: grid; grid-template-columns: 1fr; gap: 1.125rem; }
@media (min-width: 480px) { .cc-form-row { grid-template-columns: 1fr 1fr; } }
.cc-contact-success {
  background: hsl(140 50% 50% / 0.1); border: 1px solid hsl(140 50% 50% / 0.3);
  border-radius: var(--radius); padding: 1rem 1.25rem; margin-bottom: 1.5rem;
  display: flex; align-items: center; gap: 0.625rem; color: hsl(140 50% 35%);
}
.dark .cc-contact-success { color: hsl(140 50% 65%); }
.cc-contact-error {
  background: hsl(0 70% 50% / 0.1); border: 1px solid hsl(0 70% 50% / 0.3);
  border-radius: var(--radius); padding: 1rem 1.25rem; margin-bottom: 1.5rem; color: hsl(0 70% 45%);
}

/* ── Empty state ─────────────────────────────────────────────────────────── */
.cc-empty { text-align: center; padding: 3rem 1rem; color: var(--text-muted); }

/* ── Pagination ──────────────────────────────────────────────────────────── */
.cc-pagination { display: flex; justify-content: center; margin: 3rem 0; }
.cc-pagination .nav-links { display: flex; gap: 0.5rem; align-items: center; }
.cc-pagination .page-numbers {
  padding: 0.5rem 0.875rem; border-radius: var(--radius); border: 1px solid var(--border);
  background: var(--bg-card); color: var(--text-muted); font-size: 0.9rem;
  transition: all var(--transition); text-decoration: none;
}
.cc-pagination .page-numbers:hover, .cc-pagination .page-numbers.current {
  background: var(--primary); color: var(--primary-fg); border-color: var(--primary);
}

/* ── Input error ─────────────────────────────────────────────────────────── */
.cc-input-error { border-color: hsl(0 70% 50%) !important; box-shadow: 0 0 0 3px hsl(0 70% 50% / 0.2) !important; }

/* ── Spinner ─────────────────────────────────────────────────────────────── */
.cc-spinner {
  width: 18px; height: 18px; border: 2px solid var(--border);
  border-top-color: var(--primary); border-radius: 50%;
  animation: cc-spin 0.7s linear infinite; display: inline-block;
}
@keyframes cc-spin { to { transform: rotate(360deg); } }

/* ── Utilities ───────────────────────────────────────────────────────────── */
.cc-mt-2 { margin-top: 2rem; }
.cc-mt-3 { margin-top: 3rem; }

/* Sidebar */
.cc-sidebar { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--border); }

/* Comments */
.cc-comments { padding-top: 2rem; border-top: 1px solid var(--border); }

/* Mobile responsive */
@media (max-width: 640px) {
  .cc-hero { padding: 3rem 0 4rem; }
  .cc-footer-grid { gap: 2rem; }
  .cc-tool-page { padding: 1rem 1rem 3rem; }
  .cc-section { padding: 0 0.5rem; }
}

/* Scroll animations */
.cc-animate { opacity: 0; transform: translateY(16px); transition: opacity 0.4s ease, transform 0.4s ease; }
.cc-animate.cc-visible { opacity: 1; transform: translateY(0); }
