/* Force surrounding theme wrappers to pure white (kills #FCFAF5 cream bg) */
html, body,
.site, .site-content, .site-main, #main, #content, #page,
.entry, .entry-content, .post-content, .page-content,
.wp-block-post-content, .wp-site-blocks, main, article,
.wrap, .container, .single-post, .page{
  background:#FFFFFF !important;
  background-color:#FFFFFF !important;
  background-image:none !important;
}

/* Kill any theme/Elementor border or top margin above the OTD widget */
.elementor-widget-otd_calculator{margin:0 !important;padding:0 !important;border:none !important;background:transparent !important}
.elementor-widget-otd_calculator > .elementor-widget-container{margin:0 !important;padding:0 !important;border:none !important;background:transparent !important;box-shadow:none !important}
.entry-content > .elementor-widget-otd_calculator:first-child,
.entry-content .elementor-widget-otd_calculator:first-child{margin-top:0 !important}
/* Some themes add top border to first content block - kill it */
.entry-content,.post-content,.page-content{padding-top:0 !important;border-top:none !important}

/* ============================================================
   KILL WHITE SPACE ABOVE HERO
   Zero out top padding/margin on the calculator wrapper and its
   immediate Elementor ancestors so the dark hero bg sits flush
   under the site header.
   ============================================================ */
.cc-otd{margin-top:0 !important;padding-top:0 !important}
.cc-otd .cc-hero{margin-top:0 !important}

/* ============================================================
   ELEMENTOR HOST RESET
   Each page section ships as one HTML widget. Elementor wraps it in
   .elementor-section > .elementor-container > .elementor-column > ...
   We need:
     - zero padding on those wrappers so our own <section class="cc-hero">
       (etc.) controls vertical rhythm
     - full-width stretch so the dark hero bg bleeds edge-to-edge
     - .cc-otd-wrap section padding zeroed (we set it via JSON too, but
       belt-and-suspenders against theme overrides)
   ============================================================ */
.cc-otd-wrap > .elementor-container,
.cc-otd-boot > .elementor-container,
.cc-otd-js-wrap > .elementor-container{max-width:none;padding:0}
.cc-otd-wrap .elementor-column,
.cc-otd-boot .elementor-column,
.cc-otd-js-wrap .elementor-column{padding:0}
.cc-otd-wrap .elementor-widget-wrap,
.cc-otd-boot .elementor-widget-wrap,
.cc-otd-js-wrap .elementor-widget-wrap{padding:0}
.cc-otd-wrap .elementor-widget,
.cc-otd-boot .elementor-widget,
.cc-otd-js-wrap .elementor-widget{margin:0}
.cc-otd-wrap .elementor-widget-container,
.cc-otd-boot .elementor-widget-container,
.cc-otd-js-wrap .elementor-widget-container{padding:0;margin:0}
/* Boot + JS wrappers render nothing visible */
.cc-otd-boot,.cc-otd-js-wrap{display:block;height:0;overflow:hidden}

/* ============================================================
   ELEMENTOR INTEGRATION
   - Default container max-width for content sections
   - Hero gets 780px centered
   - Section heads as native widgets carry their own classes
   - Section CTA centers the button widget
   ============================================================ */

/* Every cc-otd section's container gets a sane content width */
.cc-otd .cc-features-section > .elementor-container,
.cc-otd .cc-steps-section > .elementor-container,
.cc-otd .cc-factors-section > .elementor-container,
.cc-otd .cc-compare-section > .elementor-container,
.cc-otd .cc-rows-section > .elementor-container,
.cc-otd .cc-form-section > .elementor-container,
.cc-otd .cc-nego-section > .elementor-container,
.cc-otd .cc-stats-cta > .elementor-container,
.cc-otd .cc-founder-wrap > .elementor-container,
.cc-otd .cc-calc-section > .elementor-container{
  max-width:1180px;padding:0 20px;
}

/* Hero: narrower, centered content over the dark animated bg */
.cc-otd .cc-hero > .elementor-container{
  max-width:780px;padding:64px 20px 56px;
  text-align:center;position:relative;z-index:1;
}
@media(min-width:768px){
  .cc-otd .cc-hero > .elementor-container{padding:96px 20px 80px}
}
@media(min-width:1100px){
  .cc-otd .cc-hero > .elementor-container{padding:120px 20px 96px}
}

/* Reset Elementor widget margins inside our sections so spacing is ours */
.cc-otd .elementor-section .elementor-widget{margin:0}
.cc-otd .elementor-section .elementor-widget:not(:last-child){margin-bottom:0}

/* Heading widget renders <h1>..<h3> directly — our existing .cc-otd h* rules
   apply. Reset Elementor's default heading title margin so layout is ours. */
.cc-otd .elementor-heading-title{margin:0;font:inherit;color:inherit;line-height:inherit;letter-spacing:inherit}

/* Text editor: paragraph styles inherit. Strip Elementor's container padding. */
.cc-otd .elementor-widget-text-editor .elementor-widget-container > p{margin:0 0 12px}
.cc-otd .elementor-widget-text-editor .elementor-widget-container > p:last-child{margin-bottom:0}

/* Section heads (pill + H2 + intro) — widgets carry the classes */
.cc-otd .elementor-widget.cc-section-pill{margin-bottom:18px;text-align:center}
.cc-otd .elementor-widget.cc-section-pill .cc-pill{
  display:inline-flex;align-items:center;gap:8px;padding:7px 14px;
  background:#fff;border:1px solid var(--hair);border-radius:999px;
  font-size:12px;font-weight:700;color:var(--ink-2);
  box-shadow:var(--sh-1);text-transform:uppercase;letter-spacing:.10em;
}
.cc-otd .elementor-widget.cc-section-h2{margin-bottom:12px;text-align:center;max-width:720px;margin-left:auto;margin-right:auto}
.cc-otd .elementor-widget.cc-section-h2 h2{
  font-size:clamp(26px,3.8vw,42px);color:var(--ink);text-wrap:balance;letter-spacing:-.025em;line-height:1.1;
}
.cc-otd .elementor-widget.cc-section-intro{margin-bottom:44px;text-align:center;max-width:720px;margin-left:auto;margin-right:auto}
.cc-otd .elementor-widget.cc-section-intro p{color:var(--ink-2);font-size:16px;line-height:1.7;margin:0}
@media(min-width:768px){
  .cc-otd .elementor-widget.cc-section-intro{margin-bottom:52px}
  .cc-otd .elementor-widget.cc-section-intro p{font-size:17px}
}

/* Section CTA button: centered, normal pill width */
.cc-otd .elementor-widget-button.cc-section-cta{
  margin-top:42px !important;text-align:center !important;
}
.cc-otd .elementor-widget-button.cc-section-cta .elementor-widget-container{
  display:flex;justify-content:center;
}
.cc-otd .elementor-widget-button.cc-section-cta .elementor-button-wrapper{
  display:inline-block !important;width:auto !important;
}

/* Re-skin Elementor button widget when carrying cc-btn-* class on widget.
   Force inline-flex + auto width so the button never stretches column-wide. */
