/*
Theme Name: MyDewCast
Theme URI: https://mydewcast.com
Author: 麦地传播
Description: v3 — Emerald Gold · 品牌与用户一同生长
Version: 3.0.0
Text Domain: mydewcast
*/

/* ============================================================
   VI DESIGN TOKENS · 2026-06-20
   ============================================================ */
:root {
  /* ── Palette ── */
  --clr-primary:        #064e3b;
  --clr-accent-green:   #34d399;
  --clr-accent-gold:    #eab308;
  --clr-bg-light:       #ecfdf5;
  --clr-bg-white:       #f8fafc;
  --clr-bg-dark:        #0a0a0a;
  --clr-hero:           #064e3b;
  --clr-text-primary:   #0f172a;
  --clr-text-body:      #334155;
  --clr-text-muted:     #64748b;
  --clr-border:         #e2e8f0;
  --clr-glass-bg:       rgba(6,78,59,0.70);
  --clr-glass-border:   rgba(52,211,153,0.14);

  /* ── Typography ── */
  --font-display-cn: 'Noto Serif SC', 'STSong', 'Songti SC', serif;
  --font-display-en: 'Playfair Display', 'Georgia', serif;
  --font-body:      'Noto Serif SC', 'STSong', serif;
  --font-mono:      'JetBrains Mono', 'SF Mono', monospace;

  /* ── Spacing (Airy · 12px base) ── */
  --sp-xs: 0.75rem;    /* 12px */
  --sp-sm: 1.5rem;     /* 24px */
  --sp-md: 3rem;       /* 48px */
  --sp-lg: 6rem;       /* 96px */
  --sp-xl: 8rem;       /* 128px */
  --container: 80rem;  /* 1280px */

  /* ── Radius (Sharp) ── */
  --r-sm: 4px;
  --r-md: 8px;
  --r-lg: 12px;

  /* ── Shadows (Subtle) ── */
  --sh-hover: 0 1px 2px rgba(0,0,0,0.30);
  --sh-card:  0 4px 16px rgba(0,0,0,0.40);
  --sh-glow:  0 4px 24px rgba(52,211,153,0.12);
  --sh-gold:  0 4px 24px rgba(234,179,8,0.18);

  /* ── Animation ── */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in:  cubic-bezier(0.4, 0, 1, 1);
  --ease-both: cubic-bezier(0.65, 0, 0.35, 1);
  --dur-fast: 200ms;
  --dur-normal: 400ms;
  --dur-slow: 600ms;
  --dur-hero: 800ms;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  font-family:var(--font-body);
  background:var(--clr-bg-dark);
  color:var(--clr-text-body);
  line-height:1.75;
  font-size:17px;
  overflow-x:hidden;
  cursor:default;
}
a{color:var(--clr-accent-green);text-decoration:none;transition:color var(--dur-fast) var(--ease-out)}
a:hover{color:var(--clr-accent-gold)}
img,video{max-width:100%;height:auto;display:block}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display-cn);color:var(--clr-text-primary);font-weight:700;line-height:1.2;letter-spacing:-0.01em}
::selection{background:rgba(52,211,153,0.2);color:#fff}

/* ── Noise Overlay ── */
.noise-layer{
  position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:0.04;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ── Cursor Glow ── */
.cursor-glow{
  position:fixed;z-index:9998;pointer-events:none;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(52,211,153,0.12) 0%,transparent 70%);
  transform:translate(-50%,-50%);opacity:0;transition:opacity .3s;
}
.cursor-glow.visible{opacity:1}
@media(max-width:768px){.cursor-glow{display:none}}

/* ============================================================
   LAYOUT
   ============================================================ */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--sp-sm)}
