/*
Theme Name: Riddhi Studio
Theme URI: https://riddhistudio.com
Author: Vikas Bhardwaj
Description: Riddhi Studio — One Membership. Every WordPress Tool We Build. Plugins + Themes All-Access Club.
Version: 5.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GPL v2 or later
Text Domain: riddhistudio
Tags: plugin-sales, light, modern, professional, woocommerce
*/

/* ============================================================
   BOOTSTRAP VARIABLE OVERRIDES  (must be in :root before BS loads)
   ============================================================ */
:root {
  --bs-primary:         #059669;
  --bs-primary-rgb:     5,150,105;
  --bs-body-font-family:'Inter', system-ui, sans-serif;
  --bs-body-font-size:  1rem;
  --bs-body-line-height:1.65;
  --bs-body-color:      #111827;
  --bs-border-color:    #E5E7EB;
  --bs-border-radius:   10px;
  --bs-border-radius-lg:16px;
  --bs-link-color:      #4F46E5;
  --bs-link-hover-color:#4338CA;
}

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  /* Backgrounds */
  --c-bg:         #FFFFFF;
  --c-bg-alt:     #F9FAFB;
  --c-bg-deep:    #F3F4F6;
  --c-surface:    #FFFFFF;

  /* Brand — CTA / Conversion (green — "go", "money", "growth") */
  --c-primary:    #059669;
  --c-primary-dk: #047857;
  --c-primary-lt: #ECFDF5;

  /* Brand — Trust / Navigation (indigo — "reliable", "tech", "serious") */
  --c-indigo:     #4F46E5;
  --c-indigo-dk:  #4338CA;
  --c-indigo-lt:  #EEF2FF;
  --c-indigo-foc: #A5B4FC;

  /* Accent */
  --c-accent:     #0EA5E9;
  --c-accent-lt:  #E0F2FE;

  /* Semantic */
  --c-green:      #059669;
  --c-green-lt:   #ECFDF5;
  --c-amber:      #D97706;
  --c-amber-lt:   #FFFBEB;
  --c-red:        #DC2626;
  --c-red-lt:     #FEF2F2;

  /* Text */
  --c-text:       #111827;
  --c-text-2:     #374151;
  --c-muted:      #6B7280;
  --c-subtle:     #9CA3AF;
  --c-ghost:      #D1D5DB;

  /* Borders */
  --c-border:     #E5E7EB;
  --c-border-md:  #D1D5DB;
  --c-border-foc: #6EE7B7;

  /* Typography */
  --f-display:    'Plus Jakarta Sans', system-ui, sans-serif;
  --f-body:       'Inter', system-ui, sans-serif;
  --f-mono:       'JetBrains Mono', 'Courier New', monospace;

  /* Radii */
  --r-xs: 4px;
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 18px;
  --r-xl: 24px;
  --r-2xl:32px;

  /* Shadows */
  --sh-xs: 0 1px 2px rgba(17,24,39,.05);
  --sh-sm: 0 1px 3px rgba(17,24,39,.08), 0 0 0 1px rgba(17,24,39,.04);
  --sh-md: 0 4px 16px rgba(17,24,39,.09), 0 1px 4px rgba(17,24,39,.05);
  --sh-lg: 0 8px 32px rgba(17,24,39,.11), 0 2px 8px rgba(17,24,39,.05);
  --sh-xl: 0 20px 60px rgba(17,24,39,.14), 0 4px 16px rgba(17,24,39,.06);
  --sh-glow:0 0 0 3px rgba(5,150,105,.15);
  --sh-glow-lg:0 8px 32px rgba(5,150,105,.25);

  /* Motion */
  --ease: cubic-bezier(.16,1,.3,1);
  --t:    .2s cubic-bezier(.4,0,.2,1);

  /* Layout */
  --mw: 1180px;
  --mh: 0px;   /* masthead height — set by JS */
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--c-bg);color:var(--c-text);
  font-family:var(--f-body);font-size:1rem;line-height:1.65;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  font-feature-settings:'cv11','ss01';overflow-x:hidden;
}
a{color:var(--c-indigo);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--c-indigo-dk)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
button{font-family:var(--f-body)}
h1,h2,h3,h4,h5,h6{
  font-family:var(--f-display);font-weight:700;
  line-height:1.18;color:var(--c-text);letter-spacing:-.018em;
  font-feature-settings:'cv11'
}
p{color:var(--c-muted);line-height:1.75}

/* ============================================================
   LAYOUT
   ============================================================ */
.rs-container{max-width:var(--mw);margin:0 auto;padding:0 28px}
.section-pad    {padding:88px 0}
.section-pad-sm {padding:60px 0}
.section-pad-lg {padding:120px 0}
.section-alt    {background:var(--c-bg-alt)}
.section-deep   {background:var(--c-bg-deep)}

/* ============================================================
   TYPOGRAPHY SCALE
   ============================================================ */
