/* ============================================
   STUDIO M.A — Stylesheet
   Pure CSS, sem dependências
   ============================================ */

/* === FONTES === */
@font-face {
  font-family: 'Moisette';
  src: url('public/fonts/Moisette-Light.otf') format('opentype');
  font-weight: 300;
  font-display: swap;
}
@font-face {
  font-family: 'Moisette';
  src: url('public/fonts/Moisette-Medium.otf') format('opentype');
  font-weight: 500;
  font-display: swap;
}
@font-face {
  font-family: 'Moisette';
  src: url('public/fonts/Moisette-Bold.otf') format('opentype');
  font-weight: 700;
  font-display: swap;
}
@font-face {
  font-family: 'Gotham';
  src: url('public/fonts/Gotham-Light.otf') format('opentype');
  font-weight: 300;
  font-display: swap;
}
@font-face {
  font-family: 'Gotham';
  src: url('public/fonts/Gotham-Book.otf') format('opentype');
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: 'Gotham';
  src: url('public/fonts/Gotham-Medium.otf') format('opentype');
  font-weight: 500;
  font-display: swap;
}

/* === VARIÁVEIS === */
:root {
  --bg:              #F9F0EC;
  --fg:              #0F0F11;
  --primary:         #0F0F11;
  --primary-fg:      #F9F0EC;
  --muted:           #DFD3C7;
  --muted-fg:        #7C6E66;
  --sand:            #CDBAAD;
  --cream:           #F9F0EC;
  --border:          #D9CCBE;
  --brand:           #757560;
  --font-serif:      'Moisette', Georgia, serif;
  --font-sans:       'Gotham', system-ui, sans-serif;
  --sec-pad:         clamp(3rem, 8vw, 8rem);
  --con-pad:         clamp(1.25rem, 4vw, 4rem);
  --shadow-s:        0 4px 20px -4px rgba(30,24,18,.08);
  --shadow-m:        0 8px 30px -6px rgba(30,24,18,.12);
  --ease:            cubic-bezier(.4,0,.2,1);
}

/* === RESET === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html  { scroll-behavior: smooth; }
body  {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: .01em;
  -webkit-font-smoothing: antialiased;
}
img, video { max-width: 100%; display: block; }
a  { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { font-family: var(--font-sans); }
::selection { background: rgba(117,117,96,.2); }

/* === TIPOGRAFIA === */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-serif);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -.01em;
}
.font-serif { font-family: var(--font-serif); }
.text-display {
  font-size: clamp(1.875rem, 6vw, 4.5rem);
  line-height: 1.1;
  letter-spacing: -.02em;
}
.text-title {
  font-size: clamp(1.5rem, 4vw, 3rem);
  line-height: 1.15;
}
.text-micro {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .15em;
}
.text-body-lg { font-size: clamp(1rem,2vw,1.25rem); line-height:1.7; }
.text-body    { font-size: 1rem; line-height: 1.7; }
.text-muted   { color: var(--muted-fg); }
.text-prim-fg { color: var(--primary-fg); }
.text-brand   { color: var(--brand); }
.italic       { font-style: italic; }
.font-medium  { font-weight: 500; }
.text-center  { text-align: center; }
.text-left    { text-align: left; }
.text-balance { text-wrap: balance; }
.leading-relaxed { line-height: 1.7; }

/* === LAYOUT === */
.container {
  margin: 0 auto;
  width: 100%;
  max-width: 1280px;
  padding-left:  var(--con-pad);
  padding-right: var(--con-pad);
}
.sec-pad { padding-top: var(--sec-pad); padding-bottom: var(--sec-pad); }
.bg-cream   { background: var(--cream); }
.bg-sand    { background: var(--sand); }
.bg-primary { background: var(--primary); color: var(--primary-fg); }

