/* =========================================================
   NEO ARTE — Marketing Digital
   Estilo dark/teal inspirado no layout iGreen Energy
   ========================================================= */

:root{
  /* Paleta Neo Arte (dark + teal/azul-esverdeado da logo) */
  --bg:#081519;
  --bg-2:#0b1a21;
  --bg-3:#0f2630;
  --surface:#11242c;
  --surface-2:#16313b;
  --border:rgba(20,184,166,.16);
  --border-strong:rgba(20,184,166,.35);

  --teal:#14b8a6;
  --teal-bright:#2dd4bf;
  --teal-glow:#0fd9c0;
  --teal-deep:#0d9488;

  --text:#eaf6f4;
  --text-soft:#a9c4c2;
  --text-dim:#6f8d8c;

  --white:#ffffff;
  --radius:14px;
  --radius-sm:9px;
  --radius-lg:20px;
  --container:1180px;
  --shadow:0 16px 44px rgba(0,0,0,.4);
  --shadow-teal:0 12px 30px rgba(20,184,166,.22);
  --font-head:'Outfit',system-ui,sans-serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --transition:.3s cubic-bezier(.4,0,.2,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  font-size:15px;
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
section{position:relative}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 22px;
}

h1,h2,h3,h4{font-family:var(--font-head);line-height:1.15;font-weight:800}

/* ---------- BOTÕES ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;border-radius:50px;
  font-family:var(--font-head);font-weight:600;font-size:14px;
  cursor:pointer;border:none;transition:var(--transition);
  white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(135deg,var(--teal),var(--teal-deep));
  color:#04201c;box-shadow:var(--shadow-teal);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(20,184,166,.4)}
.btn-outline{
  background:transparent;color:var(--text);
  border:1.5px solid var(--border-strong);
}
.btn-outline:hover{border-color:var(--teal);color:var(--teal-bright);transform:translateY(-2px)}
.btn-lg{padding:14px 30px;font-size:15px}
.btn-block{width:100%;justify-content:center}

/* ---------- PRELOADER ---------- */
#preloader{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .6s ease,visibility .6s ease;
}
#preloader.hidden{opacity:0;visibility:hidden}
.preloader-inner{display:flex;flex-direction:column;align-items:center;gap:22px}
.preloader-icon{width:80px;height:80px}
.preloader-bar{width:180px;height:4px;background:var(--surface);border-radius:50px;overflow:hidden}
.preloader-bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--teal),var(--teal-bright));border-radius:50px;animation:loadbar 1.6s ease forwards}
@keyframes loadbar{to{width:100%}}
.preloader-text{font-family:var(--font-head);color:var(--text-soft);font-size:14px;letter-spacing:1px}

/* ---------- HEADER ---------- */
#header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  padding:14px 0;transition:var(--transition);
  background:transparent;
}
#header.scrolled{
  background:rgba(8,21,25,.85);
  backdrop-filter:blur(16px);
  padding:9px 0;
  border-bottom:1px solid var(--border);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo-img{height:44px;width:auto}
#header.scrolled .nav-logo-img{height:38px}
.nav-menu{display:flex;gap:30px}
.nav-link{
  font-family:var(--font-head);font-weight:500;font-size:14px;
  color:var(--text-soft);position:relative;padding:6px 0;transition:var(--transition);
}
.nav-link::after{
  content:'';position:absolute;bottom:0;left:0;width:0;height:2px;
  background:var(--teal);transition:var(--transition);
}
.nav-link:hover,.nav-link.active{color:var(--teal-bright)}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-cta{font-size:14px;padding:11px 22px}
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-hamburger span{width:26px;height:2px;background:var(--text);border-radius:2px;transition:var(--transition)}

