/* =========================================================================
   PIKE LAW — WordPress Theme Stylesheet
   Editorial design: deep forest green primary, warm parchment background,
   brass gold accent. Hand-written, vanilla CSS. All colors HSL.
   ========================================================================= */

:root {
    /* Surfaces */
    --background: 40 33% 97%;
    --foreground: 155 35% 10%;
    --card: 0 0% 100%;
    --card-foreground: 155 35% 10%;

    /* Brand */
    --primary: 148 55% 18%;
    --primary-foreground: 40 33% 97%;
    --primary-glow: 148 45% 28%;

    --secondary: 148 25% 94%;
    --secondary-foreground: 148 55% 18%;

    --muted: 40 20% 92%;
    --muted-foreground: 155 15% 35%;

    --accent: 38 65% 48%;
    --accent-foreground: 155 35% 10%;
    --accent-soft: 38 75% 92%;

    --border: 148 15% 86%;
    --input: 148 15% 86%;
    --ring: 148 55% 18%;

    --radius: 0.375rem;

    --gradient-forest: linear-gradient(135deg, hsl(148 55% 12%) 0%, hsl(148 45% 22%) 100%);
    --gradient-gold: linear-gradient(135deg, hsl(38 70% 55%), hsl(38 60% 42%));
    --gradient-overlay: linear-gradient(180deg, hsl(148 55% 8% / 0.55) 0%, hsl(148 55% 8% / 0.85) 100%);
    --gradient-radial-glow: radial-gradient(circle at 30% 20%, hsl(38 65% 48% / 0.15), transparent 60%);

    --shadow-elegant: 0 20px 60px -20px hsl(148 55% 12% / 0.35);
    --shadow-card: 0 4px 24px -6px hsl(148 55% 12% / 0.12);
    --shadow-gold: 0 8px 30px -8px hsl(38 65% 48% / 0.45);

    --transition-smooth: 0.4s cubic-bezier(0.4, 0, 0.2, 1);

    --container-max: 1152px;
}

* { box-sizing: border-box; }
*::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    background: hsl(var(--background));
    color: hsl(var(--foreground));
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    font-size: 16px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
ul, ol { padding: 0; margin: 0; list-style: none; }
p { margin: 0 0 1rem; }

h1, h2, h3, h4, h5, .font-display, .section-title, .subsection-title, .card-title {
    font-family: 'Cormorant Garamond', 'Times New Roman', serif;
    font-weight: 600;
    letter-spacing: -0.01em;
    color: hsl(var(--primary));
    margin: 0 0 0.75rem;
    line-height: 1.15;
}

::selection { background: hsl(var(--accent) / 0.4); }

/* Skip link */
.skip-link {
    position: absolute;
    left: -10000px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
}
.skip-link:focus { left: 1rem; top: 1rem; width: auto; height: auto; padding: 0.5rem 1rem; background: hsl(var(--primary)); color: hsl(var(--primary-foreground)); z-index: 100; }
.screen-reader-text { position: absolute; left: -10000px; }

/* Layout */
.container-tight { width: 100%; max-width: var(--container-max); margin: 0 auto; padding: 0 1.5rem; }
.container-narrow { max-width: 768px; }
.text-center { text-align: center; }
.italic { font-style: italic; }
.accent { color: hsl(var(--accent)); }
.light { color: hsl(var(--primary-foreground)); }
.muted { color: hsl(var(--muted-foreground)); }
.muted-light { color: hsl(var(--primary-foreground) / 0.7); }
.hide-on-mobile { display: none; }

/* Common section pieces */
.section-title {
    font-size: clamp(2rem, 1rem + 3vw, 3.25rem);
    text-wrap: balance;
}
.section-title.light { color: hsl(var(--primary-foreground)); }
.subsection-title { font-size: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
.subsection-title.light { color: hsl(var(--primary-foreground)); }
.card-title { font-size: 1.5rem; }
.section-lede { color: hsl(var(--muted-foreground)); font-size: 1.125rem; line-height: 1.7; max-width: 56ch; }
.section-lede.light { color: hsl(var(--primary-foreground) / 0.8); max-width: 70ch; }
.section-intro { margin: 0 auto 3rem; max-width: 48rem; }
.section-intro.text-center { text-align: center; }

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: hsl(var(--accent));
}
.eyebrow::before {
    content: '';
    display: inline-block;
    height: 1px;
    width: 2rem;
    background: hsl(var(--accent));
}
.eyebrow--icon::before { display: none; }
.eyebrow--accent { color: hsl(var(--accent)); }
.eyebrow--accent::before { background: hsl(var(--accent)); }

/* Icons */
.pike-icon { display: inline-block; vertical-align: middle; flex-shrink: 0; }
.icon-xs { width: 0.875rem; height: 0.875rem; }
.icon-sm { width: 1rem; height: 1rem; }
.icon-md { width: 1.25rem; height: 1.25rem; }
.icon-lg { width: 2rem; height: 2rem; }
.icon-accent { color: hsl(var(--accent)); }
.star-filled { fill: hsl(var(--accent)); color: hsl(var(--accent)); }

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.625rem 1.25rem;
    border-radius: var(--radius);
    font-weight: 500;
    font-size: 0.875rem;
    line-height: 1.2;
    border: 1px solid transparent;
    cursor: pointer;
    transition: all 0.2s var(--transition-smooth);
    text-align: center;
    white-space: nowrap;
}
.btn--primary { background: hsl(var(--primary)); color: hsl(var(--primary-foreground)); box-shadow: var(--shadow-card); }
.btn--primary:hover { background: hsl(var(--primary-glow)); }
.btn--outline { background: transparent; color: hsl(var(--primary)); border-color: hsl(var(--input)); }
.btn--outline:hover { background: hsl(var(--secondary)); }
.btn--hero {
    background: hsl(var(--accent));
    color: hsl(var(--accent-foreground));
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    box-shadow: var(--shadow-gold);
}
.btn--hero:hover { background: hsl(var(--accent) / 0.9); }
.btn--ghost-light {
    background: transparent;
    color: hsl(var(--primary-foreground));
    border-color: hsl(var(--primary-foreground) / 0.3);
    backdrop-filter: blur(4px);
}
.btn--ghost-light:hover { background: hsl(var(--primary-foreground) / 0.1); }
.btn--sm { padding: 0.5rem 0.875rem; font-size: 0.8125rem; }
.btn--lg { padding: 0.875rem 2rem; font-size: 0.875rem; }
.btn--xl { padding: 1.125rem 2.5rem; font-size: 0.875rem; }
.btn--block { display: flex; width: 100%; }