.t-display{font-size:clamp(2.5rem,5.5vw,4.75rem);font-weight:800;letter-spacing:-.04em;line-height:1.02;font-family:var(--f-display)}
.t-h1     {font-size:clamp(2rem,4vw,3.25rem);font-weight:700;letter-spacing:-.03em;font-family:var(--f-display)}
.t-h2     {font-size:clamp(1.5rem,2.8vw,2.25rem);font-weight:700;letter-spacing:-.025em;font-family:var(--f-display)}
.t-h3     {font-size:clamp(1.125rem,2vw,1.375rem);font-weight:700;letter-spacing:-.015em;font-family:var(--f-display)}
.t-lead   {font-size:clamp(1rem,1.8vw,1.125rem);line-height:1.75;color:var(--c-muted)}
.t-sm     {font-size:.875rem;line-height:1.5}
.t-xs     {font-size:.8125rem;line-height:1.5}
.t-gradient{background:linear-gradient(135deg,var(--c-indigo) 0%,var(--c-primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.t-muted  {color:var(--c-muted)}

/* Section label pill */
.s-label{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--f-body);font-size:.75rem;font-weight:600;
  letter-spacing:.07em;text-transform:uppercase;
  color:var(--c-indigo);background:var(--c-indigo-lt);
  border:1px solid var(--c-indigo-foc);
  padding:5px 12px;border-radius:var(--r-xs);margin-bottom:16px;
}
.s-label::before{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;background:currentColor}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:11px 22px;border-radius:var(--r-sm);
  font-family:var(--f-body);font-size:.9375rem;font-weight:600;
  cursor:pointer;transition:all var(--t);border:1.5px solid transparent;
  outline:none;white-space:nowrap;text-decoration:none;letter-spacing:-.01em;
  position:relative;
}
.btn:focus-visible{outline:3px solid var(--c-border-foc);outline-offset:2px}
.btn-primary{
  background:var(--c-primary);color:#fff;border-color:var(--c-primary);
  box-shadow:0 1px 3px rgba(5,150,105,.35),0 1px 2px rgba(5,150,105,.2);
}
.btn-primary:hover{
  background:var(--c-primary-dk);border-color:var(--c-primary-dk);color:#fff;
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(5,150,105,.38),0 1px 4px rgba(5,150,105,.2);
}
.btn-primary:active{transform:none;box-shadow:none}
.btn-outline{
  background:transparent;color:var(--c-text-2);
  border-color:var(--c-border-md);box-shadow:var(--sh-xs);
}
.btn-outline:hover{border-color:var(--c-indigo);color:var(--c-indigo);background:var(--c-indigo-lt)}
.btn-white{background:#fff;color:var(--c-primary);border-color:#fff}
.btn-white:hover{background:#ECFDF5;color:var(--c-primary-dk)}
.btn-ghost{background:transparent;color:var(--c-muted);border-color:transparent}
.btn-ghost:hover{color:var(--c-text);background:var(--c-bg-deep)}
/* Indigo variant — for sign-in, secondary nav actions (trust signal) */
.btn-indigo{
  background:var(--c-indigo);color:#fff;border-color:var(--c-indigo);
  box-shadow:0 1px 3px rgba(79,70,229,.28);
}
.btn-indigo:hover{
  background:var(--c-indigo-dk);border-color:var(--c-indigo-dk);color:#fff;
  transform:translateY(-1px);
  box-shadow:0 4px 14px rgba(79,70,229,.3);
}
.btn-lg{padding:14px 28px;font-size:1rem}
.btn-sm{padding:7px 14px;font-size:.8125rem}
.btn-xl{padding:16px 36px;font-size:1.0625rem}
/* Primary conversion CTA — pulsing green for hero + pricing */
.btn-cta{
  background:linear-gradient(135deg,var(--c-primary) 0%,var(--c-primary-dk) 100%);
  color:#fff;border-color:transparent;
  box-shadow:0 2px 8px rgba(5,150,105,.4),0 1px 2px rgba(5,150,105,.2);
  animation:pulse-glow 2.8s ease-in-out infinite;
  font-weight:700;letter-spacing:-.015em;
}
.btn-cta:hover{
  background:linear-gradient(135deg,#047857 0%,#065F46 100%);
  color:#fff;animation:none;
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(5,150,105,.45),0 2px 6px rgba(5,150,105,.25);
}
.btn-cta:active{transform:none;animation:none}

/* ============================================================
   CARDS
   ============================================================ */
.card-base{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:28px;
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
  box-shadow:var(--sh-xs);
}
.card-base:hover{border-color:var(--c-border-foc);box-shadow:var(--sh-md);transform:translateY(-2px)}

/* ============================================================
   BADGES
   ============================================================ */
.badge-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--r-xs);font-size:.71875rem;font-weight:600;letter-spacing:.02em}
.badge-blue  {background:var(--c-indigo-lt);color:var(--c-indigo);border:1px solid var(--c-indigo-foc)}
.badge-green {background:var(--c-green-lt);color:var(--c-green);border:1px solid #A7F3D0}
.badge-amber {background:var(--c-amber-lt);color:var(--c-amber);border:1px solid #FDE68A}
.badge-cyan  {background:var(--c-accent-lt);color:#0284C7;border:1px solid #BAE6FD}

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.announcement-bar{
  background:linear-gradient(90deg,var(--c-primary) 0%,#047857 50%,var(--c-indigo) 100%);
  padding:9px 0;text-align:center;font-family:var(--f-body);
  font-size:.8125rem;font-weight:500;color:#fff;
}
.announcement-bar a{color:#fff;text-decoration:underline;text-underline-offset:2px}
.announcement-bar a:hover{opacity:.85}
.announcement-bar strong{font-weight:700}

/* ============================================================
   MASTHEAD (fixed wrapper: bar + header)
   ============================================================ */
#masthead{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background var(--t),box-shadow var(--t);
}
#masthead.scrolled{
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:var(--sh-sm);
}
#site-header{border-bottom:1px solid transparent;transition:border-color var(--t)}
#masthead.scrolled #site-header{border-bottom-color:var(--c-border)}

.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:66px;padding:0 28px;max-width:var(--mw);margin:0 auto;
}

/* Logo */
.site-logo{
  display:flex;align-items:center;gap:9px;
  font-family:var(--f-display);font-size:1.1875rem;font-weight:800;
  color:var(--c-text);text-decoration:none;letter-spacing:-.02em;flex-shrink:0;
}
.site-logo:hover{color:var(--c-text)}
.logo-icon{
  width:36px;height:36px;
  flex-shrink:0;display:block;
  border-radius:var(--r-sm);
  box-shadow:0 2px 8px rgba(13,59,38,.25);
}
.logo-wordmark span{color:var(--c-indigo)}

/* Desktop nav */
.main-nav{display:flex;align-items:center;gap:1px}
.main-nav a{
  font-family:var(--f-body);color:var(--c-muted);
  font-size:.875rem;font-weight:500;
  padding:7px 12px;border-radius:var(--r-sm);transition:all var(--t);
}
.main-nav a:hover,.main-nav a.active{color:var(--c-text);background:var(--c-bg-deep)}

/* Dropdown */
.has-dropdown{position:relative}
.dropdown-menu-custom{
  position:absolute;top:calc(100% + 10px);left:50%;
  transform:translateX(-50%) translateY(-4px);
  min-width:210px;background:var(--c-surface);
  border:1px solid var(--c-border);border-radius:var(--r-md);
  padding:5px;opacity:0;visibility:hidden;
  transition:opacity var(--t),transform var(--t),visibility var(--t);
  box-shadow:var(--sh-lg);
}
.has-dropdown:hover .dropdown-menu-custom{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown-menu-custom a{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:var(--r-sm);width:100%;color:var(--c-muted);font-size:.875rem}
.dropdown-menu-custom a:hover{color:var(--c-text);background:var(--c-bg-deep)}

.header-actions{display:flex;align-items:center;gap:8px}

/* Mobile menu button */
.mobile-menu-btn{
  display:none;background:none;border:1px solid var(--c-border);
  color:var(--c-text);cursor:pointer;padding:7px;border-radius:var(--r-sm);
}
/* Mobile drawer */
.mobile-nav{
  display:none;position:fixed;left:0;right:0;bottom:0;
  top:var(--mh,104px);
  background:var(--c-bg);z-index:999;padding:16px;
  flex-direction:column;gap:4px;overflow-y:auto;
  border-top:1px solid var(--c-border);
}
.mobile-nav.open{display:flex}
.mobile-nav a{
  display:block;padding:12px 14px;color:var(--c-text-2);
  font-size:.9375rem;font-weight:500;border-radius:var(--r-sm);
  border-bottom:1px solid var(--c-border);
}
.mobile-nav a:hover{color:var(--c-primary);background:var(--c-primary-lt)}
.mobile-nav-cta{display:flex;gap:10px;padding:16px 0}

/* ============================================================
   HERO (split layout)
   ============================================================ */
.hero-section{
  padding-top:var(--mh,104px);
  background:linear-gradient(155deg,#EEF2FF 0%,#F9FAFB 48%,#ECFDF5 100%);
  position:relative;overflow:hidden;
}
.hero-section::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(5,150,105,.08) 1px,transparent 1px);
  background-size:30px 30px;
  mask-image:radial-gradient(ellipse 80% 90% at 50% 10%,black 0%,transparent 100%);
  pointer-events:none;
}
.hero-inner{
  position:relative;z-index:1;
  padding:72px 0 60px;
  min-height:calc(100vh - var(--mh,104px));
  display:flex;align-items:center;
}

/* Left column */
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--f-body);font-size:.75rem;font-weight:600;
  letter-spacing:.07em;text-transform:uppercase;
  color:var(--c-indigo);background:var(--c-indigo-lt);
  border:1px solid var(--c-indigo-foc);
  padding:5px 13px;border-radius:var(--r-xs);margin-bottom:22px;
}
.hero-eyebrow::before{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;background:currentColor}

.hero-title{
  font-size:clamp(2.4rem,5.5vw,4.25rem);font-weight:800;
  letter-spacing:-.04em;line-height:1.04;font-family:var(--f-display);
  color:var(--c-text);margin-bottom:20px;
}
.hero-subtitle{
  font-size:clamp(1rem,1.7vw,1.125rem);color:var(--c-muted);
  line-height:1.75;margin-bottom:34px;max-width:480px;
}
.hero-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.hero-guarantee{font-size:.78125rem;color:var(--c-subtle);margin-top:10px;display:flex;align-items:center;gap:5px}
.hero-guarantee svg{color:var(--c-green);flex-shrink:0}

/* Trust row */
.hero-trust{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hero-avatars{display:flex}
.hero-avatars span{
  width:32px;height:32px;border-radius:50%;border:2px solid #fff;
  background:linear-gradient(135deg,var(--c-primary),var(--c-accent));
  display:flex;align-items:center;justify-content:center;
  font-size:.6875rem;font-weight:700;color:#fff;
  margin-left:-8px;font-family:var(--f-display);flex-shrink:0;
}
.hero-avatars span:first-child{margin-left:0}
.hero-trust-text{font-size:.8125rem;color:var(--c-text-2);font-weight:500}
.hero-trust-text strong{color:var(--c-text);font-weight:700}
.hero-stars{color:#F59E0B;font-size:.875rem;letter-spacing:.5px}
.hero-trust-divider{width:1px;height:20px;background:var(--c-border)}

/* ── Dashboard Mockup ── */
.hero-mockup-wrap{
  position:relative;
  padding:24px 0 24px 32px;
}
.hero-mockup-wrap::before{
  content:'';position:absolute;
  width:400px;height:400px;
  background:radial-gradient(ellipse,rgba(5,150,105,.1) 0%,transparent 65%);
  top:50%;left:50%;transform:translate(-50%,-50%);
  pointer-events:none;
}
.mockup-card{
  background:#fff;border-radius:var(--r-xl);
  box-shadow:var(--sh-xl);border:1px solid var(--c-border);
  overflow:hidden;position:relative;z-index:1;
  animation:float 4s ease-in-out infinite;
}
.mockup-titlebar{
  display:flex;align-items:center;gap:8px;
  padding:12px 16px;background:var(--c-bg-alt);
  border-bottom:1px solid var(--c-border);
}
.mockup-dots{display:flex;gap:5px}
.mockup-dots span{width:11px;height:11px;border-radius:50%}
.mockup-dots .d-red   {background:#FF5F57}
.mockup-dots .d-amber {background:#FEBC2E}
.mockup-dots .d-green {background:#28C840}
.mockup-titlebar-text{font-size:.78125rem;font-weight:600;color:var(--c-muted);font-family:var(--f-body);margin-left:4px}
.mockup-body{padding:20px}

/* Mockup stat row */
.mockup-stats-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.mockup-stat{
  background:var(--c-bg-alt);border:1px solid var(--c-border);
  border-radius:var(--r-sm);padding:12px 14px;
}
.mockup-stat-label{font-size:.6875rem;font-weight:600;color:var(--c-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.mockup-stat-val{font-size:1.25rem;font-weight:800;font-family:var(--f-display);color:var(--c-text);letter-spacing:-.02em}
.mockup-stat-sub{font-size:.6875rem;color:var(--c-green);font-weight:600;margin-top:2px}

/* Mockup plugin list */
.mockup-plugin-list{display:flex;flex-direction:column;gap:8px}
.mockup-plugin-row{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;background:var(--c-bg-alt);
  border-radius:var(--r-sm);border:1px solid var(--c-border);
}
.mockup-plugin-icon{
  width:30px;height:30px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-size:.875rem;flex-shrink:0;
}
.mockup-plugin-name{font-size:.8125rem;font-weight:600;color:var(--c-text);flex:1;font-family:var(--f-display)}
.mockup-bar-wrap{flex:1;height:5px;background:var(--c-border);border-radius:100px;overflow:hidden;max-width:80px}
.mockup-bar{height:100%;border-radius:100px}
.mockup-badge-ok{display:flex;align-items:center;gap:3px;font-size:.6875rem;font-weight:700;color:var(--c-green);flex-shrink:0}

/* Float cards beside mockup */
.mockup-float{
  position:absolute;background:#fff;border-radius:var(--r-md);
  border:1px solid var(--c-border);box-shadow:var(--sh-md);
  padding:10px 14px;z-index:2;
}
.mockup-float-tl{top:-16px;left:-20px}
.mockup-float-br{bottom:-12px;right:-16px}
.mockup-float-label{font-size:.6875rem;color:var(--c-muted);font-weight:500;margin-bottom:2px}
.mockup-float-val{font-size:.9375rem;font-weight:800;color:var(--c-text);font-family:var(--f-display);letter-spacing:-.02em}
.mockup-float-trend{font-size:.6875rem;font-weight:600;color:var(--c-green);display:flex;align-items:center;gap:2px}

/* ============================================================
   COMPATIBILITY STRIP (marquee)
   ============================================================ */
.compat-strip{
  padding:16px 0;border-top:1px solid var(--c-border);
  border-bottom:1px solid var(--c-border);background:var(--c-bg);overflow:hidden;
}
.compat-label{font-size:.75rem;font-weight:600;color:var(--c-subtle);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap;padding:0 28px;flex-shrink:0}
.marquee-outer{overflow:hidden;flex:1}
.marquee-track{display:flex;gap:0;animation:marquee 28s linear infinite;width:max-content}
.marquee-item{
  display:flex;align-items:center;gap:8px;
  padding:6px 24px;
  font-size:.875rem;font-weight:600;color:var(--c-subtle);
  white-space:nowrap;
  border-right:1px solid var(--c-border);
}
.marquee-item svg{flex-shrink:0;color:var(--c-ghost)}

/* ============================================================
   STATS COUNTER SECTION
   ============================================================ */
.stats-section{background:var(--c-indigo);padding:52px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat-item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:0 28px;
  border-right:1px solid rgba(255,255,255,.15);
}
.stat-item:last-child{border-right:none}
.stat-number{
  font-family:var(--f-display);font-size:clamp(2rem,4vw,3rem);
  font-weight:800;color:#fff;letter-spacing:-.04em;
  display:block;margin-bottom:4px;text-align:center;
}
.stat-label{font-size:.875rem;color:rgba(255,255,255,.72);font-weight:500;letter-spacing:-.01em}
.stat-icon{color:rgba(255,255,255,.4);margin-bottom:8px}

/* ============================================================
   PLUGIN CARDS
   ============================================================ */
.plugin-card{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--sh-sm);
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
  display:flex;flex-direction:column;
}
.plugin-card:hover{border-color:var(--c-border-foc);box-shadow:var(--sh-lg);transform:translateY(-3px)}

.plugin-card-header{
  padding:28px 28px 20px;
  position:relative;
}
.plugin-card-icon{
  width:52px;height:52px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  font-size:1.375rem;margin-bottom:16px;
}
.plugin-card h3{font-size:1.125rem;font-weight:700;color:var(--c-text);margin-bottom:6px;letter-spacing:-.015em}
.plugin-card .t-lead{font-size:.875rem;color:var(--c-muted);line-height:1.6}
.plugin-card-badge{position:absolute;top:20px;right:20px}

.plugin-card-features{
  padding:0 28px 20px;flex:1;
  display:flex;flex-direction:column;gap:8px;
}
.plugin-feat-item{
  display:flex;align-items:flex-start;gap:8px;
  font-size:.84375rem;color:var(--c-text-2);line-height:1.5;
}
.plugin-feat-item svg{color:var(--c-green);flex-shrink:0;margin-top:1px}

.plugin-card-footer{
  padding:16px 28px 24px;
  border-top:1px solid var(--c-border);
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;
  margin-top:auto;
}
.plugin-price{font-family:var(--f-display);font-size:1.5rem;font-weight:800;color:var(--c-text);letter-spacing:-.03em;line-height:1}
.plugin-price span{font-size:.875rem;font-weight:400;color:var(--c-muted)}

/* Icon colors */
.icon-blue  {background:var(--c-indigo-lt);color:var(--c-indigo);border:1px solid #C7D2FE}
.icon-cyan  {background:#E0F2FE;color:#0284C7;border:1px solid #BAE6FD}
.icon-green {background:#ECFDF5;color:var(--c-green);border:1px solid #A7F3D0}
.icon-amber {background:#FFFBEB;color:var(--c-amber);border:1px solid #FDE68A}

/* ============================================================
   BENEFITS / FEATURES GRID
   ============================================================ */
.benefit-card{
  display:flex;flex-direction:column;gap:14px;
  padding:28px;background:var(--c-surface);
  border:1px solid var(--c-border);border-radius:var(--r-lg);
  box-shadow:var(--sh-xs);
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
}
.benefit-card:hover{border-color:var(--c-border-foc);box-shadow:var(--sh-md);transform:translateY(-2px)}
.benefit-icon{
  width:44px;height:44px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.benefit-icon svg{width:20px;height:20px}
.benefit-card h4{font-size:1rem;font-weight:700;color:var(--c-text);margin:0}
.benefit-card p{font-size:.875rem;color:var(--c-muted);line-height:1.65;margin:0}

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.how-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;position:relative}
.how-steps::before{
  content:'';position:absolute;
  top:28px;left:calc(16.666% + 28px);right:calc(16.666% + 28px);
  height:1px;background:linear-gradient(90deg,var(--c-indigo-foc),var(--c-border),var(--c-indigo-foc));
  z-index:0;
}
.how-step{text-align:center;position:relative;z-index:1}
.how-step-num{
  width:56px;height:56px;border-radius:50%;
  background:var(--c-indigo);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-size:1.25rem;font-weight:800;
  margin:0 auto 20px;box-shadow:0 8px 32px rgba(79,70,229,.25);
  border:4px solid var(--c-indigo-lt);
}
.how-step h4{font-size:1.0625rem;font-weight:700;color:var(--c-text);margin-bottom:8px}
.how-step p{font-size:.875rem;color:var(--c-muted);line-height:1.65;max-width:240px;margin:0 auto}

/* ============================================================
   COMPARISON TABLE
   ============================================================ */
.comparison-wrap{overflow-x:auto;border-radius:var(--r-xl);border:1px solid var(--c-border);box-shadow:var(--sh-sm)}
.comparison-table{width:100%;border-collapse:collapse;min-width:560px}
.comparison-table thead tr{background:var(--c-bg-alt)}
.comparison-table th{
  padding:18px 24px;text-align:left;
  font-size:.75rem;font-weight:700;color:var(--c-muted);
  text-transform:uppercase;letter-spacing:.07em;
  border-bottom:2px solid var(--c-border);
}
.comparison-table th.col-us{
  background:var(--c-primary-lt);color:var(--c-primary);
  border-bottom-color:var(--c-border-foc);
}
.comparison-table td{
  padding:14px 24px;font-size:.875rem;color:var(--c-muted);
  background:var(--c-surface);border-bottom:1px solid var(--c-border);vertical-align:middle;
}
.comparison-table td.col-us{
  background:#F0FDF9;color:var(--c-text-2);font-weight:600;
}
.comparison-table tr:last-child td{border-bottom:none}
.comparison-table tr:hover td{background:var(--c-bg-alt)}
.comparison-table tr:hover td.col-us{background:#DCFCE7}
.col-feature{font-weight:500;color:var(--c-text-2)}
.check-green{display:inline-flex;align-items:center;gap:5px;color:var(--c-green);font-weight:600}
.check-red  {color:var(--c-subtle)}

/* ============================================================
   PRICING
   ============================================================ */
/* pricing-toggle-wrap removed in v5 — yearly billing only */

.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}

.pricing-card{
  background:var(--c-surface);border:1.5px solid var(--c-border);
  border-radius:var(--r-2xl);padding:36px 28px;position:relative;
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
  box-shadow:var(--sh-sm);
}
.pricing-card:hover{border-color:var(--c-border-foc);box-shadow:var(--sh-md);transform:translateY(-3px)}

.pricing-card.featured{
  background:linear-gradient(155deg,#3730A3 0%,#4F46E5 45%,#4338CA 100%);
  border-color:transparent;transform:scale(1.04);
  box-shadow:0 8px 32px rgba(79,70,229,.35),0 2px 8px rgba(79,70,229,.18);
}
.pricing-card.featured:hover{transform:scale(1.04) translateY(-3px);box-shadow:0 16px 48px rgba(79,70,229,.42)}

/* Override text in featured — full white for max contrast */
.pricing-card.featured .pricing-tier{color:rgba(255,255,255,.65)!important;letter-spacing:.1em}
.pricing-card.featured .pricing-desc{color:rgba(255,255,255,.88)!important;font-weight:500}
.pricing-card.featured .pricing-feature{color:#fff!important;font-weight:500}
.pricing-card.featured .pricing-period{color:rgba(255,255,255,.75)!important}
.pricing-card.featured .pricing-amount{color:#fff!important;text-shadow:0 2px 8px rgba(0,0,0,.15)}
.pricing-card.featured .pricing-divider{background:rgba(255,255,255,.18)}
.pricing-card.featured .feat-check{color:#6EE7B7!important}
.pricing-card.featured .feat-x{color:rgba(255,255,255,.28)!important}
.pricing-card.featured::before{display:none}
/* Savings pill on featured — high contrast green-on-white */
.pricing-card.featured .pricing-savings{
  background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.3);
  color:#fff!important;
}
/* Strikethrough price on featured */
.pricing-card.featured .price-original{color:rgba(255,255,255,.5)!important}
/* Includes pills on featured */
.pricing-card.featured .pricing-includes-pill{
  background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.25);color:#fff!important;
}
.pricing-card.featured .pricing-includes-pill--theme{
  background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2);color:#fff!important;
}
.pricing-card.featured .pricing-includes-pill--future{
  background:rgba(110,231,183,.2);border-color:rgba(110,231,183,.4);color:#6EE7B7!important;
}

.featured-label{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:#fff;color:var(--c-indigo);
  padding:4px 16px;border-radius:var(--r-xs);
  font-size:.6875rem;font-weight:800;white-space:nowrap;
  border:1px solid var(--c-indigo-foc);box-shadow:var(--sh-sm);
  letter-spacing:.07em;text-transform:uppercase;
}

.pricing-tier{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--c-muted);margin-bottom:10px}
.pricing-price-row{display:flex;align-items:flex-end;gap:4px;margin-bottom:4px}
.pricing-amount{font-family:var(--f-display);font-size:2.75rem;font-weight:800;color:var(--c-text);line-height:1;letter-spacing:-.04em}
.pricing-period{font-size:.875rem;color:var(--c-muted);margin-bottom:6px}
.pricing-savings{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.75rem;font-weight:600;color:var(--c-green);
  background:var(--c-green-lt);border:1px solid #A7F3D0;
  padding:3px 8px;border-radius:var(--r-xs);margin-bottom:12px;
}
.pricing-desc{font-size:.875rem;color:var(--c-muted);margin-bottom:24px;min-height:36px;line-height:1.6}
.pricing-features-list{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.pricing-feature{display:flex;align-items:flex-start;gap:9px;font-size:.84375rem;color:var(--c-text-2);line-height:1.5}
.feat-check{color:var(--c-green);flex-shrink:0;margin-top:1px}
.feat-x    {color:var(--c-ghost);flex-shrink:0;margin-top:1px}
.pricing-divider{height:1px;background:var(--c-border);margin:20px 0}

/* Payment logos row */
.payment-logos{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:32px}
.payment-logo{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-xs);padding:6px 12px;
  font-size:.6875rem;font-weight:700;color:var(--c-muted);
  letter-spacing:.03em;box-shadow:var(--sh-xs);
}

/* Pricing urgency banner */
.pricing-urgency{
  text-align:center;margin-bottom:40px;
  padding:14px 24px;
  background:linear-gradient(135deg,#FFFBEB,#FEF3C7);
  border:1px solid #FDE68A;border-radius:var(--r-md);
  font-size:.875rem;color:var(--c-amber);font-weight:600;
  display:flex;align-items:center;justify-content:center;gap:8px;
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonial-card{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:26px;
  box-shadow:var(--sh-xs);
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
  break-inside:avoid;
}
.testimonial-card:hover{border-color:var(--c-border-foc);box-shadow:var(--sh-md);transform:translateY(-2px)}
.t-stars{display:flex;gap:2px;color:#F59E0B;font-size:.875rem;margin-bottom:14px}
.t-quote{font-size:.9375rem;color:var(--c-text-2);line-height:1.75;margin-bottom:18px;font-style:italic;quotes:"\201C""\201D"}
.t-quote::before{content:open-quote}
.t-quote::after{content:close-quote}
.t-author{display:flex;align-items:center;gap:11px}
.t-avatar{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--c-primary),var(--c-accent));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-size:.875rem;font-weight:700;color:#fff;
  flex-shrink:0;
}
.t-name{font-size:.875rem;font-weight:600;color:var(--c-text);letter-spacing:-.01em}
.t-role{font-size:.75rem;color:var(--c-muted);margin-top:1px}

.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* ============================================================
   FAQ
   ============================================================ */
.faq-item{
  border:1px solid var(--c-border);border-radius:var(--r-md);
  overflow:hidden;margin-bottom:8px;background:var(--c-surface);
  box-shadow:var(--sh-xs);
  transition:border-color var(--t),box-shadow var(--t);
}
.faq-item.open{border-color:var(--c-indigo-foc);box-shadow:var(--sh-sm)}
.faq-trigger{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:16px 20px;cursor:pointer;font-weight:600;font-size:.9375rem;
  color:var(--c-text);font-family:var(--f-display);letter-spacing:-.01em;
  transition:background var(--t);
}
.faq-trigger:hover{background:var(--c-bg-alt)}
.faq-icon{
  width:22px;height:22px;border-radius:var(--r-xs);
  background:var(--c-bg-deep);border:1px solid var(--c-border);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:all var(--t);font-size:.9rem;color:var(--c-muted);
}
.faq-item.open .faq-icon{background:var(--c-indigo);border-color:var(--c-indigo);color:#fff;transform:rotate(45deg)}
.faq-body{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-body-inner{padding:0 20px 18px;font-size:.875rem;color:var(--c-muted);line-height:1.75}
.faq-item.open .faq-body{max-height:400px}

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner{
  background:linear-gradient(140deg,#047857 0%,#059669 45%,#0EA5E9 100%);
  border-radius:var(--r-2xl);padding:72px 56px;text-align:center;
  position:relative;overflow:hidden;
  box-shadow:0 16px 48px rgba(5,150,105,.25);
}
.cta-banner::before{content:'';position:absolute;top:-80px;right:-80px;width:300px;height:300px;background:rgba(255,255,255,.06);border-radius:50%}
.cta-banner::after {content:'';position:absolute;bottom:-60px;left:-60px;width:240px;height:240px;background:rgba(255,255,255,.04);border-radius:50%}
.cta-banner h2,.cta-banner .t-h2{color:#fff!important;position:relative;z-index:1}
.cta-banner p{color:rgba(255,255,255,.78)!important;position:relative;z-index:1}
.cta-banner-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;position:relative;z-index:1;margin-top:28px}
.cta-banner-trust{
  display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;
  position:relative;z-index:1;margin-top:20px;
  font-size:.8125rem;color:rgba(255,255,255,.65);font-weight:500;
}
.cta-banner-trust span{display:flex;align-items:center;gap:5px}
.cta-banner-trust svg{color:rgba(255,255,255,.5)}

/* ============================================================
   FOOTER
   ============================================================ */
#site-footer{background:var(--c-bg-alt);border-top:1px solid var(--c-border);padding:64px 0 0}

.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px}

.footer-brand p{font-size:.875rem;color:var(--c-muted);line-height:1.7;margin:14px 0 22px;max-width:270px}

.footer-social{display:flex;gap:7px}
.social-btn{
  width:34px;height:34px;background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;
  color:var(--c-muted);font-size:.8125rem;transition:all var(--t);
}
.social-btn:hover{background:var(--c-indigo);border-color:var(--c-indigo);color:#fff;transform:translateY(-2px)}

.footer-col h5{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--c-text);margin-bottom:14px;font-family:var(--f-body)}
.footer-col ul{display:flex;flex-direction:column;gap:9px}
.footer-col ul li a{color:var(--c-muted);font-size:.875rem;transition:color var(--t)}
.footer-col ul li a:hover{color:var(--c-indigo)}

/* Trust badges in footer */
.footer-trust{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  padding:20px 0;border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border);
  margin-bottom:20px;
}
.trust-badge{
  display:flex;align-items:center;gap:6px;
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-sm);padding:6px 12px;
  font-size:.75rem;font-weight:600;color:var(--c-text-2);
  box-shadow:var(--sh-xs);
}
.trust-badge svg{flex-shrink:0}
.trust-badge.tb-green svg{color:var(--c-green)}
.trust-badge.tb-blue  svg{color:var(--c-indigo)}
.trust-badge.tb-amber svg{color:var(--c-amber)}

.footer-bottom{padding:20px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer-bottom p,.footer-bottom a{font-size:.8125rem;color:var(--c-muted)}
.footer-bottom a:hover{color:var(--c-indigo)}
.footer-legal-links{display:flex;gap:20px;flex-wrap:wrap}

/* ============================================================
   STICKY CTA  (appears after hero scroll)
   ============================================================ */
.sticky-cta{
  position:fixed;bottom:28px;left:50%;transform:translateX(-50%);
  z-index:500;
  background:#fff;border:1px solid var(--c-border);
  border-radius:100px;padding:10px 10px 10px 20px;
  display:flex;align-items:center;gap:16px;
  box-shadow:var(--sh-xl);
  opacity:0;visibility:hidden;
  transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s;
  transform:translateX(-50%) translateY(12px);
}
.sticky-cta.visible{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.sticky-cta-text{font-size:.875rem;font-weight:600;color:var(--c-text-2);white-space:nowrap}
.sticky-cta-text strong{color:var(--c-text)}

/* Back to top */
.back-to-top{
  position:fixed;bottom:28px;right:28px;width:40px;height:40px;
  background:var(--c-primary);color:#fff;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;opacity:0;visibility:hidden;
  transition:all var(--t);z-index:100;border:none;
  box-shadow:0 4px 12px rgba(5,150,105,.35);
}
.back-to-top.visible{opacity:1;visibility:visible}
.back-to-top:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(5,150,105,.45)}

/* Cookie banner */
.cookie-banner{
  position:fixed;bottom:18px;left:18px;right:18px;max-width:480px;
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:18px 22px;
  z-index:200;box-shadow:var(--sh-lg);display:none;
}
.cookie-banner.visible{display:block}
.cookie-banner p{font-size:.875rem;color:var(--c-text-2);margin-bottom:14px}
.cookie-actions{display:flex;gap:8px}

/* ============================================================
   MISC COMPONENTS
   ============================================================ */
.skip-link{position:absolute;top:-100px;left:14px;background:var(--c-indigo);color:#fff;padding:9px 14px;border-radius:var(--r-sm);font-size:.875rem;font-weight:600;z-index:9999;transition:top .2s}
.skip-link:focus{top:14px;color:#fff}
.screen-reader-text{clip:rect(1px,1px,1px,1px);position:absolute!important;height:1px;width:1px;overflow:hidden}
.breadcrumbs{display:flex;align-items:center;gap:7px;font-size:.8125rem;color:var(--c-muted);margin-bottom:22px}
.breadcrumbs a{color:var(--c-muted)}.breadcrumbs a:hover{color:var(--c-indigo)}.breadcrumbs span{color:var(--c-ghost)}
.notice{padding:12px 15px;border-radius:var(--r-sm);font-size:.875rem;display:flex;align-items:flex-start;gap:9px;margin-bottom:14px}
.notice-success{background:var(--c-green-lt);border:1px solid #A7F3D0;color:var(--c-green)}
.notice-error  {background:var(--c-red-lt);border:1px solid #FECACA;color:var(--c-red)}
.notice-info   {background:var(--c-indigo-lt);border:1px solid var(--c-indigo-foc);color:var(--c-indigo)}
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:.875rem;font-weight:600;color:var(--c-text);margin-bottom:6px;letter-spacing:-.01em}
.form-control{width:100%;background:var(--c-surface);border:1.5px solid var(--c-border);border-radius:var(--r-sm);padding:10px 14px;color:var(--c-text);font-family:var(--f-body);font-size:.9375rem;outline:none;transition:border-color var(--t),box-shadow var(--t)}
.form-control:focus{border-color:var(--c-primary);box-shadow:var(--sh-glow)}
.form-control::placeholder{color:var(--c-ghost)}
textarea.form-control{resize:vertical;min-height:120px}

/* Blog cards */
.post-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);overflow:hidden;transition:border-color var(--t),box-shadow var(--t),transform var(--t);box-shadow:var(--sh-xs)}
.post-card:hover{transform:translateY(-3px);border-color:var(--c-border-foc);box-shadow:var(--sh-md)}
.post-thumb{width:100%;height:196px;object-fit:cover;background:var(--c-bg-deep);display:flex;align-items:center;justify-content:center}
.post-body{padding:22px}
.post-cat{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--c-indigo);margin-bottom:8px}
.post-title{font-size:1.0625rem;font-weight:700;margin-bottom:8px;color:var(--c-text);line-height:1.35;letter-spacing:-.015em;font-family:var(--f-display)}
.post-title:hover{color:var(--c-indigo)}
.post-excerpt{font-size:.875rem;color:var(--c-muted);margin-bottom:14px}
.post-meta{display:flex;align-items:center;gap:10px;font-size:.78125rem;color:var(--c-subtle)}

/* Plugin hero (single page) */
/* Two-column utility grid */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}

.plugin-hero{padding:120px 0 80px;background:linear-gradient(160deg,#F9FAFB 0%,#ECFDF5 100%);position:relative;overflow:hidden}

/* ============================================================
   ANIMATIONS
   ============================================================ */
.fade-up{opacity:0;transform:translateY(22px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.fade-up.in{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.08s}.delay-2{transition-delay:.16s}.delay-3{transition-delay:.24s}.delay-4{transition-delay:.32s}
.counter{display:inline-block}

@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse-glow{
  0%,100%{box-shadow:0 1px 3px rgba(5,150,105,.3),0 0 0 0 rgba(5,150,105,0)}
  50%{box-shadow:0 4px 16px rgba(5,150,105,.32),0 0 0 6px rgba(5,150,105,.08)}
}
@keyframes slideUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   WP DEFAULTS
   ============================================================ */
.alignleft {float:left;margin-right:22px;margin-bottom:14px}
.alignright{float:right;margin-left:22px;margin-bottom:14px}
.aligncenter{margin:0 auto 14px;display:block}
.alignwide{max-width:1400px;margin-left:auto;margin-right:auto}
.alignfull{max-width:100%;margin-left:calc(-50vw + 50%)}
.wp-caption{max-width:100%}.wp-caption-text{font-size:.8125rem;color:var(--c-muted);text-align:center;margin-top:6px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1100px){
  .hero-mockup-wrap{padding:0 0 32px}
  .how-steps::before{display:none}
  .pricing-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .pricing-card.featured{transform:none}
  .pricing-card.featured:hover{transform:translateY(-3px)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.15);padding:24px}
  .stat-item:nth-child(odd){border-right:1px solid rgba(255,255,255,.15)}
  .stat-item:last-child{border-bottom:none}
  .stat-item:nth-last-child(2){border-bottom:none}
}
@media(max-width:992px){
  .hero-inner{flex-direction:column;padding:52px 0 48px;min-height:auto;gap:40px}
  .hero-mockup-wrap{padding:0}
  .how-steps{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr 1fr}
  /* Floating decoration cards overlap when hero stacks */
  .mockup-float{display:none}
}
@media(max-width:768px){
  .main-nav,.header-actions .btn:not(.mobile-menu-btn){display:none}
  .mobile-menu-btn{display:flex}
  /* Header inner padding — 28px is tight on phones */
  .header-inner{padding:0 16px}
  .section-pad{padding:60px 0}
  .section-pad-sm{padding:44px 0}
  .section-pad-lg{padding:80px 0}
  /* CTA banner — start reducing horizontal padding */
  .cta-banner{padding:52px 32px}
  .cta-banner-actions{gap:10px;margin-top:20px}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;text-align:center}
  /* Footer brand — remove unnecessary max-width on single-column */
  .footer-brand p{max-width:100%}
  /* Footer top padding — 64px is too heavy on phones */
  #site-footer{padding:40px 0 0}
  .site-footer-brand{padding:40px 0 0}
  .hero-trust{gap:10px}
  .how-steps{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .sticky-cta{display:none}
  .compat-label{display:none}
  /* Stats section — reduce padding on mobile */
  .stats-section{padding:40px 0}
  /* grid-2 and plugin-hero — already added in previous patch */
  .grid-2{grid-template-columns:1fr;gap:28px}
  .plugin-hero{padding:calc(var(--mh,104px) + 40px) 0 48px}
  .plugin-hero .grid-2{gap:28px}
  .plugin-screenshot{border-radius:var(--r-lg);overflow:hidden}
  /* Brand story strip — gap too large when logo+text wrap to separate rows */
  .brand-story-inner{gap:24px}
  /* Launch bar — pill takes a full row on small screens, hide it */
  .launch-bar-pill{display:none}
  .launch-bar-inner{gap:8px}
  .launch-bar-countdown{display:none}
  /* v5 responsive additions */
  .brand-story-strip{padding:40px 0}
  .brand-lotus-mark{width:56px;height:56px}
  .countdown-wrap{gap:4px}
  .countdown-num{font-size:1rem}
}
@media(max-width:576px){
  .rs-container{padding:0 16px}
  .hero-actions{flex-direction:column;align-items:stretch}
  .btn-xl{text-align:center}
  /* CTA banner — critical: 56px×2 padding on a 320px screen = only 208px content */
  .cta-banner{padding:40px 20px}
  .cta-banner-actions{flex-direction:column;align-items:stretch;gap:8px}
  /* Hero — reduce top/bottom padding further on small phones */
  .hero-inner{padding:44px 0 36px}
  /* Plugin cards — reduce 28px side padding to 16px on small phones */
  .plugin-card-header{padding:20px 16px 16px}
  .plugin-card-features{padding:0 16px 16px}
  .plugin-card-footer{padding:12px 16px 20px}
  /* Pricing grid — allow full width on small phones */
  .pricing-grid{max-width:100%}
  /* Pricing card — reduce padding for small phones */
  .pricing-card{padding:28px 20px}
  /* Stat items — 28px side padding in 2-col grid is too much on 360px screens */
  .stat-item{padding:20px 12px}
  /* Section padding — further reduce for small phones */
  .section-pad{padding:48px 0}
  .section-pad-sm{padding:36px 0}
  .section-pad-lg{padding:64px 0}
  /* Stats grid */
  .stats-grid{grid-template-columns:1fr 1fr}
  /* Lifetime card left col — min-width:280px overflows on very small screens */
  .lifetime-card-left{min-width:0}
  .lifetime-card{gap:24px}
}
@media print{
  #masthead,.back-to-top,.cookie-banner,.sticky-cta{display:none!important}
  body{background:#fff;color:#000}
}

/* ============================================================
   v4 — ALL-ACCESS MEMBERSHIP COMPONENTS
   ============================================================ */

/* Membership badges in hero */
.membership-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 20px 0 28px;
}

.membership-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 100px;
  font-size: .78rem;
  font-weight: 600;
  border: 1px solid;
}

.membership-badge--plugin {
  background: var(--c-primary-lt);
  color: var(--c-primary);
  border-color: var(--c-border-foc);
}

.membership-badge--theme {
  background: #FDF4FF;
  color: #9333EA;
  border-color: #E9D5FF;
}

.membership-badge--future {
  background: var(--c-green-lt);
  color: var(--c-green);
  border-color: #A7F3D0;
}

/* Included section headers (plugins / themes dividers) */
.included-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--c-border);
}

.included-type-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-weight: 700;
  font-size: .875rem;
  padding: 7px 14px;
  border-radius: var(--r-sm);
}

.included-type-plugin {
  background: var(--c-primary-lt);
  color: var(--c-primary);
}

.included-type-theme {
  background: #FDF4FF;
  color: #9333EA;
}

/* Membership "included" tag inside plugin/theme cards */
.membership-included-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .75rem;
  font-weight: 600;
  color: var(--c-green);
  background: var(--c-green-lt);
  padding: 4px 10px;
  border-radius: 100px;
  border: 1px solid #A7F3D0;
}

/* Theme cards */
.theme-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color var(--t), box-shadow var(--t), transform var(--t);
  box-shadow: var(--sh-xs);
}

.theme-card:hover {
  border-color: #C4B5FD;
  transform: translateY(-4px);
  box-shadow: var(--sh-md);
}

.theme-card--coming {
  opacity: .85;
}

.theme-screenshot {
  width: 100%;
  overflow: hidden;
}

.theme-screenshot-placeholder {
  width: 100%;
  height: 180px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  position: relative;
}

.coming-soon-overlay {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0,0,0,.6);
  color: #fff;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 100px;
  white-space: nowrap;
}

.theme-card-body {
  padding: 20px;
}

.theme-card-body h3 {
  font-size: 1.05rem;
  margin-bottom: 6px;
}

.theme-card-body p {
  font-size: .875rem;
  margin-bottom: 16px;
}

.theme-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

/* Themes coming notice */
.themes-coming-notice {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: #EFF6FF;
  border: 1px solid #BFDBFE;
  border-radius: var(--r-md);
  padding: 16px 20px;
  margin-top: 24px;
  font-size: .875rem;
  color: var(--c-text-2);
}

.themes-coming-notice svg {
  color: var(--c-indigo);
  flex-shrink: 0;
  margin-top: 2px;
}

/* Pricing: includes summary pills */
.pricing-includes-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 10px 0 14px;
}

.pricing-includes-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .7rem;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 100px;
  background: var(--c-primary-lt);
  color: var(--c-primary);
  border: 1px solid var(--c-border-foc);
}

.pricing-includes-pill--theme {
  background: #FDF4FF;
  color: #9333EA;
  border-color: #E9D5FF;
}

.pricing-includes-pill--future {
  background: var(--c-green-lt);
  color: var(--c-green);
  border-color: #A7F3D0;
}

/* Lifetime deal card */
.lifetime-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  background: linear-gradient(135deg, #1E1B4B 0%, #312E81 50%, #1E40AF 100%);
  border-radius: var(--r-xl);
  padding: 40px 48px;
  margin-top: 32px;
  flex-wrap: wrap;
}

.lifetime-card-left { flex: 1; min-width: 280px; }
.lifetime-card-left .s-label { color: rgba(255,255,255,.7); background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.2); }
.lifetime-card-left h3 { color: #fff; }
.lifetime-card-left p { color: rgba(255,255,255,.7); }

.lifetime-card-right {
  text-align: center;
  flex-shrink: 0;
}

.lifetime-price {
  font-family: var(--f-display);
  font-size: 1.5rem;
  font-weight: 800;
  color: rgba(255,255,255,.7);
  line-height: 1;
}

.lifetime-price span {
  font-size: 3.5rem;
  color: #fff;
  letter-spacing: -.04em;
}

/* Purple badge for themes */
.badge-purple {
  background: #FDF4FF;
  color: #9333EA;
  border: 1px solid #E9D5FF;
  padding: 3px 10px;
  border-radius: 100px;
  font-size: .72rem;
  font-weight: 700;
}

/* Newsletter form inline */
.newsletter-form-inline {
  display: flex;
  gap: 10px;
  max-width: 460px;
  margin: 0 auto;
}

.newsletter-input {
  flex: 1;
  background: #fff;
  border: 1.5px solid var(--c-border-md);
  border-radius: var(--r-sm);
  padding: 12px 16px;
  font-family: var(--f-body);
  font-size: .9375rem;
  color: var(--c-text);
  outline: none;
  transition: border-color var(--t);
}

.newsletter-input:focus { border-color: var(--c-indigo); box-shadow: var(--sh-glow); }
.newsletter-input::placeholder { color: var(--c-subtle); }

/* Update announcement bar and header for membership messaging */
.header-actions .btn-primary::after { content: none; }

/* Update footer tagline references */
.footer-brand .membership-note {
  font-size: .75rem;
  color: var(--c-subtle);
  margin-top: 8px;
  display: flex;
  align-items: center;
  gap: 5px;
}

/* Themes archive page */
.themes-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }

@media (max-width: 991px) {
  .themes-grid { grid-template-columns: repeat(2, 1fr); }
  .lifetime-card { padding: 32px 28px; }
}
@media (max-width: 600px) {
  .themes-grid { grid-template-columns: 1fr; }
  .membership-badge-row { gap: 6px; }
  .newsletter-form-inline { flex-direction: column; }
  .lifetime-card { padding: 28px 20px; }
  .lifetime-price span { font-size: 2.5rem; }
  .pricing-includes-summary { gap: 5px; }
}


/* ============================================================
   v5.0 PREMIUM ENHANCEMENT LAYER
   Brand bridge: Indigo SaaS base + Riddhi Studio green/gold
   ============================================================ */

/* ── Brand token extensions ── */
:root {
  /* Riddhi brand palette (from media kit / logo) */
  --c-brand-green:      #0D3B26;
  --c-brand-green2:     #155232;
  --c-brand-green-lt:   #E8F5EE;
  --c-brand-gold:       #C9A84C;
  --c-brand-gold-lt:    #E8C96A;
  --c-brand-gold-pale:  #FBF6E9;
  --c-brand-cream:      #FDFAF4;

  /* Elevated shadows */
  --sh-gold:  0 0 0 3px rgba(201,168,76,.18);
  --sh-brand: 0 8px 32px rgba(13,59,38,.18), 0 2px 8px rgba(13,59,38,.08);

  /* Fonts — add Cormorant for display headings */
  --f-serif: 'Cormorant Garamond', Georgia, serif;
}

/* ── Cormorant Garamond for display hero ── */
.t-serif        { font-family: var(--f-serif); font-style: italic; }
.hero-title     { font-family: var(--f-serif); font-style: normal; }
.hero-title em  { font-style: italic; color: var(--c-brand-gold); -webkit-text-fill-color: var(--c-brand-gold); }

/* ── Gold gradient text variant ── */
.t-gold {
  background: linear-gradient(135deg, var(--c-brand-gold) 0%, var(--c-brand-gold-lt) 60%, #B8922E 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* ============================================================
   LAUNCH ANNOUNCEMENT BAR  (premium green/gold)
   ============================================================ */
.launch-bar {
  background: var(--c-brand-green);
  padding: 10px 0;
  position: relative; overflow: hidden;
}
.launch-bar::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 30% 50%, rgba(201,168,76,.12), transparent 55%),
              radial-gradient(ellipse at 75% 50%, rgba(201,168,76,.08), transparent 50%);
  pointer-events: none;
}
.launch-bar-inner {
  position: relative; z-index: 1;
  display: flex; align-items: center; justify-content: center; gap: 14px;
  flex-wrap: wrap;
  max-width: var(--mw); margin: 0 auto; padding: 0 20px;
}
.launch-bar-pill {
  background: rgba(201,168,76,.18);
  border: 1px solid rgba(201,168,76,.35);
  color: var(--c-brand-gold-lt);
  font-size: .6875rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  padding: 3px 10px; border-radius: 100px;
  display: flex; align-items: center; gap: 5px;
}
.launch-bar-pill-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--c-brand-gold);
  animation: lb-pulse 2s ease-in-out infinite;
}
@keyframes lb-pulse { 0%,100%{opacity:1} 50%{opacity:.35} }
.launch-bar-text {
  font-size: .8125rem; font-weight: 400;
  color: rgba(255,255,255,.82); letter-spacing: .01em;
}
.launch-bar-text strong { color: #fff; font-weight: 700; }
.launch-bar-cta {
  font-size: .75rem; font-weight: 600;
  color: var(--c-brand-green);
  background: var(--c-brand-gold);
  padding: 4px 13px; border-radius: 100px;
  text-decoration: none; letter-spacing: .02em;
  transition: background var(--t), transform var(--t);
  white-space: nowrap;
}
.launch-bar-cta:hover { background: var(--c-brand-gold-lt); transform: scale(1.03); }
.launch-bar-countdown {
  font-size: .75rem; color: rgba(255,255,255,.55);
  display: flex; align-items: center; gap: 5px;
}
.launch-bar-countdown strong { color: var(--c-brand-gold-lt); font-weight: 600; font-variant-numeric: tabular-nums; }

/* ============================================================
   FOUNDING MEMBER BADGE  (lotus motif pill)
   ============================================================ */
.founding-badge {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--c-brand-gold-pale);
  border: 1px solid rgba(201,168,76,.35);
  color: #7A5B1A;
  font-size: .6875rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  padding: 5px 14px; border-radius: 100px;
}
.founding-badge::before { content: '🪷'; font-size: .75rem; }

/* ============================================================
   PRICING — LAUNCH DISCOUNT CARDS
   ============================================================ */
.pricing-launch-ribbon {
  background: linear-gradient(135deg, var(--c-brand-green), var(--c-brand-green2));
  color: var(--c-brand-gold-lt);
  font-size: .625rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  padding: 4px 12px; border-radius: 0 0 var(--r-sm) var(--r-sm);
  display: inline-flex; align-items: center; gap: 5px;
  position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  white-space: nowrap; box-shadow: 0 2px 8px rgba(13,59,38,.25);
}
.pricing-launch-ribbon::before { content: '🪷'; font-size: .75rem; }

/* Price with strikethrough + launch price */
.price-original {
  font-size: 1rem; font-weight: 500;
  color: var(--c-muted);
  text-decoration: line-through;
  text-decoration-color: var(--c-red);
  margin-right: 6px;
}
.price-launch {
  display: inline-flex; align-items: baseline; gap: 2px;
}
.price-launch-amount {
  font-family: var(--f-display); font-size: 3rem; font-weight: 800;
  line-height: 1; letter-spacing: -.04em; color: var(--c-text);
}
.price-launch-curr {
  font-size: 1.25rem; font-weight: 700; color: var(--c-muted);
  align-self: flex-start; margin-top: .5rem;
}
.price-launch-period {
  font-size: .8125rem; color: var(--c-muted); font-weight: 500; margin-left: 2px;
}
.price-save-pill {
  display: inline-flex; align-items: center; gap: 4px;
  background: #ECFDF5; border: 1px solid #A7F3D0;
  color: var(--c-green); font-size: .6875rem; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 100px; margin-left: 8px;
}

/* Featured plan premium glow — reinforces the main block above */
.pricing-card.featured {
  border-color: transparent;
  box-shadow: 0 8px 32px rgba(79,70,229,.35), 0 2px 8px rgba(79,70,229,.18);
}

/* Lifetime card — premium green treatment */
.pricing-card-lifetime {
  background: linear-gradient(145deg, var(--c-brand-green) 0%, var(--c-brand-green2) 100%);
  border: 1px solid rgba(201,168,76,.25);
  box-shadow: var(--sh-brand);
  color: #fff;
  position: relative; overflow: hidden;
}
.pricing-card-lifetime::before {
  content: '';
  position: absolute; bottom: -60px; right: -60px;
  width: 220px; height: 220px;
  background: radial-gradient(ellipse, rgba(201,168,76,.15), transparent 65%);
  pointer-events: none;
}
.pricing-card-lifetime .plan-tier    { color: var(--c-brand-gold-lt); }
.pricing-card-lifetime .plan-desc    { color: rgba(255,255,255,.6); }
.pricing-card-lifetime .feature-row  { border-color: rgba(255,255,255,.08); }
.pricing-card-lifetime .feature-row span { color: rgba(255,255,255,.82); }
.pricing-card-lifetime .check-icon   { color: var(--c-brand-gold); }
.pricing-card-lifetime .price-launch-amount,
.pricing-card-lifetime .price-launch-curr { color: #fff; }
.pricing-card-lifetime .price-launch-period { color: rgba(255,255,255,.55); }
.pricing-card-lifetime .price-original { color: rgba(255,255,255,.4); }

/* Gold CTA button for lifetime */
.btn-gold {
  background: linear-gradient(135deg, var(--c-brand-gold) 0%, var(--c-brand-gold-lt) 100%);
  color: var(--c-brand-green); border-color: transparent;
  font-weight: 700;
  box-shadow: 0 2px 8px rgba(201,168,76,.35);
}
.btn-gold:hover {
  background: linear-gradient(135deg, var(--c-brand-gold-lt) 0%, var(--c-brand-gold) 100%);
  color: var(--c-brand-green);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(201,168,76,.45);
}

/* ============================================================
   COUNTDOWN TIMER WIDGET
   ============================================================ */
.countdown-wrap {
  display: flex; align-items: center; gap: 6px;
  font-size: .75rem; color: var(--c-muted);
}
.countdown-unit {
  display: flex; flex-direction: column; align-items: center;
  background: var(--c-bg-deep);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xs);
  padding: 4px 7px; min-width: 38px;
}
.countdown-num {
  font-family: var(--f-display); font-size: 1.25rem; font-weight: 800;
  color: var(--c-text); line-height: 1; font-variant-numeric: tabular-nums;
}
.countdown-label {
  font-size: .5625rem; font-weight: 600; letter-spacing: .06em;
  text-transform: uppercase; color: var(--c-subtle); margin-top: 2px;
}
.countdown-sep { font-size: 1rem; font-weight: 700; color: var(--c-muted); margin-bottom: 6px; }

/* ============================================================
   BRAND STORY STRIP  (lotus + name origin)
   ============================================================ */
.brand-story-strip {
  background: var(--c-brand-green);
  padding: 52px 0;
  position: relative; overflow: hidden;
}
.brand-story-strip::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 10% 50%, rgba(201,168,76,.1), transparent 40%),
    radial-gradient(ellipse at 90% 50%, rgba(201,168,76,.07), transparent 40%);
  pointer-events: none;
}
.brand-story-inner {
  position: relative; z-index: 1;
  display: flex; align-items: center; gap: 48px;
  flex-wrap: wrap;
}
.brand-lotus-mark {
  flex-shrink: 0; width: 80px; height: 80px;
  opacity: .85;
}
.brand-story-content {}
.brand-story-label {
  font-size: .6875rem; font-weight: 600; letter-spacing: .1em;
  text-transform: uppercase; color: var(--c-brand-gold);
  margin-bottom: 10px;
}
.brand-story-quote {
  font-family: var(--f-serif); font-size: clamp(1.25rem, 2.5vw, 1.75rem);
  font-style: italic; color: #fff; line-height: 1.45; margin-bottom: 10px;
}
.brand-story-sub {
  font-size: .875rem; color: rgba(255,255,255,.55); font-weight: 300; line-height: 1.65;
}
.brand-story-sub a { color: var(--c-brand-gold); text-decoration: underline; text-underline-offset: 2px; }

/* ============================================================
   PREMIUM CARD ENHANCEMENTS
   ============================================================ */

/* Shimmer loading effect on cards */
.card-shimmer {
  position: relative; overflow: hidden;
}
.card-shimmer::after {
  content: '';
  position: absolute; top: 0; left: -100%; bottom: 0; width: 60%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.06), transparent);
  animation: shimmer 3s ease-in-out infinite;
}
@keyframes shimmer { 0%{left:-100%} 100%{left:200%} }