/* Flex helpers */
.flex         { display: flex; }
.flex-col     { flex-direction: column; }
.flex-wrap    { flex-wrap: wrap; }
.items-center { align-items: center; }
.items-start  { align-items: flex-start; }
.justify-center   { justify-content: center; }
.justify-between  { justify-content: space-between; }
.gap-1  { gap: .25rem; }
.gap-2  { gap: .5rem; }
.gap-3  { gap: .75rem; }
.gap-4  { gap: 1rem; }
.gap-6  { gap: 1.5rem; }
.gap-8  { gap: 2rem; }
.gap-10 { gap: 2.5rem; }
.gap-16 { gap: 4rem; }

/* Spacing */
.mt-2  { margin-top: .5rem; }
.mt-3  { margin-top: .75rem; }
.mt-4  { margin-top: 1rem; }
.mt-6  { margin-top: 1.5rem; }
.mt-8  { margin-top: 2rem; }
.mt-10 { margin-top: 2.5rem; }
.mt-12 { margin-top: 3rem; }
.mt-16 { margin-top: 4rem; }
.mb-4  { margin-bottom: 1rem; }
.mb-6  { margin-bottom: 1.5rem; }
.mb-8  { margin-bottom: 2rem; }
.mb-12 { margin-bottom: 3rem; }
.mx-auto { margin: 0 auto; }
.py-6  { padding-top:1.5rem; padding-bottom:1.5rem; }

/* Size helpers */
.w-full  { width: 100%; }
.h-full  { height: 100%; }
.max-w-xl  { max-width: 36rem; }
.max-w-2xl { max-width: 42rem; }
.max-w-3xl { max-width: 48rem; }
.max-w-4xl { max-width: 56rem; }
.relative { position: relative; }
.absolute { position: absolute; }
.overflow-hidden { overflow: hidden; }
.rounded-sm   { border-radius: 2px; }
.rounded-full { border-radius: 9999px; }
.hidden { display: none; }
.block  { display: block; }
.space-y-4 > * + * { margin-top: 1rem; }
.space-y-6 > * + * { margin-top: 1.5rem; }
.shrink-0 { flex-shrink: 0; }
.flex-1   { flex: 1; }
.inset-0  { inset: 0; }
.order-1  { order: 1; }
.order-2  { order: 2; }

/* === GRID === */
.grid { display: grid; }
.grid-2   { grid-template-columns: repeat(2,1fr); }
.grid-3   { grid-template-columns: repeat(3,1fr); }
.grid-4   { grid-template-columns: repeat(4,1fr); }
.grid-5   { grid-template-columns: repeat(5,1fr); }
.grid-lg2 { grid-template-columns: 1fr 1fr; }