.cta-row { display: flex; flex-wrap: wrap; gap: 1rem; }
.cta-row--center { justify-content: center; }
.link-accent {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: hsl(var(--primary));
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.125rem;
    font-weight: 600;
    transition: color 0.2s;
}
.link-accent:hover { color: hsl(var(--accent)); }

/* Topbar */
.topbar {
    display: none;
    background: hsl(var(--primary));
    color: hsl(var(--primary-foreground));
    font-size: 0.75rem;
}
.topbar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}
.topbar__address { display: inline-flex; align-items: center; gap: 0.5rem; opacity: 0.9; }
.topbar__cta {
    color: hsl(var(--accent));
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}
@media (min-width: 768px) { .topbar { display: block; } }

/* Header */
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: hsl(var(--background));
    transition: all 0.3s var(--transition-smooth);
}
.site-header.is-scrolled {
    background: hsl(var(--background) / 0.95);
    backdrop-filter: blur(8px);
    box-shadow: var(--shadow-card);
}
.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1.5rem;
    gap: 1rem;
}

.site-logo { display: flex; align-items: center; gap: 0.75rem; }
.site-logo__mark {
    display: flex;
    width: 3rem;
    height: 3rem;
    border: 2px solid hsl(var(--primary));
    align-items: center;
    justify-content: center;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.25rem;
    font-weight: 700;
    color: hsl(var(--primary));
    transition: all 0.3s;
}
.site-logo:hover .site-logo__mark { background: hsl(var(--primary)); color: hsl(var(--primary-foreground)); }
.site-logo__text { display: none; }
.site-logo__name { font-family: 'Cormorant Garamond', serif; font-size: 1.25rem; font-weight: 600; color: hsl(var(--primary)); display: block; line-height: 1; }
.site-logo__tag { font-size: 0.625rem; text-transform: uppercase; letter-spacing: 0.22em; color: hsl(var(--muted-foreground)); margin-top: 0.25rem; display: block; }
@media (min-width: 640px) { .site-logo__text { display: block; } }

.site-nav { display: none; }
.site-nav__list { display: flex; gap: 2rem; align-items: center; }
.site-nav__list a { font-size: 0.875rem; font-weight: 500; color: hsl(var(--foreground) / 0.8); position: relative; padding: 0.25rem 0; transition: color 0.2s; }
.site-nav__list a::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -2px;
    height: 1px;
    width: 0;
    background: hsl(var(--accent));
    transition: width 0.3s;
}
.site-nav__list a:hover { color: hsl(var(--primary)); }
.site-nav__list a:hover::after { width: 100%; }
@media (min-width: 1024px) { .site-nav { display: block; } }

.site-header__actions { display: flex; align-items: center; gap: 0.75rem; }
.site-header__phone {
    display: none;
    align-items: center;
    gap: 0.5rem;
    color: hsl(var(--primary));
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.125rem;
    font-weight: 600;
    transition: color 0.2s;
}
.site-header__phone:hover { color: hsl(var(--accent)); }
.site-header__phone-ring {
    display: inline-flex;
    width: 2.25rem;
    height: 2.25rem;
    background: hsl(var(--accent) / 0.1);
    border-radius: 50%;
    align-items: center;
    justify-content: center;
    color: hsl(var(--accent));
    animation: pulse-ring 2s infinite;
}
@media (min-width: 640px) { .site-header__phone { display: inline-flex; } }
@media (min-width: 768px) { .hide-on-mobile { display: inline-flex; } }

.nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem;
    color: hsl(var(--primary));
}
.nav-toggle__close { display: none; }
.nav-toggle.is-open .nav-toggle__open { display: none; }
.nav-toggle.is-open .nav-toggle__close { display: inline-block; }
@media (min-width: 1024px) { .nav-toggle { display: none; } }

.mobile-nav { border-top: 1px solid hsl(var(--border)); background: hsl(var(--background)); padding: 1rem 0 1.25rem; }
.mobile-nav[hidden] { display: none; }
.mobile-nav__list { display: flex; flex-direction: column; gap: 0.75rem; padding-bottom: 1rem; }
.mobile-nav__list a { font-size: 1rem; font-weight: 500; color: hsl(var(--foreground) / 0.8); padding: 0.25rem 0; }
.mobile-nav__phone { display: inline-flex; align-items: center; gap: 0.5rem; color: hsl(var(--primary)); font-weight: 600; padding: 0.75rem 0; border-top: 1px solid hsl(var(--border)); margin-bottom: 0.75rem; }

/* Hero */
.hero { position: relative; isolation: isolate; overflow: hidden; }
.hero__media { position: absolute; inset: 0; z-index: -1; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; }
.hero__overlay { position: absolute; inset: 0; background: var(--gradient-overlay); }
.hero__glow { position: absolute; inset: 0; background: var(--gradient-radial-glow); }
.hero__inner {
    padding-top: 6rem;
    padding-bottom: 6rem;
    color: hsl(var(--primary-foreground));
    max-width: 56rem;
    animation: fade-up 0.7s var(--transition-smooth) both;
}
@media (min-width: 768px) { .hero__inner { padding-top: 9rem; padding-bottom: 9rem; } }
@media (min-width: 1024px) { .hero__inner { padding-top: 11rem; padding-bottom: 11rem; } }

.hero__eyebrow { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1.5rem; }
.hero__eyebrow-line { display: inline-block; height: 1px; width: 2.5rem; background: hsl(var(--accent)); }
.hero__eyebrow-text { color: hsl(var(--accent)); font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.22em; }

