/* criminallawyerjacksonville.com — shared design system (2026-06-03 refresh)
   Family-matched to grahamsyfert.com; criminal-defense palette:
   charcoal hero, navy accent (#14365c), gold rule (#c79100), green CTA (#2e7d32). */

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'Segoe UI', Arial, sans-serif; line-height: 1.7; color: #2b2b2b; background: #fff; }
img { max-width: 100%; height: auto; }
a { color: #14365c; }

/* ---------- Top header / nav ---------- */
.site-header {
    position: sticky; top: 0; z-index: 50;
    background: #0e1b2c; color: #fff;
    box-shadow: 0 2px 8px rgba(0,0,0,0.18);
}
.nav-inner {
    max-width: 1040px; margin: 0 auto; padding: 0 18px;
    display: flex; align-items: center; justify-content: space-between; min-height: 60px;
}
.brand { display: flex; align-items: center; gap: 10px; text-decoration: none; color: #fff; font-weight: 700; font-size: 1.05em; letter-spacing: .2px; }
.brand .brand-mark { color: #c79100; font-size: 1.25em; line-height: 1; }
.brand small { display: block; font-weight: 400; font-size: .62em; color: #9fb3c8; letter-spacing: .3px; }
.nav-links { display: flex; align-items: center; gap: 4px; list-style: none; }
.nav-links a { color: #e7eef5; text-decoration: none; padding: 10px 12px; border-radius: 5px; font-size: .95em; }
.nav-links a:hover { background: #1c3050; color: #fff; }
.nav-drop { position: relative; }
.nav-drop > a::after { content: " \25be"; color: #9fb3c8; }
.nav-menu {
    display: none; position: absolute; top: 100%; left: 0; min-width: 240px;
    background: #fff; border: 1px solid #dfe5ec; border-radius: 8px; box-shadow: 0 12px 28px rgba(0,0,0,0.16); padding: 8px; z-index: 60;
}
.nav-drop:hover .nav-menu, .nav-drop:focus-within .nav-menu { display: block; }
.nav-menu a { display: block; color: #243b55; padding: 9px 12px; border-radius: 5px; font-size: .92em; }
.nav-menu a:hover { background: #f0f4f8; }
.nav-cta { background: #2e7d32; color: #fff !important; padding: 9px 16px !important; border-radius: 6px; font-weight: 700; }
.nav-cta:hover { background: #1b5e20 !important; }
.nav-toggle { display: none; background: none; border: 0; color: #fff; font-size: 1.5em; cursor: pointer; padding: 6px 10px; }
@media (max-width: 860px) {
    .nav-toggle { display: block; }
    .nav-links { display: none; position: absolute; top: 60px; left: 0; right: 0; flex-direction: column; align-items: stretch; background: #0e1b2c; padding: 8px 12px 14px; gap: 2px; }
    .nav-links.open { display: flex; }
    .nav-links a { padding: 12px 10px; }
    .nav-drop .nav-menu { position: static; display: block; box-shadow: none; border: 0; background: #13243a; padding: 0 0 6px 12px; }
    .nav-menu a { color: #cfe0f0; }
    .nav-menu a:hover { background: #1c3050; }
}

/* ---------- Hero ---------- */
.hero {
    position: relative; overflow: hidden;
    display: flex; flex-direction: column; justify-content: center; align-items: center;
    min-height: 360px;
    background: linear-gradient(135deg, #0e1b2c 0%, #24344a 100%);
    color: #fff; text-align: center; padding: 58px 20px 50px;
}
.hero::before {
    content: ""; position: absolute; inset: 0; z-index: 0;
    background: radial-gradient(ellipse at top, rgba(199,145,0,0.16), transparent 60%);
}
.hero-content { position: relative; z-index: 2; max-width: 820px; }
.hero h1 { font-size: 2.2em; margin-bottom: 12px; font-weight: 700; letter-spacing: -0.4px; }
.hero .tagline { font-size: 1.1em; color: #cdd8e4; margin: 0 auto 24px; max-width: 660px; }
.hero .eyebrow { color: #e6b94d; font-weight: 700; letter-spacing: 1.5px; font-size: .8em; text-transform: uppercase; margin-bottom: 12px; }

.cta-button {
    display: inline-block; background-color: #2e7d32; color: #fff; padding: 14px 32px;
    text-decoration: none; border-radius: 6px; font-weight: 700; font-size: 1.08em; transition: background-color .25s;
}
.cta-button:hover { background-color: #1b5e20; }
.cta-button.alt { background: #c79100; }
.cta-button.alt:hover { background: #a87a00; }

/* ---------- Trust strip ---------- */
.trust-strip { background: #f0f3f6; color: #3a4654; text-align: center; padding: 12px 18px; font-size: .92em; }
.trust-strip strong { color: #14365c; }
.reviewed-by { text-align: center; padding: 12px 20px; background: #fafbfc; color: #5a6675; font-size: .88em; border-bottom: 1px solid #eef1f4; }

/* ---------- Layout ---------- */
.container { max-width: 960px; margin: 0 auto; padding: 0 20px; }
.container.narrow { max-width: 760px; }
.section { padding: 52px 0; }
.section.alt { background: #f7f8fa; }
.section h2 { font-size: 1.6em; color: #14365c; margin-bottom: 16px; }
.section h3 { color: #14365c; margin: 22px 0 8px; font-size: 1.18em; }
.section p { margin-bottom: 14px; font-size: 1.02em; }
.section ul, .section ol { margin: 0 0 14px 22px; }
.section li { margin-bottom: 7px; }

/* Breadcrumb */
.breadcrumb { background: #eef2f6; font-size: .85em; color: #5a6675; }
.breadcrumb .container { padding-top: 10px; padding-bottom: 10px; }
.breadcrumb a { color: #14365c; text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }

/* Answer capsule */
.answer-capsule { background: #fff8e1; border-left: 4px solid #c79100; padding: 30px 26px; }
.answer-capsule p { font-size: 1.06em; margin-bottom: 12px; }
.answer-capsule p:last-child { margin-bottom: 0; }

/* Practice card grid */
.practice-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 22px; }
.practice-grid.three { grid-template-columns: 1fr 1fr 1fr; }
.practice-card { background: #fff; border: 1px solid #e0e3e7; border-left: 4px solid #14365c; border-radius: 7px; padding: 22px 20px; transition: box-shadow .2s, transform .2s; }
.practice-card:hover { box-shadow: 0 8px 22px rgba(20,54,92,0.12); transform: translateY(-2px); }
.practice-card h3 { color: #14365c; font-size: 1.16em; margin: 0 0 9px; }
.practice-card p { color: #555; font-size: .95em; margin-bottom: 12px; }
.practice-card a { display: inline-block; color: #14365c; font-weight: 600; text-decoration: none; }
.practice-card a:hover { text-decoration: underline; }
@media (max-width: 820px) { .practice-grid, .practice-grid.three { grid-template-columns: 1fr; } }

/* Sub-topic chip list */
.subtopics { display: flex; flex-wrap: wrap; gap: 9px; margin: 16px 0 4px; }
.subtopics a { background: #eef2f6; color: #14365c; padding: 7px 13px; border-radius: 20px; text-decoration: none; font-size: .9em; border: 1px solid #dde4ec; }
.subtopics a:hover { background: #14365c; color: #fff; }

/* Case-result cards */
.case-result { background: #fff; border: 1px solid #e3e7ec; border-radius: 7px; padding: 18px 20px; margin-bottom: 14px; border-top: 3px solid #c79100; }
.case-result h4 { color: #14365c; font-size: 1.05em; margin-bottom: 6px; }
.case-result .verdict { display: inline-block; background: #e8f5e9; color: #1b5e20; font-weight: 700; font-size: .8em; padding: 3px 10px; border-radius: 12px; margin-bottom: 8px; }
.results-disclaimer { font-size: .82em; color: #7a8493; font-style: italic; margin-top: 8px; }

/* Why list */
.why-list { list-style: none; padding: 0; margin: 18px 0 0; }
.why-list li { padding: 14px 18px 14px 46px; background: #fff; border-left: 4px solid #2e7d32; margin-bottom: 10px; border-radius: 4px; position: relative; }
.why-list li::before { content: "\2713"; position: absolute; left: 16px; top: 14px; color: #2e7d32; font-weight: 700; font-size: 1.1em; }
.why-list strong { color: #14365c; display: block; margin-bottom: 3px; }

/* FAQ */
.faq { background: #fff; border-radius: 6px; margin-bottom: 8px; border: 1px solid #e0e3e7; }
.faq summary { cursor: pointer; padding: 15px 20px; font-weight: 600; color: #14365c; list-style: none; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: " +"; float: right; color: #c79100; font-weight: 700; }
.faq[open] summary::after { content: " \2013"; }
.faq[open] summary { border-bottom: 1px solid #f0f0f0; }
.faq .faq-body { padding: 15px 20px 17px; color: #444; }

/* Callout band */
.research { background: #14365c; color: #fff; padding: 46px 20px; text-align: center; }
.research h2 { color: #fff; font-size: 1.4em; margin-bottom: 12px; }
.research p { color: #d0deef; max-width: 720px; margin: 0 auto 12px; }
.research a { color: #ffd54f; font-weight: 600; }

/* Final CTA */
.final-cta { background: #0e1b2c; color: #fff; text-align: center; padding: 54px 20px; }
.final-cta h2 { color: #fff; font-size: 1.5em; margin-bottom: 12px; }
.final-cta p { color: #b9c4d2; max-width: 620px; margin: 0 auto 20px; }
.final-cta .contact-details { color: #8b97a6; font-size: .9em; margin-top: 18px; }

/* Footer */
.site-footer { background: #0a1320; color: #9fb0c2; font-size: .9em; padding: 36px 20px 26px; }
.footer-inner { max-width: 1040px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 26px; }
.site-footer h4 { color: #fff; font-size: .95em; margin-bottom: 10px; letter-spacing: .3px; }
.site-footer a { color: #b9c8d8; text-decoration: none; }
.site-footer a:hover { color: #fff; text-decoration: underline; }
.site-footer ul { list-style: none; }
.site-footer li { margin-bottom: 6px; }
.footer-disclaimer { max-width: 1040px; margin: 22px auto 0; padding-top: 18px; border-top: 1px solid #1c2a3d; font-size: .8em; color: #6f7d8e; line-height: 1.6; }
@media (max-width: 760px) { .footer-inner { grid-template-columns: 1fr; } }

/* Sticky mobile call bar */
.callbar { display: none; }
@media (max-width: 860px) {
    .callbar { display: flex; position: fixed; bottom: 0; left: 0; right: 0; z-index: 80; }
    .callbar a { flex: 1; text-align: center; padding: 13px 8px; font-weight: 700; text-decoration: none; color: #fff; font-size: 1.02em; }
    .callbar .cb-call { background: #2e7d32; }
    .callbar .cb-eval { background: #14365c; }
    body { padding-bottom: 52px; }
}

/* utility */
.center { text-align: center; }
.lead { font-size: 1.12em; color: #3a4654; }
hr.gold { border: 0; border-top: 2px solid #c79100; width: 60px; margin: 18px 0; }
