﻿﻿/*
Theme Name: IMForM Escola de Missões
Theme URI: https://imform.com.br
Author: IMForM
Description: Tema personalizado do Instituto de Formação Missionária — Teresópolis, RJ.
Version: 1.0
Text Domain: imform
*/

:root{--red:#c33541;--red-dark:#9e2733;--red-soft:rgba(195,53,65,0.08);--red-border:rgba(195,53,65,0.2);--dark:#282c2f;--dark2:#1a1d1f;--white:#fefefe;--cream:#f7f4ef;--stone:#e6e1d8;--ink:#1c1f21;--gray:#7a7672;--gray-light:#b5b0a8;--hv:'Helvetica Neue',Helvetica,Arial,sans-serif;--serif:'Cormorant Garamond',serif}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--white);color:var(--ink);font-family:var(--hv);font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.1rem 2.5rem;display:flex;align-items:center;justify-content:space-between;background:rgba(254,254,254,0);backdrop-filter:blur(0px);border-bottom:1px solid transparent;transition:all .4s ease}
nav.scrolled{background:rgba(254,254,254,0.96);backdrop-filter:blur(16px);border-color:var(--stone);box-shadow:0 1px 24px rgba(0,0,0,.06)}
.nav-logo{font-family:var(--hv);font-size:15px;font-weight:700;color:var(--white);text-decoration:none;letter-spacing:.12em;text-transform:uppercase;transition:color .3s}
nav.scrolled .nav-logo{color:var(--ink)}
.nav-logo span{color:var(--red)}
.nav-links{display:flex;align-items:center;gap:2.25rem}
.nav-links a{font-size:12.5px;font-weight:400;color:rgba(255,255,255,0.75);text-decoration:none;letter-spacing:.05em;transition:color .2s}
.nav-links a:hover{color:var(--white)}
nav.scrolled .nav-links a{color:var(--gray)}
nav.scrolled .nav-links a:hover{color:var(--ink)}
.nav-cta{background:var(--red);color:var(--white)!important;font-size:12.5px;font-weight:500;padding:.5rem 1.2rem;border-radius:4px;text-decoration:none;transition:background .2s,transform .18s;letter-spacing:.04em}
.nav-cta:hover{background:var(--red-dark)!important;transform:translateY(-1px)}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;z-index:101}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--white);transition:all .3s}
nav.scrolled .nav-burger span,.mobile-menu.open ~ nav .nav-burger span{background:var(--ink)}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--white);z-index:99;padding:5rem 2rem 2rem;flex-direction:column;gap:1.5rem;overflow-y:auto}
.mobile-menu a{font-size:16px;font-weight:400;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--stone);padding-bottom:1rem;letter-spacing:.03em}
.mobile-menu.open{display:flex}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden}
.hero-img{position:absolute;inset:0;background-size:cover;background-position:center 35%;z-index:0;transform:scale(1.03);transition:transform 8s ease}
.hero-img.loaded{transform:scale(1)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top, rgba(10,8,8,0.94) 0%, rgba(10,8,8,0.55) 45%, rgba(10,8,8,0.25) 100%);z-index:1}
.hero-overlay2{position:absolute;inset:0;background:linear-gradient(100deg, rgba(195,53,65,0.18) 0%, transparent 60%);z-index:1}
.hero-content{position:relative;z-index:2;padding:11rem 2.5rem 5.5rem;max-width:1100px;margin:0 auto;width:100%}
.hero-eyebrow{font-size:10px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-bottom:1.75rem;display:flex;align-items:center;gap:14px}
.hero-eyebrow::before{content:'';display:block;width:28px;height:1px;background:var(--red)}
.hero-title{font-family:var(--hv);font-size:clamp(54px,7.5vw,100px);font-weight:200;color:var(--white);line-height:.97;letter-spacing:-.03em;margin-bottom:1.75rem}
.hero-title em{font-family:var(--serif);font-style:italic;color:rgba(254,254,254,.6);font-weight:300}
.hero-title strong{font-family:var(--serif);font-weight:600;font-style:italic;color:var(--white)}
.hero-sub{font-size:15px;font-weight:400;color:rgba(254,254,254,.62);line-height:1.8;max-width:480px;margin-bottom:3rem}
.hero-sub strong{color:rgba(254,254,254,.9);font-weight:400}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:4rem}
.btn-hero-p{display:inline-flex;align-items:center;gap:10px;background:var(--red);color:var(--white);font-family:var(--hv);font-size:13px;font-weight:500;padding:.85rem 1.75rem;border-radius:4px;text-decoration:none;letter-spacing:.04em;transition:background .2s,transform .18s,box-shadow .2s;box-shadow:0 4px 20px rgba(195,53,65,.4)}
.btn-hero-p:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 8px 32px rgba(195,53,65,.5)}
.btn-hero-g{display:inline-flex;align-items:center;gap:8px;color:rgba(254,254,254,.7);font-size:13px;font-weight:400;text-decoration:none;border-bottom:1px solid rgba(254,254,254,.3);padding-bottom:2px;letter-spacing:.03em;transition:color .2s,border-color .2s}
.btn-hero-g:hover{color:var(--white);border-color:rgba(254,254,254,.7)}
.hero-stats{display:flex;gap:0;border-top:1px solid rgba(255,255,255,.12)}
.hero-stat{padding:1.5rem 2.5rem 1.5rem 0;border-right:1px solid rgba(255,255,255,.08);margin-right:2.5rem}
.hero-stat:last-child{border-right:none;margin-right:0}
.stat-val{font-family:var(--hv);font-size:26px;font-weight:600;color:var(--white);line-height:1;margin-bottom:4px;letter-spacing:-.02em}
.stat-label{font-size:10px;font-weight:400;color:rgba(254,254,254,.42);letter-spacing:.1em;text-transform:uppercase}

