/* ── Agile Executives v11, Shared Stylesheet (Stitch identity) ── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px}
@media(max-width:600px){html{font-size:16.5px}}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--ink-body);background:var(--paper-white);line-height:1.6;-webkit-font-smoothing:antialiased;font-feature-settings:'cv11','ss01'}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--tide-teal);color:#fff}
.material-symbols-outlined{font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24}

/* ── DESIGN TOKENS (Stitch identity) ── */
:root{
  /* Brand */
  --anchor-navy: #164686;
  --primary:     #002f65;
  --slate-ink:   #0F1620;
  --tide-teal:   #00A89C;
  --teal-deep:   #008175;
  --teal-bright: #0CC6B5;
  --sail-blue:   #4A90D9;
  --berry:       #9C2F4D;
  /* Surfaces */
  --paper-white: #FFFFFF;
  --mist:        #F4F7FB;
  --tideline:    #DDE6F0;
  --ink-body:    #1A2433;
  --slate:       #2A3440;
  --slate-500:   #64748B;
  --slate-600:   #475569;
  --slate-300:   #cbd5e1;
  /* Legacy aliases, keep so existing pages render with new palette */
  --navy:        #164686;
  --navy-dk:     #002f65;
  --navy-mid:    #1e5aa8;
  --navy-pale:   #eef2fb;
  --navy-border: #DDE6F0;
  --white:       #ffffff;
  --charcoal:    #1A2433;
  --mid:         #475569;
  --light:       #F4F7FB;
  --border:      #DDE6F0;
  --teal:        #00A89C;
  --teal-dk:     #008175;
  --teal-mid:    #0CC6B5;
  --teal-pale:   #e0f5f3;
  --teal-border: #b1e6e1;
  --blue:        #4A90D9;
  --blue-dk:     #2a6db8;
  --blue-pale:   #eaf2fb;
  --blue-border: #c5dcf2;
  --green-acc:   #008175;
  /* Effects */
  --shadow:      0 4px 24px rgba(15,22,32,.08);
  --shadow-lg:   0 12px 48px rgba(15,22,32,.14);
  --shadow-xl:   0 24px 64px rgba(15,22,32,.18);
  --radius:      4px;
  --radius-md:   8px;
  --radius-lg:   12px;
}

/* ── LAYOUT ── */
.container{max-width:1280px;margin:0 auto;padding:0 32px}

/* ── TYPOGRAPHY ── */
.tag,.eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:'Inter',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--tide-teal);margin-bottom:18px}
.tag::before,.eyebrow::before{content:'';display:inline-block;width:32px;height:2px;background:var(--tide-teal);flex-shrink:0}
.tag-teal{color:var(--tide-teal)}
.tag-teal::before{background:var(--tide-teal)}
.tag-white{color:var(--teal-bright)}
.tag-white::before{background:var(--teal-bright)}
.tag-berry{color:var(--berry)}
.tag-berry::before{background:var(--berry)}
.tag-noline{padding:5px 14px;background:rgba(0,168,156,.10);border-radius:999px;color:var(--teal-deep)}
.tag-noline::before{display:none}
.section-title{font-family:'Inter',sans-serif;font-size:clamp(2rem,3.6vw,3.2rem);font-weight:800;color:var(--anchor-navy);line-height:1.12;letter-spacing:-.02em;margin-bottom:18px}
.section-title em{font-style:normal;color:var(--tide-teal);font-weight:800}
.section-title-white{color:#fff}
.section-sub{font-size:1.05rem;color:var(--slate-600);max-width:640px;line-height:1.72}
.section-sub-white{color:rgba(255,255,255,.72)}
.display-xl{font-size:clamp(2.6rem,5vw,4.4rem);font-weight:800;line-height:1.05;letter-spacing:-.025em;color:var(--anchor-navy)}
.display-xl em{font-style:normal;color:var(--tide-teal);font-weight:800}

/* ── BUTTONS (sharp, eyebrow-style labels) ── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 30px;border-radius:var(--radius);font-family:'Inter',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;transition:all .25s ease;border:2px solid transparent;white-space:nowrap;line-height:1}
.btn-primary{background:var(--anchor-navy);color:#fff;border-color:var(--anchor-navy)}
.btn-primary:hover{background:var(--primary);border-color:var(--primary);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-teal{background:var(--tide-teal);color:#fff;border-color:var(--tide-teal)}
.btn-teal:hover{background:var(--teal-deep);border-color:var(--teal-deep);box-shadow:0 8px 24px rgba(0,168,156,.28)}
.btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-outline-white:hover{background:rgba(255,255,255,.10);border-color:#fff}
.btn-outline-navy{background:transparent;color:var(--anchor-navy);border:2px solid var(--anchor-navy)}
.btn-outline-navy:hover{background:var(--anchor-navy);color:#fff}
.btn-outline-teal{background:transparent;color:var(--teal-deep);border:2px solid var(--tide-teal)}
.btn-outline-teal:hover{background:var(--tide-teal);color:#fff}
.btn-blue{background:var(--sail-blue);color:#fff;border-color:var(--sail-blue)}
.btn-blue:hover{background:var(--blue-dk);border-color:var(--blue-dk)}

/* FOCUS */
.btn:focus-visible,.nav-links a:focus-visible,.nav-dropdown a:focus-visible,.form-submit:focus-visible,a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--tide-teal);outline-offset:3px;border-radius:2px}