/* ---------- HERO ---------- */
#hero{
  min-height:auto;display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding:130px 0 70px;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg-img{
  position:absolute;inset:0;
  background:url('../assets/imagens/hero-bg-neo-arte.jpg') center/cover no-repeat;
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(900px 600px at 70% 35%,rgba(20,184,166,.18),transparent 70%),
    linear-gradient(180deg,rgba(8,21,25,.6) 0%,rgba(8,21,25,.85) 60%,var(--bg) 100%);
}
.hero-bg-grid{
  position:absolute;inset:0;z-index:1;opacity:.4;
  background-image:linear-gradient(rgba(20,184,166,.06) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(20,184,166,.06) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(circle at 60% 40%,black,transparent 80%);
}
.hero-shape{position:absolute;border-radius:50%;filter:blur(80px);z-index:0;opacity:.5}
.hero-shape-1{width:420px;height:420px;background:rgba(20,184,166,.35);top:-100px;right:-80px}
.hero-shape-2{width:300px;height:300px;background:rgba(13,148,136,.3);bottom:-60px;left:-60px}
.hero .container{position:relative;z-index:3}
.hero-content{position:relative;z-index:3}
.hero-visual{position:relative;z-index:3}
.hero-grid{display:block;max-width:820px}
.hero-content{max-width:820px}
.hero-title{
  font-size:clamp(2rem,4.5vw,3.6rem);font-weight:800;
  letter-spacing:-1px;margin-bottom:18px;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(20,184,166,.12);border:1px solid var(--border-strong);
  padding:7px 15px;border-radius:50px;font-family:var(--font-head);
  font-size:12px;font-weight:600;color:var(--teal-bright);letter-spacing:.5px;
  margin-bottom:20px;
}
.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--teal-bright);box-shadow:0 0 12px var(--teal-bright);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero-title{
  font-size:clamp(2rem,4vw,3.2rem);font-weight:800;
  letter-spacing:-1px;margin-bottom:18px;
}
.hero-title .highlight{
  background:linear-gradient(120deg,var(--teal-bright),var(--teal),var(--teal-glow));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.typed-cursor{color:var(--teal-bright);font-weight:300;animation:blink 1s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.hero-subtitle{font-size:clamp(.95rem,1.5vw,1.05rem);color:var(--text-soft);max-width:520px;margin-bottom:24px}
.hero-subtitle strong{color:var(--text)}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}
.trust-tag{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-head);font-size:13px;font-weight:500;color:var(--text-soft);
  background:var(--surface);padding:7px 14px;border-radius:50px;border:1px solid var(--border);
}
.trust-tag svg{width:16px;height:16px;color:var(--teal-bright)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
.hero-visual{display:flex;justify-content:center;align-items:center;position:relative}
.hero-logo-big{
  width:min(100%,300px);
  filter:drop-shadow(0 16px 40px rgba(20,184,166,.3));
  animation:float 6s ease-in-out infinite;
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-dim);font-size:12px;font-family:var(--font-head);letter-spacing:1px}
.hero-scroll-line{width:2px;height:40px;background:linear-gradient(var(--teal),transparent);border-radius:2px;animation:scrolldown 2s infinite}
@keyframes scrolldown{0%{opacity:0;transform:scaleY(0);transform-origin:top}50%{opacity:1}100%{opacity:0;transform:scaleY(1);transform-origin:bottom}}

/* ---------- TRUST STRIP ---------- */
.trust-strip{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:26px 0}
.trust-strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.trust-strip-item{display:flex;align-items:center;gap:13px;justify-content:center}
.trust-strip-item svg{width:30px;height:30px;color:var(--teal-bright);flex-shrink:0}
.trust-strip-item strong{display:block;font-family:var(--font-head);font-size:19px;color:var(--text)}
.trust-strip-item span{font-size:12px;color:var(--text-dim)}

