/*
Theme Name: Blindspots
Template: twentytwentyfour
Version: 1.0
Description: Custom child theme for blindspots.in - professional resume and compliance blog
Author: Sanjay
*/

:root {
  --bs-ink: #1a1d23;
  --bs-ink-soft: #4a4f58;
  --bs-ink-faint: #8b8f99;
  --bs-paper: #ffffff;
  --bs-paper-soft: #f6f6f4;
  --bs-line: #e3e3e0;
  --bs-accent: #185fa5;
  --bs-accent-bg: #e6f1fb;
  --bs-accent-text: #0c447c;
  --bs-radius: 10px;
}

@media (prefers-color-scheme: dark) {
  :root {
    --bs-ink: #f1f1ee;
    --bs-ink-soft: #b4b2a9;
    --bs-ink-faint: #888780;
    --bs-paper: #1c1c1a;
    --bs-paper-soft: #242422;
    --bs-line: #3a3a37;
    --bs-accent: #85b7eb;
    --bs-accent-bg: #042c53;
    --bs-accent-text: #b5d4f4;
  }
}

body {
  background: var(--bs-paper);
  color: var(--bs-ink);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
}

a { color: var(--bs-accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---------- Site header ---------- */
.bs-header {
  max-width: 920px;
  margin: 0 auto;
  padding: 24px 24px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--bs-line);
}

.bs-header .bs-brand {
  font-size: 16px;
  font-weight: 600;
  color: var(--bs-ink);
}

.bs-header .bs-brand span {
  color: var(--bs-ink-faint);
  font-weight: 400;
  margin-left: 6px;
}

.bs-nav {
  display: flex;
  gap: 28px;
  font-size: 14px;
}

.bs-nav a {
  color: var(--bs-ink-soft);
}

.bs-nav a.bs-active,
.bs-nav a:hover {
  color: var(--bs-ink);
}

/* ---------- Hero (homepage) ---------- */
.bs-hero {
  max-width: 920px;
  margin: 0 auto;
  padding: 56px 24px 40px;
  border-bottom: 1px solid var(--bs-line);
}

.bs-eyebrow {
  font-size: 13px;
  color: var(--bs-accent);
  letter-spacing: 0.03em;
  margin-bottom: 10px;
}

.bs-hero h1 {
  font-size: 34px;
  font-weight: 600;
  line-height: 1.3;
  margin: 0 0 16px;
  max-width: 620px;
}

.bs-hero p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--bs-ink-soft);
  max-width: 560px;
  margin: 0 0 24px;
}

.bs-btn-row { display: flex; gap: 12px; }

.bs-btn {
  display: inline-block;
  padding: 11px 20px;
  border-radius: var(--bs-radius);
  font-size: 14px;
  font-weight: 500;
  border: 1px solid var(--bs-line);
}

.bs-btn-primary {
  background: var(--bs-ink);
  color: var(--bs-paper);
  border-color: var(--bs-ink);
}

.bs-btn-primary:hover { opacity: 0.9; text-decoration: none; }
.bs-btn-secondary { color: var(--bs-ink); }
.bs-btn-secondary:hover { background: var(--bs-paper-soft); text-decoration: none; }

/* ---------- Focus area cards ---------- */
.bs-focus-section {
  max-width: 920px;
  margin: 0 auto;
  padding: 40px 24px;
  border-bottom: 1px solid var(--bs-line);
}

.bs-section-label {
  font-size: 13px;
  color: var(--bs-ink-faint);
  margin-bottom: 18px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.bs-focus-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.bs-focus-card {
  background: var(--bs-paper-soft);
  border-radius: 12px;
  padding: 18px;
}

.bs-focus-card .bs-icon {
  font-size: 22px;
  color: var(--bs-accent);
  margin-bottom: 10px;
  display: block;
  font-style: normal;
}

.bs-focus-card h3 {
  font-size: 14px;
  font-weight: 600;
  margin: 0 0 4px;
}

.bs-focus-card p {
  font-size: 13px;
  color: var(--bs-ink-soft);
  margin: 0;
  line-height: 1.5;
}

@media (max-width: 700px) {
  .bs-focus-grid { grid-template-columns: 1fr; }
}

/* ---------- Recent posts list ---------- */
.bs-recent {
  max-width: 920px;
  margin: 0 auto;
  padding: 40px 24px 56px;
}

.bs-recent-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 16px;
}

.bs-recent-header a { font-size: 13px; }

.bs-post-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 0;
  border-bottom: 1px solid var(--bs-line);
}

.bs-post-row:last-child { border-bottom: none; }

.bs-tag {
  font-size: 12px;
  padding: 3px 10px;
  border-radius: 6px;
  margin-right: 10px;
  background: var(--bs-accent-bg);
  color: var(--bs-accent-text);
  font-weight: 500;
}

