/*
Theme Name: Otica Campos
Author: Nera Digital
Author URI: https://neradigital.com.br
Description: Site institucional da Otica Campos
Version: 4.0
*/

*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --laranja:#E8620A;
  --laranja-escuro:#C04D00;
  --laranja-claro:#FFF0E8;
  --creme:#FAF7F4;
  --bege:#F2EDE8;
  --marrom:#3D2B1F;
  --cinza:#6B6560;
  --branco:#FFFFFF;
}
html{scroll-behavior:smooth;}
body{font-family:'Nunito',sans-serif;color:var(--marrom);background:var(--branco);}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;width:100%;z-index:99998;
  background:rgba(255,255,255,0.97);
  border-bottom:1px solid #f0e8e0;
  padding:0 5%;
  display:flex;align-items:center;justify-content:space-between;
  height:86px;
  backdrop-filter:blur(8px);
}
.nav-logo{
  font-family:'Playfair Display',serif;
  font-size:1.5rem;font-weight:700;
  color:var(--marrom);letter-spacing:-0.5px;
  text-decoration:none;
}
.nav-logo span{color:var(--laranja);}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none;}
.nav-links a{
  text-decoration:none;font-size:0.9rem;font-weight:600;
  color:var(--cinza);transition:color 0.2s;
}
.nav-links a:hover{color:var(--laranja);}
.nav-cta{
  background:var(--laranja);color:#fff;
  padding:10px 22px;border-radius:50px;
  font-weight:700;font-size:0.88rem;
  text-decoration:none;transition:background 0.2s;white-space:nowrap;
}
.nav-cta:hover{background:var(--laranja-escuro);color:#fff;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;border:none;background:none;padding:4px;}
.hamburger span{width:24px;height:2px;background:var(--marrom);border-radius:2px;transition:all 0.3s;display:block;}
.mobile-menu{
  display:none;position:fixed;top:86px;left:0;width:100%;
  background:#fff;padding:1.5rem 5%;
  border-bottom:1px solid #f0e8e0;z-index:998;
  flex-direction:column;gap:1rem;
  z-index:99999;
}
.mobile-menu a{
  font-size:1rem;font-weight:600;color:var(--marrom);
  text-decoration:none;padding:0.75rem 0;
  border-bottom:1px solid var(--bege);
  display:block;position:relative;z-index:99999;
}
.mobile-menu .nav-cta{text-align:center;margin-top:0.5rem;}
.mobile-menu.open{display:flex;}

/* ── HERO ── */
#home{
  min-height:100vh;
  background:var(--creme);
  display:flex;align-items:center;
  padding:86px 5% 0;
  position:relative;overflow:hidden;
}
.hero-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:4rem;align-items:center;
  max-width:1200px;margin:0 auto;width:100%;
  padding:5rem 0;
}
.hero-tag{
  display:inline-block;
  background:var(--laranja-claro);color:var(--laranja-escuro);
  font-size:0.8rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  padding:6px 14px;border-radius:50px;margin-bottom:1.5rem;
}
.hero-h1{
  font-family:'Playfair Display',serif;
  font-size:3rem;line-height:1.2;font-weight:700;
  color:var(--marrom);margin-bottom:1.5rem;
}
.hero-h1 em{color:var(--laranja);font-style:normal;}
.hero-sub{
  font-size:1.1rem;line-height:1.8;color:var(--cinza);
  margin-bottom:2.5rem;max-width:480px;
}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;}
.btn-primary{
  background:var(--laranja);color:#fff;
  padding:14px 32px;border-radius:50px;
  font-weight:700;font-size:1rem;
  text-decoration:none;transition:all 0.2s;
  display:inline-flex;align-items:center;gap:8px;
}
.btn-primary:hover{background:var(--laranja-escuro);transform:translateY(-2px);}
.btn-outline{
  border:2px solid var(--marrom);color:var(--marrom);
  padding:14px 32px;border-radius:50px;
  font-weight:700;font-size:1rem;
  text-decoration:none;transition:all 0.2s;
}
.btn-outline:hover{background:var(--marrom);color:#fff;}
.hero-img{position:relative;}
.hero-img img{
  width:100%;border-radius:20px;
  object-fit:cover;height:560px;
  box-shadow:0 30px 80px rgba(61,43,31,0.15);
}
.hero-badge{
  position:absolute;bottom:-20px;left:-20px;
  background:#fff;border-radius:16px;
  padding:16px 20px;
  box-shadow:0 10px 40px rgba(0,0,0,0.1);
  display:flex;align-items:center;gap:12px;
}
.hero-badge-icon{display:flex;align-items:center;justify-content:center;}
.hero-badge-text strong{display:block;font-size:1rem;font-weight:700;color:var(--marrom);}
.hero-badge-text span{font-size:0.8rem;color:var(--cinza);}

/* ── SEÇÕES GERAIS ── */
section{padding:6rem 5%;}
.section-inner{max-width:1200px;margin:0 auto;}
.section-tag{
  display:inline-block;
  background:var(--laranja-claro);color:var(--laranja-escuro);
  font-size:0.78rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  padding:5px 14px;border-radius:50px;margin-bottom:1rem;
}
.section-title{
  font-family:'Playfair Display',serif;
  font-size:2.4rem;font-weight:700;color:var(--marrom);
  line-height:1.25;margin-bottom:1rem;
}
.section-title em{color:var(--laranja);font-style:normal;}
.section-sub{font-size:1.05rem;color:var(--cinza);line-height:1.8;max-width:580px;}

/* ── IVISION ── */
#ivision{background:var(--marrom);}
#ivision .section-title{color:#fff;}
#ivision .section-sub{color:rgba(255,255,255,0.7);}
#ivision .section-tag{background:rgba(232,98,10,0.3);color:#ffb07a;}
.ivision-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
  margin-top:3rem;
}
.ivision-card{
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);
  border-radius:16px;padding:2rem;
  transition:background 0.2s;
}
.ivision-card:hover{background:rgba(255,255,255,0.1);}
.ivision-icon{
  width:52px;height:52px;border-radius:12px;
  background:rgba(232,98,10,0.25);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.25rem;
  color:rgba(255,220,180,0.9);
}
.ivision-card h3{font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:0.75rem;}
.ivision-card p{font-size:0.9rem;color:rgba(255,255,255,0.65);line-height:1.7;}

