/* =========================================================
   SEMENTES DO ALECRIM — Design System
   Base creme quente + blocos de cor (intensidade ~40)
   ========================================================= */

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

/* Europa Grotesk No 2 SH — Light (texto) / Medium (títulos).
   Fonte comercial (Scangraphic): carregada via cópia local se instalada/enviada.
   Fallback elegante: Hanken Grotesk (grotesca neutra). Para o render exato,
   envie os arquivos .woff2 e eu ligo o src real aqui. */
@font-face{
  font-family:'Europa Grotesk No 2 SH Light';
  src:local('Europa Grotesk No 2 SH Light'), local('EuropaGroteskNo2SH-Light'), local('Europa Grotesk No 2 SH');
  font-weight:300; font-display:swap;
}
@font-face{
  font-family:'Europa Grotesk No 2 SH Medium';
  src:local('Europa Grotesk No 2 SH Medium'), local('EuropaGroteskNo2SH-Medium'), local('Europa Grotesk No 2 SH');
  font-weight:500; font-display:swap;
}

:root{
  /* ---- Brand palette (paleta clara/arejada) ---- */
  --sol:        rgb(244,223,113);   /* amarelo suave */
  --sol-soft:   #F7EBAE;
  --laranja:    rgb(215,232,221);   /* verde-claro (antigo laranja) */
  --laranja-soft:#E6F0EA;
  --alecrim:    #149B7A;   /* verde do raminho / "ALECRIM" */
  --alecrim-soft:#9AD8C6;
  --vermelho:   #E0503A;
  --roxo:       #8E5BB0;
  --azul:       #4F93CF;
  --azul-soft:  #BFE0F2;
  --coral:      #F2967E;
  --rosa:       #E58BB0;

  /* ---- Neutros (bege → branco) ---- */
  --cream:      #FFFFFF;
  --cream-2:    #FFFFFF;
  --paper:      #FFFFFF;
  --ink:        #26302B;   /* texto: verde-carvão (antigo marrom) */
  --ink-soft:   #5C6B62;
  --ink-faint:  #9AA79E;
  --line:       #E6ECE8;

  /* ---- Tunable via Tweaks ---- */
  --accent:     var(--alecrim);
  --radius:     0px;
  --radius-sm:  0px;
  --radius-lg:  0px;
  --hero-dark:  0.16;   /* intensidade do escurecimento do hero (tweakável) */

  --font-display: 'Europa Grotesk No 2 SH Medium', 'Hanken Grotesk', system-ui, sans-serif;
  --font-body:    'Europa Grotesk No 2 SH Light', 'Hanken Grotesk', system-ui, sans-serif;

  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --shadow: 0 22px 60px -28px rgba(46,38,32,.45);
  --shadow-sm: 0 10px 30px -18px rgba(46,38,32,.5);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--ink);
  font-size:18px;
  line-height:1.6;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--sol); color:var(--ink); }

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:500;
  line-height:1.04;
  letter-spacing:-0.015em;
  margin:0;
  text-wrap:balance;
}

.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(72px,10vw,140px); position:relative; }

/* ---------- Eyebrow ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--font-display);
  font-weight:600; font-size:.78rem;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--ink-soft);
}
.eyebrow::before{
  content:""; width:10px; height:10px;
  background:var(--accent); flex:none;
}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ink); --fg:var(--cream);
  display:inline-flex; align-items:center; gap:.6em; white-space:nowrap;
  font-family:var(--font-display); font-weight:600; font-size:1rem;
  background:var(--bg); color:var(--fg);
  padding:.6em 1.5em; border-radius:0; border:none; cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .2s;
  box-shadow:var(--shadow-sm);
}
.btn:hover{ transform:translateY(-3px); }
.btn .arrow{ transition:transform .25s; }
.btn:hover .arrow{ transform:translate(4px,0); }
.btn--sol{ --bg:var(--sol); --fg:var(--ink); }
.btn--laranja{ --bg:var(--laranja); --fg:var(--ink); }
.btn--alecrim{ --bg:var(--alecrim); --fg:#fff; }
.btn--ghost{ --bg:transparent; --fg:var(--ink); box-shadow:inset 0 0 0 1.5px var(--ink); }
.btn--ghost:hover{ --bg:var(--ink); --fg:#fff; }
.btn--lg{ font-size:1.08rem; padding:.62em 1.7em; }

/* ---------- Decorative dots (REMOVIDOS a pedido) ---------- */
.dot, .page-hero__dots, .hero__faixa, .matricula__deco{ display:none !important; }