/* ---------- SEÇÕES GERAIS ---------- */
section[id]{padding:70px 0}
.section-alt{background:var(--bg-2)}
.section-label{
  display:inline-block;font-family:var(--font-head);font-weight:600;
  font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--teal-bright);
  margin-bottom:12px;
}
.section-title{font-size:clamp(1.5rem,3vw,2.2rem);margin-bottom:14px;letter-spacing:-.5px}
.section-title span{color:var(--teal-bright)}
.section-divider{width:60px;height:3px;background:linear-gradient(90deg,var(--teal),var(--teal-bright));border-radius:50px;margin:0 auto 18px}
.section-divider.left{margin:0 0 18px}
.section-subtitle{color:var(--text-soft);max-width:580px;margin:0 auto;font-size:.98rem}
.section-header{text-align:center;margin-bottom:44px}
.section-cta{text-align:center;margin-top:40px}

/* ---------- QUEM SOMOS ---------- */
.sobre-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center}
.sobre-text{color:var(--text-soft);margin-bottom:20px}
.sobre-text strong{color:var(--text)}
.sobre-features{display:flex;flex-direction:column;gap:20px;margin:30px 0}
.sobre-feature{display:flex;gap:16px;align-items:flex-start}
.sobre-feature-icon{
  flex-shrink:0;width:50px;height:50px;border-radius:14px;
  background:rgba(20,184,166,.12);border:1px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
}
.sobre-feature-icon svg{width:24px;height:24px;color:var(--teal-bright)}
.sobre-feature-text strong{display:block;font-family:var(--font-head);color:var(--text);margin-bottom:4px}
.sobre-feature-text p{color:var(--text-dim);font-size:14px}
.sobre-counters{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.counter-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:30px 24px;text-align:center;transition:var(--transition);
}
.counter-card:hover{border-color:var(--border-strong);transform:translateY(-6px)}
.counter-value{font-family:var(--font-head);font-size:34px;font-weight:900;color:var(--teal-bright);line-height:1}
.counter-label{color:var(--text-dim);font-size:13px;margin-top:7px}

/* ---------- TABS DE SERVIÇOS (estilo iGreen showcase) ---------- */
.tabs-nav{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:40px}
.tab-btn{
  font-family:var(--font-head);font-weight:600;font-size:14px;
  padding:12px 24px;border-radius:50px;cursor:pointer;
  background:var(--surface);border:1px solid var(--border);color:var(--text-soft);
  transition:var(--transition);
}
.tab-btn.active{background:linear-gradient(135deg,var(--teal),var(--teal-deep));color:#04201c;border-color:transparent}
.tab-panel{display:none}
.tab-panel.active{display:block;animation:fadein .5s ease}
@keyframes fadein{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.tab-content-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.tab-img{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)}
.tab-img img{width:100%;height:100%;object-fit:cover}
.tab-text h4{font-size:13px;letter-spacing:2px;color:var(--teal-bright);font-weight:600;margin-bottom:6px}
.tab-text h3{font-size:1.6rem;margin-bottom:14px}
.tab-text p{color:var(--text-soft);margin-bottom:22px}

/* ---------- TIMELINE / COMO FUNCIONA ---------- */
.timeline-grid{display:flex;align-items:flex-start;justify-content:center;gap:0;flex-wrap:wrap}
.timeline-item{flex:1;min-width:200px;text-align:center;padding:0 18px;position:relative}
.timeline-number{font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--teal-deep);margin-bottom:14px}
.timeline-icon{
  width:72px;height:72px;margin:0 auto 16px;border-radius:20px;
  background:var(--surface);border:1px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
}
.timeline-icon svg{width:36px;height:36px;color:var(--teal-bright)}
.timeline-title{font-size:1.1rem;margin-bottom:8px}
.timeline-desc{color:var(--text-dim);font-size:13px}
.timeline-connector{display:flex;align-items:center;padding-top:42px;color:var(--border-strong)}
.timeline-connector svg{width:50px;height:20px}