.section{padding-top:var(--sp-lg);padding-bottom:var(--sp-lg)}
.section-sm{padding-top:var(--sp-md);padding-bottom:var(--sp-md)}
.section-dark{background:var(--clr-bg-dark)}
.section-dark h1,.section-dark h2,.section-dark h3{color:var(--clr-bg-white)}
.section-light{background:var(--clr-bg-light)}
.section-white{background:var(--clr-bg-white)}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.display-xl{font-family:var(--font-display-cn);font-size:clamp(3rem,7vw,5.5rem);font-weight:900;line-height:1.08;letter-spacing:-0.03em;color:var(--clr-bg-white)}
.display-lg{font-family:var(--font-display-cn);font-size:clamp(2.25rem,5vw,3.5rem);font-weight:700;line-height:1.15;letter-spacing:-0.02em}
.display{font-family:var(--font-display-cn);font-size:clamp(1.75rem,3vw,2.5rem);font-weight:700;line-height:1.2}
.heading{font-family:var(--font-display-cn);font-size:clamp(1.25rem,2vw,1.75rem);font-weight:700;line-height:1.25}
.body-lg{font-size:1.125rem;line-height:1.75}
.body{font-size:1rem;line-height:1.75}
.sm{font-size:0.875rem;line-height:1.65}
.xs{font-size:0.75rem;line-height:1.5}
.text-gold{color:var(--clr-accent-gold)}
.text-green{color:var(--clr-accent-green)}
.text-muted{color:var(--clr-text-muted)}
.text-center{text-align:center}
.font-bold{font-weight:700}
.font-black{font-weight:900}
.uppercase{text-transform:uppercase;letter-spacing:0.08em}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.9rem 2rem;font-family:var(--font-display-en);font-size:0.95rem;
  font-weight:600;border-radius:var(--r-md);border:none;cursor:pointer;
  transition:all var(--dur-normal) var(--ease-out);text-decoration:none;
  position:relative;overflow:hidden;
}
.btn:active{transform:scale(0.97)}
.btn-primary{background:var(--clr-accent-gold);color:var(--clr-bg-dark)}
.btn-primary:hover{color:var(--clr-bg-dark);box-shadow:var(--sh-gold);transform:translateY(-2px)}
.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,0.5)}
.btn-outline:hover{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.5);transform:translateY(-2px)}
.btn-lg{padding:1.1rem 2.5rem;font-size:1rem}
.btn-ghost{background:transparent;color:var(--clr-accent-green);border:1.5px solid var(--clr-accent-green)}
.btn-ghost:hover{background:var(--clr-accent-green);color:#fff}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:0.75rem 0;transition:all var(--dur-normal) var(--ease-out);
}
.site-header.scrolled{
  background:rgba(10,10,10,0.90);backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,0.06);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.header-logo{display:flex;align-items:center;gap:0.5rem;color:#fff;font-family:var(--font-display-en);font-size:1.2rem;font-weight:700;text-decoration:none}
.header-logo:hover{opacity:0.85}
.header-logo img{height:34px;width:auto}
.header-logo-text{display:flex;align-items:baseline;gap:0.4rem}
.header-logo-cn{font-family:var(--font-display-cn);font-size:1.15rem;font-weight:700;color:#fff}
.header-logo-divider{color:rgba(255,255,255,0.25);font-weight:300}
.header-logo-en{font-family:'Caveat',cursive;color:var(--clr-accent-gold);font-size:1.25rem;font-weight:600;line-height:1}

.nav-desktop{display:none;align-items:center;gap:0.25rem}
.nav-desktop a{padding:0.5rem 0.9rem;font-size:0.85rem;font-weight:500;color:rgba(255,255,255,0.65);border-radius:var(--r-sm);transition:all var(--dur-fast) var(--ease-out)}
.nav-desktop a:hover{color:#fff;background:rgba(255,255,255,0.06)}
.nav-desktop .nav-cta{margin-left:0.4rem;padding:0.45rem 1.1rem;background:var(--clr-accent-gold);color:var(--clr-bg-dark);font-weight:600}
.nav-desktop .nav-cta:hover{background:#f0c020;color:var(--clr-bg-dark)}

.mobile-toggle{display:flex;flex-direction:column;gap:5px;padding:0.5rem;background:none;border:none;cursor:pointer;z-index:110}
.mobile-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all var(--dur-fast) var(--ease-out)}
.mobile-nav{position:fixed;inset:0;background:rgba(6,78,59,0.97);backdrop-filter:blur(20px);z-index:90;display:none;flex-direction:column;align-items:center;justify-content:center;gap:1rem}
.mobile-nav.open{display:flex}
.mobile-nav a{font-size:1.4rem;font-weight:700;font-family:var(--font-display-cn);color:rgba(255,255,255,0.8);padding:0.75rem 1.5rem;border-radius:var(--r-md);transition:all var(--dur-fast)}
.mobile-nav a:hover{color:#fff;background:rgba(255,255,255,0.08)}

@media(min-width:768px){.nav-desktop{display:flex}.mobile-toggle{display:none}}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  justify-content:center;overflow:hidden;background:var(--clr-hero);
}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:0.75}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(4,40,24,0.35) 0%,rgba(2,44,34,0.15) 40%,rgba(4,40,24,0.65) 100%)}
.hero-bg-pulse{
  position:absolute;inset:-30%;z-index:0;
  background:radial-gradient(ellipse at 30% 30%,rgba(52,211,153,0.18) 0%,transparent 50%),
             radial-gradient(ellipse at 70% 60%,rgba(234,179,8,0.08) 0%,transparent 45%),
             radial-gradient(ellipse at 50% 80%,rgba(52,211,153,0.12) 0%,transparent 40%);
  animation:heroPulse 10s ease-in-out infinite alternate;
}
@keyframes heroPulse{0%{opacity:0.6;transform:scale(1)}100%{opacity:1;transform:scale(1.08)}}
.hero-grid{
  position:absolute;inset:0;z-index:0;opacity:0.03;
  background-image:linear-gradient(rgba(255,255,255,.1) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center,black 25%,transparent 70%);
}
.hero-content{position:relative;z-index:10;text-align:center;max-width:56rem;padding:6rem var(--sp-sm) 4rem}
.hero-badge{display:inline-flex;align-items:center;gap:0.5rem;padding:0.5rem 1.2rem;border-radius:99px;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.04);backdrop-filter:blur(10px);font-size:0.8rem;font-weight:500;color:rgba(255,255,255,0.7);margin-bottom:2rem;letter-spacing:0.04em}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--clr-accent-gold);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.3;transform:scale(0.5)}}
.hero-title{font-family:'Inter',system-ui,-apple-system,sans-serif;color:#fff;margin-bottom:1.5rem;font-size:clamp(2.2rem,5.5vw,4.5rem);font-weight:800;line-height:1.15;letter-spacing:-0.02em}
.hero-title-line{display:block;overflow:hidden;white-space:nowrap}
.hero-title-line span{display:block;transform:translateY(120%)}
.hero-subtitle{font-size:clamp(1.05rem,1.8vw,1.25rem);color:rgba(255,255,255,0.78);max-width:36rem;margin:0 auto 2.5rem;line-height:1.7}
.hero-cta-group{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:10;display:flex;flex-direction:column;align-items:center;gap:0.5rem;color:rgba(255,255,255,0.35);font-size:0.75rem}
.hero-scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,rgba(255,255,255,0.3),transparent)}