.hero__title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2.5rem, 1rem + 5vw, 4.5rem);
    line-height: 1.05;
    color: hsl(var(--primary-foreground));
    margin: 0 0 1.5rem;
    text-wrap: balance;
}
.hero__title-accent {
    display: block;
    margin-top: 0.5rem;
    color: hsl(var(--accent));
    font-style: italic;
    font-weight: 500;
}
.hero__desc {
    font-size: clamp(1.125rem, 0.5rem + 1vw, 1.25rem);
    color: hsl(var(--primary-foreground) / 0.85);
    line-height: 1.7;
    max-width: 36rem;
    margin-bottom: 2rem;
}
.hero__desc strong { color: hsl(var(--primary-foreground)); }
.hero__cta { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem; margin-bottom: 3rem; }

.hero__trust {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    max-width: 36rem;
    padding-top: 2rem;
    border-top: 1px solid hsl(var(--primary-foreground) / 0.15);
}
.hero__trust-item { display: flex; align-items: flex-start; gap: 0.75rem; }
.hero__trust-value { font-family: 'Cormorant Garamond', serif; font-size: clamp(1.5rem, 0.5rem + 2vw, 2rem); color: hsl(var(--primary-foreground)); line-height: 1; }
.hero__trust-label { font-size: 0.6875rem; text-transform: uppercase; letter-spacing: 0.1em; color: hsl(var(--primary-foreground) / 0.6); margin-top: 0.25rem; }

@keyframes fade-up { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes pulse-ring {
    0% { box-shadow: 0 0 0 0 hsl(var(--accent) / 0.5); }
    70% { box-shadow: 0 0 0 14px hsl(var(--accent) / 0); }
    100% { box-shadow: 0 0 0 0 hsl(var(--accent) / 0); }
}

/* Trial-ready */
.trial-ready { background: hsl(var(--card)); padding: 4rem 0; border-bottom: 1px solid hsl(var(--border)); }
.trial-ready__inner { max-width: 56rem; margin: 0 auto; text-align: center; }
.trial-ready__inner .eyebrow { justify-content: center; }
.trial-ready .cta-row { justify-content: center; margin-top: 2rem; }

/* Trust bar */
.trust-bar { background: hsl(var(--primary)); color: hsl(var(--primary-foreground)); border-block: 1px solid hsl(var(--primary-glow) / 0.3); }
.trust-bar__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.75rem 2.5rem;
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: hsl(var(--primary-foreground) / 0.7);
}
.trust-bar__item { display: inline-flex; align-items: center; gap: 0.5rem; }

/* Experience block */
.experience { padding: 5rem 0; background: hsl(var(--secondary)); }
.experience__grid { display: grid; gap: 3rem; align-items: center; }
@media (min-width: 1024px) { .experience__grid { grid-template-columns: 7fr 5fr; gap: 4rem; padding: 2rem 0; } }
.experience__copy .btn { margin-top: 1rem; }
.experience__card { position: relative; padding: 2rem; background: var(--gradient-forest); color: hsl(var(--primary-foreground)); border-radius: var(--radius); box-shadow: var(--shadow-elegant); overflow: hidden; }
@media (min-width: 768px) { .experience__card { padding: 2.5rem; } }
.experience__grid-bg, .why-trial__grid-bg, .wills-probate__grid-bg, .contact__grid-bg {
    position: absolute; inset: 0; pointer-events: none; opacity: 0.1;
    background-image: linear-gradient(hsl(var(--accent) / 0.4) 1px, transparent 1px),
                      linear-gradient(90deg, hsl(var(--accent) / 0.4) 1px, transparent 1px);
    background-size: 60px 60px;
}
.experience__card-inner { position: relative; }
.experience__num { font-family: 'Cormorant Garamond', serif; font-size: clamp(4rem, 2rem + 6vw, 6rem); color: hsl(var(--accent)); line-height: 1; margin-bottom: 0.5rem; }
.experience__num-of { color: hsl(var(--primary-foreground) / 0.4); font-size: 0.7em; }
.experience__num-label { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; color: hsl(var(--primary-foreground)); margin-bottom: 1rem; }
.experience__note { color: hsl(var(--primary-foreground) / 0.75); font-size: 0.875rem; line-height: 1.7; display: flex; align-items: flex-start; gap: 0.5rem; }

/* Practice areas */
.practice-areas { padding: 5rem 0; background: hsl(var(--background)); }
.practice-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background: hsl(var(--border));
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-card);
}
@media (min-width: 768px) { .practice-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .practice-grid { grid-template-columns: repeat(3, 1fr); } }

.practice-card {
    position: relative;
    display: block;
    padding: 2rem;
    background: hsl(var(--card));
    transition: background-color 0.3s;
}
.practice-card:hover { background: hsl(var(--secondary)); }
.practice-card__tag {
    position: absolute;
    top: 1rem;
    right: 1rem;
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    background: hsl(var(--accent));
    color: hsl(var(--accent-foreground));
    padding: 0.25rem 0.5rem;
    border-radius: 2px;
    font-weight: 700;
}
.practice-card__icon {
    display: inline-flex;
    width: 3rem;
    height: 3rem;
    border-radius: var(--radius);
    background: hsl(var(--primary) / 0.05);
    border: 1px solid hsl(var(--primary) / 0.1);
    align-items: center;
    justify-content: center;
    color: hsl(var(--primary));
    margin-bottom: 1.25rem;
    transition: all 0.3s;
}
.practice-card:hover .practice-card__icon { background: hsl(var(--primary)); color: hsl(var(--primary-foreground)); border-color: hsl(var(--primary)); }
.practice-card__title { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; color: hsl(var(--primary)); margin: 0 0 0.5rem; display: flex; align-items: center; gap: 0.5rem; }
.practice-card__arrow { opacity: 0; transform: translateX(-0.5rem); transition: all 0.3s; }
.practice-card:hover .practice-card__arrow { opacity: 1; transform: translateX(0); }
.practice-card__desc { color: hsl(var(--muted-foreground)); font-size: 0.875rem; line-height: 1.7; margin-bottom: 1rem; }
.practice-card__extra { display: inline-block; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: hsl(var(--accent)); font-weight: 600; cursor: pointer; margin-bottom: 0.75rem; }
.practice-card__extra:hover { text-decoration: underline; }
.practice-card__hover { display: block; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: hsl(var(--accent)); font-weight: 600; opacity: 0; transition: opacity 0.3s; }
.practice-card:hover .practice-card__hover { opacity: 1; }
.practice-areas__outro { margin-top: 3rem; }
.practice-areas__outro p { color: hsl(var(--muted-foreground)); margin-bottom: 1rem; }

