


:root{
  --bg: #fff;
  --ink: #0b1020;
  --muted: #5b6476;
  --soft: #f3f7fb;
  --soft-2:#f7fbff;
  --border:#e3eaf4;

  /* Paleta inspirada na sua logo */
  --brand:#1fb6d2;    /* teal */
  --brand-2:#3b82f6;  /* azul */
  --brand-3:#7c3aed;  /* roxo */

  --shadow: 0 12px 30px rgba(16, 24, 40, .10);
  --radius: 18px;

  --container: 1120px;

  --font-sans: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-serif: "Playfair Display", Georgia, serif;
}


*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
}

img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
ul{margin:0; padding-left:1.1rem}
p{margin:0 0 1rem}

.container{
  width:min(var(--container), calc(100% - 2.2rem));
  margin-inline:auto;
}

/* Acessibilidade */
.skip-link{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.skip-link:focus{
  left:1rem;
  top:1rem;
  width:auto;
  height:auto;
  padding:.75rem 1rem;
  border-radius:999px;
  background:#111827;
  color:#fff;
  z-index:9999;
}

/* Header */
.header{
  position:sticky;
  top:0;
  z-index:200;
  background:rgba(255,255,255,.85);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(234,223,224,.65);
}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.8rem 0;
}
.brand img{
  height:36px;
  width:auto;
}

.nav{display:flex; align-items:center; gap:1rem}
.nav__toggle{
  display:none;
  border:1px solid var(--border);
  background:#fff;
  border-radius:12px;
  padding:.55rem .6rem;
  cursor:pointer;
}
.nav__toggle span{
  display:block;
  width:22px;
  height:2px;
  background:#111827;
  margin:4px 0;
  border-radius:2px;
}
.nav__list{
  display:flex;
  align-items:center;
  gap:1.25rem;
  list-style:none;
  padding:0;
}
.nav__list a{
  font-weight:500;
  color:#111827;
  opacity:.92;
}
.nav__list a:hover{opacity:1}

/* Botões */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.85rem 1.15rem;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:600;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease, border-color .12s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn--primary{
  background: linear-gradient(90deg, var(--brand) 0%, var(--brand-2) 45%, var(--brand-3) 100%);
  color:#fff;
  box-shadow: 0 12px 26px rgba(59,130,246,.18);
}
.btn--primary:hover{box-shadow: 0 16px 34px rgba(124,58,237,.24)}
.btn--ghost{
  background:#fff;
  border-color:rgba(234,223,224,.9);
  color:#111827;
}
.btn--ghost:hover{border-color:rgba(217,79,127,.35)}
.btn--pill{padding:.65rem 1rem}
.btn--light{
  background:#fff;
  color:#111827;
  border-color:rgba(255,255,255,.6);
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
}
.btn--light:hover{transform:translateY(-1px)}