/* ============================================================
   SECTION HEADER
   ============================================================ */
.section-header{text-align:center;max-width:34rem;margin:0 auto var(--sp-md)}
.section-header .tag{display:inline-block;padding:0.3rem 0.9rem;border-radius:99px;background:rgba(52,211,153,0.1);color:var(--clr-accent-green);font-size:0.78rem;font-weight:600;margin-bottom:var(--sp-xs);letter-spacing:0.05em;text-transform:uppercase}
.section-header h2{font-size:clamp(1.75rem,3.5vw,2.8rem);font-weight:700;margin-bottom:var(--sp-xs);color:var(--clr-text-primary)}
.section-header p{font-size:1.05rem;color:var(--clr-text-muted);line-height:1.7}
.section-dark .section-header h2{color:#fff}
.section-dark .section-header p{color:rgba(255,255,255,0.55)}
.section-dark .section-header .tag{background:rgba(52,211,153,0.12);color:var(--clr-accent-green)}

/* ============================================================
   CARDS
   ============================================================ */
.card{
  background:var(--clr-bg-white);border:1px solid var(--clr-border);
  border-radius:var(--r-md);padding:var(--sp-sm);transition:all var(--dur-normal) var(--ease-out)
}
.card:hover{box-shadow:var(--sh-card);transform:translateY(-3px);border-color:transparent}

/* Glass card */
.card-glass{
  background:var(--clr-glass-bg);backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);border:1px solid var(--clr-glass-border);
  border-radius:var(--r-md);padding:var(--sp-sm);
  transition:all var(--dur-normal) var(--ease-out);
}
.card-glass:hover{background:rgba(6,78,59,0.82);border-color:rgba(52,211,153,0.25);box-shadow:0 12px 40px rgba(6,78,59,0.35);transform:translateY(-4px)}
.card-glass h3{color:#fff}
.card-glass p{color:rgba(255,255,255,0.68)}
.card-glass .card-icon{background:rgba(52,211,153,0.12)}
.card-glass .card-icon svg{color:var(--clr-accent-gold)}

.card-icon{width:2.5rem;height:2.5rem;border-radius:var(--r-sm);background:rgba(52,211,153,0.08);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-xs);flex-shrink:0}
.card-icon svg{width:1.25rem;height:1.25rem;color:var(--clr-primary)}
.card h3{font-size:1.2rem;margin-bottom:0.5rem}
.card p{font-size:0.95rem;color:var(--clr-text-body);line-height:1.7}