/* ---------- Pill tag ---------- */
.tag{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--font-display); font-weight:600; font-size:.8rem;
  padding:.4em .9em; border-radius:0;
  background:var(--paper); color:var(--ink);
  box-shadow:inset 0 0 0 1.5px var(--line);
}

/* ---------- Reveal on scroll ---------- */
[data-reveal]{ opacity:0; transform:translateY(34px); transition:opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal][data-delay="1"]{ transition-delay:.08s; }
[data-reveal][data-delay="2"]{ transition-delay:.16s; }
[data-reveal][data-delay="3"]{ transition-delay:.24s; }
[data-reveal][data-delay="4"]{ transition-delay:.32s; }
[data-reveal][data-delay="5"]{ transition-delay:.40s; }
[data-reveal][data-delay="6"]{ transition-delay:.48s; }
/* zoom-in reveal variant */
[data-reveal="zoom"]{ transform:translateY(20px) scale(.97); }
[data-reveal="zoom"].in{ transform:none; }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1 !important; transform:none !important; }
  html{ scroll-behavior:auto; }
}

/* ---------- Image slot styling ---------- */
image-slot{ background:var(--cream-2); box-shadow:var(--shadow-sm); }

/* =========================================================
   HEADER / NAV
   ========================================================= */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:60;
  --head-fg:#fff;
  background:transparent;
  border-bottom:1px solid transparent;
  transition:background 0s, backdrop-filter 0s, border-color .3s ease, box-shadow .3s ease;
}
/* top-down scrim: darkest where the logo sits, dissolving into the photo */
.site-header::before{
  content:""; position:absolute; left:0; right:0; top:0; height:300px; z-index:-1;
  pointer-events:none; opacity:1; transition:opacity .5s ease;
  background:linear-gradient(180deg,
    rgba(20,15,10,.62) 0%,
    rgba(20,15,10,.42) 28%,
    rgba(20,15,10,.20) 55%,
    rgba(20,15,10,.06) 80%,
    rgba(20,15,10,0) 100%);
}
.site-header.scrolled::before{ opacity:0; }
.site-header.scrolled{
  background:rgba(255,255,255,.9);
  -webkit-backdrop-filter:blur(16px) saturate(1.3);
  backdrop-filter:blur(16px) saturate(1.3);
  border-bottom-color:rgba(46,38,32,.10);
  box-shadow:0 6px 28px -22px rgba(46,38,32,.6);
  transition:background .28s ease, backdrop-filter .28s ease, border-color .3s ease, box-shadow .3s ease;
}
.nav{
  display:flex; flex-direction:column; align-items:center; gap:1.05rem;
  padding:26px var(--gutter) 18px;
  max-width:var(--maxw); margin-inline:auto;
  transition:padding .42s cubic-bezier(.2,.8,.2,1), gap .42s ease;
}
.nav__logo{
  display:flex; align-items:center; justify-content:center;
  transition:transform .42s ease;
}
.nav__logo-full{
  height:124px; width:auto; display:block;
  filter:drop-shadow(0 5px 20px rgba(20,15,10,.5));
  transition:height .42s cubic-bezier(.2,.8,.2,1), filter .45s ease;
}
.nav__logo-icon{
  display:none; height:50px; width:auto;
  filter:drop-shadow(0 3px 12px rgba(20,15,10,.4));
  transition:height .42s cubic-bezier(.2,.8,.2,1);
}
/* on scroll → single row: sun icon on the LEFT, links on the right */
.site-header.scrolled .nav{
  flex-direction:row; align-items:center; justify-content:space-between;
  padding:9px var(--gutter); gap:1.5rem;
}
.site-header.scrolled .nav__logo{ margin-right:auto; }
.site-header.scrolled .nav__logo-full{ display:none; }
.site-header.scrolled .nav__logo-icon{ display:block; height:46px; filter:none; }
.site-header.scrolled .nav__links{ flex-wrap:nowrap; gap:1.35rem; }
.site-header.scrolled .nav__links a{ font-size:.76rem; letter-spacing:.06em; }
.nav__links{ display:flex; gap:2.1rem; align-items:center; justify-content:center; flex-wrap:wrap; }
.nav__links a{
  font-family:var(--font-display); font-weight:600; font-size:.82rem;
  text-transform:uppercase; letter-spacing:.1em; white-space:nowrap;
  color:var(--head-fg, var(--ink)); position:relative; padding:.3em 0;
  transition:color .4s ease;
}
.nav__links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px;
  background:var(--accent); border-radius:2px; transition:right .3s cubic-bezier(.2,.8,.2,1);
}
.nav__links a:hover::after{ right:0; }
.nav__links a[aria-current="page"]{ color:var(--head-fg); }
.nav__links a[aria-current="page"]:not(.btn)::after{ right:0; background:var(--accent); }
.nav__links a.btn[aria-current="page"]{ box-shadow:var(--shadow-sm), 0 0 0 3px color-mix(in srgb, var(--alecrim) 28%, transparent); }

