/*
Theme Name: badminton-theme v1.1
Theme URI: https://pressmegpt.com
Author: PressMeGPT
Author URI: https://pressmegpt.com
Description: This theme was generated by PressMeGPT.com - AI WordPress Theme Generator. Free software released under GNU GPLv2 with attribution.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.4
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: badminton-theme
Tags: custom, pressmegpt, ai-generated, custom-logo, custom-menu, custom-colors, dark, custom-fonts

This theme was created with PressMeGPT.com - AI WordPress Theme Generator.
Free to use, modify, and distribute under GNU GPLv2 with attribution.
*/

/* Reset and base styles */
*, *::before, *::after {
    box-sizing: border-box;
}

body {
    margin: 0;
    padding: 0;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    line-height: 1.6;
}

img {
    max-width: 100%;
    height: auto;
}

a {
    text-decoration: none;
}

/* ===== Header Styles ===== */
.site-header {
    padding: 1rem 2rem;
}

.header-inner {
    max-width: 1400px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
}

/* Header Layout: Logo Left, Menu Right (default) */
.header-layout-logo-left-menu-right .header-inner {
    flex-direction: row;
    justify-content: space-between;
}

/* Header Layout: Logo Right, Menu Left */
.header-layout-logo-right-menu-left .header-inner {
    flex-direction: row-reverse;
    justify-content: space-between;
}

/* Header Layout: Logo Center, Menu Below */
.header-layout-logo-center-menu-below .header-inner {
    flex-direction: column;
    text-align: center;
}

.header-layout-logo-center-menu-below .site-branding {
    margin-bottom: 1rem;
}

/* Header Layout: Logo Center, Menu Split */
.header-layout-logo-center-menu-split .header-inner {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
}

.header-layout-logo-center-menu-split .menu-left {
    justify-self: end;
}

.header-layout-logo-center-menu-split .menu-right {
    justify-self: start;
}

/* Site Branding */
.site-branding {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.site-branding a {
    display: inline-block;
}

.custom-logo {
    display: block;
    height: auto;
}

.site-title {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
}

.site-title a {
    color: inherit;
}

.site-description {
    margin: 0.25rem 0 0;
    font-size: 0.875rem;
    opacity: 0.8;
}

/* Primary Navigation */
.main-navigation {
    display: flex;
    align-items: center;
}

.main-navigation ul {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 1.5rem;
}

.main-navigation li {
    position: relative;
}

.main-navigation a {
    display: block;
    padding: 0.5rem 0;
    font-weight: 500;
    transition: color 0.2s ease;
}

.main-navigation a:hover {
    opacity: 0.7;
}

/* Dropdown menus */
.main-navigation ul ul {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 200px;
    flex-direction: column;
    gap: 0;
    background: #fff;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    border-radius: 4px;
    padding: 0.5rem 0;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s, visibility 0.2s;
}

.main-navigation li:hover > ul {
    opacity: 1;
    visibility: visible;
}

.main-navigation ul ul a {
    padding: 0.5rem 1rem;
    color: #333;
}

/* Mobile Menu Toggle */
.menu-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
}

.menu-toggle svg {
    width: 24px;
    height: 24px;
}

@media (max-width: 768px) {
    .menu-toggle {
        display: block;
    }
    
    .main-navigation {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: inherit;
        padding: 1rem;
        box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    }
    
    .main-navigation.toggled {
        display: block;
    }
    
    .main-navigation ul {
        flex-direction: column;
        gap: 0.5rem;
    }
    
    .main-navigation ul ul {
        position: static;
        opacity: 1;
        visibility: visible;
        box-shadow: none;
        padding-left: 1rem;
    }
}

/* ===== Footer Styles ===== */
.site-footer {
    padding: 2rem;
}

.footer-inner {
    max-width: 1400px;
    margin: 0 auto;
}

/* Footer Layout: Centered */
.footer-layout-centered .footer-inner {
    text-align: center;
}

.footer-layout-centered .footer-navigation ul {
    justify-content: center;
}

/* Footer Layout: Left Aligned */
.footer-layout-left-aligned .footer-inner {
    text-align: left;
}

/* Footer Layout: Split */
.footer-layout-split .footer-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
}

/* Footer Navigation */
.footer-navigation {
    margin-bottom: 1rem;
}

