@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600&display=swap');

/* =========================
   Base / Reset
   ========================= */
   :root{
    --container:1200px;
    --navy:#0b2029;        /* barra azul */
    --navy-2:#0f2a35;
    --text:#2b2f33;
    --muted:#6d767d;
    --gray-mid:#4b5563;    /* texto secundário (contato, cards) */
    --white:#ffffff;
    --gold:#b89a5b;
    --gold-strong:#e0a84a; /* títulos alaranjados */
    --bg:#ffffff;
    --soft:#f6f7f9;
    --radius:14px;
    --shadow:0 14px 34px rgba(0,0,0,.12);
    --border-light:rgba(0,0,0,.06);
    --border-mid:rgba(0,0,0,.12);
    --border-line:rgba(0,0,0,.15);
    --font_base:"Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }
  
  *{ box-sizing:border-box; }
  html{ scroll-behavior:smooth; }
  a:focus-visible,
  button:focus-visible{
    outline:2px solid var(--gold);
    outline-offset:2px;
  }
  body{
    margin:0;
    font-family:var(--font_base);
    color:var(--text);
    background:var(--bg);
    line-height:1.55;
  }
  
  img{ max-width:100%; display:block; }
  a{ color:inherit; }
  
  .container{
    width:min(var(--container), calc(100% - 56px));
    margin:0 auto;
  }
  
  .center{ text-align:center; }
  .muted{ color:var(--muted); }
  
  /* =========================
     HEADER (topbar + navbar) refinado
     ========================= */
  .site_header{
    position:sticky;
    top:0;
    z-index:50;
    background:var(--white);
  }
  
  /* ===== Topbar (branco) ===== */
  .topbar{
    background:var(--white);
    border-bottom:1px solid var(--border-light);
  }
  .topbar__inner{
    display:grid;
    grid-template-columns:1fr auto 1fr; /* endereço | logo | telefones */
    align-items:center;
    gap:50px;           /* antes 24px */
    padding:14px 0;     /* antes 18px */
  }
  .topbar__address{
    margin:0;
    color:var(--muted);
    font-size:14px;         /* levemente menor, mais elegante */
    line-height:1.3;
    text-align:right;       /* aproxima visualmente do logo */
    justify-self:end;       /* puxa para perto do centro */
  }
  .topbar__brand{
    justify-self:center;
    display:inline-flex;
    align-items:center;
    text-decoration:none;
  }
  .topbar__brand img{
    height:72px; /* antes 78px */
    width:auto;
    display:block;
  }
  .topbar__phones{
    justify-self:start;   /* antes era end */
    display:flex;
    flex-direction:column;
    gap:10px;
  }
  .topbar__phone{
    display:inline-flex;
    align-items:center;
    gap:12px;             /* "mais espaçado" do ícone pro texto */
    text-decoration:none;
    color:#5f676e;        /* um pouco mais "presente" */
    font-size:14px;
    font-weight:500;
  }
  .topbar__phone:hover{
    color:#3f464c;
  }
  .topbar__icon{
    width:15px;
    height:15px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    opacity:.95;
  }
  .topbar__icon svg{
    width:15px;
    height:15px;
    fill:#59b04f; /* verde ícones */
  }
  .topbar__text{
    white-space:nowrap;
  }
  
  /* ===== Navbar (azul) ===== */
  .navbar{
    background:var(--navy);
    box-shadow:0 6px 18px rgba(0,0,0,.18);
  }
  .navbar__inner{
    display:grid;
    grid-template-columns:1fr auto; /* menu central | social direita */
    align-items:center;
    padding:1px 0;  /* metade */
    gap:18px;
  }
  .nav_links{
    margin:0;
    padding:0;
    list-style:none;
    display:flex;
    justify-content:center;
    gap:44px; /* antes 54px */
  }
  .nav_links li{
    margin:0;
    padding:0;
  }
  .nav_links a{
    color:rgba(255,255,255,.65); /* mais cinza */
    text-decoration:none;
    letter-spacing:.22em;    /* mais sofisticado */
    font-size:13px;          /* antes 14px */
    text-transform:uppercase;
    padding:8px 0;
    display:inline-block;
  }
  .nav_links a:hover{
    color:rgba(255,255,255,.92);
  }
  .nav_social{
    display:inline-flex;
    align-items:center;
    gap:2px;
    justify-self:end;
    margin-right: 80px;
  }
  .nav_social__link{
    width:34px;
    height:34px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-decoration:none;
    color: #ffffff;   /* branco puro */
    opacity: 1;
  }
  .nav_social__link svg{
    width:22px;
    height:22px;
    fill:currentColor;
  }
  .nav_social__link:hover{
    opacity:1;
  }
  
  /* =========================
     Buttons
     ========================= */
  .btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.6rem;
    padding:.92rem 1.2rem;
    border-radius:999px;
    text-decoration:none;
    font-weight:800;
    letter-spacing:.06em;
    text-transform:uppercase;
    font-size:.85rem;
    border:none;
    cursor:pointer;
  }
  /* =========================
     HERO (início)
     ========================= */
  .hero{
    position:relative;
    min-height:78vh;                 /* ajuste se quiser mais alto/baixo */
    background:url("../img/hero.jpeg") center/cover no-repeat;
  }
  .hero::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(
      90deg,
      rgba(0,0,0,.55) 0%,
      rgba(80,60,20,.35) 55%,
      rgba(0,0,0,.35) 100%
    );
    pointer-events:none;
  }
  .hero__inner{
    position:relative;               /* pra ficar acima do overlay */
    z-index:1;
    min-height:inherit;
  }
  .hero__content{
    position:absolute;
    right:10%;                       /* controla o X */
    top:48%;                         /* controla o Y (descer/subir) */
    transform:translateY(-50%);      /* centraliza em relação ao top */
    text-align:left;
    color:#fff;
    max-width:520px;
  }
  .hero__title{
    font-weight:300;
    letter-spacing:1px;
    line-height:1.05;
    color:rgba(255,255,255,.92);
    font-size: clamp(28px, 4.2vw, 45px);
    text-shadow:0 1px 10px rgba(0,0,0,.25);
    margin-bottom:1.3rem;
  }
  .btn_primary{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding:14px 24px;
    border-radius:999px;
    color:rgba(255,255,255,.95);
    background:rgba(255,255,255,.10);
    text-decoration:none;
    text-transform:uppercase;
    letter-spacing:2px;
    font-size:16px;
    line-height:1.2;
    border:0;
  }
  .btn_primary:hover{
    background:rgba(255,255,255,.16);
  }
  .btn_arrow{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex-shrink:0;
    opacity:.9;
  }
  .btn_arrow svg{
    display:block;
    width:20px;
    height:20px;
  }
  .btn_primary__text{
    line-height:1.2;
  }
  
  /* =========================
     Sections
     ========================= */
  .section{
    padding:4rem 0;
  }
  
  .section__title{
    margin:0 0 1rem 0;
    color:var(--gold);
    font-weight:900;
    letter-spacing:.22em;   /* mais elegante */
    text-transform:uppercase;
    font-size:1.25rem;
  }
  
  .section__subtitle{
    font-size:1.2rem;
    margin-top:1.4rem;
    font-weight:900;
  }
  
  
  /* =========================
     Sobre (#sobre)
     ========================= */
  /* GRID do sobre */
  .about__grid{
    display:grid;
    grid-template-columns:auto 1fr;
    gap:80px;
    align-items:start;
  }
  .about__media{
    position:relative;
  }
  /* Caixa do carrossel com altura parecida com o original */
  .carousel{
    position:relative;
    border-radius:18px;
    overflow:hidden;
    background:#f3f3f3;
    aspect-ratio:3/4;   /* proporção vertical elegante */
    width:100%;
    max-width:420px;    /* controla largura */
    margin:0 auto;     /* centraliza */
  }
  .carousel__viewport{
    width:100%;
    height:100%;
    overflow:hidden;
  }
  .carousel__track{
    display:flex;
    height:100%;
    transition:transform .45s ease;
    will-change:transform;
  }
  .carousel__track img{
    flex:0 0 100%;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
  }
  .carousel__btn{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    z-index:5;
    width:48px;
    height:48px;
    border-radius:50%;
    border:1px solid rgba(11,32,41,.0);
    background:rgba(255,255,255,.20);
    backdrop-filter:blur(6px);
    color:rgb(11,32,41);
    font-size:22px;
    line-height:1;
    display:grid;
    place-items:center;
    cursor:pointer;
    transition:all .2s ease;
  }
  .carousel__btn:hover{
    background:rgba(11,32,41,.30);
    transform:translateY(-50%) scale(1.03);
  }
  .carousel__btn_prev{ left:16px; }
  .carousel__btn_next{ right:16px; }
  
  .about__text p{
    margin:0 0 .9rem 0;
    font-size:1.02rem;
    line-height:1.9;        /* mais leve */
    color:#46505a;
  }
  
  /* Sobre: títulos e texto específicos */
  .section_about .section__title{
    letter-spacing:.35em;
    font-weight:600;
    font-size:22px;
    color:#b79b57; /* dourado suave */
    margin-bottom:18px;
  }
  .section_about .section__subtitle{
    font-size:18px;       /* menor que o seu atual */
    font-weight:500;
    color:#1b1f24;
    margin:0 0 18px;
  }
  .section_about .about__text p{
    font-size:14px;       /* aqui é o principal */
    line-height:1.9;
    color:#666e78;
    margin:0 0 18px;
    max-width:620px;
    text-align: justify;
  }
  
  /* =========================
     Equipe (#equipe)
     ========================= */
  /* IMPORTANTE: não deixe background na section inteira */
  .section_team{
    background:transparent;
    color:#fff;
  }
  /* Fundo bege só no mini-hero */
  .team_hero_bg{
    background:#f4efe6;   /* bege/amarelado */
    padding:36px 0;        /* altura do bloco (reduzida) */
  }
  /* grid do hero */
  .team_hero__grid{
    display:grid;
    grid-template-columns:1fr 1.25fr;
    align-items:center;
    gap:60px;
  }
  /* título grande dourado */
  .team_hero__title{
    color:#caa455;        /* dourado */
    font-weight:300;      /* bem elegante */
    line-height:1.05;
    letter-spacing:.02em;
    font-size:38px;       /* reduzido */
    margin:18px 0 26px;
  }
  /* "Núcleo Odontológico Savassi" */
  .team_hero__kicker{
    color:#0b1e2b;
    font-weight:700;
    font-size:22px;
    margin:0;
  }
  /* link com setinha (sem botão) */
  .team_hero__text .btn_primary{
    background:transparent;
    border:0;
    padding:0;
    margin-top:1.5rem;     /* espaço entre título e botão */
    display:inline-flex;
    gap:8px;
    align-items:center;
    color:#0b1e2b;
    font-weight:600;
    letter-spacing:.12em;
    text-transform:uppercase;
    font-size:16px;
  }
  .team_hero__text .btn_primary .btn_arrow{
    font-size:18px;
    line-height:1;
  }
  .team_hero__image{
    border-radius:var(--radius);
    overflow:hidden;
    width:100%;
    height:320px;               /* altura fixa: força o crop e o object-position a funcionar */
  }
  /* imagem da equipe: corte na cintura (object-position só funciona com altura fixa no container) */
  .team_hero__image img{
    width:100%;
    height:100%;
    display:block;
    object-fit:cover;
    object-position:center 28%; /* 20–35: quanto menor, mais “sobe” o corte (cintura) */
  }
  
  /* Zona escura: faixa "Profissionais / APAIXONADOS" + cards */
  .team_cards_zone{
    background:var(--navy);
    color:#fff;
  }
  .team_cards_banner{
    padding:2.5rem 0;
    text-align:center;
  }
  .team_cards_banner__inner{
    max-width:var(--container);
    margin:0 auto;
    padding:0 1.5rem;
  }
  .team_cards_banner__kicker{
    margin:0 0 .35rem;
    font-size:1.1rem;
    font-weight:400;
    color:rgba(255,255,255,.9);
  }
  .team_cards_banner__title{
    margin:0;
    font-size:clamp(2rem, 4vw, 4rem);
    font-weight:700;
    letter-spacing:.02em;
    color:#fff;
  }
  /* Cards */
  .team_cards{
    margin-top:0;
    padding:2rem 0 3rem;
    display:grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap:1.4rem;                 /* mais respiro */
  }
  
  .team_card{
    padding:0 0 1.6rem 0;
    background:rgba(255,255,255,.06);
    border:none;
    box-shadow:none;
    border-radius:var(--radius);
    overflow:hidden;
  }
  
  /* Foto até a borda do card, sem moldura */
  .team_card__img-wrap{
    width:100%;
    height:280px;
    overflow:hidden;
    background:transparent;
  }
  .team_card__img-wrap img{
    width:100%;
    height:100%;
    display:block;
    object-fit:cover;
    object-position:center top;   /* rosto visível, corte na cintura */
  }
  
  .team_card h4{
    margin:.85rem 1.2rem .25rem;
    font-size:.92rem;
    letter-spacing:.10em;
    text-transform:uppercase;
    color:var(--gold-strong);
    font-weight:800;
  }
  
  .team_card p{
    margin:0 1.2rem 1rem;
    font-size:.95rem;
    line-height:1.5;
    color:rgba(255,255,255,.75);
  }
  
  /* =========================
     Especialidades (#especialidades)
     ========================= */
  .section_specs{
    background:var(--bg);
    padding-bottom:2rem;
  }
  /* Título + linha (compartilhado com .section_contact) */
  .section_specs__title,
  .section_contact__title{
    font-size:clamp(1.5rem, 3.5vw, 2rem);
    margin-bottom:.6rem;
  }
  .section_specs__line,
  .section_contact__line{
    width:100%;
    margin:0 0 1rem;
    border:0;
    border-top:2px solid var(--border-line);
  }
  .section_specs__subtitle{
    font-size:1.45rem;
    color:#000;
    margin:0 0 0.5rem;
    font-weight:500;
  }
  
  .specs_grid{
    margin-top:2rem;
    display:grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap:1.3rem;
  }
  
  .spec_card{
    background:#fff;
    border:none;
    border-radius:0;
    box-shadow:none;
    padding:1.6rem 1.4rem;
  }
  
  /* Wrapper do ícone: borda circular com espaço entre borda e imagem */
  .spec_card__icon{
    width:98px;
    height:98px;
    margin:0 auto 1.25rem;
    padding:15px;
    border-radius:50%;
    border:1px solid #000;
    opacity: 0.5;
    display:flex;
    align-items:center;
    justify-content:center;
    box-sizing:border-box;
  }
  .spec_card__icon img{
    width:100%;
    height:100%;
    display:block;
    object-fit:contain;
    opacity:.95;
  }
  
  .spec_card h4{
    text-align:center;
    margin:.2rem 0 .6rem;
    letter-spacing:.06em;
    text-transform:uppercase;
    font-size:1rem;
    color:var(--gold-strong);
    font-weight:800;
  }
  
  .spec_card p{
    margin:0;
    font-size:1rem;
    line-height:1.75;
    color:var(--gray-mid);
    text-align:center;
  }
  
  /* =========================
     Contato (#contato)
     ========================= */
  .section_contact{
    background:var(--soft);
    border-top:1px solid var(--border-light);
  }
  .section_contact__subtitle{
    font-size:1rem;
    color:var(--gray-mid);
    margin:0 auto 1.25rem;
    font-weight:500;
    max-width:480px;
    line-height:1.6;
    text-align:center;
  }
  
  .contact__info{
    margin:0 auto;
    max-width:480px;
    text-align:left;
  }
  .contact__name{
    margin:0 0 1rem;
    font-size:1.1rem;
    font-weight:700;
    color:var(--navy);
  }
  .contact__row{
    display:flex;
    align-items:center;
    gap:.6rem;
    margin-bottom:.75rem;
    text-decoration:none;
    color:var(--gray-mid);
    font-size:1rem;
  }
  .contact__row:last-child{ margin-bottom:0; }
  a.contact__row:hover{ color:var(--navy); }
  .contact__row.contact__address{
    cursor:default;
    align-items:flex-start;
  }
  .contact__icon{
    flex-shrink:0;
    width:22px;
    height:22px;
    color:#25a34f;
  }
  .contact__icon svg{
    width:100%;
    height:100%;
    fill:currentColor;
  }
  .contact__icon--whatsapp{ color:#25D366; }
  .contact__icon--phone,
  .contact__icon--location{ color:#25a34f; }
  .contact__text{ line-height:1.45; }
  
  /* Mapa */
  .contact__map{
    margin-top:2rem;
    border-radius:var(--radius);
    overflow:hidden;
    background:#e9edf2;
    border:1px solid var(--border-mid);
  }
  .contact__map iframe{
    width:100%;
    height:360px;
    border:0;
    border-radius:14px;
    display:block;
  }
  
  /* =========================
     Footer
     ========================= */
  .footer{
    background:var(--navy);
    border-top:none;
    padding:3.0rem 0;
    color:rgba(255,255,255,.9);
    font-size:0.875rem;
    line-height:1.5;
  }
  .footer .container{
    width:min(1560px, calc(100% - 56px));
  }
  .footer__inner{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:2rem;
    flex-wrap:wrap;
  }
  .footer__logo{
    flex-shrink:0;
    display:block;
  }
  .footer__logo img{
    height:72px;
    width:auto;
    display:block;
  }
  .footer__text{
    min-width:0;
  }
  .footer p{ margin:.25rem 0; color:inherit; line-height:1.5; }
  .footer .muted{ color:rgba(255,255,255,.65); }
  .footer strong{ font-weight:700; }
  
  /* =========================
     WhatsApp flutuante
     ========================= */
  .whatsapp_float{
    position:fixed;
    right:32px;
    bottom:32px;
    width:56px;
    height:56px;
    border-radius:50%;
    background:rgba(11,32,41,.85); /* azul do seu site */
    backdrop-filter:blur(6px);
    display:flex;
    align-items:center;
    justify-content:center;
    box-shadow:0 10px 30px rgba(0,0,0,.25);
    transition:all .3s ease;
    z-index:999;
    text-decoration:none;
    color:#fff;
  }
  .whatsapp_float svg{
    width:24px;
    height:24px;
    fill:#ffffff;
  }
  .whatsapp_float:hover{
    background:#25D366;
    transform:translateY(-4px);
    box-shadow:0 18px 40px rgba(0,0,0,.35);
  }
  
  /* =========================
     Responsive
     ========================= */
  /* mobile header: esconder endereço e links, mostrar botão */
  @media (max-width: 980px){
    .topbar__inner{
      grid-template-columns:1fr;
      text-align:center;
      gap:10px;
    }
    .topbar__address{ justify-self:center; }
    .topbar__phones{ justify-self:center; align-items:center; }
    .navbar__inner{
      grid-template-columns:1fr;
      gap:10px;
    }
    .nav_links{
      flex-wrap:wrap;
      gap:18px 28px;
    }
    .nav_social{ justify-self:center; }
  
    .about__grid{ grid-template-columns:1fr; }
    .carousel{ height:420px; }
  
    .team_hero__grid{ grid-template-columns:1fr; gap:28px; }
    .team_hero__title{ font-size:30px; }
  
    .team_cards{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
    .specs_grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  }
  
  /* ajuste no mobile pra não ficar espremido */
  @media (max-width: 768px){
    .hero__inner{
      justify-content:center;
      padding:5.2rem 0 4.2rem;
      text-align:center;
    }
  }
  
  @media (max-width: 520px){
    .hero{ min-height:68vh; }
    .hero__inner{ justify-content:flex-start; }
  
    .specs_grid{ grid-template-columns:1fr; }
    .team_cards{ grid-template-columns:1fr; }
  
    .topbar__brand img{ height:46px; }
  }