/* ============================================
   DESIGN TOKENS
   ============================================ */
:root {
  --sn-seaglass: #7DCDCB;
  --sn-aqua: #48B9C7;
  --sn-dusty-blue: #569BB4;
  --sn-aegean: #517189;
  --sn-dark-blue: #0B2646;
  --sn-light-gray-blue: #F4F5FA;
  --sn-dark-gray-blue: #6B6F82;
  --sn-aegean-light: #88B1C7;

  --surface: #FFFFFF;
  --surface-dim: #F4F5FA;
  --surface-container: #F0F1F6;
  --surface-container-high: #E8EAF0;
  --surface-container-highest: #DFE1E8;

  --text-primary: #000000;
  --text-secondary: #333333;

  --elevation-1: 0 1px 3px 1px rgba(0,0,0,0.06), 0 1px 2px 0 rgba(0,0,0,0.04);
  --elevation-2: 0 2px 6px 2px rgba(0,0,0,0.07), 0 1px 2px 0 rgba(0,0,0,0.04);
  --elevation-3: 0 4px 8px 3px rgba(0,0,0,0.07), 0 1px 3px 0 rgba(0,0,0,0.04);
  --elevation-4: 0 8px 16px 4px rgba(0,0,0,0.1), 0 2px 4px 0 rgba(0,0,0,0.06);

  --shape-sm: 8px; --shape-md: 12px; --shape-lg: 16px; --shape-xl: 24px; --shape-full: 9999px;
  --font-heading: 'Fira Sans', sans-serif;
  --font-body: 'Open Sans', sans-serif;

  --space-xs: 4px; --space-sm: 8px; --space-md: 16px; --space-lg: 24px;
  --space-xl: 32px; --space-2xl: 48px; --space-3xl: 64px; --space-4xl: 120px;

  --max-width: 1200px;
  --header-height: 80px;
  --announce-height: 40px;
  --total-header: calc(var(--header-height) + var(--announce-height));

  /* Section spacing — generous */
  --section-pad: 120px;
}
/* ============================================
   FEATURED POST HERO
   ============================================ */
.blog-hero{
  position:relative;min-height:650px;display:flex;align-items:flex-end;
  overflow:hidden;border-radius:30px;width:1300px;margin:0 auto;padding: 20px;
}
.blog-hero-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform 8s ease;
}
.blog-hero:hover .blog-hero-img{transform:scale(1.03)}
 
/* Heavy bottom gradient so text is always readable */
.blog-hero::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(
    to top,
    rgba(11,38,70,0.95) 0%,
    rgba(11,38,70,0.75) 30%,
    rgba(11,38,70,0.3) 60%,
    rgba(11,38,70,0.05) 100%
  );
  pointer-events:none;
}
.lf-col-filters {padding:50px 0 50px 0!important;}
.blog-hero-content{
  position:relative;z-index:2;
  width:100%;padding:var(--space-3xl) 0;
}
 
.blog-hero-tag{
  display:inline-block;
  background:var(--sn-aqua);color:var(--sn-dark-blue);
  font-family:var(--font-heading);font-size:0.6875rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.06em;
  padding:5px 14px;border-radius:var(--shape-full);
  margin-bottom:var(--space-md);
}
 
.blog-hero-title{
  font-size:clamp(1.75rem,4vw,3rem);font-weight:800;color:#fff;
  line-height:1.1;margin-bottom:var(--space-md);
  max-width:720px;letter-spacing:-0.02em;
}
 
.blog-hero-excerpt{
  font-size:1.0625rem;color:rgba(255,255,255,0.8);
  line-height:1.7;max-width:580px;margin-bottom:var(--space-lg);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
 
.blog-hero-meta{
  display:flex;align-items:center;gap:var(--space-md);
  font-size:0.8125rem;color:#ffffff;font-weight:600;
  margin-bottom:var(--space-lg);
}
.blog-hero-meta-sep{opacity:0.3}
 
.blog-hero-link{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-heading);font-size:0.9375rem;font-weight:600;
  color:var(--sn-seaglass);transition:gap 0.2s ease;
}
.blog-hero-link:hover{gap:12px}
.blog-hero-link svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
 
/* Subtle "Latest" label top-left */
.blog-hero-badge{
  position:absolute;top:var(--space-lg);left:0;z-index:3;
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-heading);font-size:0.6875rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.08em;
  color:rgba(255,255,255,0.5);padding:20px;
}
.blog-hero-badge::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--sn-seaglass);
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:0.3}}
 
/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:768px){
  .blog-hero{min-height:400px}
  .blog-hero-title{font-size:clamp(1.375rem,6vw,2rem)}
  .blog-hero-excerpt{font-size:0.9375rem;-webkit-line-clamp:3}
  .blog-hero-content{padding:var(--space-2xl) 0}
}
@media(max-width:480px){
  .blog-hero{min-height:340px}
  .blog-hero-content{padding:var(--space-xl) 0}
}
/* ============================================
   RESET & BASE — larger body text
   ============================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:var(--font-body);font-size:17px;line-height:1.7;
  color:var(--text-primary);background:var(--surface);
  -webkit-font-smoothing:antialiased;
  padding-top:var(--total-header);
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text-primary)}
p,li,span,label,blockquote{color:var(--text-primary)}

:focus-visible{outline:2px solid var(--sn-aqua);outline-offset:2px}

.skip-link{position:absolute;top:-100%;left:var(--space-md);background:var(--sn-dark-blue);color:#fff;padding:var(--space-sm) var(--space-md);border-radius:var(--shape-sm);z-index:1000;font-weight:600;font-size:1rem}
.skip-link:focus{top:var(--space-md)}

.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ============================================
   AUTO-DETECT LINK COLORS
   ============================================ */
.bg-light a:not(.btn){color:var(--sn-dark-blue)}
.bg-light a:not(.btn):hover{color:var(--sn-dusty-blue)}
.bg-dark,.bg-dark *{color:#fff}
.bg-dark a:not(.btn){color:#fff}
.bg-dark a:not(.btn):hover{color:var(--sn-seaglass)}

/* ============================================
   BUTTONS — slightly larger
   ============================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);
  padding:14px 32px;border-radius:var(--shape-full);
  font-family:var(--font-heading);font-size:1rem;font-weight:600;
  border:none;cursor:pointer;transition:all 0.2s ease;text-decoration:none;white-space:nowrap;
}
.btn-filled{background:var(--sn-dark-blue);color:#fff !important}
.btn-filled:hover{background:#0d2f55;box-shadow:var(--elevation-2)}
.btn-outlined{background:transparent;color:var(--sn-dark-blue)!important;border:1.5px solid var(--sn-aegean-light)}
.btn-outlined:hover{background:rgba(11,38,70,0.04);border-color:var(--sn-aegean)}
.btn-white{background:#fff;color:var(--sn-dark-blue)!important;font-weight:700}
.btn-white:hover{box-shadow:var(--elevation-2)}
.btn-seaglass{background:var(--sn-seaglass);color:var(--sn-dark-blue)!important;font-weight:700}
.btn-seaglass:hover{background:#6bc2c0;box-shadow:var(--elevation-2)}

/* ============================================
   ANNOUNCEMENT BAR
   ============================================ */
.announcement-bar{background:#000;color:#fff;text-align:center;padding:10px var(--space-lg);font-size:0.9rem;font-weight:500;position:fixed;top:0;left:0;right:0;z-index:101;height:var(--announce-height,40px)}
.announcement-bar a{color:var(--sn-seaglass)!important;font-weight:700;text-decoration:underline;text-underline-offset:2px}
.announcement-bar a:hover{color:#fff!important}

/* ============================================
   HEADER — smart transparent/solid
   ============================================ */
.site-header{
  position:fixed;top:var(--announce-height,40px);left:0;right:0;z-index:100;
  height:var(--header-height);
  transition:background 0.35s ease,box-shadow 0.35s ease,border-color 0.35s ease;
  background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--surface-container-high);
}
.site-header.scrolled{box-shadow:var(--elevation-2)}
/* ================================================
   HOME PAG HEADER
=================================================== */
.par-hero{position:relative;min-height:80vh;display:flex;align-items:center;overflow:hidden}
.par-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 30%;filter:brightness(0.45)}
.par-hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(11,38,70,0.92) 0%,rgba(11,38,70,0.75) 45%,rgba(11,38,70,0.3) 100%)}
.par-hero-content{max-width:600px}
.par-hero-sub{font-size:1.125rem;color:rgba(255,255,255,.85);line-height:1.7;margin-bottom:var(--space-lg);max-width:520px}
.par-hero-stars{display:flex;align-items:center;gap:8px;margin-bottom:var(--space-xl)}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .7s ease-out forwards;opacity:0}

/* Transparent on dark hero */
.site-header.hero-dark{background:transparent;backdrop-filter:none;border-bottom-color:transparent;box-shadow:none}
.site-header.hero-dark .logo-img{filter:brightness(0) invert(1)}
.site-header.hero-dark .nav-link,
.site-header.hero-dark .nav-dropdown-trigger{color:rgba(255,255,255,0.9)}
.site-header.hero-dark .nav-link:hover,
.site-header.hero-dark .nav-dropdown-trigger:hover{color:#fff}
.site-header.hero-dark .header-login{color:rgba(255,255,255,0.8)}
.site-header.hero-dark .header-login:hover{color:#fff}
.site-header.hero-dark .btn-header-cta{background:var(--sn-seaglass);color:var(--sn-dark-blue)}
.site-header.hero-dark .mobile-toggle{color:#fff}

/* Solid state (scrolled, or image hero, or default) */
.site-header.solid{background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);border-bottom-color:var(--surface-container-high)}
.site-header.solid .logo-img{filter:none}
.site-header.solid .nav-link,
.site-header.solid .nav-dropdown-trigger{color:var(--text-secondary)}
.site-header.solid .nav-link:hover,
.site-header.solid .nav-dropdown-trigger:hover{color:var(--sn-dark-blue)}
.site-header.solid .header-login{color:var(--text-secondary)}
.site-header.solid .btn-header-cta{background:var(--sn-dark-blue);color:#fff}
.site-header.solid .mobile-toggle{color:var(--text-primary)}

.logo-img{height:75px;width:auto;transition:filter 0.35s ease}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg);
}

.main-nav{display:flex;align-items:center;gap:0}
.nav-link{
  padding:10px 16px;font-family:var(--font-heading);
  font-size:1rem;font-weight:500;color:var(--text-secondary);
  transition:color 0.15s ease;background:none;border:none;cursor:pointer;
}
.nav-link:hover{color:var(--sn-dark-blue)}

.nav-dropdown{position:relative}
.nav-dropdown-trigger{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--font-heading);font-size:1rem;font-weight:500;
  color:var(--text-secondary);background:none;border:none;cursor:pointer;
  padding:10px 16px;transition:color 0.15s ease;
}
.nav-dropdown-trigger:hover{color:var(--sn-dark-blue)}
.nav-dropdown-trigger svg{width:15px;height:15px;transition:transform 0.2s ease}
.nav-dropdown.open .nav-dropdown-trigger svg{transform:rotate(180deg)}

