/* ==============================
   Design Tokens
============================== */
:root{
  --bg-warm:#FDFCFB;
  --bg-cream:#F5EFE6;
  --ink-navy:#1a365d;
  --text:#334155;
  --slate:#475569;
  --border:#e2e8f0;

  --cta-top:#0D9488;
  --cta-bot:#0A7A71;
  --cta-text:#fff;
  --cta-shadow:rgba(13,148,136,.25);

  --footer-blue:#002B5B;

  --font-body:"Inter", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-head:"Lora", Georgia, serif;
}

/* ==============================
   Base
============================== */
html.smooth{scroll-behavior:smooth}
html,body{max-width:100%;overflow-x:hidden}   /* stop horizontal scroll everywhere */

body{
  margin:0;
  font-family:var(--font-body);
  background:var(--bg-warm);
  color:var(--text);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

h1,h2,h3{font-family:var(--font-head);color:var(--ink-navy);font-weight:600;line-height:1.2;letter-spacing:-.5px}
h1{font-size:clamp(2.2rem,3.2vw+1rem,3rem)}
h2{font-size:clamp(1.6rem,1.2vw+1.2rem,2.25rem)}
h3{font-size:1.25rem}

a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

/* ==============================
   Layout Helpers
============================== */
.container{max-width:1100px;margin:0 auto;padding:70px 20px}
.narrow{max-width:65ch;margin-inline:auto}
.page-layout{display:block}

.comparison-grid{display:grid;gap:2rem}
@media (min-width:768px){.comparison-grid{grid-template-columns:1fr 1fr}}

/* ==============================
   Buttons (canonical)
============================== */
.btn{
  /* was inline-block */
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.4rem;

  padding:10px 22px;
  border-radius:10px;
  font-weight:600;
  border:1px solid transparent;
  cursor:pointer;
  text-decoration:none; /* ensure <a> has no underline */
  transition:transform .08s ease, box-shadow .2s ease, background-color .2s ease, border-color .2s ease;
  box-shadow:0 3px 5px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.08);
}
.btn:focus-visible{outline:2px solid var(--cta-top);outline-offset:2px}