/* Wills & Probate */
.wills-probate { padding: 5rem 0; background: hsl(var(--card)); }
.wills-probate__intro { display: grid; gap: 3rem; margin-bottom: 5rem; }
@media (min-width: 1024px) { .wills-probate__intro { grid-template-columns: 7fr 5fr; gap: 4rem; } }
.wills-probate__sidebar { background: hsl(var(--secondary)); border: 1px solid hsl(var(--border)); padding: 2rem; border-radius: var(--radius); box-shadow: var(--shadow-card); }
.wills-probate__sidebar p { color: hsl(var(--muted-foreground)); font-size: 0.875rem; margin-bottom: 1.5rem; }

.wills-probate__assets { margin-bottom: 5rem; }
.will-assets-grid { display: grid; gap: 1px; background: hsl(var(--border)); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-card); }
@media (min-width: 640px) { .will-assets-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .will-assets-grid { grid-template-columns: repeat(3, 1fr); } }
.will-asset { background: hsl(var(--card)); padding: 1.5rem; }
.will-asset__icon { display: inline-flex; width: 2.5rem; height: 2.5rem; border-radius: var(--radius); background: hsl(var(--primary) / 0.05); border: 1px solid hsl(var(--primary) / 0.1); align-items: center; justify-content: center; color: hsl(var(--primary)); margin-bottom: 1rem; }
.will-asset h4 { font-family: 'Cormorant Garamond', serif; font-size: 1.125rem; color: hsl(var(--primary)); margin: 0 0 0.5rem; }
.will-asset p { color: hsl(var(--muted-foreground)); font-size: 0.875rem; line-height: 1.7; margin: 0; }
.wills-probate__note { color: hsl(var(--muted-foreground)); font-size: 0.875rem; max-width: 50rem; margin-top: 1.5rem; }

.wills-probate__trust { display: grid; gap: 2.5rem; margin-bottom: 5rem; }
@media (min-width: 1024px) { .wills-probate__trust { grid-template-columns: 5fr 7fr; gap: 4rem; align-items: start; } }
.trust-asset-list { display: grid; gap: 0.75rem; }
@media (min-width: 640px) { .trust-asset-list { grid-template-columns: 1fr 1fr; } }
.trust-asset-list li { display: flex; align-items: center; gap: 0.75rem; background: hsl(var(--secondary)); border: 1px solid hsl(var(--border)); padding: 0.75rem 1rem; border-radius: var(--radius); font-size: 0.875rem; color: hsl(var(--primary)); font-weight: 500; }
.trust-asset__dot { display: inline-block; height: 0.375rem; width: 0.375rem; border-radius: 50%; background: hsl(var(--accent)); flex-shrink: 0; }

.wills-probate__probate { position: relative; background: var(--gradient-forest); color: hsl(var(--primary-foreground)); padding: 2rem; border-radius: var(--radius); box-shadow: var(--shadow-elegant); overflow: hidden; }
@media (min-width: 768px) { .wills-probate__probate { padding: 3rem; } }
.wills-probate__probate-inner { position: relative; display: grid; gap: 2.5rem; align-items: start; }
@media (min-width: 1024px) { .wills-probate__probate-inner { grid-template-columns: 7fr 5fr; } }
.wills-probate__probate-card { background: hsl(var(--primary-foreground) / 0.05); border: 1px solid hsl(var(--primary-foreground) / 0.15); padding: 1.5rem; border-radius: var(--radius); }
.probate-steps { display: flex; flex-direction: column; gap: 0.75rem; margin-top: 1rem; }
.probate-steps li { display: flex; align-items: flex-start; gap: 0.75rem; font-size: 0.875rem; color: hsl(var(--primary-foreground) / 0.85); }
.probate-step__num { font-family: 'Cormorant Garamond', serif; color: hsl(var(--accent)); font-size: 1rem; line-height: 1; margin-top: 0.125rem; flex-shrink: 0; }
.wills-probate__probate-cta { position: relative; margin-top: 2.5rem; padding-top: 2rem; border-top: 1px solid hsl(var(--primary-foreground) / 0.1); display: flex; flex-direction: column; gap: 1.25rem; }
@media (min-width: 768px) { .wills-probate__probate-cta { flex-direction: row; align-items: center; justify-content: space-between; } }
.wills-probate__probate-cta p { color: hsl(var(--primary-foreground) / 0.8); margin: 0; max-width: 32rem; }

/* About */
.about { position: relative; padding: 5rem 0; background: hsl(var(--secondary) / 0.4); overflow: hidden; }
.about__dots {
    position: absolute; inset: 0; z-index: -1; opacity: 0.03;
    background-image: radial-gradient(circle at 1px 1px, hsl(var(--primary)) 1px, transparent 0);
    background-size: 32px 32px;
}
.about__grid { display: grid; gap: 3rem; align-items: center; }
@media (min-width: 1024px) { .about__grid { grid-template-columns: 5fr 7fr; gap: 4rem; } }
.about__media { position: relative; }
.about__portrait { width: 100%; aspect-ratio: 4/5; object-fit: cover; object-position: 85% center; border-radius: var(--radius); box-shadow: var(--shadow-elegant); }
.about__overlay { display: none; position: absolute; bottom: -1.5rem; right: -1.5rem; align-items: stretch; gap: 0.75rem; }
@media (min-width: 768px) { .about__overlay { display: flex; } }
.about__badge { width: auto; aspect-ratio: 1; height: 100%; filter: drop-shadow(0 8px 16px rgba(0,0,0,0.2)); }
.about__years { background: hsl(var(--primary)); color: hsl(var(--primary-foreground)); padding: 1.5rem; max-width: 14rem; box-shadow: var(--shadow-elegant); }
.about__years-num { font-family: 'Cormorant Garamond', serif; font-size: 3rem; color: hsl(var(--accent)); line-height: 1; }
.about__years-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.18em; margin-top: 0.5rem; color: hsl(var(--primary-foreground) / 0.8); }

