/* ===== CREA-T · Rediseño 2026 (Grupo Fantome) ===== */
:root{
  --cream:#f7f1e6; --cream2:#fbf8f1; --paper:#ffffff;
  --ink:#33302b; --muted:#7c756a;
  --green:#4a7c59; --green-d:#3a6147; --green-l:#e7efe5;
  --terra:#d98452; --terra-d:#c46c3c;
  --sage:#eef2e9; --line:#e7ded0;
  --shadow:0 18px 40px -22px rgba(58,97,71,.45);
  --radius:22px; --radius-s:14px;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:"Nunito Sans",system-ui,-apple-system,Segoe UI,sans-serif;
  font-size:18px;line-height:1.7;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:"Fraunces","Georgia",serif;font-weight:600;line-height:1.12;color:var(--ink);margin:0 0 .4em}
h1{font-size:clamp(2.4rem,5.5vw,4.2rem);letter-spacing:-.01em}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:1.45rem}
p{margin:0 0 1rem}
a{color:var(--green-d);text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:"Nunito Sans";text-transform:uppercase;letter-spacing:.18em;font-size:.8rem;font-weight:800;color:var(--terra-d);margin-bottom:.6rem}
.lead{font-size:1.2rem;color:#544e45;max-width:62ch}
.center{text-align:center}.center .lead{margin-inline:auto}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:800;font-size:1rem;
  padding:.85em 1.5em;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:.2s}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-d);transform:translateY(-2px)}