.card-header{display:flex;align-items:center;gap:0.75rem;margin-bottom:0.75rem}
.card-header h3{margin-bottom:0;font-size:1.15rem}

/* Grid */
.grid-2{display:grid;gap:var(--sp-sm)}
.grid-3{display:grid;gap:var(--sp-sm)}
.grid-4{display:grid;gap:var(--sp-sm)}
.grid-5{display:grid;gap:var(--sp-sm)}
@media(min-width:640px){.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}.grid-4{grid-template-columns:repeat(2,1fr)}.grid-5{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-5{grid-template-columns:repeat(5,1fr)}}

/* ============================================================
   SERVICE CARDS
   ============================================================ */
.service-card{
  background:var(--clr-glass-bg);backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);border:1px solid var(--clr-glass-border);
  border-radius:var(--r-md);padding:var(--sp-sm);height:100%;
  transition:all var(--dur-normal) var(--ease-out);
}
.service-card:hover{background:rgba(6,78,59,0.82);border-color:rgba(52,211,153,0.25);box-shadow:0 12px 40px rgba(6,78,59,0.35);transform:translateY(-4px)}
.service-card-header{display:flex;align-items:center;gap:0.75rem;margin-bottom:0.75rem}
.service-card-icon{width:2.25rem;height:2.25rem;border-radius:var(--r-sm);background:rgba(52,211,153,0.12);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.service-card-icon svg{width:1.15rem;height:1.15rem;color:var(--clr-accent-gold)}
.service-card h3{font-size:1.1rem;color:#fff;margin-bottom:0}
.service-card-desc{font-size:0.88rem;color:rgba(255,255,255,0.6);margin-bottom:1rem;line-height:1.65}
.service-card-features{display:flex;flex-direction:column;gap:0.4rem}
.service-card-features li{font-size:0.82rem;color:rgba(255,255,255,0.55);display:flex;align-items:center;gap:0.5rem}
.service-card-features li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--clr-accent-gold);flex-shrink:0}
.service-card-timeline{display:inline-block;margin-top:1rem;padding:0.3rem 0.8rem;border-radius:99px;background:rgba(52,211,153,0.1);font-size:0.72rem;font-weight:600;color:var(--clr-accent-green)}

/* ============================================================
   CASE STUDY CARDS
   ============================================================ */
