 :root{
        /* Paleta: calma + confiança + acolhimento */
        --bg: #F8FAFC;          /* quase branco (leve, limpo) */
        --surface: #FFFFFF;     /* cartões */
        --text: #0F172A;        /* slate-900 */
        --muted: #475569;       /* slate-600 */
        --primary: #0F766E;     /* teal-700 (confiança/saúde) */
        --primary-2: #14B8A6;   /* teal-500 (destaques) */
        --accent: #7C3AED;      /* violeta (humanidade/acolhimento) */
        --soft: #F1F5F9;        /* slate-100 */
        --border: #E2E8F0;      /* slate-200 */
        --danger: #DC2626;      /* red-600 */
        --shadow: 0 10px 30px rgba(2, 6, 23, .08);
        --radius: 18px;
        --radius-sm: 12px;
        --maxw: 1120px;
        }

        *{ box-sizing: border-box; }
        html, body{ height: 100%; }
        body{
        margin:0;
        font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji", "Segoe UI Emoji";
        color: var(--text);
        background:
            radial-gradient(900px 500px at 15% 0%, rgba(20,184,166,.18), transparent 60%),
            radial-gradient(800px 500px at 85% 10%, rgba(124,58,237,.14), transparent 55%),
            var(--bg);
        line-height: 1.5;
        }

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

        .container{ width: min(var(--maxw), calc(100% - 40px)); margin: 0 auto; }

        /* Header */
        header{
        position: sticky;
        top: 0;
        z-index: 50;
        backdrop-filter: blur(10px);
        background: rgba(248,250,252,.65);
        border-bottom: 1px solid rgba(226,232,240,.7);
        }
        .nav{
        display:flex;
        align-items:center;
        justify-content: space-between;
        padding: 14px 0;
        gap: 16px;
        }
        .brand{
        display:flex; align-items:center; gap: 10px;
        font-weight: 800;
        letter-spacing: .2px;
        }
        .logo{
        width: 38px; height: 38px;
        border-radius: 12px;
        background: linear-gradient(135deg, rgba(15,118,110,1), rgba(124,58,237,.9));
        box-shadow: 0 10px 20px rgba(15,118,110,.25);
        }
        .brand small{ display:block; font-weight: 600; color: var(--muted); letter-spacing: 0; }

        nav ul{ list-style:none; margin:0; padding:0; display:flex; gap: 14px; align-items:center; }
        nav a{
        padding: 10px 10px;
        border-radius: 12px;
        color: var(--muted);
        font-weight: 600;
        }
        nav a:hover{ background: rgba(226,232,240,.6); color: var(--text); }

        .btn{
        display:inline-flex;
        align-items:center;
        justify-content:center;
        gap:10px;
        padding: 12px 16px;
        border-radius: 14px;
        border: 1px solid rgba(226,232,240,.9);
        background: var(--surface);
        box-shadow: 0 8px 24px rgba(2,6,23,.06);
        font-weight: 700;
        cursor:pointer;
        transition: transform .08s ease, box-shadow .18s ease, background .18s ease;
        white-space: nowrap;
        }
        .btn:hover{ transform: translateY(-1px); box-shadow: 0 14px 30px rgba(2,6,23,.10); }
        .btn:active{ transform: translateY(0); }
        .btn-primary{
        border: none;
        background: linear-gradient(135deg, var(--primary), var(--accent));
        color: white;
        }
        .btn-primary:hover{ filter: brightness(1.03); }

        .hamburger{ display:none; }

        /* Hero */
        .hero{ padding: 56px 0 28px; }
        .hero-grid{
        display:grid;
        grid-template-columns: 1.15fr .85fr;
        gap: 26px;
        align-items: stretch;
        }
        .hero-card{
        background: rgba(255,255,255,.7);
        border: 1px solid rgba(226,232,240,.9);
        box-shadow: var(--shadow);
        border-radius: var(--radius);
        padding: 28px;
        }
        .kicker{
        display:inline-flex;
        align-items:center;
        gap: 10px;
        padding: 8px 12px;
        border-radius: 999px;
        background: rgba(20,184,166,.12);
        border: 1px solid rgba(20,184,166,.25);
        color: #0b3d39;
        font-weight: 800;
        letter-spacing: .2px;
        font-size: 13px;
        }
        h1{
        margin: 14px 0 10px;
        font-size: clamp(28px, 3.3vw, 44px);
        line-height: 1.1;
        letter-spacing: -.6px;
        }
        .lead{
        margin: 0 0 18px;
        color: var(--muted);
        font-size: 16.5px;
        max-width: 56ch;
        }
        .hero-actions{ display:flex; flex-wrap: wrap; gap: 12px; margin-top: 14px; }

        .badges{
        margin-top: 18px;
        display:flex; flex-wrap:wrap; gap:10px;
        }
        .badge{
        font-size: 13px;
        color: var(--muted);
        background: rgba(241,245,249,.7);
        border: 1px solid rgba(226,232,240,.9);
        padding: 8px 10px;
        border-radius: 999px;
        font-weight: 700;
        }

        .side{
        display:flex;
        flex-direction: column;
        gap: 14px;
        height: 100%;
        }
        .quote{
        position: relative;
        overflow: hidden;
        }
        .quote:before{
        content:"";
        position:absolute;
        inset:-40px -60px auto auto;
        width:180px; height:180px;
        background: radial-gradient(circle at 30% 30%, rgba(124,58,237,.25), transparent 60%);
        transform: rotate(18deg);
        }
        .quote p{ margin: 0; color: var(--muted); font-size: 15.5px; }
        .quote strong{ color: var(--text); }
        .mini{
        display:grid;
        grid-template-columns: 1fr 1fr;
        gap: 10px;
        }
        .mini .tile{
        background: rgba(255,255,255,.75);
        border: 1px solid rgba(226,232,240,.9);
        border-radius: 16px;
        padding: 14px;
        box-shadow: 0 10px 30px rgba(2,6,23,.06);
        }
        .tile h3{ margin: 0 0 6px; font-size: 14px; letter-spacing: .2px; }
        .tile p{ margin:0; color: var(--muted); font-size: 13.5px; }

        /* Sections */
        section{ padding: 42px 0; }
        .section-title{
        display:flex;
        justify-content: space-between;
        align-items: flex-end;
        gap: 16px;
        margin-bottom: 16px;
        }
        .section-title h2{
        margin:0;
        font-size: 26px;
        letter-spacing: -.3px;
        }
        .section-title p{
        margin:0;
        color: var(--muted);
        max-width: 60ch;
        }

        .grid-3{
        display:grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 14px;
        }
        .card{
        background: rgba(255,255,255,.8);
        border: 1px solid rgba(226,232,240,.9);
        border-radius: var(--radius);
        padding: 18px;
        box-shadow: 0 10px 28px rgba(2,6,23,.06);
        }
        .card h3{ margin: 6px 0 8px; font-size: 18px; }
        .card p{ margin: 0; color: var(--muted); }

        .icon{
        width: 44px; height: 44px;
        border-radius: 14px;
        background: rgba(20,184,166,.12);
        border: 1px solid rgba(20,184,166,.25);
        display:grid; place-items:center;
        font-weight: 900;
        color: #0b3d39;
        }
        .icon.alt{
        background: rgba(124,58,237,.10);
        border: 1px solid rgba(124,58,237,.22);
        color: #3b1a7a;
        }

        /* About */
        .about{
        display:grid;
        grid-template-columns: .95fr 1.05fr;
        gap: 16px;
        align-items: start;
        }
        .about .photo{
        background: linear-gradient(135deg, rgba(15,118,110,.18), rgba(124,58,237,.12));
        border: 1px solid rgba(226,232,240,.9);
        border-radius: var(--radius);
        min-height: 320px;
        position: relative;
        overflow: hidden;
        box-shadow: var(--shadow);
        }
        .about .photo:after{
        content:"";
        position:absolute;
        inset:auto -40px -40px auto;
        width: 220px; height: 220px;
        background: radial-gradient(circle at 30% 30%, rgba(20,184,166,.35), transparent 60%);
        transform: rotate(12deg);
        }
        .about .photo .hint{
        position:absolute; inset:auto 18px 18px 18px;
        background: rgba(255,255,255,.85);
        border: 1px solid rgba(226,232,240,.9);
        border-radius: 16px;
        padding: 12px 14px;
        color: var(--muted);
        font-weight: 700;
        font-size: 13px;
        }
        .about .content{
        background: rgba(255,255,255,.8);
        border: 1px solid rgba(226,232,240,.9);
        border-radius: var(--radius);
        padding: 20px;
        box-shadow: 0 10px 28px rgba(2,6,23,.06);
        }
        .about .content p{ color: var(--muted); }
        .list{
        margin: 12px 0 0;
        padding: 0;
        list-style: none;
        display:grid;
        gap: 10px;
        }
        .list li{
        display:flex; gap: 10px; align-items: flex-start;
        padding: 12px;
        border-radius: 16px;
        background: rgba(241,245,249,.7);
        border: 1px solid rgba(226,232,240,.9);
        }
        .check{
        width: 22px; height: 22px;
        border-radius: 8px;
        background: rgba(20,184,166,.18);
        border: 1px solid rgba(20,184,166,.28);
        display:grid; place-items:center;
        font-weight: 900;
        color: #0b3d39;
        flex: 0 0 auto;
        margin-top: 1px;
        }

        /* Contact + Form */
        .contact-grid{
        display:grid;
        grid-template-columns: 1fr 1fr;
        gap: 14px;
        align-items: start;
        }
        .contact-card{ padding: 20px; }
        .contact-items{ margin-top: 10px; display:grid; gap: 10px; }
        .contact-item{
        display:flex; gap: 10px; align-items:flex-start;
        padding: 12px;
        border-radius: 16px;
        background: rgba(241,245,249,.7);
        border: 1px solid rgba(226,232,240,.9);
        color: var(--muted);
        }

        form{ display:grid; gap: 12px; }
        .field{
        display:grid; gap: 6px;
        }
        label{ font-weight: 800; font-size: 13px; }
        input, select, textarea{
        width: 100%;
        padding: 12px 12px;
        border-radius: 14px;
        border: 1px solid rgba(226,232,240,.95);
        background: rgba(255,255,255,.92);
        color: var(--text);
        outline: none;
        font-size: 15px;
        }
        input:focus, select:focus, textarea:focus{
        border-color: rgba(20,184,166,.7);
        box-shadow: 0 0 0 4px rgba(20,184,166,.14);
        }
        textarea{ min-height: 120px; resize: vertical; }
        .help{
        font-size: 12.5px; color: var(--muted);
        display:flex; justify-content: space-between; gap: 12px;
        }
        .error{
        display:none;
        color: var(--danger);
        font-size: 13px;
        font-weight: 700;
        }
        .row{
        display:grid;
        grid-template-columns: 1fr 1fr;
        gap: 12px;
        }
        .submit-row{
        display:flex;
        gap: 10px;
        align-items:center;
        justify-content: space-between;
        flex-wrap: wrap;
        margin-top: 2px;
        }
        .privacy{
        color: var(--muted);
        font-size: 12.5px;
        max-width: 70ch;
        }

        /* FAQ */
        details{
        background: rgba(255,255,255,.82);
        border: 1px solid rgba(226,232,240,.9);
        border-radius: 16px;
        padding: 14px 14px;
        box-shadow: 0 10px 28px rgba(2,6,23,.05);
        }
        details summary{
        cursor:pointer;
        font-weight: 900;
        list-style: none;
        }
        details p{ margin: 10px 0 0; color: var(--muted); }
        details summary::-webkit-details-marker{ display:none; }

        footer{
        padding: 28px 0 50px;
        color: var(--muted);
        }
        footer .foot{
        display:flex;
        justify-content: space-between;
        gap: 14px;
        flex-wrap: wrap;
        padding-top: 16px;
        border-top: 1px solid rgba(226,232,240,.85);
        }

        /* Floating WhatsApp */
        .wa-float{
        position: fixed;
        right: 18px;
        bottom: 18px;
        z-index: 60;
        }

        /* Responsive */
        @media (max-width: 980px){
        .hero-grid{ grid-template-columns: 1fr; }
        .mini{ grid-template-columns: 1fr 1fr; }
        .grid-3{ grid-template-columns: 1fr; }
        .about{ grid-template-columns: 1fr; }
        .contact-grid{ grid-template-columns: 1fr; }
        }
        @media (max-width: 720px){
        nav ul{ display:none; }
        .hamburger{ display:inline-flex; }
        .row{ grid-template-columns: 1fr; }
        .mini{ grid-template-columns: 1fr; }
        }

        /* Reduced motion */
        @media (prefers-reduced-motion: reduce){
        .btn{ transition: none; }
        html:focus-within{ scroll-behavior:auto; }
        }
        /* ===========================
   MOBILE FIRST – HEADER FIX
   =========================== */