/* SECTION COMMONS */
.section{padding:7rem 2.5rem}
.container{max-width:1100px;margin:0 auto}
.eyebrow{font-size:10px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--red);margin-bottom:.9rem;display:flex;align-items:center;gap:10px}
.eyebrow::before{content:'';display:block;width:22px;height:1px;background:var(--red)}
.sec-title{font-family:var(--hv);font-size:clamp(34px,4.5vw,52px);font-weight:200;color:var(--ink);line-height:1.08;letter-spacing:-.025em;margin-bottom:1rem}
.sec-title em{font-family:var(--serif);font-style:italic;color:var(--red);font-weight:300;font-size:1.08em}
.sec-lead{font-size:15px;font-weight:400;color:var(--gray);line-height:1.8;max-width:520px}

/* BUTTONS */
.btn-r{display:inline-flex;align-items:center;gap:9px;background:var(--red);color:var(--white);font-family:var(--hv);font-size:13px;font-weight:500;padding:.75rem 1.6rem;border-radius:4px;text-decoration:none;letter-spacing:.04em;transition:background .2s,transform .18s,box-shadow .2s;box-shadow:0 2px 12px rgba(195,53,65,.25)}
.btn-r:hover{background:var(--red-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(195,53,65,.35)}
.btn-o{display:inline-flex;align-items:center;gap:9px;color:var(--ink);font-family:var(--hv);font-size:13px;font-weight:400;padding:.75rem 1.4rem;border-radius:4px;text-decoration:none;letter-spacing:.04em;border:1px solid var(--stone);background:var(--white);transition:all .2s}
.btn-o:hover{border-color:var(--red-border);color:var(--red)}
.btn-r svg,.btn-o svg{flex-shrink:0}

/* SOBRE */
.sobre{background:var(--cream)}
.sobre-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.sobre-visual{position:relative}
.sobre-frame{border-radius:2px;aspect-ratio:4/5;overflow:hidden;background:var(--stone);box-shadow:0 14px 50px rgba(28,31,33,.18)}
.sobre-frame img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s ease}
.sobre-frame:hover img{transform:scale(1.03)}
.sobre-badge{position:absolute;bottom:-1.5rem;right:-1.5rem;background:var(--red);color:var(--white);padding:1.5rem 1.75rem;border-radius:2px;text-align:center;box-shadow:0 8px 32px rgba(195,53,65,.35)}
.sobre-badge-num{font-family:var(--hv);font-size:38px;font-weight:700;line-height:1;display:block;letter-spacing:-.02em}
.sobre-badge-lbl{font-size:9px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;opacity:.75;margin-top:5px;display:block}
.sobre-pill{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:400;color:var(--red);border:1px solid var(--red-border);border-radius:2px;padding:5px 12px;margin-bottom:1.75rem;letter-spacing:.04em}
.sobre-text p{font-size:14.5px;font-weight:400;color:var(--gray);line-height:1.9;margin-bottom:1.25rem}
.sobre-text p strong{color:var(--ink);font-weight:500}
.ornament{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}
.ornament-line{flex:1;height:1px;background:var(--stone)}
.ornament-dot{width:5px;height:5px;border-radius:50%;background:var(--red);flex-shrink:0}