.footer-navigation ul {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.footer-navigation a {
    font-size: 0.875rem;
    transition: opacity 0.2s;
}

.footer-navigation a:hover {
    opacity: 0.7;
}

/* Footer Menu Position */
.footer-menu-below .footer-navigation {
    order: 2;
    margin-bottom: 0;
    margin-top: 1rem;
}

.footer-menu-below .site-info {
    order: 1;
}

/* Footer Widgets */
.footer-widgets {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 2rem;
    margin-bottom: 2rem;
}

.footer-widgets .widget {
    margin-bottom: 0;
}

.footer-widgets .widget-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 1rem;
}

/* Site Info */
.site-info {
    font-size: 0.875rem;
    opacity: 0.8;
}

.site-info p {
    margin: 0;
}

@media (max-width: 768px) {
    .footer-layout-split .footer-inner {
        flex-direction: column;
        text-align: center;
    }
    
    .footer-navigation ul {
        justify-content: center;
    }
}

/* ===== Widget Styles ===== */
.widget {
    margin-bottom: 2rem;
}

.widget-title {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 1rem;
}

.widget ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.widget li {
    padding: 0.25rem 0;
}

/* ===== Content Styles ===== */
.content-area {
    max-width: 1200px;
    margin: 0 auto;
    padding: 2rem;
}

.entry-header {
    margin-bottom: 1.5rem;
}

.entry-title {
    font-size: 2rem;
    margin: 0 0 0.5rem;
}

.entry-meta {
    font-size: 0.875rem;
    opacity: 0.7;
}

.entry-content {
    margin-bottom: 2rem;
}

.entry-footer {
    font-size: 0.875rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(0,0,0,0.1);
}

.post-thumbnail {
    margin-bottom: 1.5rem;
}

.post-thumbnail img {
    border-radius: 8px;
}

/* ===== Sidebar ===== */
.widget-area {
    padding: 2rem;
}

/* ===== Utility Classes ===== */
.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    word-wrap: normal !important;
}

.skip-link:focus {
    background-color: #f1f1f1;
    clip: auto !important;
    clip-path: none;
    color: #21759b;
    display: block;
    font-size: 0.875rem;
    font-weight: 700;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
}

/* Theme Designer Custom Styles */
/* Base Styles */
* { min-width: 0; box-sizing: border-box; }
body { margin: 0; font-family: var(--td-font-body); color: var(--td-color-text); background-color: var(--td-color-background); line-height: 1.6; }
img { max-width: 100%; height: auto; }
a { text-decoration: none; color: var(--td-color-link); }
a:hover { color: var(--td-color-link-hover); }

/* FSE Specific Styles */
.fse-section { padding: 80px 0; overflow-x: hidden; position: relative; }
.fse-group { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.fse-heading { font-family: var(--td-font-heading); color: var(--td-color-heading); line-height: 1.1; margin-bottom: 20px; letter-spacing: -0.03em; }
.fse-paragraph { margin-bottom: 20px; }
.fse-image { display: block; }

.fse-button { display: inline-flex; align-items: center; justify-content: center; padding: 14px 28px; border-radius: 8px; font-weight: 600; text-align: center; cursor: pointer; transition: transform 0.3s ease, background-color 0.3s ease, filter 0.3s ease, box-shadow 0.3s ease; }
.fse-button:hover { filter: brightness(1.1); text-decoration: none; transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,0.2); }
.fse-button-primary { background-color: var(--td-color-btn-primary-bg); color: var(--td-color-btn-primary-text); border: none; }
.fse-button-secondary { background-color: var(--td-color-btn-secondary-bg); color: var(--td-color-btn-secondary-text); border: 2px solid var(--td-color-btn-secondary-bg); }
.fse-button-secondary:hover { background-color: transparent; color: var(--td-color-btn-secondary-bg); filter: brightness(1.2); }
.fse-button-link { background: none; border: none; color: var(--td-color-link); padding: 0; margin-top: 15px; }
.fse-button-link:hover { text-decoration: underline; background: none; transform: none; box-shadow: none; }
.fse-button-link i { margin-left: 8px; }

.fse-columns { display: flex; flex-wrap: wrap; gap: 30px; }
.fse-column { flex: 1 1 300px; min-width: 0; }
@media (max-width: 768px) { .fse-columns { flex-direction: column; } .fse-column { flex: 1 1 100%; width: 100%; } }

