/*
Theme Name: Forum Sports Management
Theme URI: https://forumsports.com
Author: Forum Sports Management
Author URI: https://forumsports.com
Description: A bold, data-driven dark theme for sports talent representation. Cyan and black with BlenderPro italic typography, hero slideshow, services grid, team profiles, news carousel and contact form. Custom post types for Services and Team Members, Customizer integration for hero copy, contact details and contact form shortcode.
Version: 2.2.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: forum-sports-theme
Tags: dark, custom-colors, custom-logo, custom-menu, featured-images, threaded-comments, sticky-post, custom-post-types
*/

/* =============================================================
   0. Self-hosted BlenderPro fonts (uploaded with theme)
   ============================================================= */
@font-face {
    font-family: 'BlenderPro';
    src: url('assets/fonts/BlenderPro-Heavy.ttf') format('truetype');
    font-weight: 700 900;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'BlenderPro';
    src: url('assets/fonts/BlenderPro-BoldItalic.ttf') format('truetype');
    font-weight: 600 800;
    font-style: italic;
    font-display: swap;
}

/* =============================================================
   1. Design tokens (CSS variables)
   ============================================================= */
:root {
    --color-primary: #0D0D0D;
    --color-secondary: #FFFFFF;
    --color-accent: #00FFFF;
    --color-hover: #00B3B3;
    --color-form-bg: #1A1A1A;
    --color-grey: rgba(255, 255, 255, 0.7);
    --color-card: #181818;
    --color-border: rgba(255, 255, 255, 0.08);
    --font-display: 'BlenderPro', 'Oswald', 'Inter', 'Arial Narrow', sans-serif;
    --font-body: 'BlenderPro', 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --container: 1280px;
    --gutter: clamp(1rem, 4vw, 2.5rem);
    --section-py: clamp(4rem, 10vh, 7rem);
    --radius: 4px;
    --shadow: 0 8px 28px rgba(0,0,0,0.35);
    --transition: 0.25s ease;
}

/* =============================================================
   2. Reset / base
   ============================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    padding: 0;
    background: var(--color-primary);
    color: var(--color-secondary);
    font-family: var(--font-body);
    font-style: italic;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
img, svg { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-accent); }
button { font: inherit; cursor: pointer; }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    font-weight: 700;
    font-style: italic;
    letter-spacing: 0.02em;
    line-height: 1.05;
    margin: 0 0 0.6em;
    text-transform: uppercase;
}
h1 { font-size: clamp(2.5rem, 6vw, 5rem); }
h2 { font-size: clamp(2rem, 4.5vw, 3.75rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.5rem); }
p  { margin: 0 0 1em; }

.container {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--gutter);
}
.section-padding {
    padding: var(--section-py) 0;
}
.screen-reader-text {
    position: absolute !important;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0);
    white-space: nowrap; border: 0;
}

/* =============================================================
   3. Header & navigation
   ============================================================= */
.site-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    padding: 1.2rem var(--gutter);
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: background-color var(--transition), padding var(--transition);
    background: transparent;
}
.site-header.is-scrolled {
    background: rgba(13,13,13,0.92);
    backdrop-filter: blur(8px);
    padding: 0.7rem var(--gutter);
}
.site-branding .logo {
    display: inline-block;
    max-width: 160px;
}
.site-branding .logo img {
    max-height: 60px;
    width: auto;
}
.site-branding .logo-text {
    font-family: var(--font-display);
    font-size: 2rem;
    font-style: italic;
    font-weight: 800;
    color: var(--color-secondary);
    letter-spacing: 0.02em;
    line-height: 0.95;
    text-transform: uppercase;
}
.site-branding .logo-text small {
    display: block;
    font-size: 0.65rem;
    letter-spacing: 0.25em;
    margin-top: 4px;
    font-weight: 600;
}

.desktop-nav { display: none; }
@media (min-width: 900px) {
    .desktop-nav { display: block; }
}
.desktop-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 2.5rem;
}
.desktop-nav a {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 700;
    font-size: 0.95rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-secondary);
    position: relative;
    padding: 4px 0;
}
.desktop-nav a:hover,
.desktop-nav .current-menu-item > a,
.desktop-nav .current_page_item > a {
    color: var(--color-accent);
}

