
:root{
  --bg:#f7f2ec;
  --panel:#fffaf5;
  --panel-2:#f1e7dc;
  --ink:#231b17;
  --muted:#67564b;
  --line:#dfd1c0;
  --brand:#8a664c;
  --brand-strong:#6b4d39;
  --brand-soft:#d9c0a8;
  --shadow:0 20px 40px rgba(35,27,23,.08);
  --radius:24px;
  --radius-sm:18px;
  --container:min(1120px, calc(100% - 2rem));
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.7), transparent 30%),
    linear-gradient(180deg, #faf6f1 0%, var(--bg) 100%);
  line-height:1.6;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
p{margin:0 0 1rem}
ul{margin:0;padding-left:1.2rem}
h1,h2,h3,h4{
  margin:0 0 1rem;
  line-height:1.1;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight:600;
  letter-spacing:.01em;
}
h1{font-size:clamp(2.8rem, 6vw, 5rem)}
h2{font-size:clamp(2rem, 4vw, 3.2rem)}
h3{font-size:1.6rem}
h4{font-size:1.15rem; font-family: Inter, system-ui, sans-serif; font-weight:700}
small,.eyebrow{font-size:.82rem;letter-spacing:.18em;text-transform:uppercase}
.muted{color:var(--muted)}
.container{width:var(--container); margin-inline:auto}
.section{padding:4.75rem 0}
.section-tight{padding:3.2rem 0}
.panel{
  background:rgba(255,250,245,.82);
  border:1px solid rgba(223,209,192,.9);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.kicker{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding:.55rem .9rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.12);
  color:#fff7ee;
  backdrop-filter: blur(8px);
  margin-bottom:1rem;
  font-weight:600;
}
.kicker.kicker-light{
  background:rgba(138,102,76,.08);
  color:var(--brand-strong);
  border-color:rgba(138,102,76,.15);
}
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(250,245,239,.88);
  backdrop-filter: blur(18px);
  border-bottom:1px solid rgba(223,209,192,.65);
}
.nav-wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  min-height:78px;
}
.brand{
  display:flex;
  align-items:center;
  gap:.85rem;
  min-width:0;
}
.brand img{
  width:52px;
  height:52px;
  border-radius:16px;
  border:1px solid rgba(138,102,76,.18);
  background:#fff;
}
.brand-mark-text{min-width:0}
.brand-mark-text strong{
  display:block;
  font-size:1rem;
  font-weight:800;
  line-height:1.1;
}
.brand-mark-text span{
  display:block;
  color:var(--muted);
  font-size:.86rem;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.nav-links{
  display:flex;
  align-items:center;
  gap:1.15rem;
  list-style:none;
  padding:0;
  margin:0;
}
.nav-links a{
  color:var(--muted);
  font-weight:600;
}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-cta{
  display:flex;
  align-items:center;
  gap:.7rem;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  min-height:48px;
  padding:.88rem 1.15rem;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:700;
  transition:.22s ease;
  cursor:pointer;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  background:linear-gradient(135deg, var(--brand), var(--brand-strong));
  color:#fff8ef;
  box-shadow:0 14px 24px rgba(107,77,57,.2);
}
.btn-secondary{
  border-color:rgba(138,102,76,.18);
  background:#fffaf5;
}
.btn-ghost{
  background:transparent;
  border-color:rgba(255,255,255,.26);
  color:#fffaf5;
}
.menu-toggle{
  display:none;
  width:46px;
  height:46px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fffaf5;
}
.hero{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(110deg, rgba(35,27,23,.88), rgba(75,56,46,.52)),
    url("../img/hero-pattern.svg") center/cover no-repeat;
  color:#fffaf5;
}
.hero::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:180px;
  background:linear-gradient(180deg, transparent, rgba(247,242,236,1));
}
.hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:2rem;
  min-height:clamp(640px, 82vh, 780px);
  align-items:center;
  padding:4.6rem 0 6.2rem;
}
.hero-copy p{
  color:rgba(255,245,235,.9);
  font-size:1.07rem;
  max-width:62ch;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
  margin-top:1.4rem;
}
.hero-highlights{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:.9rem;
  margin-top:2rem;
}
.hero-highlights div{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:20px;
  padding:1rem;
  backdrop-filter: blur(10px);
}
.hero-highlights strong{
  display:block;
  font-size:1.2rem;
  margin-bottom:.15rem;
}
.hero-card{
  padding:1.35rem;
  background:rgba(255,250,245,.1);
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(14px);
  border-radius:28px;
  box-shadow:var(--shadow);
}
.hero-card .mini-card{
  background:rgba(255,250,245,.92);
  color:var(--ink);
  border:1px solid rgba(255,255,255,.35);
  border-radius:22px;
  padding:1.2rem;
}
.hero-card-grid{
  display:grid;
  gap:1rem;
}
.hero-card img{
  border-radius:22px;
  border:1px solid rgba(255,255,255,.18);
}
.stat-row{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:1rem;
}
.stat-card{padding:1.35rem}
.stat-card strong{
  display:block;
  font-size:1.6rem;
  font-family:"Cormorant Garamond", Georgia, serif;
  margin-bottom:.25rem;
}
.grid-3,.grid-2,.grid-4{
  display:grid;
  gap:1.15rem;
}
.grid-2{grid-template-columns:repeat(2, minmax(0, 1fr))}
.grid-3{grid-template-columns:repeat(3, minmax(0, 1fr))}
.grid-4{grid-template-columns:repeat(4, minmax(0, 1fr))}
.card{padding:1.25rem}
.service-card img,.gallery-card img,.academy-visual img{
  border-radius:22px;
  margin-bottom:1rem;
  border:1px solid var(--line);
}
.service-card p,.review-card p,.info-card p{color:var(--muted)}
.service-meta{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  margin-top:1rem;
  padding-top:.95rem;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:.95rem;
}
.badge-row{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
}
.badge{
  padding:.5rem .8rem;
  border-radius:999px;
  background:rgba(138,102,76,.08);
  color:var(--brand-strong);
  border:1px solid rgba(138,102,76,.15);
  font-size:.92rem;
  font-weight:600;
}
.dual-panel{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:1.2rem;
}
.info-list{
  display:grid;
  gap:.85rem;
}
.info-list div{
  display:flex;
  gap:.9rem;
  align-items:flex-start;
  padding:1rem;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.45);
}
.info-list span{
  width:38px;
  height:38px;
  flex:none;
  border-radius:12px;
  display:grid;
  place-items:center;
  background:rgba(138,102,76,.1);
  color:var(--brand-strong);
  font-weight:800;
}
.review-card{
  position:relative;
  padding-top:1.6rem;
}
.review-card::before{
  content:"“";
  position:absolute;
  top:.35rem;
  left:1rem;
  font-size:3rem;
  color:rgba(138,102,76,.25);
  font-family: Georgia, serif;
}
.review-author{margin-top:1rem;font-weight:700}
.cta-band{
  overflow:hidden;
  position:relative;
  color:#fffaf5;
  background:linear-gradient(135deg, #5b4333, #2c221e);
}
.cta-band::before{
  content:"";
  position:absolute;
  inset:0;
  background:url("../img/hero-pattern.svg") center/cover;
  opacity:.18;
}
.cta-band .inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:1rem;
  align-items:center;
  padding:2.2rem;
}
.cta-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}
.page-hero{
  padding:4.3rem 0 2.6rem;
}
.page-hero .panel{padding:2rem}
.page-hero-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:1.2rem;
  align-items:center;
}
.page-hero img{border-radius:24px;border:1px solid var(--line)}
.check-list{
  display:grid;
  gap:.7rem;
  list-style:none;
  padding:0;
}
.check-list li{
  position:relative;
  padding-left:1.8rem;
  color:var(--muted);
}
.check-list li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:var(--brand-strong);
  font-weight:800;
}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(12, minmax(0,1fr));
  gap:1rem;
}
.gallery-card{
  grid-column:span 4;
  padding:1rem;
}
.gallery-card.large{grid-column:span 8}
.gallery-card.tall img{aspect-ratio:3/4;object-fit:cover}
.gallery-card img{width:100%;aspect-ratio:4/3;object-fit:cover}
.contact-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:1.2rem;
}
.contact-links{
  display:grid;
  gap:.9rem;
}
.contact-link{
  display:flex;
  align-items:flex-start;
  gap:.9rem;
  padding:1rem;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.5);
}
.contact-link strong{display:block}
.footer{
  padding:2rem 0 3rem;
  color:var(--muted);
}
.footer-grid{
  display:grid;
  grid-template-columns:1fr auto;
  gap:1rem;
  align-items:center;
  padding-top:2rem;
  border-top:1px solid var(--line);
}
.footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
}
.floating-whatsapp{
  position:fixed;
  right:1rem;
  bottom:1rem;
  z-index:45;
}
.floating-whatsapp a{
  width:58px;
  height:58px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, #7d5c45, #5c4131);
  color:#fffaf5;
  box-shadow:0 18px 30px rgba(53,38,30,.26);
  font-size:1.5rem;
}
.note{
  padding:.9rem 1rem;
  border-radius:18px;
  border:1px dashed rgba(138,102,76,.25);
  background:rgba(138,102,76,.05);
  color:var(--muted);
}
.table-like{
  display:grid;
  gap:.75rem;
}
.table-row{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:1rem;
  padding:1rem;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.55);
}
.section-heading{
  display:flex;
  flex-wrap:wrap;
  align-items:end;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:1.4rem;
}
.section-heading p{max-width:62ch}
.editor-layout{
  display:grid;
  grid-template-columns:310px 1fr;
  gap:1.2rem;
}
.editor-sidebar{
  padding:1.2rem;
  position:sticky;
  top:96px;
  align-self:start;
}
.editor-main{
  padding:1.2rem;
}
.editor-main textarea{
  width:100%;
  min-height:520px;
  resize:vertical;
  padding:1rem;
  border-radius:20px;
  border:1px solid var(--line);
  font: 500 .95rem/1.5 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  background:#fffdf9;
  color:#2b211c;
}
.editor-output{
  margin-top:1rem;
  padding:1rem;
  border-radius:18px;
  background:rgba(138,102,76,.05);
  border:1px solid rgba(138,102,76,.14);
}
.hidden{display:none !important}