/* Header */
.fse-header { padding: 15px 0; background-color: var(--td-color-header-bg); border-bottom: 1px solid rgba(255,255,255,0.05); }
.fse-header-content { display: flex; justify-content: space-between; align-items: center; max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.fse-logo-area { display: flex; align-items: center; gap: 10px; }
.fse-logo { height: 70px; width: auto; min-height: 60px; filter: brightness(1.2); }
.fse-site-title { font-size: 1.6rem; font-weight: 700; color: var(--td-color-header-text); font-family: var(--td-font-heading); letter-spacing: -0.02em;}
.fse-main-nav { display: flex; }
.fse-nav-menu { display: flex; gap: 30px; list-style: none; margin: 0; padding: 0; justify-content: center; align-items: center; }
.fse-nav-menu a { text-decoration: none; color: var(--td-color-header-text); font-weight: 500; white-space: nowrap; transition: color 0.3s ease; }
.fse-nav-menu a:hover { color: var(--td-color-primary); }
.fse-toggle-button { display: none; background: none; border: none; font-size: 24px; cursor: pointer; color: var(--td-color-header-text); }
.fse-header-actions { display: flex; gap: 15px; }
.fse-main-nav.mobile-open { display: flex !important; position: absolute; transform: translateY(0); top: 100%; left: 0; right: 0; background: var(--td-color-header-bg, #fff); flex-direction: column; padding: 20px; box-shadow: 0 4px 6px rgba(0,0,0,0.1); z-index: 100; }
.fse-main-nav.mobile-open .fse-nav-menu { flex-direction: column; gap: 15px; align-items: flex-start; }
@media (max-width: 768px) {
  .fse-toggle-button { display: block; order: 3; margin-left: auto; color: var(--td-color-primary); }
  .fse-main-nav { display: none; }
  .fse-header-actions { display: none; }
  .fse-header-content { flex-wrap: wrap; }
  .fse-site-title { font-size: 1.3rem; }
}

/* Hero Section */
.fse-hero { text-align: center; min-height: 85vh; display: flex; align-items: center; justify-content: center; padding: 100px 0; background: radial-gradient(circle at 50% 50%, #1e3a8a -10%, #0a0a0e 70%); position: relative; overflow: hidden; }
.fse-hero-content { position: relative; z-index: 2; color: #fff; max-width: 900px; }
.fse-hero .fse-heading { font-size: clamp(2.8rem, 5vw, 4.8rem); font-weight: 700; margin-bottom: 25px; color: #fff; letter-spacing: -0.04em; }
.fse-hero .fse-paragraph { font-size: clamp(1.1rem, 2vw, 1.35rem); max-width: 700px; margin: 0 auto 40px; color: rgba(255,255,255,0.85); line-height: 1.7; }
.fse-hero-buttons { display: flex; justify-content: center; gap: 20px; flex-wrap: wrap; margin-top: 30px; }
.fse-hero-buttons .fse-button { padding: 16px 36px; border-radius: 10px; font-size: 1.1rem; }
.noise-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: url('data:image/svg+xml,%3Csvg viewBox="0 0 256 256" xmlns="http://www.w3.org/2000/svg"%3E%3Cfilter id="noise"%3E%3CfeTurbulence type="fractalNoise" baseFrequency="0.65" numOctaves="3" stitchTiles="stitch"/%3E%3C/filter%3E%3Crect width="100%25" height="100%25" filter="url(%23noise)" opacity="0.04"/%3E%3C/svg%3E'); z-index: 1; }
@media (max-width: 480px) { .fse-hero-buttons { flex-direction: column; align-items: center; } .fse-hero-buttons .fse-button { width: 100%; max-width: 280px; } }

/* Section Intro */
.fse-section-intro { text-align: center; max-width: 700px; margin: -10px auto 60px; font-size: 1.15rem; color: rgba(255,255,255,0.7); }
.fse-section:nth-of-type(odd) { background-color: var(--td-color-background-alt); }
.fse-section:nth-of-type(even) { background-color: var(--td-color-background); }

/* Programs Section */
.fse-programs .fse-heading { text-align: center; font-size: clamp(2rem, 4vw, 3.2rem); color: var(--td-color-heading); }
.fse-programs-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; max-width: 1200px; margin: 0 auto; }
.fse-programs-grid .fse-card { background: rgba(50,50,70,0.3); border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 25px; text-align: center; box-shadow: 0 4px 30px rgba(0,0,0,0.08); backdrop-filter: blur(5px); }
.fse-programs-grid .fse-card img { border-radius: 8px; margin-bottom: 20px; width: 100%; height: 200px; object-fit: cover; filter: brightness(0.9); }
.fse-programs-grid .fse-card .fse-heading { font-size: 1.6rem; margin-top: 10px; color: var(--td-color-primary); }
.fse-programs-grid .fse-card .fse-paragraph { font-size: 0.95rem; line-height: 1.7; color: rgba(255,255,255,0.7); }
@media (max-width: 992px) { .fse-programs-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 576px) { .fse-programs-grid { grid-template-columns: 1fr; } }

/* Coaches Section */
.fse-coaches { background-color: var(--td-color-background-alt); }
.fse-coaches .fse-heading { text-align: center; font-size: clamp(2rem, 4vw, 3.2rem); color: var(--td-color-heading); }
.fse-team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; max-width: 1200px; margin: 0 auto; }
.fse-team-member { text-align: center; background: rgba(50,50,70,0.3); border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 30px; box-shadow: 0 4px 30px rgba(0,0,0,0.08); backdrop-filter: blur(5px); }
.fse-team-member img { width: 150px; height: 150px; border-radius: 50%; object-fit: cover; margin: 0 auto 20px; border: 3px solid var(--td-color-primary); }
.fse-team-member .fse-heading { font-size: 1.5rem; margin-bottom: 5px; color: #fff; }
.fse-team-member .fse-paragraph { color: var(--td-color-primary); font-weight: 600; font-size: 0.9rem; margin-bottom: 10px; }
.fse-team-member .fse-coach-bio { font-size: 0.9rem; color: rgba(255,255,255,0.7); }
@media (max-width: 992px) { .fse-team-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 576px) { .fse-team-grid { grid-template-columns: 1fr; } }

/* Schedule Section */
.fse-schedule { background-color: var(--td-color-background); }
.fse-schedule .fse-heading { text-align: center; font-size: clamp(2rem, 4vw, 3.2rem); color: var(--td-color-heading); }
.fse-schedule-layout { display: flex; flex-wrap: wrap; gap: 40px; margin-top: 50px; }
.fse-schedule-card { background: rgba(50,50,70,0.3); border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 30px; box-shadow: 0 4px 30px rgba(0,0,0,0.08); backdrop-filter: blur(5px); height: 100%; }
.fse-schedule-card .fse-heading { font-size: 1.8rem; margin-bottom: 15px; color: var(--td-color-primary); }
.fse-schedule-card .fse-paragraph { margin-bottom: 10px; color: rgba(255,255,255,0.8); font-size: 1rem; }
.fse-schedule-card .fse-location { margin-top: 20px; font-size: 0.95rem; color: rgba(255,255,255,0.6); }
.fse-schedule-card .fse-location i { margin-right: 8px; color: var(--td-color-primary); }
.fse-schedule-cta { text-align: center; margin-top: 60px; }

/* Testimonials Section */
.fse-testimonials { background-color: var(--td-color-background-alt); position: relative; overflow: hidden; }
.fse-testimonials .fse-heading { text-align: center; font-size: clamp(2rem, 4vw, 3.2rem); color: var(--td-color-heading); }
.fse-testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; max-width: 1200px; margin: 0 auto; }
.fse-testimonial-card { background: rgba(50,50,70,0.3); border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 30px; text-align: center; box-shadow: 0 4px 30px rgba(0,0,0,0.08); backdrop-filter: blur(5px); }
.fse-testimonial-card .fse-avatar { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; margin: 0 auto 20px; border: 2px solid var(--td-color-secondary); }
.fse-testimonial-card .fse-paragraph { font-style: italic; font-size: 1.05rem; margin-bottom: 20px; color: rgba(255,255,255,0.8); line-height: 1.7; }
.fse-testimonial-card .fse-testimonial-author { font-weight: 600; color: var(--td-color-primary); font-size: 0.95rem; display: block; }
@media (max-width: 992px) { .fse-testimonials-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 576px) { .fse-testimonials-grid { grid-template-columns: 1fr; } }

/* Final CTA Section */
.fse-cta-final { text-align: center; padding: 100px 0; background: radial-gradient(circle at 50% 50%, #1e3a8a -10%, #0a0a0e 70%); color: #fff; }
.fse-cta-final .fse-heading { font-size: clamp(2.5rem, 5vw, 4rem); color: #fff; }
.fse-cta-final .fse-paragraph { font-size: clamp(1.1rem, 2vw, 1.35rem); max-width: 800px; margin: 0 auto 40px; color: rgba(255,255,255,0.85); line-height: 1.7; }

/* Footer */
.fse-footer { background-color: var(--td-color-footer-bg); padding: 60px 0 20px; color: var(--td-color-footer-text); }
.fse-footer-content { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.fse-footer-columns { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 40px; margin-bottom: 40px; }
.fse-footer-columns .fse-column { text-align: left; }
.fse-footer-columns .fse-column h4 { margin-bottom: 15px; font-size: 1.2rem; color: var(--td-color-footer-text); text-align: left; font-family: var(--td-font-heading); }
.fse-footer-logo { height: 50px; width: auto; margin-bottom: 15px; filter: brightness(1.2); }
.fse-footer-about .fse-paragraph { font-size: 0.95rem; line-height: 1.7; color: rgba(255,255,255,0.7); }
.fse-footer-menu { list-style: none; padding: 0; margin: 0; text-align: left; }
.fse-footer-menu li { margin-bottom: 10px; }
.fse-footer-menu li a { color: rgba(255,255,255,0.8); text-decoration: none; transition: color 0.3s ease; }
.fse-footer-menu li a:hover { color: var(--td-color-primary); }
.fse-contact-list { list-style: none; padding: 0; margin: 0; text-align: left; }
.fse-contact-list li { margin-bottom: 12px; display: flex; align-items: flex-start; gap: 10px; justify-content: flex-start; font-size: 0.95rem; color: rgba(255,255,255,0.8); }
.fse-contact-list i { width: 20px; color: var(--td-color-primary); flex-shrink: 0; margin-top: 3px; }
.fse-footer-bottom { border-top: 1px solid rgba(255,255,255,0.15); padding-top: 20px; text-align: center; margin-top: 40px; }
.fse-copyright { font-size: 14px; text-align: center; color: rgba(255,255,255,0.6); }
@media (max-width: 768px) {
  .fse-footer-columns { grid-template-columns: 1fr; gap: 30px; }
  .fse-footer-columns .fse-column { text-align: center; }
  .fse-footer-columns .fse-column h4 { text-align: center; }
  .fse-footer-menu { text-align: center; }
  .fse-contact-list li { justify-content: center; }
}

/* Global Dark Colors */
:root {
  --td-color-primary: #1e3a8a; /* Deep Blue */
  --td-color-secondary: #ff8c00; /* Dark Orange */
  --td-color-background: #0a0a0e; /* Near Black */
  --td-color-background-alt: #1a1a2e; /* Slightly Lighter Dark */
  --td-color-text: #f0f0f0; /* Light Gray */
  --td-color-heading: #ffffff; /* White */
  --td-color-link: var(--td-color-primary);
  --td-color-link-hover: #ff8c00;
  --td-color-btn-primary-bg: var(--td-color-primary);
  --td-color-btn-primary-text: #ffffff;
  --td-color-btn-primary-hover: #2a52b1;
  --td-color-btn-secondary-bg: var(--td-color-secondary);
  --td-color-btn-secondary-text: #ffffff;
  --td-color-btn-secondary-hover: #ffad42;
  --td-color-header-bg: #0a0a0e;
  --td-color-header-text: #ffffff;
  --td-color-footer-bg: #111116;
  --td-color-footer-text: #f0f0f0;
  --td-font-body: 'Inter', sans-serif;
  --td-font-heading: 'Outfit', sans-serif;
  --td-font-size-base: 16px;
  --td-heading-scale: 1.25;
}
/* === Scroll Reveal Animation System === */
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes fadeSlideLeft {
  from { opacity: 0; transform: translateX(-30px); }
  to { opacity: 1; transform: translateX(0); }
}
@keyframes fadeSlideRight {
  from { opacity: 0; transform: translateX(30px); }
  to { opacity: 1; transform: translateX(0); }
}
@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.95); }
  to { opacity: 1; transform: scale(1); }
}
.animate-on-scroll { opacity: 0; }
.animate-slide-left { opacity: 0; }
.animate-slide-right { opacity: 0; }
.animate-scale { opacity: 0; }
.animate-on-scroll.visible { animation: fadeSlideUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards; }
.animate-slide-left.visible { animation: fadeSlideLeft 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards; }
.animate-slide-right.visible { animation: fadeSlideRight 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards; }
.animate-scale.visible { animation: scaleIn 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards; }
/* Hover micro-interactions — buttons only lighten slightly, no underline, no text color change */
.fse-button { transition: transform 0.3s ease, box-shadow 0.3s ease, filter 0.2s ease; }
.fse-button:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,0.15); filter: brightness(1.1); text-decoration: none !important; }
.fse-button:hover * { text-decoration: none !important; color: inherit !important; }

