/* Sunny Days – Visual Skin (non-breaking, logic-agnostic) */
@import url('tokens.css');

/* Container & section rhythm */
.container{max-width:1160px;margin-inline:auto;padding:0 22px;gap: 24px;}
.sd-section{
  background:var(--sd-white);
  border-top:1px solid var(--sd-border);
  padding-block:var(--sd-section-pad)!important;
}
.sd-section:first-of-type{border-top:0}
.sd-section.soft{background:var(--sd-soft)}
.sd-section.band{
  background:var(--sd-cta-grad);
  color:#0b1521;
  padding-block:var(--sd-band-pad)!important;
}
.sd-section.dark{
  background:var(--sd-navy);
  color:#e9f0f8;
  border-top:0;
}
.sd-header{margin:0 0 22px}
.sd-sub{color:#64748b;max-width:720px;margin:0}
.sd-eyebrow{
  display:inline-block;
  font-size:14px;
  line-height:1.4;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:700;
  color:#64748b;
  /* margin:0 0 10px; */
}
.sd-header > .sd-eyebrow{flex:0 0 100%;}
.sd-header .titlewrap .sd-eyebrow{display:block;margin:0 0 10px;}
.sd-section.band .sd-eyebrow{color:rgba(11,21,33,0.72)}

/* Hero (uses inline background from Customizer) */
.hero {position:relative;color:#fff}
.hero:before{content:"";position:absolute;inset:0;background:var(--sd-hero-grad);}
.hero .container{position:relative}
.hero .sd-eyebrow{letter-spacing:.18em;text-transform:uppercase;opacity:.82;font-weight:600;color:rgba(255,255,255,0.82)}
.hero h1{font-size:56px;line-height:1.05;margin:10px 0 14px;font-weight:800}
.hero .lead{max-width:760px;color:#e6edf6;font-size:18px}
.hero h1,
.hero .lead{
  text-shadow:0 14px 30px rgba(11,18,32,0.6);
}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 28px;
  border-radius:20px;
  font-weight:700;
  font-size:16px;
  background:#fff;
  color:#0b1220;
  border:1px solid rgba(12,22,36,0.1);
  box-shadow:0 18px 36px rgba(12,22,36,0.12);
  text-decoration:none;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
  cursor:pointer;
}
.btn:hover,
.btn:focus{
  transform:translateY(-2px);
  box-shadow:0 24px 48px rgba(12,22,36,0.16);
}
.btn.primary{
  background:linear-gradient(135deg,#ff8a00 0%,#ffb847 100%);
  color:#0b1220;
  border:none;
  box-shadow:0 24px 50px rgba(255,140,0,0.3);
}
.btn.secondary{
  background:#fff;
  color:#0b1220;
}
.btn:focus-visible{
  outline:3px solid rgba(12,22,36,0.35);
  outline-offset:3px;
}

/* Header & nav (existing IDs/classes kept) */
.sd-site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(11,18,32,0.9);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid rgba(255,255,255,0.12);
  color:var(--sd-white);
  padding-bottom:0;
}
.sd-site-header__inner{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:.5rem 1rem;
}
/* Logo */
.sd-logo{
  display:flex;
  align-items:center;
  flex-shrink:0;
}
.sd-logo__img{
  height:80px;
  width:auto;
  max-width:320px;
  object-fit:contain;
}
.sd-header-actions{
  display:flex;
  align-items:center;
  gap:12px;
}
.sd-nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.18);color:#fff;padding:10px;cursor:pointer;transition:background .2s ease,border-color .2s ease}
.sd-nav-toggle:hover,.sd-nav-toggle:focus{background:rgba(255,255,255,0.18);border-color:rgba(255,255,255,0.32)}
.sd-nav-toggle__bar{display:block;width:100%;height:2px;background:currentColor;border-radius:999px;transition:transform .2s ease,opacity .2s ease}
.sd-menu{display:flex;gap:18px;list-style:none;margin:0;padding:0}
.sd-menu > li > a{display:block;padding:.5rem .25rem;text-decoration:none;font-weight:600;color:var(--sd-white);border-bottom:2px solid transparent;transition:color .2s,border-color .2s}
.sd-menu > li > a:hover{color:var(--sd-amber);border-bottom-color:var(--sd-amber)}
.sd-menu li{position:relative}

/* Invisible bridge to keep submenu accessible when hovering */
.sd-menu .sub-menu::before{
  content:'';
  position:absolute;
  top:-10px;
  left:0;
  right:0;
  height:10px;
  background:transparent;
}

.sd-menu .sub-menu{
  display:none;
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  list-style:none;
  margin:0;
  padding:6px 0;
  min-width:220px;
  background:rgba(11,18,32,0.9);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:4px;
  box-shadow:none;
  z-index:1300;
  opacity:1;
}
.sd-menu li:hover > .sub-menu,
.sd-menu li:focus-within > .sub-menu{
  display:flex;
  flex-direction:column;
}
.sd-menu .sub-menu > li{
  width:100%;
  opacity:1;
  visibility:visible;
  transition:none;
}
.sd-menu .sub-menu > li > a{
  display:block;
  padding:.55rem 1.5rem;
  color:var(--sd-white);
  font-weight:600;
  text-decoration:none;
  transition:color .2s ease, background .2s ease, text-decoration .2s ease;
  opacity:1;
}
.sd-menu .sub-menu > li > a:hover,
.sd-menu .sub-menu > li > a:focus{
  color:var(--sd-amber);
  background:rgba(255,167,36,0.12);
  text-decoration:underline;
  text-underline-offset:6px;
}

/* Nested submenus (second level) */
.sd-menu .sub-menu .sub-menu{
  display:none;
  position:absolute;
  top:0;
  left:100%;
  margin-left:4px;
  list-style:none;
  margin:0;
  padding:6px 0;
  min-width:220px;
  background:rgba(11,18,32,0.9);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:4px;
  box-shadow:none;
  z-index:1301;
  opacity:1;
}

.sd-menu .sub-menu li:hover > .sub-menu,
.sd-menu .sub-menu li:focus-within > .sub-menu{
  display:flex;
  flex-direction:column;
}

.sd-site-header__cta .btn{
  padding:11px 22px;
  font-size:15px;
  border-radius:18px;
  box-shadow:0 16px 32px rgba(255,140,0,0.28);
}

@media(max-width:900px){
  .sd-nav-toggle{display:flex}
  .sd-primary-nav{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:rgba(8,14,24,0.97);
    padding:24px 0 28px;
    border-bottom-left-radius:18px;
    border-bottom-right-radius:18px;
    box-shadow:0 18px 36px rgba(9,18,32,0.38);
    display:none;
    flex-direction:column;
    align-items:center;
    gap:18px;
    z-index:1200;
    max-height:calc(100vh - 90px);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .sd-menu{
    flex-direction:column;
    align-items:center;
    gap:18px;
    text-align:center;
    width:100%;
  }
  .sd-menu > li{
    width:100%;
    position:relative;
  }
  .sd-menu > li > a{
    font-size:1.15rem;
    color:#fff;
    padding:.25rem 0;
    position:relative;
    display:inline-block;
  }
  /* Chevron indicator for items with submenus */
  .sd-menu > li.menu-item-has-children > a::after{
    content:'';
    display:inline-block;
    width:7px;
    height:7px;
    border-right:2px solid rgba(255,255,255,0.5);
    border-bottom:2px solid rgba(255,255,255,0.5);
    transform:rotate(45deg);
    margin-left:10px;
    transition:transform .25s cubic-bezier(0.4, 0, 0.2, 1), border-color .25s ease;
    vertical-align:middle;
    position:relative;
    top:-2px;
  }
  .sd-menu > li.menu-item-has-children > a:hover::after{
    border-color:rgba(255,167,36,0.8);
  }
  .sd-menu > li.menu-item-has-children.submenu-open > a{
    color:rgba(255,167,36,0.95);
  }
  .sd-menu > li.menu-item-has-children.submenu-open > a::after{
    transform:rotate(-135deg);
    top:2px;
    border-color:rgba(255,167,36,0.9);
  }
  /* Submenu - hidden by default, toggleable */
  .sd-menu .sub-menu{
    position:static;
    display:none;
    flex-direction:column;
    width:calc(100% - 32px);
    margin-left:16px;
    margin-right:16px;
    background:rgba(5,10,18,0.6);
    border:1px solid rgba(255,255,255,0.06);
    box-shadow:inset 0 2px 12px rgba(0,0,0,0.2);
    padding:0;
    margin-top:12px;
    margin-bottom:0;
    border-radius:10px;
    overflow:hidden;
    opacity:0;
    max-height:0;
    transition:opacity .3s cubic-bezier(0.4, 0, 0.2, 1), max-height .3s cubic-bezier(0.4, 0, 0.2, 1), padding .3s ease, margin .3s ease;
  }
  .sd-menu > li.submenu-open .sub-menu{
    display:flex;
    opacity:1;
    max-height:600px;
    padding:8px 0 12px;
    margin-bottom:4px;
  }
  .sd-menu .sub-menu > li{
    opacity:0;
    transform:translateY(-6px);
    transition:opacity .25s ease, transform .25s ease;
  }
  .sd-menu > li.submenu-open .sub-menu > li{
    opacity:1;
    transform:translateY(0);
  }
  /* Stagger animation for submenu items */
  .sd-menu > li.submenu-open .sub-menu > li:nth-child(1){transition-delay:.06s}
  .sd-menu > li.submenu-open .sub-menu > li:nth-child(2){transition-delay:.12s}
  .sd-menu > li.submenu-open .sub-menu > li:nth-child(3){transition-delay:.18s}
  .sd-menu > li.submenu-open .sub-menu > li:nth-child(4){transition-delay:.24s}
  .sd-menu > li.submenu-open .sub-menu > li:nth-child(5){transition-delay:.30s}
  .sd-menu .sub-menu > li > a{
    margin:0;
    padding:11px 20px 11px 40px;
    color:rgba(255,255,255,0.88);
    font-size:1.05rem;
    font-weight:500;
    transition:color .2s ease, transform .2s ease, background .2s ease, padding-left .2s ease;
    position:relative;
  }
  .sd-menu .sub-menu > li > a::before{
    content:'';
    position:absolute;
    left:22px;
    top:50%;
    transform:translateY(-50%);
    width:5px;
    height:5px;
    border-radius:50%;
    background:rgba(255,167,36,0.4);
    transition:all .2s ease;
  }
  .sd-menu .sub-menu > li > a:hover,
  .sd-menu .sub-menu > li > a:focus{
    color:rgba(255,167,36,1);
    background:rgba(255,167,36,0.08);
    padding-left:44px;
  }
  .sd-menu .sub-menu > li > a:hover::before,
  .sd-menu .sub-menu > li > a:focus::before{
    background:var(--sd-amber);
    transform:translateY(-50%) scale(1.4);
    box-shadow:0 0 8px rgba(255,167,36,0.4);
  }
  .sd-site-header__cta{display:none}
  html.sd-nav-open .sd-primary-nav{display:flex}
  html.sd-nav-open body{overflow:hidden}
}

@media(max-width:540px){
  .sd-primary-nav{padding:20px 0 24px;border-bottom-left-radius:0;border-bottom-right-radius:0;background: rgb(46 52 65);;}
  .sd-menu > li > a{font-size:1.05rem}
}

@media(max-width:720px){
  .sd-section{padding-block:calc(var(--sd-section-pad) * 0.8)!important}
  .sd-section.band,.sd-section.soft{padding-block:calc(var(--sd-band-pad) * 0.85)!important}
}

@media(max-width:480px){
  .volunteer-cta{gap:10px}
}

/* Grids */
.split-2{display:grid;grid-template-columns:1.25fr .75fr;gap:26px}
@media (max-width:980px){.split-2{grid-template-columns:1fr}}
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:980px){.cards-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.cards-grid{grid-template-columns:1fr}}

/* Cards */
.card{background:var(--sd-card);border:1px solid var(--sd-border);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 26px rgba(11,18,32,0.05)}
.card .pad{padding:20px}
.card h3{margin:0 0 8px;font-size:22px}
.card .meta{color:var(--sd-muted);font-size:14px}

/* Badges & micro */
.badge{display:inline-block;padding:6px 10px;border-radius:999px;background:var(--sd-soft);border:1px solid var(--sd-border);color:var(--sd-text);font-weight:600;font-size:12px}

/* Webinars embed box (right side) */
.sd-webinar-embed{background:#eaf1fa;border:1px solid #d6e2f2;border-radius:18px;overflow:hidden}
.sd-webinar-embed iframe{width:100%;height:var(--sd-embed-h);display:block}

/* Alternating bands */
.band-dark{background:#0b1521;color:#d8e6fb}
.band-dark .sd-header h2{color:#fff}
.band-dark .card{background:#0f1b2d;border-color:#1c2b43}
.band-dark .meta{color:#93a8c2}

/* Partners grid */
.partner-logos{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:28px;justify-items:center;align-items:center}
.partner-logos img{max-height:48px;width:auto;opacity:.85;filter:grayscale(100%);transition:opacity .2s,filter .2s}
.partner-logos img:hover{opacity:1;filter:none}

/* Team */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media (max-width:980px){.team-grid{grid-template-columns:repeat(2,1fr)}}
.member{background:var(--sd-card);border:1px solid var(--sd-border);border-radius:18px;overflow:hidden;display:flex;flex-direction:column}
.member img{width:100%;height:280px;object-fit:cover;display:block}
.member .pad{padding:16px}
.member .pos{color:var(--sd-muted);font-size:14px}

/* Single Team Member Page */
.team-member-nav{padding:20px 0;border-bottom:1px solid var(--sd-border)}
.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--sd-orange);font-weight:600;text-decoration:none;transition:gap .2s ease}
.back-link:hover{gap:4px;text-decoration:underline}

.team-member-header{padding-top:48px!important}
.team-member-intro{display:grid;grid-template-columns:320px 1fr;gap:48px;align-items:start}
@media (max-width:768px){.team-member-intro{grid-template-columns:1fr;gap:32px;text-align:center}}

.team-member-photo{position:relative;width:100%;aspect-ratio:1;border-radius:24px;overflow:hidden;box-shadow:0 12px 40px rgba(11,21,33,0.15)}
.member-photo{width:100%;height:100%;object-fit:cover;display:block}
.member-photo-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#e2e8f0 0%,#cbd5e1 100%);display:flex;align-items:center;justify-content:center}

.team-member-meta{display:flex;flex-direction:column;gap:16px}
@media (max-width:768px){.team-member-meta{align-items:center}}

.team-member-name{font-size:48px;font-weight:800;line-height:1.1;margin:0;color:var(--sd-dark)}
@media (max-width:768px){.team-member-name{font-size:36px}}

.team-member-position{font-size:22px;font-weight:600;color:var(--sd-orange);margin-top:-4px}
@media (max-width:768px){.team-member-position{font-size:18px}}

.team-member-contact{display:flex;gap:12px;margin-top:8px}
@media (max-width:768px){.team-member-contact{justify-content:center}}

.contact-link{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:var(--sd-card);border:1px solid var(--sd-border);border-radius:10px;color:var(--sd-dark);text-decoration:none;font-weight:500;font-size:15px;transition:all .2s ease}
.contact-link:hover{background:#f8fafc;border-color:var(--sd-orange);color:var(--sd-orange);transform:translateY(-2px);box-shadow:0 4px 12px rgba(11,21,33,0.1)}
.contact-link svg{flex-shrink:0}

.team-member-bio{border-top:1px solid var(--sd-border)}
.team-member-content{max-width:820px;font-size:18px;line-height:1.7;color:#334155}
.team-member-content p{margin-bottom:20px}
.team-member-content p:last-child{margin-bottom:0}
.team-member-content h2{font-size:28px;font-weight:700;margin:32px 0 16px;color:var(--sd-dark)}
.team-member-content h3{font-size:22px;font-weight:600;margin:24px 0 12px;color:var(--sd-dark)}
.team-member-content ul,.team-member-content ol{margin:16px 0;padding-left:28px}
.team-member-content li{margin-bottom:8px}

/* CTA bands */
.sd-section.band{
  color:#0b1220;
  text-align:center;
}
.cta-band{
  background:var(--sd-cta-grad);
  color:#0b1220;
  position:relative;
  overflow:hidden;
}
.cta-band::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.35;
  background:radial-gradient(circle at 12% 18%,rgba(255,255,255,0.35),transparent 55%),radial-gradient(circle at 82% 24%,rgba(255,255,255,0.18),transparent 58%);
  pointer-events:none;
}
.cta-band .container{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.cta-band .sd-header{
  margin:0;
  max-width:760px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:16px;
  text-align:center;
}
.cta-band .sd-header h2{
  color:#0b1220;
  margin:0;
  font-weight:800;
}
.cta-band .sd-eyebrow{
  color:rgba(11,18,32,0.7);
  letter-spacing:.3em;
  font-weight:700;
}
.cta-band .blurb{
  margin:0;
  max-width:580px;
  color:rgba(11,18,32,0.76);
  font-size:12px;
  font-weight:700;
}
.cta-band .cta-actions{margin-top:4px}
.cta-band .cta-actions .btn{min-width:220px}

.volunteer-cta{gap: 0px;}
.volunteer-cta .sd-header{margin-bottom:0}

/* ===== Newsletter (clean, leveled pills) ===== */
.newsletter.cta-band .container{gap:28px}
.newsletter.cta-band .newsletter-signup{
  display:flex;
  align-items:center;           /* level baselines */
  justify-content:center;
  gap:16px;
  flex-wrap:nowrap;             /* side-by-side on desktop */
}
.newsletter.cta-band .newsletter-signup .input{
  padding:14px 28px;
  border-radius:20px;          /* pill */
  box-sizing:border-box;
  width:min(560px,100%);
  background:#fff;
  box-shadow:0 20px 44px rgba(12,22,36,0.18);
  font-size:17px;
  line-height:1;                /* avoid baseline drift */
  color:#0b1220;
  -webkit-appearance:none;
  appearance:none;
}
.newsletter.cta-band .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:56px;                  /* exact match with input */
  padding:14px 28px;
  min-width:180px;
  border-radius:20px;          /* pill */
  background:#fff;              /* ‘secondary’ already does this; kept as guard */
  color:#0b1220;
  box-shadow:0 20px 44px rgba(12,22,36,0.12);
}
@media (max-width:720px){
  .newsletter.cta-band .newsletter-signup{flex-wrap:wrap;}
  .newsletter.cta-band .newsletter-signup .input,
  .newsletter.cta-band .btn{width:100%;}
}

.footer-cta{
  border-radius:0;
}
.footer-cta .blurb{
  color:rgba(11,18,32,0.76);
  margin:0;
}
.donate-cta{
  background:#0b1521;
  color:#fff;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.donate-cta::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.4;
  background:radial-gradient(circle at 15% 20%,rgba(104,126,255,0.2),transparent 55%), radial-gradient(circle at 85% 15%,rgba(255,157,64,0.25),transparent 60%);
  pointer-events:none;
}
.donate-cta .container{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:24px;
}
.donate-cta .sd-header{
  margin:0 auto 18px;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:16px;
  flex-direction:column;
  max-width:720px;
}
.donate-cta .cta-actions{margin:0}
.donate-cta .cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
  margin:0
}
.donate-cta .sd-eyebrow{
  color:#9fb2ff;
  letter-spacing:.08em;
  font-weight:700;
  font-size:12px
}
.donate-cta h2{
  margin:0;
  font-size:clamp(2rem,4vw,3.25rem);
  font-weight:800;
  color:#fff;
}
.donate-cta .blurb{
  margin:0;
  color:rgba(204,214,232,0.9);
  max-width:540px;
  flex:0 0 auto;
}
.donate-cta .btn{
  min-width:220px;
  padding:16px 42px;
  border-radius:22px;
  font-size:18px;
  box-shadow:0 22px 48px rgba(255,140,0,0.32);
}
.donate-cta .btn:hover,
.donate-cta .btn:focus{
  transform:translateY(-2px);
  box-shadow:0 28px 56px rgba(255,140,0,0.38);
}
.site-footer{background:var(--sd-navy);color:#dee6f4;padding:48px 0 32px;border-top:1px solid rgba(255,255,255,0.08)}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:28px}
.footer-grid > *{min-width:0}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li+li{margin-top:8px}
.site-footer a{color:rgba(255,255,255,0.85);}
.site-footer a:hover,
.site-footer a:focus{color:var(--sd-amber);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.12);margin-top:24px;padding-top:18px;color:#a7b6c7}
@media (max-width:900px){
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr;gap:20px}
}

/* ==== Testimonial cards (works with your existing markup) ==== */
/* Grid */
.sd-section.soft .cards-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 24px;
}

/* Card panel */
.sd-section.soft .cards-grid blockquote.card{
  grid-column: span 12;
  position: relative;
  background: #fff;
  border-radius: 24px;
  box-shadow: 0 10px 24px rgba(10,20,35,0.08);
  overflow: hidden;           /* keep the accent clipped to the round corners */
  margin: 0;                  /* remove default blockquote margins */
  padding: 28px 32px;
}

/* Full-height orange accent bar */
.sd-section.soft .cards-grid blockquote.card::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 10px;
  background: var(--sd-accent, #fb8500);
  border-radius: 24px 0 0 24px;
}

/* Neutralize inner .pad if present to avoid double padding */
.sd-section.soft blockquote.card .pad{ padding: 0; }

/* ==== Page hero & shared layouts ==== */
.page-hero{
  position:relative;
  background:linear-gradient(135deg,var(--sd-navy) 0%,#102846 55%,#1f3c65 100%);
  color:#e6edf6;
  padding:110px 0 96px;
  overflow:hidden;
}
.page-hero .container{position:relative;z-index:1}
.badge--hero{
  background:var(--sd-orange);
  border-color:var(--sd-orange);
  color:var(--sd-text);
  box-shadow:0 8px 20px rgba(251,133,0,0.25);
}
.page-hero__title{
  font-size:clamp(2.5rem,5vw,3.75rem);
  line-height:1.08;
  margin:18px 0 12px;
  font-weight:800;
  color:#fff;
}
.page-hero__lead{
  font-size:1.15rem;
  max-width:760px;
  color:rgba(230,237,246,0.9);
  margin:0;
}
.page-hero__search{
  margin-top:32px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
.page-hero__search input[type="search"]{
  flex:1 1 260px;
  padding:14px 18px;
  border-radius:14px;
  border:1px solid var(--sd-border);
  background:rgba(255,255,255,0.98);
  color:var(--sd-ink);
  font-size:16px;
  box-shadow:0 8px 22px rgba(12,22,36,0.18);
  transition:box-shadow .2s ease,border-color .2s ease;
}
.page-hero__search input[type="search"]:focus{
  outline:0;
  border-color:var(--sd-orange);
  box-shadow:0 12px 28px rgba(251,133,0,0.28);
}
.page-hero__search input::placeholder{color:#5e7089}
.page-hero__search .btn{
  padding:14px 26px;
  border-radius:14px;
  font-size:16px;
}

.about-overview{padding:84px 0}
.about-pillars{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.about-card{
  background:#fff;
  border:1px solid #e1e7f2;
  border-radius:20px;
  padding:22px 24px;
  box-shadow:0 14px 34px rgba(11,18,32,0.06);
}
.about-card h3{margin:0 0 10px;font-size:22px;color:var(--sd-ink)}
.about-card p{margin:0;color:#4f5f79;font-size:16px;line-height:1.55}

.about-story{
  background:var(--sd-white);
  border:1px solid var(--sd-border);
  border-radius:22px;
  padding:24px 26px;
  box-shadow:0 18px 36px rgba(11,18,32,0.07);
  display:flex;
  flex-direction:column;
  gap:16px;
  max-height:100%;
}
.about-story .badge{
  align-self:flex-start;
  background:rgba(251,133,0,0.12);
  border-color:rgba(251,133,0,0.3);
  color:var(--sd-text);
}
.about-timeline{
  margin-top:4px;
  border-left:2px solid var(--sd-border);
  padding-left:24px;
  max-height:440px;
  overflow-y:auto;
  scroll-behavior:smooth;
}
.about-timeline::-webkit-scrollbar{width:6px}
.about-timeline::-webkit-scrollbar-thumb{
  background:rgba(15,34,56,0.18);
  border-radius:999px;
}
.about-timeline::-webkit-scrollbar-track{background:transparent}
.timeline-item{
  position:relative;
  padding-left:12px;
  margin-bottom:28px;
}
.timeline-item:last-child{margin-bottom:0}
.timeline-item__marker{
  width:12px;
  height:12px;
  border-radius:999px;
  background:var(--sd-orange);
  border:2px solid #fff;
  box-shadow:0 0 0 3px rgba(251,133,0,0.18);
  position:absolute;
  left:-31px;
  top:6px;
}
.timeline-item__year{
  font-weight:700;
  color:var(--sd-ink);
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:13px;
}
.timeline-item__title{
  margin:6px 0 6px;
  font-size:20px;
  line-height:1.3;
  color:var(--sd-ink);
}
.timeline-item__summary{
  margin:0;
  color:#53637d;
  font-size:15px;
  line-height:1.55;
}

.about-body{padding:72px 0 96px}
.about-article__content{max-width:760px;margin:0 auto;font-size:17px;color:#3a3a3a}
.about-article__content > *:first-child{margin-top:0}
.about-article__content h2,.about-article__content h3{color:var(--sd-ink)}

.archive-grid .cards-grid{margin-top:32px}
.archive-empty{
  margin:40px 0;
  padding:28px 32px;
  background:var(--sd-bg);
  border:1px dashed #c8d8ee;
  border-radius:18px;
  color:#41526a;
  text-align:center;
}
.pagination{display:flex;justify-content:center;margin:42px 0 0}
.pagination ul{display:flex;gap:8px;list-style:none;margin:0;padding:0;background:var(--sd-white);border-radius:999px;padding:6px 10px;border:1px solid var(--sd-border);box-shadow:0 14px 28px rgba(15,34,56,0.12)}
.pagination li{display:flex}
.pagination a,.pagination span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:40px;
  height:40px;
  border-radius:999px;
  font-weight:600;
  color:var(--sd-ink);
  text-decoration:none;
  padding:0 14px;
}
.pagination .current{
  background:var(--sd-orange);
  color:var(--sd-text);
}
.pagination a:hover{background:rgba(251,133,0,0.18)}

.contact-body{padding:72px 0 100px}
.contact-form{
  display:grid;
  gap:14px;
  max-width:540px;
  margin-bottom:32px;
}
.contact-form input,
.contact-form textarea{
  border-radius:14px;
  border:1px solid var(--sd-border);
  padding:14px 18px;
  font-size:16px;
  color:var(--sd-ink);
  background:var(--sd-white);
  box-shadow:0 6px 20px rgba(15,34,56,0.08);
  transition:border-color .2s ease, box-shadow .2s ease;
}
.contact-form textarea{resize:vertical;min-height:140px}
.contact-form input:focus,
.contact-form textarea:focus{
  outline:0;
  border-color:#fb8500;
  box-shadow:0 10px 28px rgba(251,133,0,0.2);
}
.contact-article__content{max-width:760px;font-size:17px;color:#3a3a3a}
.contact-article__content > *:first-child{margin-top:0}

@media (max-width:1024px){
  .about-pillars{grid-template-columns:1fr}
  .about-story{margin-top:28px}
  .about-timeline{max-height:none}
}
@media (max-width:640px){
  .page-hero{padding:84px 0 72px}
  .page-hero__title{font-size:clamp(2.2rem,6.2vw,3.1rem)}
  .page-hero__search{flex-direction:column;align-items:stretch}
  .page-hero__search .btn{width:100%}
  .contact-form{max-width:100%}
  .contact-form .btn{width:100%}
  .about-overview{padding:64px 0}
  .about-card{padding:20px}
  .about-story{padding:22px}
  .timeline-item__title{font-size:18px}
}

/* Responsive columns (2-up then 3-up) */
@media (min-width: 720px){
  .sd-section.soft .cards-grid blockquote.card{ grid-column: span 6; }
}
@media (min-width: 1080px){
  .sd-section.soft .cards-grid blockquote.card{ grid-column: span 4; }
}

/* === Header with right-aligned actions === */
.sd-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}
.sd-header h2{font-size:var(--sd-h2-size);}
.sd-header .blurb{max-width:720px;margin:6px 0 0;flex:1 1 100%;text-align:left}
.sd-header .actions{margin-left:auto;display:flex;gap:12px;align-items:center}
.sd-header .seeall{white-space:nowrap;font-weight:600;color:var(--sd-orange,#fb8500)}
@media(max-width:768px){.sd-header{flex-direction:column;align-items:flex-start}
  .sd-header .actions{align-self:stretch;justify-content:flex-end;width:100%}}

/* Authoritative section paddings */
.sd-section{padding-block:var(--sd-section-pad)!important}
.sd-section.band,.sd-section.soft{padding-block:var(--sd-band-pad)!important}

/* Cards & typography tokens */
.card img{width:100%;height:280px;object-fit:cover;display:block}
.card h3{font-size:var(--sd-h3-size)}

/* Testimonials scoped */
.sd-testimonials{position:relative;padding-top:calc(var(--sd-section-pad) + 24px)!important}
.sd-testimonials .sd-header{margin-bottom:36px}
.sd-testimonials .cards-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:28px}
.sd-testimonials blockquote.card{grid-column:span 12;position:relative;background:var(--sd-white);border-radius:28px;box-shadow:0 24px 50px rgba(20,42,78,0.12);overflow:hidden;margin:0;transition:transform .2s ease,box-shadow .2s ease}
@media(min-width:720px){.sd-testimonials blockquote.card{grid-column:span 6}}
@media(min-width:1080px){.sd-testimonials blockquote.card{grid-column:span 4}}
.sd-testimonials blockquote.card:hover{transform:translateY(-4px);box-shadow:0 32px 64px rgba(20,42,78,0.16)}
.sd-testimonials blockquote.card .pad{padding:36px 40px}
.sd-testimonials blockquote.card p{margin:0 0 18px;color:#24344e;font-size:18px;line-height:1.6}
.sd-testimonials blockquote.card .meta{margin:0;color:#5c6f8a;font-weight:600;font-size:15px}
.sd-testimonials blockquote.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:16px;background:linear-gradient(180deg,#fb8500 0%,#ffb347 100%);border-radius:0 18px 18px 0}
.sd-testimonials blockquote.card::after{content:"";position:absolute;left:16px;top:18px;bottom:18px;width:1px;background:rgba(251,133,0,0.12)}

/* Updates list rows */
.sd-updates .news-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:20px}
.sd-updates .news-item{position:relative;border:1px solid var(--sd-border);border-radius:20px;padding:6px;background:linear-gradient(160deg,#f8f9fb 0%,#eef2f7 100%);box-shadow:0 10px 24px rgba(12,22,36,0.08)}
.sd-updates .news-item .inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:22px 26px;background:var(--sd-white);border-radius:16px;box-shadow:0 14px 30px rgba(12,22,36,0.08);transition:transform .18s ease, box-shadow .18s ease}
.sd-updates .news-item .inner:hover{transform:translateY(-4px);box-shadow:0 18px 36px rgba(12,22,36,0.12)}
.sd-updates .news-item h3{margin:0;font-weight:600;color:var(--sd-ink,#0b1220)}
.sd-updates .news-item .meta{margin:6px 0 0;font-size:15px;color:#6a7d97}
.sd-updates .news-item .read{white-space:nowrap;color:var(--sd-orange,#fb8500);font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:color .18s ease}
.sd-updates .news-item .inner:hover .read{color:#d96e00}
@media(max-width:720px){
  .sd-updates .news-item .inner{flex-direction:column;align-items:flex-start;padding:20px 22px;gap:12px}
  .sd-updates .news-item .read{align-self:flex-start}
}
@media(max-width:520px){
  .sd-updates .news-item .inner{padding:18px 18px}
}

/* Webinars equal columns */
.sd-webinars .split-2{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:900px){.sd-webinars .split-2{grid-template-columns:1fr 1fr}}
.sd-webinars .split-2>.card{display:flex;flex-direction:column;justify-content:space-between}
.sd-webinars .card{min-height:400px}
.sd-webinars .embed{position:relative;border-radius:14px;overflow:hidden;background:#eaf1fa;border:1px solid #d6e2f2}
.sd-webinars .embed::before{content:"";display:block;aspect-ratio:16/9}
.sd-webinars .embed iframe,.sd-webinars .embed video{position:absolute;inset:0;width:100%;height:100%}

/* Webinars video grid */
.video-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 24px;
}
.video-grid .card{
  grid-column: span 6;
}
@media (max-width: 900px){
  .video-grid .card{ grid-column: span 12; }
}
.video-grid .video-embed iframe,
.video-grid .video-embed video{
  width:100%;
  height:100%;
  display:block;
}