/* ── PRODUTOS ── */
#produtos{background:var(--creme);}
.produtos-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;
  margin-top:3rem;
}
.produto-card{
  background:#fff;border-radius:16px;padding:2rem 1.5rem;
  text-align:center;border:1px solid #ece7e2;
  transition:all 0.2s;text-decoration:none;display:block;
  color:var(--marrom);
}
.produto-card:hover{
  border-color:var(--laranja);
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(232,98,10,0.12);
}
.produto-icon{margin-bottom:1rem;display:flex;justify-content:center;color:var(--laranja);}
.produto-card h3{font-weight:700;font-size:1rem;margin-bottom:0.5rem;}
.produto-card p{font-size:0.85rem;color:var(--cinza);line-height:1.6;}

/* ── SOBRE (home) ── */
#sobre-home{background:var(--bege);}
.sobre-home-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.sobre-home-img img{width:100%;border-radius:20px;object-fit:cover;height:500px;box-shadow:0 20px 60px rgba(61,43,31,0.12);}
.sobre-home-text .section-sub{max-width:none;margin-bottom:2rem;}
.check-list{list-style:none;display:flex;flex-direction:column;gap:0.75rem;margin-bottom:2.5rem;}
.check-list li{display:flex;align-items:flex-start;gap:12px;font-size:0.95rem;color:var(--cinza);}
.check-list li::before{
  content:'✓';
  min-width:24px;height:24px;border-radius:50%;
  background:var(--laranja-claro);color:var(--laranja);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:0.8rem;margin-top:1px;
}

/* ── DEPOIMENTOS ── */
#depoimentos{background:#fff;}
.dep-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem;}
.dep-card{
  background:var(--creme);border-radius:16px;padding:2rem;
  border:1px solid #ece7e2;
}
.dep-stars{color:var(--laranja);font-size:1rem;margin-bottom:1rem;}
.dep-text{font-size:0.95rem;color:var(--cinza);line-height:1.75;margin-bottom:1.5rem;font-style:italic;}
.dep-autor{font-weight:700;font-size:0.9rem;color:var(--marrom);}
.dep-fonte{font-size:0.78rem;color:var(--cinza);}