/* CURSOS */
.cursos{background:var(--white)}
.cursos-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3.5rem;gap:2rem;flex-wrap:wrap}
.cursos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--stone);border:1px solid var(--stone);border-radius:2px;overflow:hidden;margin-bottom:3rem}
.curso-card{background:var(--white);padding:1.75rem 1.6rem;transition:background .25s,transform .2s;position:relative;overflow:hidden;cursor:pointer}
.curso-card::before{content:'';position:absolute;top:0;left:0;width:2px;height:0;background:var(--red);transition:height .3s ease}
.curso-card:hover::before{height:100%}
.curso-card:hover{background:var(--cream);transform:translateY(-3px)}
.curso-card:hover .curso-icon{background:var(--red);transform:rotate(-6deg) scale(1.08)}
.curso-card:hover .curso-icon svg{stroke:var(--white)}
.curso-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;background:var(--red-soft);flex-shrink:0;transition:background .25s,transform .25s}
.curso-icon svg{width:20px;height:20px;stroke:var(--red);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;transition:stroke .25s}
.curso-num{font-size:10px;font-weight:500;color:var(--gray-light);letter-spacing:.1em;display:block;margin-bottom:.4rem}
.curso-nome{font-size:14.5px;font-weight:500;color:var(--ink);margin-bottom:.5rem;line-height:1.3;letter-spacing:-.01em}
.curso-desc-s{font-size:12.5px;font-weight:300;color:var(--gray);line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cursos-cta{text-align:center}
.cursos-cta p{font-size:13.5px;color:var(--gray);margin-bottom:1.25rem;font-weight:300}

/* GALERIA */
.galeria{background:var(--dark2);padding:9rem 2.5rem 7rem;position:relative;overflow:hidden}
.galeria::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 65% 80% at 20% 30%,rgba(195,53,65,.10),transparent 60%);pointer-events:none}
.galeria-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3.5rem;gap:2rem;flex-wrap:wrap;position:relative;z-index:1}
.galeria-head .sec-title{color:var(--white)}
.galeria-head .sec-title em{color:rgba(195,53,65,.9)}
.galeria-head .sec-lead{color:rgba(254,254,254,.5)}
.galeria-head .eyebrow{color:var(--red)}
.galeria-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:170px;gap:8px;position:relative;z-index:1}
.gal-item{position:relative;overflow:hidden;border-radius:2px;cursor:pointer;background:#0e1011}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .9s cubic-bezier(.2,.7,.2,1),filter .4s}
.gal-item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,rgba(0,0,0,.05) 50%,transparent 100%);opacity:.6;transition:opacity .3s;pointer-events:none}
.gal-item:hover::after{opacity:.9}
.gal-item:hover img{transform:scale(1.06)}
.gal-cap{position:absolute;bottom:1rem;left:1.1rem;right:1.1rem;color:var(--white);font-size:10.5px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;z-index:2;opacity:0;transform:translateY(8px);transition:opacity .35s,transform .35s}
.gal-item:hover .gal-cap{opacity:1;transform:translateY(0)}
.g1{grid-column:span 6;grid-row:span 2}
.g2{grid-column:span 3;grid-row:span 2}
.g3{grid-column:span 3;grid-row:span 2}
.g4{grid-column:span 4;grid-row:span 2}
.g5{grid-column:span 4;grid-row:span 2}
.g6{grid-column:span 4;grid-row:span 2}
.g7{grid-column:span 7;grid-row:span 2}
.g8{grid-column:span 5;grid-row:span 2}
.galeria-foot{margin-top:3rem;text-align:center;position:relative;z-index:1}
.galeria-foot p{font-size:13px;color:rgba(254,254,254,.5);margin-bottom:1.25rem;font-weight:300}