.bs-post-title { font-size: 14px; color: var(--bs-ink); }
.bs-post-meta { font-size: 13px; color: var(--bs-ink-faint); white-space: nowrap; }

/* ---------- Documentation layout (compliance section) ---------- */
.bs-docs-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 32px 24px 64px;
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  gap: 0;
  align-items: start;
}

.bs-docs-sidebar {
  background: var(--bs-paper-soft);
  border-radius: 12px;
  padding: 20px 16px;
  position: sticky;
  top: 24px;
}

.bs-docs-sidebar .bs-section-label {
  margin-bottom: 14px;
}

.bs-cat-group { margin-bottom: 6px; }

.bs-cat-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 8px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  color: var(--bs-ink-soft);
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  font-family: inherit;
}

.bs-cat-toggle:hover { background: var(--bs-paper); }

.bs-cat-toggle.bs-cat-open {
  background: var(--bs-accent-bg);
  color: var(--bs-accent-text);
}

.bs-cat-toggle .bs-chevron {
  font-size: 14px;
  transition: transform 0.15s ease;
  display: inline-block;
}

.bs-cat-toggle.bs-cat-open .bs-chevron { transform: rotate(90deg); }

.bs-cat-posts {
  padding-left: 22px;
  margin-top: 2px;
  display: none;
}

.bs-cat-posts.bs-cat-open { display: block; }

.bs-cat-posts a {
  display: block;
  font-size: 13px;
  color: var(--bs-ink-soft);
  padding: 6px 0 6px 10px;
  border-left: 2px solid transparent;
}

.bs-cat-posts a:hover {
  color: var(--bs-ink);
  text-decoration: none;
}

.bs-cat-posts a.bs-post-active {
  color: var(--bs-accent-text);
  background: var(--bs-accent-bg);
  border-left-color: var(--bs-accent);
  font-weight: 500;
  border-radius: 0 6px 6px 0;
}

.bs-docs-content {
  padding: 4px 0 4px 40px;
}

.bs-docs-content .bs-breadcrumb {
  font-size: 12px;
  color: var(--bs-ink-faint);
  margin: 0 0 8px;
}

.bs-docs-content h1 {
  font-size: 24px;
  font-weight: 600;
  margin: 0 0 8px;
}

.bs-docs-content .bs-post-date {
  font-size: 13px;
  color: var(--bs-ink-faint);
  margin: 0 0 24px;
}

.bs-docs-content .bs-entry-body {
  font-size: 16px;
  line-height: 1.75;
  color: var(--bs-ink-soft);
  max-width: 680px;
}

.bs-docs-content .bs-entry-body p { margin: 0 0 18px; }
.bs-docs-content .bs-entry-body h2 { font-size: 19px; font-weight: 600; color: var(--bs-ink); margin: 32px 0 12px; }
.bs-docs-content .bs-entry-body h3 { font-size: 16px; font-weight: 600; color: var(--bs-ink); margin: 24px 0 10px; }
.bs-docs-content .bs-entry-body ul, .bs-docs-content .bs-entry-body ol { margin: 0 0 18px; padding-left: 22px; }
.bs-docs-content .bs-entry-body code {
  background: var(--bs-paper-soft);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 14px;
}

@media (max-width: 800px) {
  .bs-docs-wrap { grid-template-columns: 1fr; }
  .bs-docs-sidebar { position: static; margin-bottom: 24px; }
  .bs-docs-content { padding-left: 0; }
}

/* ---------- Simple content pages (About / Experience / Contact) ---------- */
.bs-simple-page {
  max-width: 680px;
  margin: 0 auto;
  padding: 56px 24px 64px;
}

.bs-simple-page h1 {
  font-size: 28px;
  font-weight: 600;
  margin: 0 0 28px;
}

.bs-simple-page .bs-entry-body {
  font-size: 16px;
  line-height: 1.75;
  color: var(--bs-ink-soft);
}

.bs-simple-page .bs-entry-body p { margin: 0 0 18px; }
.bs-simple-page .bs-entry-body h2 { font-size: 20px; font-weight: 600; color: var(--bs-ink); margin: 36px 0 12px; }
.bs-simple-page .bs-entry-body h3 { font-size: 16px; font-weight: 600; color: var(--bs-ink); margin: 26px 0 10px; }
.bs-simple-page .bs-entry-body ul, .bs-simple-page .bs-entry-body ol { margin: 0 0 18px; padding-left: 22px; }
.bs-simple-page .bs-entry-body li { margin-bottom: 6px; }
.bs-simple-page .bs-entry-body strong { color: var(--bs-ink); font-weight: 600; }
.bs-simple-page .bs-entry-body a { text-decoration: underline; }

/* ---------- Footer ---------- */
.bs-footer {
  max-width: 920px;
  margin: 0 auto;
  padding: 32px 24px;
  border-top: 1px solid var(--bs-line);
  font-size: 13px;
  color: var(--bs-ink-faint);
  display: flex;
  justify-content: space-between;
}