.case-card{background:var(--clr-bg-white);border-radius:var(--r-md);overflow:hidden;border:1px solid var(--clr-border);transition:all var(--dur-normal) var(--ease-out)}
.case-card:hover{box-shadow:0 20px 40px rgba(0,0,0,0.15);transform:translateY(-5px);border-color:transparent}
.case-card-media{height:13rem;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--clr-primary),#022c22)}
.case-card-media::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(6,78,59,0.9),transparent 60%);opacity:0;transition:opacity .3s ease;z-index:1}
.case-card:hover .case-card-media::after{opacity:1}
.case-card-media svg{transition:transform .3s ease;z-index:0;color:rgba(52,211,153,0.3)}
.case-card:hover .case-card-media svg{transform:scale(1.1)}
.case-card-media-label{position:absolute;bottom:1rem;left:1rem;z-index:2;color:#fff;font-size:0.78rem;font-weight:600;opacity:0;transform:translateY(8px);transition:all .3s ease}
.case-card:hover .case-card-media-label{opacity:1;transform:translateY(0)}
.case-card-body{padding:1.25rem}
.case-card-tags{display:flex;flex-wrap:wrap;gap:0.4rem;margin-bottom:0.6rem}
.case-card-tag{padding:0.2rem 0.65rem;border-radius:99px;background:rgba(52,211,153,0.08);color:var(--clr-primary);font-size:0.72rem;font-weight:600}
.case-card-body h3{font-size:1.05rem;margin-bottom:0.4rem}
.case-card-body p{font-size:0.85rem;color:var(--clr-text-body);margin-bottom:0.6rem;line-height:1.6}
.case-metric{font-size:0.78rem;font-weight:700;color:var(--clr-primary)}

/* ============================================================
   PROCESS STEPS
   ============================================================ */
.process-grid{display:grid;gap:var(--sp-sm);position:relative}
@media(min-width:768px){.process-grid{grid-template-columns:repeat(4,1fr)}}
.process-step{text-align:center}
.process-num{width:3rem;height:3rem;margin:0 auto 1rem;border-radius:50%;background:rgba(52,211,153,0.1);border:2px solid rgba(52,211,153,0.2);display:flex;align-items:center;justify-content:center;font-family:var(--font-display-en);font-size:1.1rem;font-weight:700;color:var(--clr-accent-green);transition:all var(--dur-fast)}
.process-step:hover .process-num{background:var(--clr-accent-green);color:var(--clr-bg-dark);border-color:var(--clr-accent-green)}
.process-step h4{color:#fff;font-size:1rem;margin-bottom:0.4rem}
.process-step p{font-size:0.82rem;color:rgba(255,255,255,0.5)}

/* ============================================================
   BLOG CARDS
   ============================================================ */
.blog-card{display:block;background:var(--clr-bg-white);border-radius:var(--r-md);overflow:hidden;border:1px solid var(--clr-border);transition:all var(--dur-normal) var(--ease-out);color:inherit;text-decoration:none}
.blog-card:hover{box-shadow:var(--sh-card);transform:translateY(-3px);border-color:transparent}
.blog-card-image{height:10rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--clr-primary),var(--clr-bg-dark));position:relative;overflow:hidden}
.blog-card-image svg{color:rgba(52,211,153,0.3);position:relative;z-index:1}
.blog-card-body{padding:1.25rem}
.blog-card-meta{display:flex;align-items:center;gap:0.6rem;margin-bottom:0.6rem;font-size:0.72rem;color:var(--clr-text-muted)}
.blog-card-cat{padding:0.15rem 0.6rem;border-radius:99px;background:rgba(52,211,153,0.08);color:var(--clr-primary);font-weight:600}
.blog-card h3{font-size:1.05rem;margin-bottom:0.4rem;transition:color var(--dur-fast)}
.blog-card:hover h3{color:var(--clr-primary)}
.blog-card p{font-size:0.85rem;color:var(--clr-text-body);line-height:1.6}

/* ============================================================
   INDUSTRY BADGES
   ============================================================ */
.industry-grid{display:grid;gap:0.75rem;max-width:42rem;margin:0 auto;grid-template-columns:repeat(2,1fr)}
@media(min-width:640px){.industry-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.industry-grid{grid-template-columns:repeat(6,1fr)}}
.industry-badge{display:flex;align-items:center;justify-content:center;padding:0.9rem 1rem;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,0.08);font-size:0.8rem;font-weight:500;color:rgba(255,255,255,0.5);transition:all var(--dur-fast) var(--ease-out);cursor:default}
.industry-badge:hover{border-color:var(--clr-accent-green);color:var(--clr-accent-green);background:rgba(52,211,153,0.05)}

/* ============================================================
   STAT CARDS
   ============================================================ */