/* ---------- SERVIÇOS GRID ---------- */
.servicos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.servico-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:26px 22px;transition:var(--transition);position:relative;overflow:hidden;
}
.servico-card::before{
  content:'';position:absolute;top:0;left:0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--teal),var(--teal-bright));transform:scaleX(0);transform-origin:left;transition:var(--transition);
}
.servico-card:hover{transform:translateY(-8px);border-color:var(--border-strong);box-shadow:var(--shadow)}
.servico-card:hover::before{transform:scaleX(1)}
.servico-icon{
  width:50px;height:50px;border-radius:14px;margin-bottom:16px;
  background:rgba(20,184,166,.12);border:1px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
}
.servico-icon svg{width:24px;height:24px;color:var(--teal-bright)}
.servico-title{font-size:1.05rem;margin-bottom:8px}
.servico-desc{color:var(--text-dim);font-size:13px}

/* ---------- ORÇAMENTO / SIMULADOR ---------- */
.simulador-wrapper{max-width:720px;margin:0 auto}
.simulador-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px}
.simulador-label{display:block;font-family:var(--font-head);font-weight:600;margin-bottom:14px;color:var(--text)}
.sim-field{margin-bottom:22px}
.sim-select,.simulador-input{
  width:100%;padding:15px 18px;border-radius:var(--radius-sm);
  background:var(--bg-3);border:1px solid var(--border);color:var(--text);
  font-family:var(--font-body);font-size:15px;
}
.sim-select:focus,.simulador-input:focus{outline:none;border-color:var(--teal)}
.simulador-input-wrap{display:flex;align-items:center;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 16px}
.simulador-prefix{color:var(--text-dim);font-family:var(--font-head)}
.simulador-input-wrap .simulador-input{border:none;background:transparent}
.simulador-result{margin-top:30px;padding-top:30px;border-top:1px solid var(--border)}
.result-box{background:var(--bg-3);border:1px solid var(--border-strong);border-radius:var(--radius);padding:26px;text-align:center;margin-bottom:20px}
.result-box .result-label{color:var(--text-dim);font-size:14px;display:block;margin-bottom:8px}
.result-box .result-value{font-family:var(--font-head);font-size:34px;font-weight:900;color:var(--teal-bright)}
.result-disclaimer{color:var(--text-dim);font-size:12px;margin:16px 0 20px}

/* ---------- APP ---------- */
.app-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.app-text{color:var(--text-soft);margin-bottom:26px}
.app-features{display:flex;flex-direction:column;gap:16px;margin-bottom:30px}
.app-feature-item{display:flex;align-items:center;gap:14px;color:var(--text-soft)}
.app-feature-item svg{width:22px;height:22px;color:var(--teal-bright);flex-shrink:0}
.app-mockup{display:flex;justify-content:center;position:relative}
.app-mockup img{border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow)}

/* ---------- CLIENTES ---------- */
.clientes-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.cliente-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;transition:var(--transition);aspect-ratio:4/3;
  position:relative;display:block;text-decoration:none;
}
.cliente-card img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2);transition:transform .4s ease}
.cliente-card:hover{border-color:var(--border-strong);transform:translateY(-5px);box-shadow:var(--shadow)}
.cliente-card:hover img{filter:grayscale(0);transform:scale(1.04)}
.cliente-card-label{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(transparent,rgba(8,21,25,.92));
  padding:22px 12px 10px;
  font-family:var(--font-head);font-size:12px;font-weight:600;color:var(--text);
  text-align:center;opacity:0;transition:var(--transition);
}
.cliente-card:hover .cliente-card-label{opacity:1;}