.cc-otd .elementor-widget-button.cc-btn-primary .elementor-button,
.cc-otd .elementor-widget-button.cc-section-cta .elementor-button{
  display:inline-flex !important;align-items:center;justify-content:center;gap:8px;
  padding:16px 28px !important;border-radius:12px !important;
  font-weight:700;font-size:15px;
  border:0;letter-spacing:.01em;line-height:1;min-height:54px;
  text-decoration:none;
  background:linear-gradient(135deg,var(--orange) 0%,var(--orange-2) 100%) !important;
  color:#fff !important;
  box-shadow:0 10px 26px rgba(229,88,76,.34) !important;
  transition:transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s var(--ease);
  animation:ccBreathCoral 3s var(--ease) infinite;
  width:auto !important;max-width:max-content !important;flex:0 0 auto !important;
}
.cc-otd .elementor-widget-button.cc-btn-primary .elementor-button:hover,
.cc-otd .elementor-widget-button.cc-section-cta .elementor-button:hover{
  background:linear-gradient(135deg,var(--orange-2) 0%,#B83A2F 100%) !important;
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 20px 44px rgba(229,88,76,.52),0 0 0 6px rgba(229,88,76,.18) !important;
  color:#fff !important;animation:none;
}

/* Hero text widget overrides */
.cc-otd .cc-hero .elementor-widget-heading h1{
  font-size:clamp(24px,5.5vw,36px) !important;
  margin:0 auto 14px !important;letter-spacing:-.028em !important;line-height:1.18 !important;
  color:#FFFFFF !important;font-weight:900;max-width:20ch;
  text-shadow:0 1px 0 rgba(0,0,0,.18), 0 0 36px rgba(255,210,122,.16);
}
@media(min-width:768px){.cc-otd .cc-hero .elementor-widget-heading h1{font-size:clamp(36px,4vw,46px) !important;line-height:1.12 !important}}
@media(min-width:1280px){.cc-otd .cc-hero .elementor-widget-heading h1{font-size:50px !important}}
.cc-otd .cc-hero .elementor-widget-text-editor p{
  color:rgba(233,241,242,.86) !important;font-size:15.5px;line-height:1.65;
  max-width:540px;margin:0 auto 22px !important;
}
@media(min-width:768px){.cc-otd .cc-hero .elementor-widget-text-editor p{font-size:16.5px}}

/* ============================================================
   ELEMENTOR NATIVE WIDGET COMPAT
   Lets content team edit pill / H2 / intro / CTA / card text via the
   Elementor panel while preserving the visual design.
   ============================================================ */

/* Heading widget renders <h1>/<h2>/<h3> directly — existing .cc-otd h* rules apply.
   Reset Elementor's default heading margin so our layout rhythm stays intact. */
.cc-otd .elementor-widget-heading .elementor-heading-title{margin:0;font:inherit;color:inherit;line-height:inherit;letter-spacing:inherit}

/* Text editor: paragraph color/sizing inherits from our cc-* rules.
   Reset Elementor margin so siblings sit tight. */
.cc-otd .elementor-widget-text-editor .elementor-widget-container > p{margin:0 0 12px}
.cc-otd .elementor-widget-text-editor .elementor-widget-container > p:last-child{margin-bottom:0}

/* Button widget: re-skin the inner <a class="elementor-button"> to match our cc-btn-* variants. */
.cc-otd .elementor-widget-button.cc-btn-primary .elementor-button,
.cc-otd .elementor-widget-button.cc-btn-gold .elementor-button{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:16px 28px;border-radius:12px;font-weight:700;font-size:15px;
  border:0;letter-spacing:.01em;line-height:1;min-height:54px;white-space:nowrap;
  text-decoration:none;
  background:linear-gradient(135deg,var(--orange) 0%,var(--orange-2) 100%) !important;
  color:#fff !important;
  box-shadow:0 10px 26px rgba(229,88,76,.34) !important;
  transition:transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s var(--ease);
  animation:ccBreathCoral 3s var(--ease) infinite;
}
.cc-otd .elementor-widget-button.cc-btn-primary .elementor-button:hover,
.cc-otd .elementor-widget-button.cc-btn-gold .elementor-button:hover{
  background:linear-gradient(135deg,var(--orange-2) 0%,#B83A2F 100%) !important;
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 20px 44px rgba(229,88,76,.52),0 0 0 6px rgba(229,88,76,.18) !important;
  color:#fff !important;animation:none;
}
.cc-otd .elementor-widget-button.cc-btn-ghost .elementor-button{
  background:rgba(255,255,255,.06) !important;color:#FFF !important;
  border:1px solid rgba(255,255,255,.22) !important;
  padding:14px 22px;font-size:14.5px;min-height:50px;border-radius:12px;
  backdrop-filter:blur(6px);
}
.cc-otd .elementor-widget-button.cc-btn-ghost .elementor-button:hover{
  background:rgba(255,255,255,.12) !important;border-color:rgba(255,210,122,.55) !important;
  transform:translateY(-3px) scale(1.02);color:#FFF !important;
}
.cc-otd .elementor-widget-button.cc-btn-white .elementor-button{
  background:#fff !important;color:var(--orange-2) !important;
  padding:16px 28px;border-radius:12px;font-weight:700;font-size:15px;min-height:54px;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 6px 18px rgba(0,0,0,.10);
}

/* Card-on-column compatibility: when an Elementor column carries cc-fcard /
   cc-step / cc-factor, the column IS the card. Zero out Elementor's column
   padding so our card padding controls spacing. */
.cc-otd .elementor-column.cc-fcard > .elementor-widget-wrap,
.cc-otd .elementor-column.cc-step > .elementor-widget-wrap,
.cc-otd .elementor-column.cc-factor > .elementor-widget-wrap{
  padding:24px 22px;
}
.cc-otd .elementor-column.cc-fcard,
.cc-otd .elementor-column.cc-step,
.cc-otd .elementor-column.cc-factor{
  background:#fff;border:1px solid var(--hair);border-radius:var(--r-lg);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  margin-bottom:14px;
}
.cc-otd .elementor-column.cc-fcard:hover,
.cc-otd .elementor-column.cc-step:hover,
.cc-otd .elementor-column.cc-factor:hover{
  transform:translateY(-4px);box-shadow:var(--sh-3);border-color:var(--gold-soft);
}
.cc-otd .elementor-column.cc-fcard h3,
.cc-otd .elementor-column.cc-step h3,
.cc-otd .elementor-column.cc-factor h3{
  font-size:17px;margin-top:14px;margin-bottom:8px;color:var(--teal-ink);
}
.cc-otd .elementor-column.cc-fcard p,
.cc-otd .elementor-column.cc-step p,
.cc-otd .elementor-column.cc-factor p{
  color:var(--ink-2);font-size:14.5px;line-height:1.65;margin:0;
}

/* Inner sections with cc-head class: section header (pill + H2 + intro), centered */
.cc-otd .elementor-section.cc-head{margin-bottom:44px;max-width:720px;margin-left:auto;margin-right:auto;text-align:center}
.cc-otd .elementor-section.cc-head .elementor-heading-title{text-align:center}
.cc-otd .elementor-section.cc-head .elementor-widget-text-editor{text-align:center}
.cc-otd .elementor-section.cc-head h2{font-size:clamp(26px,3.8vw,42px);margin-bottom:12px;color:var(--ink);text-wrap:balance}
.cc-otd .elementor-section.cc-head p{color:var(--ink-2);font-size:16px;line-height:1.7}
@media(min-width:768px){.cc-otd .elementor-section.cc-head{margin-bottom:52px}}

/* Responsive card columns - override Elementor's default per-column width */
@media(max-width:767px){
  .cc-otd .elementor-column.cc-fcard,
  .cc-otd .elementor-column.cc-step,
  .cc-otd .elementor-column.cc-factor{
    width:100% !important;max-width:100% !important;flex:0 0 100% !important;
  }
}
@media(min-width:768px) and (max-width:979px){
  .cc-otd .elementor-column.cc-fcard,
  .cc-otd .elementor-column.cc-factor{
    width:50% !important;max-width:50% !important;flex:0 0 50% !important;
  }
  .cc-otd .elementor-column.cc-step{
    width:33.333% !important;max-width:33.333% !important;flex:0 0 33.333% !important;
  }
}
/* Card-row inner sections - vertical gap between cards */
.cc-otd .elementor-section.cc-features-row,
.cc-otd .elementor-section.cc-factors-row,
.cc-otd .elementor-section.cc-steps-row{
  margin-bottom:16px;
}
/* Card icon wrapper - reset Elementor widget margins so icon sits cleanly */
.cc-otd .elementor-widget.cc-card-icon-wrap{margin-bottom:0}
.cc-otd .elementor-widget.cc-card-icon-wrap .elementor-widget-container{margin:0}
/* Section CTA - centered button */
.cc-otd .elementor-section.cc-section-cta-wrap{margin-top:42px;text-align:center}
.cc-otd .elementor-section.cc-section-cta-wrap .elementor-button-wrapper{justify-content:center;display:flex}
/* Hero — Elementor widget compatibility */
.cc-otd .cc-hero .elementor-widget-heading h1{
  font-size:clamp(24px,5.5vw,36px) !important;
  margin:0 auto 14px !important;letter-spacing:-.028em;line-height:1.18;
  color:#FFFFFF !important;font-weight:900;max-width:20ch;
  text-shadow:0 1px 0 rgba(0,0,0,.18), 0 0 36px rgba(255,210,122,.16);
}
@media(min-width:768px){.cc-otd .cc-hero .elementor-widget-heading h1{font-size:clamp(36px,4vw,46px) !important;line-height:1.12}}
@media(min-width:1280px){.cc-otd .cc-hero .elementor-widget-heading h1{font-size:50px !important}}
.cc-otd .cc-hero .elementor-widget-text-editor p{
  color:rgba(233,241,242,.86) !important;font-size:15.5px;line-height:1.65;
  max-width:540px;margin-left:auto !important;margin-right:auto !important;
}
@media(min-width:768px){.cc-otd .cc-hero .elementor-widget-text-editor p{font-size:16.5px}}
.cc-otd .cc-hero .elementor-section.cc-hero-actions{max-width:420px;margin-left:auto;margin-right:auto}

/* Form section: white card chrome wraps the 2-col inner */
.cc-otd .cc-form-section .elementor-section.cc-form-card{
  background:#fff;border-radius:var(--r-xl);box-shadow:var(--sh-4);
  border:1px solid var(--hair);position:relative;overflow:hidden;
}
.cc-otd .cc-form-section .elementor-section.cc-form-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:5px;
  background:linear-gradient(90deg,var(--teal),var(--gold),var(--orange));z-index:2;
}
.cc-otd .cc-form-section .cc-form-left > .elementor-widget-wrap{padding:40px 28px}
.cc-otd .cc-form-section .cc-form-right-col > .elementor-widget-wrap{padding:40px 28px}
@media(min-width:860px){
  .cc-otd .cc-form-section .cc-form-left > .elementor-widget-wrap{padding:54px 46px}
  .cc-otd .cc-form-section .cc-form-right-col > .elementor-widget-wrap{padding:54px 46px}
}
.cc-otd .cc-form-section .cc-form-left h2{font-size:clamp(24px,3.2vw,36px);color:var(--teal-ink);margin:16px 0 12px}
.cc-otd .cc-form-section .cc-form-left p{font-size:16px;color:var(--ink);font-weight:700;margin-bottom:6px}
.cc-otd .cc-form-section .cc-form-left p.cc-form-sub{font-size:14.5px;color:var(--ink-2);font-weight:500;margin-top:6px;line-height:1.7}

/* Negotiation: dark card chrome on inner section */
.cc-otd .cc-nego-section .elementor-section.cc-nego{
  background:linear-gradient(135deg,var(--teal-dark) 0%,var(--teal) 55%,var(--teal-2) 100%);
  color:#fff;border-radius:var(--r-xl);padding:40px 28px;overflow:hidden;position:relative;
}
@media(min-width:768px){.cc-otd .cc-nego-section .elementor-section.cc-nego{padding:58px 56px}}
.cc-otd .cc-nego-section .elementor-section.cc-nego h2{color:#fff;font-size:clamp(26px,3.4vw,38px);margin-bottom:14px;max-width:680px}
.cc-otd .cc-nego-section .elementor-section.cc-nego p{color:#e8e0c8;max-width:680px;font-size:15.5px;line-height:1.75}

/* Stats card chrome */
.cc-otd .cc-stats-cta .elementor-section.cc-stats-card{
  background:radial-gradient(circle 500px at 18% 0%,rgba(184,146,60,.22),transparent 60%),
             radial-gradient(circle 500px at 82% 100%,rgba(229,88,76,.16),transparent 60%),
             linear-gradient(135deg,var(--teal-dark) 0%,var(--teal) 60%,var(--teal-2) 100%);
  border-radius:var(--r-xl);padding:48px 28px;text-align:center;color:#fff;position:relative;overflow:hidden;
  border:1px solid rgba(184,146,60,.22);
}
@media(min-width:768px){.cc-otd .cc-stats-cta .elementor-section.cc-stats-card{padding:64px}}
.cc-otd .cc-stats-cta .elementor-section.cc-stats-card h2{color:#fff;font-size:clamp(26px,3.6vw,42px);margin-bottom:14px}
.cc-otd .cc-stats-cta .elementor-section.cc-stats-card p{color:rgba(255,255,255,.84);max-width:600px;margin:0 auto 26px;font-size:15.5px}
.cc-otd .cc-stats-cta .elementor-section.cc-stats-card .cc-counter{
  background:linear-gradient(135deg,#FFC9A8 0%,var(--orange) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;font-weight:900;
}

/* Founder card chrome */
.cc-otd .cc-founder-section .elementor-section.cc-founder{
  background:linear-gradient(135deg,var(--cream) 0%,#FFF 100%);
  border-radius:var(--r-xl);padding:36px 24px;border:1px solid var(--hair);
}
@media(min-width:880px){.cc-otd .cc-founder-section .elementor-section.cc-founder{padding:54px}}
.cc-otd .cc-founder-section .cc-founder-avatar-col .cc-founder-img{
  width:140px;height:140px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal) 0%,var(--gold) 100%);
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:46px;
  font-style:italic;letter-spacing:-.04em;box-shadow:var(--sh-3);margin:0 auto;
}
@media(min-width:880px){.cc-otd .cc-founder-section .cc-founder-avatar-col .cc-founder-img{width:180px;height:180px;font-size:60px;margin:0}}
.cc-otd .cc-founder-section .cc-founder-copy h2{font-size:clamp(22px,2.8vw,30px);color:var(--teal-ink);margin-bottom:10px}
.cc-otd .cc-founder-section .cc-founder-copy h2 em{font-style:italic;font-weight:800;color:var(--gold-2)}
.cc-otd .cc-founder-section .cc-founder-copy p{color:var(--ink-2);font-size:15px;line-height:1.7;margin-bottom:12px}

/* Content rows - 2-col inner sections */
.cc-otd .cc-rows-section .elementor-section.cc-crow{
  padding:42px 0;border-bottom:1px dashed var(--hair);
}
.cc-otd .cc-rows-section .elementor-section.cc-crow:last-child{border-bottom:0}
.cc-otd .cc-rows-section .elementor-section.cc-crow h2{font-size:clamp(22px,2.6vw,28px);color:var(--teal-ink);line-height:1.2}
.cc-otd .cc-rows-section .elementor-section.cc-crow p{color:var(--ink-2);font-size:15px;line-height:1.8;margin-bottom:14px}

/* ============================================================
   FULL-BLEED BREAKOUT
   Themes (Astra / Hello / Generatepress / custom) wrap post content
   in a max-width container (~1140-1240px). Elementor's "stretch section"
   setting depends on theme support and often fails on custom templates.
   This pure-CSS technique forces every cc-* page section to span the
   full viewport width regardless of parent constraints.
   ============================================================ */
.cc-otd-wrap{
  width:100vw;
  max-width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
}
/* Hero inherits 100vw from .cc-otd parent — no extra breakout needed */
/* Other sections same treatment */
.cc-calc-section, .cc-form-section, .cc-steps-section,
.cc-nego-section, .cc-rows-section, .cc-factors-section,
.cc-stats-cta, .cc-compare-section{
  width:100%;
}
/* Lock body from horizontal scroll caused by the breakout */
html, body{overflow-x:hidden}
/* ============================================================
   OTD CALCULATOR · Conversion-optimized rebuild
   · Scope: .cc-otd  (avoids theme + plugin collisions)
   · Mobile-first, progressive enhancement
   · Brand: teal/gold/cream · Montserrat only
   ============================================================ */
.cc-otd{
  /* === FULL VIEWPORT BREAKOUT ===
     Forces the entire widget edge-to-edge regardless of theme container
     max-width. Works in any theme template (Default / Full Width / Canvas). */
  width:100vw;
  max-width:100vw;
  margin-left:calc(-50vw + 50%);
  margin-right:calc(-50vw + 50%);
  margin-top:0;
  padding-top:0;
  border:none;
  outline:none;
  position:relative;

  /* Brand */
  --teal:#0A3D44;
  --teal-2:#1A6068;
  --teal-soft:#2A7780;
  --teal-dark:#062B30;
  --teal-ink:#082F35;
  --gold:#B8923C;
  --gold-2:#9E7C2C;
  --gold-soft:#D9B96A;
  --gold-glow:rgba(184,146,60,.22);
  --sand:#F0E4C8;
  --orange:#E5584C;
  --orange-2:#CF4438;
  --mint:#10B981;

  /* Surfaces */
  --cream:#FFFFFF;
  --cream-2:#FFFFFF;
  --off-white:#FFFFFF;
  --white:#FFFFFF;

  /* Ink scale - high-contrast near-black for accessibility */
  --ink:#0A0A0A;
  --ink-2:#161616;
  --muted:#5A5A5A;
  --slate:#333333;
  --hair:#E6DDC9;
  --hair-2:#D9CFB8;
  --hair-3:#EFE7D3;

  /* Geometry */
  --r-sm:10px;
  --r:14px;
  --r-md:18px;
  --r-lg:22px;
  --r-xl:28px;

  /* Elevation */
  --sh-1:0 1px 2px rgba(10,61,68,.04), 0 1px 1px rgba(10,61,68,.03);
  --sh-2:0 4px 12px rgba(10,61,68,.06), 0 2px 4px rgba(10,61,68,.04);
  --sh-3:0 12px 28px rgba(10,61,68,.10), 0 4px 10px rgba(10,61,68,.06);
  --sh-4:0 28px 60px rgba(10,61,68,.16), 0 10px 20px rgba(10,61,68,.08);
  --sh-gold:0 12px 28px rgba(184,146,60,.30);

  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(0,0,.2,1);

  font-family:'Montserrat',system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  background:var(--white);
  font-feature-settings:"ss01","kern","liga";
}
.cc-otd *,.cc-otd *::before,.cc-otd *::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
.cc-otd{overflow-x:hidden;max-width:100vw}
.cc-otd img,.cc-otd svg{max-width:100%;height:auto;display:block}
.cc-otd h1,.cc-otd h2,.cc-otd h3,.cc-otd h4,.cc-otd h5{font-family:inherit;color:var(--ink);font-weight:800;line-height:1.1;letter-spacing:-.022em;text-wrap:balance}
.cc-otd em.cc-italic{font-family:'Montserrat',sans-serif;font-style:italic;font-weight:800;letter-spacing:-.01em}
.cc-otd a{color:var(--teal);text-decoration:none;transition:color .2s var(--ease)}
.cc-otd a:hover{color:var(--gold-2)}
.cc-otd ul{list-style:none}
.cc-otd button{font-family:inherit}
.cc-otd ::selection{background:var(--gold);color:#fff}

/* Layout - tightened section padding (vertical rhythm) */
.cc-otd .cc-container{max-width:1180px;margin:0 auto;padding:0 20px}
.cc-otd section{padding:40px 0;position:relative}
@media(min-width:768px){.cc-otd section{padding:56px 0}}
@media(min-width:1100px){.cc-otd section{padding:72px 0}}

/* ==== Buttons ==== */
.cc-otd .cc-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;border-radius:12px;font-weight:700;font-size:14.5px;
  cursor:pointer;border:0;letter-spacing:.01em;line-height:1;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease), color .2s var(--ease);
  min-height:48px;white-space:nowrap;
}
.cc-otd .cc-btn:focus-visible{outline:3px solid var(--gold-soft);outline-offset:2px}
.cc-otd .cc-btn-primary{background:var(--teal);color:#fff;box-shadow:0 8px 22px rgba(10,61,68,.28)}
.cc-otd .cc-btn-primary:hover{background:var(--teal-dark);transform:translateY(-2px);box-shadow:0 14px 32px rgba(10,61,68,.38);color:#fff}
.cc-otd .cc-btn-gold{background:var(--gold);color:#fff;box-shadow:var(--sh-gold)}
.cc-otd .cc-btn-gold:hover{background:var(--gold-2);transform:translateY(-2px);box-shadow:0 16px 36px rgba(184,146,60,.42);color:#fff}
.cc-otd .cc-btn-ghost{background:var(--cream-2);color:var(--teal);border:1px solid var(--hair)}
.cc-otd .cc-btn-ghost:hover{background:var(--sand);color:var(--teal-dark)}
.cc-otd .cc-btn-white{background:#fff;color:var(--teal);box-shadow:0 6px 18px rgba(0,0,0,.10)}
.cc-otd .cc-btn-white:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(0,0,0,.16);color:var(--teal-dark)}
.cc-otd .cc-btn-lg{padding:16px 28px;font-size:15.5px;min-height:54px}
.cc-otd .cc-btn-block{width:100%}
/* ==== Pills / Eyebrows ==== */
.cc-otd .cc-pill{
  display:inline-flex;align-items:center;gap:8px;padding:7px 14px;
  background:#fff;border:1px solid var(--hair);border-radius:999px;
  font-size:12px;font-weight:700;color:var(--ink-2);
  box-shadow:var(--sh-1);text-transform:uppercase;letter-spacing:.10em
}
.cc-otd .cc-pill .cc-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px var(--gold-glow)}
.cc-otd .cc-pill.cc-pill-mint .cc-dot{background:var(--mint);box-shadow:0 0 0 4px rgba(16,185,129,.18)}
.cc-otd .cc-pill.cc-pill-dark{background:var(--teal-dark);color:var(--gold-soft);border-color:var(--teal-2)}

/* ============================================================
   HERO · cinematic black bg
   layers: cosmos gradient · top spotlight · drifting aurora blobs
           · diagonal light beams · twinkling stars · breathing grid
           · bottom fade to white
   All GPU-accelerated · respects prefers-reduced-motion
   ============================================================ */
.cc-otd .cc-hero{
  position:relative;padding:48px 0 56px;overflow:hidden;isolation:isolate;
  background:#000;color:#E9F1F2;
  display:flex;align-items:center;
}
@media(min-width:768px){.cc-otd .cc-hero{padding:72px 0}}
@media(min-width:1100px){.cc-otd .cc-hero{padding:96px 0}}

.cc-otd .cc-hero-bg{
  position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;
  contain:strict;
  background:
    radial-gradient(120% 90% at 50% -10%, rgba(60,28,110,.55) 0%, rgba(20,10,40,.35) 35%, rgba(0,0,0,0) 70%),
    radial-gradient(80% 60% at 100% 100%, rgba(184,146,60,.10) 0%, transparent 60%),
    radial-gradient(80% 60% at 0% 100%, rgba(229,88,76,.10) 0%, transparent 60%),
    #000;
}

/* Top spotlight bloom (gold) - breathing */
.cc-otd .cc-hero-bg .cc-spotlight{
  position:absolute;top:-260px;left:50%;width:1100px;height:900px;
  transform:translateX(-50%);
  background:radial-gradient(ellipse 50% 45% at center,
    rgba(255,210,122,.28) 0%,
    rgba(255,210,122,.08) 35%,
    transparent 60%);
  filter:blur(20px);will-change:opacity,transform;
  animation:ccSpot 9s ease-in-out infinite;
}
@keyframes ccSpot{
  0%,100%{opacity:.75;transform:translateX(-50%) scale(1)}
  50%{opacity:1;transform:translateX(-50%) scale(1.06)}
}

/* Drifting aurora blobs (3) - boosted for visibility */
.cc-otd .cc-hero-bg .cc-orb{
  position:absolute;border-radius:50%;filter:blur(80px);opacity:.65;
  will-change:transform;transform:translate3d(0,0,0);
  mix-blend-mode:screen;
}
.cc-otd .cc-hero-bg .cc-orb-1{
  width:560px;height:560px;top:-160px;left:-140px;
  background:radial-gradient(circle, rgba(184,146,60,.85) 0%, transparent 70%);
  animation:ccOrbDriftA 22s ease-in-out infinite alternate;
}
.cc-otd .cc-hero-bg .cc-orb-2{
  width:640px;height:640px;top:-60px;right:-200px;
  background:radial-gradient(circle, rgba(229,88,76,.65) 0%, transparent 70%);
  animation:ccOrbDriftB 26s ease-in-out infinite alternate;
}
.cc-otd .cc-hero-bg .cc-orb-3{
  width:520px;height:520px;bottom:-220px;left:35%;
  background:radial-gradient(circle, rgba(120,80,220,.55) 0%, transparent 70%);
  animation:ccOrbDriftC 30s ease-in-out infinite alternate;
}
@keyframes ccOrbDriftA{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(120px,80px,0) scale(1.1)}
}
@keyframes ccOrbDriftB{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(-140px,60px,0) scale(.92)}
}
@keyframes ccOrbDriftC{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(-80px,-100px,0) scale(1.14)}
}

/* Diagonal light beams (camera-flare vibe) */
.cc-otd .cc-hero-bg .cc-beam{
  position:absolute;top:-30%;width:2px;height:160%;
  background:linear-gradient(180deg,
    transparent 0%,
    rgba(255,210,122,.55) 50%,
    transparent 100%);
  filter:blur(1.5px);transform-origin:top center;will-change:opacity,transform;
}
.cc-otd .cc-hero-bg .cc-beam-1{left:22%;transform:rotate(10deg);animation:ccBeam 7s ease-in-out infinite}
.cc-otd .cc-hero-bg .cc-beam-2{left:58%;transform:rotate(-8deg);animation:ccBeam 9s ease-in-out infinite .8s}
.cc-otd .cc-hero-bg .cc-beam-3{left:80%;transform:rotate(6deg);animation:ccBeam 11s ease-in-out infinite 1.6s}
@keyframes ccBeam{
  0%,100%{opacity:0}
  35%,65%{opacity:.7}
}

/* Twinkling starfield (CSS dots, no img) */
.cc-otd .cc-hero-bg .cc-stars-layer{
  position:absolute;inset:0;
  background-image:
    radial-gradient(1.5px 1.5px at 8% 18%, rgba(255,255,255,.55), transparent 60%),
    radial-gradient(1.5px 1.5px at 22% 60%, rgba(255,255,255,.45), transparent 60%),
    radial-gradient(2px 2px at 38% 24%, rgba(255,255,255,.65), transparent 60%),
    radial-gradient(1.2px 1.2px at 52% 78%, rgba(255,255,255,.4), transparent 60%),
    radial-gradient(1.5px 1.5px at 66% 32%, rgba(255,255,255,.5), transparent 60%),
    radial-gradient(2px 2px at 82% 14%, rgba(255,255,255,.6), transparent 60%),
    radial-gradient(1.5px 1.5px at 92% 58%, rgba(255,255,255,.45), transparent 60%),
    radial-gradient(1.2px 1.2px at 14% 84%, rgba(255,255,255,.4), transparent 60%),
    radial-gradient(1.5px 1.5px at 44% 50%, rgba(255,255,255,.35), transparent 60%),
    radial-gradient(1px 1px at 72% 72%, rgba(255,255,255,.35), transparent 60%);
  opacity:.7;will-change:opacity;
  animation:ccTwinkle 6s ease-in-out infinite alternate;
}
@keyframes ccTwinkle{
  0%{opacity:.35}
  100%{opacity:.85}
}

/* Breathing grid - subtle, masked to center */
.cc-otd .cc-hero-bg .cc-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:60px 60px;
  -webkit-mask-image:radial-gradient(ellipse 65% 55% at 50% 45%, #000 25%, transparent 85%);
          mask-image:radial-gradient(ellipse 65% 55% at 50% 45%, #000 25%, transparent 85%);
  animation:ccGridBreath 6s ease-in-out infinite;
}
@keyframes ccGridBreath{
  0%,100%{opacity:.55}
  50%{opacity:.95}
}

/* Bottom fade to white - smooth handoff, tighter on mobile */
.cc-otd .cc-hero-bg::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:80px;
  background:linear-gradient(180deg, transparent 0%, var(--cream) 100%);
  z-index:5;
}
@media(min-width:768px){.cc-otd .cc-hero-bg::after{height:110px}}

/* Mobile - simpler bg (perf) */
@media(max-width:767px){
  .cc-otd .cc-hero-bg .cc-beam,
  .cc-otd .cc-hero-bg .cc-stars-layer{display:none}
  .cc-otd .cc-hero-bg .cc-orb{filter:blur(60px);opacity:.35}
  .cc-otd .cc-hero-bg .cc-grid{background-size:40px 40px}
}

/* Tighten the gap between hero (dark) and the first light section */
.cc-otd .cc-hero + section{padding-top:36px}
@media(min-width:768px){.cc-otd .cc-hero + section{padding-top:56px}}
@media(min-width:1100px){.cc-otd .cc-hero + section{padding-top:72px}}

/* ============================================================
   APPLE-GRADE UX LAYER
   - scroll progress bar (top of page)
   - trust strip (logos / metric row under hero CTAs)
   - staggered reveal sequencing
   - mobile horizontal scroll-snap deck for features
   - premium focus rings
   - magnetic CTA hover
   - 360px micro-phone breakpoint guards
   ============================================================ */

/* ---- Scroll progress bar ---- */
.cc-otd-progress{
  position:fixed;top:0;left:0;right:0;height:3px;z-index:10000;
  background:linear-gradient(90deg, var(--gold) 0%, var(--orange) 50%, var(--teal) 100%);
  transform-origin:left center;transform:scaleX(0);
  transition:transform .12s linear;will-change:transform;pointer-events:none;
}

/* ---- Trust strip under hero CTAs ---- */
.cc-otd .cc-hero-trust{
  margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  font-size:12px;color:rgba(233,241,242,.72);font-weight:600;letter-spacing:.02em;
}
.cc-otd .cc-hero-trust .cc-trust-item{
  display:inline-flex;align-items:center;gap:7px;
}
.cc-otd .cc-hero-trust .cc-trust-num{
  color:#FFD27A;font-weight:800;font-variant-numeric:tabular-nums;
}
.cc-otd .cc-hero-trust .cc-trust-divider{
  width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.18);
}

/* ---- Staggered reveal: cards animate in sequence (Apple-style) ---- */
.cc-otd .cc-features .cc-fcard.cc-in{transition-delay:0s}
.cc-otd .cc-features .cc-fcard.cc-in:nth-child(2){transition-delay:.08s}
.cc-otd .cc-features .cc-fcard.cc-in:nth-child(3){transition-delay:.16s}
.cc-otd .cc-features .cc-fcard.cc-in:nth-child(4){transition-delay:.24s}
.cc-otd .cc-features .cc-fcard.cc-in:nth-child(5){transition-delay:.32s}
.cc-otd .cc-features .cc-fcard.cc-in:nth-child(6){transition-delay:.40s}

.cc-otd .cc-steps .cc-step.cc-in:nth-child(2){transition-delay:.10s}
.cc-otd .cc-steps .cc-step.cc-in:nth-child(3){transition-delay:.20s}

.cc-otd .cc-factors .cc-factor.cc-in{transition-delay:0s}
.cc-otd .cc-factors .cc-factor.cc-in:nth-child(odd){transition-delay:.05s}
.cc-otd .cc-factors .cc-factor.cc-in:nth-child(even){transition-delay:.12s}

/* ---- Mobile horizontal scroll-snap deck for "Why Use" cards
        (Apple-style swipe gallery on small screens) ---- */
@media(max-width:639px){
  .cc-otd .cc-features{
    display:flex;grid-template-columns:none;gap:14px;
    overflow-x:auto;overflow-y:hidden;
    scroll-snap-type:x mandatory;scroll-padding-left:20px;
    padding:6px 20px 18px;margin:0 -20px;
    scrollbar-width:none;-ms-overflow-style:none;
    scroll-behavior:smooth;
    -webkit-overflow-scrolling:touch;
  }
  .cc-otd .cc-features::-webkit-scrollbar{display:none}
  .cc-otd .cc-features .cc-fcard{
    flex:0 0 84%;scroll-snap-align:start;
  }
  /* Visual hint: 2nd card peeks at the right edge */
  .cc-otd .cc-features::after{content:"";flex:0 0 6px}
}

/* ---- Premium focus ring (visible only for keyboard users) ---- */
.cc-otd :focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(184,146,60,.55), 0 0 0 6px rgba(184,146,60,.18);
  transition:box-shadow .15s var(--ease);
}

/* ---- Magnetic CTA hover (subtle 2% scale - Apple-style press feedback) ---- */
.cc-otd .cc-btn-primary,
.cc-otd .cc-btn-gold,
.cc-otd .cc-calc-go{
  transition:transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s var(--ease), background .2s var(--ease) !important;
}
.cc-otd .cc-btn-primary:hover,
.cc-otd .cc-btn-gold:hover,
.cc-otd .cc-calc-go:hover{
  transform:translateY(-3px) scale(1.02) !important;
}

/* ---- Smooth scroll (Apple-style momentum) ---- */
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

/* ---- Fluid responsive guards ---- */
/* very small phones (iPhone SE, Galaxy Fold cover) */
@media(max-width:360px){
  .cc-otd .cc-container{padding:0 16px}
  .cc-otd .cc-hero h1{font-size:28px;letter-spacing:-.025em}
  .cc-otd .cc-lead{font-size:15px}
  .cc-otd .cc-calc-head{padding:18px 18px 0}
  .cc-otd .cc-calc-body{padding:14px 18px 4px}
  .cc-otd .cc-results,.cc-otd .cc-calc-foot{padding-left:18px;padding-right:18px}
}
/* compact CTA padding on phones so both sit side-by-side */
@media(max-width:480px){
  .cc-otd .cc-hero .cc-btn-primary,
  .cc-otd .cc-hero .cc-btn-ghost{
    padding:14px 12px;font-size:13.5px;min-height:50px;
  }
  .cc-otd .cc-hero-actions{gap:8px}
}

/* hero is single-column centered on mobile/tablet (≤979px).
   On desktop (≥980px) → 2-col grid with calc card on the right. */

/* Right-slot lives inside hero on desktop; hidden on mobile */
.cc-otd .cc-hero-right-slot{display:none}

@media(min-width:980px){
  .cc-otd .cc-hero{
    min-height:auto;
    padding:80px 0;
  }
  .cc-otd .cc-hero-grid{
    display:grid;grid-template-columns:1fr 1.1fr;gap:54px;
    text-align:left;max-width:1180px;align-items:center;
  }
  .cc-otd .cc-hero-grid > div{text-align:left}
  .cc-otd .cc-hero h1{margin-left:0;margin-right:0;max-width:none}
  .cc-otd .cc-hero .cc-lead{margin-left:0;margin-right:0;max-width:520px}
  .cc-otd .cc-hero-badges,
  .cc-otd .cc-hero-actions,
  .cc-otd .cc-hero-meta{justify-content:flex-start;margin-left:0;margin-right:auto}
  .cc-otd .cc-hero-actions{max-width:420px}
  .cc-otd .cc-hero-right-slot{display:block;position:relative}
  .cc-otd .cc-hero-right-slot .cc-calc-wrap{max-width:none;margin:0}
  .cc-otd .cc-calc-section{display:none}
  .cc-otd .cc-hero-scroll{display:none}
}
@media(min-width:1100px){
  .cc-otd .cc-hero{padding:96px 0}
}

/* prevent horizontal scrollbar on any width */
.cc-otd,.cc-otd *{min-width:0}

/* Calc card head and breakdown - tabular alignment for numbers */
.cc-otd .cc-r-price,.cc-otd .cc-r-tax,.cc-otd .cc-r-title,
.cc-otd .cc-r-reg,.cc-otd .cc-r-doc,.cc-otd .cc-r-total{
  font-variant-numeric:tabular-nums;
}

/* Stat card - count-up number (set via JS) */
.cc-otd .cc-counter{display:inline-block;font-variant-numeric:tabular-nums}

.cc-otd .cc-hero-grid{
  display:block;position:relative;z-index:1;
  text-align:center;max-width:780px;margin:0 auto;
}
.cc-otd .cc-hero-grid > div{text-align:center}
.cc-otd .cc-hero-badges,
.cc-otd .cc-hero-actions,
.cc-otd .cc-hero-meta{justify-content:center}
.cc-otd .cc-hero h1,
.cc-otd .cc-hero .cc-lead{margin-left:auto;margin-right:auto}

/* Desktop 2-col: text left, calc right */
@media(min-width:980px){
  .cc-otd .cc-hero-grid{
    display:grid;
    grid-template-columns:1fr 1.1fr;
    gap:48px;
    align-items:center;
    text-align:left;
    max-width:1180px;
  }
  .cc-otd .cc-hero-grid > div{text-align:left}
  .cc-otd .cc-hero h1,
  .cc-otd .cc-hero .cc-lead{
    margin-left:0;margin-right:0;max-width:520px;
  }
  .cc-otd .cc-hero h1{max-width:none}
  .cc-otd .cc-hero-actions,
  .cc-otd .cc-hero-meta,
  .cc-otd .cc-hero-badges{
    justify-content:flex-start;margin-left:0;margin-right:auto;
  }
  .cc-otd .cc-hero-actions{max-width:280px}
  .cc-otd .cc-hero .cc-calc-wrap{max-width:none;margin:0}
}
@media(min-width:1280px){
  .cc-otd .cc-hero .cc-calc-wrap{max-width:560px;margin-left:auto}
}
/* Mobile: calc card sits below hero text with small gap */
@media(max-width:979px){
  .cc-otd .cc-hero .cc-calc-wrap{margin-top:32px}
}

.cc-otd .cc-hero-rating{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.08);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:6px 13px 6px 8px;
  font-size:12px;color:#F2E9D4;font-weight:600;margin-bottom:14px;
  box-shadow:0 8px 24px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.08);
}