@media (max-width:1023px) {
  .grid-4   { grid-template-columns: repeat(2,1fr); }
  .grid-lg2 { grid-template-columns: 1fr; }
  .lg-order-1 { order: 1; }
  .lg-order-2 { order: 2; }
}
@media (max-width:767px) {
  .grid-3 { grid-template-columns: 1fr; }
  .grid-5 { grid-template-columns: repeat(2,1fr); }
  .md-grid-2 { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width:639px) {
  .grid-2 { grid-template-columns: 1fr; }
}

/* === HEADER === */
.site-header {
  position: fixed;
  top:0; left:0; right:0;
  z-index: 50;
  padding: 1.5rem 0;
  transition: all .5s var(--ease);
}
.site-header.scrolled {
  background: rgba(249,240,236,.95);
  backdrop-filter: blur(8px);
  box-shadow: var(--shadow-s);
  padding: .75rem 0;
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.header-logo img { height: 2.5rem; width: auto; }

.nav-desktop {
  display: none;
  align-items: center;
  gap: 2.5rem;
}
@media (min-width:1024px) {
  .nav-desktop { display: flex; }
  .mobile-btn  { display: none; }
}

.nav-link {
  font-size: .875rem;
  letter-spacing: .05em;
  color: var(--muted-fg);
  transition: color .3s;
  position: relative;
}
.nav-link::after {
  content:'';
  position: absolute; bottom:-2px; left:0;
  height:1px; width:0;
  background: currentColor;
  transition: width .5s;
}
.nav-link:hover       { color: var(--fg); }
.nav-link:hover::after{ width:100%; }
.nav-link.active      { color: var(--fg); }

.mobile-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: .5rem;
  color: var(--fg);
  position: relative; z-index:60;
}
.icon-close { display: none; }

/* Mobile nav */
.mobile-nav {
  position: fixed; inset:0;
  background: var(--bg);
  z-index: 55;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity .4s var(--ease);
}
.mobile-nav.open { opacity:1; pointer-events:all; }
.mobile-nav .nav-link {
  font-family: var(--font-serif);
  font-size: 2rem;
  color: var(--fg);
  letter-spacing: -.01em;
}
.mobile-nav .nav-link::after { display:none; }

/* === BOTÕES === */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .75rem 2rem;
  font-size: .875rem;
  font-weight: 500;
  letter-spacing: .05em;
  border-radius: 9999px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all .3s;
  text-decoration: none;
}
.btn-hero         { background:var(--primary);  color:var(--primary-fg); border-color:var(--primary); }
.btn-hero:hover   { opacity:.85; }
.btn-outline      { background:transparent; color:var(--fg); border-color:rgba(15,15,17,.3); }
.btn-outline:hover{ background:var(--fg); color:var(--primary-fg); }
.btn-elegant      { background:transparent; color:var(--fg); border-color:var(--fg); }
.btn-elegant:hover{ background:var(--fg); color:var(--primary-fg); }
.btn-whatsapp         { background:#25D366; color:#fff; border-color:#25D366; }
.btn-whatsapp:hover   { background:#1da851; }
.btn-outline-light        { background:transparent; color:var(--primary-fg); border-color:rgba(249,240,236,.3); }
.btn-outline-light:hover  { background:var(--primary-fg); color:var(--primary); }
.btn-lg { padding:1rem 2.5rem; font-size:1rem; }

/* === HERO === */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.hero-bg { position:absolute; inset:0; }
.hero-bg img { width:100%; height:100%; object-fit:cover; }
.hero-overlay {
  position:absolute; inset:0;
  background: linear-gradient(to bottom, rgba(249,240,236,.95), rgba(249,240,236,.7) 50%, rgba(249,240,236,.2));
}
@media (min-width:640px) {
  .hero-overlay {
    background: linear-gradient(to right, rgba(249,240,236,.95), rgba(249,240,236,.7) 50%, rgba(249,240,236,.2));
  }
}
.hero-content { position:relative; padding-top:7rem; padding-bottom:4rem; }
.scroll-line {
  position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%);
  display:none;
}
@media (min-width:640px) { .scroll-line { display:block; } }
.scroll-line div {
  width:1px; height:3rem;
  background: linear-gradient(to bottom, rgba(15,15,17,.4), transparent);
  animation: scrollBounce 2s infinite;
}
@keyframes scrollBounce {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(8px); }
}

/* === PAGE HERO === */
.page-hero { padding-top:8rem; padding-bottom:5rem; background:var(--cream); }

/* === SECTION HEADING === */
.sec-heading { max-width:48rem; }
.sec-heading.center { margin:0 auto; text-align:center; }
.sec-heading .label { display:block; margin-bottom:1rem; }

/* === ABOUT PILLARS === */
.pillar { border-left:2px solid rgba(117,117,96,.3); padding-left:1rem; }

/* === SERVICE CARDS (home) === */
.srv-card { display:block; transition:all .5s; }
.srv-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-m); }
.srv-card-img {
  position:relative; border-radius:2px; overflow:hidden;
  aspect-ratio:3/4;
}
.srv-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .7s; }
.srv-card-img:hover img { transform:scale(1.03); }
.srv-card-overlay {
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(15,15,17,.6), transparent);
}
.srv-card-body {
  position:absolute; bottom:0; left:0; right:0;
  padding:1.5rem; color:var(--primary-fg);
}
.srv-card-arrow {
  display:flex; align-items:center; gap:.5rem;
  font-size:.875rem; font-weight:500;
  margin-top:1rem; opacity:0; transition:opacity .3s;
}
.srv-card:hover .srv-card-arrow { opacity:1; }

