/*
Theme Name:   StartupDB Child
Theme URI:    https://startupdb.net
Description:  StartupDB child theme. Parent: GeneratePress. State-aware color theming,
              law entry / town rule / distributor single templates, dark mode support.
Author:       iamtmib
Version:      1.0.0
Template:     generatepress
Text Domain:  startupdb-child
*/

/* ── Import parent theme ────────────────────────────────────────────────── */
@import url("../generatepress/style.css");

/* ═══════════════════════════════════════════════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════════════════════════════════════════════ */
:root {
    /* Brand */
    --sdbc-navy:     #1b3a6b;
    --sdbc-blue:     #2563eb;
    --sdbc-blue-lt:  #dbeafe;
    --sdbc-teal:     #0f766e;
    --sdbc-amber:    #b45309;
    --sdbc-red:      #b91c1c;
    --sdbc-green:    #15803d;

    /* Neutrals */
    --sdbc-gray-900: #111827;
    --sdbc-gray-700: #374151;
    --sdbc-gray-500: #6b7280;
    --sdbc-gray-300: #d1d5db;
    --sdbc-gray-100: #f3f4f6;
    --sdbc-white:    #ffffff;

    /* Layout */
    --sdbc-radius:   8px;
    --sdbc-radius-lg:12px;

    /* State accent (overridden per state via body class) */
    --sdbc-accent:   var(--sdbc-blue);
    --sdbc-accent-lt:var(--sdbc-blue-lt);
}