.cred-list { display: grid; gap: 0.75rem; margin: 1.5rem 0 2.5rem; }
@media (min-width: 640px) { .cred-list { grid-template-columns: 1fr 1fr; } }
.cred-list li { display: flex; align-items: flex-start; gap: 0.75rem; font-size: 0.875rem; }
.cred-list__check {
    margin-top: 0.25rem;
    width: 1.25rem; height: 1.25rem;
    flex-shrink: 0;
    border-radius: 50%;
    background: hsl(var(--accent) / 0.15);
    display: inline-flex; align-items: center; justify-content: center;
    color: hsl(var(--accent));
}
.cred-list__check .pike-icon { stroke-width: 3; }

/* Why Trial Matters */
.why-trial { position: relative; padding: 5rem 0; background: var(--gradient-forest); color: hsl(var(--primary-foreground)); overflow: hidden; }
.why-trial__inner { position: relative; }
.why-trial__intro { max-width: 56rem; margin-bottom: 3.5rem; }
.why-trial__grid { display: grid; gap: 1.5rem; }
@media (min-width: 640px) { .why-trial__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .why-trial__grid { grid-template-columns: repeat(4, 1fr); } }
.why-trial__card { background: hsl(var(--primary-foreground) / 0.05); border: 1px solid hsl(var(--primary-foreground) / 0.1); padding: 1.5rem; border-radius: var(--radius); }
.why-trial__icon { display: inline-flex; width: 2.75rem; height: 2.75rem; border-radius: var(--radius); background: hsl(var(--accent) / 0.15); border: 1px solid hsl(var(--accent) / 0.3); align-items: center; justify-content: center; color: hsl(var(--accent)); margin-bottom: 1rem; }
.why-trial__card h3 { color: hsl(var(--primary-foreground)); font-size: 1.125rem; line-height: 1.3; margin: 0 0 0.5rem; }
.why-trial__card p { color: hsl(var(--primary-foreground) / 0.7); font-size: 0.875rem; line-height: 1.7; margin: 0; }

/* Process */
.process { padding: 5rem 0; background: hsl(var(--secondary) / 0.4); }
.process__grid { display: grid; gap: 1.5rem; position: relative; }
@media (min-width: 768px) { .process__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .process__grid { grid-template-columns: repeat(4, 1fr); } }
.process__connector { display: none; position: absolute; top: 3rem; left: 12.5%; right: 12.5%; height: 1px; background: linear-gradient(90deg, transparent, hsl(var(--accent) / 0.4), transparent); }
@media (min-width: 1024px) { .process__connector { display: block; } }
.process__card { background: hsl(var(--card)); border: 1px solid hsl(var(--border)); padding: 1.5rem; height: 100%; }
.process__head { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 1.5rem; }
.process__icon { display: inline-flex; width: 3.5rem; height: 3.5rem; background: hsl(var(--primary)); color: hsl(var(--primary-foreground)); border-radius: var(--radius); align-items: center; justify-content: center; }
.process__num { font-family: 'Cormorant Garamond', serif; font-size: 3rem; color: hsl(var(--accent) / 0.3); line-height: 1; }
.process__card h3 { font-size: 1.25rem; margin: 0 0 0.75rem; color: hsl(var(--primary)); }
.process__card p { color: hsl(var(--muted-foreground)); font-size: 0.875rem; line-height: 1.7; margin: 0; }
.process__outro { margin-top: 3.5rem; }
.process__outro .section-lede { margin-left: auto; margin-right: auto; max-width: 36rem; }

/* Case Results */
.case-results { position: relative; padding: 5rem 0; background: hsl(var(--foreground)); color: hsl(var(--primary-foreground)); overflow: hidden; }
.case-results__bg { position: absolute; inset: 0; z-index: -1; opacity: 0.2; }
.case-results__bg img { width: 100%; height: 100%; object-fit: cover; }
.case-results__bg-overlay { position: absolute; inset: 0; background: hsl(var(--foreground) / 0.8); }
.case-results__head { display: flex; flex-direction: column; gap: 1.5rem; margin-bottom: 3.5rem; }
@media (min-width: 768px) { .case-results__head { flex-direction: row; justify-content: space-between; align-items: flex-end; } }
.case-results__head .section-title { color: hsl(var(--primary-foreground)); }
.case-results__disclaimer { color: hsl(var(--primary-foreground) / 0.7); font-size: 0.875rem; max-width: 28rem; }

.case-results__grid { display: grid; gap: 1.5rem; }
@media (min-width: 768px) { .case-results__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .case-results__grid { grid-template-columns: repeat(3, 1fr); } }

