/* ==========================================================================
   Perficient 2026 Theme — Design System CSS
   Based on Storybook design tokens + Figma mockups
   ========================================================================== */

/* --------------------------------------------------------------------------
   @font-face Declarations
   -------------------------------------------------------------------------- */

@font-face {
    font-family: 'FK Screamer Legacy';
    src: url('../../fonts/FKScreamerLegacy-Upright.woff2') format('woff2'),
         url('../../fonts/FKScreamerLegacy-Upright.woff') format('woff');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Noe Display';
    src: url('../../fonts/NoeDisplay-Regular.woff2') format('woff2'),
         url('../../fonts/NoeDisplay-Regular.woff') format('woff');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Noe Display';
    src: url('../../fonts/NoeDisplay-Bold.woff2') format('woff2'),
         url('../../fonts/NoeDisplay-Bold.woff') format('woff');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Untitled Sans';
    src: url('../../fonts/untitled-sans-regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Untitled Sans';
    src: url('../../fonts/untitled-sans-regular-italic.woff2') format('woff2');
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Untitled Sans';
    src: url('../../fonts/untitled-sans-bold.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Untitled Sans';
    src: url('../../fonts/untitled-sans-bold-italic.woff2') format('woff2');
    font-weight: 700;
    font-style: italic;
    font-display: swap;
}

/* --------------------------------------------------------------------------
   CSS Custom Properties — Design Tokens
   -------------------------------------------------------------------------- */

:root {
    /* Colors — Primary */
    --color-perficient-green: #075056;
    --color-navy-blue: #024879;
    --color-brand-black: #1B2227;
    --color-turquoise: #71D8C5;
    --color-poppy: #FE3A39;

    /* Colors — Neutral */
    --color-white: #FFFFFF;
    --color-light-grey: #e6eff6;
    --color-grey: #C5DCEE;

    /* Derived Colors */
    --color-bg: var(--color-grey);
    --color-bg-card: var(--color-white);
    --color-bg-light: var(--color-light-grey);
    --color-text: var(--color-brand-black);
    --color-text-dark: var(--color-brand-black);
    --color-accent: var(--color-perficient-green);
    --color-link: var(--color-perficient-green);
    --color-link-hover: var(--color-navy-blue);
    --color-tag: var(--color-perficient-green);
    --color-divider: rgba(27, 34, 39, 0.15);

    /* Font Families */
    --font-display: 'FK Screamer Legacy', 'Impact', sans-serif;
    --font-serif: 'Noe Display', 'Georgia', serif;
    --font-sans: 'Untitled Sans', system-ui, -apple-system, sans-serif;

    /* Font Sizes — Desktop (default) */
    --fs-h1: 6.25rem;    /* 100px */
    --fs-h2: 4.75rem;    /* 76px */
    --fs-h3: 4rem;       /* 64px */
    --fs-h4: 2.5rem;     /* 40px */
    --fs-h5: 1.5rem;     /* 24px */
    --fs-stat: 6.25rem;  /* 100px */
    --fs-overline: 0.875rem; /* 14px */
    --fs-p1: 1.125rem;   /* 18px */
    --fs-p2: 1rem;       /* 16px */
    --fs-p3: 0.875rem;   /* 14px */
    --fs-utility: 0.75rem; /* 12px */

    /* Line Heights */
    --lh-display: 0.85;
    --lh-serif: 1.1;
    --lh-body: 1.3;
    --lh-tight: 1.2;

    /* Spacing Scale */
    --space-xs: 0.5rem;    /* 8px */
    --space-sm: 1rem;      /* 16px */
    --space-md: 1.5rem;    /* 24px */
    --space-lg: 2rem;      /* 32px */
    --space-xl: 3rem;      /* 48px */
    --space-2xl: 4rem;     /* 64px */
    --space-3xl: 6rem;     /* 96px */
    --space-4xl: 8rem;     /* 128px */

    /* Layout */
    --container-max: 1280px;
    --container-narrow: 800px;
    --container-padding: 1.5rem;
    --grid-gap: 1.5rem;

    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-base: 250ms ease;
    --transition-slow: 400ms ease;

    /* Border Radius */
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 16px;
}

/* --------------------------------------------------------------------------
   Mobile Typography Overrides
   -------------------------------------------------------------------------- */

@media (max-width: 1023px) {
    :root {
        --fs-h1: 4.5rem;     /* 72px */
        --fs-h2: 3.44rem;    /* 55px */
        --fs-h3: 3rem;       /* 48px */
        --fs-h4: 1.75rem;    /* 28px */
        --fs-h5: 1.125rem;   /* 18px */
        --fs-stat: 5rem;     /* 80px */
        --fs-overline: 0.75rem; /* 12px */
        --container-padding: 1rem;
        --grid-gap: 1rem;
    }
}

/* --------------------------------------------------------------------------
   Reset / Base
   -------------------------------------------------------------------------- */

*,
*::before,
*::after {
    box-sizing: border-box;
    /* margin/padding reset removed — Tailwind v4 handles this in @layer base.
       An unlayered reset here overrides ALL Tailwind margin/padding utilities
       (e.g., xl:mx-auto, py-10) because unlayered CSS beats @layer in cascade. */
}

html {
    font-size: 100%;
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-sans);
    font-size: var(--fs-p2);
    font-weight: 400;
    line-height: var(--lh-body);
    color: var(--color-text);
    background: linear-gradient(var(--color-grey) 0%, #DEF0FF 25%, #EEF7FF 50%, #DEF0FF 75%, var(--color-grey) 100%);
    background-attachment: fixed;
    -webkit-font-smoothing: auto;
    -moz-osx-font-smoothing: auto;
}

/* img reset removed — Tailwind preflight handles it in @layer base.
   Unlayered img rules override ALL Tailwind utilities (h-[41px], etc.) */

a {
    color: var(--color-link);
    text-decoration: none;
    transition: color var(--transition-fast);
}

a:hover {
    color: var(--color-link-hover);
}

ul, ol {
    list-style: none;
}

button {
    cursor: pointer;
    border: none;
    background: none;
    font-family: inherit;
}

/* --------------------------------------------------------------------------
   Typography
   -------------------------------------------------------------------------- */

h1, .h1 {
    font-family: var(--font-display);
    font-size: var(--fs-h1);
    font-weight: 700;
    line-height: var(--lh-display);
    text-transform: uppercase;
    letter-spacing: -0.02em;
}

h2, .h2 {
    font-family: var(--font-display);
    font-size: var(--fs-h2);
    font-weight: 700;
    line-height: var(--lh-display);
    text-transform: uppercase;
    letter-spacing: -0.02em;
}

h3, .h3 {
    font-family: var(--font-display);
    font-size: var(--fs-h3);
    font-weight: 700;
    line-height: var(--lh-display);
    text-transform: uppercase;
    letter-spacing: -0.01em;
}

h4, .h4 {
    font-family: var(--font-serif);
    font-size: var(--fs-h4);
    font-weight: 400;
    line-height: var(--lh-serif);
}

h5, .h5 {
    font-family: var(--font-serif);
    font-size: var(--fs-h5);
    font-weight: 400;
    line-height: var(--lh-serif);
}

.overline {
    font-family: var(--font-sans);
    font-size: var(--fs-overline);
    font-weight: 700;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.stat {
    font-family: var(--font-serif);
    font-size: var(--fs-stat);
    font-weight: 700;
    line-height: var(--lh-display);
}

.utility-text {
    font-family: var(--font-sans);
    font-size: var(--fs-utility);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.p1 { font-size: var(--fs-p1); }
.p2 { font-size: var(--fs-p2); }
.p3 { font-size: var(--fs-p3); }

/* --------------------------------------------------------------------------
   Layout — Container & Grid
   -------------------------------------------------------------------------- */

.container {
    width: 100%;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-padding);
}

.container--narrow {
    max-width: var(--container-narrow);
}

.grid {
    display: grid;
    gap: var(--grid-gap);
}

.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 767px) {
    .grid--2,
    .grid--3,
    .grid--4 {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 768px) and (max-width: 1023px) {
    .grid--3,
    .grid--4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Production CSS Overrides
   The Vercel site uses scroll-reveal animations (data-reveal + JS) that set
   elements to opacity:0 initially. Since we don't load their animation JS,
   force all revealed components to be visible.
   -------------------------------------------------------------------------- */

.component[data-reveal] {
    opacity: 1 !important;
    transform: none !important;
}

/* --------------------------------------------------------------------------
   WordPress Admin Bar — Adjust fixed mega panels
   When logged in, WP adds a 32px admin bar (46px on mobile ≤782px).
   The dynamic JS in theme.js handles mega panel positioning, but the
   admin bar offset needs to be accounted for.
   -------------------------------------------------------------------------- */

.admin-bar .mega-menu-panel {
    /* JS sets top dynamically; admin bar is already accounted for
       because getBoundingClientRect().bottom includes the admin bar offset */
}

/* --------------------------------------------------------------------------
   Mega Menu — Green CTA panel fix (B018)
   Production CSS overrides inline Tailwind on .feature-cta inside mega menu.
   Forces vertical layout, proper padding, and prevents text cutoff.
   -------------------------------------------------------------------------- */

/* Mega menu CTA panel — no overrides needed.
   FK Screamer Legacy font loads correctly now, so the Vercel production
   Tailwind CSS handles the green panel layout natively at 68px/0.85 leading.
   Font fix: replaced broken symlinks in /fonts/ with real files (2026-03-23). */

/* --------------------------------------------------------------------------
   Header/Footer — Force nav link colors to black (B015)
   Browser default link blue can override Tailwind text-brand-black on <a> tags
   when specificity is insufficient. This ensures all shared header/footer
   navigation links render in the brand black color.
   -------------------------------------------------------------------------- */

.prft-public-header a,
.prft-public-footer a,
.prft-public-header button {
    color: var(--color-brand-black, #1B2227);
}

.prft-public-header a:visited,
.prft-public-footer a:visited {
    color: var(--color-brand-black, #1B2227);
}

/* Green section buttons keep their own Tailwind color classes (text-brand-black
   normal, hover:bg-turquoise hover:text-black on hover). Don't override. */

/* --------------------------------------------------------------------------
   Header — Synced from Perficient Vercel site (Tailwind classes)
   Production Tailwind CSS loaded via perficient-production.css.
   These are WP-specific overrides and mobile nav behavior only.
   Last synced: 2026-03-04
   -------------------------------------------------------------------------- */

/* Mobile nav overlay: when hamburger is toggled, show the nav container */
.prft-public-header.mobile-menu-active {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999;
    background: white;
    overflow-y: auto;
    /* Make header itself a flex column so we can reorder children */
    display: flex;
    flex-direction: column;
}

/* Main header bar (logo + nav + hamburger) comes first */
.prft-public-header.mobile-menu-active .main-header-bar {
    order: 1;
}

/* Utility nav (About Us, Careers, Contact) comes after main nav */
.prft-public-header.mobile-menu-active .utility-nav-wrapper.mobile-nav-open {
    display: block !important;
    padding: 0 24px;
    order: 2;
}

/* Break the header bar's fixed-height row so nav can wrap below logo */
.prft-public-header.mobile-menu-active .main-header-bar > div {
    flex-wrap: wrap;
    height: auto;
    align-items: center;
    padding-bottom: 0;
}

/* Logo + hamburger stay in a row at the top */
.prft-public-header.mobile-menu-active .logo {
    flex: 1;
}

/* When mobile menu is active, show items that are normally hidden */
.prft-public-header.mobile-menu-active .main-nav-container.mobile-nav-open {
    display: flex !important;
    flex-direction: column;
    gap: 0;
    padding: 0 24px;
    padding-top: 1rem;
    align-items: stretch;
    flex-basis: 100%;
    order: 10;
}

/* In mobile menu, hide the desktop items (hidden lg:block -> still hidden on mobile) */
.prft-public-header.mobile-menu-active .main-nav-container .hidden.lg\:block {
    display: none !important;
}

/* In mobile menu, show the mobile items (lg:hidden -> visible) */
.prft-public-header.mobile-menu-active .main-nav-container .lg\:hidden {
    display: block !important;
}

/* In mobile menu, hide desktop utility nav, show mobile utility nav */
.prft-public-header.mobile-menu-active .utility-navigation.hidden.lg\:block {
    display: none !important;
}

.prft-public-header.mobile-menu-active .utility-navigation-mobile.lg\:hidden {
    display: block !important;
}

/* Accordion chevron rotation transition */
.mobile-nav-accordion svg {
    transition: transform 200ms ease;
}

/* --------------------------------------------------------------------------
   Hero
   -------------------------------------------------------------------------- */

.hero {
    padding: var(--space-3xl) 0 var(--space-2xl);
}

.hero__overline {
    color: var(--color-perficient-green);
    margin-bottom: var(--space-md);
}

.hero__title {
    max-width: 900px;
    margin-bottom: var(--space-md);
}

.hero__description {
    font-size: var(--fs-p1);
    line-height: var(--lh-body);
    max-width: 700px;
    opacity: 0.85;
}

/* --------------------------------------------------------------------------
   Tag / Category Pill
   -------------------------------------------------------------------------- */

.tag {
    display: inline-block;
    font-family: var(--font-sans);
    font-size: var(--fs-utility);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-perficient-green);
    border: 1px solid var(--color-perficient-green);
    padding: 0.25em 0.75em;
    border-radius: 2px;
    transition: all var(--transition-fast);
}

.tag:hover {
    background-color: var(--color-perficient-green);
    color: var(--color-white);
}

.tag--solid {
    background-color: var(--color-turquoise);
    color: var(--color-brand-black);
    border-color: var(--color-turquoise);
}

.tag--solid:hover {
    background-color: var(--color-perficient-green);
    border-color: var(--color-perficient-green);
    color: var(--color-white);
}

/* --------------------------------------------------------------------------
   Post Card
   -------------------------------------------------------------------------- */

.card {
    display: flex;
    flex-direction: column;
    background-color: var(--color-white);
    border: 1px solid var(--color-divider);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
}

.card__image {
    display: block;
    aspect-ratio: 16 / 10;
    overflow: hidden;
}

.card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.card:hover .card__image img {
    transform: scale(1.05);
}

.card__body {
    padding: var(--space-md);
    display: flex;
    flex-direction: column;
    flex: 1;
}

.card__category {
    margin-bottom: var(--space-xs);
}

.card__title {
    font-family: var(--font-serif);
    font-size: var(--fs-h5);
    font-weight: 400;
    line-height: var(--lh-serif);
    margin-bottom: var(--space-sm);
    text-transform: none;
    letter-spacing: normal;
}

.card__title a {
    color: var(--color-brand-black);
}

.card__title a:hover {
    color: var(--color-perficient-green);
}

.card__excerpt {
    font-size: var(--fs-p3);
    opacity: 0.8;
    line-height: var(--lh-body);
    margin-bottom: var(--space-sm);
    flex: 1;
}

.card__meta {
    font-size: var(--fs-utility);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    opacity: 0.6;
    margin-top: auto;
}

/* Featured Card — Large */
.card--featured {
    grid-column: 1 / -1;
}

@media (min-width: 768px) {
    .card--featured {
        display: grid;
        grid-template-columns: 1.2fr 1fr;
    }

    .card--featured .card__image {
        aspect-ratio: auto;
        min-height: 400px;
    }

    .card--featured .card__body {
        padding: var(--space-xl);
        justify-content: center;
    }

    .card--featured .card__title {
        font-family: var(--font-serif);
        font-size: var(--fs-h4);
    }

    .card--featured .card__excerpt {
        font-size: var(--fs-p1);
    }
}

/* --------------------------------------------------------------------------
   Post Grid
   -------------------------------------------------------------------------- */

.post-grid {
    display: grid;
    gap: var(--grid-gap);
    grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 1023px) {
    .post-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 639px) {
    .post-grid {
        grid-template-columns: 1fr;
    }
}

/* --------------------------------------------------------------------------
   Article — Single Post
   -------------------------------------------------------------------------- */

.article-header {
    padding: var(--space-2xl) 0;
    border-bottom: 1px solid var(--color-divider);
    margin-bottom: var(--space-xl);
}

.article-header__category {
    margin-bottom: var(--space-sm);
}

.article-header__title {
    font-family: var(--font-serif);
    font-size: clamp(2rem, 4vw, 3.5rem);
    font-weight: 700;
    line-height: 1.1;
    margin-bottom: var(--space-md);
    max-width: 900px;
    text-transform: none;
    letter-spacing: normal;
}

.article-header__meta {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--fs-p3);
    opacity: 0.7;
}

.article-header__meta a {
    color: var(--color-perficient-green);
}

.article-header__image {
    margin-top: var(--space-xl);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.article-header__image img {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

/* Article Content — Rich Text */
.article-content {
    max-width: var(--container-narrow);
    margin-inline: auto;
    padding-bottom: var(--space-3xl);
}

.article-content p {
    font-size: var(--fs-p1);
    line-height: 1.7;
    margin-bottom: var(--space-md);
}

.article-content h2 {
    font-family: var(--font-serif);
    font-size: var(--fs-h4);
    font-weight: 700;
    margin-top: var(--space-2xl);
    margin-bottom: var(--space-md);
    text-transform: none;
    letter-spacing: 0;
}

.article-content h3 {
    font-family: var(--font-serif);
    font-size: var(--fs-h5);
    font-weight: 700;
    margin-top: var(--space-xl);
    margin-bottom: var(--space-sm);
    text-transform: none;
    letter-spacing: 0;
}

.article-content h4 {
    font-family: var(--font-serif);
    font-size: 1.25rem;  /* 20px — between h5 (24px) and body (18px) */
    font-weight: 700;
    line-height: var(--lh-serif);
    margin-top: var(--space-lg);
    margin-bottom: var(--space-sm);
    text-transform: none;
    letter-spacing: 0;
}

.article-content ul,
.article-content ol {
    margin-bottom: var(--space-md);
    padding-left: var(--space-lg);
}

.article-content ul { list-style: disc; }
.article-content ol { list-style: decimal; }

.article-content li {
    font-size: var(--fs-p1);
    line-height: 1.7;
    margin-bottom: var(--space-xs);
}

.article-content blockquote {
    border-left: 3px solid var(--color-turquoise);
    padding-left: var(--space-lg);
    margin: var(--space-xl) 0;
    font-family: var(--font-serif);
    font-size: var(--fs-h5);
    font-style: italic;
    opacity: 0.9;
}

.article-content img {
    border-radius: var(--radius-md);
    margin: var(--space-lg) 0;
}

.article-content a {
    color: var(--color-perficient-green);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.article-content a:hover {
    color: var(--color-navy-blue);
}

.article-content pre,
.article-content code {
    font-family: 'SFMono-Regular', 'Menlo', monospace;
    font-size: 0.9em;
}

.article-content pre {
    background-color: rgba(27, 34, 39, 0.06);
    padding: var(--space-md);
    border-radius: var(--radius-md);
    overflow-x: auto;
    margin-bottom: var(--space-md);
}

.article-content code {
    background-color: rgba(27, 34, 39, 0.08);
    padding: 0.15em 0.4em;
    border-radius: 3px;
}

.article-content pre code {
    background: none;
    padding: 0;
}

.article-content table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: var(--space-md);
}

.article-content th,
.article-content td {
    padding: var(--space-sm);
    border-bottom: 1px solid var(--color-divider);
    text-align: left;
}

.article-content th {
    font-weight: 700;
    font-size: var(--fs-p3);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* --------------------------------------------------------------------------
   Article Tags
   -------------------------------------------------------------------------- */

.article-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
    padding: var(--space-lg) 0;
    border-top: 1px solid var(--color-divider);
}

/* --------------------------------------------------------------------------
   Author Box
   -------------------------------------------------------------------------- */

.author-box {
    display: flex;
    gap: var(--space-md);
    align-items: flex-start;
    padding: var(--space-lg);
    background-color: var(--color-white);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-xl);
}

.author-box__avatar {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
}

.author-box__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.author-box__name {
    font-family: var(--font-serif);
    font-size: var(--fs-h5);
    font-weight: 700;
    margin-bottom: var(--space-xs);
}

.author-box__bio {
    font-size: var(--fs-p3);
    opacity: 0.8;
    line-height: var(--lh-body);
}

/* --------------------------------------------------------------------------
   Post Navigation
   -------------------------------------------------------------------------- */

.post-nav {
    display: flex;
    justify-content: space-between;
    gap: var(--space-md);
    padding: var(--space-xl) 0;
    border-top: 1px solid var(--color-divider);
}

.post-nav__link {
    font-family: var(--font-sans);
    font-size: var(--fs-p3);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-perficient-green);
}

.post-nav__link:hover {
    color: var(--color-navy-blue);
}

/* --------------------------------------------------------------------------
   Related Posts
   -------------------------------------------------------------------------- */

.related-posts {
    border-top: 1px solid var(--color-divider);
    padding: var(--space-2xl) 0;
    margin-top: var(--space-xl);
}

.related-posts__heading {
    font-family: var(--font-serif);
    font-size: var(--fs-h4);
    font-weight: 700;
    margin-bottom: var(--space-lg);
    text-transform: none;
    letter-spacing: normal;
}

/* --------------------------------------------------------------------------
   Archive / Category Header
   -------------------------------------------------------------------------- */

.archive-header {
    padding: var(--space-2xl) 0 var(--space-xl);
    border-bottom: 1px solid var(--color-divider);
    margin-bottom: var(--space-xl);
}

.archive-header__title {
    font-family: var(--font-display);
    font-size: var(--fs-h3);
    text-transform: uppercase;
}

.archive-header__description {
    margin-top: var(--space-sm);
    font-size: var(--fs-p1);
    opacity: 0.8;
    max-width: 700px;
}

/* --------------------------------------------------------------------------
   Author Bio
   -------------------------------------------------------------------------- */

.author-bio {
    padding: var(--space-xl) 0;
    border-bottom: 1px solid var(--color-divider);
    margin-bottom: var(--space-xl);
}

.author-bio__inner {
    display: flex;
    align-items: flex-start;
    gap: var(--space-lg);
}

.author-bio__avatar-wrap {
    flex-shrink: 0;
}

.author-bio__avatar-wrap img {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
}

.author-bio__description {
    font-size: var(--fs-p1);
    line-height: 1.6;
    max-width: 700px;
}

.author-bio__count {
    margin-top: var(--space-sm);
    font-size: var(--fs-p3);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-teal);
}

@media (max-width: 639px) {
    .author-bio__inner {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .author-bio__avatar-wrap img {
        width: 96px;
        height: 96px;
    }
}

/* --------------------------------------------------------------------------
   Pagination
   -------------------------------------------------------------------------- */

.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-2xl) 0;
}

.pagination a,
.pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 var(--space-sm);
    font-family: var(--font-sans);
    font-size: var(--fs-p3);
    font-weight: 700;
    color: var(--color-brand-black);
    border: 1px solid var(--color-divider);
    border-radius: var(--radius-sm);
    transition: all var(--transition-fast);
}

.pagination a:hover {
    background-color: var(--color-turquoise);
    border-color: var(--color-turquoise);
    color: var(--color-brand-black);
}

.pagination .current {
    background-color: var(--color-turquoise);
    border-color: var(--color-turquoise);
    color: var(--color-brand-black);
}

/* --------------------------------------------------------------------------
   Footer — Synced verbatim from Perficient Vercel site (Tailwind classes)
   All footer styling comes from perficient-production.css Tailwind utilities.
   Last synced: 2026-03-04
   -------------------------------------------------------------------------- */

/* Fix: On mobile (<768px), footer columns must stack full-width.
   In the downloaded Tailwind CSS, basis-1/2 wins over basis-full due to
   source order. We override to block layout so columns stack naturally. */
@media (max-width: 767px) {
    .prft-public-footer .column-splitter {
        display: block !important;
    }

    .prft-public-footer .column-splitter > div {
        width: 100% !important;
        flex-basis: auto !important;
    }
}

/* --------------------------------------------------------------------------
   Search Form
   -------------------------------------------------------------------------- */

.search-form {
    display: flex;
    max-width: 500px;
}

.search-form__input {
    flex: 1;
    font-family: var(--font-sans);
    font-size: var(--fs-p2);
    padding: 0.75em 1em;
    border: 1px solid var(--color-divider);
    border-right: none;
    border-radius: var(--radius-sm) 0 0 var(--radius-sm);
    background: var(--color-white);
    color: var(--color-brand-black);
}

.search-form__input::placeholder {
    color: rgba(27, 34, 39, 0.4);
}

.search-form__button {
    font-family: var(--font-sans);
    font-size: var(--fs-p3);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.75em 1.5em;
    background-color: var(--color-turquoise);
    color: var(--color-brand-black);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    border: 1px solid var(--color-turquoise);
    transition: background-color var(--transition-fast);
}

.search-form__button:hover {
    background-color: var(--color-perficient-green);
    border-color: var(--color-perficient-green);
    color: var(--color-white);
}

/* --------------------------------------------------------------------------
   404 Page
   -------------------------------------------------------------------------- */

.error-404 {
    text-align: center;
    padding: var(--space-4xl) 0;
}

.error-404__title {
    font-family: var(--font-display);
    font-size: var(--fs-h1);
    text-transform: uppercase;
    margin-bottom: var(--space-md);
}

.error-404__message {
    font-size: var(--fs-p1);
    opacity: 0.7;
    margin-bottom: var(--space-xl);
}

.error-404 .search-form {
    max-width: 480px;
    margin: 0 auto var(--space-lg);
}

.error-404__home-link {
    margin-top: var(--space-md);
}

/* --------------------------------------------------------------------------
   Button
   -------------------------------------------------------------------------- */

.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5em;
    font-family: var(--font-sans);
    font-size: var(--fs-p3);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.75em 1.5em;
    border-radius: var(--radius-sm);
    transition: all var(--transition-fast);
}