.mobile-toggle {
    background: transparent;
    border: 0;
    color: var(--color-secondary);
    padding: 8px;
    display: inline-flex;
    flex-direction: column;
    gap: 5px;
}
.mobile-toggle span {
    width: 26px;
    height: 2px;
    background: var(--color-secondary);
    transition: transform var(--transition), opacity var(--transition);
}
.mobile-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.mobile-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.mobile-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
@media (min-width: 900px) {
    .mobile-toggle { display: none; }
}

.off-canvas-nav {
    position: fixed;
    inset: 0 0 0 auto;
    width: min(80vw, 320px);
    background: var(--color-primary);
    z-index: 99;
    transform: translateX(100%);
    transition: transform var(--transition);
    padding: 6rem 2rem 2rem;
    border-left: 1px solid var(--color-border);
}
.off-canvas-nav.is-open { transform: translateX(0); }
.off-canvas-nav ul { list-style: none; margin: 0; padding: 0; }
.off-canvas-nav li { margin-bottom: 1.25rem; }
.off-canvas-nav a {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.4rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-secondary);
}
.off-canvas-nav a:hover { color: var(--color-accent); }

/* =============================================================
   4. Hero
   ============================================================= */
.hero-section {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    text-align: center;
    isolation: isolate;
}
.hero-slides {
    position: absolute; inset: 0;
    z-index: -2;
}
.hero-slide {
    position: absolute; inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0;
    transition: opacity 1.2s ease-in-out;
}
.hero-slide.is-active { opacity: 1; }
.hero-section::before {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(rgba(13,13,13,0.55), rgba(13,13,13,0.7));
    z-index: -1;
}
.hero-inner {
    padding: 0 var(--gutter);
    max-width: 1100px;
}
.hero-tagline {
    display: block;
    color: var(--color-accent);
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 600;
    letter-spacing: 0.4em;
    font-size: clamp(0.85rem, 1.4vw, 1.1rem);
    text-transform: uppercase;
    margin-bottom: 1.5rem;
}
.hero-heading {
    font-size: clamp(2.2rem, 6vw, 5rem);
    margin: 0 0 1.5rem;
    color: var(--color-secondary);
}
.hero-divider {
    display: block;
    width: 90px; height: 3px;
    background: var(--color-accent);
    margin: 1.5rem auto 2rem;
}
.hero-button {
    display: inline-block;
    background: var(--color-accent);
    color: #000;
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    padding: 1rem 2.4rem;
    border-radius: var(--radius);
    transition: background-color var(--transition), transform var(--transition), color var(--transition);
}
.hero-button:hover {
    background: var(--color-hover);
    color: #000;
    transform: translateY(-2px);
}

/* =============================================================
   5. Section headings
   ============================================================= */
.section-header {
    text-align: center;
    max-width: 760px;
    margin: 0 auto 3.5rem;
}
.section-header .title {
    color: rgba(255,255,255,0.18);
    font-size: clamp(2rem, 6vw, 5rem);
    margin-bottom: 0;
}
.section-header .subtitle {
    color: var(--color-grey);
    font-family: var(--font-body);
    font-style: italic;
    font-size: 1.05rem;
    margin-top: 1.5rem;
}
.section-header::after {
    content: "";
    display: block;
    width: 60px; height: 3px;
    background: var(--color-accent);
    margin: 1rem auto 0;
}

/* =============================================================
   6. About section
   ============================================================= */
#about .about-content {
    text-align: center;
    max-width: 880px;
    margin: 0 auto;
}
#about .title {
    font-size: clamp(2.2rem, 5vw, 4rem);
    color: var(--color-secondary);
    margin-bottom: 0.5rem;
}
#about .about-content::after {
    content: "";
    display: block;
    width: 60px; height: 3px;
    background: var(--color-accent);
    margin: 1.25rem auto 2rem;
}
#about .description {
    font-family: var(--font-body);
    font-style: italic;
    font-size: 1.05rem;
    color: var(--color-grey);
    margin-bottom: 2rem;
}
.read-more-wrapper { text-align: center; margin-top: 1.5rem; }
.read-more-link {
    color: var(--color-accent);
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-size: 0.95rem;
}
.read-more-link::after {
    content: " \2192";
    transition: transform var(--transition);
}
.read-more-link:hover { color: var(--color-hover); }