/* SKIP LINK */
.skip-link{position:absolute;top:-100%;left:16px;background:var(--anchor-navy);color:#fff;padding:12px 24px;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;z-index:9999;transition:top .2s}
.skip-link:focus{top:0}

/* ── NAV ── */
.nav{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--tideline);transition:box-shadow .3s,border-color .3s}
.nav.scrolled{box-shadow:0 4px 18px rgba(15,22,32,.06)}
.nav-inner{display:flex;align-items:center;flex-wrap:wrap;row-gap:4px;column-gap:12px;padding:14px 0 0}
.nav-logo{display:flex;align-items:center;gap:12px;font-size:1.18rem;font-weight:900;color:var(--anchor-navy);letter-spacing:-.025em;order:1}
.nav-logo img{transition:opacity .2s;display:block}
.nav-links{display:flex;align-items:center;justify-content:center;gap:6px;list-style:none;order:3;flex-basis:100%;border-top:1px solid var(--tideline);margin-top:10px}
.nav-links>li{position:relative}
.nav-links>li>a{font-size:.78rem;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:var(--slate-500);transition:color .2s,border-color .2s;padding:16px 14px;display:flex;align-items:center;gap:6px;border-bottom:2px solid transparent}
.nav-links>li>a:hover,.nav-links>li>a.active,.nav-links>li.active>a{color:var(--anchor-navy);border-bottom-color:var(--anchor-navy)}
.has-dropdown::after{content:'';display:inline-block;border:4px solid transparent;border-top-color:currentColor;border-bottom:none;margin-top:3px;opacity:.55;transition:transform .2s}
.nav-links>li:hover .has-dropdown::after{transform:rotate(180deg)}
.nav-dropdown{position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--tideline);border-radius:var(--radius);padding:10px;min-width:230px;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .2s,transform .2s,visibility .2s;z-index:300;pointer-events:none}
.nav-links>li:hover .nav-dropdown,.nav-links>li:focus-within .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
.nav-dropdown a{display:flex;align-items:center;gap:10px;padding:11px 14px;font-size:.9rem;font-weight:600;color:var(--ink-body);transition:background .15s,color .15s;white-space:nowrap;text-transform:none;letter-spacing:0}
.nav-dropdown a:hover{background:var(--mist);color:var(--anchor-navy)}
.nav-right{display:flex;align-items:center;gap:14px;order:2;margin-left:auto}
.nav-cta{font-size:.78rem;padding:13px 22px}
.nav-burger{display:none;background:none;border:none;cursor:pointer;padding:6px;order:2;margin-left:auto}
.nav-burger span{display:block;width:24px;height:2px;background:var(--anchor-navy);margin:5px 0}

/* Mobile menu */
.mobile-menu{position:fixed;top:64px;left:0;right:0;background:#fff;border-bottom:1px solid var(--tideline);padding:18px 24px;z-index:199;display:none;flex-direction:column;gap:2px;box-shadow:var(--shadow-lg);max-height:calc(100vh - 64px);overflow-y:auto}
.mobile-menu.open{display:flex}
.mobile-menu-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.16em;color:var(--tide-teal);padding:14px 14px 6px;margin-top:4px}
.mobile-menu a{padding:12px 14px;font-size:.92rem;font-weight:600;color:var(--ink-body);transition:background .2s,color .2s}
.mobile-menu a:hover{background:var(--mist);color:var(--anchor-navy)}
.mobile-menu .btn{margin-top:12px;text-align:center;justify-content:center}
.mobile-menu-divider{height:1px;background:var(--tideline);margin:8px 0}