/* === TESTIMONIALS === */
.testi-card {
  background:var(--bg); padding:2rem; border-radius:2px;
  box-shadow:var(--shadow-s); display:flex; flex-direction:column;
}
.stars { display:flex; gap:.25rem; }
.star { fill:#FACC15; color:#FACC15; }
.testi-author {
  display:flex; align-items:center; gap:.75rem;
  margin-top:1.5rem; padding-top:1.5rem;
  border-top:1px solid var(--border);
}
.testi-author img { width:2.5rem; height:2.5rem; border-radius:9999px; object-fit:cover; }
.stats-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:2rem; text-align:center;
}
@media (min-width:768px) { .stats-grid { grid-template-columns:repeat(4,1fr); } }
.stat-value { font-family:var(--font-serif); font-size:clamp(2rem,5vw,3rem); }

/* === EXPERIENCE === */
.feature-item { display:flex; gap:1rem; }
.feature-icon {
  flex-shrink:0; width:2.5rem; height:2.5rem;
  border-radius:9999px; background:rgba(117,117,96,.1);
  display:flex; align-items:center; justify-content:center;
  color:var(--brand);
}

/* === RESULTS === */
.result-card {
  position:relative; border-radius:2px; overflow:hidden;
  aspect-ratio:4/5; cursor:pointer;
}
.result-card img { width:100%; height:100%; object-fit:cover; }
.result-overlay {
  position:absolute; inset:0;
  background:rgba(15,15,17,0); transition:background .5s;
}
.result-card:hover .result-overlay { background:rgba(15,15,17,.4); }
.result-info {
  position:absolute; inset:0; display:flex; align-items:flex-end;
  padding:1.5rem; color:var(--primary-fg);
  opacity:0; transition:opacity .5s;
}
.result-card:hover .result-info { opacity:1; }

/* === CTA BOX === */
.cta-box {
  background:var(--primary); color:var(--primary-fg);
  border-radius:2px; padding:5rem 4rem; text-align:center;
}
@media (max-width:640px) { .cta-box { padding:3rem 1.5rem; } }

/* === FOOTER === */
.site-footer { background:var(--primary); color:var(--primary-fg); }
.footer-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:2rem;
}
@media (min-width:1024px) { .footer-grid { grid-template-columns:repeat(4,1fr); } }
.footer-brand { grid-column:span 2; }
@media (min-width:1024px) { .footer-brand { grid-column:span 1; } }
.footer-logo img { height:2.5rem; filter:brightness(0) invert(1); }
.footer-social { display:flex; gap:1rem; margin-top:1.5rem; }
.footer-social a {
  padding:.5rem; border:1px solid rgba(249,240,236,.2);
  border-radius:9999px; transition:background .3s;
  display:flex; align-items:center;
}
.footer-social a:hover { background:rgba(249,240,236,.1); }
.footer-col h4 {
  font-size:.75rem; text-transform:uppercase; letter-spacing:.15em;
  color:rgba(249,240,236,.5); margin-bottom:1.5rem;
  font-family:var(--font-sans); font-weight:400;
}
.footer-col ul { display:flex; flex-direction:column; gap:1rem; }
.footer-col a { font-size:.875rem; color:rgba(249,240,236,.7); transition:color .3s; }
.footer-col a:hover { color:var(--primary-fg); }
.footer-contact-item {
  display:flex; align-items:flex-start; gap:.75rem;
  font-size:.875rem; color:rgba(249,240,236,.7);
}
.footer-contact-item svg { flex-shrink:0; color:rgba(249,240,236,.5); }
.footer-bottom { border-top:1px solid rgba(249,240,236,.1); }
.footer-bottom-inner {
  padding:1.5rem 0;
  display:flex; flex-direction:column; align-items:center; gap:1rem;
}
@media (min-width:768px) {
  .footer-bottom-inner { flex-direction:row; justify-content:space-between; }
}
.footer-bottom p, .footer-bottom a {
  font-size:.75rem; color:rgba(249,240,236,.5); transition:color .3s;
}
.footer-bottom a:hover { color:rgba(249,240,236,.7); }
.footer-bottom-links { display:flex; gap:1.5rem; }

