/* ============================================================
   CannabisForSeniors.org — Sage Trust Theme
   ============================================================
   Calm sage-green palette with warm-cream backgrounds. Tuned
   for older readers: slightly larger body text, higher contrast,
   tighter line-height for scannability. Inherits typography and
   layout primitives from base.css.
   ============================================================ */

:root {
    /* Primary: Sage Trust */
    --cs-primary-950: #102b25;
    --cs-primary-900: #173a31;
    --cs-primary-800: #1f4e41;
    --cs-primary-700: #2d6855;   /* anchor */
    --cs-primary-600: #3e836c;
    --cs-primary-500: #5a9d83;
    --cs-primary-400: #82b8a0;
    --cs-primary-300: #abd0bf;
    --cs-primary-200: #d0e3d8;
    --cs-primary-100: #e7f0eb;
    --cs-primary-50:  #f3f7f4;

    /* Accent: Warm Rust (for callouts, CTAs) */
    --cs-accent: #a0563c;
    --cs-accent-light: #fbeae3;

    /* Buff: Warm Cream (page wash) */
    --cs-buff: #6b6557;
    --cs-buff-light: #faf6ef;

    /* Semantic mappings */
    --cs-primary: var(--cs-primary-700);
    --cs-primary-hover: var(--cs-primary-800);
    --cs-primary-active: var(--cs-primary-900);
    --cs-text-heading: var(--cs-primary-900);
    --cs-bg-section: var(--cs-primary-50);
    --cs-link: var(--cs-primary-700);
    --cs-link-hover: var(--cs-primary-900);

    /* Senior-tuned typography: bump body slightly, tighten lead spacing */
    --cs-body-size: 1.1875rem;       /* ~19px (base is 18px) */
    --cs-body-leading: 1.7;
}

/* Higher contrast body text for older eyes */
body {
    color: #1f2724;
}

/* Stronger link contrast + always underlined for accessibility */
a {
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
}
a:hover, a:focus {
    text-decoration-thickness: 2px;
}
.nav-link, .navbar-brand, .breadcrumb a, .btn, .dropdown-item, .footer-link, .top-bar-link {
    text-decoration: none;
}

/* Larger, calmer focus ring for keyboard users */
:focus-visible {
    outline: 3px solid var(--cs-primary-500);
    outline-offset: 2px;
    border-radius: 3px;
}

/* Buttons: more padding for easier targeting */
.btn {
    padding-top: 0.625rem;
    padding-bottom: 0.625rem;
}
.btn-lg {
    padding-top: 0.875rem;
    padding-bottom: 0.875rem;
    font-size: 1.0625rem;
}

/* Page wash on warm cream */
body {
    background: var(--cs-buff-light);
}

/* Hero section with sage gradient */
.section-home .hero,
.page-hero {
    background: linear-gradient(135deg, var(--cs-primary-800) 0%, var(--cs-primary-700) 100%);
    color: #fff;
    padding: 3.5rem 0 3rem;
}
.section-home .hero h1,
.page-hero h1 {
    color: #fff;
    margin-bottom: 1rem;
}
.section-home .hero .lead,
.page-hero .lead {
    color: rgba(255,255,255,0.92);
    max-width: 60ch;
}

/* "Talk to your pharmacist" callout — used heavily on safety pages */
.callout-pharmacist {
    background: var(--cs-accent-light);
    border-left: 5px solid var(--cs-accent);
    padding: 1.125rem 1.25rem;
    border-radius: 4px;
    margin: 1.75rem 0;
    font-size: 1rem;
}
.callout-pharmacist .callout-title {
    font-weight: 700;
    color: var(--cs-accent);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 0.875rem;
    margin-bottom: 0.375rem;
    display: block;
}

/* Evidence-strength badges (research-rated content) */
.evidence-badge {
    display: inline-block;
    font-size: 0.8125rem;
    font-weight: 600;
    padding: 0.25rem 0.625rem;
    border-radius: 999px;
    margin-left: 0.5rem;
    vertical-align: middle;
}
.evidence-strong  { background: #1d4138; color: #e7f0eb; }
.evidence-moderate{ background: #6b8e7f; color: #fff; }
.evidence-limited { background: #d0c5a8; color: #4a3f1f; }
.evidence-emerging{ background: #fbeae3; color: var(--cs-accent); border: 1px solid var(--cs-accent); }

/* Citation styling */
.citation, cite {
    font-size: 0.9375rem;
    color: var(--cs-gray-600, #6b7280);
    font-style: normal;
}

/* Section card grid for home/section overview pages */
.topic-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.25rem;
    margin: 2rem 0;
}
.topic-card {
    background: #fff;
    border: 1px solid var(--cs-primary-100);
    border-radius: 8px;
    padding: 1.5rem;
    transition: border-color 0.15s, transform 0.15s;
}
.topic-card:hover {
    border-color: var(--cs-primary-400);
    transform: translateY(-1px);
}
.topic-card h3 {
    margin-top: 0;
    margin-bottom: 0.5rem;
    font-size: 1.1875rem;
    color: var(--cs-primary-800);
}
.topic-card p {
    margin-bottom: 0.875rem;
    color: var(--cs-text);
}
.topic-card .topic-card-link {
    font-weight: 600;
    color: var(--cs-primary-700);
}