.case-card {
    display: flex;
    flex-direction: column;
    background: hsl(var(--foreground) / 0.4);
    backdrop-filter: blur(4px);
    border: 1px solid hsl(var(--primary-foreground) / 0.15);
    padding: 1.75rem;
    transition: border-color 0.3s;
}
.case-card:hover { border-color: hsl(var(--accent)); }
.case-card--feature { background: hsl(var(--primary) / 0.4); }
@media (min-width: 1024px) { .case-card--feature { grid-row: span 2; justify-content: space-between; } }
.case-card__head { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; margin-bottom: 1rem; }
.case-card__type { font-size: 0.625rem; text-transform: uppercase; letter-spacing: 0.2em; color: hsl(var(--primary-foreground) / 0.6); }
.case-card__outcome { font-size: 0.625rem; text-transform: uppercase; letter-spacing: 0.08em; padding: 0.25rem 0.5rem; background: hsl(var(--accent)); color: hsl(var(--accent-foreground)); font-weight: 700; white-space: nowrap; }
.case-card__title { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; color: hsl(var(--primary-foreground)); margin: 0 0 0.75rem; font-style: italic; }
.case-card__summary { color: hsl(var(--primary-foreground) / 0.7); font-size: 0.875rem; line-height: 1.7; margin: 0; }
.case-card__cta { margin-top: 1.5rem; padding-top: 1rem; border-top: 1px solid hsl(var(--primary-foreground) / 0.1); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: hsl(var(--accent)); display: flex; align-items: center; gap: 0.5rem; opacity: 0.7; transition: opacity 0.3s; }
.case-card:hover .case-card__cta { opacity: 1; }
.case-card--cta { background: hsl(var(--accent) / 0.05); border: 1px solid hsl(var(--accent) / 0.3); align-items: flex-start; justify-content: center; }
.case-card--cta h3 { font-size: 1.5rem; color: hsl(var(--primary-foreground)); margin: 0 0 0.75rem; }
.case-card--cta p { color: hsl(var(--primary-foreground) / 0.75); font-size: 0.875rem; margin-bottom: 1.5rem; }

/* Areas served */
.areas-served { padding: 5rem 0; background: hsl(var(--secondary)); }
.counties-grid { display: grid; gap: 1px; background: hsl(var(--border)); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-card); }
@media (min-width: 640px) { .counties-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .counties-grid { grid-template-columns: repeat(4, 1fr); } }
.county-card { background: hsl(var(--card)); padding: 1.5rem; display: block; transition: background-color 0.3s; }
.county-card:hover { background: hsl(var(--background)); }
.county-card__head { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 1rem; }
.county-card__head h3 { font-size: 1.125rem; color: hsl(var(--primary)); margin: 0; transition: color 0.2s; }
.county-card:hover .county-card__head h3 { color: hsl(var(--accent)); }
.county-card ul { display: flex; flex-direction: column; gap: 0.375rem; font-size: 0.875rem; color: hsl(var(--muted-foreground)); }
.county-card li { display: flex; align-items: baseline; gap: 0.5rem; }
.county-card__dot { display: inline-block; height: 0.25rem; width: 0.25rem; border-radius: 50%; background: hsl(var(--accent) / 0.6); flex-shrink: 0; }
.areas-served__outro { margin-top: 3rem; }
.areas-served__outro p { color: hsl(var(--muted-foreground)); margin-bottom: 1rem; }

/* Testimonials carousel */
.testimonials { padding: 5rem 0; background: hsl(var(--background)); }
.testimonials__stars { display: flex; align-items: center; justify-content: center; gap: 0.25rem; margin-bottom: 0.75rem; }
.testimonials .section-intro p { color: hsl(var(--muted-foreground)); }

.carousel { position: relative; }
.carousel__viewport { overflow: hidden; }
.carousel__track { display: flex; transition: transform 0.5s var(--transition-smooth); margin: 0 -0.5rem; }
.carousel__slide { flex: 0 0 100%; padding: 0 0.5rem; }
@media (min-width: 768px) { .carousel__slide { flex-basis: 50%; } }
@media (min-width: 1024px) { .carousel__slide { flex-basis: 33.333%; } }

.testimonial-card {
    height: 100%;
    background: hsl(var(--card));
    border: 1px solid hsl(var(--border));
    padding: 1.75rem;
    margin: 0;
    display: flex;
    flex-direction: column;
}
.testimonial-card--feature { background: hsl(var(--primary)); color: hsl(var(--primary-foreground)); border-color: hsl(var(--accent)); }
.testimonial-card__quote { color: hsl(var(--accent) / 0.6); margin-bottom: 1rem; }
.testimonial-card--feature .testimonial-card__quote { color: hsl(var(--accent)); }
.testimonial-card blockquote { font-family: 'Cormorant Garamond', serif; font-style: italic; line-height: 1.6; font-size: 1.125rem; flex: 1; margin: 0 0 1.5rem; color: hsl(var(--foreground)); }
.testimonial-card--feature blockquote { color: hsl(var(--primary-foreground)); }
.testimonial-card figcaption { display: flex; align-items: center; justify-content: space-between; padding-top: 1rem; border-top: 1px solid hsl(var(--border) / 0.5); margin-top: auto; }
.testimonial-card__name { font-weight: 600; font-size: 0.875rem; color: hsl(var(--primary)); }
.testimonial-card--feature .testimonial-card__name { color: hsl(var(--accent)); }
.testimonial-card__title { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: hsl(var(--muted-foreground)); margin-top: 0.25rem; }
.testimonial-card--feature .testimonial-card__title { color: hsl(var(--primary-foreground) / 0.6); }
.testimonial-card__stars { display: flex; gap: 0.125rem; }

.carousel__btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 2.75rem;
    height: 2.75rem;
    border: 1px solid hsl(var(--border));
    background: hsl(var(--card));
    border-radius: 50%;
    color: hsl(var(--primary));
    font-size: 1rem;
    z-index: 2;
    transition: all 0.2s;
    box-shadow: var(--shadow-card);
}
.carousel__btn:hover { background: hsl(var(--primary)); color: hsl(var(--primary-foreground)); border-color: hsl(var(--primary)); }
.carousel__btn--prev { left: -1rem; }
.carousel__btn--next { right: -1rem; }
@media (min-width: 768px) { .carousel__btn--prev { left: -1.5rem; } .carousel__btn--next { right: -1.5rem; } }
.carousel__dots { display: flex; justify-content: center; gap: 0.5rem; margin-top: 1.5rem; }
.carousel__dot { width: 0.5rem; height: 0.5rem; border-radius: 50%; background: hsl(var(--border)); border: 0; padding: 0; cursor: pointer; transition: background 0.2s; }
.carousel__dot.is-active { background: hsl(var(--accent)); }