.nav-dropdown-menu{
  position:absolute;top:100%;left:50%;transform:translateX(-50%);
  background:var(--surface);border-radius:var(--shape-md);
  box-shadow:var(--elevation-3);border:1px solid var(--surface-container-high);
  padding:var(--space-sm) var(--space-sm) var(--space-sm);min-width:260px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity 0.15s ease,visibility 0.15s ease;
  padding-top:calc(var(--space-sm) + 8px);margin-top:0;
}
/* Invisible bridge covers the gap between trigger and menu */
.nav-dropdown-menu::before{
  content:'';position:absolute;top:-12px;left:-20px;right:-20px;height:calc(100% + 24px);
  pointer-events:auto;z-index:-1;
}
.nav-dropdown.open .nav-dropdown-menu{
  opacity:1;visibility:visible;pointer-events:auto;
}
.nav-dropdown-item{
  display:block;padding:10px 14px;font-size:0.9375rem;color:var(--text-secondary);
  border-radius:var(--shape-sm);transition:all 0.15s ease;
}
.nav-dropdown-item:hover{background:var(--surface-container);color:var(--sn-dark-blue)}

.header-actions{display:flex;align-items:center;gap:var(--space-sm)}
.header-login{font-family:var(--font-heading);font-size:1rem;font-weight:500;color:var(--text-secondary);padding:10px 16px}
.header-login:hover{color:var(--sn-dark-blue)}
.btn-header-cta{font-size:0.9375rem;padding:10px 24px}

.mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:var(--space-sm);color:var(--text-primary)}
.mobile-toggle svg{width:28px;height:28px}

.partner-logos{padding:var(--space-xl) 0;overflow:hidden;mask-image:linear-gradient(to right,transparent,black 3%,black 97%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 3%,black 97%,transparent)}

/* ============================================
   MOBILE MENU — flyout card with accordion subs
   ============================================ */
.mobile-overlay{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(0,0,0,0.4);z-index:199;
}
.mobile-overlay.open{display:block}

.mobile-menu{
  position:fixed;top:0;right:-360px;width:340px;max-width:85vw;height:100%;
  background:var(--surface);z-index:200;padding:var(--space-lg);
  overflow-y:auto;box-shadow:var(--elevation-4);
  transition:right 0.3s cubic-bezier(0.25,0.46,0.45,0.94);
}
.mobile-menu.open{right:0}

.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}
.mobile-menu-close{background:none;border:none;cursor:pointer;padding:var(--space-sm);color:var(--text-primary)}
.mobile-menu-close svg{width:28px;height:28px}

.mobile-nav-item{border-bottom:1px solid var(--surface-container-high)}
.mobile-nav-link{
  display:block;padding:16px 0;font-family:var(--font-heading);
  font-size:1.125rem;font-weight:500;color:var(--text-primary);
}

/* Accordion parent */
.mobile-nav-parent{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 0;font-family:var(--font-heading);
  font-size:1.125rem;font-weight:500;color:var(--text-primary);
  cursor:pointer;background:none;border:none;width:100%;text-align:left;
}
.mobile-nav-parent svg{
  width:18px;height:18px;transition:transform 0.25s ease;flex-shrink:0;
}
.mobile-nav-parent.expanded svg{transform:rotate(180deg)}

.mobile-nav-sub{
  max-height:0;overflow:hidden;transition:max-height 0.3s ease;
  padding-left:var(--space-md);
}
.mobile-nav-sub.expanded{max-height:400px}
.mobile-nav-sub a{
  display:block;padding:12px 0;font-size:1.0625rem;color:var(--text-secondary);
  border-bottom:1px solid var(--surface-container);
}
.mobile-nav-sub a:last-child{border-bottom:none}

.mobile-menu-actions{margin-top:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-sm)}
.mobile-menu-actions .btn{text-align:center;justify-content:center}

/* ============================================
   HERO SLIDER — 60vh, darker left overlay
   ============================================ */
.hero-slider{position:relative;width:100%;height:60vh;min-height:440px;overflow:hidden}
.hero-slide{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;transition:opacity 1.2s ease;z-index:0}
.hero-slide.active{opacity:1;z-index:1}
.hero-slide-bg{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;will-change:transform}
.hero-slide.active .hero-slide-bg{animation:kenburns 8s ease forwards}
@keyframes kenburns{0%{transform:scale(1)}100%{transform:scale(1.08)}}

/* Darker left overlay */
.hero-slide-overlay{
  position:absolute;top:0;left:0;width:100%;height:100%;
  background:linear-gradient(to right,rgba(11,38,70,0.88) 0%,rgba(11,38,70,0.7) 40%,rgba(11,38,70,0.35) 70%,rgba(11,38,70,0.15) 100%);
}

.hero-slide-content{
  position:relative;z-index:2;height:100%;
  display:flex;flex-direction:column;justify-content:center;
  max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg);color:#fff;
}
.hero-slide-content h1{
  font-size:clamp(2.25rem,5vw,3.75rem);font-weight:800;
  line-height:1.08;margin-bottom:var(--space-md);color:#fff;
  max-width:640px;letter-spacing:-0.02em;
}
.hero-slide-content p{
  font-size:clamp(1.0625rem,2vw,1.25rem);line-height:1.65;
  color:rgba(255,255,255,0.9);max-width:540px;margin-bottom:var(--space-xl);
}
.hero-slide-content .btn{align-self:flex-start}
.hero-display-text{
  font-family:var(--font-heading);font-size:clamp(2.25rem,5vw,3.75rem);font-weight:800;
  line-height:1.08;margin-bottom:var(--space-md);color:#fff;
  max-width:640px;letter-spacing:-0.02em;
}

.hero-dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:10;display:flex;gap:12px}
.hero-dot{width:12px;height:12px;border-radius:50%;border:2px solid #fff;background:transparent;cursor:pointer;transition:background 0.3s ease;padding:0}
.hero-dot.active{background:#fff}

/* IRT Banner */
.hero-banner{text-align:center;padding:var(--space-lg) var(--space-lg);background:var(--surface)}
.hero-banner img{max-width:100%;height:auto;border-radius:var(--shape-sm)}
.hero-banner-desktop{display:block;margin:0 auto;max-width:var(--max-width)}
.hero-banner-mobile{display:none;margin:0 auto}

/* ============================================
   CASHBACK — generous section padding
   ============================================ */
.cashback{padding:var(--section-pad) 0}
.cashback-header{text-align:center;margin-bottom:var(--space-xl)}
.cashback-header h2{font-size:clamp(1.875rem,3.5vw,2.75rem);font-weight:700;margin-bottom:var(--space-sm)}
.cashback-header .cashback-stat{font-size:clamp(1.125rem,2vw,1.5rem);font-weight:600}

.cashback-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-bottom:var(--space-2xl)}
.cashback-card{background:var(--surface);border-radius:var(--shape-lg);padding:var(--space-xl);box-shadow:var(--elevation-1);border:1px solid var(--surface-container-high);text-align:center}
.cashback-card h3{font-size:1.25rem;font-weight:700;margin-bottom:var(--space-xs)}
.cashback-card p{font-size:1.0625rem}

.logo-track{display:flex;gap:var(--space-3xl);align-items:center;animation:scroll-logos 60s linear infinite;width:max-content;padding:0 var(--space-lg)}
.logo-track img{height:60px;width:auto;min-width:120px;flex-shrink:0;object-fit:contain}
@keyframes scroll-logos{to{transform:translateX(-50%)}}
.cashback-cta{text-align:center;margin-top:var(--space-xl)}

/* ============================================
   VALUE PROP BANNER
   ============================================ */
.value-prop{padding:var(--space-3xl) 0 calc(var(--space-3xl) + 16px);text-align:center}
.value-prop h2{font-size:clamp(1.625rem,3vw,2.5rem);font-weight:700;margin-bottom:var(--space-sm)}
.value-prop p{font-size:1.125rem;max-width:620px;margin:0 auto var(--space-lg)}

/* ============================================
   SERVICES — 20px+ row gap
   ============================================ */
.services{padding:var(--section-pad) 0}
.services-header{text-align:center;max-width:720px;margin:0 auto var(--space-3xl)}
.services-header h2{font-size:clamp(1.875rem,3.5vw,2.75rem);font-weight:700;margin-bottom:var(--space-md)}
.services-header p{font-size:1.125rem;line-height:1.7}

.service-block{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl);
  align-items:center;margin-bottom:var(--space-3xl);
}
.service-block:last-child{margin-bottom:0}
.service-block.reverse{direction:rtl}
.service-block.reverse>*{direction:ltr}

.service-img{border-radius:var(--shape-xl);overflow:hidden}
.service-img img{width:100%;aspect-ratio:3/2;object-fit:cover}

.service-text h3{font-size:1.625rem;font-weight:700;margin-bottom:var(--space-xs)}
.service-text h4{font-size:1.0625rem;font-weight:600;font-style:italic;color:var(--sn-aegean);margin-bottom:var(--space-md)}
.service-text p{font-size:1.0625rem;line-height:1.75}

/* ============================================
   MID CTA + FORM
   ============================================ */
.mid-cta{padding:var(--section-pad) 0;background:var(--surface-dim)}
.mid-cta-inner{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl);align-items:center}
.mid-cta-text h2{font-size:clamp(1.5rem,3vw,2.125rem);font-weight:700;margin-bottom:var(--space-md)}
.mid-cta-img{border-radius:var(--shape-xl);overflow:hidden}
.mid-cta-img img{width:100%;aspect-ratio:3/2;object-fit:cover}

.lead-form-card{background:var(--surface);border-radius:var(--shape-xl);padding:var(--space-xl) var(--space-lg);box-shadow:var(--elevation-3);border:1px solid var(--surface-container-high)}
.lead-form-card h3{font-size:1.25rem;font-weight:700;margin-bottom:var(--space-lg);text-align:center}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);margin-bottom:var(--space-md)}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-label{font-size:0.9375rem;font-weight:600;font-family:var(--font-heading)}
.form-input,.form-select{
  padding:12px 14px;border:1.5px solid var(--surface-container-highest);
  border-radius:var(--shape-sm);font-family:var(--font-body);font-size:1rem;
  color:var(--text-primary);background:var(--surface);transition:border-color 0.15s ease;
  appearance:none;-webkit-appearance:none;
}
.form-input:focus,.form-select:focus{outline:none;border-color:var(--sn-aqua);box-shadow:0 0 0 3px rgba(72,185,199,0.15)}
.form-select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B6F82' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;
}
.form-submit{width:100%;margin-top:var(--space-sm)}

/* ============================================
   FEATURE CAROUSEL — arrows outside content
   ============================================ */