/* Base mobile (default) */
header .nav {
  flex-wrap: wrap;
  align-items: flex-start;
}

/* Bloco de identidade (nome + registro) */
.brand {
  width: 100%;
  flex-direction: row;
  align-items: center;
}

/* Esconde botão "Agendar" do topo no mobile */
header .btn-primary {
  display: none;
}

/* Botão "Agendar consulta" reposicionado abaixo do nome */
header .nav::after {
  content: "";
  width: 100%;
}

header .nav .btn-primary + .btn-primary,
header .nav .btn-primary:last-child {
  display: none;
}

/* Cria área exclusiva para CTA mobile */
header .nav {
  row-gap: 10px;
}

/* CTA mobile abaixo do nome */
header .nav .btn-primary.mobile-cta {
  display: inline-flex;
  width: 100%;
  justify-content: center;
  margin-top: 6px;
}

/* ===========================
   DESKTOP (mantém tudo igual)
   =========================== */
@media (min-width: 721px) {
  header .nav {
    flex-wrap: nowrap;
    align-items: center;
  }

  header .btn-primary {
    display: inline-flex;
  }

  header .nav .btn-primary.mobile-cta {
    display: none;
  }
}

/* ===========================
   ABOUT – IMAGE CENTER FIX
   =========================== */

.about .photo {
  display: grid;
  place-items: center;
}

/* Reaproveita .hint como wrapper visual da imagem */
.about .photo .hint {
  position: relative;
  inset: auto;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
}

/* Imagem centralizada e responsiva */
.about .photo .hint img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: cover;
  border-radius: var(--radius);
}

/* ===========================
   ABOUT – IMAGE SIZE CONTROL
   =========================== */

/* Container da foto */
.about .photo {
  max-width: 420px;   /* largura confortável */
  max-height: 520px;  /* altura elegante */
  width: 100%;
  margin: 0 auto;     /* centraliza no layout */
}

/* Wrapper da imagem */
.about .photo .hint {
  width: 100%;
  height: 100%;
}

/* Imagem em si */
.about .photo .hint img {
  width: 100%;
  height: 100%;
  max-width: 420px;
  max-height: 520px;
  object-fit: cover;
}

@media (max-width: 720px) {
  .about .photo {
    max-width: 320px;
    max-height: 380px;
  }

  .about .photo .hint img {
    max-width: 320px;
    max-height: 380px;
  }
}