.btn--primary {
    background-color: var(--color-turquoise);
    color: var(--color-brand-black);
}

.btn--primary:hover {
    background-color: var(--color-perficient-green);
    color: var(--color-white);
}

.btn--outline {
    border: 1px solid var(--color-turquoise);
    color: var(--color-turquoise);
}

.btn--outline:hover {
    background-color: var(--color-turquoise);
    color: var(--color-brand-black);
}

/* Arrow link */
.arrow-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5em;
    font-family: var(--font-sans);
    font-size: var(--fs-p3);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-perficient-green);
    transition: gap var(--transition-fast);
}

.arrow-link::after {
    content: '\2192';
}

.arrow-link:hover {
    gap: 0.75em;
    color: var(--color-navy-blue);
}

/* --------------------------------------------------------------------------
   Utility Classes
   -------------------------------------------------------------------------- */

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.text-center { text-align: center; }
.text-accent { color: var(--color-perficient-green); }
.text-muted { opacity: 0.6; }

.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }
.mb-xl { margin-bottom: var(--space-xl); }

/* --------------------------------------------------------------------------
   WordPress Specific — wp-block, alignments, etc.
   -------------------------------------------------------------------------- */

.wp-block-image {
    margin: var(--space-lg) 0;
}

/* WordPress alignment classes */
.alignfull {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(-50vw + 50%);
}