.features-carousel-section{padding:var(--section-pad) 0}
.features-carousel-header{text-align:center;margin-bottom:var(--space-2xl)}
.features-carousel-header h2{font-size:clamp(1.875rem,3.5vw,2.75rem);font-weight:700}

.carousel-outer{position:relative;padding:0 60px}
.carousel-wrapper{overflow:hidden;border-radius:var(--shape-lg)}
.carousel-track{display:flex;transition:transform 0.5s cubic-bezier(0.25,0.46,0.45,0.94);cursor:grab}
.carousel-track.dragging{cursor:grabbing;transition:none}

.carousel-slide{
  min-width:100%;display:grid;grid-template-columns:1fr 1fr;
  gap:var(--space-3xl);align-items:center;padding:var(--space-md);
}
.carousel-slide-img{border-radius:var(--shape-xl);overflow:hidden}
.carousel-slide-img img{width:100%;aspect-ratio:3/2;object-fit:cover}
.carousel-slide-text h3{font-size:clamp(1.375rem,2.5vw,1.875rem);font-weight:700;margin-bottom:var(--space-md)}
.carousel-slide-text p{font-size:1.0625rem;line-height:1.75}
.carousel-slide-text p strong{font-weight:700}

/* Arrows positioned outside the content */
.carousel-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:var(--surface);box-shadow:var(--elevation-2);
  border:1px solid var(--surface-container-high);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:5;transition:box-shadow 0.2s ease;color:var(--text-primary);
}
.carousel-arrow:hover{box-shadow:var(--elevation-3)}
.carousel-arrow svg{width:20px;height:20px}
.carousel-prev{left:0}
.carousel-next{right:0}

.carousel-dots{display:flex;justify-content:center;gap:10px;margin-top:var(--space-xl)}
.carousel-dot{width:10px;height:10px;border-radius:50%;background:var(--surface-container-highest);border:none;cursor:pointer;transition:background 0.3s ease;padding:0}
.carousel-dot.active{background:var(--sn-dark-blue)}

/* ============================================
   JOIN CTA
   ============================================ */
.join-cta{padding:var(--space-3xl) 0 calc(var(--space-3xl) + 16px);text-align:center;background:var(--sn-dark-blue)}
.join-cta h2{font-size:clamp(1.875rem,3.5vw,2.75rem);font-weight:700;color:#fff;margin-bottom:var(--space-sm)}
.join-cta p{font-size:1.125rem;max-width:620px;margin:0 auto var(--space-lg);color:rgba(255,255,255,0.85)}

/* ============================================
   TRAINING CTA
   ============================================ */
.training-cta{padding:var(--space-2xl) 0 var(--space-3xl);text-align:center}
.training-cta .btn{margin:0 var(--space-sm)}

/* ============================================
   TESTIMONIALS
   ============================================ */
.testimonials{padding:var(--section-pad) 0;background:var(--surface-dim)}
.testimonials-header{text-align:center;margin-bottom:var(--space-2xl)}
.testimonials-header h2{font-size:clamp(1.875rem,3.5vw,2.75rem);font-weight:700}

.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}
.testimonial-card{background:var(--surface);border-radius:var(--shape-lg);padding:var(--space-xl);box-shadow:var(--elevation-1);border:1px solid var(--surface-container-high)}
.testimonial-quote{font-size:1rem;line-height:1.75;font-style:italic;margin-bottom:var(--space-lg);padding-top:var(--space-lg);position:relative}
.testimonial-quote::before{content:'';position:absolute;top:0;left:0;width:32px;height:3px;background:var(--sn-seaglass);border-radius:2px}
.testimonial-author{display:flex;align-items:center;gap:var(--space-sm)}
.testimonial-avatar{width:44px;height:44px;border-radius:var(--shape-full);background:var(--surface-container);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.875rem;color:var(--sn-aegean);flex-shrink:0;font-family:var(--font-heading)}
.testimonial-name{font-weight:600;font-size:0.9375rem;font-family:var(--font-heading)}
.testimonial-role{font-size:0.8125rem;color:var(--sn-dark-gray-blue)}

/* ============================================
   ARTICLES & RESOURCES
   ============================================ */
.resources{padding:var(--section-pad) 0}
.resources-header{margin-bottom:var(--space-xl)}
.resources-header h2{font-size:clamp(1.875rem,3.5vw,2.75rem);font-weight:700;margin-bottom:var(--space-sm)}
.resources-header p{font-size:1.125rem;line-height:1.7;max-width:660px}

.resources-section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}
.resources-section-header h3{font-size:1.5rem;font-weight:700}
.resources-section-header p{font-size:1rem;max-width:520px}

.articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-bottom:var(--space-3xl)}
.article-card{background:var(--surface);border-radius:var(--shape-lg);overflow:hidden;box-shadow:var(--elevation-1);border:1px solid var(--surface-container-high);transition:box-shadow 0.2s ease,transform 0.2s ease;cursor:pointer;display:block}
.article-card:hover{box-shadow:var(--elevation-3);transform:translateY(-2px)}
.article-card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.article-body{padding:var(--space-lg)}
.article-body h4{font-size:1.0625rem;font-weight:700;line-height:1.4;margin-bottom:var(--space-sm)}
.article-body p{font-size:0.9375rem;line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ============================================
   EVENTS
   ============================================ */
.events{padding:var(--space-3xl) 0 var(--section-pad)}
.events-header{margin-bottom:var(--space-xl)}
.events-header h2{font-size:clamp(1.875rem,3.5vw,2.75rem);font-weight:700}

.event-card{
  background:linear-gradient(135deg,var(--sn-dark-blue) 0%,#163a5e 50%,var(--sn-aegean) 100%);
  border-radius:var(--shape-xl);padding:var(--space-3xl);
  display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl);
  align-items:center;position:relative;overflow:hidden;
}
.event-card::before{content:'';position:absolute;top:-40%;right:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(125,205,203,0.12) 0%,transparent 70%);pointer-events:none}
.event-content{position:relative;z-index:1}
.event-content h3{font-size:clamp(1.875rem,3vw,2.75rem);font-weight:700;color:#fff;margin-bottom:var(--space-xs)}
.event-content h4{font-size:1.375rem;font-weight:600;color:var(--sn-seaglass);margin-bottom:var(--space-md)}
.event-content p{color:rgba(255,255,255,0.8);font-size:1.0625rem;line-height:1.75;margin-bottom:var(--space-xl);max-width:460px}
.event-content p strong{color:#fff}
.event-logo{position:relative;z-index:1;display:flex;align-items:center;justify-content:center}
.event-logo img{max-width:400px;width:100%}

/* ============================================
   FOOTER — all white text, larger sizes
   ============================================ */
.site-footer{background:var(--sn-dark-blue);padding:var(--space-3xl) 0 0}
.site-footer,.site-footer *{color:#fff}

.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--space-xl);padding-bottom:var(--space-3xl);border-bottom:1px solid rgba(255,255,255,0.1)}
.footer-brand-img{height:56px;width:auto;margin-bottom:var(--space-md)}
.footer-brand p{font-size:0.9375rem;color:rgba(255,255,255,0.7);line-height:1.65;margin-bottom:var(--space-md);max-width:300px}
.footer-contact{font-size:1rem;color:#fff;margin-bottom:var(--space-xs)}
.footer-contact a{color:#fff}
.footer-contact a:hover{color:var(--sn-seaglass)}

.footer-socials{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}
.social-icon{width:36px;height:36px;border-radius:var(--shape-sm);display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.1);color:#fff;transition:all 0.15s ease;flex-shrink:0}
.social-icon:hover{background:rgba(255,255,255,0.2)}
.social-icon svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}

.footer-col h4{font-size:0.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:rgba(255,255,255,0.5);margin-bottom:var(--space-md)}
.footer-col a{display:block;font-size:1rem;color:#fff;padding:5px 0}
.footer-col a:hover{color:var(--sn-seaglass)}

.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) 0;font-size:0.875rem;color:#fff;flex-wrap:wrap;gap:var(--space-md)}
.footer-bottom span{color:#fff}
.footer-legal a{color:#fff;margin-left:var(--space-md)}
.footer-legal a:hover{color:var(--sn-seaglass)}

/* ============================================
   DARK THEME — base: #0B2646
   All contrast ratios meet WCAG AA (4.5:1 body, 3:1 large text)
   #FFFFFF on #0B2646 = 15.4:1 ✓
   #7DCDCB on #0B2646 = 8.2:1 ✓
   #88B1C7 on #0B2646 = 6.3:1 ✓
   #48B9C7 on #0B2646 = 7.2:1 ✓
   ============================================ */
html.dark-theme {
  --surface: #0B2646;
  --surface-dim: #081d37;
  --surface-container: #0f3058;
  --surface-container-high: #143a68;
  --surface-container-highest: #1a4578;
  --text-primary: #FFFFFF;
  --text-secondary: #d0d8e0;
  --elevation-1: 0 1px 3px 1px rgba(0,0,0,0.2), 0 1px 2px 0 rgba(0,0,0,0.15);
  --elevation-2: 0 2px 6px 2px rgba(0,0,0,0.25), 0 1px 2px 0 rgba(0,0,0,0.15);
  --elevation-3: 0 4px 8px 3px rgba(0,0,0,0.25), 0 1px 3px 0 rgba(0,0,0,0.15);
  --elevation-4: 0 8px 16px 4px rgba(0,0,0,0.3), 0 2px 4px 0 rgba(0,0,0,0.2);
}

/* Dark theme overrides that can't be handled by tokens alone */
html.dark-theme body { background: #0B2646; color: #fff; }
html.dark-theme h1,html.dark-theme h2,html.dark-theme h3,html.dark-theme h4,html.dark-theme h5,html.dark-theme h6 { color: #fff; }
html.dark-theme p,html.dark-theme li,html.dark-theme span,html.dark-theme label,html.dark-theme blockquote { color: #fff; }
html.dark-theme img { opacity: 0.92; }

/* Header */
html.dark-theme .site-header { background: rgba(11,38,70,0.95); border-bottom-color: #1a4578; }
html.dark-theme .nav-link,
html.dark-theme .nav-dropdown-trigger,
html.dark-theme .header-login { color: #d0d8e0; }
html.dark-theme .nav-link:hover,
html.dark-theme .nav-dropdown-trigger:hover,
html.dark-theme .header-login:hover { color: #fff; }
html.dark-theme .nav-dropdown-menu { background: #0f3058; border-color: #1a4578; }
html.dark-theme .nav-dropdown-item { color: #d0d8e0; }
html.dark-theme .nav-dropdown-item:hover { background: #143a68; color: #fff; }

/* Mobile menu */
html.dark-theme .mobile-menu { background: #0B2646; }
html.dark-theme .mobile-menu-close,
html.dark-theme .mobile-toggle { color: #fff; }
html.dark-theme .mobile-nav-link,
html.dark-theme .mobile-nav-parent { color: #fff; }
html.dark-theme .mobile-nav-item { border-bottom-color: #1a4578; }
html.dark-theme .mobile-nav-sub a { color: #d0d8e0; border-bottom-color: #143a68; }

/* Buttons in dark mode */
html.dark-theme .btn-filled { background: var(--sn-seaglass); color: #0B2646 !important; }
html.dark-theme .btn-filled:hover { background: #6bc2c0; }
html.dark-theme .btn-outlined { color: #fff !important; border-color: var(--sn-aegean-light); }
html.dark-theme .btn-outlined:hover { background: rgba(255,255,255,0.06); border-color: #fff; }

/* Cards */
html.dark-theme .cashback-card,
html.dark-theme .testimonial-card,
html.dark-theme .article-card,
html.dark-theme .lead-form-card { background: #0f3058; border-color: #1a4578; }
html.dark-theme .article-card:hover { box-shadow: var(--elevation-3); }

/* Form inputs */
html.dark-theme .form-input,
html.dark-theme .form-select { background: #081d37; border-color: #1a4578; color: #fff; }
html.dark-theme .form-input:focus,
html.dark-theme .form-select:focus { border-color: var(--sn-aqua); }
html.dark-theme .form-input::placeholder { color: #88B1C7; }
html.dark-theme .form-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2388B1C7' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
}

/* Carousel arrows */
html.dark-theme .carousel-arrow { background: #0f3058; border-color: #1a4578; color: #fff; }
html.dark-theme .carousel-dot { background: #1a4578; }
html.dark-theme .carousel-dot.active { background: var(--sn-seaglass); }

/* Testimonials */
html.dark-theme .testimonial-avatar { background: #143a68; color: var(--sn-seaglass); }
html.dark-theme .testimonial-role { color: var(--sn-aegean-light); }

/* Partner logos */
html.dark-theme .logo-track img { filter: brightness(1.3) contrast(0.9); }

/* Sections that were dark blue in light mode — invert to lighter surface in dark mode so they contrast */
html.dark-theme .value-prop { background: #143a68 !important; }
html.dark-theme .value-prop h2 { color: #fff; }
html.dark-theme .value-prop p { color: rgba(255,255,255,0.85); }

html.dark-theme .join-cta { background: #143a68; }
html.dark-theme .join-cta h2 { color: #fff; }
html.dark-theme .join-cta p { color: rgba(255,255,255,0.85); }
html.dark-theme .join-cta .btn-seaglass { background: var(--sn-seaglass); color: #0B2646 !important; }

/* Sections that were bg-light become the dark surface */
html.dark-theme .bg-light a:not(.btn) { color: var(--sn-seaglass); }
html.dark-theme .bg-light a:not(.btn):hover { color: #fff; }

/* Mid CTA background */
html.dark-theme .mid-cta { background: #081d37; }
html.dark-theme .testimonials { background: #081d37; }
html.dark-theme .hero-banner { background: #0B2646; }

/* Event card gradient adjust */
html.dark-theme .event-card { background: linear-gradient(135deg, #081d37 0%, #0f3058 50%, #1a4578 100%); }

/* Announcement bar stays dark */
html.dark-theme .announcement-bar { background: #000; }

/* Focus ring lighter for visibility on dark */
html.dark-theme :focus-visible { outline-color: var(--sn-seaglass); }

/* ============================================
   FLOATING UTILITY WIDGET
   ============================================ */
.utility-widget {
  position: fixed;
  right: 20px;
  bottom: 24px;
  z-index: 150;
  display: none;
  flex-direction: column;
  gap: 0;
  background: var(--surface);
  border-radius: var(--shape-lg);
  box-shadow: var(--elevation-3);
  border: 1px solid var(--surface-container-high);
  overflow: hidden;
  transition: opacity 0.3s ease, transform 0.3s ease;
 
}
.utility-widget.hidden {
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
}

.utility-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-primary);
  transition: background 0.15s ease, color 0.15s ease;
  position: relative;
}
.utility-btn:hover {
  background: var(--surface-container);
}
.utility-btn svg {
  width: 20px;
  height: 20px;
}
.utility-btn + .utility-btn {
  border-top: 1px solid var(--surface-container-high);
}

/* Dark theme adjustments for the widget */
html.dark-theme .utility-widget {
  background: #0f3058;
  border-color: #1a4578;
}
html.dark-theme .utility-btn { color: #fff; }
html.dark-theme .utility-btn:hover { background: #143a68; }
html.dark-theme .utility-btn + .utility-btn { border-top-color: #1a4578; }

/* ============================================
   ANIMATIONS
   ============================================ */
.animate-in{opacity:0;transform:translateY(20px);transition:opacity 0.5s ease,transform 0.5s ease}
.animate-in.visible{opacity:1;transform:translateY(0)}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;transition-duration:0.01ms!important}
  .animate-in{opacity:1;transform:none}
  .logo-track{animation:none}
  .hero-slide-bg{animation:none!important}
  .mobile-menu{transition:none}
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .service-block,.mid-cta-inner,.event-card{grid-template-columns:1fr;gap:var(--space-xl)}
  .service-block.reverse{direction:ltr}
  .carousel-slide{grid-template-columns:1fr;gap:var(--space-xl)}
  .carousel-outer{padding:0 50px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cashback-cards{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}
}
@media(max-width:768px){
  :root{--section-pad:80px}
  .main-nav,.header-actions{display:none}
  .mobile-toggle{display:block}
  .hero-slider{height:55vh;min-height:360px}
  .hero-slide-content h1,.hero-display-text{font-size:1.875rem}
  .testimonials-grid{grid-template-columns:1fr}
  .articles-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-banner-desktop{display:none}
  .hero-banner-mobile{display:block}
  .resources-section-header{flex-direction:column;align-items:flex-start}
  .event-card{padding:var(--space-xl)}
  .training-cta .btn{display:block;margin:0 0 var(--space-sm) 0}
  .carousel-outer{padding:0 44px}
  .carousel-arrow{width:40px;height:40px}
}
@media(max-width:480px){
  .container{padding:0 var(--space-md)}
  .hero-slider{height:50vh;min-height:320px}
  .carousel-outer{padding:0 36px}
  .carousel-arrow{width:32px;height:32px}
  .carousel-arrow svg{width:16px;height:16px}
}

/* ============================================
   PRICING PAGE — page-specific styles
   ============================================ */
/* ============================================
   PAGE HERO — 70vh dark blue, chart right
   ============================================ */
.page-hero{min-height:70vh;display:flex;align-items:center;background:var(--sn-dark-blue);position:relative;overflow:hidden;padding:calc(var(--total-header) + 40px) 0 var(--space-3xl);margin-top:calc(var(--total-header) * -1)}
.page-hero::after{content:'';position:absolute;top:-20%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(125,205,203,0.08) 0%,transparent 70%);pointer-events:none}
.page-hero .container{position:relative;z-index:1}
.page-hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl);align-items:center}
.page-hero-text h1{font-size:clamp(2.25rem,4.5vw,3.25rem);font-weight:800;line-height:1.08;margin-bottom:var(--space-md);letter-spacing:-0.02em;color:#fff}
.page-hero-text .hero-subtitle{font-size:1.1875rem;line-height:1.6;margin-bottom:var(--space-lg);color:var(--sn-seaglass);font-weight:500;font-style:italic}
.page-hero-text ul{margin-bottom:var(--space-lg)}
.page-hero-text li{padding:8px 0;padding-left:28px;position:relative;font-size:1.0625rem;color:rgba(255,255,255,0.9)}
.page-hero-text li::before{content:'';position:absolute;left:0;top:14px;width:14px;height:14px;border-radius:50%;background:var(--sn-seaglass);opacity:0.7}
.page-hero .btn-seaglass{background:var(--sn-seaglass);color:var(--sn-dark-blue)!important;font-weight:700}
.page-hero .btn-seaglass:hover{background:#6bc2c0;box-shadow:var(--elevation-2)}

/* Hero line chart card */
.hero-chart-card{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:var(--shape-xl);padding:var(--space-xl)}
.hero-chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-lg)}
.hero-chart-header h3{font-size:1.125rem;font-weight:700;color:#fff}
.hero-chart-stat{text-align:right}
.hero-chart-stat .stat-number{font-family:var(--font-heading);font-size:2.75rem;font-weight:800;color:var(--sn-seaglass);line-height:1}
.hero-chart-stat .stat-label{font-size:0.8125rem;color:rgba(255,255,255,0.6);margin-top:2px}
.hero-chart-svg{width:100%;overflow:visible}
.hero-chart-footer{display:flex;gap:var(--space-xl);margin-top:var(--space-lg)}
.hero-chart-metric{text-align:center;flex:1}
.hero-chart-metric .metric-value{font-family:var(--font-heading);font-size:1.5rem;font-weight:800;color:#fff}
.hero-chart-metric .metric-label{font-size:0.8125rem;color:rgba(255,255,255,0.55)}

/* Line chart animation */
.chart-line{stroke-dasharray:1000;stroke-dashoffset:1000;transition:stroke-dashoffset 2s cubic-bezier(0.25,0.46,0.45,0.94)}
.chart-line.animated{stroke-dashoffset:0}
.chart-area{opacity:0;transition:opacity 1.5s ease 0.5s}
.chart-area.animated{opacity:1}
.chart-dot{opacity:0;transform:scale(0);transition:opacity 0.3s ease,transform 0.3s ease}
.chart-dot.animated{opacity:1;transform:scale(1)}

/* ============================================
   PRICING INTRO — two column with image
   ============================================ */
.pricing-intro{padding:var(--section-pad) 0;text-align:left}
.pricing-intro-inner{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl);align-items:center}
.pricing-intro-text h2{font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:700;margin-bottom:var(--space-sm)}
.pricing-intro-text .pricing-intro-sub{font-size:clamp(1.125rem,2vw,1.375rem);font-weight:600;color:var(--sn-aegean);margin-bottom:var(--space-md)}
.pricing-intro-text p{font-size:1.0625rem;line-height:1.75}
.pricing-intro-img{border-radius:var(--shape-xl);overflow:hidden}
.pricing-intro-img img{width:100%;aspect-ratio:4/3;object-fit:cover}

/* ============================================
   ANIMATED CHARTS
   ============================================ */
.charts-section{padding:0 0 var(--section-pad)}
.charts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}
.chart-card{background:var(--surface);border-radius:var(--shape-lg);padding:var(--space-xl);box-shadow:var(--elevation-1);border:1px solid var(--surface-container-high);text-align:center}
.chart-card h3{font-size:1.125rem;font-weight:700;margin-bottom:var(--space-md)}
.chart-svg{margin:0 auto var(--space-md)}
.chart-value{font-family:var(--font-heading);font-size:2rem;font-weight:800;color:var(--sn-dark-blue)}
.chart-label{font-size:0.875rem;color:var(--sn-dark-gray-blue)}

/* Animated bar chart */
.bar-chart{display:flex;align-items:flex-end;justify-content:center;gap:12px;height:140px;padding:0 var(--space-md)}
.bar-col{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}
.bar{width:100%;border-radius:var(--shape-sm) var(--shape-sm) 0 0;transition:height 1s cubic-bezier(0.34,1.56,0.64,1);height:0}
.bar-col span{font-size:0.75rem;font-weight:600;color:var(--sn-dark-gray-blue)}
.bar.animated{/* heights set by JS */}

/* Donut chart */
.donut-ring{transition:stroke-dasharray 1.5s ease}

/* ============================================
   PRICING — COMPACT CARDS + COMPARISON TABLE
   ============================================ */
.pricing-table-section{padding:var(--section-pad) 0}
.pricing-table-section h2{font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:700;text-align:center;margin-bottom:var(--space-sm)}
.pricing-table-section>div>.pricing-sub{text-align:center;font-size:1.0625rem;margin-bottom:var(--space-2xl)}

/* Compact tier cards */
.tier-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg);margin-bottom:var(--space-3xl)}
.tier-card{background:var(--surface);border-radius:var(--shape-xl);padding:var(--space-xl) var(--space-lg);box-shadow:var(--elevation-1);border:1px solid var(--surface-container-high);text-align:center;position:relative;transition:box-shadow 0.2s ease,transform 0.2s ease}
.tier-card:hover{box-shadow:var(--elevation-3);transform:translateY(-2px)}
.tier-card.featured{border-color:var(--sn-aqua);border-width:2px}
.tier-card.featured::before{content:'Most Popular';position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--sn-aqua);color:var(--sn-dark-blue);font-family:var(--font-heading);font-size:0.75rem;font-weight:700;padding:4px 16px;border-radius:var(--shape-full);letter-spacing:0.03em;white-space:nowrap}
.tier-card h3{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-xs)}
.tier-card .tier-desc{font-size:0.9375rem;min-height:44px;margin-bottom:var(--space-md);line-height:1.5}
.tier-price{font-family:var(--font-heading);font-size:2.5rem;font-weight:800;color:var(--sn-dark-blue);margin-bottom:var(--space-xs)}
.tier-price-note{font-size:0.8125rem;color:var(--sn-dark-gray-blue);line-height:1.4;min-height:36px;margin-bottom:var(--space-lg)}
.tier-card .btn{width:100%;justify-content:center}

/* Comparison table */
.compare-table-wrap{overflow-x:auto;margin-bottom:var(--space-lg);border-radius:var(--shape-lg);border:1px solid var(--surface-container-high)}
.compare-table{width:100%;border-collapse:collapse;font-size:0.9375rem}
.compare-table thead th{background:var(--sn-dark-blue);color:#fff;font-family:var(--font-heading);font-weight:700;font-size:1rem;padding:16px 12px;text-align:center;position:sticky;top:0;z-index:2}
.compare-table thead th:first-child{text-align:left;min-width:260px}
.compare-table thead th.col-featured{background:#0d3050}
.compare-table tbody td{padding:14px 12px;text-align:center;border-bottom:1px solid var(--surface-container-high);vertical-align:middle}
.compare-table tbody td:first-child{text-align:left;font-weight:500;position:relative}
.compare-table tbody tr:last-child td{border-bottom:none}
.compare-table tbody tr:hover td{background:rgba(72,185,199,0.04)}

/* Feature name with tooltip in table */
.compare-feat{position:relative;cursor:default;display:inline}
.compare-feat[data-tip]{border-bottom:1px dotted var(--sn-aegean-light);cursor:help}
.compare-tip{position:absolute;bottom:calc(100% + 8px);left:0;background:var(--sn-dark-blue);color:#fff;font-size:0.8125rem;font-weight:400;line-height:1.5;padding:10px 14px;border-radius:var(--shape-sm);width:280px;box-shadow:var(--elevation-3);opacity:0;visibility:hidden;pointer-events:none;transition:opacity 0.15s ease;z-index:20}
.compare-tip::after{content:'';position:absolute;top:100%;left:20px;border:6px solid transparent;border-top-color:var(--sn-dark-blue)}
.compare-feat:hover .compare-tip,.compare-feat:focus .compare-tip{opacity:1;visibility:visible}

/* Check / X / Addon icons in table */
.t-check{color:var(--sn-aqua);display:inline-block}
.t-x{color:var(--surface-container-highest);display:inline-block;opacity:0.5}
.t-addon{color:var(--sn-aegean);font-size:0.8125rem;font-weight:600}
.t-check svg,.t-x svg{width:20px;height:20px;vertical-align:middle}

/* Section divider rows */
.compare-table .section-row td{background:var(--surface-dim);font-family:var(--font-heading);font-weight:700;font-size:0.8125rem;letter-spacing:0.04em;text-transform:uppercase;color:var(--sn-aegean);padding:10px 12px}

/* Dark theme for table */
html.dark-theme .tier-card{background:#0f3058;border-color:#1a4578}
html.dark-theme .tier-card.featured{border-color:var(--sn-aqua)}
html.dark-theme .tier-price{color:var(--sn-seaglass)}
html.dark-theme .tier-price-note{color:var(--sn-aegean-light)}
html.dark-theme .compare-table thead th{background:#081d37}
html.dark-theme .compare-table thead th.col-featured{background:#0f3058}
html.dark-theme .compare-table tbody td{border-bottom-color:#1a4578}
html.dark-theme .compare-table tbody tr:hover td{background:rgba(72,185,199,0.06)}
html.dark-theme .compare-table .section-row td{background:#081d37}
html.dark-theme .compare-table-wrap{border-color:#1a4578}
html.dark-theme .compare-tip{background:#143a68}
html.dark-theme .compare-tip::after{border-top-color:#143a68}
html.dark-theme .t-x{color:#1a4578}

/* ============================================
   COACHING SECTION
   ============================================ */
.coaching{padding:var(--section-pad) 0;background:var(--surface-dim)}
.coaching-header{text-align:center;max-width:720px;margin:0 auto var(--space-2xl)}
.coaching-header h2{font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:700;margin-bottom:var(--space-md)}
.coaching-header p{font-size:1.0625rem;line-height:1.75}
.coaching-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}
.coaching-card{background:var(--surface);border-radius:var(--shape-lg);padding:var(--space-xl);box-shadow:var(--elevation-1);border:1px solid var(--surface-container-high)}
.coaching-card h3{font-size:1.25rem;font-weight:700;margin-bottom:var(--space-sm)}
.coaching-card p{font-size:1rem;line-height:1.7}
.coaching-cta{text-align:center;margin-top:var(--space-2xl)}

/* ============================================
   PARTNER LOGOS
   ============================================ */
.partners-section{padding:var(--section-pad) 0}
.partners-header{text-align:center;margin-bottom:var(--space-xl)}
.partners-header h2{font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:700;margin-bottom:var(--space-sm)}
.partners-header p{font-size:1.0625rem;max-width:640px;margin:0 auto}
.logo-track{display:flex;gap:var(--space-3xl);align-items:center;animation:scroll-logos 60s linear infinite;width:max-content;padding:0 var(--space-lg)}
.logo-track img{height:60px;width:auto;min-width:120px;flex-shrink:0;object-fit:contain}
@keyframes scroll-logos{to{transform:translateX(-50%)}}
.partners-note{text-align:center;font-size:0.9375rem;font-style:italic;color:var(--sn-dark-gray-blue);margin-top:var(--space-md)}

/* ============================================
   BENEFITS GRID
   ============================================ */
.benefits{padding:var(--section-pad) 0;background:var(--surface-dim)}
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}
.benefit-card{background:var(--surface);border-radius:var(--shape-lg);padding:var(--space-xl);box-shadow:var(--elevation-1);border:1px solid var(--surface-container-high)}
.benefit-card-img{border-radius:var(--shape-md);overflow:hidden;margin-bottom:var(--space-md)}
.benefit-card-img img{width:20%;aspect-ratio:10/10;object-fit:contained}
.benefit-card h3{font-size:1.125rem;font-weight:700;margin-bottom:var(--space-sm)}
.benefit-card p{font-size:0.9375rem;line-height:1.7}

/* ============================================
   BOTTOM CTA
   ============================================ */
.bottom-cta{padding:var(--space-3xl) 0 calc(var(--space-3xl)+16px);text-align:center;background:var(--sn-dark-blue)}
.bottom-cta h2{font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:700;color:#fff;margin-bottom:var(--space-sm)}
.bottom-cta p{font-size:1.0625rem;color:rgba(255,255,255,0.85);max-width:600px;margin:0 auto var(--space-lg)}
.bottom-cta-btns{display:flex;justify-content:center;gap:var(--space-md);flex-wrap:wrap}

/* ============================================


/* Pricing page dark theme additions */
html.dark-theme .page-hero{background:#143a68}
html.dark-theme .hero-chart-card{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.08)}
html.dark-theme .tier-card{background:#0f3058;border-color:#1a4578}
html.dark-theme .tier-card.featured{border-color:var(--sn-aqua)}
html.dark-theme .tier-price{color:var(--sn-seaglass)}
html.dark-theme .tier-price-note{color:var(--sn-aegean-light)}
html.dark-theme .compare-table thead th{background:#081d37}
html.dark-theme .compare-table thead th.col-featured{background:#0f3058}
html.dark-theme .compare-table tbody td{border-bottom-color:#1a4578}
html.dark-theme .compare-table tbody tr:hover td{background:rgba(72,185,199,0.06)}
html.dark-theme .compare-table .section-row td{background:#081d37}
html.dark-theme .compare-table-wrap{border-color:#1a4578}
html.dark-theme .compare-tip{background:#143a68}
html.dark-theme .compare-tip::after{border-top-color:#143a68}
html.dark-theme .t-x{color:#1a4578}
html.dark-theme .coaching-card,.html.dark-theme .benefit-card{background:#0f3058;border-color:#1a4578}
html.dark-theme .coaching,html.dark-theme .benefits{background:#081d37}
html.dark-theme .bottom-cta{background:#143a68}
html.dark-theme .bottom-cta h2{color:#fff}
html.dark-theme .bottom-cta p{color:rgba(255,255,255,0.85)}
html.dark-theme .pricing-intro-text .pricing-intro-sub{color:var(--sn-seaglass)}

/* Pricing page responsive additions */
@media(max-width:1024px){
  .page-hero-inner,.pricing-intro-inner{grid-template-columns:1fr;gap:var(--space-xl)}
  .page-hero{min-height:auto;padding:var(--space-3xl) 0}
  .tier-cards{grid-template-columns:repeat(2,1fr)}
  .coaching-grid{grid-template-columns:1fr}
  .benefits-grid{grid-template-columns:repeat(2,1fr)}
  .compare-table{font-size:0.8125rem}
  .compare-table thead th{font-size:0.875rem;padding:12px 8px}
  .compare-table tbody td{padding:10px 8px}
}
@media(max-width:768px){
  .tier-cards{grid-template-columns:1fr;max-width:400px;margin-left:auto;margin-right:auto}
  .benefits-grid{grid-template-columns:1fr}
  .bottom-cta-btns{flex-direction:column;align-items:center}
  .compare-table thead th:first-child{min-width:160px}
}

/* ============================================
   BLOG — Archive Cards Grid
   ============================================ */
.blog-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}

.blog-card{display:block;background:var(--surface);border-radius:var(--shape-lg);overflow:hidden;box-shadow:var(--elevation-1);border:1px solid var(--surface-container-high);transition:box-shadow 0.2s ease,transform 0.2s ease;text-decoration:none;color:inherit}
.blog-card:hover{box-shadow:var(--elevation-3);transform:translateY(-3px)}

.blog-card-img{overflow:hidden}
.blog-card-img img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform 0.4s ease}
.blog-card:hover .blog-card-img img{transform:scale(1.03)}

.blog-card-body{padding:var(--space-lg)}
.blog-card-cat{display:inline-block;font-family:var(--font-heading);font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--sn-aqua);margin-bottom:var(--space-sm)}
.blog-card-title{font-family:var(--font-heading);font-size:1.125rem;font-weight:700;line-height:1.35;margin-bottom:var(--space-sm);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-card-excerpt{font-size:0.9375rem;line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:var(--space-md)}
.blog-card-meta{font-size:0.8125rem;color:var(--sn-dark-gray-blue)}

/* ============================================
   BLOG — Single Post Layout
   ============================================ */
.post-grid{display:grid;grid-template-columns:1fr 340px;gap:var(--space-3xl);align-items:start}

/* Post content typography */
.post-content{max-width:100%}
.post-content h2{font-size:1.625rem;font-weight:700;margin:var(--space-2xl) 0 var(--space-md);line-height:1.25}
.post-content h3{font-size:1.25rem;font-weight:700;margin:var(--space-xl) 0 var(--space-sm)}
.post-content p{font-size:1.0625rem;line-height:1.8;margin-bottom:var(--space-lg)}
.post-content ul,.post-content ol{margin-bottom:var(--space-lg);padding-left:var(--space-lg)}
.post-content li{font-size:1.0625rem;line-height:1.75;margin-bottom:var(--space-sm);list-style:disc}
.post-content ol li{list-style:decimal}
.post-content li strong{font-weight:700}
.post-content img{width:100%;height:auto;border-radius:var(--shape-lg)}
.post-content a{color:var(--sn-dusty-blue);text-decoration:underline;text-underline-offset:2px}
.post-content a:hover{color:var(--sn-dark-blue)}

/* In-article CTA box */
.post-cta-box{background:var(--surface-dim);border-radius:var(--shape-xl);padding:var(--space-xl);margin:var(--space-2xl) 0;border-left:4px solid var(--sn-aqua)}
.post-cta-box h3{font-size:1.25rem;font-weight:700;margin-bottom:var(--space-sm)}
.post-cta-box p{font-size:1rem;margin-bottom:var(--space-md)}

/* Sidebar */
.post-sidebar{position:sticky;top:calc(var(--header-height) + var(--space-lg))}
.sidebar-card{background:var(--surface);border-radius:var(--shape-lg);padding:var(--space-lg);box-shadow:var(--elevation-1);border:1px solid var(--surface-container-high);margin-bottom:var(--space-lg)}
.sidebar-card h3{font-family:var(--font-heading);font-size:1.125rem;font-weight:700;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:2px solid var(--sn-seaglass)}
.sidebar-post{display:flex;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid var(--surface-container-high);text-decoration:none;transition:opacity 0.15s ease}
.sidebar-post:last-child{border-bottom:none}
.sidebar-post:hover{opacity:0.8}
.sidebar-post img{width:72px;height:50px;border-radius:var(--shape-sm);object-fit:cover;flex-shrink:0}
.sidebar-post span{font-size:0.8125rem;font-weight:600;line-height:1.35;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

.sidebar-cta{background:var(--sn-dark-blue);border-color:transparent}
.sidebar-cta h3{color:#fff;border-bottom-color:rgba(255,255,255,0.15)}
.sidebar-cta p{color:rgba(255,255,255,0.8);font-size:0.9375rem}

/* ============================================
   BLOG — Dark Theme
   ============================================ */
html.dark-theme .blog-card{background:#0f3058;border-color:#1a4578}
html.dark-theme .blog-card-meta{color:var(--sn-aegean-light)}
html.dark-theme .post-content a{color:var(--sn-seaglass)}
html.dark-theme .post-content a:hover{color:#fff}
html.dark-theme .post-cta-box{background:#0f3058;border-left-color:var(--sn-aqua)}
html.dark-theme .sidebar-card{background:#0f3058;border-color:#1a4578}
html.dark-theme .sidebar-post{border-bottom-color:#1a4578}
html.dark-theme .sidebar-cta{background:#143a68}

/* ============================================
   BLOG — Responsive
   ============================================ */
@media(max-width:1024px){
  .post-grid{grid-template-columns:1fr;gap:var(--space-xl)}
  .post-sidebar{position:static}
}
@media(max-width:768px){
  .blog-cards-grid{grid-template-columns:1fr}
}

/* ============================================
   SERVICES — Cards & Detail Pages
   ============================================ */

/* Service card (used on services hub) */
.service-feed-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-lg);
}

.service-card-link {
  display: block;
  background: var(--surface);
  border-radius: var(--shape-xl);
  overflow: hidden;
  box-shadow: var(--elevation-1);
  border: 1px solid var(--surface-container-high);
  transition: box-shadow 0.2s ease, transform 0.2s ease;
  text-decoration: none;
  color: inherit;
}
.service-card-link:hover {
  box-shadow: var(--elevation-3);
  transform: translateY(-3px);
}

.service-card-link .svc-card-img { overflow: hidden; }
.service-card-link .svc-card-img img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.service-card-link:hover .svc-card-img img { transform: scale(1.03); }

.service-card-link .svc-card-body { padding: var(--space-xl); }
.service-card-link .svc-card-body h2 {
  font-family: var(--font-heading);
  font-size: 1.375rem;
  font-weight: 700;
  margin-bottom: var(--space-xs);
}
.service-card-link .svc-card-subtitle {
  font-size: 1rem;
  font-weight: 500;
  font-style: italic;
  color: var(--sn-aegean);
  margin-bottom: var(--space-md);
}
.service-card-link .svc-card-excerpt {
  font-size: 1rem;
  line-height: 1.7;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: var(--space-md);
}
.service-card-link .svc-card-arrow {
  font-family: var(--font-heading);
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--sn-dark-blue);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: gap 0.2s ease;
}
.service-card-link:hover .svc-card-arrow { gap: 10px; color: var(--sn-dusty-blue); }

/* Service detail page — full-width, no sidebar */
.service-detail-hero {
  background: var(--sn-dark-blue);
  padding: var(--space-3xl) 0 var(--space-2xl);
  position: relative;
  overflow: hidden;
}
.service-detail-hero::after {
  content: '';
  position: absolute;
  top: -20%;
  right: -10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(125,205,203,0.08) 0%, transparent 70%);
  pointer-events: none;
}
.service-detail-hero .container { position: relative; z-index: 1; }
.service-detail-hero h1 {
  font-size: clamp(2.25rem, 4.5vw, 3.25rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.08;
  margin-bottom: var(--space-sm);
  letter-spacing: -0.02em;
}
.service-detail-hero .svc-subtitle {
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--sn-seaglass);
  font-style: italic;
}

/* Alternating content blocks */
.svc-blocks { padding: var(--section-pad) 0; }
.svc-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3xl);
  align-items: center;
  margin-bottom: var(--space-3xl);
}
.svc-block:last-child { margin-bottom: 0; }
.svc-block:nth-child(even) { direction: rtl; }
.svc-block:nth-child(even) > * { direction: ltr; }

.svc-block-img { border-radius: var(--shape-xl); overflow: hidden; }
.svc-block-img img { width: 100%; aspect-ratio: 3/2; object-fit: cover; }

.svc-block-text h2 { font-size: 1.625rem; font-weight: 700; margin-bottom: var(--space-md); }
.svc-block-text p { font-size: 1.0625rem; line-height: 1.75; }

/* Service detail CTA */
.svc-cta {
  padding: var(--space-3xl) 0 calc(var(--space-3xl) + 16px);
  background: var(--sn-dark-blue);
  text-align: center;
}
.svc-cta h2 { font-size: clamp(1.75rem, 3.5vw, 2.5rem); font-weight: 700; color: #fff; margin-bottom: var(--space-sm); }
.svc-cta p { font-size: 1.0625rem; color: rgba(255,255,255,0.85); max-width: 560px; margin: 0 auto var(--space-lg); }

/* Dark theme */
html.dark-theme .service-card-link { background: #0f3058; border-color: #1a4578; }
html.dark-theme .service-card-link .svc-card-subtitle { color: var(--sn-seaglass); }
html.dark-theme .service-card-link .svc-card-arrow { color: var(--sn-seaglass); }
html.dark-theme .service-detail-hero { background: #143a68; }
html.dark-theme .svc-cta { background: #143a68; }

/* Responsive */
@media (max-width: 1024px) {
  .service-feed-grid { grid-template-columns: 1fr; }
  .svc-block { grid-template-columns: 1fr; gap: var(--space-xl); }
  .svc-block:nth-child(even) { direction: ltr; }
}

/* ============================================
   FAQ ACCORDION
   ============================================ */
.faq-item{border-bottom:1px solid var(--surface-container-high)}
.faq-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:20px 0;background:none;border:none;cursor:pointer;font-family:var(--font-heading);font-size:1.125rem;font-weight:600;color:var(--text-primary);text-align:left;gap:var(--space-md)}
.faq-trigger svg{width:20px;height:20px;flex-shrink:0;transition:transform 0.25s ease;color:var(--sn-aegean)}
.faq-trigger[aria-expanded="true"] svg{transform:rotate(180deg)}
.faq-trigger:hover{color:var(--sn-dark-blue)}
.faq-content{max-height:0;overflow:hidden;transition:max-height 0.3s ease}
.faq-content p{font-size:1.0625rem;line-height:1.75;padding-bottom:20px}
.faq-content a{color:var(--sn-dusty-blue);text-decoration:underline}

html.dark-theme .faq-trigger{color:#fff}
html.dark-theme .faq-trigger:hover{color:var(--sn-seaglass)}
html.dark-theme .faq-item{border-bottom-color:#1a4578}
html.dark-theme .faq-content a{color:var(--sn-seaglass)}

/* ============================================
   TRAINING LIST
   ============================================ */
.training-list{display:flex;flex-direction:column;gap:0}
.training-item{display:flex;align-items:center;justify-content:space-between;padding:18px 0;border-bottom:1px solid var(--surface-container-high);gap:var(--space-lg)}
.training-info h3{font-size:1.0625rem;font-weight:600;margin-bottom:2px}
.training-info p{font-size:0.9375rem;color:var(--sn-dark-gray-blue)}

html.dark-theme .training-item{border-bottom-color:#1a4578}
html.dark-theme .training-info p{color:var(--sn-aegean-light)}

@media(max-width:768px){
  .training-item{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}
}

/* ============================================
   SERVICE PAGE — Animated SVG Graphics
   ============================================ */

/* Floating bob */
@keyframes svgFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
.anim-float { animation: svgFloat 3s ease-in-out infinite; }

/* Gentle pulse scale */
@keyframes svgPulse { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.04);opacity:0.85} }
.anim-pulse { animation: svgPulse 4s ease-in-out infinite; }

/* Spinning dashed ring */
@keyframes svgSpin { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
.anim-spin { animation: svgSpin 20s linear infinite; transform-origin: 200px 120px; }

/* Dash march */
@keyframes svgDash { to{stroke-dashoffset:-14} }
.anim-dash { animation: svgDash 1.5s linear infinite; }

/* Bar grow from bottom */
@keyframes svgGrow { from{transform:scaleY(0)} to{transform:scaleY(1)} }
.anim-grow { animation: svgGrow 0.8s ease-out forwards; transform: scaleY(0); }

/* Line draw */
@keyframes svgDraw { to{stroke-dashoffset:0} }
.anim-draw { animation: svgDraw 1.5s ease-out 0.6s forwards; }

/* Pop in */
@keyframes svgPop { 0%{transform:scale(0);opacity:0} 60%{transform:scale(1.3);opacity:1} 100%{transform:scale(1);opacity:1} }
.anim-pop { animation: svgPop 0.4s ease-out forwards; transform: scale(0); opacity: 0; }

/* Slide in from left */
@keyframes svgSlideIn { from{transform:translateX(-20px);opacity:0} to{transform:translateX(0);opacity:1} }
.anim-slide-in { animation: svgSlideIn 0.5s ease-out forwards; transform: translateX(-20px); opacity: 0; }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .anim-float, .anim-pulse, .anim-spin, .anim-dash,
  .anim-grow, .anim-draw, .anim-pop, .anim-slide-in {
    animation: none !important;
    transform: none !important;
    opacity: 1 !important;
    stroke-dashoffset: 0 !important;
  }
}

/* Dark theme SVG adjustments */
html.dark-theme .svc-feature-graphic svg rect[fill="var(--sn-light-gray-blue)"] { fill: #143a68; }
html.dark-theme .svc-feature-graphic svg rect[fill="#fff"] { fill: #0f3058; }
html.dark-theme .svc-feature-graphic svg text { fill: var(--sn-seaglass); }

/* Responsive: stack features */
@media (max-width: 1024px) {
  .svc-feature-block { grid-template-columns: 1fr !important; direction: ltr !important; }
  .svc-feature-block > * { direction: ltr !important; }
  .svc-feature-graphic { order: -1; max-width: 320px; margin: 0 auto var(--space-xl); }
}

/* ============================================
   BENEFITS HERO — Growth Garden
   ============================================ */
.benefits-hero{
  min-height:92vh;display:flex;align-items:center;
  background:var(--sn-dark-blue);position:relative;overflow:hidden;
  padding:calc(var(--total-header) + 40px) 0 80px;
  margin-top:calc(var(--total-header) * -1);
}
.benefits-hero::before{
  content:'';position:absolute;bottom:0;left:0;right:0;height:40%;
  background:linear-gradient(to top,rgba(125,205,203,0.06) 0%,transparent 100%);
  pointer-events:none;
}
.benefits-hero-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl);align-items:center;
  position:relative;z-index:1;
}
.benefits-hero-text h1{
  font-size:clamp(2.5rem,5vw,3.75rem);font-weight:800;color:#fff;
  line-height:1.04;margin-bottom:var(--space-md);letter-spacing:-0.025em;
}
.benefits-hero-text .hero-sub{
  font-size:1.25rem;font-weight:500;color:var(--sn-seaglass);
  font-style:italic;margin-bottom:var(--space-lg);
}
.benefits-hero-text p{
  font-size:1.0625rem;color:rgba(255,255,255,0.8);line-height:1.75;
  margin-bottom:var(--space-xl);max-width:500px;
}

/* Growth viz animations */
.growth-viz{position:relative;width:100%;max-width:480px;margin:0 auto}
.growth-viz svg{width:100%;height:auto}
@keyframes barGrow{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.gv-bar{transform-origin:bottom center;animation:barGrow 1s cubic-bezier(0.34,1.56,0.64,1) forwards;transform:scaleY(0)}
@keyframes sunRise{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
.gv-sun{animation:sunRise 1.2s ease-out 1.2s forwards;opacity:0}
@keyframes lineReveal{from{stroke-dashoffset:600}to{stroke-dashoffset:0}}
.gv-line{stroke-dasharray:600;stroke-dashoffset:600;animation:lineReveal 2s ease-out 0.8s forwards}
@keyframes leafSprout{0%{transform:scale(0) rotate(-20deg);opacity:0}60%{transform:scale(1.1) rotate(3deg);opacity:1}100%{transform:scale(1) rotate(0deg);opacity:1}}
.gv-leaf{transform-origin:bottom center;animation:leafSprout 0.6s ease-out forwards;opacity:0}
@keyframes metricFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@keyframes metricFadeIn{from{opacity:0;transform:translateY(12px) scale(0.95)}to{opacity:1;transform:translateY(0) scale(1)}}
.gv-metric{animation:metricFadeIn 0.5s ease-out forwards,metricFloat 4s ease-in-out 2s infinite;opacity:0}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp 0.7s ease-out forwards;opacity:0}

/* ============================================
   TRAINING HERO — Pillar Reveal
   ============================================ */
.training-hero{
  min-height:80vh;display:flex;align-items:center;
  background:var(--sn-dark-blue);position:relative;overflow:hidden;
  padding:calc(var(--total-header) + 40px) 0 80px;
  margin-top:calc(var(--total-header) * -1);
}
.training-hero-inner{
  display:grid;grid-template-columns:1.1fr 0.9fr;gap:var(--space-3xl);align-items:center;
  position:relative;z-index:1;
}
.training-hero-text h1{
  font-size:clamp(2.5rem,5vw,3.5rem);font-weight:800;color:#fff;
  line-height:1.06;margin-bottom:var(--space-md);letter-spacing:-0.02em;
}
.training-hero-text p{
  font-size:1.0625rem;color:rgba(255,255,255,0.8);line-height:1.75;
  margin-bottom:var(--space-xl);max-width:500px;
}
@keyframes pillarRise{from{transform:scaleY(0);opacity:0.3}to{transform:scaleY(1);opacity:1}}
.pillar{transform-origin:bottom center;animation:pillarRise 0.8s cubic-bezier(0.34,1.56,0.64,1) forwards;transform:scaleY(0)}
.pillar-label{animation:metricFadeIn 0.4s ease-out forwards;opacity:0}

/* ============================================
   EVENTS HERO — Countdown
   ============================================ */
.events-hero{
  min-height:80vh;display:flex;align-items:center;
  background:linear-gradient(160deg,var(--sn-dark-blue) 0%,#163a5e 50%,var(--sn-aegean) 100%);
  position:relative;overflow:hidden;
  padding:calc(var(--total-header) + 40px) 0 80px;
  margin-top:calc(var(--total-header) * -1);
}
.events-hero::before{
  content:'';position:absolute;top:50%;left:50%;width:700px;height:700px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(125,205,203,0.1) 0%,transparent 70%);
  transform:translate(-50%,-50%);pointer-events:none;
}
.events-hero-inner{text-align:center;position:relative;z-index:1;max-width:800px;margin:0 auto}
.events-hero-inner h1{
  font-size:clamp(2.5rem,5.5vw,4rem);font-weight:800;color:#fff;
  line-height:1.04;margin-bottom:var(--space-sm);letter-spacing:-0.03em;
}
.events-hero-inner .event-tagline{
  font-size:1.25rem;color:var(--sn-seaglass);font-weight:500;
  font-style:italic;margin-bottom:var(--space-2xl);
}
.countdown-row{display:flex;justify-content:center;gap:20px;margin-bottom:var(--space-2xl)}
.countdown-block{
  background:rgba(255,255,255,0.06);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.1);border-radius:var(--shape-lg);
  padding:24px 32px;min-width:110px;text-align:center;
  animation:metricFadeIn 0.6s ease-out forwards;opacity:0;
}
.countdown-num{
  font-family:var(--font-heading);font-size:3.5rem;font-weight:800;
  color:#fff;line-height:1;margin-bottom:4px;
}
.countdown-label{
  font-size:0.75rem;font-weight:600;text-transform:uppercase;
  letter-spacing:0.08em;color:var(--sn-seaglass);
}
.event-location{
  font-size:1.0625rem;color:rgba(255,255,255,0.7);margin-bottom:var(--space-lg);
}
.event-location strong{color:#fff}

/* ============================================
   CTA — Social Proof (Pricing/Benefits)
   ============================================ */
.cta-social{
  padding:80px 0 96px;position:relative;overflow:hidden;
  background:var(--sn-dark-blue);
}
.cta-social::before{
  content:'';position:absolute;top:-200px;right:-100px;width:500px;height:500px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(125,205,203,0.1) 0%,transparent 60%);
  pointer-events:none;
}
.cta-social-inner{
  display:grid;grid-template-columns:1.2fr 0.8fr;gap:var(--space-3xl);align-items:center;
  position:relative;z-index:1;
}
.cta-social-text h2{
  font-size:clamp(1.75rem,3.5vw,2.75rem);font-weight:800;color:#fff;
  line-height:1.1;margin-bottom:var(--space-md);letter-spacing:-0.02em;
}
.cta-social-text p{
  font-size:1.0625rem;color:rgba(255,255,255,0.8);line-height:1.7;
  margin-bottom:var(--space-xl);max-width:480px;
}
.cta-social-proof{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}
.cta-avatars{display:flex;align-items:center}
.cta-avatar{
  width:48px;height:48px;border-radius:50%;
  background:var(--sn-aegean);border:3px solid var(--sn-dark-blue);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-heading);font-size:0.75rem;font-weight:700;color:#fff;
  margin-left:-12px;position:relative;
}
.cta-avatar:first-child{margin-left:0}
.cta-avatar:nth-child(1){background:var(--sn-dusty-blue)}
.cta-avatar:nth-child(2){background:var(--sn-aegean)}
.cta-avatar:nth-child(3){background:var(--sn-aqua);color:var(--sn-dark-blue)}
.cta-avatar:nth-child(4){background:var(--sn-seaglass);color:var(--sn-dark-blue)}
.cta-avatar.cta-avatar-count{
  background:var(--sn-dark-blue);border-color:var(--sn-seaglass);
  font-size:0.7rem;min-width:56px;padding:0 8px;border-radius:var(--shape-full);
  width:auto;
}
.cta-counter-wrap{text-align:center}
.cta-counter{
  font-family:var(--font-heading);font-size:3rem;font-weight:800;
  color:var(--sn-seaglass);line-height:1;margin-bottom:4px;
}
.cta-counter-label{font-size:0.8125rem;color:rgba(255,255,255,0.6);font-weight:600}

/* ============================================
   CTA — Asymmetric Proof Cards
   ============================================ */
.cta-asym{
  padding:80px 0 96px;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--sn-dark-blue) 0%,#122e4d 60%,#163a5e 100%);
}
.cta-asym-inner{
  display:grid;grid-template-columns:1.1fr 0.9fr;gap:var(--space-3xl);align-items:center;
  position:relative;z-index:1;
}
.cta-asym-text h2{
  font-size:clamp(2rem,4vw,3rem);font-weight:800;color:#fff;
  line-height:1.08;margin-bottom:var(--space-md);letter-spacing:-0.02em;
}
.cta-asym-text p{
  font-size:1.0625rem;color:rgba(255,255,255,0.8);line-height:1.7;
  margin-bottom:var(--space-xl);max-width:460px;
}
.proof-stack{display:flex;flex-direction:column;gap:16px;position:relative;padding:20px 0}
.proof-card{
  background:rgba(255,255,255,0.06);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.1);border-radius:var(--shape-lg);
  padding:20px 24px;display:flex;align-items:center;gap:16px;
  transition:transform 0.3s ease,box-shadow 0.3s ease;cursor:default;
}
.proof-card:hover{transform:translateY(-3px) rotate(0deg) !important;box-shadow:0 8px 24px rgba(0,0,0,0.2)}
.proof-card:nth-child(1){transform:rotate(-1.2deg)}
.proof-card:nth-child(2){transform:rotate(0.8deg);margin-left:20px}
.proof-card:nth-child(3){transform:rotate(-0.5deg);margin-left:8px}
.proof-icon{
  width:48px;height:48px;border-radius:var(--shape-md);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.proof-card:nth-child(1) .proof-icon{background:rgba(125,205,203,0.15)}
.proof-card:nth-child(2) .proof-icon{background:rgba(72,185,199,0.15)}
.proof-card:nth-child(3) .proof-icon{background:rgba(86,155,180,0.15)}
.proof-stat{font-family:var(--font-heading);font-size:1.375rem;font-weight:800;color:#fff;line-height:1.2}
.proof-stat-label{font-size:0.8125rem;color:rgba(255,255,255,0.6);margin-top:2px}

/* ============================================
   HERO/CTA — Dark Theme Overrides
   ============================================ */
html.dark-theme .benefits-hero{background:#143a68}
html.dark-theme .training-hero{background:#143a68}
html.dark-theme .cta-social{background:#143a68}
html.dark-theme .site-header.hero-dark{background:transparent}
html.dark-theme .site-header.solid{background:rgba(11,38,70,0.97);border-bottom-color:#1a4578}
html.dark-theme .site-header.solid .nav-link,
html.dark-theme .site-header.solid .nav-dropdown-trigger{color:#d0d8e0}
html.dark-theme .site-header.solid .nav-link:hover,
html.dark-theme .site-header.solid .nav-dropdown-trigger:hover{color:#fff}
html.dark-theme .site-header.solid .header-login{color:#d0d8e0}
html.dark-theme .site-header.solid .logo-img{filter:brightness(0) invert(1)}

/* ============================================
   HERO/CTA — Responsive
   ============================================ */
@media(max-width:1024px){
  .benefits-hero-inner,.training-hero-inner,.cta-social-inner,.cta-asym-inner{grid-template-columns:1fr}
  .countdown-row{flex-wrap:wrap}
}
@media(max-width:768px){
  .countdown-block{padding:16px 20px;min-width:80px}
  .countdown-num{font-size:2.5rem}
  .proof-card{margin-left:0 !important;transform:none !important}
}
/* ============================================
   MOBILE — par-hero, CTAs, heroes
   ============================================ */
@media(max-width:1024px){
  .par-cta-inner{grid-template-columns:1fr}
  .par-cta-viz{margin-top:var(--space-xl)}
  .par-hero-content{max-width:100%}
  .par-hero-sub{max-width:100%}
}
@media(max-width:768px){
  .announcement-bar{font-size:.75rem;padding:8px var(--space-md);height:auto}
  .par-hero{min-height:60vh;padding:var(--space-2xl) 0}
  .par-hero h1{font-size:clamp(1.75rem,7vw,2.5rem) !important}
  .par-hero-sub{font-size:1rem}
  .par-hero-stars{flex-wrap:wrap}
  .par-hero-stars span{font-size:.75rem}
  .benefits-hero,.training-hero,.events-hero{min-height:auto;padding:calc(var(--total-header) + 24px) 0 var(--space-2xl)}
  .benefits-hero-inner,.training-hero-inner{gap:var(--space-xl)}
  .benefits-hero-text h1,.training-hero-text h1,.events-hero-inner h1{font-size:2rem}
  .countdown-block{padding:16px 20px;min-width:70px}
  .countdown-num{font-size:2rem}
  .cta-social{padding:var(--space-3xl) 0}
  .cta-social-inner{gap:var(--space-xl)}
  .cta-social-text h2{font-size:1.75rem}
  .cta-counter{font-size:2.25rem}
  .cta-asym{padding:var(--space-3xl) 0}
  .cta-asym-inner{gap:var(--space-xl)}
  .cta-asym-text h2{font-size:1.75rem}
  .proof-card{margin-left:0 !important;transform:none !important}
  .par-cta{padding:var(--space-3xl) 0}
  .par-cta-inner{gap:var(--space-xl)}
  .par-cta h2{font-size:1.75rem}
  .par-intro-grid{grid-template-columns:1fr;gap:var(--space-xl)}
  .par-test-grid{grid-template-columns:1fr}
  .btn{padding:12px 22px;font-size:.875rem}
}
@media(max-width:480px){
  .par-hero{min-height:50vh}
  .par-hero h1{font-size:1.625rem !important}
  .par-hero-sub{font-size:.9375rem}
  .par-hero-breadcrumb a,.par-hero-breadcrumb .current{font-size:.75rem}
  .par-hero-stars svg{width:16px;height:16px}
  .countdown-block{padding:12px 14px;min-width:60px}
  .countdown-num{font-size:1.5rem}
  .countdown-label{font-size:.625rem}
  .cta-counter{font-size:1.75rem}
  .cta-social-text h2,.cta-asym-text h2,.par-cta h2{font-size:1.5rem}
}
/* ============================================
   MOBILE FIXES — all pages
   ============================================ */
@media(max-width:768px){

  /* Contact page — blank page is the hero having huge min-height with no content visible */
  /* Services hub — text/image wrapping around each other instead of stacking */
  .svc-page-hero,
  .services-hero{
    padding:var(--space-2xl) 0 !important;
    min-height:auto !important;
  }
  .svc-page-hero .container,
  .services-hero .container{
    display:flex;flex-direction:column;
  }

  /* Services hub — intro text wrapping around floating image */
  .services-hero .container div[style*="float"],
  .services-hero .container img[style*="float"],
  .svc-page-hero .container div[style*="float"],
  .svc-page-hero .container img[style*="float"]{
    float:none !important;
    width:100% !important;
    margin:0 0 var(--space-lg) 0 !important;
  }

  /* All inline grid layouts that use style attributes */
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"]{
    grid-template-columns:1fr !important;
  }

  /* Events page — event cards still two-column */
  .event-card{
    display:flex !important;
    flex-direction:column !important;
    padding:var(--space-lg) !important;
  }
  .event-card .event-content{order:2}
  .event-card .event-logo{order:1;margin-bottom:var(--space-md)}
  .event-card .event-logo img{max-width:200px}

  /* Training page — image/text blocks wrapping side by side */
  .svc-block,
  [class*="svc-block"],
  .svc-feature-block{
    display:flex !important;
    flex-direction:column !important;
    gap:var(--space-lg) !important;
  }
  .svc-block img,
  .svc-feature-block img,
  [class*="svc-block"] img{
    width:100% !important;
    max-width:100% !important;
    float:none !important;
    margin:0 0 var(--space-md) 0 !important;
    order:-1;
  }

  /* Pricing page — hero chart needs to stack below text */
  .page-hero-inner{
    grid-template-columns:1fr !important;
    gap:var(--space-xl) !important;
  }
  .page-hero{
    min-height:auto !important;
    padding:var(--space-2xl) 0 !important;
  }

  /* Benefits page — same hero treatment */
  .benefits-hero-inner{
    grid-template-columns:1fr !important;
  }

  @media(max-width:768px){
  .feat-tabs{display:block !important;}
  .feat-tabs-nav{display:none !important}
  .feat-tabs-content{height:auto !important}
  .feat-panel{
    position:relative !important;
    display:none !important;
    opacity:1 !important;
    visibility:visible !important;
    transform:none !important;
    padding:0 !important;
  }
  .feat-panel.active{display:block !important;padding:25px!important;background-color:#F4F5FA!important;border-radius: 0 0 25px 25px!important}
  
  /* Mobile tab accordion buttons injected by JS */
  .feat-mobile-trigger{
    display:flex;align-items:center;justify-content:space-between;
    width:100%;padding:16px 0;
    background:none;border:none;border-bottom:1px solid var(--surface-container-high);
    cursor:pointer;font-family:var(--font-heading);
    font-size:1.0625rem;font-weight:600;color:var(--text-primary);
    text-align:left;
  }
  .feat-mobile-trigger.active{color:var(--sn-dark-blue);border-bottom-color:var(--sn-aqua)}
  .feat-mobile-trigger svg{
    width:20px;height:20px;flex-shrink:0;
    transition:transform .25s ease;color:var(--sn-aegean);
  }
  .feat-mobile-trigger.active svg{transform:rotate(180deg)}
}

  /* Comparison table — needs horizontal scroll */
  .compare-table-wrap{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  .compare-table{
    min-width:600px;
  }

  /* CTA social proof — stack everything */
  .cta-social-inner{
    grid-template-columns:1fr !important;
    gap:var(--space-xl) !important;
  }
  .cta-social-proof{
    align-items:flex-start !important;
  }

  /* Bottom gray CTA */
  .par-cta-inner{
    grid-template-columns:1fr !important;
    gap:var(--space-xl) !important;
  }

  /* Any two-column layout using inline styles */
  [style*="display:grid"][style*="1fr 1fr"],
  [style*="display: grid"][style*="1fr 1fr"]{
    grid-template-columns:1fr !important;
  }

  /* Kill any negative margins on heroes that cause blank space */
  [style*="margin-top:calc(var(--total-header)"],
  [style*="margin-top: calc(var(--total-header)"]{
    margin-top:0 !important;
  }
}