/* Educational + FAQ accordions */
.educational { padding: 5rem 0; background: hsl(var(--secondary)); }
.educational__grid, .faq__grid { display: grid; gap: 3rem; }
@media (min-width: 1024px) { .educational__grid, .faq__grid { grid-template-columns: 4fr 8fr; } }
.educational__intro p { color: hsl(var(--muted-foreground)); margin-bottom: 1.5rem; }
.faq { padding: 5rem 0; background: hsl(var(--background)); }
.faq__intro p { color: hsl(var(--muted-foreground)); margin-bottom: 1.5rem; }
.educational__list, .faq__list { display: flex; flex-direction: column; gap: 0.75rem; }

.accordion-item { border: 1px solid hsl(var(--border)); background: hsl(var(--card)); padding: 0 1.5rem; border-radius: var(--radius); transition: border-color 0.3s; }
.accordion-item[open] { border-color: hsl(var(--accent)); }
.accordion-item summary {
    list-style: none;
    cursor: pointer;
    padding: 1.25rem 0;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.125rem;
    color: hsl(var(--primary));
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    position: relative;
}
.accordion-item summary::-webkit-details-marker { display: none; }
.accordion-item summary > span { display: inline-flex; align-items: center; gap: 0.75rem; }
.accordion-item summary::after {
    content: '';
    width: 0.75rem;
    height: 0.75rem;
    border-right: 2px solid hsl(var(--accent));
    border-bottom: 2px solid hsl(var(--accent));
    transform: rotate(45deg);
    transition: transform 0.2s;
    flex-shrink: 0;
}
.accordion-item[open] summary::after { transform: rotate(-135deg); }
.accordion-item__body { color: hsl(var(--muted-foreground)); line-height: 1.7; padding-bottom: 1.25rem; }
.educational .accordion-item__body { padding-left: 2rem; }

/* Consult & Contact */
.consult { padding: 5rem 0; background: hsl(var(--background)); }
.consult .section-intro p { color: hsl(var(--muted-foreground)); }

.contact { position: relative; padding: 5rem 0; background: var(--gradient-forest); color: hsl(var(--primary-foreground)); overflow: hidden; }
.contact__grid { position: relative; display: grid; gap: 3rem; }
@media (min-width: 1024px) { .contact__grid { grid-template-columns: 5fr 7fr; gap: 4rem; } }
.contact__list { display: flex; flex-direction: column; gap: 1.25rem; margin: 2rem 0 2.5rem; }
.contact__list li { display: flex; align-items: flex-start; gap: 1rem; }
.contact__icon { display: inline-flex; width: 2.5rem; height: 2.5rem; border-radius: var(--radius); background: hsl(var(--accent) / 0.15); border: 1px solid hsl(var(--accent) / 0.3); align-items: center; justify-content: center; color: hsl(var(--accent)); flex-shrink: 0; }
.contact__label { font-size: 0.6875rem; text-transform: uppercase; letter-spacing: 0.18em; color: hsl(var(--primary-foreground) / 0.6); }
.contact__list a { color: hsl(var(--primary-foreground)); font-weight: 500; transition: color 0.2s; }
.contact__list a:hover { color: hsl(var(--accent)); }
.contact__list span { color: hsl(var(--primary-foreground)); font-weight: 500; }
.contact__privilege { display: flex; align-items: center; gap: 0.75rem; font-size: 0.75rem; color: hsl(var(--primary-foreground) / 0.7); padding-top: 1.5rem; border-top: 1px solid hsl(var(--primary-foreground) / 0.1); }

.contact__form-wrap {
    position: relative;
    background: hsl(var(--card));
    color: hsl(var(--card-foreground));
    padding: 2rem;
    box-shadow: var(--shadow-elegant);
}
@media (min-width: 768px) { .contact__form-wrap { padding: 2.5rem; } }
.contact__badge {
    position: absolute;
    top: -1rem;
    left: 2rem;
    background: hsl(var(--accent));
    color: hsl(var(--accent-foreground));
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-weight: 700;
    padding: 0.4rem 0.75rem;
}

/* Forms */
.contact-form { display: flex; flex-direction: column; gap: 1.25rem; }
.contact-form label { display: flex; flex-direction: column; gap: 0.5rem; }
.contact-form label > span { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: hsl(var(--muted-foreground)); }
.contact-form input,
.contact-form select,
.contact-form textarea {
    width: 100%;
    padding: 0.625rem 0.875rem;
    border: 1px solid hsl(var(--input));
    border-radius: var(--radius);
    background: hsl(var(--background));
    color: hsl(var(--foreground));
    font: inherit;
    font-size: 0.875rem;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
    outline: none;
    border-color: hsl(var(--ring));
    box-shadow: 0 0 0 3px hsl(var(--ring) / 0.15);
}
.contact-form input,
.contact-form select { height: 2.75rem; }
.contact-form textarea { resize: vertical; min-height: 7rem; }
.form-row { display: grid; gap: 1.25rem; }
@media (min-width: 640px) { .form-row { grid-template-columns: 1fr 1fr; } }
.form-disclaimer { display: flex; align-items: center; justify-content: center; gap: 0.5rem; font-size: 0.75rem; color: hsl(var(--muted-foreground)); margin-top: 0.5rem; }
.form-success { background: hsl(148 55% 92%); color: hsl(148 55% 18%); border: 1px solid hsl(148 55% 60%); padding: 1rem; border-radius: var(--radius); margin-bottom: 1.5rem; }
.form-error { background: hsl(0 80% 95%); color: hsl(0 70% 35%); border: 1px solid hsl(0 70% 60%); padding: 1rem; border-radius: var(--radius); margin-bottom: 1.5rem; }