.alignwide {
    max-width: calc(var(--container-max) + 4rem);
    margin-inline: auto;
}

.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

.alignleft,
.article-content img.alignleft {
    float: left;
    margin: 0.5em var(--space-md) 0.5em 0;
}

.alignright,
.article-content img.alignright {
    float: right;
    margin: 0.5em 0 0.5em var(--space-md);
}

.alignnone {
    display: block;
    margin: var(--space-sm) 0;
}

/* Clear floats after aligned images */
.article-content::after {
    content: '';
    display: table;
    clear: both;
}

.wp-block-embed {
    margin: var(--space-lg) 0;
}

.wp-caption {
    max-width: 100%;
}

.wp-caption-text {
    font-size: var(--fs-p3);
    opacity: 0.6;
    margin-top: var(--space-xs);
}

/* --------------------------------------------------------------------------
   WordPress [gallery] Shortcode
   -------------------------------------------------------------------------- */

.gallery {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm, 12px);
    margin: var(--space-lg, 32px) 0;
}

.gallery .gallery-item {
    margin: 0;
}

.gallery-columns-1 .gallery-item { flex: 0 0 100%; max-width: 100%; }
.gallery-columns-2 .gallery-item { flex: 0 0 calc((100% - 1rem) / 2); max-width: calc((100% - 1rem) / 2); }
.gallery-columns-3 .gallery-item { flex: 0 0 calc((100% - 2rem) / 3); max-width: calc((100% - 2rem) / 3); }
.gallery-columns-4 .gallery-item { flex: 0 0 calc((100% - 3rem) / 4); max-width: calc((100% - 3rem) / 4); }

.gallery .gallery-icon {
    overflow: hidden;
    border-radius: 4px;
}

.gallery .gallery-icon img {
    width: 100%;
    height: auto;
    display: block;
    aspect-ratio: 4/3;
    object-fit: cover;
}

.gallery .gallery-icon a {
    display: block;
}

.gallery .gallery-caption {
    font-size: var(--fs-p3, 13px);
    opacity: 0.7;
    margin-top: var(--space-xs, 4px);
    text-align: center;
}

@media (max-width: 640px) {
    .gallery-columns-3 .gallery-item,
    .gallery-columns-4 .gallery-item {
        flex-basis: calc((100% - 1rem) / 2);
        max-width: calc((100% - 1rem) / 2);
    }
}

@media (max-width: 400px) {
    .gallery .gallery-item {
        flex-basis: 100%;
        max-width: 100%;
    }
}

/* end of theme.css */