.btn-terra{background:var(--terra);color:#fff}
.btn-terra:hover{background:var(--terra-d);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-ghost:hover{background:rgba(255,255,255,.16)}
.btn-outline{background:transparent;color:var(--green-d);border-color:var(--green)}
.btn-outline:hover{background:var(--green);color:#fff}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(247,241,230,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:inline-flex;font-family:"Marcellus",serif;font-weight:400;font-size:1.7rem;
  text-transform:uppercase;letter-spacing:.42em;color:#3c3c3b;padding-left:.42em}
.brand:hover{color:var(--green-d)}
.menu{display:flex;align-items:center;gap:1.6rem;list-style:none;margin:0;padding:0}
.menu a{color:var(--ink);font-weight:700;font-size:1rem;padding:.3em 0;position:relative}
.menu a:hover{color:var(--green-d)}
.menu a.active{color:var(--green-d)}
.menu a.active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:3px;background:var(--terra);border-radius:3px}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.burger{display:none;background:none;border:0;font-size:1.7rem;cursor:pointer;color:var(--green-d)}

/* hero */
.hero{position:relative;min-height:78vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,55,42,.15) 0%,rgba(33,48,36,.78) 100%);z-index:1}
.hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero .wrap{position:relative;z-index:2;padding-bottom:64px;padding-top:80px}
.hero h1{color:#fff;max-width:16ch;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero p{color:rgba(255,255,255,.92);font-size:1.25rem;max-width:52ch}
.hero .btns{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.5rem}
.hero--sm{min-height:52vh}
.hero--sm h1{font-size:clamp(2.2rem,4.5vw,3.4rem)}

/* sections */
section{padding:84px 0}
.sec-sage{background:var(--sage)}
.sec-green{background:var(--green-d);color:#fff}
.sec-green h2,.sec-green h3{color:#fff}
.sec-green .lead{color:rgba(255,255,255,.85)}
.sec-cream{background:var(--cream2)}

/* two worlds */
.worlds{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.world{position:relative;border-radius:var(--radius);overflow:hidden;min-height:420px;display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow)}
.world img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.5s}
.world:hover img{transform:scale(1.05)}
.world::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(33,48,36,.85));z-index:1}
.world-body{position:relative;z-index:2;padding:32px}
.world-body h3{color:#fff;font-size:1.9rem}
.world-body p{color:rgba(255,255,255,.9);margin-bottom:1rem}

/* cards grid */
.grid{display:grid;gap:26px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--paper);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.25s;border:1px solid var(--line)}
.card:hover{transform:translateY(-6px)}
.card-img{aspect-ratio:4/3;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.card:hover .card-img img{transform:scale(1.06)}
.card-body{padding:24px;display:flex;flex-direction:column;flex:1}
.card-body h3{font-size:1.3rem;margin-bottom:.3rem}
.tag{display:inline-block;background:var(--green-l);color:var(--green-d);font-weight:800;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;padding:.3em .8em;border-radius:999px;margin-bottom:.7rem;align-self:flex-start}
.meta{list-style:none;padding:0;margin:.4rem 0 1rem;font-size:.95rem;color:#5b554c}
.meta li{padding:.18em 0;border-bottom:1px dashed var(--line)}
.meta li b{color:var(--ink)}
.card .btn{margin-top:auto;align-self:flex-start}

/* feature row */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.feature img{border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover;width:100%}
.feature.rev .txt{order:2}

/* quote */
.quote{max-width:50ch;margin:0 auto;text-align:center}
.quote p{font-family:"Fraunces",serif;font-size:clamp(1.4rem,2.5vw,2rem);font-style:italic;line-height:1.4}
.quote cite{display:block;margin-top:1rem;font-family:"Nunito Sans";font-style:normal;font-weight:800;letter-spacing:.05em;color:var(--terra-d)}
.sec-green .quote cite{color:#f0c9a8}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gallery a{border-radius:14px;overflow:hidden;aspect-ratio:1}
.gallery img{width:100%;height:100%;object-fit:cover;transition:.4s}
.gallery a:hover img{transform:scale(1.08)}

/* team */
.team-photo{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;background:#fff;padding:10px}
.people{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.person{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-s);padding:20px}
.person h4{margin:0 0 .2rem;font-size:1.15rem}
.person span{color:var(--terra-d);font-weight:800;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}
.person p{font-size:.95rem;color:#5b554c;margin:.5rem 0 0}

/* table */
.table-wrap{overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow)}
table.rates{width:100%;border-collapse:collapse;background:#fff;min-width:620px}
table.rates th,table.rates td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line)}
table.rates thead th{background:var(--green);color:#fff;font-weight:800;font-size:.95rem}
table.rates td.num{text-align:center;font-variant-numeric:tabular-nums}
table.rates tr:hover td{background:var(--green-l)}
table.rates .grp td{background:var(--sage);font-weight:800;color:var(--green-d)}
table.rates tfoot td{font-weight:800;background:#f3ead9}

/* inscription banner */
.insc{background:linear-gradient(120deg,var(--terra),var(--terra-d));color:#fff;border-radius:var(--radius);padding:48px;text-align:center;box-shadow:var(--shadow)}
.insc h2{color:#fff}
.insc p{color:rgba(255,255,255,.95);max-width:60ch;margin-inline:auto}
.notice{background:#fff8ed;border:2px dashed var(--terra);border-radius:var(--radius-s);padding:18px 22px;color:#8a4a1f;font-size:.95rem;margin-top:18px}
.embed-ph{background:var(--sage);border:2px dashed var(--green);border-radius:var(--radius);min-height:420px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--green-d);padding:40px}
.embed-ph .ico{font-size:3rem;margin-bottom:.4rem}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.cinfo{list-style:none;padding:0;margin:0}
.cinfo li{display:flex;gap:16px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line)}
.cinfo .ic{flex:0 0 46px;height:46px;border-radius:12px;background:var(--green-l);display:grid;place-items:center;font-size:1.4rem}
.cinfo b{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.cinfo a,.cinfo span{font-size:1.1rem;color:var(--ink);font-weight:700}
.form input,.form textarea{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:12px;font:inherit;font-size:1rem;margin-bottom:14px;background:#fff;color:var(--ink)}
.form input:focus,.form textarea:focus{outline:2px solid var(--green)}
.form .row{display:flex;gap:14px}.form .row input{flex:1}
.map{border:0;width:100%;height:320px;border-radius:var(--radius);box-shadow:var(--shadow);margin-top:20px}

/* footer */
.footer{background:#2c352c;color:#cdd6cb;padding:64px 0 28px;font-size:.95rem}
.footer h4{color:#fff;font-family:"Nunito Sans";font-size:.85rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1rem}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.footer a{color:#cdd6cb}.footer a:hover{color:#fff}
.footer ul{list-style:none;padding:0;margin:0}.footer li{padding:.25em 0}
.fbrand{font-family:"Marcellus",serif;font-size:1.7rem;color:#fff;margin-bottom:.6rem}
.fbottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#9aa697;font-size:.85rem}

/* whatsapp float */
.wa{position:fixed;right:22px;bottom:22px;z-index:60;width:60px;height:60px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 10px 26px -8px rgba(0,0,0,.5);transition:.2s}
.wa:hover{transform:scale(1.08)}
.wa svg{width:32px;height:32px;fill:#fff}

/* responsive */
@media(max-width:900px){
  .menu{position:fixed;inset:74px 0 auto 0;flex-direction:column;background:var(--cream2);
    padding:20px 24px;gap:.4rem;border-bottom:1px solid var(--line);display:none;box-shadow:var(--shadow)}
  .menu.open{display:flex}
  .menu a{padding:.7em 0;width:100%;border-bottom:1px solid var(--line)}
  .burger{display:block}
  .nav-cta .btn{display:none}
  .worlds,.feature,.contact-grid,.grid-3,.grid-2{grid-template-columns:1fr}
  .feature.rev .txt{order:0}
  .people{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){.people{grid-template-columns:1fr}.form .row{flex-direction:column;gap:0}}