/* ---------- FAQ ---------- */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}
.faq-item.active{border-color:var(--border-strong)}
.faq-question{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:22px 26px;background:none;border:none;cursor:pointer;text-align:left;
  font-family:var(--font-head);font-weight:600;font-size:16px;color:var(--text);
}
.faq-question svg{width:22px;height:22px;color:var(--teal-bright);transition:var(--transition);flex-shrink:0}
.faq-item.active .faq-question svg{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-answer p{padding:0 26px 22px;color:var(--text-soft)}

/* ---------- CONTATO ---------- */
.contato-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contato-text{color:var(--text-soft);margin-bottom:30px}
.contato-info-items{display:flex;flex-direction:column;gap:20px;margin-bottom:30px}
.contato-info-item{display:flex;gap:16px;align-items:center}
.contato-info-icon{
  width:52px;height:52px;border-radius:14px;flex-shrink:0;
  background:rgba(20,184,166,.12);border:1px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
}
.contato-info-icon svg{width:24px;height:24px;color:var(--teal-bright)}
.contato-info-item strong{display:block;font-family:var(--font-head);color:var(--text)}
.contato-info-item a,.contato-info-item span{color:var(--text-soft);font-size:15px}
.contato-form-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:38px}
.form-title{font-size:1.4rem;margin-bottom:24px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-family:var(--font-head);font-size:14px;font-weight:500;margin-bottom:8px;color:var(--text-soft)}
.form-control{
  width:100%;padding:14px 16px;border-radius:var(--radius-sm);
  background:var(--bg-3);border:1px solid var(--border);color:var(--text);
  font-family:var(--font-body);font-size:15px;transition:var(--transition);
}
.form-control:focus{outline:none;border-color:var(--teal)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ---------- FOOTER ---------- */
#footer{background:var(--bg-2);border-top:1px solid var(--border);padding:70px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1.3fr;gap:40px;padding-bottom:50px}
.footer-logo{height:60px;margin-bottom:18px}
.footer-desc{color:var(--text-dim);font-size:14px;max-width:320px}
.footer-col-title{font-size:1.1rem;margin-bottom:20px;color:var(--text)}
.footer-links{display:flex;flex-direction:column;gap:12px}
.footer-links a{color:var(--text-soft);font-size:14px;transition:var(--transition)}
.footer-links a:hover{color:var(--teal-bright);padding-left:6px}
.footer-contact-list{display:flex;flex-direction:column;gap:14px}
.footer-contact-item{display:flex;align-items:center;gap:12px;color:var(--text-soft);font-size:14px}
.footer-contact-item svg{width:20px;height:20px;color:var(--teal-bright);flex-shrink:0}
.footer-social{display:flex;gap:12px;margin-top:18px}
.footer-social a{
  width:42px;height:42px;border-radius:12px;background:var(--surface);
  border:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:var(--transition);
}
.footer-social a:hover{background:var(--teal);border-color:var(--teal)}
.footer-social a:hover svg{color:#04201c}
.footer-social svg{width:20px;height:20px;color:var(--text-soft)}
.footer-bottom{border-top:1px solid var(--border);padding:24px 0;text-align:center}
.footer-bottom p{color:var(--text-dim);font-size:13px}
.footer-bottom span{color:var(--text-soft)}

/* ---------- FLUTUANTES ---------- */
.whatsapp-float{
  position:fixed;bottom:28px;right:28px;z-index:900;
  width:60px;height:60px;border-radius:50%;
  background:#25d366;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px rgba(37,211,102,.5);transition:var(--transition);
}
.whatsapp-float:hover{transform:scale(1.1)}
.whatsapp-float svg{width:32px;height:32px;color:#fff}
#back-to-top{
  position:fixed;bottom:28px;left:28px;z-index:900;
  width:48px;height:48px;border-radius:12px;cursor:pointer;
  background:var(--surface);border:1px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:var(--transition);
}
#back-to-top.show{opacity:1;visibility:visible}
#back-to-top:hover{background:var(--teal);border-color:var(--teal)}
#back-to-top svg{width:22px;height:22px;color:var(--teal-bright)}
#back-to-top:hover svg{color:#04201c}

/* =========================================================
   PLANOS DE PREÇO
   ========================================================= */
.planos-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
  align-items:start;
}
.plano-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:30px 24px;
  display:flex;flex-direction:column;gap:0;
  transition:var(--transition);position:relative;
}
.plano-card:hover{border-color:var(--border-strong);transform:translateY(-6px);box-shadow:var(--shadow)}
.plano-destaque{
  border-color:var(--teal)!important;
  background:linear-gradient(160deg,var(--surface) 60%,rgba(20,184,166,.08));
  box-shadow:0 0 40px rgba(20,184,166,.18);
}
.plano-badge{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--teal),var(--teal-deep));
  color:#04201c;font-family:var(--font-head);font-size:12px;font-weight:700;
  padding:5px 18px;border-radius:50px;letter-spacing:.5px;white-space:nowrap;
}
.plano-header{margin-bottom:24px}
.plano-label{
  font-family:var(--font-head);font-size:12px;font-weight:700;
  letter-spacing:2px;color:var(--teal-bright);text-transform:uppercase;
  display:block;margin-bottom:6px;
}
.plano-desc{color:var(--text-dim);font-size:13px;margin-bottom:18px}
.plano-preco{display:flex;align-items:flex-end;gap:4px;margin-bottom:8px}
.plano-cifrao{font-family:var(--font-head);font-size:18px;font-weight:700;color:var(--text);margin-bottom:6px}
.plano-valor{font-family:var(--font-head);font-size:40px;font-weight:900;color:var(--text);line-height:1}
.plano-destaque .plano-valor{color:var(--teal-bright)}
.plano-periodo{font-family:var(--font-head);font-size:14px;color:var(--text-dim);margin-bottom:6px}
.plano-anuncio{font-size:11px;color:var(--text-dim);background:rgba(20,184,166,.08);padding:6px 10px;border-radius:8px;border-left:2px solid var(--teal)}
.plano-itens{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:26px;flex:1}
.plano-itens li{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-soft)}
.plano-itens li svg{width:16px;height:16px;color:var(--teal-bright);flex-shrink:0}
.plano-itens li.plano-nao{color:var(--text-dim);opacity:.6}
.plano-itens li.plano-nao svg{color:var(--text-dim)}
.planos-nota{
  display:flex;align-items:flex-start;gap:10px;
  margin-top:30px;padding:16px 20px;
  background:rgba(20,184,166,.07);border:1px solid var(--border);
  border-radius:var(--radius);color:var(--text-dim);font-size:13px;
}
.planos-nota svg{color:var(--teal-bright);flex-shrink:0;margin-top:1px}
@media(max-width:1100px){.planos-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.planos-grid{grid-template-columns:1fr}}