/* RETIRO */
.retiro-sec{background:var(--dark2);padding:7rem 2.5rem;position:relative;overflow:hidden;border-top:1px solid rgba(255,255,255,.04)}
.retiro-sec::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 55% 80% at 75% 50%,rgba(195,53,65,.22),transparent)}
.retiro-sec::after{content:'2027';position:absolute;right:-1.5rem;top:50%;transform:translateY(-50%);font-family:var(--hv);font-size:220px;font-weight:700;color:rgba(255,255,255,.025);line-height:1;pointer-events:none;letter-spacing:-.05em}
.retiro-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:6rem;align-items:center;position:relative;z-index:1}
.retiro-pill{display:inline-flex;align-items:center;gap:7px;font-size:9.5px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--red);background:rgba(195,53,65,.1);border:1px solid rgba(195,53,65,.22);border-radius:2px;padding:5px 12px;margin-bottom:1.5rem}
.retiro-title{font-family:var(--hv);font-size:clamp(38px,4.5vw,60px);font-weight:200;color:var(--white);line-height:1.05;letter-spacing:-.025em;margin-bottom:1.25rem}
.retiro-title em{font-family:var(--serif);font-style:italic;color:rgba(195,53,65,.85);font-size:1.05em;font-weight:300}
.retiro-body{font-size:14.5px;font-weight:400;color:rgba(254,254,254,.6);line-height:1.85;margin-bottom:2.25rem}
.retiro-cards{display:flex;flex-direction:column;gap:10px}
.retiro-card{display:flex;gap:14px;align-items:flex-start;padding:1.1rem 1.2rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:6px;transition:background .2s,border-color .2s}
.retiro-card:hover{background:rgba(255,255,255,.07);border-color:rgba(195,53,65,.2)}
.rc-icon{width:36px;height:36px;border-radius:6px;background:rgba(195,53,65,.12);border:1px solid rgba(195,53,65,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rc-icon svg{width:17px;height:17px;stroke:var(--red);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.rc-label{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(254,254,254,.35);margin-bottom:3px}
.rc-val{font-size:14px;font-weight:300;color:rgba(254,254,254,.85)}

/* LOCACAO */
.locacao{background:var(--cream)}
.locacao-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.loc-features{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:1.75rem 0}
.loc-feat{background:var(--white);border:1px solid var(--stone);border-radius:6px;padding:.9rem 1.1rem;display:flex;gap:12px;align-items:flex-start;transition:border-color .2s}
.loc-feat:hover{border-color:var(--red-border)}
.loc-feat-icon{width:34px;height:34px;border-radius:6px;background:var(--red-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.loc-feat-icon svg{width:17px;height:17px;stroke:var(--red);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.loc-feat-name{font-size:12.5px;font-weight:500;color:var(--ink);margin-bottom:2px}
.loc-feat-val{font-size:11.5px;font-weight:300;color:var(--gray)}
.loc-tipos{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:2rem}
.loc-tipo{font-size:11.5px;color:var(--gray);background:var(--white);border:1px solid var(--stone);border-radius:2px;padding:4px 12px;letter-spacing:.03em;transition:border-color .2s,color .2s;cursor:default}
.loc-tipo:hover{border-color:var(--red-border);color:var(--red)}
.loc-visual{position:relative}
.loc-stack{position:relative;height:540px}
.loc-main{width:78%;height:82%;border-radius:2px;position:absolute;bottom:0;left:0;overflow:hidden;box-shadow:0 16px 50px rgba(28,31,33,.16)}
.loc-main img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s ease}
.loc-main:hover img{transform:scale(1.04)}
.loc-accent{width:58%;height:52%;border-radius:2px;position:absolute;top:0;right:0;border:5px solid var(--cream);overflow:hidden;box-shadow:0 16px 40px rgba(28,31,33,.18);z-index:1}
.loc-accent img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s ease}
.loc-accent:hover img{transform:scale(1.05)}
.loc-badge{position:absolute;bottom:2rem;right:0;background:var(--red);color:var(--white);padding:1.25rem 1.5rem;border-radius:2px;text-align:center;z-index:2;box-shadow:0 8px 28px rgba(195,53,65,.35)}
.loc-badge-num{font-family:var(--hv);font-size:30px;font-weight:700;line-height:1;display:block;letter-spacing:-.02em}
.loc-badge-lbl{font-size:9px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;opacity:.85;margin-top:4px;display:block}

/* CTA STRIP */
.cta-strip{background:var(--red);padding:5.5rem 2.5rem;text-align:center}
.cta-title{font-family:var(--hv);font-size:clamp(34px,4.5vw,58px);font-weight:200;color:var(--white);line-height:1.08;margin-bottom:1rem;letter-spacing:-.025em}
.cta-title em{font-family:var(--serif);font-style:italic;opacity:.7;font-size:1.06em;font-weight:300}
.cta-sub{font-size:14.5px;font-weight:400;color:rgba(254,254,254,.8);margin-bottom:2.5rem;line-height:1.75}
.cta-row{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.btn-cta-p{display:inline-flex;align-items:center;gap:10px;background:var(--white);color:var(--red);font-family:var(--hv);font-size:13px;font-weight:500;padding:.85rem 1.75rem;border-radius:4px;text-decoration:none;letter-spacing:.04em;transition:all .2s}
.btn-cta-p:hover{background:var(--cream);transform:translateY(-1px)}
.btn-cta-g{display:inline-flex;align-items:center;gap:8px;color:rgba(254,254,254,.8);font-family:var(--hv);font-size:13px;font-weight:400;text-decoration:none;border:1px solid rgba(254,254,254,.35);padding:.85rem 1.6rem;border-radius:4px;letter-spacing:.04em;transition:all .2s}
.btn-cta-g:hover{color:var(--white);border-color:rgba(254,254,254,.7)}

/* CONTATO */
.contato{background:var(--dark2);padding:7rem 2.5rem}
.contato-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}
.contato-form{display:flex;flex-direction:column;gap:14px}
.fg{display:flex;flex-direction:column;gap:6px}
.flabel{font-size:11px;font-weight:500;color:rgba(254,254,254,.4);letter-spacing:.08em;text-transform:uppercase}
.finput{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:4px;padding:.8rem 1rem;color:var(--white);font-family:var(--hv);font-size:13.5px;font-weight:300;outline:none;transition:border-color .2s;width:100%}
.finput:focus{border-color:rgba(195,53,65,.45)}
.finput::placeholder{color:rgba(254,254,254,.22)}
textarea.finput{resize:vertical;min-height:110px}
.btn-submit{background:var(--red);color:var(--white);font-family:var(--hv);font-size:13px;font-weight:500;padding:.85rem 2rem;border-radius:4px;border:none;cursor:pointer;transition:background .2s,transform .18s;width:100%;margin-top:4px;letter-spacing:.04em}
.btn-submit:hover{background:var(--red-dark);transform:translateY(-1px)}
.ci-item{margin-bottom:1.75rem}
.ci-label{font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:rgba(254,254,254,.35);margin-bottom:.5rem}
.ci-val{font-size:14.5px;font-weight:400;color:rgba(254,254,254,.85);line-height:1.6}
.ci-val a{color:rgba(254,254,254,.8);text-decoration:none;transition:color .2s}
.ci-val a:hover{color:var(--white)}
.social-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:.5rem}
.soc-btn{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:400;color:rgba(254,254,254,.55);border:1px solid rgba(255,255,255,.08);border-radius:4px;padding:.5rem .9rem;text-decoration:none;transition:all .2s;letter-spacing:.03em}
.soc-btn:hover{color:var(--white);border-color:rgba(255,255,255,.3)}
.soc-btn svg{width:16px;height:16px;flex-shrink:0}
.doador-box{margin-top:2rem;padding:1.4rem;background:rgba(195,53,65,.08);border:1px solid rgba(195,53,65,.18);border-radius:6px}
.doador-lbl{font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:rgba(195,53,65,.85);margin-bottom:.5rem}
.doador-text{font-size:13px;font-weight:300;color:rgba(254,254,254,.6);margin-bottom:1rem;line-height:1.6}

/* FOOTER */
footer{background:var(--dark2);border-top:1px solid rgba(255,255,255,.05);padding:1.75rem 2.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-logo{font-family:var(--hv);font-size:13px;font-weight:700;color:rgba(254,254,254,.4);text-decoration:none;letter-spacing:.12em;text-transform:uppercase}
.footer-logo span{color:rgba(195,53,65,.7)}
.footer-copy{font-size:11px;color:rgba(254,254,254,.28);letter-spacing:.03em}

/* ANIM */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.anim{opacity:0;transform:translateY(28px);transition:opacity .85s cubic-bezier(.16,.84,.44,1),transform .85s cubic-bezier(.16,.84,.44,1)}
.anim.vis{opacity:1;transform:translateY(0)}
.anim-l{opacity:0;transform:translateX(-52px);transition:opacity .9s cubic-bezier(.16,.84,.44,1),transform .9s cubic-bezier(.16,.84,.44,1)}
.anim-r{opacity:0;transform:translateX(52px);transition:opacity .9s cubic-bezier(.16,.84,.44,1),transform .9s cubic-bezier(.16,.84,.44,1)}
.anim-scale{opacity:0;transform:scale(.91);transition:opacity .85s cubic-bezier(.16,.84,.44,1),transform .85s cubic-bezier(.16,.84,.44,1)}
.anim-l.vis,.anim-r.vis,.anim-scale.vis{opacity:1;transform:none}
.anim-d1{transition-delay:.1s}.anim-d2{transition-delay:.2s}.anim-d3{transition-delay:.3s}.anim-d4{transition-delay:.45s}.anim-d5{transition-delay:.6s}

/* SCROLL PROGRESS */
.scroll-prog{position:fixed;top:0;left:0;height:2px;background:linear-gradient(90deg,var(--red),#e8665f);z-index:200;width:0;transition:width .1s ease-out;box-shadow:0 0 8px rgba(195,53,65,.6)}

/* HERO TITLE LINE REVEAL */
.hero-title .line{display:block;overflow:hidden}
.hero-title .line>span{display:inline-block;opacity:0;transform:translateY(60%);animation:lineUp 1s cubic-bezier(.2,.7,.2,1) forwards}
.hero-title .line:nth-child(1)>span{animation-delay:.15s}
.hero-title .line:nth-child(2)>span{animation-delay:.32s}
.hero-title .line:nth-child(3)>span{animation-delay:.49s}
@keyframes lineUp{to{opacity:1;transform:translateY(0)}}
.hero-eyebrow,.hero-sub,.hero-actions,.hero-stats{opacity:0;transform:translateY(20px);animation:fadeUp .8s cubic-bezier(.2,.7,.2,1) forwards}
.hero-eyebrow{animation-delay:.1s}
.hero-sub{animation-delay:.65s}
.hero-actions{animation-delay:.78s}
.hero-stats{animation-delay:.92s}

/* MARQUEE STRIP */
.marquee-strip{padding:3rem 0;background:var(--ink);overflow:hidden;position:relative;border-top:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.04)}
.marquee-strip::before,.marquee-strip::after{content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.marquee-strip::before{left:0;background:linear-gradient(to right,var(--ink),transparent)}
.marquee-strip::after{right:0;background:linear-gradient(to left,var(--ink),transparent)}
.marquee-track{display:flex;gap:14px;width:max-content;animation:marquee 48s linear infinite}
.marquee-strip:hover .marquee-track{animation-play-state:paused}
.marquee-card{flex-shrink:0;width:280px;height:360px;border-radius:2px;overflow:hidden;position:relative;background:#0e1011}
.marquee-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .9s ease}
.marquee-card:hover img{transform:scale(1.05)}
.marquee-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.55),transparent 60%)}
.marquee-label{position:absolute;bottom:1rem;left:1.1rem;right:1.1rem;color:rgba(255,255,255,.85);font-size:10.5px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;z-index:2}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(calc(-294px * 8))}}

/* MAGNETIC BUTTON GLOW */
.btn-hero-p::after,.btn-r::after,.btn-submit::after{content:'';position:absolute;inset:0;border-radius:inherit;box-shadow:0 0 0 0 rgba(195,53,65,.4);transition:box-shadow .4s ease;pointer-events:none}
.btn-hero-p,.btn-r,.btn-submit{position:relative}
.btn-hero-p:hover::after,.btn-r:hover::after,.btn-submit:hover::after{box-shadow:0 0 0 8px rgba(195,53,65,0)}

/* SECTION RELATIVE */
.section,.galeria,.retiro-sec{position:relative}

/* NAV LOGO */
.nav-logo{color:var(--white);display:inline-flex;align-items:center;transition:color .3s ease}
nav.scrolled .nav-logo{color:var(--ink)}
.nav-logo-img{height:42px;width:auto;display:block}
.footer-logo-img{height:26px;width:auto;display:block;color:rgba(254,254,254,.55)}

/* RESPONSIVE */
@media(max-width:900px){
  nav{padding:.9rem 1.25rem}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .hero-content{padding:7rem 1.25rem 4rem}
  .hero-stats{flex-wrap:wrap;gap:0}
  .hero-stat{padding:1.25rem 1.5rem 1.25rem 0;margin-right:1.5rem}
  .section,.galeria,.retiro-sec,.contato{padding:4.5rem 1.25rem}
  .sobre-grid,.retiro-grid,.locacao-grid,.contato-grid{grid-template-columns:1fr;gap:3rem}
  .sobre-badge{bottom:-1rem;right:-.5rem}
  .cursos-grid{grid-template-columns:1fr 1fr}
  .loc-features{grid-template-columns:1fr}
  .loc-stack{height:340px}
  .retiro-sec::after{font-size:100px}
  .galeria-grid{grid-template-columns:repeat(6,1fr);grid-auto-rows:140px}
  .g1{grid-column:span 6;grid-row:span 2}
  .g2,.g3{grid-column:span 3;grid-row:span 2}
  .g4,.g5,.g6{grid-column:span 2;grid-row:span 2}
  .g7,.g8{grid-column:span 3;grid-row:span 2}
  footer{flex-direction:column;text-align:center}
}
@media(max-width:500px){
  .cursos-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .cta-row{flex-direction:column;align-items:center}
  .retiro-grid{gap:2.5rem}
  .galeria-grid{grid-template-columns:1fr;grid-auto-rows:220px}
  .g1,.g2,.g3,.g4,.g5,.g6,.g7,.g8{grid-column:span 1;grid-row:span 1}
}