.btn-primary{
  color:var(--cta-text);
  background:linear-gradient(180deg,var(--cta-top) 0%,var(--cta-bot) 100%);
  border-color:var(--cta-top);
  box-shadow:0 6px 12px var(--cta-shadow);
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 16px rgba(0,0,0,.10)}
.btn-primary:active{transform:translateY(0);background:linear-gradient(180deg,#0B7E75 0%,#096B62 100%);box-shadow:0 4px 10px rgba(0,0,0,.08)}

.btn-secondary{background:var(--bg-cream);color:var(--ink-navy);border:1px solid #E3DCD1;box-shadow:none}
.btn-secondary:hover{background:#EBE4DA;border-color:#EBE4DA}

.btn-outline{background:transparent;color:var(--ink-navy);border:1px solid #E3DCD1;box-shadow:none}
.btn-outline:hover{background:#efe7db}

/* REMOVE the entire duplicate block you added earlier:
   a.btn, button.btn, input[type="submit"].btn { … }
   a.btn:link, a.btn:visited { … }
   .btn-primary { background: linear-gradient(180deg,#10b981,#0d9488); … }
   .btn-primary:hover, .btn-primary:focus { … }
   .btn-outline { … teal border … }
*/

.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}
@media (max-width:639px){.hero-ctas{flex-direction:column}}


/* ==============================
   CTA panel & footer (clean)
   — place AFTER global .btn/* rules
============================== */

/* CTA Panel (dark card above footer) */
.cta-panel{
  background: var(--footer-blue);
  color: #fff;
  text-align: center;
  border-radius: 16px;
  padding: 48px 24px;
}
.cta-panel h2{ color:#fff; margin:0 0 .5rem }

/* Row with the two CTAs */
.lead-cta-row{
  margin-top: 18px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

/* Buttons inside the dark CTA panel */
.cta-panel .btn{ box-shadow: none; } /* calmer on dark bg */
.cta-panel .btn-primary{
  /* primary stays your green gradient with white text from .btn-primary */
  box-shadow: 0 8px 18px rgba(0,0,0,.18);
}
.cta-panel .btn-outline{
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255,255,255,.7);
  padding: 8px 24px;
  border-radius: 8px;
  font-weight: 600;
  transition: .2s;
}
.cta-panel .btn-outline:hover{
  background: #fff;
  color: var(--footer-blue);
}
.cta-panel .btn:focus-visible{
  outline-color: #fff; /* higher contrast on dark */
}

/* Footer */
.footer{
  background: var(--footer-blue);
  color: #cdd5e0;
}
.footer a{ color:#cdd5e0; text-decoration: none; }
.footer a:hover{ color:#fff; }

.footer-top{ padding:60px 20px 30px; }
.footer-grid{
  display:grid; gap:32px; grid-template-columns:1fr; align-items:start;
}
@media (min-width:768px){ .footer-grid{ grid-template-columns:1.6fr 1fr 1fr 1fr; } }
@media (min-width:1100px){ .footer-grid{ grid-template-columns:1.8fr repeat(4,1fr); } }

.footer-disclosure-box{
  background: var(--bg-cream);
  padding: 1.25rem;
  margin: 0 auto 1.5rem;
  border-radius: 10px;
  text-align: center;
  max-width: 1000px;
}
.footer-disclosure-text{
  font-size: .9rem;
  color: var(--ink-navy);
  line-height: 1.5;
  margin: 0 auto;
  max-width: 820px;
}

.footer-logo{ display:block; margin:0 auto .75rem; height:32px; width:auto; }
.footer-brand .footer-logo{ margin:0 0 12px 0; }

.footer-grid h3{
  font-family: var(--font-head);
  color:#fff; font-size:1rem; letter-spacing:.01em;
  margin:0 0 10px;
}

.footer-nav ul,
.footer-legal ul{ list-style:none; padding:0; margin:0; }
.footer-nav li+li,
.footer-legal li+li{ margin-top:6px; }

.footer-ctas{ margin-top:14px; display:flex; flex-wrap:wrap; gap:10px; }

/* White-outline button ONLY on dark footer (scoped) */
.footer .btn-outline{
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255,255,255,.7);
  padding: 8px 24px;
  border-radius: 8px;
  font-weight: 600;
  transition: .2s;
}
.footer .btn-outline:hover{
  background: #fff;
  color: var(--footer-blue);
}

.footer-bottom{
  background: rgba(0,0,0,.08);
  color: rgba(255,255,255,.8);
  text-align: center;
  font-size: 13.33px; /* 10pt minimum for compliance */
  padding: 14px 20px;
}

/* ==============================
   Header
============================== */
.header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(10px);
  background:rgba(253,252,251,.9);
  border-bottom:1px solid var(--border);
}
.header-inner{
  max-width:1100px;margin:0 auto;padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;
}
.brand img{max-width:170px;height:auto}

.badge{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--border);padding:6px 12px;border-radius:999px;
  font-size:12px;font-weight:500;color:var(--slate);background:#fff;
}

/* ==============================
   Hero
============================== */
.hero{border-bottom:1px solid #f1f5f9;min-height:60vh}
.hero-inner{display:grid;gap:24px;align-items:start}
@media (min-width:992px){.hero-inner{grid-template-columns:1fr 1fr}}

.hero-meta{margin-top:16px;font-size:11px;color:var(--slate)}
.hero-trust{margin-top:22px;display:flex;gap:24px;color:var(--slate);font-size:14px;flex-wrap:wrap}
.hero-trust strong{font-weight:900}

/* chart box */
.tax-chart{background:var(--bg-warm);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 4px 6px -1px rgba(0,0,0,.05),0 2px 4px -1px rgba(0,0,0,.03);margin:1rem 0}
.tax-chart__head{text-align:center;margin-bottom:12px}
.eyebrow{display:block;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:#6b7280;margin-bottom:4px}
.tax-chart__title{margin:0;font-family:var(--font-head);color:var(--ink-navy);font-size:1.5rem;line-height:1.2}
.tax-chart__meta{color:#4a5568;font-size:.9rem;margin-top:4px}
.tax-chart__img{width:100%;height:auto;border-radius:8px;margin-top:1rem}
.tax-chart__caption{margin-top:1rem;color:#4a5568;font-size:.875rem;text-align:center;line-height:1.4}

/* ==============================
   Main content
============================== */
.section{border-bottom:1px solid #f1f5f9;scroll-margin-top:100px}
.section-breaker{background:var(--bg-cream)}
.split{display:grid;gap:24px;align-items:start}
@media (min-width:1024px){.split{grid-template-columns:1fr 1fr}}

.list-default{color:var(--slate);padding-left:18px;margin:10px 0}

/* ==============================
   Cards & grids
============================== */
.card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:24px;transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px rgba(0,0,0,.07),0 4px 6px -2px rgba(0,0,0,.04)}
.services{display:grid;gap:24px}
@media (min-width:768px){.services{grid-template-columns:1fr 1fr}}
@media (min-width:1200px){.services{grid-template-columns:repeat(3,1fr)}}

.kpi-cards{display:grid;gap:24px;margin-top:16px}

/* ==============================
   Mobile nav (off-canvas) & utilities
============================== */
.nav-list{display:flex;gap:20px;list-style:none;margin:0;padding:0}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}

.mobile-nav-toggle{display:block;position:relative;z-index:9999;background:transparent;border:0;padding:.5em;cursor:pointer}
.mobile-nav-toggle .icon-close{display:none}
.nav-open .mobile-nav-toggle .icon-close{display:block}
.nav-open .mobile-nav-toggle .icon-hamburger{display:none}

/* Drawer: completely off-screen until opened */
@media (max-width:1024px){
  .primary-nav{
    position:fixed; top:0; bottom:0; right:-100vw; left:auto;
    width:min(84vw,360px);
    padding:4rem 1.25rem 2rem; /* Reduced top padding to show more items */
    background:var(--bg-warm);
    box-shadow:-12px 0 24px rgba(0,0,0,.08);
    overflow-y:auto;
    transition:right .25s ease;
    z-index:1000;
    /* Add visual scroll indicator */
    background-image:linear-gradient(to bottom,var(--bg-warm) 0%,var(--bg-warm) 85%,transparent 100%);
    background-attachment:local;
  }
  body.nav-open{overflow:hidden}                 /* lock background when open */
  body.nav-open .primary-nav{ right:0; }

  .primary-nav .nav-list{
    flex-direction:column;
    gap:1rem; /* Reduced from 2rem to show more items */
    font-size:1.125rem;
    padding-bottom:1rem; /* Extra space at bottom for scrolling */
  }
  
  /* Show scrollbar styling hint */
  .primary-nav::-webkit-scrollbar{
    width:6px;
  }
  .primary-nav::-webkit-scrollbar-track{
    background:transparent;
  }
  .primary-nav::-webkit-scrollbar-thumb{
    background:rgba(0,0,0,.2);
    border-radius:3px;
  }
}

.lang-switch-desktop{display:none}
.lang-switch-mobile{display:block}

@media (min-width:768px){
  .mobile-nav-toggle{display:none}
  .lang-switch-desktop{display:block;margin-left:1rem}
  .lang-switch-mobile{display:none}
  .primary-nav{position:static;right:auto;left:auto;top:auto;bottom:auto;box-shadow:none;overflow:visible;padding:0}
  .primary-nav .nav-list{flex-direction:row;gap:20px;font-size:inherit}
}

/* Skip link, reveal, back to top */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:12px;top:12px;width:auto;height:auto;padding:8px 10px;background:var(--ink-navy);color:#fff;border-radius:8px;z-index:1000}

.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}

.backtotop{
  position:fixed;bottom:18px;right:18px;width:40px;height:40px;border-radius:50%;
  background:var(--cta-top);color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 15px -3px rgba(0,0,0,.2);text-decoration:none;
}
.backtotop:hover{transform:translateY(-2px)}

/* Fonts: Using Google Fonts (Inter & Lora) - local @font-face removed to fix 404 */

/* ==============================
   Services (re-usable)
============================== */
.services-heading{font-family:Lora,Georgia,serif;color:#1a365d;font-size:1.5rem;margin:0 0 1.5rem;font-weight:600}
.services-grid{display:grid;gap:20px;grid-template-columns:1fr;margin-top:12px;margin-bottom:2.5rem}
@media (min-width:640px){.services-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (min-width:1024px){.services-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}

.service-card{background:#fff;border:1px solid #ece7df;border-radius:16px;padding:20px;box-shadow:0 2px 10px rgba(0,0,0,.04);display:flex;flex-direction:column;justify-content:space-between}
.service-card h3{font-family:Lora,Georgia,serif;color:#1a365d;font-size:1.15rem;margin:0 0 8px}
.service-card p{margin:0 0 10px;line-height:1.5}
.service-card .btn{margin-top:6px;text-decoration:none !important}
.service-card .btn-primary{color:#fff !important;background:linear-gradient(180deg,#0D9488 0%,#0A7A71 100%) !important;text-decoration:none !important}
.service-card:hover{box-shadow:0 8px 22px rgba(0,0,0,.08);transform:translateY(-2px)}
.card.accent{background:#F5EFE6;border:1px solid #E8E1D6;border-radius:16px;padding:20px}
.card.accent .cta-bar{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}

.wrap-crumbs .breadcrumb ol{display:flex;gap:8px;flex-wrap:wrap}
.tags a{display:inline-block;padding:4px 10px;border:1px solid #e5e2dc;border-radius:999px;margin:0 6px 6px 0;font-size:.9rem}

/* ==============================
   Explainer Page Styles (merged from explainer.css)
============================== */

/* Layout helpers */
.wrap {
    max-width: 760px; /* ~65ch */
    margin: 0 auto;
    padding: 24px 20px;
}

/* Single-column stack everywhere */
.grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}

/* remove the desktop 2-col behavior */
@media (min-width:1024px){
    .grid { grid-template-columns: 1fr; }
}

/* Typography helpers */
.muted { opacity: .85; }
.small { font-size: .9rem; }

/* Breadcrumbs */
.breadcrumb ol {
    list-style: none; display: flex; gap: .5rem; padding: 0; margin: 6px 0 0;
}
.breadcrumb li::after { content: "›"; margin: 0 .5rem; }
.breadcrumb li:last-child::after { content: ""; }
.breadcrumb a { text-decoration: none; color: #1a365d; }
.breadcrumb [aria-current="page"] { font-weight: 600; color: #555; }

/* Page head */
.page-head .lede { opacity: .9; }
.meta { display: flex; gap: 16px; flex-wrap: wrap; font-size: .95rem; }

/* Cards / accents */
.card { border: 1px solid #e5e7eb; border-radius: 14px; padding: 16px 18px; background: #fff; }
.card.accent { background: #F5EFE6; }

/* Disclosures */
.disclosure {
    font-size: .95rem; background: #f9fafb; border: 1px solid #e5e7eb; border-radius: 12px; padding: 12px;
}

/* Keypoints list */
.keypoints { margin: 0; padding-left: 1.25rem; }
.keypoints li { margin: .35rem 0; }

/* CTAs */
.cta-bar { display: flex; gap: 12px; flex-wrap: wrap; margin: 16px 0; }

/* Resources list */
.resources { padding-left: 1.25rem; }
.resources li { margin: .25rem 0; }

/* Tags */
.tags a {
    display: inline-block; margin: 6px 8px 0 0; padding: 4px 10px; border: 1px solid #ddd; border-radius: 999px; text-decoration: none; font-size: .85rem;
}

/* Quick actions — becomes normal stacked section (no sticky) */
.quick-actions {
    background: #fff; border: 1px solid #eee; border-radius: 14px; padding: 12px; position: static; margin-top: 8px;
}
.quick-actions .qa-title { margin-top: 0; }
.quick-actions .qa-list { padding-left: 1rem; margin: 0; }
.quick-actions .rule { height: 1px; background: #eee; margin: 16px 0; }

/* Accessibility helpers */
.visually-hidden {
    position: absolute!important; clip: rect(1px,1px,1px,1px); padding: 0!important; border: 0!important; height: 1px!important; width: 1px!important; overflow: hidden;
}

/* ===== Explainer page spacing tweaks (scoped & non-destructive) ===== */
/* 1) Breadcrumbs tighter to header */
.wrap.wrap-crumbs { padding-top: 8px; padding-bottom: 0; }
.breadcrumb { font-size: .875rem; font-weight: 600; margin-top: 2px; margin-bottom: 6px; }

/* 2) Bring Published/Compliance line closer to disclosure and de-emphasize */
.content .disclosure + .page-head { margin-top: 8px; }
.content .page-head { margin-bottom: 10px; }
.content .page-head h1 { margin-top: 8px; margin-bottom: 6px; }
.content .page-head .lede { margin: 4px 0 6px; }
.content .page-head .meta { font-size: .875rem; font-weight: 600; margin-top: 0; margin-bottom: 0; opacity: .9; }

/* ===== Buttons: keep only sizing if needed (inherited colors from main.css) ===== */
.content .cta-bar .btn { padding: 8px 24px; border-radius: 8px; font-weight: 600; }

/* ===== Article Grid (for learn/index page) ===== */
.article-grid {
    display: grid;
    gap: 2rem;
    grid-template-columns: 1fr;
    margin-top: 2rem;
}

@media (min-width: 640px) {
    .article-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1024px) {
    .article-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.article-grid .card {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.article-grid .card h3 {
    margin-top: 0;
    margin-bottom: 0.75rem;
    font-size: 1.15rem;
    line-height: 1.3;
}

.article-grid .card h3 a {
    color: #1a365d;
    text-decoration: none;
    transition: color 0.2s ease;
}

.article-grid .card h3 a:hover {
    color: #0D9488;
    text-decoration: underline;
}

.article-grid .card p {
    margin: 0.5rem 0;
    flex-grow: 1;
    line-height: 1.6;
}

.article-grid .card .meta {
    margin-top: auto;
    padding-top: 0.75rem;
    font-size: 0.875rem;
    color: #666;
}

/* ===== Article Content Styling (for markdown-rendered content) ===== */
.article-content {
    line-height: 1.7;
    color: #333;
}

.article-content h2 {
    font-family: var(--font-head, 'Lora', Georgia, serif);
    font-size: clamp(1.5rem, 1.2vw + 1rem, 2rem);
    color: #1a365d;
    font-weight: 600;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    line-height: 1.3;
    letter-spacing: -0.3px;
}

.article-content h2:first-of-type {
    margin-top: 0;
}

.article-content h3 {
    font-family: var(--font-head, 'Lora', Georgia, serif);
    font-size: 1.35rem;
    color: #1a365d;
    font-weight: 600;
    margin-top: 2rem;
    margin-bottom: 0.75rem;
    line-height: 1.4;
}

.article-content h4 {
    font-size: 1.15rem;
    color: #1a365d;
    font-weight: 600;
    margin-top: 1.5rem;
    margin-bottom: 0.5rem;
    line-height: 1.4;
}

.article-content p {
    margin: 1rem 0;
    line-height: 1.7;
}

.article-content ul,
.article-content ol {
    margin: 1rem 0;
    padding-left: 1.5rem;
    line-height: 1.7;
}

.article-content li {
    margin: 0.5rem 0;
}

.article-content li > p {
    margin: 0.25rem 0;
}

.article-content strong {
    font-weight: 600;
    color: #1a365d;
}

.article-content hr {
    border: none;
    border-top: 2px solid #e5e7eb;
    margin: 2.5rem 0;
}

.article-content code {
    background: #f3f4f6;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 0.9em;
    font-family: 'Courier New', monospace;
}

.article-content pre {
    background: #f3f4f6;
    padding: 1rem;
    border-radius: 8px;
    overflow-x: auto;
    margin: 1.5rem 0;
}

.article-content blockquote {
    border-left: 4px solid #0D9488;
    padding-left: 1.5rem;
    margin: 1.5rem 0;
    font-style: italic;
    color: #555;
}

.article-content a {
    color: #0D9488;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.article-content a:hover {
    color: #0a7a70;
}

/* ==============================
   Modal Styles (merged from modal.css)
============================== */

/* ========= Modal overlay (true overlay, scroll-locked) ========= */
.modal {
  position: fixed !important;
  inset: 0;
  display: none !important;       /* hidden by default - use !important to override any inline styles */
  align-items: flex-start;
  justify-content: center;
  z-index: 2000;                  /* above header/footer */
}
.modal[aria-hidden="false"] { 
  display: flex !important;       /* Show when opened */
}

.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 43, 91, .55); /* dark blue tint */
  backdrop-filter: blur(1px);
}

.modal-panel {
  position: relative;
  margin: 10vh auto 5vh;
  width: min(92vw, 760px);
  max-height: 86vh;               /* scroll inside panel (not page) */
  overflow: auto;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 24px 64px rgba(0,0,0,.2);
  padding: 1.25rem;
}
.modal-close {
  position: absolute;
  top: .75rem; right: .75rem;
  border: 0; background: transparent;
  font-size: 1.5rem; line-height: 1; cursor: pointer;
  color: #1a365d;
}
@media (min-width: 640px){
  .modal-panel { padding: 2rem; }
}

/* Prevent background scroll while modal open (toggled by JS) */
body.modal-open { overflow: hidden; }

/* ========= Kit (ConvertKit) Form Styling ========= */
/* Only style the container and our custom elements, let Kit handle form internals */

.kit-form-container{
  max-width:480px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding:0 20px !important;
}

.kit-form-container .h3{
  font:600 22px Lora,serif;
  color:#1a365d;
  margin:0 0 .25rem;
}

.kit-form-container .muted{
  color:#475569;
  margin-bottom:1rem;
}

.kit-form-container .small{
  font-size:.9rem;
  color:#475569;
}

/* Override Kit's default button styles to match our site design */
/* Use maximum specificity to override Kit's injected styles - must load after Kit's script */
.formkit-form[data-uid="86874a5009"] .formkit-submit.formkit-submit,
.formkit-form[data-uid="86874a5009"] button.formkit-submit[data-element="submit"]{
  width:100% !important;
  background:linear-gradient(180deg,#0D9488 0%,#0A7A71 100%) !important;
  background-color:#0D9488 !important;
  color:#fff !important;
  border:none !important;
  border-radius:10px !important;
  font-size:1.125rem !important;
  font-weight:600 !important;
  padding:1rem 1.5rem !important;
  min-height:48px !important;
  box-shadow:0 6px 12px rgba(13,148,136,.25) !important;
  cursor:pointer !important;
  transition:transform .08s ease, box-shadow .2s ease !important;
  display:inline-block !important;
}

/* Allow hover state but don't block if Kit disables button */
.formkit-form[data-uid="86874a5009"] .formkit-submit:hover:not([data-active]){
  transform:translateY(-1px) !important;
  box-shadow:0 10px 16px rgba(0,0,0,.10) !important;
}

.formkit-form[data-uid="86874a5009"] .formkit-submit:active:not([data-active]){
  transform:translateY(0) !important;
  background:linear-gradient(180deg,#0B7E75 0%,#096B62 100%) !important;
}

/* Preserve Kit's loading state - don't override when [data-active] */
.formkit-form[data-uid="86874a5009"] .formkit-submit[data-active]{
  cursor:wait !important;
  /* Let Kit's spinner show - don't override opacity/visibility */
}

/* Style input to match our site while letting Kit handle functionality */
/* Use maximum specificity to override Kit's injected styles */
.formkit-form[data-uid="86874a5009"] .formkit-input[name="email_address"],
.formkit-form[data-uid="86874a5009"] input.formkit-input{
  width:100% !important;
  font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif !important;
  padding:.625rem 1rem !important;
  font-size:16px !important;
  height:48px !important;
  min-height:48px !important;
  box-sizing:border-box !important;
  border-radius:.5rem !important;
  border:1px solid #d1d5db !important;
  background:#fff !important;
  line-height:1.5 !important;
}

/* Ensure the formkit-field container also takes full width and has spacing */
.formkit-form[data-uid="86874a5009"] .formkit-field{
  width:100% !important;
  flex:1 0 100% !important;
  margin-bottom:.75rem !important;
  max-width:100% !important;
}

/* Add spacing between fields and button in the formkit-fields container */
/* Use gap but allow Kit's flexbox to still work */
.formkit-form[data-uid="86874a5009"] .formkit-fields[data-stacked="false"]{
  gap:.75rem !important;
}

/* Allow Kit's error messages to display properly */
.formkit-form[data-uid="86874a5009"] .formkit-alert{
  display:block !important;
  margin-top:.75rem !important;
}

.formkit-form[data-uid="86874a5009"] .formkit-alert:empty{
  display:none !important;
}

/* Style "Built with Kit" message to be simple and unflashy */
.formkit-form[data-uid="86874a5009"] .formkit-powered-by-convertkit-container{
  margin-top:.75rem !important;
  margin-bottom:0 !important;
  text-align:center !important;
}

.formkit-form[data-uid="86874a5009"] .formkit-powered-by-convertkit{
  font-size:.75rem !important;
  color:#9ca3af !important;
  text-decoration:none !important;
  opacity:.7 !important;
  display:inline-block !important;
}

.formkit-form[data-uid="86874a5009"] .formkit-powered-by-convertkit:hover{
  opacity:1 !important;
  text-decoration:underline !important;
}

/* Privacy text spacing */
.kit-form-container .privacy{
  margin-top:1rem;
}

.kit-form-container .privacy p{
  margin:0;
  line-height:1.5;
}

/* Responsive tweaks */
@media (max-width:640px){
  .kit-form-container{
    max-width:100%;
  }
  
  .formkit-form[data-uid="86874a5009"] .formkit-submit{
    font-size:1rem !important;
    padding:.9rem 1rem !important;
  }
}