/* Premium feature check */
.check-gold {
  width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0;
  background: var(--c-brand-gold-pale);
  border: 1px solid rgba(201,168,76,.3);
  display: flex; align-items: center; justify-content: center;
  color: #7A5B1A; font-size: .625rem;
}

/* Plugin / Theme cards — premium hover border */
.plugin-card:hover, .theme-card:hover {
  border-color: var(--c-border-foc);
  box-shadow: var(--sh-md), 0 0 0 1px rgba(5,150,105,.15);
}

/* ============================================================
   SECTION DIVIDER — gold rule
   ============================================================ */
.gold-rule {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,.35) 30%, rgba(201,168,76,.35) 70%, transparent);
  margin: 0;
}

/* ============================================================
   FOOTER — brand green treatment
   ============================================================ */
.site-footer-brand {
  background: var(--c-brand-green);
  padding: 64px 0 0;
  position: relative; overflow: hidden;
}
.site-footer-brand::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,.4) 50%, transparent);
}
.site-footer-brand .footer-logo-text { color: #fff; }
.site-footer-brand .footer-tagline   { color: rgba(255,255,255,.5); }
.site-footer-brand .footer-link      { color: rgba(255,255,255,.55); }
.site-footer-brand .footer-link:hover { color: var(--c-brand-gold-lt); }
.site-footer-brand .footer-heading   { color: var(--c-brand-gold); font-size: .6875rem; letter-spacing: .1em; text-transform: uppercase; }
.site-footer-brand .footer-bottom    {
  border-top: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.3);
  margin-top: 48px; padding: 20px 0;
  font-size: .8125rem;
}
.site-footer-brand .footer-bottom a  { color: rgba(255,255,255,.45); }
.site-footer-brand .footer-bottom a:hover { color: var(--c-brand-gold-lt); }