.stat-card{text-align:center;padding:2rem 1rem}
.stat-number{font-family:var(--font-mono);font-size:clamp(2.5rem,5vw,3.5rem);font-weight:700;color:var(--clr-accent-green);line-height:1;margin-bottom:0.25rem}
.stat-label{font-size:0.88rem;color:rgba(255,255,255,0.45);font-weight:500}

/* ============================================================
   FILTER BAR
   ============================================================ */
.filter-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:0.4rem;margin-bottom:var(--sp-md)}
.filter-btn{padding:0.5rem 1.2rem;border-radius:99px;border:1px solid var(--clr-border);background:var(--clr-bg-white);cursor:pointer;font-family:var(--font-body);font-size:0.82rem;font-weight:500;color:var(--clr-text-body);transition:all var(--dur-fast) var(--ease-out)}
.filter-btn:hover{border-color:var(--clr-accent-green);color:var(--clr-primary)}
.filter-btn.active{background:var(--clr-primary);border-color:var(--clr-primary);color:#fff}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{max-width:38rem;margin:0 auto;display:flex;flex-direction:column;gap:0.6rem}
.faq-item{border:1px solid var(--clr-border);border-radius:var(--r-md);overflow:hidden;background:var(--clr-bg-white)}
.faq-q{width:100%;padding:1.1rem 1.25rem;background:none;border:none;cursor:pointer;text-align:left;font-family:var(--font-body);font-size:0.95rem;font-weight:600;color:var(--clr-text-primary);display:flex;justify-content:space-between;align-items:center;transition:background var(--dur-fast)}
.faq-q:hover{background:var(--clr-bg-light)}
.faq-q::after{content:'+';font-size:1.3rem;color:var(--clr-accent-green);transition:transform var(--dur-fast)}
.faq-item.open .faq-q::after{content:'−';transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.faq-item.open .faq-a{max-height:14rem;padding:0 1.25rem 1.25rem}
.faq-a p{font-size:0.9rem;color:var(--clr-text-body);line-height:1.7}

/* ============================================================
   CTA SECTION
   ============================================================ */
.cta-section{background:var(--clr-primary);position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(52,211,153,0.12) 0%,transparent 50%),radial-gradient(ellipse at 70% 50%,rgba(234,179,8,0.06) 0%,transparent 50%);z-index:0}
.cta-content{position:relative;z-index:1;text-align:center;max-width:32rem;margin:0 auto}
.cta-content h2{color:#fff;font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:700;margin-bottom:1rem}
.cta-content p{color:rgba(255,255,255,0.55);font-size:1.05rem;margin-bottom:1.75rem;line-height:1.7}
.cta-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:0.75rem}
.cta-note{margin-top:1rem;font-size:0.8rem;color:rgba(255,255,255,0.35)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--clr-bg-dark);border-top:1px solid rgba(255,255,255,0.05)}
.footer-grid{display:grid;gap:var(--sp-md);padding:var(--sp-sm) 0 var(--sp-lg)}
@media(min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1fr}}
.footer-brand{color:rgba(255,255,255,0.45);font-size:0.88rem;line-height:1.7;max-width:20rem}
.footer-brand a{display:flex;align-items:center;gap:0.4rem;margin-bottom:0.75rem;text-decoration:none}
.footer-brand a img{height:28px;width:auto}
.footer-col h4{color:#fff;font-size:0.78rem;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:1rem}
.footer-col nav{display:flex;flex-direction:row;flex-wrap:wrap;gap:0.75rem 1.25rem}
.footer-col nav a{font-size:0.85rem;color:rgba(255,255,255,0.5);transition:color var(--dur-fast)}
.footer-col nav a:hover{color:var(--clr-accent-green)}
.footer-col address{font-style:normal;font-size:0.85rem;color:rgba(255,255,255,0.5);line-height:1.8}
.footer-col address a{color:rgba(255,255,255,0.5);transition:color var(--dur-fast)}
.footer-col address a:hover{color:var(--clr-accent-green)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.05);padding:1.25rem 0;text-align:center;font-size:0.78rem;color:rgba(255,255,255,0.3)}

/* ============================================================
   FORMS
   ============================================================ */
