:root {
      --bg: #f5f8fe;
      --surface: #ffffff;
      --surface-2: #eef4ff;
      --ink: #15233f;
      --muted: #5d6f8e;
      --brand: #0f4aa3;
      --brand-dark: #0a377f;
      --sage: #4f89e8;
      --terracotta: #d5a029;
      --gold: #d6a634;
      --line: rgba(10,55,127,.14);
      --shadow: 0 24px 70px rgba(10,55,127,.17);
      --radius-xl: 34px;
      --radius-lg: 24px;
      --radius-md: 18px;
      --max: 1180px;
    }

    * { box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body {
      margin: 0;
      color: var(--ink);
      background:
        radial-gradient(circle at top left, rgba(214,166,52,.18), transparent 34rem),
        radial-gradient(circle at 85% 10%, rgba(79,137,232,.15), transparent 28rem),
        var(--bg);
      font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      line-height: 1.55;
      overflow-x: hidden;
    }
    a { color: inherit; text-decoration: none; }
    img { max-width: 100%; display: block; }
    .container { width: min(var(--max), calc(100% - 44px)); margin: 0 auto; }

    .topbar {
      position: sticky;
      top: 0;
      z-index: 50;
      backdrop-filter: blur(18px);
      background: rgba(245,248,254,.88);
      border-bottom: 1px solid rgba(10,55,127,.08);
    }
    .nav {
      min-height: 76px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 22px;
    }
    .brand { display: flex; align-items: center; gap: 13px; min-width: 0; }
    .brand-logo {
      width: 56px;
      height: 56px;
      object-fit: contain;
      flex: 0 0 auto;
      filter: drop-shadow(0 10px 22px rgba(10,55,127,.16));
    }
    .brand-mark {
      width: 44px;
      height: 44px;
      border-radius: 18px;
      background: linear-gradient(135deg, var(--brand-dark), var(--terracotta));
      color: #fff;
      display: grid;
      place-items: center;
      font-weight: 800;
      letter-spacing: -.04em;
      box-shadow: 0 12px 28px rgba(10,55,127,.22);
      flex: 0 0 auto;
    }
    .brand-name { font-weight: 800; letter-spacing: -.03em; font-size: 1.06rem; white-space: nowrap; color: var(--brand-dark); }
    .brand-sub { color: var(--gold); font-size: .8rem; margin-top: -2px; white-space: nowrap; font-weight: 700; }
    .nav-links { display: flex; align-items: center; gap: 24px; color: var(--muted); font-size: .92rem; }
    .nav-links a { transition: .2s ease; }
    .nav-links a:hover { color: var(--brand-dark); }
    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      min-height: 48px;
      padding: 0 20px;
      border-radius: 999px;
      font-weight: 750;
      letter-spacing: -.01em;
      border: 1px solid transparent;
      transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
      cursor: pointer;
      white-space: nowrap;
    }
    .btn:hover { transform: translateY(-2px); }
    .btn-primary { background: linear-gradient(135deg, var(--brand-dark), var(--terracotta)); color: #fff; box-shadow: 0 18px 36px rgba(15,74,163,.28); }
    .btn-secondary { background: rgba(255,255,255,.78); color: var(--brand-dark); border-color: rgba(10,55,127,.14); }
    .btn-small { min-height: 42px; padding-inline: 16px; font-size: .9rem; }

    .hero { padding: 78px 0 52px; position: relative; }
    .hero-grid { display: grid; grid-template-columns: 1.07fr .93fr; gap: 54px; align-items: center; }
    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      padding: 8px 13px;
      border: 1px solid rgba(10,55,127,.12);
      background: rgba(255,255,255,.76);
      color: var(--brand-dark);
      border-radius: 999px;
      font-size: .86rem;
      font-weight: 750;
      box-shadow: 0 12px 34px rgba(10,55,127,.08);
    }
    .dot { width: 8px; height: 8px; border-radius: 999px; background: var(--sage); box-shadow: 0 0 0 5px rgba(79,137,232,.16); }
    h1, h2, h3 { margin: 0; letter-spacing: -.055em; line-height: 1.02; }
    h1 { font-size: clamp(2.55rem, 6vw, 5.75rem); margin-top: 22px; max-width: 860px; }
    .highlight { color: var(--brand); }
    .hero-lead {
      max-width: 680px;
      color: var(--muted);
      font-size: clamp(1.05rem, 1.5vw, 1.26rem);
      margin: 24px 0 0;
    }
    .hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
    .hero-proof {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 13px;
      margin-top: 38px;
      max-width: 720px;
    }
    .proof-card {
      background: rgba(255,255,255,.78);
      border: 1px solid rgba(10,55,127,.10);
      border-radius: 20px;
      padding: 17px 16px;
      box-shadow: 0 18px 38px rgba(10,55,127,.08);
    }
    .proof-card strong { display:block; font-size: 1.02rem; color: var(--brand-dark); letter-spacing: -.02em; }
    .proof-card { backdrop-filter: blur(10px); }
    .proof-card span { display:block; color: var(--muted); font-size: .88rem; margin-top: 3px; }

    .portrait-wrap { position: relative; min-height: 620px; display: grid; place-items: center; }
    .portrait-glow {
      position: absolute;
      inset: 36px 0 0 40px;
      border-radius: 46px;
      background:
        radial-gradient(circle at 30% 20%, rgba(255,255,255,.72), transparent 24rem),
        linear-gradient(145deg, rgba(15,74,163,.18), rgba(79,137,232,.18));
      transform: rotate(-4deg);
      filter: blur(.1px);
    }
    .portrait-card {
      position: relative;
      width: min(420px, 100%);
      border-radius: 44px;
      padding: 14px;
      background: rgba(255,255,255,.82);
      border: 1px solid rgba(10,55,127,.12);
      box-shadow: var(--shadow);
    }
    .portrait-card::before {
      content: "";
      position: absolute;
      inset: -24px -24px auto auto;
      width: 118px;
      height: 118px;
      border-radius: 999px;
      background: rgba(214,166,52,.24);
      z-index: -1;
    }
    .portrait {
      height: 560px;
      width: 100%;
      object-fit: cover;
      object-position: center;
      border-radius: 34px;
      filter: saturate(1.02) contrast(1.01);
    }
    .floating-note {
      position: absolute;
      left: -26px;
      bottom: 42px;
      width: 235px;
      padding: 17px 17px 16px;
      background: rgba(7,40,95,.93);
      color: #fff;
      border: 1px solid rgba(255,255,255,.12);
      border-radius: 22px;
      box-shadow: 0 22px 50px rgba(7,40,95,.24);
    }
    .floating-note small { color: rgba(255,255,255,.72); display:block; margin-bottom: 5px; }
    .floating-note strong { display:block; line-height: 1.2; letter-spacing: -.02em; }

    section { padding: 76px 0; }
    .section-head { max-width: 760px; margin-bottom: 34px; }
    .kicker { color: var(--terracotta); text-transform: uppercase; letter-spacing: .16em; font-size: .76rem; font-weight: 850; margin-bottom: 12px; }
    h2 { font-size: clamp(2.05rem, 4vw, 4rem); }
    .section-head p { color: var(--muted); font-size: 1.05rem; margin: 16px 0 0; }

    .split { display: grid; grid-template-columns: .98fr 1.02fr; gap: 32px; align-items: stretch; }
    .panel {
      background: rgba(255,255,255,.80);
      border: 1px solid rgba(10,55,127,.11);
      border-radius: var(--radius-xl);
      box-shadow: 0 24px 60px rgba(10,55,127,.09);
    }
    .panel-pad { padding: clamp(26px, 4vw, 42px); }
    .large-text { color: var(--muted); font-size: 1.06rem; margin: 0; }
    .quote-line {
      border-left: 4px solid var(--gold);
      padding-left: 18px;
      margin-top: 24px;
      color: var(--brand-dark);
      font-size: 1.18rem;
      font-weight: 720;
      letter-spacing: -.02em;
      line-height: 1.42;
    }
    .feature-list { display: grid; gap: 12px; margin-top: 28px; }
    .feature { display: grid; grid-template-columns: 35px 1fr; gap: 12px; align-items: start; }
    .feature-icon {
      width: 35px;
      height: 35px;
      border-radius: 13px;
      background: rgba(79,137,232,.14);
      display: grid;
      place-items: center;
      color: var(--brand-dark);
      font-weight: 900;
    }
    .feature strong { display:block; letter-spacing: -.02em; }
    .feature span { color: var(--muted); font-size: .95rem; display:block; margin-top: 2px; }

    .presence-card {
      min-height: 100%;
      background:
        linear-gradient(145deg, rgba(8,47,117,.97), rgba(15,74,163,.92)),
        radial-gradient(circle at top right, rgba(214,166,52,.26), transparent 22rem);
      color: #fff;
      overflow: hidden;
      position: relative;
    }
    .presence-card::after {
      content: "";
      position:absolute;
      right:-90px;
      bottom:-100px;
      width:260px;
      height:260px;
      border-radius:999px;
      background: rgba(255,255,255,.08);
    }
    .presence-card p { color: rgba(255,255,255,.75); margin: 12px 0 0; }
    .presence-list { display: grid; gap: 10px; margin-top: 28px; position: relative; z-index: 1; }
    .presence-list div {
      padding: 13px 14px;
      border: 1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.07);
      border-radius: 16px;
      color: rgba(255,255,255,.92);
    }

    .grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
    .care-card {
      padding: 24px;
      border-radius: 24px;
      border: 1px solid rgba(10,55,127,.10);
      background: rgba(255,253,249,.75);
      box-shadow: 0 18px 42px rgba(10,55,127,.07);
      min-height: 176px;
    }
    .care-card .num { font-weight: 900; color: var(--gold); font-size: .88rem; letter-spacing: .08em; }
    .care-card h3 { margin-top: 14px; font-size: 1.24rem; letter-spacing: -.035em; }
    .care-card p { color: var(--muted); margin: 10px 0 0; font-size: .96rem; }

    .conditions {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-top: 22px;
    }
    .pill {
      padding: 10px 13px;
      background: rgba(15,74,163,.08);
      color: var(--brand-dark);
      border: 1px solid rgba(10,55,127,.09);
      border-radius: 999px;
      font-weight: 700;
      font-size: .9rem;
    }

    .testimonial {
      position: relative;
      padding: clamp(28px, 5vw, 52px);
      overflow: hidden;
    }
    .stars { color: #d5a029; letter-spacing: .12em; font-size: 1.08rem; }
    blockquote {
      margin: 18px 0 0;
      font-size: clamp(1.22rem, 2vw, 1.62rem);
      line-height: 1.42;
      letter-spacing: -.035em;
      max-width: 880px;
    }
    .author { margin-top: 24px; color: var(--muted); }
    .author strong { color: var(--ink); }

    .contact-grid { display: grid; grid-template-columns: .84fr 1.16fr; gap: 22px; align-items: stretch; }
    .contact-list { display: grid; gap: 14px; margin-top: 24px; }
    .contact-item {
      padding: 17px;
      border-radius: 18px;
      background: rgba(238,244,255,.82);
      border: 1px solid rgba(10,55,127,.09);
    }
    .contact-item small { display:block; color: var(--muted); margin-bottom: 3px; }
    .contact-item strong { letter-spacing: -.02em; }
    .map {
      width: 100%;
      min-height: 430px;
      height: 100%;
      border: 0;
      border-radius: 30px;
      filter: saturate(.9) contrast(.98);
    }

    .final-cta {
      padding: 64px 0 86px;
    }
    .cta-box {
      position: relative;
      overflow: hidden;
      border-radius: 38px;
      padding: clamp(34px, 6vw, 62px);
      background:
        radial-gradient(circle at 12% 20%, rgba(214,166,52,.24), transparent 24rem),
        linear-gradient(135deg, #082b69, #0f4aa3);
      color: #fff;
      box-shadow: 0 26px 80px rgba(10,55,127,.22);
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 28px;
      align-items: center;
    }
    .cta-box h2 { max-width: 780px; }
    .cta-box p { color: rgba(255,255,255,.74); max-width: 690px; margin: 16px 0 0; font-size: 1.05rem; }
    .cta-box .btn { background: #fff; color: var(--brand-dark); box-shadow: 0 18px 36px rgba(0,0,0,.18); }

    footer {
      padding: 30px 0;
      border-top: 1px solid rgba(10,55,127,.10);
      color: var(--muted);
      font-size: .92rem;
    }
    .footer-grid { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
    .whatsapp-float {
      position: fixed;
      right: 18px;
      bottom: 18px;
      width: 58px;
      height: 58px;
      border-radius: 22px;
      background: #25D366;
      color: #fff;
      display: grid;
      place-items: center;
      box-shadow: 0 16px 35px rgba(37,211,102,.33);
      z-index: 60;
      font-size: 27px;
      line-height: 1;
    }
    .whatsapp-float:hover { transform: translateY(-2px); }
    .highlight { color: var(--brand); text-shadow: 0 8px 24px rgba(15,74,163,.08); }

    @media (max-width: 980px) {
      .nav-links { display: none; }
      .hero { padding-top: 48px; }
      .hero-grid, .split, .contact-grid, .cta-box { grid-template-columns: 1fr; }
      .portrait-wrap { min-height: auto; margin-top: 14px; }
      .portrait-card { width: min(460px, 100%); }
      .portrait { height: 520px; }
      .floating-note { left: 18px; bottom: 26px; }
      .grid-3 { grid-template-columns: 1fr; }
      .hero-proof { grid-template-columns: 1fr; }
      .cta-box .btn { justify-self: start; }
    }

    @media (max-width: 620px) {
      .container { width: min(100% - 28px, var(--max)); }
      .nav { min-height: 68px; }
      .brand-logo { width: 46px; height: 46px; }
      .brand-name { font-size: .98rem; }
      .brand-sub { font-size: .74rem; }
      .btn-small { display:none; }
      h1 { font-size: clamp(2.35rem, 13vw, 3.55rem); }
      .hero-lead { font-size: 1rem; }
      .hero-actions { flex-direction: column; }
      .btn { width: 100%; }
      .portrait-card { border-radius: 32px; padding: 10px; }
      .portrait { height: 438px; border-radius: 25px; object-position: center top; }
      .portrait-glow { inset: 26px 14px 0 18px; }
      .floating-note { position: relative; width: 100%; left: auto; bottom: auto; margin-top: 12px; border-radius: 18px; }
      section { padding: 55px 0; }
      .panel { border-radius: 26px; }
      .contact-item { padding: 15px; }
      .map { min-height: 330px; border-radius: 24px; }
      .final-cta { padding-bottom: 70px; }
      .whatsapp-float { width: 54px; height: 54px; border-radius: 20px; }
    }