/* =============================================================
   7. Services grid
   ============================================================= */
.service-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.5rem;
    max-width: 1280px;
    margin: 0 auto;
}
.service-link-card { display: block; height: 100%; }
.service-card {
    background: var(--color-card);
    border: 1px solid var(--color-border);
    padding: 2.5rem 1.75rem;
    border-radius: var(--radius);
    text-align: center;
    height: 100%;
    transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.service-card .icon {
    font-size: 2.6rem;
    color: var(--color-accent);
    margin-bottom: 1.25rem;
}
.service-card h3 {
    font-size: 1.15rem;
    margin-bottom: 1rem;
    color: var(--color-secondary);
    letter-spacing: 0.06em;
}
.service-card p {
    color: var(--color-grey);
    font-family: var(--font-body);
    font-style: italic;
    font-size: 0.95rem;
    margin: 0;
}
.service-card:hover, .digital-hover:hover {
    transform: translateY(-6px);
    border-color: var(--color-accent);
    box-shadow: 0 12px 36px rgba(0,255,255,0.08);
}

/* =============================================================
   8. Team grid
   ============================================================= */
.employee-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem;
    max-width: 1100px;
    margin: 0 auto;
}
.employee-summary {
    background: var(--color-card);
    border: 1px solid var(--color-border);
    padding: 2rem 1.75rem;
    border-radius: var(--radius);
    text-align: center;
    transition: transform var(--transition), border-color var(--transition);
}
.employee-summary:hover {
    transform: translateY(-6px);
    border-color: var(--color-accent);
}
.employee-photo {
    width: 140px; height: 140px;
    margin: 0 auto 1.25rem;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid var(--color-accent);
    background: var(--color-form-bg);
}
.employee-photo img {
    width: 100%; height: 100%;
    object-fit: cover;
}
.employee-summary h3 {
    font-size: 1.35rem;
    margin-bottom: 0.25rem;
}
.employee-title {
    color: var(--color-accent);
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.85rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 1rem;
}
.employee-summary p {
    color: var(--color-grey);
    font-family: var(--font-body);
    font-style: italic;
    font-size: 0.95rem;
}

/* Full team page – stacked bios with accent bar */
.team-full-list {
    max-width: 980px;
    margin: 0 auto;
    display: grid;
    gap: 2rem;
}
.team-full-bio {
    background: var(--color-card);
    border-left: 3px solid var(--color-accent);
    padding: 2rem 2.25rem;
    border-radius: var(--radius);
}
.team-full-bio h2 {
    color: var(--color-secondary);
    font-size: 1.85rem;
    margin-bottom: 0.35rem;
}
.team-full-bio.has-photo {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 2rem;
    align-items: start;
}
@media (max-width: 768px) {
    .team-full-bio.has-photo {
        grid-template-columns: 1fr;
        text-align: center;
    }
}
.team-full-photo {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid var(--color-accent);
    flex-shrink: 0;
}
@media (max-width: 768px) {
    .team-full-photo { margin: 0 auto 1rem; }
}
.team-full-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
}
.team-full-bio .role {
    color: var(--color-grey);
    font-family: var(--font-body);
    font-style: italic;
    font-size: 0.95rem;
    margin-bottom: 1.5rem;
    letter-spacing: 0.04em;
}
.team-full-bio .bio p { color: rgba(255,255,255,0.85); font-family: var(--font-body); font-style: italic; }
.team-full-bio .social a { color: var(--color-secondary); font-size: 1.25rem; margin-right: 0.75rem; }
.team-full-bio .social a:hover { color: var(--color-accent); }

/* =============================================================
   9. News
   ============================================================= */