.form-grid{display:grid;gap:var(--sp-md)}
@media(min-width:768px){.form-grid{grid-template-columns:1fr 1fr}}
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:0.8rem;font-weight:600;color:var(--clr-text-primary);margin-bottom:0.3rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:0.8rem 1rem;border:1px solid var(--clr-border);border-radius:var(--r-sm);font-family:var(--font-body);font-size:0.9rem;color:var(--clr-text-primary);background:var(--clr-bg-white);transition:border-color var(--dur-fast)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--clr-accent-green);box-shadow:0 0 0 3px rgba(52,211,153,0.1)}
.form-group textarea{min-height:7rem;resize:vertical}

/* ============================================================
   PAGE HEADER
   ============================================================ */
.page-header{position:relative;padding-top:7rem;padding-bottom:var(--sp-md);background:var(--clr-primary);text-align:center;overflow:hidden}
.page-header-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:0.5}
.page-header-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(4,40,24,0.65) 0%,rgba(2,44,34,0.5) 100%)}
.page-header .container{position:relative;z-index:2}
.page-header h1{color:#fff;font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:0.5rem}
.page-header p{color:rgba(255,255,255,0.65);font-size:1rem;max-width:28rem;margin:0 auto}

/* ============================================================
   METHODOLOGY
   ============================================================ */
.method-grid{display:grid;gap:var(--sp-sm)}
@media(min-width:768px){.method-grid{grid-template-columns:repeat(4,1fr)}}
.method-item{text-align:center}
.method-num{width:2.25rem;height:2.25rem;margin:0 auto 0.6rem;border-radius:50%;background:var(--clr-accent-green);color:var(--clr-bg-dark);display:flex;align-items:center;justify-content:center;font-family:var(--font-display-en);font-size:0.85rem;font-weight:700}
.method-item h4{color:#fff;font-size:0.9rem;margin-bottom:0.3rem}
.method-item p{font-size:0.8rem;color:rgba(255,255,255,0.5)}

/* ============================================================
   SUBSCRIPTION
   ============================================================ */
.subscribe-box{max-width:26rem;margin:var(--sp-lg) auto 0;text-align:center;padding:2.5rem;border-radius:var(--r-md);background:var(--clr-bg-light)}
.subscribe-box h3{font-size:1.15rem;margin-bottom:0.5rem}
.subscribe-box p{font-size:0.85rem;color:var(--clr-text-muted);margin-bottom:1.25rem}
.subscribe-form{display:flex;gap:0.5rem}
.subscribe-form input{flex:1;padding:0.7rem 1rem;border:1px solid var(--clr-border);border-radius:var(--r-sm);font-family:var(--font-body);font-size:0.85rem}
.subscribe-form input:focus{outline:none;border-color:var(--clr-accent-green)}

/* ============================================================
   POST SUBMIT STEPS
   ============================================================ */
.step-list{display:flex;flex-direction:column;gap:1.25rem}
.step-item{display:flex;gap:0.9rem;align-items:flex-start}
.step-num{flex-shrink:0;width:2rem;height:2rem;border-radius:50%;background:var(--clr-accent-green);color:var(--clr-bg-dark);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.85rem}
.step-item h4{font-size:0.95rem;margin-bottom:0.2rem}
.step-item p{font-size:0.82rem;color:var(--clr-text-muted)}

/* ============================================================
   MAGNETIC ELEMENT
   ============================================================ */
.magnetic{display:inline-block;transition:transform .4s cubic-bezier(.33,1,.68,1)}

/* ============================================================
   ANIMATIONS · GSAP hooks
   ============================================================ */
[data-gsap-reveal]{opacity:0;transform:translateY(40px)}
[data-gsap-reveal].revealed{opacity:1;transform:translateY(0)}

/* Motion One fallback — used when GSAP not yet loaded */
@media(prefers-reduced-motion:reduce){
  [data-gsap-reveal]{opacity:1;transform:none}
  .hero-title-line span{transform:none}
  .cursor-glow{display:none}
}

/* ============================================================
   UTILITY
   ============================================================ */
.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}
.mx-auto{margin-left:auto;margin-right:auto}
.w-full{width:100%}
.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}
.gap-1{gap:0.25rem}.gap-2{gap:0.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}
.mt-4{margin-top:1rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}
.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}
.relative{position:relative}.hidden{display:none}