/* ---- Trust badges (Google + BBB) - compact, always side-by-side ---- */
.cc-otd .cc-hero-badges{
  display:inline-flex;gap:8px;flex-wrap:nowrap;margin:0 auto;
  justify-content:center;align-items:stretch;
  max-width:fit-content;
}
.cc-otd .cc-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:#FFFFFF;border-radius:12px;padding:6px 12px 6px 6px;
  text-decoration:none;color:#0A0A0A;
  box-shadow:0 8px 22px rgba(0,0,0,.26), 0 1px 0 rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.04);
  flex:0 1 auto;min-width:0;
}
.cc-otd .cc-badge-icon{
  width:30px;height:30px;flex-shrink:0;border-radius:8px;
  background:#FFF;display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.04);
}
.cc-otd .cc-badge-icon svg{width:18px;height:18px;display:block}
.cc-otd .cc-badge-icon-bbb{
  background:#0D2A4F;color:#FFD24A;
  font-family:'Montserrat',sans-serif;font-weight:900;font-size:12px;
  letter-spacing:-.04em;line-height:1;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);
}
.cc-otd .cc-badge-text{display:flex;flex-direction:column;line-height:1.1;gap:1px;min-width:0}
.cc-otd .cc-badge-stars{font-size:9.5px;color:#F8B400;letter-spacing:1px;line-height:1}
.cc-otd .cc-badge-text strong{font-size:12px;font-weight:800;color:#0A0A0A;letter-spacing:-.005em;white-space:nowrap}
.cc-otd .cc-badge-text small{font-size:10px;color:#5A5A5A;font-weight:600;white-space:nowrap}

/* phone */
@media(max-width:480px){
  .cc-otd .cc-hero-badges{gap:6px}
  .cc-otd .cc-badge{padding:5px 10px 5px 5px;gap:6px;border-radius:10px}
  .cc-otd .cc-badge-icon{width:26px;height:26px;border-radius:7px}
  .cc-otd .cc-badge-icon svg{width:15px;height:15px}
  .cc-otd .cc-badge-icon-bbb{font-size:11px}
  .cc-otd .cc-badge-stars{font-size:8.5px;letter-spacing:.8px}
  .cc-otd .cc-badge-text strong{font-size:11px}
  .cc-otd .cc-badge-text small{font-size:9.5px}
}
/* micro phones - hide subtext to keep one row */
@media(max-width:360px){
  .cc-otd .cc-badge-text small{display:none}
}

/* ---- Scroll cue at bottom of hero (clickable jump) ---- */
.cc-otd .cc-hero-scroll{
  position:absolute;left:50%;bottom:24px;transform:translateX(-50%);
  z-index:6;display:flex;flex-direction:column;align-items:center;gap:6px;
  font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.55);text-decoration:none;
  transition:color .2s var(--ease), transform .2s var(--ease);
}
.cc-otd .cc-hero-scroll:hover{color:#FFD27A;transform:translateX(-50%) translateY(-2px)}
.cc-otd .cc-hero-scroll .cc-scroll-mouse{
  width:22px;height:34px;border:1.5px solid rgba(255,255,255,.35);
  border-radius:12px;position:relative;display:block;
}
.cc-otd .cc-hero-scroll .cc-scroll-mouse::after{
  content:"";position:absolute;left:50%;top:6px;
  width:2px;height:6px;background:#FFD27A;
  border-radius:2px;transform:translateX(-50%);
  animation:ccScrollDot 1.8s ease-in-out infinite;
}
@keyframes ccScrollDot{
  0%{transform:translateX(-50%) translateY(0);opacity:1}
  60%{transform:translateX(-50%) translateY(12px);opacity:0}
  100%{transform:translateX(-50%) translateY(0);opacity:0}
}
@media(max-width:480px){.cc-otd .cc-hero-scroll{bottom:16px;font-size:9px}}
@media(prefers-reduced-motion:reduce){
  .cc-otd .cc-hero-scroll .cc-scroll-mouse::after{animation:none}
}
.cc-otd .cc-stars{
  display:inline-flex;gap:1px;font-size:14px;line-height:1;
  background:linear-gradient(135deg,#FFD27A,#B8923C);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cc-otd .cc-hero-rating strong{color:#FFF;font-weight:800}

.cc-otd .cc-hero h1{
  font-size:clamp(24px,5.5vw,36px);margin-bottom:14px;letter-spacing:-.028em;line-height:1.18;
  color:#FFFFFF;font-weight:900;
  text-shadow:0 1px 0 rgba(0,0,0,.18), 0 0 36px rgba(255,210,122,.16);
  max-width:20ch;position:relative;isolation:isolate;
}
/* Soft warm glow behind the headline (focal anchor) */
.cc-otd .cc-hero h1::before{
  content:"";position:absolute;top:50%;left:50%;
  width:120%;height:300%;transform:translate(-50%,-50%);
  background:radial-gradient(ellipse 50% 40% at center,
    rgba(255,180,90,.18) 0%,
    rgba(255,90,76,.10) 35%,
    transparent 70%);
  filter:blur(20px);z-index:-1;pointer-events:none;
}
@media(min-width:768px){.cc-otd .cc-hero h1{font-size:clamp(36px,4.2vw,48px);line-height:1.12}}
@media(min-width:1280px){.cc-otd .cc-hero h1{font-size:52px}}
.cc-otd .cc-hero h1 .cc-grad{
  background:linear-gradient(135deg,#FFD27A 0%,var(--orange) 60%, #FF8E80 100%);
  background-size:200% 200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:ccGradShift 8s ease-in-out infinite;
}
@keyframes ccGradShift{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}
.cc-otd .cc-hero .cc-lead{
  font-size:15.5px;color:rgba(233,241,242,.82);max-width:520px;margin-bottom:22px;line-height:1.6
}
@media(min-width:768px){.cc-otd .cc-hero .cc-lead{font-size:16.5px}}
.cc-otd .cc-hero-actions{
  display:flex;gap:10px;flex-wrap:nowrap;margin-bottom:18px;align-items:stretch;
  max-width:420px;margin-left:auto;margin-right:auto;
}
.cc-otd .cc-hero-actions .cc-btn{
  flex:1 1 0;min-width:0;white-space:nowrap;
}
/* Hero meta — pill strip with green checks, single bar */
.cc-otd .cc-hero-meta{
  display:inline-flex;align-items:center;gap:14px;flex-wrap:nowrap;
  padding:9px 16px;margin:0 auto 18px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  border-radius:999px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  box-shadow:0 8px 20px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.06);
  max-width:fit-content;
}
@media(max-width:480px){
  .cc-otd .cc-hero-meta{gap:10px;padding:7px 12px}
}
@media(max-width:380px){
  .cc-otd .cc-hero-meta{gap:8px;padding:6px 10px}
}
.cc-otd .cc-hero .cc-meta{
  display:inline-flex;align-items:center;gap:6px;font-size:12.5px;
  color:#FFFFFF;font-weight:600;white-space:nowrap;
}
.cc-otd .cc-hero .cc-meta .cc-check{
  width:16px;height:16px;border-radius:50%;
  background:rgba(16,185,129,.22);color:#34D399;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:900;flex-shrink:0;
  box-shadow:inset 0 0 0 1px rgba(52,211,153,.40);
}
@media(max-width:480px){
  .cc-otd .cc-hero .cc-meta{font-size:11.5px;gap:5px}
  .cc-otd .cc-hero .cc-meta .cc-check{width:14px;height:14px;font-size:9px}
}

/* Hero CTA hierarchy: primary loud, ghost calm — Apple-style */
.cc-otd .cc-hero .cc-btn-primary{
  padding:16px 28px;font-size:15px;min-height:54px;
  box-shadow:0 14px 38px rgba(229,88,76,.55), 0 0 0 1px rgba(255,255,255,.06) inset !important;
}
.cc-otd .cc-hero .cc-btn-ghost{
  background:rgba(255,255,255,.06);color:#FFF;
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  padding:16px 22px;font-size:14.5px;min-height:54px;
}
.cc-otd .cc-hero .cc-btn-ghost:hover{
  background:rgba(255,255,255,.12);color:#FFF;border-color:rgba(255,210,122,.55);
}

/* ==== Calculator card ==== */
.cc-otd .cc-calc{
  background:#fff;border:1px solid rgba(255,255,255,.08);border-radius:var(--r-xl);
  box-shadow:
    0 30px 80px rgba(0,0,0,.45),
    0 10px 30px rgba(184,146,60,.18),
    0 0 0 1px rgba(255,255,255,.05);
  overflow:hidden;position:relative;
}
/* Animated halo ring around calc card. Lives on a wrapper because
   .cc-calc itself has overflow:hidden. Works in any section. */
.cc-otd .cc-calc-wrap{position:relative;isolation:isolate}
.cc-otd .cc-calc-wrap::before{
  content:"";position:absolute;inset:-18px;border-radius:calc(var(--r-xl) + 18px);
  background:conic-gradient(from 0deg,
    rgba(184,146,60,0) 0deg,
    rgba(184,146,60,.55) 90deg,
    rgba(229,88,76,.50) 180deg,
    rgba(20,184,166,.40) 270deg,
    rgba(184,146,60,0) 360deg);
  filter:blur(22px);opacity:.45;z-index:-1;pointer-events:none;
  animation:ccHaloSpin 14s linear infinite;
}
@keyframes ccHaloSpin{to{transform:rotate(360deg)}}

/* ====== CALC SECTION (own section, overlaps hero bottom edge) ====== */
.cc-otd .cc-calc-section{
  position:relative;z-index:3;
  padding:0 0 64px;
  background:transparent;
}
.cc-otd .cc-hero + .cc-calc-section{
  padding-top:0;
  margin-top:-64px;
}
@media(min-width:768px){
  .cc-otd .cc-hero + .cc-calc-section{margin-top:-96px}
  .cc-otd .cc-calc-section{padding-bottom:96px}
}
.cc-otd .cc-calc-section .cc-calc-wrap{
  max-width:640px;margin:0 auto;
}
/* tighter gap to the section that follows calc */
.cc-otd .cc-calc-section + section{padding-top:32px}
@media(min-width:768px){.cc-otd .cc-calc-section + section{padding-top:48px}}
.cc-otd .cc-calc::before{
  content:"";position:absolute;top:0;left:0;right:0;height:5px;
  background:linear-gradient(90deg,var(--teal),var(--gold),var(--orange))
}
.cc-otd .cc-calc-head{padding:22px 24px 0;display:flex;justify-content:space-between;align-items:center;gap:12px}
.cc-otd .cc-calc-head h3{font-size:18px;color:var(--teal);letter-spacing:-.015em}
.cc-otd .cc-calc-head h3 small{display:block;font-size:12px;color:var(--muted);font-weight:600;margin-top:3px;letter-spacing:0;text-transform:none}
.cc-otd .cc-live{
  display:inline-flex;align-items:center;gap:6px;
  font-size:10.5px;color:var(--mint);font-weight:800;text-transform:uppercase;letter-spacing:.12em;
  background:rgba(16,185,129,.10);padding:5px 10px;border-radius:999px
}
.cc-otd .cc-live .cc-blip{width:6px;height:6px;border-radius:50%;background:var(--mint);animation:ccBlip 1.6s ease-in-out infinite}
@keyframes ccBlip{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}
.cc-otd .cc-calc-body{padding:18px 24px 6px}
.cc-otd .cc-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cc-otd .cc-field{margin-bottom:12px}
.cc-otd .cc-field label{
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;font-weight:800;color:var(--ink-2);margin-bottom:6px;
  text-transform:uppercase;letter-spacing:.06em
}
.cc-otd .cc-field label .cc-hint{font-weight:600;color:var(--muted);text-transform:none;letter-spacing:0;font-size:11.5px}
.cc-otd .cc-input-wrap{position:relative}
.cc-otd .cc-input-wrap .cc-prefix{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-weight:700;pointer-events:none}
.cc-otd .cc-input-wrap input{padding-left:26px}
.cc-otd .cc-calc input,.cc-otd .cc-calc select{
  width:100%;padding:13px 14px;font-size:15px;font-family:inherit;
  border:1.5px solid var(--hair);border-radius:12px;background:#fff;color:var(--ink);
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
  min-height:48px
}
.cc-otd .cc-calc input:focus,.cc-otd .cc-calc select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px rgba(10,61,68,.10)}
.cc-otd .cc-calc input::placeholder{color:var(--muted);opacity:.7}
.cc-otd .cc-advanced{margin-top:4px;border-top:1px dashed var(--hair);padding-top:12px}
.cc-otd .cc-advanced-toggle{
  background:none;border:0;cursor:pointer;width:100%;display:flex;justify-content:space-between;align-items:center;
  font-family:inherit;font-size:13px;font-weight:700;color:var(--teal);padding:6px 0;
}
.cc-otd .cc-advanced-toggle .cc-chev{transition:transform .25s var(--ease);display:inline-block}
.cc-otd .cc-advanced.cc-open .cc-chev{transform:rotate(180deg)}
.cc-otd .cc-advanced-fields{max-height:0;overflow:hidden;transition:max-height .35s var(--ease), margin .35s var(--ease)}
.cc-otd .cc-advanced.cc-open .cc-advanced-fields{max-height:360px;margin-top:10px}
.cc-otd .cc-calc-go{
  width:100%;margin-top:8px;padding:16px;border:0;border-radius:14px;cursor:pointer;
  background:linear-gradient(135deg,var(--teal) 0%,var(--teal-2) 100%);color:#fff;
  font-weight:800;font-size:15.5px;font-family:inherit;letter-spacing:.02em;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);min-height:56px;
  display:flex;align-items:center;justify-content:center;gap:10px
}
.cc-otd .cc-calc-go:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(10,61,68,.4)}
.cc-otd .cc-calc-go:active{transform:translateY(0)}

.cc-otd .cc-results{padding:8px 24px 18px}
.cc-otd .cc-breakdown{
  background:linear-gradient(180deg,var(--cream) 0%,var(--cream-2) 100%);
  border-radius:14px;padding:16px 18px;border:1px solid var(--hair)
}
.cc-otd .cc-line{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:7px 0;font-size:13.5px;color:var(--ink-2)
}
.cc-otd .cc-line .cc-v{font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.cc-otd .cc-line.cc-total{border-top:1.5px dashed var(--hair-2);margin-top:6px;padding-top:14px;font-size:15px;align-items:center}
.cc-otd .cc-line.cc-total .cc-label{font-weight:800;color:var(--ink)}
.cc-otd .cc-line.cc-total .cc-v{
  font-size:26px;font-weight:900;letter-spacing:-.02em;
  background:linear-gradient(135deg,var(--teal),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent
}

.cc-otd .cc-calc-foot{
  padding:14px 24px;background:linear-gradient(180deg,var(--cream-2),var(--sand));
  border-top:1px solid var(--hair);font-size:12.5px;color:var(--ink-2);line-height:1.55
}
.cc-otd .cc-calc-foot strong{color:var(--ink);font-weight:800}
.cc-otd .cc-calc-foot a{color:var(--gold-2);font-weight:800;border-bottom:1px solid currentColor}

/* ==== Live activity ticker ==== */
.cc-otd .cc-ticker{
  display:flex;align-items:center;gap:10px;margin-top:18px;
  background:#fff;border:1px solid var(--hair);border-radius:999px;
  padding:9px 14px 9px 9px;font-size:13px;color:var(--ink-2);
  box-shadow:var(--sh-1);max-width:540px;overflow:hidden
}
.cc-otd .cc-ticker-pulse{
  width:24px;height:24px;flex-shrink:0;border-radius:50%;
  background:var(--mint);position:relative
}
.cc-otd .cc-ticker-pulse::after{
  content:"";position:absolute;inset:-4px;border-radius:50%;
  background:var(--mint);opacity:.4;animation:ccPulseRing 2s ease-out infinite
}
@keyframes ccPulseRing{0%{transform:scale(1);opacity:.5}100%{transform:scale(1.8);opacity:0}}
.cc-otd .cc-ticker-text{flex:1;transition:opacity .3s var(--ease);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cc-otd .cc-ticker-text strong{color:var(--teal);font-weight:800}
.cc-otd .cc-ticker-text em{font-style:normal;color:var(--gold-2);font-weight:800}
.cc-otd .cc-ticker-tag{
  font-size:9.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  background:var(--mint);color:#fff;padding:3px 7px;border-radius:6px;flex-shrink:0
}

/* ============================================================
   PROOF STRIP
   ============================================================ */

@media(max-width:767px){

}

/* ============================================================
   SECTION HEADER
   ============================================================ */
.cc-otd .cc-head{text-align:center;max-width:720px;margin:0 auto 44px}
@media(min-width:768px){.cc-otd .cc-head{margin-bottom:52px}}
.cc-otd .cc-head .cc-pill{margin-bottom:18px}
.cc-otd .cc-head h2{font-size:clamp(26px,3.8vw,42px);margin-bottom:12px;letter-spacing:-.025em;color:var(--teal-ink)}
.cc-otd .cc-head p{color:var(--ink-2);font-size:16px;line-height:1.7}
@media(min-width:768px){.cc-otd .cc-head p{font-size:17px}}

/* ============================================================
   WHY USE
   ============================================================ */
.cc-otd .cc-features{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:640px){.cc-otd .cc-features{grid-template-columns:1fr 1fr;gap:16px}}
@media(min-width:980px){.cc-otd .cc-features{grid-template-columns:repeat(3,1fr);gap:18px}}
.cc-otd .cc-fcard{
  background:#fff;border:1px solid var(--hair);border-radius:var(--r-lg);padding:24px 22px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
  position:relative;overflow:hidden
}
.cc-otd .cc-fcard::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg,var(--gold-glow) 0%,transparent 40%);
  opacity:0;transition:opacity .35s var(--ease);pointer-events:none
}
.cc-otd .cc-fcard:hover{transform:translateY(-4px);box-shadow:var(--sh-3);border-color:var(--gold-soft)}
.cc-otd .cc-fcard:hover::after{opacity:.6}
.cc-otd .cc-ficon{
  width:46px;height:46px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin-bottom:14px;color:#fff;position:relative;z-index:1
}
.cc-otd .cc-ficon.cc-b1{background:linear-gradient(135deg,var(--teal),var(--teal-soft))}
.cc-otd .cc-ficon.cc-b2{background:linear-gradient(135deg,var(--gold),var(--gold-soft))}
.cc-otd .cc-ficon.cc-b3{background:linear-gradient(135deg,var(--orange),var(--gold))}
.cc-otd .cc-ficon.cc-b4{background:linear-gradient(135deg,var(--teal-2),var(--gold-2))}
.cc-otd .cc-ficon.cc-b5{background:linear-gradient(135deg,var(--gold-2),var(--orange-2))}
.cc-otd .cc-ficon.cc-b6{background:linear-gradient(135deg,var(--teal),var(--orange))}
.cc-otd .cc-fcard h3{font-size:17px;margin-bottom:8px;color:var(--teal-ink);position:relative;z-index:1}
.cc-otd .cc-fcard p{color:var(--ink-2);font-size:14.5px;line-height:1.65;position:relative;z-index:1}

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.cc-otd .cc-steps-section{background:var(--cream)}
.cc-otd .cc-steps{display:grid;grid-template-columns:1fr;gap:16px;position:relative}
@media(min-width:768px){.cc-otd .cc-steps{grid-template-columns:repeat(3,1fr);gap:20px}}
@media(min-width:768px){
  .cc-otd .cc-steps::before{
    content:"";position:absolute;top:46px;left:14%;right:14%;height:2px;
    background:repeating-linear-gradient(90deg,var(--hair-2) 0 6px,transparent 6px 12px);
    z-index:0
  }
}
.cc-otd .cc-step{
  background:#fff;border-radius:var(--r-lg);padding:28px 24px;border:1px solid var(--hair);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);position:relative;z-index:1
}
.cc-otd .cc-step:hover{transform:translateY(-4px);box-shadow:var(--sh-3)}
.cc-otd .cc-step .cc-n{
  display:inline-flex;width:46px;height:46px;border-radius:14px;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#fff;
  align-items:center;justify-content:center;font-weight:900;font-size:17px;
  margin-bottom:14px;box-shadow:var(--sh-gold)
}
.cc-otd .cc-step h3{font-size:18px;margin-bottom:8px;color:var(--teal-ink)}
.cc-otd .cc-step p{color:var(--ink-2);font-size:14.5px;line-height:1.65}

/* ============================================================
   FORM CTA
   ============================================================ */
.cc-otd .cc-form-section{padding:40px 0;background:linear-gradient(180deg,#fff 0%,var(--cream) 100%)}
@media(min-width:768px){.cc-otd .cc-form-section{padding:56px 0}}
@media(min-width:1100px){.cc-otd .cc-form-section{padding:72px 0}}
.cc-otd .cc-form-card{
  background:#fff;border-radius:var(--r-xl);overflow:hidden;
  display:grid;grid-template-columns:1fr;
  box-shadow:var(--sh-4);border:1px solid var(--hair);position:relative
}
@media(min-width:860px){.cc-otd .cc-form-card{grid-template-columns:1.1fr 1fr}}
.cc-otd .cc-form-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:5px;
  background:linear-gradient(90deg,var(--teal),var(--gold),var(--orange))
}
.cc-otd .cc-form-left{padding:40px 28px;background:linear-gradient(135deg,var(--cream) 0%,#fff 100%);position:relative}
@media(min-width:860px){.cc-otd .cc-form-left{padding:54px 46px}}
.cc-otd .cc-form-left h2{font-size:clamp(24px,3.2vw,36px);margin:16px 0 12px;color:var(--teal-ink)}
.cc-otd .cc-form-left h2 .cc-grad{background:linear-gradient(135deg,var(--gold),var(--orange));-webkit-background-clip:text;background-clip:text;color:transparent}
.cc-otd .cc-form-left>p{font-size:16px;color:var(--ink);font-weight:700;margin-bottom:6px}
.cc-otd .cc-form-left>p.cc-form-sub{font-size:14.5px;color:var(--ink-2);font-weight:500;margin-top:6px;line-height:1.7}
.cc-otd .cc-perks{margin-top:26px;padding-top:22px;border-top:1px dashed var(--hair)}
.cc-otd .cc-perk{display:flex;align-items:center;gap:12px;padding:8px 0;font-size:14.5px;color:var(--ink-2);font-weight:600}
.cc-otd .cc-form-right{padding:40px 28px;display:flex;flex-direction:column;justify-content:center;background:#fff}
@media(min-width:860px){.cc-otd .cc-form-right{padding:54px 46px}}
.cc-otd .cc-form-right .cc-field{margin-bottom:14px}
.cc-otd .cc-form-right label{display:block;font-size:12px;font-weight:800;color:var(--ink-2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}
.cc-otd .cc-form-right input{
  width:100%;padding:14px 16px;font-size:15px;font-family:inherit;
  border:1.5px solid var(--hair);border-radius:12px;background:var(--off-white);color:var(--ink);
  transition:border-color .2s var(--ease), background .2s var(--ease), box-shadow .2s var(--ease);
  min-height:50px
}
.cc-otd .cc-form-right input:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(10,61,68,.10)}
.cc-otd .cc-form-note{font-size:12px;color:var(--muted);text-align:center;margin-top:12px}

/* ============================================================
   EXPERT NEGOTIATION (dark card)
   ============================================================ */
.cc-otd .cc-nego-section{padding:20px 0 40px}
@media(min-width:768px){.cc-otd .cc-nego-section{padding:28px 0 56px}}
@media(min-width:1100px){.cc-otd .cc-nego-section{padding:32px 0 72px}}
.cc-otd .cc-nego{
  background:linear-gradient(135deg,var(--teal-dark) 0%,var(--teal) 55%,var(--teal-2) 100%);
  color:#fff;border-radius:var(--r-xl);padding:40px 28px;position:relative;overflow:hidden
}
@media(min-width:768px){.cc-otd .cc-nego{padding:58px 56px}}
.cc-otd .cc-nego::before{
  content:"";position:absolute;top:-100px;right:-100px;width:380px;height:380px;
  background:radial-gradient(circle,rgba(184,146,60,.32),transparent 70%);border-radius:50%
}
.cc-otd .cc-nego::after{
  content:"";position:absolute;bottom:-140px;left:-60px;width:340px;height:340px;
  background:radial-gradient(circle,rgba(229,88,76,.18),transparent 70%);border-radius:50%
}
.cc-otd .cc-nego>*{position:relative;z-index:1}
.cc-otd .cc-nego h2{color:#fff;font-size:clamp(26px,3.4vw,38px);margin-bottom:14px;max-width:680px}
.cc-otd .cc-nego h2 em{font-family:'Montserrat',sans-serif;font-style:italic;font-weight:800;color:var(--gold-soft)}
.cc-otd .cc-nego .cc-lead2{color:#e8e0c8;max-width:680px;margin-bottom:24px;font-size:15.5px;line-height:1.75}
.cc-otd .cc-nego ul{margin-bottom:28px}
.cc-otd .cc-nego li{padding:10px 0 10px 36px;position:relative;color:#f0e4c8;font-size:14.5px;line-height:1.6}
.cc-otd .cc-nego li::before{content:"";position:absolute;left:0;top:11px;width:24px;height:24px;border-radius:8px;background:linear-gradient(135deg,var(--gold),var(--orange))}
.cc-otd .cc-nego li::after{content:"✓";position:absolute;left:6px;top:11px;color:#fff;font-weight:900;font-size:13px}
.cc-otd .cc-nego li strong{color:#fff;font-weight:800}

/* ============================================================
   TESTIMONIALS
   ============================================================ */

/* ============================================================
   COMPARE TABLE
   ============================================================ */
.cc-otd .cc-compare-section{background:var(--cream)}
.cc-otd .cc-compare{
  background:#fff;border:1px solid var(--hair);border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--sh-2);max-width:920px;margin:0 auto
}
.cc-otd .cc-compare-row{
  display:grid;grid-template-columns:1.2fr 1fr 1.2fr;
  border-bottom:1px solid var(--hair);
}
.cc-otd .cc-compare-row:last-child{border-bottom:0}
.cc-otd .cc-compare-cell{padding:16px 18px;font-size:14px;color:var(--ink-2);display:flex;align-items:center}
.cc-otd .cc-compare-cell:first-child{font-weight:700;color:var(--ink);background:var(--cream-2)}
.cc-otd .cc-compare-cell:last-child{background:linear-gradient(135deg,rgba(184,146,60,.08),rgba(229,88,76,.04));border-left:3px solid var(--gold)}
.cc-otd .cc-compare-head{background:var(--teal-dark)!important}
.cc-otd .cc-compare-head .cc-compare-cell{background:transparent;color:#fff;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:18px;justify-content:center}
.cc-otd .cc-compare-head .cc-compare-cell:first-child{background:transparent;color:rgba(255,255,255,.5)}
.cc-otd .cc-compare-head .cc-compare-cell:last-child{background:transparent;color:var(--gold-soft);border-left:0}
.cc-otd .cc-compare-row.cc-compare-foot{background:var(--cream-2);grid-template-columns:1fr;text-align:center;padding:22px}
.cc-otd .cc-compare-foot p{font-size:14px;color:var(--ink-2);margin-bottom:14px;padding:0}
.cc-otd .cc-compare-foot p strong{color:var(--teal-ink)}
.cc-otd .cc-x{color:var(--orange);font-weight:800;margin-right:6px}
.cc-otd .cc-tick{color:var(--mint);font-weight:800;margin-right:6px}
@media(max-width:680px){
  .cc-otd .cc-compare-row{grid-template-columns:1fr 1fr;font-size:13px}
  .cc-otd .cc-compare-cell:first-child{grid-column:1/-1;justify-content:center;font-size:12.5px;text-transform:uppercase;letter-spacing:.05em;padding:10px;background:var(--teal-dark);color:#fff!important}
  .cc-otd .cc-compare-cell:last-child{border-left:0;border-top:3px solid var(--gold)}
  .cc-otd .cc-compare-head{display:none}
  .cc-otd .cc-compare-row.cc-compare-foot{grid-template-columns:1fr}
  .cc-otd .cc-compare-foot .cc-compare-cell:first-child{display:none}
}

/* ============================================================
   FOUNDER
   ============================================================ */
.cc-otd .cc-founder{
  background:linear-gradient(135deg,var(--cream) 0%,var(--cream-2) 100%);
  border-radius:var(--r-xl);padding:36px 24px;border:1px solid var(--hair);
  display:grid;grid-template-columns:1fr;gap:28px;align-items:center
}
@media(min-width:880px){.cc-otd .cc-founder{grid-template-columns:auto 1fr;padding:54px;gap:48px}}
.cc-otd .cc-founder-img{
  width:140px;height:140px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal) 0%,var(--gold) 100%);
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:46px;
  font-family:'Montserrat',sans-serif;font-style:italic;letter-spacing:-.04em;
  box-shadow:var(--sh-3);margin:0 auto
}
@media(min-width:880px){.cc-otd .cc-founder-img{width:180px;height:180px;font-size:60px;margin:0}}
.cc-otd .cc-founder-copy h2{font-size:clamp(22px,2.8vw,30px);color:var(--teal-ink);margin-bottom:10px}
.cc-otd .cc-founder-copy h2 em{font-family:'Montserrat',sans-serif;font-style:italic;font-weight:800;color:var(--gold-2)}
.cc-otd .cc-founder-copy p{color:var(--ink-2);font-size:15px;margin-bottom:12px;line-height:1.7}
.cc-otd .cc-founder-sign{margin-top:18px;padding-top:18px;border-top:1px dashed var(--hair-2)}
.cc-otd .cc-founder-sign strong{display:block;color:var(--teal-ink);font-size:14.5px;font-weight:800}
.cc-otd .cc-founder-sign span{display:block;color:var(--muted);font-size:12.5px;margin-top:3px}

/* ============================================================
   LEAD MAGNET (email checklist)
   ============================================================ */

/* ============================================================
   TRUST BADGES
   ============================================================ */

/* ============================================================
   CONTENT ROWS (Smart Negotiation / Maximize Savings / No Surprises)
   ============================================================ */
.cc-otd .cc-rows-section{background:#fff}
.cc-otd .cc-crow{padding:42px 0;border-bottom:1px dashed var(--hair)}
.cc-otd .cc-crow:last-child{border-bottom:0}
.cc-otd .cc-cgrid{
  display:grid;grid-template-columns:1fr;gap:24px;align-items:start;max-width:1080px;margin:0 auto
}
@media(min-width:880px){.cc-otd .cc-cgrid{grid-template-columns:1fr 1.45fr;gap:56px}}
.cc-otd .cc-ctag{
  display:inline-block;padding:5px 12px;background:rgba(184,146,60,.14);color:var(--gold-2);
  font-size:11px;font-weight:800;border-radius:999px;text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px
}
.cc-otd .cc-cgrid h2{font-size:clamp(22px,2.6vw,28px);color:var(--teal-ink);letter-spacing:-.02em;line-height:1.2}
.cc-otd .cc-cgrid p{color:var(--ink-2);font-size:15px;margin-bottom:14px;line-height:1.8}
.cc-otd .cc-cgrid p:last-child{margin-bottom:0}
.cc-otd .cc-tip{
  background:linear-gradient(135deg,rgba(184,146,60,.10),rgba(229,88,76,.05));
  border-left:4px solid var(--gold);border-radius:12px;padding:18px 22px;margin-top:18px
}
.cc-otd .cc-tip strong{display:block;color:var(--gold-2);margin-bottom:6px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:800}
.cc-otd .cc-tip p{margin:0;color:var(--ink);font-size:14.5px;line-height:1.7}

/* ============================================================
   8 IMPORTANT FACTORS
   ============================================================ */
.cc-otd .cc-factors-section{background:var(--cream)}
.cc-otd .cc-factors{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:780px){.cc-otd .cc-factors{grid-template-columns:1fr 1fr;gap:18px}}
.cc-otd .cc-factor{
  background:#fff;border-radius:var(--r-lg);padding:28px;border:1px solid var(--hair);
  transition:box-shadow .3s var(--ease), border-color .3s var(--ease), transform .3s var(--ease)
}
.cc-otd .cc-factor:hover{box-shadow:var(--sh-3);border-color:var(--gold-soft);transform:translateY(-2px)}
.cc-otd .cc-factor-top{display:flex;gap:14px;align-items:center;margin-bottom:14px}
.cc-otd .cc-factor-n{
  width:44px;height:44px;border-radius:12px;
  background:linear-gradient(135deg,var(--teal),var(--gold));color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:900;font-size:16px;flex-shrink:0;
  box-shadow:0 6px 16px rgba(10,61,68,.25)
}
.cc-otd .cc-factor h3{font-size:17px;color:var(--teal-ink);line-height:1.25;letter-spacing:-.015em}
.cc-otd .cc-factor p{color:var(--ink-2);font-size:14px;line-height:1.7;margin:0}

/* ============================================================
   STATS CTA CARD (Clients Served)
   ============================================================ */
.cc-otd .cc-stats-cta{padding:40px 0}
@media(min-width:768px){.cc-otd .cc-stats-cta{padding:56px 0}}
@media(min-width:1100px){.cc-otd .cc-stats-cta{padding:72px 0}}
.cc-otd .cc-stats-card{
  background:
    radial-gradient(circle 500px at 18% 0%, rgba(184,146,60,.22), transparent 60%),
    radial-gradient(circle 500px at 82% 100%, rgba(229,88,76,.16), transparent 60%),
    linear-gradient(135deg, var(--teal-dark) 0%, var(--teal) 60%, var(--teal-2) 100%);
  border-radius:var(--r-xl);padding:48px 28px;text-align:center;color:#fff;
  position:relative;overflow:hidden;border:1px solid rgba(184,146,60,.22)
}
@media(min-width:768px){.cc-otd .cc-stats-card{padding:64px}}
.cc-otd .cc-stats-card::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.06) 1.4px,transparent 1.4px);
  background-size:24px 24px;opacity:.5;pointer-events:none
}
.cc-otd .cc-stats-card>*{position:relative;z-index:1}
.cc-otd .cc-stats-card h2{
  color:#fff;font-size:clamp(26px,3.6vw,42px);margin-bottom:14px;letter-spacing:-.025em
}
.cc-otd .cc-stats-card h2 span{
  background:linear-gradient(135deg, var(--gold-soft) 0%, var(--gold) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;font-weight:900
}
.cc-otd .cc-stats-card p{
  color:rgba(255,255,255,.84);max-width:600px;margin:0 auto 26px;font-size:15.5px;line-height:1.7
}

/* ============================================================
   FAQ
   ============================================================ */

/* ============================================================
   GUARANTEE CARD
   ============================================================ */

/* ============================================================
   FINALE
   ============================================================ */

/* ============================================================
   FLOATING CTA - bottom-center pill (centered on all sizes,
   avoids overlap with right-anchored chat widgets)
   ============================================================ */
.cc-otd .cc-float{
  position:fixed;left:50%;bottom:22px;z-index:9998;
  opacity:0;pointer-events:none;
  transform:translateX(-50%) translateY(14px) scale(.95);
  transition:opacity .35s var(--ease), transform .35s var(--ease);
  display:block;
  max-width:calc(100% - 24px);
  margin-bottom:env(safe-area-inset-bottom,0);
}
.cc-otd .cc-float.cc-show{
  opacity:1;
  transform:translateX(-50%) translateY(0) scale(1);
  pointer-events:auto;
}
.cc-otd .cc-float-btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:10px 18px 10px 10px;
  background:linear-gradient(135deg, var(--orange) 0%, var(--orange-2) 100%);
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  box-shadow:0 14px 40px rgba(229,88,76,.45), 0 4px 12px rgba(229,88,76,.25), inset 0 1px 0 rgba(255,255,255,.18);
  color:#fff;text-decoration:none;
  font-weight:800;font-size:14px;line-height:1;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease);
}
.cc-otd .cc-float-btn:hover{
  background:linear-gradient(135deg, var(--orange-2) 0%, #B83A2F 100%);
  color:#fff;
  box-shadow:0 22px 52px rgba(229,88,76,.58), 0 6px 16px rgba(229,88,76,.32), inset 0 1px 0 rgba(255,255,255,.28);
}
.cc-otd .cc-float-ic{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:#fff;color:var(--orange-2);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 12px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.6);
  position:relative;
}
.cc-otd .cc-float-ic::after{
  content:"";position:absolute;inset:-5px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.55);
  animation:ccFloatRing 2.4s var(--ease) infinite;
}
@keyframes ccFloatRing{0%{transform:scale(1);opacity:.55}100%{transform:scale(1.6);opacity:0}}
.cc-otd .cc-float-text{display:flex;flex-direction:column;align-items:flex-start;gap:2px;line-height:1.1;text-align:left}
.cc-otd .cc-float-text small{
  font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.85);
}
.cc-otd .cc-float-text strong{font-size:14px;font-weight:800;color:#fff;letter-spacing:.005em}

/* Hide deprecated inner cta pill - markup may still have it but it's invisible */
.cc-otd .cc-float-cta{display:none!important}

/* Float CTA visible on every breakpoint; hover lifts but keeps center */
.cc-otd .cc-float.cc-show:hover{
  transform:translateX(-50%) translateY(-2px) scale(1.02);
}

/* ============================================================
   Mobile sticky bottom bar - clean, well-proportioned
   ============================================================ */
.cc-otd .cc-stickybar{
  position:fixed;left:12px;right:12px;bottom:12px;z-index:9998;
  background:#fff;border:1px solid var(--hair);
  border-radius:14px;
  padding:10px 10px 10px 16px;
  margin-bottom:env(safe-area-inset-bottom,0);
  display:none;align-items:center;gap:12px;
  box-shadow:0 14px 36px rgba(10,61,68,.16), 0 2px 8px rgba(10,61,68,.08);
  transform:translateY(calc(100% + 24px));transition:transform .4s var(--ease);
}
.cc-otd .cc-stickybar.cc-show{transform:translateY(0)}
.cc-otd .cc-stickybar-msg{flex:1;min-width:0;line-height:1.2}
.cc-otd .cc-stickybar-msg strong{
  display:block;font-size:13px;font-weight:800;color:var(--teal-ink);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.cc-otd .cc-stickybar-msg span{
  display:block;font-size:11px;color:var(--muted);margin-top:2px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.cc-otd .cc-stickybar .cc-btn{
  padding:11px 18px;font-size:13px;min-height:44px;flex-shrink:0;
  border-radius:999px;
}
/* Stickybar replaced by centered cc-float on mobile - keep hidden */
.cc-otd .cc-stickybar{display:none!important}
/* removed: padding-bottom on mobile was reserving space for sticky bar */

/* ============================================================
   EXIT INTENT MODAL
   ============================================================ */

/* ============================================================
   SCROLL-REVEAL animations
   ============================================================ */
.cc-otd .cc-reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease-out), transform .7s var(--ease-out)}
.cc-otd .cc-reveal.cc-in{opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){
  .cc-otd .cc-reveal{opacity:1;transform:none;transition:none}
  .cc-otd *{animation:none!important;transition:none!important}
}

/* ============================================================
   CTA BUTTON ANIMATIONS - shimmer · breath · press · halo
   ============================================================ */
/* ===== Shiny CTA - continuous diagonal sweep + animated border ring =====
   Uses simple background-position animation (works in every browser, no @property) */
@keyframes ccShineSweep{
  0%, 8%    { background-position: 0% 0; }
  72%, 100% { background-position: 100% 0; }
}

/* Base interactive setup - all CTAs */
.cc-otd .cc-btn,.cc-otd .cc-calc-go,.cc-otd .cc-float-btn,.cc-otd .cc-float-cta{
  position:relative;overflow:hidden;isolation:isolate;will-change:transform;
}
.cc-otd .cc-btn>*,.cc-otd .cc-calc-go>*,.cc-otd .cc-float-btn>*,.cc-otd .cc-float-cta>*{position:relative;z-index:2}

/* Diagonal sweep gloss - always running */
.cc-otd .cc-btn::before,
.cc-otd .cc-calc-go::before,
.cc-otd .cc-float-cta::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:1;
  background:linear-gradient(115deg,
    transparent 38%,
    rgba(255,255,255,.55) 50%,
    transparent 62%);
  background-size:300% 100%;
  background-position:0% 0;
  animation:ccShineSweep 3s ease-in-out infinite;
}

/* Animated 1.5px border highlight ring (mask-composite trick - ShinyButton port) */
.cc-otd .cc-btn::after,
.cc-otd .cc-calc-go::after,
.cc-otd .cc-float-cta::after{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(115deg,
    rgba(255,255,255,.12) 38%,
    rgba(255,255,255,.95) 50%,
    rgba(255,255,255,.12) 62%);
  background-size:300% 100%;
  background-position:0% 0;
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  pointer-events:none;z-index:3;
  animation:ccShineSweep 3s ease-in-out infinite;
}

/* Ghost / white variants: tone down the highlight (less contrast on light bg) */
.cc-otd .cc-btn-white::before, .cc-otd .cc-btn-ghost::before{
  background:linear-gradient(115deg, transparent 38%, rgba(229,88,76,.20) 50%, transparent 62%);
  background-size:300% 100%;
}
.cc-otd .cc-btn-white::after, .cc-otd .cc-btn-ghost::after{
  background:linear-gradient(115deg, rgba(229,88,76,.10) 38%, rgba(229,88,76,.55) 50%, rgba(229,88,76,.10) 62%);
  background-size:300% 100%;
}

/* Idle breathing - primary / gold / white / ghost variants */
.cc-otd .cc-btn-primary{animation:ccBreath 3.2s var(--ease) infinite}
.cc-otd .cc-btn-gold,.cc-otd .cc-calc-go{animation:ccBreathGold 3s var(--ease) infinite}
.cc-otd .cc-btn-primary:hover,.cc-otd .cc-btn-gold:hover,.cc-otd .cc-calc-go:hover{animation:none}

/* Floating CTA: same breath as other primary CTAs (unified across page) */
.cc-otd .cc-float-btn{animation:ccBreathCoral 3s var(--ease) infinite}
.cc-otd .cc-float-btn:hover{animation:none;transform:translateY(-3px) scale(1.02)}

/* Press feedback - matches whileTap:0.95 */
.cc-otd .cc-btn:active,
.cc-otd .cc-calc-go:active,
.cc-otd .cc-float-btn:active,
.cc-otd .cc-float-cta:active{
  transform:translateY(1px) scale(.95);
  transition-duration:.08s;
}

/* Hover intensification */
.cc-otd .cc-btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(10,61,68,.42),0 0 0 4px rgba(184,146,60,.18)}
.cc-otd .cc-btn-gold:hover{transform:translateY(-3px);box-shadow:0 20px 44px rgba(184,146,60,.52),0 0 0 6px rgba(184,146,60,.18)}
.cc-otd .cc-calc-go:hover{transform:translateY(-3px);box-shadow:0 20px 44px rgba(10,61,68,.45),0 0 0 6px rgba(184,146,60,.18)}
.cc-otd .cc-btn-white:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(0,0,0,.20),0 0 0 4px rgba(184,146,60,.20)}
.cc-otd .cc-btn-ghost:hover{background:var(--sand);border-color:var(--gold-soft);transform:translateY(-2px);box-shadow:0 10px 22px rgba(10,61,68,.10)}

/* Reduced motion: kill all idle anims + shimmer overlay */
@media(prefers-reduced-motion:reduce){
  .cc-otd .cc-btn,.cc-otd .cc-calc-go,.cc-otd .cc-float-btn,.cc-otd .cc-float-cta{animation:none!important}
  .cc-otd .cc-btn::before,.cc-otd .cc-calc-go::before,.cc-otd .cc-float-cta::before,
  .cc-otd .cc-btn::after,.cc-otd .cc-calc-go::after,.cc-otd .cc-float-cta::after{display:none}
}

/* ============================================================
   CTA COLOR UNIFICATION - every CTA = coral/orange
   ============================================================ */
@keyframes ccBreathCoral{
  0%,100%{box-shadow:0 10px 26px rgba(229,88,76,.34),0 0 0 0 rgba(229,88,76,0)}
  50%{box-shadow:0 14px 34px rgba(229,88,76,.48),0 0 0 8px rgba(229,88,76,.14)}
}

.cc-otd .cc-btn-primary,
.cc-otd .cc-btn-gold,
.cc-otd .cc-calc-go{
  background:linear-gradient(135deg,var(--orange) 0%,var(--orange-2) 100%)!important;
  color:#fff!important;
  box-shadow:0 10px 26px rgba(229,88,76,.34)!important;
  animation:ccBreathCoral 3s var(--ease) infinite!important;
}
.cc-otd .cc-btn-primary:hover,
.cc-otd .cc-btn-gold:hover,
.cc-otd .cc-calc-go:hover{
  background:linear-gradient(135deg,var(--orange-2) 0%,#B83A2F 100%)!important;
  transform:translateY(-3px)!important;
  box-shadow:0 20px 44px rgba(229,88,76,.52),0 0 0 6px rgba(229,88,76,.18)!important;
  animation:none!important;
}

.cc-otd .cc-btn-ghost{background:var(--cream-2);color:var(--orange-2);border:1px solid rgba(229,88,76,.32)}
.cc-otd .cc-btn-ghost:hover{background:rgba(229,88,76,.08);color:var(--orange-2);border-color:var(--orange);transform:translateY(-2px);box-shadow:0 10px 22px rgba(229,88,76,.18)}

.cc-otd .cc-btn-white{background:#fff;color:var(--orange-2);box-shadow:0 6px 18px rgba(0,0,0,.10)}
.cc-otd .cc-btn-white:hover{transform:translateY(-3px);color:var(--orange-2);box-shadow:0 18px 38px rgba(0,0,0,.20),0 0 0 4px rgba(229,88,76,.22)}

/* Floating CTA — unified coral breath */
.cc-otd .cc-float-btn{animation:ccBreathCoral 3s var(--ease) infinite}
.cc-otd .cc-float-text small{color:rgba(255,255,255,.85)!important}
.cc-otd .cc-float-text strong{color:#fff!important}

/* Sticky mobile bar CTA */
.cc-otd .cc-stickybar .cc-btn-gold{box-shadow:0 8px 22px rgba(229,88,76,.45)!important}

/* Stats CTA card headline + gradient strip recolor for harmony */
.cc-otd .cc-stats-card h2 span{
  background:linear-gradient(135deg, #FFC9A8 0%, var(--orange) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ============================================================
   HubSpot form: invalid state + contact row under form
   ============================================================ */
.cc-otd .cc-form-right input.cc-invalid{
  border-color:#ff4444 !important;
  background:#fff5f5 !important;
  box-shadow:0 0 0 4px rgba(255,68,68,.12) !important;
}
.cc-otd .cc-form-right .cc-err{
  color:#d63b3b;font-size:12px;margin-top:4px;display:block;font-weight:600
}
.cc-otd .cc-contact-row{
  display:flex;flex-wrap:wrap;gap:14px;margin-top:18px;
  padding-top:18px;border-top:1px dashed var(--hair)
}
.cc-otd .cc-contact-link{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13.5px;color:var(--teal-ink);font-weight:700;
  padding:8px 12px;border-radius:999px;background:var(--cream-2);
  border:1px solid var(--hair);text-decoration:none;
  transition:all .2s var(--ease)
}
.cc-otd .cc-contact-link:hover{
  background:var(--sand);border-color:var(--gold-soft);color:var(--teal-dark);
  transform:translateY(-1px);box-shadow:var(--sh-2)
}
.cc-otd .cc-contact-ic{font-size:15px;line-height:1}

/* ============================================================
   PERF · paint deferral for below-fold sections
   Saves render work on long page. Skipped for hero+form (above the fold).
   ============================================================ */
.cc-otd .cc-steps-section,
.cc-otd .cc-nego-section,
.cc-otd .cc-rows-section,
.cc-otd .cc-factors-section,
.cc-otd .cc-stats-cta,
.cc-otd .cc-compare-section{
  content-visibility:auto;
  contain-intrinsic-size:auto 720px;
}

/* ============================================================
   MOTION · honor user preference
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  .cc-otd .cc-hero-bg .cc-orb,
  .cc-otd .cc-hero-bg .cc-spotlight,
  .cc-otd .cc-hero-bg .cc-beam,
  .cc-otd .cc-hero-bg .cc-stars-layer,
  .cc-otd .cc-hero-bg .cc-grid,
  .cc-otd .cc-hero h1 .cc-grad,
  .cc-otd .cc-calc-wrap::before{
    animation:none !important;
  }
}

/* ============================================================
   HERO ALIGNMENT - final overrides (cascade-safe)
   Mobile/tablet (<980px): everything centered.
   Desktop (>=980px): everything left-aligned (2-col layout, calc on right).
   ============================================================ */
@media(max-width:979px){
  .cc-otd .cc-hero-grid,
  .cc-otd .cc-hero-grid > div{text-align:center !important}
  .cc-otd .cc-hero h1,
  .cc-otd .cc-hero .cc-lead{
    margin-left:auto !important;margin-right:auto !important;text-align:center !important;
  }
  .cc-otd .cc-hero-actions{
    margin-left:auto !important;margin-right:auto !important;
    justify-content:center !important;
  }
  .cc-otd .cc-hero-meta,
  .cc-otd .cc-hero-badges{
    margin-left:auto !important;margin-right:auto !important;
    justify-content:center !important;
  }
}
@media(min-width:980px){
  .cc-otd .cc-hero-grid,
  .cc-otd .cc-hero-grid > div{text-align:left !important}
  .cc-otd .cc-hero h1{
    margin-left:0 !important;margin-right:0 !important;
    text-align:left !important;max-width:none !important;
  }
  .cc-otd .cc-hero .cc-lead{
    margin-left:0 !important;margin-right:0 !important;
    text-align:left !important;max-width:520px !important;
  }
  .cc-otd .cc-hero-actions{
    margin-left:0 !important;margin-right:auto !important;
    justify-content:flex-start !important;
    max-width:280px !important;
  }
  .cc-otd .cc-hero-meta,
  .cc-otd .cc-hero-badges{
    margin-left:0 !important;margin-right:auto !important;
    justify-content:flex-start !important;
  }
}

/* ============================================================
   PATCHES — gradient-clip, custom HS form states, founder hide
   ============================================================ */

/* Gradient text first-letter clip fix (webkit-background-clip:text)
   Browsers clip the first glyph when letter-spacing is negative.
   Inline-block + tiny side padding restores the missing pixel column. */
.cc-otd .cc-grad,
.cc-otd .cc-line.cc-total .cc-v,
.cc-otd .cc-counter,
.cc-otd .cc-stars,
.cc-otd .cc-stats-card h2 span,
.cc-otd .cc-stats-card .elementor-heading-title span,
.cc-stats-cta .elementor-section.cc-stats-card .elementor-heading-title span{
  display:inline-block;
  padding-left:.06em;
  padding-right:.06em;
}

/* Custom HubSpot form — error + valid states, success banner */
.cc-otd .cc-form-right .cc-req{color:var(--orange);font-weight:800;margin-left:2px}
.cc-otd .cc-form-right .cc-field-error{
  display:block;color:#E5584C;font-size:12px;
  margin-top:6px;min-height:14px;font-weight:600;letter-spacing:.01em;
}
.cc-otd .cc-form-right input.cc-invalid{
  border-color:#E5584C !important;
  background:rgba(229,88,76,.04) !important;
  box-shadow:0 0 0 4px rgba(229,88,76,.10) !important;
}
.cc-otd .cc-form-right input.cc-valid{
  border-color:#10B981 !important;
  background:rgba(16,185,129,.04) !important;
}
.cc-otd .cc-hs-success{
  display:none;
  margin-top:14px;padding:14px 16px;
  background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(16,185,129,.06));
  border:1px solid rgba(16,185,129,.32);
  color:#0F7C5C;border-radius:12px;
  font-size:14.5px;font-weight:700;text-align:center;
  animation:none;
}
.cc-otd .cc-hs-success.cc-show{display:block;animation:ccHsSuccess .35s var(--ease)}
@keyframes ccHsSuccess{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:translateY(0)}
}