/* Footer */
.site-footer { background: hsl(var(--foreground)); color: hsl(var(--primary-foreground) / 0.8); padding: 4rem 0 2rem; margin-bottom: 4rem; }
@media (min-width: 1024px) { .site-footer { margin-bottom: 0; } }
.site-footer__grid { display: grid; gap: 2.5rem; margin-bottom: 3rem; }
@media (min-width: 768px) { .site-footer__grid { grid-template-columns: 4fr 2fr 3fr 3fr; } }
.site-footer__logo { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1.25rem; }
.site-footer__mark { display: flex; width: 3rem; height: 3rem; border: 2px solid hsl(var(--accent)); align-items: center; justify-content: center; font-family: 'Cormorant Garamond', serif; font-size: 1.25rem; font-weight: 700; color: hsl(var(--accent)); }
.site-footer__name { font-family: 'Cormorant Garamond', serif; font-size: 1.25rem; color: hsl(var(--primary-foreground)); }
.site-footer__tag { font-size: 0.625rem; text-transform: uppercase; letter-spacing: 0.22em; color: hsl(var(--primary-foreground) / 0.5); margin-top: 0.125rem; }
.site-footer__about { font-size: 0.875rem; line-height: 1.7; color: hsl(var(--primary-foreground) / 0.65); max-width: 28rem; margin-bottom: 1.5rem; }
.site-footer__pulse { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: hsl(var(--accent)); }
.pulse-dot { display: inline-block; height: 0.375rem; width: 0.375rem; border-radius: 50%; background: hsl(var(--accent)); animation: pulse 2s infinite; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
.site-footer__col h4 { font-family: 'Cormorant Garamond', serif; font-size: 1.125rem; color: hsl(var(--primary-foreground)); margin: 0 0 1rem; }
.site-footer__col ul { display: flex; flex-direction: column; gap: 0.5rem; font-size: 0.875rem; }
.site-footer__col a { transition: color 0.2s; }
.site-footer__col a:hover { color: hsl(var(--accent)); }
.site-footer__counties { color: hsl(var(--primary-foreground) / 0.7); }
.site-footer__contact a { display: flex; align-items: flex-start; gap: 0.75rem; transition: color 0.2s; }
.site-footer__contact a:hover { color: hsl(var(--accent)); }
.site-footer__phone { font-family: 'Cormorant Garamond', serif; font-size: 1.25rem; color: hsl(var(--primary-foreground)); }
.site-footer__address { display: flex; align-items: flex-start; gap: 0.75rem; }
.site-footer__bottom { border-top: 1px solid hsl(var(--primary-foreground) / 0.1); padding-top: 1.5rem; display: flex; flex-direction: column; gap: 0.75rem; font-size: 0.75rem; color: hsl(var(--primary-foreground) / 0.5); }
@media (min-width: 768px) { .site-footer__bottom { flex-direction: row; align-items: center; justify-content: space-between; } }
.site-footer__legal { display: flex; flex-direction: column; gap: 0.5rem; }
@media (min-width: 768px) { .site-footer__legal { flex-direction: row; align-items: center; gap: 1.25rem; } }
.site-footer__legal a:hover { color: hsl(var(--accent)); }

/* Sticky call bar (mobile) */
.sticky-call-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 50;
    background: hsl(var(--primary));
    color: hsl(var(--primary-foreground));
    border-top: 1px solid hsl(var(--accent) / 0.4);
    box-shadow: var(--shadow-elegant);
    display: grid;
    grid-template-columns: 1fr 1fr;
}
@media (min-width: 1024px) { .sticky-call-bar { display: none; } }
.sticky-call-bar a {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1rem;
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    transition: filter 0.2s;
    border-right: 1px solid hsl(var(--primary-foreground) / 0.15);
}
.sticky-call-bar__cta { background: hsl(var(--accent)); color: hsl(var(--accent-foreground)); border-right: 0; }
.sticky-call-bar__cta:hover { filter: brightness(1.1); }
.sticky-call-bar__call:hover { background: hsl(var(--primary-glow)); }

/* Generic page section (for blog/contact/page templates) */
.page-section { padding: 4rem 0 5rem; }
.page-section--narrow { padding-bottom: 0; }
.page-header { margin-bottom: 2rem; }
.page-title { font-size: clamp(2rem, 1rem + 3vw, 3rem); }
.page-intro { color: hsl(var(--muted-foreground)); font-size: 1.125rem; }
.post-list { display: grid; gap: 2rem; }
.post-card { display: grid; gap: 1rem; padding-bottom: 2rem; border-bottom: 1px solid hsl(var(--border)); }
@media (min-width: 640px) { .post-card { grid-template-columns: 1fr 2fr; gap: 1.5rem; } }
.post-card__title { font-size: 1.5rem; margin: 0.5rem 0; }
.post-card__title a { color: hsl(var(--primary)); transition: color 0.2s; }
.post-card__title a:hover { color: hsl(var(--accent)); }
.post-card__excerpt { color: hsl(var(--muted-foreground)); font-size: 0.9375rem; line-height: 1.7; }
.post-card__more { display: inline-block; margin-top: 0.5rem; color: hsl(var(--accent)); font-weight: 600; font-size: 0.875rem; }
.post-card__more:hover { text-decoration: underline; }
.post-single .post-content { margin-top: 2rem; line-height: 1.8; font-size: 1.0625rem; }
.post-single .post-content > * { margin-bottom: 1.25rem; }
.post-single .post-content h2 { margin-top: 2rem; font-size: 1.875rem; }
.post-single .post-content h3 { margin-top: 1.5rem; font-size: 1.5rem; }
.post-thumb { margin: 1rem 0 2rem; }

.pagination { margin-top: 2.5rem; display: flex; gap: 0.5rem; flex-wrap: wrap; }
.pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 2.25rem; height: 2.25rem; padding: 0 0.625rem; border: 1px solid hsl(var(--border)); border-radius: var(--radius); color: hsl(var(--primary)); font-weight: 500; font-size: 0.875rem; }
.pagination .page-numbers.current { background: hsl(var(--primary)); color: hsl(var(--primary-foreground)); border-color: hsl(var(--primary)); }
.pagination .page-numbers:hover:not(.current) { background: hsl(var(--secondary)); }

/* Widgets */
.widget { margin-bottom: 2rem; }
.widget-title { font-size: 1.25rem; margin-bottom: 0.75rem; }

/* Print */
@media print {
    .site-header, .site-footer, .sticky-call-bar, .topbar, .hero__media { display: none !important; }
}