@media (max-width: 980px){
  .nav-links,.nav-cta{display:none}
  .menu-toggle{display:grid;place-items:center}
  .site-header.open .nav-panel{
    display:block;
  }
  .nav-panel{
    display:none;
    padding-bottom:1rem;
  }
  .nav-panel .nav-links,.nav-panel .nav-cta{
    display:flex;
    flex-direction:column;
    align-items:stretch;
  }
  .nav-panel .nav-links{
    gap:.4rem;
    padding:.25rem 0 .6rem;
  }
  .nav-panel .nav-links a{
    padding:.7rem .2rem;
  }
  .hero-grid,.page-hero-grid,.dual-panel,.cta-band .inner,.contact-grid,.editor-layout{
    grid-template-columns:1fr;
  }
  .hero-highlights,.stat-row,.grid-4{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .grid-3{grid-template-columns:1fr 1fr}
  .gallery-card,.gallery-card.large{grid-column:span 6}
}

@media (max-width: 700px){
  .section{padding:4rem 0}
  .grid-2,.grid-3,.stat-row,.hero-highlights,.gallery-card,.gallery-card.large{
    grid-template-columns:1fr;
    grid-column:span 12;
  }
  .table-row{
    grid-template-columns:1fr;
  }
  .footer-grid{
    grid-template-columns:1fr;
  }
  .brand-mark-text span{white-space:normal}
}
