/*
Theme Name:   INSA
Theme URI:    https://agmiz.com.br
Description:  Tema oficial do Instituto Nossa Senhora Aparecida
Author:       Ágmiz
Author URI:   https://agmiz.com.br
Version:      1.1.0
Text Domain:  insa
*/

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#A04048;--red-h:#8B3640;--red-light:#FDF2F3;
  --gold:#E8A838;--gold-h:#D09530;
  --green:#4CAF7D;--green-mid:#5DBF8E;--green-light:#EDF7F2;--green-dark:#2B5C3A;
  --white:#FFFFFF;--gray:#2D2D3A;--gray-light:#6B7280;
  --border:#E5E7EB;--bg-alt:#F0F2F5;--bg-ice:#F7F8FA;
  --font-t:'Nunito',sans-serif;--font-b:'Open Sans',sans-serif;--font-a:'Playfair Display',serif;
  --r-sm:8px;--r-md:14px;--r-lg:22px;--r-full:999px;
  --sh-sm:0 2px 12px rgba(0,0,0,.05);--sh-md:0 6px 24px rgba(0,0,0,.08);
  --tr:all .3s ease;
}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--gray);background:var(--white);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{text-decoration:none}

/* HEADER */
.site-header{background:var(--green-dark);box-shadow:0 2px 20px rgba(0,0,0,.18);position:sticky;top:0;z-index:100;padding:0 40px}
.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:88px;gap:24px}
.logo-area{display:flex;align-items:center;gap:12px}
.logo-img{height:70px;width:auto}
.logo-text{font-family:var(--font-t);font-weight:800;font-size:1rem;color:#fff;line-height:1.2}
.logo-text span{color:var(--gold);display:block;font-size:.75rem;font-weight:600}
nav{display:flex;align-items:center;gap:28px}
nav a{font-family:var(--font-t);font-weight:600;font-size:.88rem;color:rgba(255,255,255,.85);transition:var(--tr);padding:4px 0;border-bottom:2px solid transparent}
nav a:hover,nav a.active{color:var(--gold);border-bottom-color:var(--gold)}

/* HAMBURGER */
.mobile-menu-toggle {
  display: none;
  flex-direction: column;
  gap: 6px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 10px;
  z-index: 101;
  position: relative;
}
.mobile-menu-toggle span {
  display: block;
  width: 28px;
  height: 3px;
  background: #fff;
  border-radius: 4px;
  transition: var(--tr);
}
.mobile-menu-toggle.active span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
.mobile-menu-toggle.active span:nth-child(2) { opacity: 0; }
.mobile-menu-toggle.active span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }

/* BOTÕES */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border-radius:var(--r-full);font-family:var(--font-t);font-weight:700;font-size:.88rem;cursor:pointer;transition:var(--tr);border:2px solid transparent}
.btn-red{background:var(--red);color:#fff;box-shadow:0 4px 16px rgba(160,64,72,.25)}
.btn-red:hover{background:var(--red-h);color:#fff;transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:#fff;box-shadow:0 4px 16px rgba(232,168,56,.3)}
.btn-gold:hover{background:var(--gold-h);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:#fff}
.btn-ghost:hover{background:#fff;color:var(--red)}
.btn-ghost-dark{background:transparent;color:var(--red);border-color:var(--red)}
.btn-ghost-dark:hover{background:var(--red);color:#fff}
.btn-whatsapp{background:#25D366;color:#fff;box-shadow:0 4px 16px rgba(37,211,102,.35)}
.btn-whatsapp:hover{background:#1ebe5d;color:#fff;transform:translateY(-2px)}
.btn-lg{padding:14px 32px;font-size:.95rem}

/* SEÇÕES */
section{padding:80px 20px}
.container{max-width:1200px;margin:0 auto}
.bg-alt{background:var(--bg-alt)}
.bg-ice{background:var(--bg-ice)}
.bg-red{background:var(--red)}
.bg-green{background:var(--green)}
.section-title{text-align:center;margin-bottom:48px}
.section-title h2{font-family:var(--font-t);font-weight:800;font-size:clamp(1.8rem,3vw,2.5rem);color:var(--gray)}
.section-title .bar{width:56px;height:4px;background:var(--gold);border-radius:var(--r-full);margin:14px auto}
.section-title p{color:var(--gray-light);max-width:580px;margin:12px auto 0;font-size:1.05rem;line-height:1.7}
.white-on-dark h2,.white-on-dark p{color:#fff}
.white-on-dark .bar{background:var(--gold)}

/* HERO */
.hero{min-height:90vh;display:flex;align-items:center;padding:80px 40px;position:relative;background:linear-gradient(135deg,rgba(232,168,56,.78) 0%,rgba(160,64,72,.68) 100%),url('https://images.unsplash.com/photo-1503676260728-1c00da094a0b?w=1600&q=80') center/cover no-repeat}
.hero-content{max-width:720px;color:#fff}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.25);border:2px solid #ffffff;color:#ffffff;padding:7px 18px;border-radius:var(--r-full);font-family:var(--font-t);font-weight:700;font-size:.83rem;margin-bottom:28px;text-shadow:0 1px 4px rgba(0,0,0,.3)}
.hero h1{font-family:var(--font-t);font-weight:900;font-size:clamp(2.2rem,5vw,3.8rem);color:#fff;line-height:1.15;margin-bottom:22px;text-shadow:0 2px 24px rgba(0,0,0,.18)}
.hero .sub{color:rgba(255,255,255,.88);font-size:1.15rem;line-height:1.72;max-width:600px;margin-bottom:38px}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-family:var(--font-t);font-size:.8rem;text-align:center;animation:bounce 2s ease-in-out infinite}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* STATS */
.stats{background:var(--red);padding:0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:36px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.12)}
.stat:last-child{border-right:none}
.stat-num{font-family:var(--font-t);font-weight:900;font-size:2.4rem;color:var(--gold);display:block;line-height:1;margin-bottom:6px}
.stat-icon{font-size:1.5rem;margin-bottom:4px;display:block}
.stat-label{color:rgba(255,255,255,.82);font-family:var(--font-t);font-weight:600;font-size:.88rem}

/* FEATURE CARDS */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.feature-card{background:var(--white);border-radius:var(--r-lg);padding:40px 30px;text-align:center;box-shadow:var(--sh-sm);border:1px solid var(--border);transition:var(--tr)}
.feature-card:hover{border-color:var(--gold);box-shadow:var(--sh-md);transform:translateY(-6px)}
.feature-emoji{font-size:3rem;margin-bottom:18px;display:block}
.feature-card h3{font-family:var(--font-t);font-weight:800;font-size:1.2rem;margin-bottom:12px}
.feature-card p{color:var(--gray-light);font-size:.93rem;line-height:1.65}
.fc-red{border-top:4px solid var(--red)!important}.fc-red h3{color:var(--red)}
.fc-green{border-top:4px solid var(--green)!important}.fc-green h3{color:var(--green)}
.fc-gold{border-top:4px solid var(--gold)!important}.fc-gold h3{color:var(--gold)}

/* INCLUSÃO */
.inclusion{background:var(--red);padding:80px 40px}
.inclusion-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.inclusion-ph{background:rgba(255,255,255,.12);border:2px dashed rgba(255,255,255,.35);border-radius:var(--r-lg);height:420px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:rgba(255,255,255,.6);font-family:var(--font-t);font-weight:600;font-size:.9rem}
.inclusion-content .badge{display:inline-block;background:rgba(232,168,56,.22);border:1px solid var(--gold);color:var(--gold);padding:5px 14px;border-radius:var(--r-full);font-family:var(--font-t);font-weight:600;font-size:.8rem;margin-bottom:20px}
.inclusion-content h2{font-family:var(--font-t);font-weight:800;font-size:clamp(1.6rem,2.5vw,2.3rem);color:#fff;line-height:1.25;margin-bottom:18px}
.inclusion-content p{color:rgba(255,255,255,.85);line-height:1.76;margin-bottom:28px;font-size:1rem}

/* DEPOIMENTOS */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial{background:var(--white);border-radius:var(--r-lg);padding:32px 28px;box-shadow:var(--sh-sm);border-left:4px solid var(--red);position:relative}
.testimonial::before{content:'"';font-family:var(--font-a);font-size:5rem;color:var(--red);opacity:.18;position:absolute;top:-12px;left:18px;line-height:1}
.test-text{font-style:italic;color:var(--gray);line-height:1.75;margin-bottom:22px;font-size:.95rem}
.test-author{display:flex;align-items:center;gap:12px}
.test-avatar{width:46px;height:46px;border-radius:50%;background:var(--red-light);border:3px solid var(--red);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.test-name{font-family:var(--font-t);font-weight:700;font-size:.9rem;color:var(--gray)}
.test-role{font-size:.78rem;color:#999}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:#fff;border-radius:var(--r-md);box-shadow:var(--sh-sm);overflow:hidden;transition:var(--tr)}
.blog-card:hover{box-shadow:var(--sh-md);transform:translateY(-4px)}
.blog-thumb{aspect-ratio:16/9;background:var(--red-light);display:flex;align-items:center;justify-content:center;color:var(--red);font-size:2rem;position:relative;overflow:hidden}
.blog-thumb img{width:100%;height:100%;object-fit:cover}
.blog-cat{display:inline-block;background:var(--red);color:#fff;padding:3px 10px;border-radius:var(--r-full);font-family:var(--font-t);font-size:.72rem;font-weight:700;position:absolute;top:12px;left:12px}
.blog-body{padding:22px 20px}
.blog-body h4{font-family:var(--font-t);font-weight:700;font-size:1rem;color:var(--gray);line-height:1.4;margin-bottom:10px}
.blog-body p{font-size:.87rem;color:var(--gray-light);line-height:1.6;margin-bottom:14px}
.blog-link{font-family:var(--font-t);font-weight:700;font-size:.83rem;color:var(--red)}
.blog-link:hover{color:var(--red-h)}

/* CTA */
.cta{background:var(--red);padding:100px 20px;text-align:center;position:relative;overflow:hidden}
.cta::before,.cta::after{content:'';position:absolute;border-radius:50%;background:rgba(255,255,255,.04)}
.cta::before{width:400px;height:400px;top:-200px;left:-80px}
.cta::after{width:300px;height:300px;bottom:-150px;right:-40px}
.cta h2{font-family:var(--font-t);font-weight:900;font-size:clamp(1.8rem,3.5vw,3rem);color:#fff;margin-bottom:16px;position:relative;z-index:1}
.cta p{color:rgba(255,255,255,.88);font-size:1.05rem;max-width:480px;margin:0 auto 36px;position:relative;z-index:1}
.cta .btn{position:relative;z-index:1}

/* FOOTER */
footer{background:var(--bg-ice);padding:64px 40px 32px;color:var(--gray)}
.footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-logo{height:52px;width:auto;margin-bottom:20px}
.footer-brand p{font-size:.9rem;color:var(--gray-light);line-height:1.7;margin-bottom:20px}
.footer-social{display:flex;gap:12px}
.footer-social a{width:38px;height:38px;background:var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gray);transition:var(--tr);font-size:.9rem}
.footer-social a:hover{background:var(--red);color:#fff}
.footer-col h4{font-family:var(--font-t);font-weight:700;font-size:.85rem;color:var(--gray);text-transform:uppercase;letter-spacing:.5px;margin-bottom:18px}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{font-size:.88rem;color:var(--gray-light);transition:var(--tr)}
.footer-col ul li a:hover{color:var(--red)}
.footer-col address{font-style:normal;font-size:.88rem;color:var(--gray-light);line-height:1.7}
.footer-col address a{color:var(--gray-light);display:block;margin-top:8px;transition:var(--tr)}
.footer-col address a:hover{color:var(--red)}
.footer-bottom{max-width:1200px;margin:0 auto;border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:.8rem;color:#aaa}
.footer-by{font-size:.8rem;color:#aaa}
.footer-by a{color:var(--gold)}

/* WHATSAPP FLOAT */
.whatsapp-float{position:fixed;bottom:28px;right:28px;width:60px;height:60px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);z-index:9999;transition:var(--tr);animation:wa-pulse 2s ease-in-out infinite}
.whatsapp-float:hover{transform:scale(1.1)}
.whatsapp-float svg{width:32px;height:32px;fill:#fff}
@keyframes wa-pulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 40px rgba(37,211,102,.6)}}

/* PASSO A PASSO */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative}
.steps::before{content:'';position:absolute;top:36px;left:12.5%;right:12.5%;height:2px;background:linear-gradient(to right,var(--red),var(--gold));z-index:0}
.step{text-align:center;position:relative;z-index:1}
.step-num{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-t);font-weight:800;font-size:1.5rem;color:#fff;margin:0 auto 20px;border:4px solid #fff;box-shadow:var(--sh-md)}
.step:nth-child(1) .step-num{background:var(--red)}
.step:nth-child(2) .step-num{background:var(--gold)}
.step:nth-child(3) .step-num{background:var(--green-mid)}
.step:nth-child(4) .step-num{background:var(--green)}
.step h3{font-family:var(--font-t);font-weight:800;font-size:1rem;margin-bottom:8px}
.step p{font-size:.88rem;color:var(--gray-light);line-height:1.55}

/* FAQ */
.faq-list{max-width:800px;margin:0 auto}
details{border-bottom:1px solid var(--border);padding:4px 0}
details:first-child{border-top:1px solid var(--border)}
summary{padding:18px 16px;font-family:var(--font-t);font-weight:600;font-size:1rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;color:var(--gray);transition:var(--tr)}
summary:hover{color:var(--red)}
summary::after{content:'+';font-size:1.4rem;color:var(--gold);transition:var(--tr)}
details[open] summary{color:var(--red)}
details[open] summary::after{content:'−'}
.faq-answer{padding:4px 16px 18px;color:var(--gray-light);line-height:1.75;font-size:.95rem}

/* GALERIA */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-ph{background:var(--red-light);border:2px dashed rgba(160,64,72,.2);border-radius:var(--r-md);aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--red);font-family:var(--font-t);font-size:.82rem;font-weight:600;text-align:center;padding:12px}
.gallery-ph .icon{font-size:2rem;opacity:.45}
.gallery-item{border-radius:var(--r-md);overflow:hidden;aspect-ratio:4/3}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.05)}

/* CHECKLIST */
.doc-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.doc-list li{display:flex;align-items:flex-start;gap:10px;font-size:.95rem;color:var(--gray);line-height:1.5}
.doc-list li::before{content:'📄';flex-shrink:0}

/* TAGS INCLUSÃO */
.tag-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.tag{background:var(--red-light);border:1px solid rgba(160,64,72,.2);color:var(--red);padding:6px 14px;border-radius:var(--r-full);font-family:var(--font-t);font-weight:600;font-size:.82rem}

/* PÁGINA INTERNA HERO */
.page-hero{background:linear-gradient(135deg,rgba(160,64,72,.92),rgba(45,45,58,.85)),url('https://images.unsplash.com/photo-1503676260728-1c00da094a0b?w=1200&q=80') center/cover;padding:80px 40px;text-align:center;color:#fff}
.page-hero .badge{display:inline-block;background:rgba(232,168,56,.22);border:1px solid var(--gold);color:var(--gold);padding:5px 14px;border-radius:var(--r-full);font-family:var(--font-t);font-weight:600;font-size:.8rem;margin-bottom:20px}
.page-hero h1{font-family:var(--font-t);font-weight:900;font-size:clamp(2rem,4vw,3.2rem);color:#fff;line-height:1.2;margin-bottom:16px;text-shadow:0 2px 20px rgba(0,0,0,.2)}
.page-hero p{color:rgba(255,255,255,.88);font-size:1.1rem;max-width:640px;margin:0 auto;line-height:1.7}

/* TWO-COL */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.two-col-text h2{font-family:var(--font-t);font-weight:800;font-size:clamp(1.6rem,2.5vw,2.2rem);color:var(--gray);margin-bottom:16px}
.two-col-text p{color:var(--gray-light);line-height:1.75;margin-bottom:16px;font-size:.98rem}
.two-col-text ul{list-style:none;margin-top:8px}
.two-col-text ul li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.95rem;color:var(--gray)}
.two-col-text ul li:last-child{border-bottom:none}
.two-col-text ul li::before{content:'✔';color:var(--green);font-weight:700;flex-shrink:0}
.img-ph{background:var(--red-light);border:2px dashed rgba(160,64,72,.2);border-radius:var(--r-lg);min-height:380px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--red);font-family:var(--font-t);font-weight:600;font-size:.9rem;text-align:center;padding:24px}
.img-ph span{font-size:3rem;opacity:.4}

/* TIMELINE ROTINA */
.timeline{display:flex;flex-direction:column;gap:0}
.tl-item{display:flex;gap:24px;padding:20px 0;border-bottom:1px solid var(--border)}
.tl-item:last-child{border-bottom:none}
.tl-time{font-family:var(--font-t);font-weight:800;font-size:.9rem;color:var(--red);min-width:60px;padding-top:2px}
.tl-emoji{font-size:1.5rem;flex-shrink:0}
.tl-content h4{font-family:var(--font-t);font-weight:700;font-size:1rem;margin-bottom:4px;color:var(--gray)}
.tl-content p{font-size:.9rem;color:var(--gray-light);line-height:1.6}

/* CARDS GRADE */
.grade-card{background:#fff;border-radius:var(--r-md);padding:28px 24px;box-shadow:var(--sh-sm);border-top:4px solid var(--gold)}
.grade-card h3{font-family:var(--font-t);font-weight:800;font-size:1.1rem;margin-bottom:12px;color:var(--gray)}
.grade-card p{font-size:.88rem;color:var(--gray-light);line-height:1.6}

/* CONTATO */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.contact-info h3{font-family:var(--font-t);font-weight:700;font-size:1.3rem;margin-bottom:24px;color:var(--gray)}
.contact-item{display:flex;gap:16px;margin-bottom:20px;align-items:flex-start}
.contact-item .icon{width:44px;height:44px;border-radius:var(--r-md);background:var(--red-light);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.contact-item p{font-size:.9rem;color:var(--gray-light);line-height:1.6;margin-top:2px}
.contact-item strong{display:block;font-family:var(--font-t);font-weight:700;color:var(--gray);margin-bottom:2px}
.contact-form{background:var(--bg-ice);border-radius:var(--r-lg);padding:40px;box-shadow:var(--sh-sm)}
.contact-form h3{font-family:var(--font-t);font-weight:700;font-size:1.2rem;margin-bottom:24px;color:var(--gray)}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-family:var(--font-t);font-weight:600;font-size:.85rem;color:var(--gray);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--r-md);font-family:var(--font-b);font-size:.9rem;color:var(--gray);transition:var(--tr);background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(160,64,72,.08)}
.form-group textarea{resize:vertical;min-height:120px}

/* RESPONSIVE */
@media(max-width:1024px){
  .features-grid,.testimonials-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .site-header{padding:0 20px}
  .mobile-menu-toggle { display: flex; }
  
  nav {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    right: -100%;
    width: 80%;
    max-width: 300px;
    height: 100vh;
    background: var(--green-dark);
    padding: 100px 40px;
    transition: var(--tr);
    box-shadow: -10px 0 30px rgba(0,0,0,0.2);
    z-index: 100;
    overflow-y: auto;
  }
  
  nav.active {
    right: 0;
  }
  
  nav a {
    font-size: 1.1rem;
    padding: 15px 0;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    width: 100%;
    text-align: left;
  }

  .hero{padding:60px 20px;min-height:70vh}
  .features-grid,.testimonials-grid,.blog-grid,.two-col,.contact-grid,.inclusion-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .steps::before{display:none}
  .doc-list{grid-template-columns:1fr}
  footer{padding:48px 20px 24px}
  .footer-grid{grid-template-columns:1fr;gap:28px}
}