/* ── MAPA ── */
#localizacao{background:var(--creme);}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;margin-top:3rem;}
.loc-info{display:flex;flex-direction:column;gap:1.5rem;}
.loc-item{display:flex;gap:1rem;align-items:flex-start;}
.loc-item-icon{
  width:44px;height:44px;border-radius:12px;min-width:44px;
  background:var(--laranja-claro);
  display:flex;align-items:center;justify-content:center;
  color:var(--laranja-escuro);
}
.loc-item-text strong{display:block;font-weight:700;color:var(--marrom);margin-bottom:4px;}
.loc-item-text span{font-size:0.9rem;color:var(--cinza);line-height:1.6;}
.loc-map{border-radius:20px;overflow:hidden;box-shadow:0 12px 40px rgba(0,0,0,0.1);}
.loc-map iframe{width:100%;height:380px;border:none;display:block;}

/* ── FOOTER ── */
footer{
  background:var(--marrom);color:rgba(255,255,255,0.7);
  padding:4rem 5% 2rem;
}
.footer-inner{max-width:1200px;margin:0 auto;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:4rem;margin-bottom:3rem;}
.footer-brand h3{
  font-family:'Playfair Display',serif;
  font-size:1.5rem;color:#fff;margin-bottom:1rem;
}
.footer-brand h3 span{color:var(--laranja);}
.footer-brand p{font-size:0.9rem;line-height:1.7;max-width:300px;}
.footer-col h4{color:#fff;font-size:0.95rem;font-weight:700;margin-bottom:1rem;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:0.6rem;}
.footer-col a{color:rgba(255,255,255,0.65);text-decoration:none;font-size:0.88rem;transition:color 0.2s;}
.footer-col a:hover{color:#fff;}
.footer-social{display:flex;gap:0.75rem;margin-top:1.5rem;}
.social-btn{
  width:40px;height:40px;border-radius:10px;
  background:rgba(255,255,255,0.08);
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;
  transition:background 0.2s;
  color:rgba(255,255,255,0.75);
}
.social-btn svg{width:18px;height:18px;}
.social-btn svg[fill="none"]{stroke:currentColor;fill:none;}
.social-btn svg[fill="currentColor"]{fill:currentColor;stroke:none;}
.social-btn:hover{background:var(--laranja);color:#fff;}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.1);
  padding-top:1.5rem;
  display:flex;justify-content:space-between;align-items:center;
  font-size:0.82rem;flex-wrap:wrap;gap:1rem;
}
.footer-bottom a{color:rgba(255,255,255,0.5);text-decoration:none;}
.footer-bottom a:hover{color:#fff;}

/* ── WHATSAPP FLOAT ── */
.wa-float{
  position:fixed;bottom:28px;right:28px;z-index:1000;
  background:#25D366;color:#fff;
  width:60px;height:60px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;
  box-shadow:0 4px 20px rgba(37,211,102,0.4);
  transition:transform 0.2s,box-shadow 0.2s;
}
.wa-float svg{width:28px;height:28px;fill:#fff;}
.wa-float:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,0.5);}

/* ── PÁGINAS INTERNAS ── */


.page-hero{
  background:var(--marrom);
  padding:146px 5% 5rem;
  text-align:center;
}
.page-hero h1{
  font-family:'Playfair Display',serif;
  font-size:2.8rem;color:#fff;margin-bottom:1rem;
}
.page-hero p{font-size:1.1rem;color:rgba(255,255,255,0.75);max-width:600px;margin:0 auto 2rem;}
.page-content{padding:5rem 5%;max-width:1000px;margin:0 auto;}
.page-content h2{
  font-family:'Playfair Display',serif;
  font-size:1.9rem;color:var(--marrom);margin:3rem 0 1.25rem;
}
.page-content h2:first-child{margin-top:0;}
.page-content p{font-size:1rem;color:var(--cinza);line-height:1.85;margin-bottom:1rem;}
.page-list{list-style:none;display:flex;flex-direction:column;gap:0.85rem;margin:1.25rem 0 2rem;}
.page-list li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:0.97rem;color:var(--cinza);line-height:1.65;
}
.page-list li::before{
  content:'→';color:var(--laranja);font-weight:700;
  min-width:20px;margin-top:1px;
}
.page-list li strong{
  white-space:nowrap;
}
.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin:2rem 0;}
.feature-card{
  background:var(--creme);border-radius:14px;padding:1.75rem;
  border:1px solid #ece7e2;
}
.feature-card h3{font-size:1.05rem;font-weight:700;color:var(--marrom);margin-bottom:0.6rem;}
.feature-card p{font-size:0.9rem;color:var(--cinza);line-height:1.65;}
.numbered-list{list-style:none;display:flex;flex-direction:column;gap:1.25rem;margin:1.5rem 0 2rem;}
.numbered-list li{display:flex;gap:16px;align-items:flex-start;}
.nl-num{
  min-width:34px;height:34px;border-radius:50%;
  background:var(--laranja);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:0.85rem;
}
.nl-text strong{display:block;color:var(--marrom);font-weight:700;margin-bottom:4px;}
.nl-text span{font-size:0.9rem;color:var(--cinza);line-height:1.65;}
.premios-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin:2.5rem 0;}
.premio-img{width:100%;border-radius:14px;object-fit:cover;height:340px;}
.cta-box{
  background:var(--marrom);border-radius:20px;
  padding:3rem;text-align:center;margin-top:3rem;
}
.cta-box h3{font-family:'Playfair Display',serif;font-size:1.7rem;color:#fff;margin-bottom:0.75rem;}
.cta-box p{color:rgba(255,255,255,0.7);margin-bottom:2rem;}
.socias-grid{display:grid;grid-template-columns:380px 1fr;gap:3rem;margin:2.5rem 0;align-items:center;}
.socias-img{width:100%;border-radius:14px;object-fit:cover;max-height:420px;}
.socias-text h3{font-size:1.3rem;font-weight:700;color:var(--marrom);margin-bottom:0.75rem;font-family:'Playfair Display',serif;}
.socias-text p{font-size:0.95rem;color:var(--cinza);line-height:1.8;}

/* ── CONTATO ── */
.contato-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:2rem;}
.contato-card{
  background:var(--creme);border-radius:16px;padding:2rem;
  border:1px solid #ece7e2;display:flex;gap:1.25rem;align-items:flex-start;
}
.contato-icon{
  width:50px;height:50px;min-width:50px;border-radius:12px;
  background:var(--laranja-claro);
  display:flex;align-items:center;justify-content:center;
  color:var(--laranja-escuro);
}
.contato-card h3{font-weight:700;color:var(--marrom);margin-bottom:6px;}
.contato-card p,
.contato-card a{font-size:0.93rem;color:var(--cinza);line-height:1.65;text-decoration:none;}
.contato-card a:hover{color:var(--laranja);}
.contato-map{border-radius:16px;overflow:hidden;margin-top:2rem;box-shadow:0 8px 30px rgba(0,0,0,0.08);}
.contato-map iframe{width:100%;height:400px;border:none;display:block;}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .hero-inner,.sobre-home-grid,.footer-grid,.loc-grid,.socias-grid{grid-template-columns:1fr;gap:2.5rem;}
  .ivision-grid{grid-template-columns:1fr;}
  .produtos-grid{grid-template-columns:repeat(2,1fr);}
  .dep-grid{grid-template-columns:1fr;}
  .feature-grid,.premios-grid{grid-template-columns:1fr;}
  .hero-h1{font-size:2.2rem;}
  .section-title{font-size:2rem;}
  .footer-grid{grid-template-columns:1fr;gap:2rem;}
  .contato-grid{grid-template-columns:1fr;}
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .hero-img img{height:380px;}
  .sobre-home-img img{height:350px;}
}
@media(max-width:600px){
  section{padding:4rem 5%;}
  .hero-h1{font-size:1.8rem;}
  .hero-tag{margin-top:1.5rem;}
  .hero-btns{flex-direction:column;}
  .btn-primary,.btn-outline{text-align:center;justify-content:center;}
  .produtos-grid{grid-template-columns:1fr 1fr;}
  .page-hero h1{font-size:2rem;}
  .hero-badge{display:none;}
}

/* WordPress admin bar */
.admin-bar nav{top:32px;}
.admin-bar .mobile-menu{top:118px;}
@media(max-width:782px){
  .admin-bar nav{top:46px;}
  .admin-bar .mobile-menu{top:132px;}
}