/* ── Per-state accent colors ─────────────────────────────────────────────── */
body.sdbc-state-nh { --sdbc-accent: #1b5e3b; --sdbc-accent-lt: #d1fae5; } /* NH green */
body.sdbc-state-ma { --sdbc-accent: #7c1616; --sdbc-accent-lt: #fee2e2; } /* MA cranberry */
body.sdbc-state-me { --sdbc-accent: #1e3a5f; --sdbc-accent-lt: #dbeafe; } /* ME navy */
body.sdbc-state-ny { --sdbc-accent: #1a237e; --sdbc-accent-lt: #e8eaf6; } /* NY blue */
body.sdbc-state-fl { --sdbc-accent: #e65100; --sdbc-accent-lt: #fff3e0; } /* FL orange */

/* ═══════════════════════════════════════════════════════════════════════════
   GLOBAL OVERRIDES
═══════════════════════════════════════════════════════════════════════════ */
body { color: var(--sdbc-gray-700); }

a { color: var(--sdbc-accent); }
a:hover { color: var(--sdbc-navy); }

.site-header {
    border-bottom: 4px solid var(--sdbc-accent);
}

/* State name badge in header */
.sdbc-state-badge {
    display: inline-block;
    background: var(--sdbc-accent);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 3px 10px;
    border-radius: 20px;
    margin-left: 10px;
    vertical-align: middle;
}

/* ═══════════════════════════════════════════════════════════════════════════
   LAW ENTRY & TOWN RULE — SINGLE POST
═══════════════════════════════════════════════════════════════════════════ */
.sdbc-law-header {
    background: var(--sdbc-accent-lt);
    border-left: 6px solid var(--sdbc-accent);
    border-radius: 0 var(--sdbc-radius) var(--sdbc-radius) 0;
    padding: 20px 24px;
    margin-bottom: 28px;
}

.sdbc-law-header h1 {
    margin: 0 0 8px;
    color: var(--sdbc-navy);
    font-size: 26px;
}

.sdbc-law-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    font-size: 13px;
    color: var(--sdbc-gray-500);
}

.sdbc-law-meta span { display: flex; align-items: center; gap: 5px; }
.sdbc-law-meta strong { color: var(--sdbc-gray-700); }

.sdbc-topic-badge {
    display: inline-block;
    background: var(--sdbc-accent);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 3px 10px;
    border-radius: 20px;
}

.sdbc-financing-badge {
    display: inline-block;
    background: #15803d;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 20px;
    margin-bottom: 12px;
}

.sdbc-law-summary {
    font-size: 17px;
    line-height: 1.75;
    color: var(--sdbc-gray-700);
    margin-bottom: 24px;
}

.sdbc-law-source {
    background: var(--sdbc-gray-100);
    border: 1px solid var(--sdbc-gray-300);
    border-radius: var(--sdbc-radius);
    padding: 14px 18px;
    font-size: 13px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    flex-wrap: wrap;
}

.sdbc-law-source__label {
    font-weight: 700;
    color: var(--sdbc-gray-700);
    flex-shrink: 0;
}

.sdbc-law-source a {
    color: var(--sdbc-blue);
    word-break: break-all;
}

.sdbc-verified-date {
    font-size: 12px;
    color: var(--sdbc-gray-500);
    margin-top: 6px;
}

/* Review overdue warning */
.sdbc-overdue-warning {
    background: #fef3c7;
    border: 1px solid #fcd34d;
    border-radius: var(--sdbc-radius);
    padding: 10px 14px;
    font-size: 13px;
    color: #92400e;
    margin-top: 10px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   DISTRIBUTOR ARCHIVE / CATEGORY PAGE
═══════════════════════════════════════════════════════════════════════════ */
.sdbc-dist-archive-header {
    margin-bottom: 28px;
}

.sdbc-dist-archive-header h1 {
    color: var(--sdbc-navy);
    font-size: 28px;
    margin-bottom: 8px;
}

.sdbc-dist-filters {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.sdbc-dist-filters select {
    border: 1px solid var(--sdbc-gray-300);
    border-radius: 6px;
    padding: 7px 12px;
    font-size: 13px;
    color: var(--sdbc-gray-700);
}

.sdbc-dist-category-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 24px;
}

.sdbc-dist-category-nav a {
    background: var(--sdbc-gray-100);
    color: var(--sdbc-gray-700);
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.15s;
}

.sdbc-dist-category-nav a:hover,
.sdbc-dist-category-nav a.active {
    background: var(--sdbc-accent);
    color: #fff;
}

/* ═══════════════════════════════════════════════════════════════════════════
   LAW ENTRY ARCHIVE / STATE HOME
═══════════════════════════════════════════════════════════════════════════ */
.sdbc-state-hero {
    background: var(--sdbc-accent);
    color: #fff;
    padding: 36px 32px;
    border-radius: var(--sdbc-radius-lg);
    margin-bottom: 32px;
}

.sdbc-state-hero h1 {
    color: #fff;
    font-size: 32px;
    margin: 0 0 8px;
}

.sdbc-state-hero p {
    color: rgba(255,255,255,0.85);
    font-size: 15px;
    margin: 0;
}

.sdbc-topic-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
    margin-bottom: 32px;
}

.sdbc-topic-card {
    background: #fff;
    border: 1px solid var(--sdbc-gray-300);
    border-radius: var(--sdbc-radius);
    padding: 18px;
    text-decoration: none;
    color: var(--sdbc-gray-700);
    transition: all 0.15s;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.sdbc-topic-card:hover {
    border-color: var(--sdbc-accent);
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    transform: translateY(-1px);
}

.sdbc-topic-card__icon  { font-size: 24px; }
.sdbc-topic-card__name  { font-weight: 700; font-size: 14px; color: var(--sdbc-navy); }
.sdbc-topic-card__count { font-size: 12px; color: var(--sdbc-gray-500); }

/* ── Law entry list card ──────────────────────────────────────────────── */
.sdbc-entry-list { display: flex; flex-direction: column; gap: 12px; }

.sdbc-entry-card {
    background: #fff;
    border: 1px solid var(--sdbc-gray-300);
    border-radius: var(--sdbc-radius);
    padding: 16px 20px;
    display: flex;
    align-items: flex-start;
    gap: 16px;
    text-decoration: none;
    color: inherit;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.sdbc-entry-card:hover {
    border-color: var(--sdbc-accent);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.sdbc-entry-card--flagged {
    border-left: 4px solid var(--sdbc-amber);
}

.sdbc-entry-card__title {
    font-weight: 700;
    color: var(--sdbc-navy);
    font-size: 15px;
    margin-bottom: 4px;
}

.sdbc-entry-card__excerpt {
    font-size: 13px;
    color: var(--sdbc-gray-500);
    line-height: 1.5;
}

.sdbc-entry-card__meta {
    margin-left: auto;
    text-align: right;
    flex-shrink: 0;
    font-size: 11px;
    color: var(--sdbc-gray-500);
}

/* ═══════════════════════════════════════════════════════════════════════════
   NAVIGATION — STATE SWITCHER
═══════════════════════════════════════════════════════════════════════════ */
.sdbc-state-switcher {
    position: relative;
    display: inline-block;
}

.sdbc-state-switcher select {
    appearance: none;
    background: var(--sdbc-accent);
    color: #fff;
    border: none;
    padding: 8px 32px 8px 14px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='white'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
}

/* ═══════════════════════════════════════════════════════════════════════════
   HOMEPAGE WIDGETS
═══════════════════════════════════════════════════════════════════════════ */
.sdbc-featured-spotlight {
    background: linear-gradient(135deg, var(--sdbc-navy) 0%, #2563eb 100%);
    color: #fff;
    border-radius: var(--sdbc-radius-lg);
    padding: 24px;
    margin-bottom: 24px;
}

.sdbc-featured-spotlight h3 {
    color: #fff;
    margin: 0 0 16px;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.8;
}

.sdbc-spotlight-item {
    display: flex;
    align-items: center;
    gap: 14px;
    background: rgba(255,255,255,0.1);
    border-radius: var(--sdbc-radius);
    padding: 14px;
    margin-bottom: 10px;
    text-decoration: none;
    color: #fff;
    transition: background 0.15s;
}

.sdbc-spotlight-item:hover { background: rgba(255,255,255,0.2); }
.sdbc-spotlight-item img   { width: 48px; height: 48px; object-fit: contain; border-radius: 6px; background: #fff; }
.sdbc-spotlight-item__name { font-weight: 700; font-size: 15px; }
.sdbc-spotlight-item__cat  { font-size: 12px; opacity: 0.75; }

/* ── Federal Law wide banner (front page) ───────────────────────────────── */
.sdbc-fed-law-wide {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 18px 24px;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-left: 4px solid #f97316;
    border-radius: 10px;
    margin: 0 0 18px;
    flex-wrap: wrap;
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    .sdbc-topic-grid         { grid-template-columns: repeat(2, 1fr); }
    .sdbc-law-meta           { gap: 10px; }
    .sdbc-dashboard-panels   { grid-template-columns: 1fr; }
    .sdbc-entry-card         { flex-direction: column; }
    .sdbc-entry-card__meta   { margin-left: 0; text-align: left; }
}

@media (max-width: 480px) {
    .sdbc-topic-grid         { grid-template-columns: 1fr; }
    .sdbc-state-hero         { padding: 24px 20px; }
    .sdbc-state-hero h1      { font-size: 24px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   SHARED ARCHIVE COMPONENTS
   Used across archive-law_entry, archive-town_rule, archive-distributor,
   archive-federal_law templates.
═══════════════════════════════════════════════════════════════════════════ */

/* Archive page wrapper */
.sdbc-archive-wrap {
    max-width: 960px;
    margin: 0 auto;
    padding: 20px;
}

/* ── Filter bar ─────────────────────────────────────────────────────────── */
.sdbc-filter-bar {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
    padding: 14px 16px;
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
}
.sdbc-filter-group {
    display: flex;
    align-items: center;
    gap: 8px;
}
.sdbc-filter-label {
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    white-space: nowrap;
}
.sdbc-filter-select {
    font-size: 13px;
    padding: 6px 10px;
    border: 1px solid #d1d5db;
    border-radius: 6px;
    background: #fff;
    cursor: pointer;
}
.sdbc-filter-reset {
    font-size: 12px;
    padding: 6px 12px;
    border: 1px solid #d1d5db;
    border-radius: 6px;
    background: #fff;
    color: #6b7280;
    cursor: pointer;
    display: none;
}
.sdbc-filter-count {
    font-size: 12px;
    color: #9ca3af;
    margin-left: auto;
}

/* ── Entry cards (law, town, federal) ───────────────────────────────────── */
.sdbc-entry-card-v2 {
    padding: 16px;
    margin-bottom: 10px;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
}
.sdbc-entry-card-v2--flagged {
    border-color: #fcd34d;
    background: #fffbeb;
}
.sdbc-entry-card-header {
    display: flex;
    align-items: baseline;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 6px;
}
.sdbc-entry-card-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
}
.sdbc-entry-card-title a {
    color: inherit;
    text-decoration: none;
}
.sdbc-entry-card-title a:hover {
    text-decoration: underline;
}
.sdbc-entry-card-summary {
    margin: 0 0 8px;
    font-size: 13px;
    color: #374151;
    line-height: 1.5;
}
.sdbc-entry-card-meta {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    font-size: 12px;
    color: #6b7280;
}
.sdbc-entry-card-meta a {
    color: #6b7280;
}

/* ── Pill badges ────────────────────────────────────────────────────────── */
.sdbc-pill {
    font-size: 11px;
    color: #6b7280;
    background: #f3f4f6;
    padding: 2px 8px;
    border-radius: 99px;
    white-space: nowrap;
}
.sdbc-pill--blue {
    color: #1e40af;
    background: #dbeafe;
    font-weight: 700;
}
.sdbc-pill--green {
    color: #15803d;
    background: #dcfce7;
    font-weight: 700;
}
.sdbc-pill--amber {
    color: #92400e;
    background: #fef3c7;
    font-weight: 700;
}
.sdbc-pill--orange {
    color: #9a3412;
    background: #ffedd5;
    font-weight: 700;
    border: 1px solid #fed7aa;
}
.sdbc-pill--red {
    color: #b91c1c;
    background: #fef2f2;
}

/* ── No results message ─────────────────────────────────────────────────── */
.sdbc-no-results {
    display: none;
    padding: 20px;
    text-align: center;
    color: #9ca3af;
    background: #f9fafb;
    border-radius: 8px;
}

/* ── Section divider with label ─────────────────────────────────────────── */
.sdbc-divider {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
}
.sdbc-divider__line {
    flex: 1;
    height: 1px;
    background: #e5e7eb;
}
.sdbc-divider__label {
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #9ca3af;
}

.sdbc-entry-card-title-link {
    color: inherit;
    text-decoration: none;
}
.sdbc-entry-card-title-link:hover {
    text-decoration: underline;
}