/* SIMULADOR */
.simulador-wrapper{max-width:680px;margin:0 auto}
.simulador-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px}
.simulador-label{display:block;font-family:var(--font-head);font-weight:600;margin-bottom:12px;color:var(--text)}
.sim-field{margin-bottom:20px}
.sim-select{width:100%;padding:14px 16px;border-radius:var(--radius-sm);background:var(--bg-3);border:1px solid var(--border);color:var(--text);font-family:var(--font-body);font-size:15px}
.sim-select:focus{outline:none;border-color:var(--teal)}
.simulador-result{margin-top:28px;padding-top:28px;border-top:1px solid var(--border)}
.result-box{background:var(--bg-3);border:1px solid var(--border-strong);border-radius:var(--radius);padding:24px;text-align:center;margin-bottom:14px}
.result-box .result-label{color:var(--text-dim);font-size:13px;display:block;margin-bottom:8px}
.result-box .result-value{font-family:var(--font-head);font-size:32px;font-weight:900;color:var(--teal-bright)}
.result-disclaimer{color:var(--text-dim);font-size:12px;margin:0 0 18px;line-height:1.6}

/* =========================================================
   TIMELINE FLOAT ANIMATION
   ========================================================= */
@keyframes tl-float {
  0%,100% { transform: translateY(0px) }
  50%      { transform: translateY(-12px) }
}

.tl-float {
  animation: tl-float 4s ease-in-out infinite;
  animation-delay: var(--tl-delay, 0s);
  transition: transform .3s ease, box-shadow .3s ease;
}

.tl-float:hover {
  animation-play-state: paused;
  transform: translateY(-16px) scale(1.04);
}

.tl-float:hover .timeline-icon {
  background: rgba(20,184,166,.25);
  border-color: var(--teal-bright);
  box-shadow: 0 0 30px rgba(20,184,166,.35);
}