/* === WHATSAPP FLOAT === */
.wa-float {
  position:fixed; bottom:1.5rem; right:1.5rem; z-index:50;
  display:flex; align-items:center; gap:.5rem;
  background:#25D366; color:#fff;
  padding:.75rem 1.25rem; border-radius:9999px;
  box-shadow:0 4px 12px rgba(0,0,0,.15);
  font-size:.875rem; font-weight:500;
  transition:transform .3s, box-shadow .3s;
  animation:floatIn .5s 1s ease-out backwards;
}
.wa-float:hover { transform:scale(1.05); box-shadow:0 8px 20px rgba(0,0,0,.2); }
@keyframes floatIn {
  from { opacity:0; transform:scale(.8) translateY(20px); }
  to   { opacity:1; transform:scale(1) translateY(0); }
}
@media (max-width:640px) { .wa-float .wa-label { display:none; } }

/* === IMAGE ELEGANT === */
.img-el { overflow:hidden; }
.img-el img { transition:transform .7s ease-out; }
.img-el:hover img { transform:scale(1.03); }

/* === HOVER LIFT === */
.hover-lift { transition:all .5s ease-out; }
.hover-lift:hover { transform:translateY(-4px); box-shadow:var(--shadow-m); }

/* === LINK UNDERLINE === */
.link-under { position:relative; }
.link-under::after {
  content:''; position:absolute; bottom:0; left:0;
  height:1px; width:0; background:currentColor; transition:width .5s;
}
.link-under:hover::after { width:100%; }

/* === SERVICES PAGE === */
.cat-icon {
  width:3rem; height:3rem; border-radius:9999px;
  background:rgba(117,117,96,.1); display:flex; align-items:center;
  justify-content:center; color:var(--brand); flex-shrink:0;
}
.srv-img  { width:100%; border-radius:2px; object-fit:cover; }
.srv-ph   {
  width:100%; border-radius:2px;
  background:rgba(117,117,96,.05);
  border:1px solid rgba(117,117,96,.1);
  display:flex; align-items:center; justify-content:center;
}
.srv-ph span { font-family:var(--font-serif); font-size:2.5rem; color:rgba(117,117,96,.3); }

/* === PORTFOLIO === */
.portfolio-bar {
  position:sticky; top:4rem; z-index:40;
  background:rgba(249,240,236,.95);
  backdrop-filter:blur(8px);
  padding:1.5rem 0;
  border-bottom:1px solid rgba(217,204,190,.5);
}
.filter-wrap { display:flex; flex-wrap:wrap; gap:.5rem; }
.filter-btn {
  padding:.375rem 1rem; font-size:.875rem;
  border-radius:2px; border:none; cursor:pointer;
  background:var(--cream); color:var(--fg);
  transition:all .3s;
}
.filter-btn:hover { background:var(--sand); }
.filter-btn.active { background:var(--primary); color:var(--primary-fg); }
.search-wrap { position:relative; width:100%; max-width:20rem; }
.search-wrap input {
  width:100%; padding:.625rem 2.5rem;
  border:1px solid var(--border); border-radius:2px;
  background:var(--cream); font-family:var(--font-sans);
  font-size:.875rem; color:var(--fg); outline:none;
  transition:border-color .3s;
}
.search-wrap input:focus { border-color:var(--muted-fg); }
.search-ico, .search-clear {
  position:absolute; top:50%; transform:translateY(-50%);
  color:var(--muted-fg); background:none; border:none; cursor:pointer;
  display:flex;
}
.search-ico   { left:.75rem; pointer-events:none; }
.search-clear { right:.75rem; }