/* Lotus watermark in footer */
.footer-lotus-watermark {
  position: absolute; bottom: -20px; right: -20px;
  width: 200px; height: 200px; opacity: .04; pointer-events: none;
}

/* ============================================================
   ANNOUNCEMENT / URGENCY BANNER — replaces old plain version
   ============================================================ */
.announcement-bar {
  background: var(--c-brand-green);
  padding: 10px 0;
  position: relative;
}
.announcement-bar::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 30%, rgba(201,168,76,.1), transparent 50%);
  pointer-events: none;
}

/* ============================================================
   HERO — green dot-grid for hero bg (growth/value signal)
   ============================================================ */
.hero-section {
  background: linear-gradient(155deg, #EEF2FF 0%, #F9FAFB 48%, #ECFDF5 100%);
}

/* ============================================================
   PREMIUM MASTHEAD — green bottom accent on scroll (subtle "go" cue)
   ============================================================ */
#masthead.scrolled {
  border-bottom: 1px solid rgba(5,150,105,.2);
}

/* ============================================================
   SCROLL-REVEAL ANIMATION
   ============================================================ */
.fade-up {
  opacity: 0; transform: translateY(24px);
  transition: opacity .55s var(--ease), transform .55s var(--ease);
}
.fade-up.visible, .fade-up.in-view {
  opacity: 1; transform: none;
}
.fade-up.delay-1 { transition-delay: .1s; }
.fade-up.delay-2 { transition-delay: .2s; }
.fade-up.delay-3 { transition-delay: .3s; }