.news-section .news-grid-carousel {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(300px, 1fr);
    gap: 1.5rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-padding: 0 var(--gutter);
    padding-bottom: 1rem;
    scrollbar-width: thin;
    scrollbar-color: var(--color-accent) var(--color-form-bg);
}
@media (min-width: 900px) {
    .news-section .news-grid-carousel {
        grid-auto-columns: minmax(0, 1fr);
        grid-template-columns: repeat(3, 1fr);
        grid-auto-flow: row;
        overflow: hidden;
    }
}
.carousel-container { position: relative; }
.news-card {
    background: var(--color-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
    display: flex; flex-direction: column;
    scroll-snap-align: start;
    transition: transform var(--transition), border-color var(--transition);
}
.news-card:hover {
    transform: translateY(-4px);
    border-color: var(--color-accent);
}
.news-card .news-thumb {
    aspect-ratio: 16/10;
    background: #222;
    overflow: hidden;
}
.news-card .news-thumb img { width: 100%; height: 100%; object-fit: cover; }
.news-card .news-body { padding: 1.25rem 1.5rem 1.5rem; flex: 1; display: flex; flex-direction: column; }
.news-card .news-date {
    color: var(--color-accent);
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.8rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    margin-bottom: 0.75rem;
}
.news-card h3 { font-size: 1.1rem; line-height: 1.25; margin-bottom: 0.85rem; }
.news-card h3 a { color: var(--color-secondary); }
.news-card h3 a:hover { color: var(--color-accent); }
.news-card .news-excerpt { color: var(--color-grey); font-family: var(--font-body); font-style: italic; font-size: 0.92rem; flex: 1; }
.news-card .news-footer { padding: 0 1.5rem 1.5rem; }
.news-card .news-footer a {
    color: var(--color-accent);
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.85rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    border-top: 1px solid var(--color-accent);
    display: inline-block;
    padding-top: 0.5rem;
}

.carousel-nav {
    position: absolute;
    top: 35%;
    transform: translateY(-50%);
    width: 44px; height: 44px;
    border-radius: 50%;
    border: 0;
    background: var(--color-accent);
    color: #000;
    display: flex; align-items: center; justify-content: center;
    z-index: 5;
    transition: background var(--transition), transform var(--transition);
}
.carousel-nav:hover { background: var(--color-hover); }
.carousel-nav.prev-btn { left: -22px; }
.carousel-nav.next-btn { right: -22px; }
@media (min-width: 900px) { .carousel-nav { display: none; } }

.btn-primary {
    display: inline-block;
    background: var(--color-accent);
    color: #000;
    padding: 0.9rem 2rem;
    border-radius: var(--radius);
    font-family: var(--font-display);
    font-style: italic;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 700;
    transition: background var(--transition), color var(--transition), transform var(--transition);
}
.btn-primary:hover {
    background: var(--color-hover);
    color: #000;
    transform: translateY(-2px);
}
.btn-primary::after { content: " \2192"; }

/* News list full page */
.news-grid-page {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1.5rem;
    max-width: 1280px;
    margin: 0 auto;
}

/* =============================================================
   10. Contact section
   ============================================================= */
.contact-container {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
    max-width: 1100px;
    margin: 0 auto;
    align-items: start;
}
@media (min-width: 900px) {
    .contact-container { grid-template-columns: 1.4fr 1fr; gap: 4rem; }
}
.contact-form {
    display: grid;
    gap: 1rem;
}
.contact-form input,
.contact-form textarea,
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 textarea {
    width: 100%;
    background: var(--color-form-bg);
    border: 1px solid var(--color-border);
    color: var(--color-secondary);
    padding: 1rem 1.1rem;
    font-family: var(--font-body);
    font-style: italic;
    font-size: 1rem;
    border-radius: var(--radius);
    transition: border-color var(--transition), background var(--transition);
}
.contact-form input:focus,
.contact-form textarea:focus,
.wpcf7 input:focus,
.wpcf7 textarea:focus {
    outline: 0;
    border-color: var(--color-accent);
    background: #222;
}
.contact-form textarea, .wpcf7 textarea { min-height: 160px; resize: vertical; }
.contact-form button,
.wpcf7 input[type="submit"] {
    background: var(--color-accent);
    color: #000;
    font-family: var(--font-display);
    font-style: italic;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    border: 0;
    padding: 0.9rem 2.5rem;
    border-radius: var(--radius);
    justify-self: start;
    font-weight: 700;
    transition: background var(--transition), transform var(--transition);
}
.contact-form button:hover,
.wpcf7 input[type="submit"]:hover {
    background: var(--color-hover);
    transform: translateY(-2px);
}

.contact-info h3 {
    color: var(--color-accent);
    font-size: 1.5rem;
    letter-spacing: 0.12em;
    margin-bottom: 1.5rem;
}
.contact-info p { color: rgba(255,255,255,0.85); font-style: italic; font-family: var(--font-body); }
.contact-info .label { color: var(--color-secondary); font-weight: 700; }
.contact-info .socials {
    display: flex; gap: 1.25rem;
    margin-top: 1.5rem;
}
.contact-info .socials a {
    color: var(--color-secondary);
    font-size: 1.3rem;
    transition: color var(--transition);
}
.contact-info .socials a:hover { color: var(--color-accent); }

/* =============================================================
   11. Footer
   ============================================================= */
.site-footer {
    background: var(--color-primary);
    border-top: 1px solid var(--color-border);
    padding: 2rem var(--gutter);
    text-align: center;
    color: var(--color-grey);
    font-family: var(--font-body);
    font-style: italic;
    font-size: 0.9rem;
}
.site-footer a { color: var(--color-grey); }
.site-footer a:hover { color: var(--color-accent); }
.footer-menu {
    list-style: none;
    margin: 0 0 0.75rem;
    padding: 0;
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}
.footer-socials {
    display: flex;
    justify-content: center;
    gap: 1.4rem;
    margin: 0 0 1.25rem;
}
.footer-socials a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: 1px solid var(--color-border);
    color: var(--color-secondary);
    font-size: 1.05rem;
    transition: color var(--transition), border-color var(--transition), background var(--transition), transform var(--transition);
}
.footer-socials a:hover {
    color: #000;
    background: var(--color-accent);
    border-color: var(--color-accent);
    transform: translateY(-2px);
}

