body.public-shell{
  --landing-accent: #758a9a;
  --landing-accent-strong: #334152;
  --landing-accent-soft: rgba(145, 182, 199, 0.18);
  --landing-ink: #223447;
  --landing-text: #53697c;
  --landing-muted: #74899a;
  --landing-border: rgba(51, 65, 82, 0.12);
  --landing-border-strong: rgba(51, 65, 82, 0.18);
  --landing-panel: #ffffff;
  --landing-panel-soft: #f1f7fa;
  --landing-surface: linear-gradient(180deg, #ffffff 0%, #f7fbfd 100%);
  --landing-surface-soft: linear-gradient(180deg, #ffffff 0%, #fbfdfe 100%);
  --landing-wash: linear-gradient(180deg, #f1f7fa 0%, #ffffff 52%, #edf5f8 100%);
  --landing-shadow-sm: 0 10px 24px rgba(15, 23, 42, 0.06);
  --landing-shadow-md: 0 18px 44px rgba(15, 23, 42, 0.08);
  --landing-shadow-lg: 0 28px 72px rgba(15, 23, 42, 0.12);
  --landing-radius: 24px;
}

body.public-shell .site-main{
  padding-bottom: 0;
}

body.public-shell .site-header{
  background: rgba(241, 247, 250, 0.92);
  border-bottom: 1px solid rgba(51, 65, 82, 0.1);
  box-shadow: 0 1px 0 rgba(51, 65, 82, 0.04);
}

body.public-shell .site-brand-mark{
  background: linear-gradient(135deg, #758a9a, #334152);
  box-shadow: 0 10px 24px rgba(51, 65, 82, 0.18);
}

body.public-shell .site-brand-title{
  color: var(--landing-ink);
}

body.public-shell .site-brand-subtitle,
body.public-shell .site-nav-link{
  color: var(--landing-text);
}

body.public-shell .site-nav-link:hover,
body.public-shell .site-nav-link.is-active{
  background: rgba(175, 197, 208, 0.18);
  color: var(--landing-accent-strong);
}

body.public-shell .site-nav-cta{
  background: linear-gradient(135deg, var(--landing-accent), var(--landing-accent-strong));
  box-shadow: 0 14px 28px rgba(51, 65, 82, 0.18);
}

body.public-shell .site-nav-cta:hover{
  background: linear-gradient(135deg, #5f7487, #29394b);
  box-shadow: 0 18px 32px rgba(41, 57, 75, 0.22);
}

body.public-shell .site-mobile-toggle{
  border-color: rgba(51, 65, 82, 0.12);
  background: rgba(255, 255, 255, 0.86);
  color: var(--landing-ink);
  box-shadow: 0 8px 20px rgba(51, 65, 82, 0.08);
}

body.public-shell .site-mobile-toggle:hover{
  border-color: rgba(145, 182, 199, 0.38);
  background: rgba(241, 247, 250, 0.98);
}

body.public-shell .mobile-nav-list{
  border-color: rgba(51, 65, 82, 0.1);
  background: rgba(241, 247, 250, 0.98);
  box-shadow: var(--landing-shadow-md);
}

body.public-shell .mobile-nav-link{
  border-color: rgba(51, 65, 82, 0.1);
  background: rgba(255, 255, 255, 0.84);
  color: var(--landing-ink);
}

body.public-shell .mobile-nav-link:hover,
body.public-shell .mobile-nav-link:focus{
  border-color: rgba(145, 182, 199, 0.42);
  background: #ffffff;
  color: var(--landing-accent-strong);
}

body.public-shell .mobile-nav-cta{
  background: linear-gradient(135deg, var(--landing-accent), var(--landing-accent-strong));
  box-shadow: 0 14px 28px rgba(51, 65, 82, 0.18);
}

body.public-shell .site-footer{
  margin-top: 0;
  border-top: 1px solid rgba(51, 65, 82, 0.08);
  background: linear-gradient(180deg, rgba(241, 247, 250, 0.35), rgba(237, 245, 248, 0.72));
}

body.public-shell .footer-card{
  border-color: rgba(51, 65, 82, 0.08);
  background: rgba(255, 255, 255, 0.82);
}

body.public-shell .hero-banner{
  max-width: 1120px;
  margin: 0 auto 0;
  border: 1px solid var(--landing-border);
  border-radius: 0;
  box-shadow: var(--landing-shadow-lg);
  background: var(--landing-panel);
}

body.public-shell .hero-banner-img{
  display: block;
  width: 100%;
  object-fit: cover;
}

body.public-shell .hero{
  padding: 2.5rem 0 0.35rem;
  background:
    radial-gradient(circle at top center, rgba(145, 182, 199, 0.18), transparent 26rem),
    var(--landing-wash);
}

body.public-shell .home-wrap{
  max-width: 1120px;
  padding: 0 1rem;
}

body.public-shell .hero-content{
  max-width: 760px;
  margin: 0 auto;
}

body.public-shell .hero-kicker{
  background: #fff;
  border-color: rgba(145, 182, 199, 0.34);
  color: var(--landing-accent-strong);
  box-shadow: 0 8px 20px rgba(145, 182, 199, 0.16);
}

body.public-shell .hero-title{
  margin-top: 1rem;
  margin-bottom: 1rem;
  color: var(--landing-ink);
  font-size: clamp(2.35rem, 5.6vw, 4.5rem);
  line-height: 0.98;
  letter-spacing: -0.045em;
  text-wrap: balance;
}

body.public-shell .hero-lede{
  max-width: 60ch;
  color: var(--landing-text);
  font-size: clamp(1.03rem, 1.5vw, 1.18rem);
  line-height: 1.72;
}

body.public-shell .hero-locality{
  display: inline-block;
  margin-top: 1rem;
  padding: 0.8rem 1rem;
  border: 1px solid rgba(145, 182, 199, 0.35);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.9);
  color: var(--landing-ink);
  font-size: 0.98rem;
  line-height: 1.55;
  box-shadow: var(--landing-shadow-sm);
}

body.public-shell .hero-locality strong{
  color: var(--landing-accent-strong);
}

body.public-shell .hero-actions{
  margin-top: 1.5rem;
  gap: 0.85rem;
}

body.public-shell .btn{
  min-height: 2.95rem;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0.01em;
  box-shadow: var(--landing-shadow-sm);
}

body.public-shell .btn::before{
  display: none;
}

body.public-shell .btn-primary{
  background: linear-gradient(135deg, var(--landing-accent), var(--landing-accent-strong));
  color: #fff;
  border: 1px solid rgba(51, 65, 82, 0.12);
  box-shadow: 0 18px 36px rgba(51, 65, 82, 0.2);
}

body.public-shell .btn-primary:hover{
  background: linear-gradient(135deg, #5f7487, #29394b);
  box-shadow: 0 22px 42px rgba(41, 57, 75, 0.24);
}

body.public-shell .btn-secondary{
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid var(--landing-border-strong);
  color: var(--landing-ink);
  box-shadow: none;
}

body.public-shell .btn-secondary:hover{
  border-color: rgba(145, 182, 199, 0.45);
  color: var(--landing-accent-strong);
}

body.public-shell .proof-strip{
  margin-top: 1.5rem;
  gap: 0.55rem;
}

body.public-shell .proof-pill{
  border-color: var(--landing-border);
  background: rgba(255, 255, 255, 0.82);
  color: var(--landing-text);
  padding: 0.42rem 0.8rem;
  box-shadow: none;
}

body.public-shell .section-process,
body.public-shell .section-values,
body.public-shell .section-faq,
body.public-shell .section-disclaimers{
  padding: 0 0 3.25rem;
}

/* --- Offering / What We Do section --- */

body.public-shell .section-offering{
  padding: 2.5rem 0 3.25rem;
  background: linear-gradient(180deg, #ffffff 0%, var(--landing-panel-soft) 100%);
}

body.public-shell .offering-intro{
  text-align: center;
  max-width: 680px;
  margin: 0 auto 1.5rem;
}

body.public-shell .offering-intro .section-subtitle{
  max-width: 60ch;
  margin-left: auto;
  margin-right: auto;
}

body.public-shell .offering-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}

body.public-shell .offering-card{
  position: relative;
  overflow: hidden;
  border: 1px solid var(--landing-border);
  border-radius: var(--landing-radius);
  background: var(--landing-surface);
  box-shadow: var(--landing-shadow-sm);
  padding: 1.6rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

body.public-shell .offering-card::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 4px;
  height: 100%;
  background: linear-gradient(180deg, var(--landing-accent-strong), var(--landing-accent));
  opacity: 0;
  transition: opacity 0.2s ease;
}

body.public-shell .offering-card:hover{
  transform: translateY(-4px);
  box-shadow: var(--landing-shadow-md);
}

body.public-shell .offering-card:hover::before{
  opacity: 1;
}

body.public-shell .offering-icon{
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  background: linear-gradient(135deg, var(--landing-accent), var(--landing-accent-strong));
  color: #fff;
  box-shadow: 0 6px 16px rgba(51, 65, 82, 0.18);
}

body.public-shell .offering-card h3{
  margin: 0 0 0.55rem;
  color: var(--landing-ink);
  font-size: 1.16rem;
  font-weight: 760;
}

body.public-shell .offering-card p{
  margin: 0;
  color: var(--landing-text);
  font-size: 0.95rem;
  line-height: 1.68;
}

@media (max-width: 767px){
  body.public-shell .offering-grid{
    grid-template-columns: 1fr;
  }

  body.public-shell .offering-card{
    border-radius: 22px;
  }
}


body.public-shell .section-title{
  color: var(--landing-ink);
  font-size: clamp(1.65rem, 2.8vw, 2.3rem);
  letter-spacing: -0.035em;
  text-wrap: balance;
}

body.public-shell .section-subtitle{
  color: var(--landing-text);
  line-height: 1.65;
}

body.public-shell .section-process .home-wrap,
body.public-shell .section-values .home-wrap,
body.public-shell .section-faq .home-wrap,
body.public-shell .section-disclaimers .home-wrap,
body.public-shell .section-cta-final .home-wrap{
  position: relative;
}

body.public-shell .section-process .home-wrap,
body.public-shell .section-faq .home-wrap,
body.public-shell .section-disclaimers .home-wrap,
body.public-shell .section-cta-final .home-wrap{
  max-width: 980px;
}

body.public-shell .lifecycle-panel,
body.public-shell .value-card,
body.public-shell .faq-item,
body.public-shell .disclaimers-list,
body.public-shell .cta-final-content{
  border: 1px solid var(--landing-border);
  border-radius: var(--landing-radius);
  background: var(--landing-surface);
  box-shadow: var(--landing-shadow-md);
}

body.public-shell .lifecycle-panel{
  padding: 1.6rem 1.8rem;
  position: relative;
  overflow: hidden;
}

body.public-shell .lifecycle-panel h2{
  margin-bottom: 1rem;
  color: var(--landing-ink);
  font-size: 1.28rem;
}

body.public-shell .lifecycle-panel ol{
  color: var(--landing-text);
  font-size: 0.98rem;
  line-height: 1.75;
}

body.public-shell .value-grid{
  gap: 1rem;
}

body.public-shell .value-card{
  position: relative;
  overflow: hidden;
  padding: 1.6rem;
  box-shadow: var(--landing-shadow-sm);
}

body.public-shell .value-card::before{
  background: linear-gradient(180deg, var(--landing-accent-strong), #afc5d0);
}

body.public-shell .value-card:hover{
  transform: translateY(-4px);
  box-shadow: var(--landing-shadow-md);
}

body.public-shell .value-card h3{
  margin-bottom: 0.7rem;
  color: var(--landing-ink);
  font-size: 1.16rem;
}

body.public-shell .value-card p{
  color: var(--landing-text);
  line-height: 1.68;
}


body.public-shell .section-faq .section-title,
body.public-shell .section-faq .section-subtitle,
body.public-shell .section-disclaimers .section-title{
  text-align: center;
}

body.public-shell .advisor-shell{
  width: 100%;
  max-width: 72rem;
  margin: 0 auto;
  overflow: hidden;
  border: 1px solid var(--landing-border-strong);
  border-radius: var(--radius-xl);
  background: var(--landing-surface);
  box-shadow: var(--landing-shadow-md);
}

body.public-shell .advisor-header{
  padding: 0.95rem 1rem;
  background: linear-gradient(180deg, rgba(175, 197, 208, 0.28) 0%, rgba(241, 247, 250, 0.94) 100%);
  border-bottom: 1px solid var(--landing-border);
}

body.public-shell .advisor-header-main{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-width: 0;
}

body.public-shell .advisor-logo{
  background: linear-gradient(135deg, var(--landing-accent), var(--landing-accent-strong));
  color: #fff;
  flex-shrink: 0;
}

body.public-shell .advisor-title{
  color: var(--landing-ink);
  letter-spacing: -0.01em;
  font-size: 1.05rem;
}

body.public-shell .advisor-subtitle{
  color: var(--landing-text);
  margin-top: 0.15rem;
  letter-spacing: 0.03em;
}

body.public-shell .advisor-header-btn{
  border-radius: 999px;
  border: 1px solid var(--landing-border-strong);
  background: rgba(255, 255, 255, 0.82);
  color: var(--landing-ink);
  font-weight: 700;
}

body.public-shell .advisor-header-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: flex-end;
  flex-shrink: 0;
}

body.public-shell .advisor-header-btn:hover{
  border-color: rgba(145, 182, 199, 0.42);
  background: #ffffff;
}

body.public-shell .advisor-header-btn-primary{
  background: linear-gradient(135deg, var(--landing-accent), var(--landing-accent-strong));
  border-color: transparent;
  color: #ffffff;
}

body.public-shell .advisor-tabs{
  border-bottom-color: var(--landing-border);
  background: rgba(255, 255, 255, 0.9);
}

body.public-shell .advisor-tab{
  min-height: 2.5rem;
  color: var(--landing-muted);
  font-size: 0.78rem;
  font-weight: 700;
}

body.public-shell .advisor-tab:hover{
  color: var(--landing-ink);
  background: rgba(145, 182, 199, 0.12);
}

body.public-shell .advisor-tab.is-active{
  color: var(--landing-ink);
  border-bottom-color: var(--landing-accent-strong);
}

body.public-shell .advisor-tab.is-completed{
  color: var(--landing-accent-strong);
}

body.public-shell .advisor-tab-num{
  background: rgba(15, 23, 42, 0.08);
  color: var(--landing-text);
}

body.public-shell .advisor-tab.is-active .advisor-tab-num{
  background: var(--landing-accent-strong);
}

body.public-shell .advisor-tab.is-completed .advisor-tab-num{
  background: var(--landing-accent);
  color: #fff;
}

body.public-shell .advisor-main{
  min-height: 27rem;
}

body.public-shell .advisor-chat-area{
  background: linear-gradient(180deg, #fbfdfe 0%, #ffffff 100%);
}

body.public-shell .advisor-messages{
  padding: 1rem;
  gap: 0.8rem;
  max-height: 23rem;
}

body.public-shell .advisor-avatar.is-ai{
  background: rgba(47, 74, 104, 0.1);
  color: #2f4a68;
}

body.public-shell .advisor-avatar.is-user{
  background: linear-gradient(135deg, var(--landing-accent), var(--landing-accent-strong));
}

body.public-shell .advisor-bubble{
  padding: 0.72rem 0.82rem;
  font-size: 0.91rem;
  line-height: 1.58;
}

body.public-shell .advisor-message:not(.is-user) .advisor-bubble{
  border-color: rgba(15, 23, 42, 0.08);
  background: #fff;
  color: var(--landing-ink);
  box-shadow: none;
}

body.public-shell .advisor-message.is-user .advisor-bubble{
  border: 1px solid rgba(117, 138, 154, 0.28);
  background: linear-gradient(180deg, #d8e5ec 0%, #c5d7e1 100%);
  color: var(--landing-ink);
}

body.public-shell .advisor-quick-btn{
  border-color: rgba(15, 23, 42, 0.08);
  background: #fff;
  color: var(--landing-ink);
  font-weight: 700;
}

body.public-shell .advisor-quick-btn:hover{
  border-color: rgba(145, 182, 199, 0.45);
  color: var(--landing-accent-strong);
}

body.public-shell .advisor-quick-btn.is-selected{
  background: linear-gradient(135deg, var(--landing-accent), var(--landing-accent-strong));
  border-color: transparent;
}

body.public-shell .advisor-input-bar{
  padding: 0.8rem;
  background: rgba(255, 255, 255, 0.94);
  border-top-color: var(--landing-border);
}

body.public-shell .advisor-input{
  min-height: 2.6rem;
  border-color: rgba(15, 23, 42, 0.1);
  border-radius: 16px;
  background: #f8fafc;
  color: var(--landing-ink);
}

body.public-shell .advisor-input::placeholder{
  color: var(--landing-muted);
}

body.public-shell .advisor-input:focus{
  border-color: rgba(145, 182, 199, 0.55);
  box-shadow: 0 0 0 3px rgba(145, 182, 199, 0.22);
}

body.public-shell .advisor-input-btn{
  border-color: rgba(15, 23, 42, 0.1);
  border-radius: 14px;
  color: var(--landing-muted);
}

body.public-shell .advisor-send-btn{
  border-radius: 14px;
  background: linear-gradient(135deg, var(--landing-accent), var(--landing-accent-strong));
  box-shadow: 0 14px 30px rgba(51, 65, 82, 0.22);
}

body.public-shell .advisor-sidebar{
  border-left-color: var(--landing-border);
  background: linear-gradient(180deg, #fbfdfe 0%, #f5f9fc 100%);
  padding: 0.95rem;
}

body.public-shell .advisor-sidebar-section{
  border-bottom-color: rgba(15, 23, 42, 0.06);
}

body.public-shell .advisor-sidebar-title{
  color: var(--landing-ink);
}

body.public-shell .advisor-sidebar-meta,
body.public-shell .advisor-profile-list,
body.public-shell .advisor-benefits-list,
body.public-shell .advisor-profile-label{
  color: var(--landing-text);
}

body.public-shell .advisor-benefits-list li::before{
  background: var(--landing-accent);
}

body.public-shell .advisor-cta{
  border-radius: 18px;
  background: linear-gradient(135deg, var(--landing-accent), var(--landing-accent-strong));
  box-shadow: 0 18px 34px rgba(51, 65, 82, 0.22);
}

body.public-shell .advisor-cta-sub{
  color: rgba(255, 255, 255, 0.8);
}

body.public-shell .advisor-typing{
  border-color: rgba(15, 23, 42, 0.08);
  background: #fff;
}

body.public-shell .advisor-typing span{
  background: rgba(117, 138, 154, 0.65);
}

body.public-shell .faq-grid{
  gap: 1rem;
}

body.public-shell .faq-item{
  padding: 1.4rem 1.5rem;
  box-shadow: var(--landing-shadow-sm);
}

body.public-shell .faq-item:hover{
  box-shadow: var(--landing-shadow-md);
}

body.public-shell .faq-item h3{
  color: var(--landing-ink);
  font-size: 1.02rem;
  line-height: 1.4;
}

body.public-shell .faq-item p{
  color: var(--landing-text);
  line-height: 1.66;
}

body.public-shell .disclaimers-list{
  margin: 0;
  padding: 1.2rem 1.4rem;
  list-style: none;
  display: grid;
  gap: 0.8rem;
  box-shadow: var(--landing-shadow-sm);
}

body.public-shell .disclaimers-list li{
  position: relative;
  padding-left: 1rem;
  color: var(--landing-muted);
  font-size: 0.86rem;
  line-height: 1.6;
}

body.public-shell .disclaimers-list li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0.55rem;
  width: 0.38rem;
  height: 0.38rem;
  border-radius: 999px;
  background: var(--landing-accent-strong);
}

body.public-shell .section-cta-final{
  padding: 0 0 4rem;
  background: linear-gradient(180deg, transparent 0%, rgba(145, 182, 199, 0.08) 100%);
}

body.public-shell .cta-final-content{
  position: relative;
  overflow: hidden;
  max-width: 760px;
  padding: 2rem 2.25rem;
  border-color: rgba(145, 182, 199, 0.28);
  box-shadow: var(--landing-shadow-lg);
}

body.public-shell .cta-final-content::before{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--landing-accent), var(--landing-accent-strong));
}

body.public-shell .cta-final-title{
  color: var(--landing-ink);
  font-size: clamp(1.8rem, 3vw, 2.5rem);
}

body.public-shell .cta-final-text{
  color: var(--landing-text);
  line-height: 1.7;
}

@media (min-width: 768px){
  body.public-shell .disclaimers-list{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 767px){
  body.public-shell .hero-banner{
    margin-top: 0;
    border-radius: 0;
  }

  body.public-shell .hero{
    padding: 2rem 0 0.35rem;
  }

  body.public-shell .home-wrap{
    padding: 0 0.85rem;
  }

  body.public-shell .hero-actions{
    justify-content: center;
  }

  body.public-shell .btn-lg{
    width: 100%;
  }

  body.public-shell .hero-title{
    font-size: clamp(2rem, 12vw, 3.2rem);
  }

  body.public-shell .lifecycle-panel,
  body.public-shell .value-card,
  body.public-shell .faq-item,
  body.public-shell .disclaimers-list,
  body.public-shell .cta-final-content{
    border-radius: 22px;
  }

  body.public-shell .mobile-nav-panel{
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }

  body.public-shell .cta-final-content{
    padding: 1.6rem 1.3rem;
  }
}