/* ---- header adapts to the background it sits over ---- */
.site-header[data-theme="dark"] .nav__links a{ text-shadow:0 1px 16px rgba(20,15,10,.45); }
.site-header[data-theme="dark"] .nav__links a::after{ background:#fff; }
.site-header[data-theme="dark"] .nav__links .btn--alecrim{
  background:#fff; color:var(--ink); text-shadow:none;
}
.site-header.scrolled .nav__links a{ text-shadow:none; }
.nav__toggle{ display:none; }
.nav__toggle span{ background:var(--head-fg) !important; }

@media (max-width: 980px){
@media (max-width: 980px){
  .nav{ flex-direction:row; justify-content:center; padding:13px var(--gutter); gap:0; position:relative; }
  .nav__logo-full{ height:54px; filter:drop-shadow(0 2px 10px rgba(20,15,10,.4)); }
  .nav__logo-icon{ display:none; }
  .site-header.scrolled .nav{ flex-direction:row; justify-content:center; padding:9px var(--gutter); }
  .site-header.scrolled .nav__logo{ margin-right:0; }
  .site-header.scrolled .nav__logo-full{ display:block; height:42px; filter:none; }
  .site-header.scrolled .nav__logo-icon{ display:none; }
  .nav__links{
    position:fixed; inset:70px 0 auto 0;
    flex-direction:column; align-items:flex-start; gap:0;
    background:var(--paper); padding:1rem var(--gutter) 2rem;
    border-bottom:1px solid var(--line);
    transform:translateY(-130%); transition:transform .4s cubic-bezier(.2,.8,.2,1);
    box-shadow:var(--shadow);
  }
  .nav__links.open{ transform:none; }
  .nav__links a{ width:100%; padding:.9rem 0; border-bottom:1px solid var(--line); font-size:1rem; letter-spacing:.08em; color:var(--ink) !important; text-shadow:none !important; }
  .nav__links .btn{ margin-top:1rem; }
  .nav__toggle{
    display:inline-flex; flex-direction:column; gap:5px; background:none; border:none;
    cursor:pointer; padding:8px; position:absolute; right:calc(var(--gutter) - 8px); top:50%; transform:translateY(-50%);
  }
  .nav__toggle span{ width:26px; height:2.5px; background:var(--head-fg); border-radius:2px; transition:.3s; }
  .site-header.scrolled .nav__toggle span{ background:var(--ink); }
  .nav__toggle.open span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
  .nav__toggle.open span:nth-child(2){ opacity:0; }
  .nav__toggle.open span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }
}

/* =========================================================
   FOOTER (paleta clara · CTA de matrícula · logo)
   ========================================================= */
.footer{ background:#fff; }
.footer__main{ background:var(--sol); color:var(--ink); }
.footer__main .wrap{
  display:grid; grid-template-columns:1.3fr .9fr; gap:clamp(36px,6vw,90px);
  padding-block:clamp(54px,7vw,96px); align-items:start;
}
.footer__brand{ font-family:var(--font-display); font-weight:600; font-size:1.2rem; margin-bottom:.55rem; color:var(--ink); }
.footer__info p, .footer__info a{ display:block; color:var(--ink-soft); margin-bottom:.16rem; font-size:1rem; line-height:1.34; }
.footer__info a{ transition:color .2s; }
.footer__info a:hover{ color:var(--ink); }
.footer__phone{ font-weight:600; color:var(--ink) !important; }
.footer__social{ display:flex; gap:12px; margin:1.5rem 0 .4rem; }
.footer__social a{ width:40px; height:40px; display:grid; place-items:center; background:var(--ink); color:#fff; margin:0; transition:background .2s, transform .2s; }
.footer__social a:hover{ background:var(--alecrim); transform:translateY(-2px); }
.footer__social svg{ width:19px; height:19px; }
.footer__policies{ margin-top:1.3rem; }
.footer__policies a{ font-size:.9rem; text-decoration:underline; text-underline-offset:3px; color:var(--ink-soft); margin-bottom:.45rem; }
.footer__cta h3{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.4rem,2.3vw,2rem); color:var(--ink); margin-bottom:.8rem; line-height:1.1; }
.footer__cta p{ color:var(--ink-soft); margin-bottom:1.5rem; max-width:34ch; }
.footer__logo-strip{ background:#fff; display:flex; justify-content:center; padding:clamp(22px,2.6vw,30px) var(--gutter); }
.footer__logo-strip img{ height:62px; width:auto; }
@media (max-width:760px){ .footer__main .wrap{ grid-template-columns:1fr; gap:40px; } }

/* =========================================================
   SLOT EDIT BADGE — "Trocar foto" sobre qualquer overlay
   (só aparece no editor; image-slot tem shadow mode:open)
   ========================================================= */
.has-slot-edit{ position:relative; }
.slot-edit{
  position:absolute; top:10px; right:10px; z-index:40;
  display:inline-flex; align-items:center; gap:.45em;
  font-family:var(--font-display); font-weight:600; font-size:.76rem;
  background:rgba(255,255,255,.95); color:#26302B;
  border:none; padding:.5em .85em; cursor:pointer; line-height:1;
  box-shadow:0 6px 18px rgba(20,15,10,.22);
  opacity:0; transform:translateY(-4px); pointer-events:none;
  transition:opacity .2s, transform .2s;
}
.slot-edit svg{ width:14px; height:14px; }
.has-slot-edit:hover > .slot-edit,
.slot-edit:focus-visible{ opacity:1; transform:none; pointer-events:auto; }
.slot-edit:hover{ background:#fff; }
.slot-edit--hero{ top:auto; bottom:clamp(20px,4vh,38px); right:var(--gutter); }
/* floating variant (segue o slot sob o cursor, acima de qualquer overlay) */
.slot-edit--float{ position:fixed; opacity:0; transform:translateY(-4px); pointer-events:none; transition:opacity .15s, transform .15s; }
.slot-edit--float.show{ opacity:1; transform:none; pointer-events:auto; }

/* =========================================================
   SHARED SUBPAGE HERO (rhythm: each page a different tint)
   ========================================================= */
.page-hero{
  position:relative; overflow:hidden;
  padding-block:clamp(96px,11vw,150px) clamp(54px,7vw,92px);
  background:
    radial-gradient(115% 130% at 86% -18%, color-mix(in srgb, var(--hero-tint, var(--alecrim)) 26%, transparent), transparent 58%),
    radial-gradient(90% 120% at 8% 120%, color-mix(in srgb, var(--hero-tint, var(--alecrim)) 14%, transparent), transparent 55%),
    var(--cream-2);
}
.page-hero .wrap{ position:relative; z-index:2; max-width:1000px; }
.page-hero h1{ font-size:clamp(2.6rem,6.4vw,5rem); margin:.7rem 0 1.1rem; }
.page-hero h1 .hl{ color:var(--hero-tint, var(--alecrim)); }
.page-hero__lead{ font-size:clamp(1.1rem,1.7vw,1.35rem); color:var(--ink-soft); max-width:56ch; }
.page-hero__dots span,
.page-hero .dot{ position:absolute; border-radius:50%; }

/* breadcrumb (shared) */
.breadcrumb{ display:flex; gap:.5rem; align-items:center; flex-wrap:wrap; white-space:nowrap; font-family:var(--font-display); font-size:.9rem; color:var(--ink-soft); font-weight:500; }
.breadcrumb a{ transition:color .2s; }
.breadcrumb a:hover{ color:var(--ink); }
.breadcrumb [aria-current]{ color:var(--hero-tint, var(--alecrim)); }

/* shared centered section header */
.sec-head{ max-width:640px; margin:0 auto clamp(40px,6vw,64px); text-align:center; }
.sec-head .eyebrow{ justify-content:center; }
.sec-head h2{ font-size:clamp(2rem,4.4vw,3.4rem); margin-top:.6rem; }
.sec-head p{ color:var(--ink-soft); margin-top:1rem; }

/* =========================================================
   CONTACT FORM (Contato)
   ========================================================= */
.contato .wrap{ display:grid; grid-template-columns:1.25fr .75fr; gap:clamp(28px,4vw,56px); align-items:start; }
.form-card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(26px,3.4vw,46px); box-shadow:var(--shadow-sm);
}
.form-card > .eyebrow{ margin-bottom:.4rem; }
.form-card h2{ font-size:clamp(1.7rem,3.4vw,2.5rem); margin-bottom:.6rem; }
.form-card .form-card__sub{ color:var(--ink-soft); margin-bottom:2rem; max-width:46ch; }

.form{ display:grid; grid-template-columns:1fr 1fr; gap:18px 20px; }
.field{ display:flex; flex-direction:column; gap:.5rem; }
.field--full{ grid-column:1 / -1; }
.field label{ font-family:var(--font-display); font-weight:600; font-size:.92rem; color:var(--ink); }
.field label .req{ color:var(--vermelho); margin-left:.15em; }
.field .input,
.field textarea,
.field select{
  font-family:var(--font-body); font-size:1rem; color:var(--ink);
  background:var(--cream); border:1.6px solid var(--line); border-radius:0;
  padding:.85rem 1rem; outline:none; width:100%;
  transition:border-color .2s, box-shadow .2s, background .2s;
}
.field textarea{ resize:vertical; min-height:120px; line-height:1.5; }
.field select{ appearance:none; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9' fill='none'%3E%3Cpath d='M1 1l6 6 6-6' stroke='%236E6053' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 1rem center; padding-right:2.6rem; }
.field .input::placeholder,
.field textarea::placeholder{ color:var(--ink-faint); }
.field .input:focus,
.field textarea:focus,
.field select:focus{
  border-color:var(--accent); background:var(--paper);
  box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent);
}
.field .input:user-invalid,
.field textarea:user-invalid{ border-color:var(--vermelho); box-shadow:0 0 0 4px color-mix(in srgb, var(--vermelho) 14%, transparent); }

/* chip-style radio group */
.chips-input{ display:flex; flex-wrap:wrap; gap:10px; }
.chip-opt{ position:relative; }
.chip-opt input{ position:absolute; opacity:0; pointer-events:none; }
.chip-opt span{
  display:inline-flex; align-items:center; gap:.45em;
  font-family:var(--font-display); font-weight:600; font-size:.92rem;
  padding:.55em 1.05em; border-radius:0; cursor:pointer;
  background:var(--cream); color:var(--ink-soft);
  box-shadow:inset 0 0 0 1.6px var(--line); transition:.2s;
}
.chip-opt span::before{ content:""; width:9px; height:9px; background:var(--ink-faint); transition:.2s; }
.chip-opt:hover span{ color:var(--ink); box-shadow:inset 0 0 0 1.6px var(--ink-faint); }
.chip-opt input:checked + span{ color:#fff; background:var(--accent); box-shadow:inset 0 0 0 1.6px var(--accent); }
.chip-opt input:checked + span::before{ background:#fff; }
.chip-opt input:focus-visible + span{ box-shadow:inset 0 0 0 1.6px var(--accent), 0 0 0 4px color-mix(in srgb, var(--accent) 20%, transparent); }

.form__actions{ grid-column:1 / -1; display:flex; align-items:center; gap:1.2rem; flex-wrap:wrap; margin-top:.4rem; }
.form__note{ font-size:.86rem; color:var(--ink-faint); max-width:30ch; }
.btn[type="submit"]{ border:none; }

/* success state */
.form-success{
  display:none; text-align:center; padding:clamp(30px,5vw,56px) clamp(20px,4vw,40px);
}
.form-card.sent .form{ display:none; }
.form-card.sent > .eyebrow,
.form-card.sent > h2,
.form-card.sent > .form-card__sub{ display:none; }
.form-card.sent .form-success{ display:block; animation:wordIn .5s cubic-bezier(.2,.9,.2,1); }
.form-success .tick{
  width:74px; height:74px; margin:0 auto 1.3rem;
  background:var(--alecrim); display:grid; place-items:center; color:#fff;
  box-shadow:0 14px 34px -14px color-mix(in srgb, var(--alecrim) 80%, transparent);
}
.form-success h3{ font-size:1.7rem; margin-bottom:.6rem; }
.form-success p{ color:var(--ink-soft); max-width:40ch; margin:0 auto; }

/* contact info sidebar */
.contato__aside{ display:flex; flex-direction:column; gap:14px; position:sticky; top:108px; }
.info-card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-sm);
  padding:1.4rem 1.5rem; box-shadow:var(--shadow-sm);
}
.info-card h3{ font-size:1.08rem; margin-bottom:1rem; display:flex; align-items:center; gap:.55rem; }
.info-card h3 .ic{ width:32px; height:32px; display:grid; place-items:center; flex:none; font-size:1rem; }
.info-row{ display:flex; flex-direction:column; gap:.15rem; margin-bottom:.9rem; }
.info-row:last-child{ margin-bottom:0; }
.info-row .k{ font-family:var(--font-display); font-weight:600; font-size:.82rem; color:var(--ink-faint); text-transform:uppercase; letter-spacing:.08em; }
.info-row .v{ font-size:1.02rem; color:var(--ink); }
.info-row a.v{ transition:color .2s; }
.info-row a.v:hover{ color:var(--accent); }
.hours-row{ display:flex; justify-content:space-between; gap:1rem; padding:.5rem 0; border-bottom:1px dashed var(--line); font-size:.98rem; }
.hours-row:last-child{ border-bottom:none; }
.hours-row span:first-child{ color:var(--ink-soft); }
.hours-row span:last-child{ font-family:var(--font-display); font-weight:600; }

@media (max-width:900px){
  .contato .wrap{ grid-template-columns:1fr; }
  .contato__aside{ position:static; }
}
@media (max-width:560px){
  .form{ grid-template-columns:1fr; }
}