.tl-float:hover .timeline-icon svg {
  color: var(--teal-bright);
  filter: drop-shadow(0 0 8px rgba(45,212,191,.6));
}

.tl-float .timeline-number {
  transition: color .3s ease;
}
.tl-float:hover .timeline-number {
  color: var(--teal-bright);
}

/* Glow no conector quando o item anterior é hovado */
#timeline-grid:has(.tl-float:hover) .timeline-connector {
  color: var(--teal-bright);
  opacity: .7;
}

/* =========================================================
   PLANOS — ALINHAMENTO PERFEITO
   ========================================================= */
.planos-grid {
  align-items: stretch; /* todos os cards mesma altura */
}
.plano-card {
  display: flex;
  flex-direction: column;
}
.plano-header {
  flex-shrink: 0; /* cabeçalho não encolhe */
}
.plano-itens {
  flex: 1; /* lista ocupa todo o espaço disponível */
  margin-bottom: 24px;
}
.plano-card .btn {
  margin-top: auto; /* botão sempre no fundo */
  flex-shrink: 0;
}

/* SETINHA ANIMADA */
.arrow-anim {
  color: var(--teal-bright);
  opacity: 0.7;
  width: 70px;
  height: 24px;
}
.timeline-connector {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 36px;
}

/* GRID SERVIÇOS — 4 colunas x 3 linhas */
.servicos-grid {
  grid-template-columns: repeat(4, 1fr);
}


/* ---------- AJUSTES PORTFÓLIO / HEADER PADRÃO ---------- */
.nav-menu{gap:24px}
.nav-cta{white-space:nowrap}
.portfolio-hero{position:relative;overflow:hidden;padding:150px 0 85px;min-height:560px;display:flex;align-items:center}
.portfolio-hero-content{position:relative;z-index:2;max-width:760px}
.portfolio-section{position:relative}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.portfolio-card{display:flex;flex-direction:column;background:rgba(255,255,255,.035);border:1px solid var(--border);border-radius:26px;overflow:hidden;transition:var(--transition);box-shadow:var(--shadow-soft);min-height:100%}
.portfolio-card:hover{transform:translateY(-7px);border-color:rgba(45,212,191,.42);box-shadow:0 24px 60px rgba(0,0,0,.34)}
.portfolio-card-img{height:210px;background:rgba(45,212,191,.08);overflow:hidden}
.portfolio-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.portfolio-card:hover .portfolio-card-img img{transform:scale(1.06)}
.portfolio-card-body{padding:24px;display:flex;flex-direction:column;gap:12px;flex:1}
.portfolio-card-label{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--teal-bright);text-transform:uppercase;letter-spacing:.08em}
.portfolio-card h3{font-family:var(--font-head);font-size:1.45rem;color:var(--text);margin:0}
.portfolio-card p{color:var(--text-soft);line-height:1.55;margin:0}
.portfolio-services{margin-top:auto;color:var(--text-dim);font-size:13px;border-top:1px solid var(--border);padding-top:14px}
.portfolio-more{display:inline-flex;align-items:center;gap:8px;color:var(--teal-bright);font-family:var(--font-head);font-weight:700;font-size:14px;margin-top:2px}
.portfolio-cta{padding:80px 0;background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.cta-card{border:1px solid var(--border);background:linear-gradient(135deg,rgba(45,212,191,.11),rgba(255,255,255,.03));border-radius:30px;padding:42px;display:flex;align-items:center;justify-content:space-between;gap:30px;box-shadow:var(--shadow-soft)}
@media (max-width:1024px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}.nav-menu{gap:18px}.nav-link{font-size:13px}.nav-cta{padding:10px 16px}}
@media (max-width:768px){.portfolio-hero{padding:120px 0 70px;min-height:auto}.portfolio-grid{grid-template-columns:1fr}.cta-card{flex-direction:column;text-align:center;padding:30px}.portfolio-card-img{height:190px}}