.portfolio-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:1rem;
}
@media (min-width:768px)  { .portfolio-grid { grid-template-columns:repeat(3,1fr); } }
@media (min-width:1024px) { .portfolio-grid { grid-template-columns:repeat(4,1fr); } }

.pf-item {
  position:relative; aspect-ratio:1;
  overflow:hidden; border-radius:2px; cursor:pointer;
}
.pf-item img, .pf-item video {
  width:100%; height:100%; object-fit:cover; transition:transform .5s;
}
.pf-item:hover img, .pf-item:hover video { transform:scale(1.05); }
.pf-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(15,15,17,.7), transparent);
  opacity:0; transition:opacity .3s;
}
.pf-item:hover .pf-overlay { opacity:1; }
.pf-info {
  position:absolute; bottom:0; left:0; right:0; padding:1rem;
  color:var(--primary-fg); transform:translateY(4px); opacity:0; transition:all .3s;
}
.pf-item:hover .pf-info { transform:translateY(0); opacity:1; }
.play-circle {
  position:absolute; inset:0; display:flex;
  align-items:center; justify-content:center;
  background:rgba(15,15,17,.2);
}
.play-circle div {
  width:3rem; height:3rem; border-radius:9999px;
  background:rgba(249,240,236,.9); display:flex;
  align-items:center; justify-content:center;
  box-shadow:var(--shadow-m);
}

/* Modal */
.pf-modal {
  display:none; position:fixed; inset:0; z-index:100;
  background:rgba(0,0,0,.8);
  align-items:center; justify-content:center; padding:1rem;
}
.pf-modal.open { display:flex; }
.pf-modal-wrap { position:relative; }
.pf-modal-box {
  background:var(--bg); border-radius:2px; overflow:hidden;
  max-width:64rem; width:100%;
  display:grid; max-height:90vh;
}
@media (min-width:768px) { .pf-modal-box { grid-template-columns:1fr 1fr; } }
.pf-modal-img { aspect-ratio:1; overflow:hidden; }
@media (min-width:768px) { .pf-modal-img { aspect-ratio:auto; } }
.pf-modal-img img, .pf-modal-img video { width:100%; height:100%; object-fit:cover; }
.pf-modal-body {
  padding:2rem; display:flex; flex-direction:column;
  justify-content:center; overflow-y:auto;
}
.pf-modal-close {
  position:absolute; top:1rem; right:1rem;
  background:rgba(249,240,236,.9); border:none; border-radius:9999px;
  width:2.5rem; height:2.5rem; display:flex; align-items:center;
  justify-content:center; cursor:pointer; z-index:101; transition:background .3s;
}
.pf-modal-close:hover { background:rgba(249,240,236,1); }

/* === CONTACT === */
.contact-card {
  text-align:center; padding:2.5rem;
  background:var(--cream); border-radius:2px;
}
.contact-icon {
  width:3.5rem; height:3.5rem; border-radius:9999px;
  background:rgba(117,117,96,.1); display:flex;
  align-items:center; justify-content:center;
  margin:0 auto; color:var(--brand);
}

/* === MARCA === */
.values-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; text-align:center;
}
@media (min-width:768px) { .values-grid { grid-template-columns:repeat(5,1fr); } }

/* === ANIMAÇÕES DE SCROLL === */
.anim-up {
  opacity:0; transform:translateY(30px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
}
.anim-left {
  opacity:0; transform:translateX(-30px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);
}
.anim-right {
  opacity:0; transform:translateX(30px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);
}
.anim-scale {
  opacity:0; transform:scale(.95);
  transition:opacity .6s var(--ease), transform .6s var(--ease);
}
.anim-visible {
  opacity:1 !important;
  transform:translate(0) scale(1) !important;
}
/* Hero — anima logo na carga */
.hero-anim {
  opacity:0; transform:translateY(30px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
}

/* Delays */
.d1 { transition-delay:.1s; }
.d2 { transition-delay:.2s; }
.d3 { transition-delay:.3s; }
.d4 { transition-delay:.4s; }
.d5 { transition-delay:.5s; }
.d6 { transition-delay:.6s; }