/* =============================================================
   12. Single news / page
   ============================================================= */
.single-post-wrap, .page-wrap {
    max-width: 800px;
    margin: 0 auto;
    padding: calc(var(--section-py) + 60px) var(--gutter) var(--section-py);
}
.single-post-wrap .post-thumb {
    margin: 0 0 2rem;
    border-radius: var(--radius);
    overflow: hidden;
}
.single-post-wrap .post-meta {
    color: var(--color-accent);
    font-family: var(--font-display);
    font-style: italic;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-size: 0.85rem;
    margin-bottom: 0.85rem;
}
.single-post-wrap h1 { font-size: clamp(2rem, 4vw, 3rem); }
.single-post-wrap .entry-content {
    color: rgba(255,255,255,0.88);
    font-family: var(--font-body);
    font-style: italic;
    font-size: 1.05rem;
    line-height: 1.7;
}
.single-post-wrap .entry-content a { color: var(--color-accent); text-decoration: underline; }
.post-nav {
    display: flex; justify-content: space-between;
    border-top: 1px solid var(--color-border);
    margin-top: 3rem;
    padding-top: 2rem;
    gap: 1rem;
    flex-wrap: wrap;
}
.post-nav a { color: var(--color-accent); font-family: var(--font-display); font-style: italic; letter-spacing: 0.12em; text-transform: uppercase; }

.back-home {
    text-align: center;
    margin-top: 3rem;
}

/* =============================================================
   13. Stagger reveal animation
   ============================================================= */
.stagger-item { opacity: 0; transform: translateY(28px); transition: opacity 0.8s ease, transform 0.8s ease; }
.stagger-reveal.is-visible .stagger-item { opacity: 1; transform: none; }
.stagger-reveal.is-visible .stagger-item:nth-child(2) { transition-delay: 0.1s; }
.stagger-reveal.is-visible .stagger-item:nth-child(3) { transition-delay: 0.2s; }
.stagger-reveal.is-visible .stagger-item:nth-child(4) { transition-delay: 0.3s; }
@media (prefers-reduced-motion: reduce) {
    .stagger-item { opacity: 1; transform: none; transition: none; }
}

/* =============================================================
   14. Utilities & responsive tweaks
   ============================================================= */
.alignwide { max-width: 1100px; margin-left: auto; margin-right: auto; }
.alignfull { width: 100%; }

@media (max-width: 600px) {
    .hero-section { min-height: 80vh; }
    .section-padding { padding: 4rem 0; }
    .section-header { margin-bottom: 2.5rem; }
}