/* ── PAGE HERO (white, editorial, teal accent) ── */
.page-hero{padding:32px 0 44px;background:#fff;position:relative;overflow:hidden;border-bottom:1px solid var(--tideline)}
.page-hero + .section{padding-top:64px}
.page-hero + .trust + .section{padding-top:80px}
.page-hero::after{content:'';position:absolute;right:-180px;top:-80px;width:520px;height:520px;background:radial-gradient(circle,rgba(0,168,156,.06) 0%,transparent 70%);pointer-events:none}
.page-hero-inner{position:relative;z-index:1;max-width:920px}
.page-hero h1{font-size:clamp(2rem,3vw,2.8rem);font-weight:800;color:var(--anchor-navy);line-height:1.12;letter-spacing:-.02em;margin-bottom:18px}
.page-hero h1 em{font-style:normal;color:var(--tide-teal)}
.page-hero p{font-size:1.02rem;color:var(--slate-600);line-height:1.65;margin-bottom:28px;max-width:640px}
.page-hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* BREADCRUMB */
.breadcrumb{display:flex;align-items:center;gap:10px;font-size:.74rem;font-weight:600;color:var(--slate-500);margin-bottom:24px;text-transform:uppercase;letter-spacing:.1em}
.breadcrumb a{color:var(--slate-500);transition:color .2s}
.breadcrumb a:hover{color:var(--tide-teal)}

/* ── TRUST BAR ── */
.trust{padding:36px 0;background:var(--mist);border-top:1px solid var(--tideline);border-bottom:1px solid var(--tideline)}
.trust-inner{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center}
.trust-label{font-size:.66rem;font-weight:700;color:var(--slate-500);letter-spacing:.2em;text-transform:uppercase;margin-right:14px}
.trust-pill,.partner-pill{background:#fff;border:1px solid var(--tideline);padding:10px 22px;font-size:.86rem;font-weight:600;color:var(--slate-600);transition:all .2s;border-radius:var(--radius)}
.partner-pill:hover{border-color:var(--tide-teal);color:var(--tide-teal);background:rgba(0,168,156,.04)}

/* ── FOOTER ── */
.footer{background:var(--anchor-navy);color:rgba(255,255,255,.72);padding:90px 0 36px;border-top:1px solid rgba(255,255,255,.05)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:64px;margin-bottom:60px}
.footer-brand-name{font-size:1.4rem;font-weight:900;color:#fff;margin-bottom:18px;display:flex;align-items:center;gap:12px;letter-spacing:-.025em}
.footer-brand-desc{font-size:.95rem;line-height:1.72;max-width:340px;margin-bottom:24px;color:rgba(255,255,255,.75)}
.footer-social{display:flex;gap:12px;margin-top:6px}
.social-link{width:42px;height:42px;border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;transition:background .25s,border-color .25s;border-radius:50%}
.social-link:hover{background:var(--tide-teal);border-color:var(--tide-teal)}
.social-link svg{width:16px;height:16px;fill:rgba(255,255,255,.85);transition:fill .25s}
.social-link:hover svg{fill:#fff}
.footer-col-title{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.18em;color:var(--teal-bright);margin-bottom:22px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer-links a{font-size:.95rem;color:rgba(255,255,255,.78);transition:color .2s}
.footer-links a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.72rem;text-transform:uppercase;letter-spacing:.13em;color:rgba(255,255,255,.55)}
.footer-bottom-links{display:flex;gap:28px}
.footer-bottom-links a:hover{color:#fff}

/* ── CARDS ── */
.card{border:1px solid var(--tideline);padding:34px 30px;transition:all .3s ease;position:relative;background:#fff;border-radius:var(--radius);display:flex;flex-direction:column;height:100%}
.card:hover{border-color:var(--tide-teal);transform:translateY(-3px);box-shadow:var(--shadow)}
.card-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:22px;background:var(--mist);color:var(--anchor-navy);transition:background .25s,color .25s;border-radius:var(--radius)}
.card:hover .card-icon{background:var(--tide-teal);color:#fff}
.card-icon .material-symbols-outlined{font-size:24px}
.card-name{font-size:1.05rem;font-weight:800;color:var(--anchor-navy);margin-bottom:10px;line-height:1.3}
.card-desc{font-size:.95rem;color:var(--slate-600);line-height:1.65;flex-grow:1}
.card-link{font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--tide-teal);display:inline-flex;align-items:center;gap:8px;margin-top:18px;transition:gap .25s}
.card:hover .card-link{gap:14px}

/* SVC PILL */
.svc-pill{display:flex;align-items:center;gap:14px;padding:18px 22px;background:#fff;border:1px solid var(--tideline);transition:all .25s;border-radius:var(--radius)}
.svc-pill:hover{box-shadow:var(--shadow);border-color:var(--tide-teal);transform:translateY(-2px)}
.svc-pill-icon{width:42px;height:42px;background:var(--mist);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--anchor-navy);border-radius:var(--radius);transition:background .25s,color .25s}
.svc-pill:hover .svc-pill-icon{background:var(--tide-teal);color:#fff}
.svc-pill-icon .icon{stroke:currentColor}
.svc-pill-name{font-size:.92rem;font-weight:700;color:var(--anchor-navy)}
.svc-pill-arrow{margin-left:auto;color:var(--tide-teal);font-weight:800}

/* COMPARE CARD */
.compare-card{background:var(--anchor-navy);color:rgba(255,255,255,.88);padding:38px 36px;border-radius:var(--radius)}
.compare-title{font-size:1rem;font-weight:800;color:#fff;margin-bottom:24px;letter-spacing:-.01em}
.compare-table{display:flex;flex-direction:column;gap:10px}
.compare-row{display:grid;grid-template-columns:1fr 84px 84px;gap:6px;align-items:center;font-size:.81rem}
.compare-head{font-weight:600;color:rgba(255,255,255,.85)}
.compare-col-head{text-align:center;font-size:.65rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.compare-val{text-align:center;font-size:.95rem;color:rgba(255,255,255,.85)}
.compare-val.good{font-weight:800;color:var(--teal-bright);font-size:.8rem}
.compare-div{height:1px;background:rgba(255,255,255,.1);grid-column:1/-1}
.compare-note{background:rgba(0,168,156,.16);border:1px solid rgba(0,168,156,.32);padding:14px 16px;margin-top:18px;display:flex;gap:10px;border-radius:var(--radius)}
.compare-note-text{font-size:.8rem;color:rgba(255,255,255,.78);line-height:1.6}
.compare-note-text strong{color:var(--teal-bright)}

/* ── SECTION LAYOUT ── */
.section{padding:80px 0}
.section-light{background:var(--mist)}
.section-dark,.section-navy{background:var(--anchor-navy);color:#fff}
.section-dark .section-title,.section-navy .section-title{color:#fff}
.section-dark .section-sub,.section-navy .section-sub{color:rgba(255,255,255,.72)}
.section-teal{background:var(--teal-deep);color:#fff}
.section-white{background:#fff}
.section-header{margin-bottom:60px}
.section-header.center,.section-header[style*="text-align:center"]{text-align:center}
.section-header.center .section-sub,.section-header[style*="text-align:center"] .section-sub{margin:0 auto}
.section-header-split{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:64px;gap:32px;flex-wrap:wrap}
.section-header-split>div:first-child{flex:1;min-width:300px}
.section-header-split .section-sub{max-width:380px;margin-bottom:6px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.grid-2-split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}

/* ── FORMS ── */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-group label{font-size:.7rem;font-weight:700;color:var(--anchor-navy);letter-spacing:.13em;text-transform:uppercase}
.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--tideline);border-radius:var(--radius);padding:12px 14px;font-size:.92rem;font-family:'Inter',sans-serif;color:var(--ink-body);background:#fff;transition:border-color .2s;outline:none;resize:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--tide-teal);box-shadow:0 0 0 4px rgba(0,168,156,.10)}
.form-submit{width:100%;padding:16px;background:var(--tide-teal);color:#fff;border:none;border-radius:var(--radius);font-family:'Inter',sans-serif;font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;transition:background .2s,transform .2s}
.form-submit:hover{background:var(--teal-deep);transform:translateY(-1px)}
.form-note{font-size:.78rem;color:var(--slate-500);text-align:center;margin-top:12px}

/* ── ICON SYSTEM ── */
.icon{width:24px;height:24px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.icon-sm{width:18px;height:18px}
.icon-lg{width:32px;height:32px}
.icon-box{width:52px;height:52px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--radius)}
.icon-box .icon{width:24px;height:24px}
.icon-box-sm{width:42px;height:42px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--radius)}
.icon-box-sm .icon{width:20px;height:20px}

/* ── STICKY CTA BAR ── */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;background:rgba(255,255,255,.97);backdrop-filter:blur(18px);border-top:1px solid var(--tideline);padding:14px 0;z-index:190;transform:translateY(100%);transition:transform .3s ease;box-shadow:0 -4px 24px rgba(15,22,32,.06)}
.sticky-cta.visible{transform:translateY(0)}
.sticky-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.sticky-cta-text{font-size:.92rem;font-weight:700;color:var(--anchor-navy)}
.sticky-cta-text span{color:var(--slate-600);font-weight:400;display:none}
@media(min-width:768px){.sticky-cta-text span{display:inline}}

/* ── HOW IT WORKS (numbered) ── */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;position:relative}
.step{position:relative;padding-top:24px}
.step-number{font-size:3rem;font-weight:900;color:var(--tide-teal);opacity:.18;line-height:1;margin-bottom:14px;width:auto;height:auto;background:none;display:block;text-align:left;letter-spacing:-.04em}
.step-name{font-size:1.15rem;font-weight:800;color:var(--anchor-navy);margin-bottom:10px;letter-spacing:-.01em}
.step-desc{font-size:.98rem;color:var(--slate-600);line-height:1.7;margin:0}
.step::after{content:'';display:block;width:48px;height:2px;background:var(--tide-teal);margin-top:24px}
.steps-connector{display:none}
.section-dark .step-number,.section-navy .step-number{color:#fff;opacity:.12;font-size:4rem}
.section-dark .step-name,.section-navy .step-name{color:#fff}
.section-dark .step-desc,.section-navy .step-desc{color:rgba(255,255,255,.72)}

/* ── TESTIMONIAL ── */
.testimonial-card{background:var(--mist);padding:36px 32px;position:relative;border-top:3px solid var(--tide-teal);border-radius:var(--radius)}
.testimonial-text{font-size:1rem;color:var(--ink-body);line-height:1.72;font-style:italic;margin-bottom:24px}
.testimonial-name{font-size:.88rem;font-weight:800;color:var(--anchor-navy);letter-spacing:-.01em}
.testimonial-role{font-size:.76rem;color:var(--slate-500);margin-top:2px}

/* ── REUSABLE PROCESS / CTA PANELS (used across home + inner pages) ── */
.process-bento{display:grid;grid-template-columns:repeat(3,1fr);gap:64px}
.process-bento .step{position:relative;padding-top:8px}
.process-bento .step::after{content:'';display:block;width:48px;height:2px;background:var(--tide-teal);margin-top:28px}
.process-bento .step-num{font-size:5rem;font-weight:900;color:rgba(255,255,255,.10);line-height:1;letter-spacing:-.04em;margin-bottom:8px}
.process-bento .step-name{font-size:1.4rem;font-weight:800;color:#fff;margin-bottom:14px;letter-spacing:-.015em}
.process-bento .step-desc{font-size:.95rem;color:rgba(255,255,255,.72);line-height:1.7}
@media(max-width:768px){.process-bento{grid-template-columns:1fr;gap:42px}}

.mw-cta-panel{background:var(--anchor-navy);padding:64px 56px;border-radius:var(--radius);position:relative;overflow:hidden}
.mw-cta-panel::before{content:'';position:absolute;right:-80px;bottom:-80px;width:340px;height:340px;background:radial-gradient(circle,rgba(0,168,156,.18) 0%,transparent 70%);pointer-events:none}
.mw-cta-panel-inner{position:relative;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center}
.mw-cta-panel h2{font-size:clamp(1.6rem,2.6vw,2.2rem);font-weight:800;color:#fff;line-height:1.15;letter-spacing:-.02em;margin-bottom:14px}
.mw-cta-panel p{color:rgba(255,255,255,.78);line-height:1.7;font-size:1rem;max-width:560px}
@media(max-width:1024px){.mw-cta-panel-inner{grid-template-columns:1fr;gap:28px}.mw-cta-panel{padding:48px 36px}}

.cta-final-panel{background:var(--anchor-navy);padding:96px 64px;text-align:center;border-radius:var(--radius);position:relative;overflow:hidden}
.cta-final-panel::before{content:'';position:absolute;left:50%;top:-220px;transform:translateX(-50%);width:780px;height:520px;background:radial-gradient(ellipse,rgba(0,168,156,.16) 0%,transparent 65%);pointer-events:none}
.cta-final-panel-inner{position:relative;max-width:720px;margin:0 auto}
.cta-final-panel h2{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;color:#fff;line-height:1.12;letter-spacing:-.025em;margin-bottom:18px}
.cta-final-panel h2 em{font-style:normal;color:var(--tide-teal)}
.cta-final-panel p{font-size:1.05rem;color:rgba(255,255,255,.78);line-height:1.7;margin-bottom:32px;max-width:560px;margin-left:auto;margin-right:auto}
@media(max-width:768px){.cta-final-panel{padding:64px 28px}}

/* Berry highlight: single "moment that matters most" card per page (DESIGN.md scarcity rule) */
.card-berry{position:relative;border-color:var(--berry)!important}
.card-berry::before{content:'';position:absolute;top:0;left:0;bottom:0;width:4px;background:var(--berry)}
.card-berry .card-name{color:var(--berry)}
.card-berry-tag{display:inline-flex;align-items:center;gap:8px;font-size:.62rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--berry);margin-bottom:14px}
.card-berry-tag::before{content:'';width:6px;height:6px;background:var(--berry);border-radius:50%}

/* Inline prose block for service intro sections */
.prose-block{max-width:820px;color:var(--slate-600);line-height:1.8;font-size:1.05rem}
.prose-block p+p{margin-top:24px}

/* ── HERO STATS ── */
.hero-stat-n{font-size:2rem;font-weight:900;color:var(--anchor-navy);line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.hero-stat-l{font-size:.66rem;color:var(--slate-500);margin-top:6px;text-transform:uppercase;letter-spacing:.13em;font-weight:700}

/* ── ANIMATIONS ── */
/* Eyebrow accent line draw-in: each .eyebrow / .tag grows its 32px teal bar from 0 on first paint */
@keyframes eyebrow-draw{from{width:0}to{width:32px}}
.eyebrow::before,.tag::before{animation:eyebrow-draw .55s cubic-bezier(.25,.8,.3,1) both}
/* Stagger when an eyebrow sits inside a .fade element revealed by scroll */
.fade.visible .eyebrow::before,.fade.visible .tag::before{animation:eyebrow-draw .55s cubic-bezier(.25,.8,.3,1) both;animation-delay:.08s}

/* Berry dot pulse on Berry tags ("Funding alert", "Most requested" etc.) */
@keyframes berry-pulse{
  0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(156,47,77,.36)}
  50%{transform:scale(1.18);box-shadow:0 0 0 6px rgba(156,47,77,0)}
}
.card-berry-tag::before,.hero-berry-badge span:first-child{animation:berry-pulse 2.2s cubic-bezier(.4,0,.4,1) infinite}

/* Hero stat count-up: numbers animate from 0 → target via JS, but the appear motion is CSS */
.hero-stat-n[data-count-target]{opacity:0;transform:translateY(6px);transition:opacity .35s ease,transform .45s ease}
.hero-stat-n[data-count-target].counted{opacity:1;transform:none}

/* ── Image hover zoom (editorial photo treatment) ── */
.img-zoom{display:block;width:100%;height:100%;overflow:hidden;border-radius:inherit}
.img-zoom img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .9s cubic-bezier(.25,.8,.3,1)}
.img-zoom:hover img,.events-grid img,.person-card .person-photo img{transition:transform .9s cubic-bezier(.25,.8,.3,1)}
.events-grid:hover img:hover,.person-card:hover .person-photo img,.hero-video-frame:hover iframe{transform:scale(1.04)}

/* ── Number scale-in (big numerals settle from slight scale) ── */
@keyframes num-settle{0%{opacity:0;transform:scale(.92) translateY(8px)}100%{opacity:1;transform:scale(1) translateY(0)}}
.process-bento .step .step-num,.fade.visible .process-bento .step .step-num{animation:num-settle .7s cubic-bezier(.2,.8,.3,1) both}
.fade.visible .process-bento .step:nth-child(2) .step-num{animation-delay:.12s}
.fade.visible .process-bento .step:nth-child(3) .step-num{animation-delay:.24s}

/* ── Final-CTA radial glow drift ── */
@keyframes glow-drift{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(20px)}
}
.cta-final-panel::before,.final-cta::before,.mw-cta-panel::before,.mw-panel::before{animation:glow-drift 14s ease-in-out infinite}

/* ── Polished button hover (universal across .btn) ── */
.btn{transition:background .25s ease,border-color .25s ease,color .25s ease,transform .25s ease,box-shadow .35s cubic-bezier(.25,.8,.3,1)}
.btn-primary:hover,.btn-teal:hover,.btn-blue:hover{transform:translateY(-2px)}
.btn-outline-navy:hover,.btn-outline-teal:hover{transform:translateY(-1px)}
.btn-teal:hover{box-shadow:0 12px 28px rgba(0,168,156,.32)}
.btn-primary:hover{box-shadow:0 12px 28px rgba(22,70,134,.28)}

/* ── Hero cascade (home page only, applied via .home-cascade class on hero block) ── */
@keyframes cascade-up{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.home-cascade > *{opacity:0;animation:cascade-up .7s cubic-bezier(.165,.84,.44,1) both}
.home-cascade > *:nth-child(1){animation-delay:.05s}
.home-cascade > *:nth-child(2){animation-delay:.20s}
.home-cascade > *:nth-child(3){animation-delay:.35s}
.home-cascade > *:nth-child(4){animation-delay:.50s}
.home-cascade > *:nth-child(5){animation-delay:.65s}

/* ── Disciplines bento subtle lift on initial reveal ── */
.disc-card{transition:background .3s ease,border-color .3s ease,transform .3s cubic-bezier(.25,.8,.3,1),box-shadow .35s cubic-bezier(.25,.8,.3,1)}
.disc-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(15,22,32,.08)}

/* Honour reduced-motion preference */
@media(prefers-reduced-motion:reduce){
  .eyebrow::before,.tag::before,.fade.visible .eyebrow::before,.fade.visible .tag::before{animation:none;width:32px}
  .card-berry-tag::before,.hero-berry-badge span:first-child{animation:none}
  .hero-stat-n[data-count-target]{opacity:1;transform:none;transition:none}
  .img-zoom img,.events-grid img,.person-card .person-photo img,.hero-video-frame iframe{transition:none}
  .events-grid:hover img:hover,.person-card:hover .person-photo img,.hero-video-frame:hover iframe{transform:none}
  .process-bento .step .step-num,.fade.visible .process-bento .step .step-num{animation:none;opacity:1;transform:none}
  .cta-final-panel::before,.final-cta::before,.mw-cta-panel::before,.mw-panel::before{animation:none}
  .btn,.disc-card{transition:none}
  .btn-primary:hover,.btn-teal:hover,.btn-blue:hover,.btn-outline-navy:hover,.btn-outline-teal:hover,.disc-card:hover{transform:none;box-shadow:none}
  .home-cascade > *{opacity:1;animation:none}
}

/* ── FADE IN ANIMATION ── */
.fade{opacity:0;transform:translateY(22px);transition:opacity .65s cubic-bezier(.165,.84,.44,1),transform .65s cubic-bezier(.165,.84,.44,1)}
.fade.visible{opacity:1;transform:translateY(0)}
.fade-stagger-1{transition-delay:0ms}
.fade-stagger-2{transition-delay:90ms}
.fade-stagger-3{transition-delay:180ms}
.fade-stagger-4{transition-delay:270ms}
.fade-stagger-5{transition-delay:360ms}
.fade-stagger-6{transition-delay:450ms}
.fade-stagger-7{transition-delay:540ms}
.fade-stagger-8{transition-delay:630ms}
.fade-stagger-9{transition-delay:720ms}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .nav-links>li>a{font-size:.66rem;padding:24px 10px}
  .container{padding:0 24px}
}
@media(max-width:1024px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .section{padding:64px 0}
  .page-hero{padding:24px 0 28px}
  .page-hero + .section{padding-top:48px}
  .page-hero + .trust + .section{padding-top:60px}
}
@media(max-width:900px){
  .nav-links,.nav-right{display:none}
  .nav-burger{display:block}
  .mobile-menu.open{display:flex}
  .steps-grid{grid-template-columns:1fr;gap:36px;max-width:520px;margin:0 auto}
}
@media(max-width:768px){
  .grid-3,.grid-2,.grid-2-split,.grid-4{grid-template-columns:1fr;gap:18px}
  .footer-grid{grid-template-columns:1fr;gap:48px}
  .footer-bottom{flex-direction:column;text-align:center}
  .form-row{grid-template-columns:1fr}
  .section-header-split{flex-direction:column;align-items:flex-start}
  .section{padding:70px 0}
  .page-hero{padding:100px 0 50px}
  .container{padding:0 20px}
  .compare-row{grid-template-columns:1fr 60px 60px}
}

/* ── PHOTO PLACEHOLDERS ── */
.photo-placeholder{width:100%;aspect-ratio:16/7;background:var(--mist);border:1px dashed var(--tideline);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--slate-500);border-radius:var(--radius)}
.photo-placeholder svg{width:36px;height:36px;opacity:.35}
.photo-placeholder span{font-size:.7rem;font-weight:700;opacity:.7;letter-spacing:.13em;text-transform:uppercase}
.photo-placeholder-sm{width:100%;aspect-ratio:3/2;background:var(--mist);border:1px dashed var(--tideline);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--slate-500);border-radius:var(--radius)}
.photo-placeholder-sm svg{width:26px;height:26px;opacity:.32}
.photo-placeholder-sm span{font-size:.68rem;font-weight:700;opacity:.6;text-transform:uppercase;letter-spacing:.12em}

/* ── EVENT TILES ── */
.events-grid{display:flex;flex-direction:column;gap:18px;max-width:920px;margin:0 auto}
.event-tile{border:1px solid var(--tideline);overflow:hidden;background:#fff;transition:box-shadow .25s,border-color .25s;border-radius:var(--radius)}
.event-tile:hover{box-shadow:var(--shadow);border-color:var(--tide-teal)}
.event-tile[open]{border-color:var(--tide-teal);box-shadow:0 8px 40px rgba(0,168,156,.12)}
.event-summary{display:flex;align-items:center;gap:22px;padding:24px 28px;cursor:pointer;list-style:none;user-select:none}
.event-summary::-webkit-details-marker{display:none}
.event-date-badge{flex-shrink:0;width:64px;height:64px;background:var(--anchor-navy);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;line-height:1;border-radius:var(--radius)}
.event-date-badge .day{font-size:1.5rem;font-weight:900}
.event-date-badge .mon{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.13em;opacity:.75;margin-top:3px}
.event-summary-body{flex:1;min-width:0}
.event-category{display:inline-block;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.16em;color:var(--tide-teal);background:rgba(0,168,156,.10);padding:4px 12px;margin-bottom:8px;border-radius:99px}
.event-summary-body h3{font-size:1.08rem;font-weight:800;color:var(--anchor-navy);line-height:1.3;margin:0 0 4px;letter-spacing:-.01em}
.event-meta{font-size:.82rem;color:var(--slate-500)}
.event-chevron{flex-shrink:0;width:34px;height:34px;background:var(--mist);display:flex;align-items:center;justify-content:center;transition:transform .3s,background .2s;border-radius:var(--radius)}
.event-tile[open] .event-chevron{transform:rotate(180deg);background:rgba(0,168,156,.12)}
.event-chevron svg{width:14px;height:14px;stroke:var(--anchor-navy)}
.event-detail{padding:0 28px 30px;border-top:1px solid var(--tideline);animation:eSlide .25s ease}
@keyframes eSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.event-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:22px}
.event-agenda{display:flex;flex-direction:column;gap:11px}
.agenda-item{display:flex;gap:14px;align-items:flex-start}
.agenda-time{font-size:.7rem;font-weight:800;color:var(--tide-teal);width:60px;flex-shrink:0;padding-top:2px;letter-spacing:.1em;text-transform:uppercase}
.agenda-title{font-size:.86rem;color:var(--ink-body);line-height:1.55}
.event-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px;padding-top:22px;border-top:1px solid var(--tideline)}
.event-tile-tbc .event-date-badge{background:var(--slate-500)}
.event-category-tbc{color:var(--slate-500)!important;background:var(--mist)!important}
.people-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.person-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px}
.person-photo{width:100%;aspect-ratio:1/1;background:var(--mist);border:1px dashed var(--tideline);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--slate-500);border-radius:var(--radius)}
.person-photo svg{width:26px;height:26px;opacity:.32}
.person-photo span{font-size:.68rem;font-weight:700;opacity:.55;text-transform:uppercase;letter-spacing:.12em}
.person-name{font-size:.88rem;font-weight:800;color:var(--anchor-navy)}
.person-role{font-size:.74rem;color:var(--slate-500)}
@media(max-width:640px){.event-detail-grid{grid-template-columns:1fr}.people-grid{grid-template-columns:repeat(2,1fr)}.event-summary{flex-wrap:wrap}}

/* ── REDUCED MOTION ── */
@media(prefers-reduced-motion:reduce){
  .fade{opacity:1;transform:none;transition:none}
  .card,.btn,.svc-pill,.partner-pill,.social-link,.nav-dropdown,.event-chevron,.event-tile{transition:none}
  .card:hover,.svc-pill:hover,.btn:hover{transform:none}
  html{scroll-behavior:auto}
}

/* ── FORM VALIDATION ── */
.form-group input:invalid:not(:placeholder-shown),.form-group textarea:invalid:not(:placeholder-shown){border-color:#dc2626}
.form-error{font-size:.74rem;color:#dc2626;margin-top:4px;display:none;font-weight:600}
.form-group.has-error .form-error{display:block}
.form-group.has-error input,.form-group.has-error textarea,.form-group.has-error select{border-color:#dc2626}
.form-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}
.form-submit.loading{position:relative;color:transparent}
.form-submit.loading::after{content:'';position:absolute;width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;top:50%;left:50%;margin:-10px 0 0 -10px}
@keyframes spin{to{transform:rotate(360deg)}}
.form-success{background:rgba(0,168,156,.08);border:1.5px solid var(--tide-teal);padding:26px;text-align:center;display:none;border-radius:var(--radius)}
.form-success.show{display:block}
.form-success-icon{font-size:2rem;margin-bottom:8px}
.form-success-title{font-size:1.05rem;font-weight:800;color:var(--anchor-navy);margin-bottom:6px}
.form-success-text{font-size:.88rem;color:var(--slate-600)}

/* ── Sitewide Event Banner ── */
.site-banner{background:linear-gradient(90deg,rgba(156,47,77,.08) 0%,rgba(156,47,77,.04) 50%,rgba(0,168,156,.06) 100%);border-bottom:1px solid var(--tideline);padding:11px 0;font-size:.9rem;font-weight:600;color:var(--ink-body);position:relative;z-index:50}
.site-banner-inner{display:flex;align-items:center;gap:14px;justify-content:center;max-width:1180px;margin:0 auto;padding:0 24px}
.site-banner-dot{width:8px;height:8px;border-radius:50%;background:var(--berry);animation:bannerPulse 2.2s ease-in-out infinite;flex-shrink:0}
.site-banner-msg{flex:1;text-align:center;line-height:1.5}
.site-banner-msg strong{color:var(--berry);font-weight:800}
.site-banner-cta{color:var(--berry);text-decoration:underline;text-underline-offset:3px;font-weight:800;white-space:nowrap}
.site-banner-cta:hover{text-decoration:none;color:#7a253c}
.site-banner-close{background:none;border:none;font-size:1.4rem;color:var(--slate-500);cursor:pointer;padding:0 6px;line-height:1;flex-shrink:0}
.site-banner-close:hover{color:var(--ink-body)}
@keyframes bannerPulse{0%,100%{opacity:1}50%{opacity:.3}}
@media(max-width:760px){.site-banner-msg{text-align:left;font-size:.82rem}.site-banner-inner{gap:10px;padding:0 16px}}

/* ── LinkedIn Nav Button ── */
.nav-linkedin{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius);color:var(--anchor-navy);transition:background .2s,color .2s,border-color .2s;margin-right:6px;border:1px solid var(--tideline);background:#fff;flex-shrink:0}
.nav-linkedin:hover{background:var(--anchor-navy);color:#fff;border-color:var(--anchor-navy)}

/* ── Berry 5% Accents (sitewide subtle touches) ── */
.tag-berry-pill{display:inline-flex;align-items:center;gap:8px;font-size:.62rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--berry);background:rgba(156,47,77,.08);border:1px solid rgba(156,47,77,.22);border-radius:99px;padding:6px 14px}
.tag-berry-pill::before{content:'';width:6px;height:6px;background:var(--berry);border-radius:50%}
.eyebrow-berry{color:var(--berry)}
.eyebrow-berry::before{background:var(--berry)}
.text-berry{color:var(--berry)}
.divider-berry{height:2px;background:linear-gradient(90deg,var(--berry) 0%,transparent 100%);margin:32px 0;border:0;max-width:120px}

/* ── Form fixes ── */
/* Placeholder colour on dark form panels (inputs that explicitly set color:#fff) */
input[style*="color:#fff"]::placeholder,
textarea[style*="color:#fff"]::placeholder,
input[style*="color:#fff"]::-webkit-input-placeholder,
textarea[style*="color:#fff"]::-webkit-input-placeholder{
  color:rgba(255,255,255,.6);
  opacity:1;
}
/* Select first-option fallback on dark panels */
select[style*="color:#fff"]{
  color:rgba(255,255,255,.6);
}
select[style*="color:#fff"]:focus,
select[style*="color:#fff"].has-value{
  color:#fff;
}

/* ── Berry on dark backgrounds: switch to soft pink for legibility ── */
.cta-final-panel .tag-berry-pill,
.section-dark .tag-berry-pill,
.section-navy .tag-berry-pill,
[style*="background:var(--anchor-navy)"] .tag-berry-pill,
[style*="background:linear-gradient"][style*="anchor-navy"] .tag-berry-pill{
  color:#ffc4d4;
  background:rgba(255,196,213,.10);
  border-color:rgba(255,196,213,.30);
}
.cta-final-panel .tag-berry-pill::before,
.section-dark .tag-berry-pill::before,
.section-navy .tag-berry-pill::before,
[style*="background:var(--anchor-navy)"] .tag-berry-pill::before,
[style*="background:linear-gradient"][style*="anchor-navy"] .tag-berry-pill::before{
  background:#ffc4d4;
}
/* eyebrow-berry inside dark sections too */
.cta-final-panel .eyebrow-berry,
.section-dark .eyebrow-berry,
.section-navy .eyebrow-berry{
  color:#ffc4d4;
}
.cta-final-panel .eyebrow-berry::before,
.section-dark .eyebrow-berry::before,
.section-navy .eyebrow-berry::before{
  background:#ffc4d4;
}