/* Hero */
.hero{
  position:relative;
  min-height: 72vh;
  display:grid;
  align-items:center;
  overflow:hidden;
}
.hero__bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 450px at 15% 10%, rgba(255,255,255,.85), transparent 60%),
    radial-gradient(700px 380px at 60% 20%, rgba(210,240,255,.45), transparent 70%),
    url("../img/hero-bloom-criativo-datiacelia.png") center/cover no-repeat;
  filter:saturate(1.05);
  transform:scale(1.02);
  z-index: 0;
}
.hero__fade{
  position:absolute;
  inset:auto 0 0 0;
  height:140px;
  background:linear-gradient(to bottom, transparent, #fff 70%);
}
.hero__inner{
  position:relative;
  padding: 4.6rem 0 4.2rem;
  max-width: 760px;
  z-index: 1;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  color: var(--brand-2);
  font-weight:600;
  background:rgba(255,255,255,.70);
  border:1px solid rgba(234,223,224,.65);
  padding:.45rem .85rem;
  border-radius:999px;
  margin-bottom:1rem;
}
.hero__title{
  font-family:var(--font-serif);
  font-weight:700;
  line-height:1.04;
  letter-spacing:-.02em;
  font-size: clamp(2.1rem, 4.2vw, 3.5rem);
  margin:0 0 1rem;
}
.accent{ color: var(--brand-2); }
.hero__text{
  color:#374151;
  font-size:1.05rem;
  max-width: 56ch;
  margin-bottom:1.6rem;
}
.hero__actions{
  display:flex;
  gap:.9rem;
  flex-wrap:wrap;
}

/* Seções */
.section{
  padding: 4.2rem 0;
}
.section--muted{
  background: linear-gradient(to bottom, var(--soft-2), #fff);
}
.section--clean{padding-top:3.2rem}
.section__kicker{
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--brand);
  margin-bottom:.65rem;
  font-weight:700;
}
.section__title{
  font-family:var(--font-serif);
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  line-height:1.15;
  margin:0 0 .9rem;
}
.section__sub{
  color:var(--muted);
  max-width: 70ch;
  margin:0 auto 1.8rem;
}
.section__text{color:#374151}
.section__text.subtle{color:var(--muted)}
.section__text.max{max-width: 72ch; margin-inline:auto}

.center{text-align:center}

/* Layouts */
.grid-2{
  display:grid;
  grid-template-columns: 1.2fr .9fr;
  gap: 2rem;
  align-items:start;
}
@media (max-width: 920px){
  .grid-2{grid-template-columns:1fr}
}

/* Cards */
.card{
  border-radius: var(--radius);
  padding: 1.4rem 1.4rem;
  box-shadow: var(--shadow);
}
.card--soft{
  background: #fff;
  border: 1px solid rgba(234,223,224,.9);
}
.card--border{
  background:#fff;
  border:1px solid rgba(234,223,224,.95);
}
.card__title{
  margin:0 0 1rem;
  font-family:var(--font-serif);
  font-size:1.15rem;
}
.checklist{
  list-style:none;
  padding:0;
  margin: .35rem 0 0;
  display:grid;
  gap:.7rem;
  color:#111827;
  font-weight:600;
}
.quote{
  font-family:var(--font-serif);
  font-style:italic;
  color:#111827;
  opacity:.88;
  border-left: 3px solid rgba(217,79,127,.35);
  padding-left: .9rem;
  margin-top:1rem;
}

.bullet{
  list-style:none;
  padding:0;
  display:grid;
  gap:.7rem;
  margin: 1rem 0 0;
}
.dot{
  display:inline-block;
  width:10px;
  height:10px;
  border-radius:999px;
  background: linear-gradient(90deg, var(--brand), var(--brand-2));
  margin-right:.55rem;
  vertical-align:middle;
}

.two-col-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.2rem;
}
.two-col-list ul{
  margin:0;
  padding-left:1rem;
  color:#374151;
}
@media (max-width: 520px){
  .two-col-list{grid-template-columns:1fr}
}

/* Cards 4 */
.cards-4{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
@media (max-width: 980px){
  .cards-4{grid-template-columns: repeat(2, 1fr)}
}
@media (max-width: 560px){
  .cards-4{grid-template-columns: 1fr}
}
.mini-card{
  background:#fff;
  border:1px solid rgba(234,223,224,.95);
  border-radius: 16px;
  padding:1.25rem 1.1rem;
  box-shadow: 0 10px 22px rgba(16,24,40,.06);
}
.mini-card--highlight{
  border-color: rgba(217,79,127,.35);
  box-shadow: 0 14px 30px rgba(217,79,127,.10);
}
.mini-card__icon{
  width:40px;
  height:40px;
  border-radius: 14px;
  background: rgba(217,79,127,.10);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:.75rem;
}
.mini-card__title{
  margin:0 0 .65rem;
  font-family:var(--font-serif);
  font-size:1.15rem;
}
.mini-card__list{
  color:#374151;
  margin:0 0 .9rem;
}
.mini-card__list li{margin:.25rem 0}
.mini-card__note{
  color:var(--muted);
  font-size:.95rem;
  margin:0;
}

/* Cards 3 */
.cards-3{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
@media (max-width: 900px){
  .cards-3{grid-template-columns:1fr}
}
.info-card{
  background:#fff;
  border: 1px solid rgba(234,223,224,.95);
  border-radius: 16px;
  padding: 1.25rem 1.2rem;
  box-shadow: 0 10px 22px rgba(16,24,40,.06);
}
.info-card__icon{
  width:40px;
  height:40px;
  border-radius: 14px;
  background: rgba(124,58,237,.10);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:.75rem;
}
.info-card__title{
  margin:0 0 .5rem;
  font-family:var(--font-serif);
}
.info-card__text{
  color:var(--muted);
  margin:0;
}

/* Portfólio */
.portfolio{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 1rem;
  align-items:stretch;
}
@media (max-width: 900px){
  .portfolio{grid-template-columns:1fr}
}
.portfolio__item{
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid rgba(234,223,224,.85);
  box-shadow: 0 14px 30px rgba(16,24,40,.08);
  background:#fff;
  position:relative;
  transform: translateZ(0);
}
.portfolio__item img{
  width:100%;
  height:100%;
  object-fit: cover;
  aspect-ratio: 16 / 10;
  transition: transform .25s ease;
}
.portfolio__item:hover img{transform:scale(1.03)}
/* 4 itens em “mosaico” parecido com o print */
.portfolio{
  grid-template-areas:
    "a b"
    "c d";
}
.portfolio__item:nth-child(1){grid-area:a}
.portfolio__item:nth-child(2){grid-area:b}
.portfolio__item:nth-child(3){grid-area:c}
.portfolio__item:nth-child(4){grid-area:d}

/* CTA */
.cta{
  padding: 4.4rem 0;
  background: linear-gradient(90deg, var(--brand-2) 0%, var(--brand-3) 55%, var(--brand) 100%);
}
.cta__inner{
  text-align:center;
  color:#fff;
}
.cta__title{
  font-family:var(--font-serif);
  margin:0 0 .5rem;
  font-size: clamp(1.7rem, 3.2vw, 2.3rem);
}
.cta__text{
  opacity:.92;
  margin:0 0 1.35rem;
}

/* Footer */
.footer{
  background:#0b1020;
  color:rgba(255,255,255,.88);
  padding: 3rem 0 1.5rem;
}
.footer__grid{
  display:grid;
  grid-template-columns: 1.35fr 1fr 1fr 1fr;
  gap: 1.4rem;
}
@media (max-width: 960px){
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 560px){
  .footer__grid{grid-template-columns:1fr}
}
.footer__logo{
  font-weight:700;
  letter-spacing:.04em;
  margin-bottom:.65rem;
}
.footer__text{color:rgba(255,255,255,.72)}
.footer__title{
  margin:0 0 .75rem;
  font-family:var(--font-serif);
  color:#fff;
}
.footer__links{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:.5rem;
}
.footer__links a{color:rgba(255,255,255,.74)}
.footer__links a:hover{color:#fff}

.social{display:flex; gap:.6rem}
.social__btn{
  width:38px;
  height:38px;
  border-radius: 12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border: 1px solid rgba(255,255,255,.16);
  color:#fff;
  background: rgba(255,255,255,.06);
}
.social__btn:hover{background: rgba(255,255,255,.10)}

.footer__bottom{
  border-top: 1px solid rgba(255,255,255,.10);
  margin-top: 1.6rem;
  padding-top: 1.2rem;
  font-size:.92rem;
  color:rgba(255,255,255,.65);
}

/* WhatsApp flutuante */
.whatsapp-float{
  position:fixed;
  right: 16px;
  bottom: 16px;
  z-index: 500;
  display:flex;
  align-items:center;
  gap:.55rem;
  padding: .75rem .95rem;
  border-radius: 999px;
  background:#0ea5e9;
  color:#fff;
  box-shadow: 0 18px 36px rgba(0,0,0,.22);
  border: 1px solid rgba(255,255,255,.25);
  transform: translateZ(0);
}
.whatsapp-float:hover{transform: translateY(-1px)}
.whatsapp-float__icon{
  width:26px;
  height:26px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background: rgba(255,255,255,.16);
}
.whatsapp-float__text{font-weight:700}

/* Mobile menu */
@media (max-width: 860px){
  .nav__toggle{display:inline-flex}
  .nav__list{
    position:absolute;
    right: 1.1rem;
    top: 64px;
    flex-direction:column;
    align-items:stretch;
    background:#fff;
    border:1px solid rgba(234,223,224,.95);
    border-radius: 16px;
    padding: .9rem;
    gap:.7rem;
    box-shadow: var(--shadow);
    min-width: 220px;
    display:none;
  }
  .nav__list.is-open{display:flex}
}

.no-copy{
  -webkit-user-select: none;
  user-select: none;
}

img{
  -webkit-user-drag: none;
  user-drag: none;
}

