:root{
  --bg: #090b0f;
  --bg-soft: #0d1016;
  --bg-card: rgba(16, 20, 27, 0.82);
  --bg-card-strong: rgba(18, 23, 31, 0.95);

  --text: #eef2f7;
  --muted: #a7b0bf;
  --muted-2: #8b94a3;

  --line: rgba(255,255,255,.08);
  --line-strong: rgba(255,255,255,.12);

  --gold: #d3aa57;
  --gold-2: #f3cf7a;
  --gold-soft: rgba(211,170,87,.16);

  --green-1: #25d366;
  --green-2: #78f2ab;

  --danger-bg: rgba(255,107,107,.12);
  --danger-line: rgba(255,107,107,.24);
  --danger-text: #ffd4d4;

  --success-bg: rgba(90, 200, 120, .12);
  --success-line: rgba(90, 200, 120, .24);
  --success-text: #c5f5d3;

  --shadow-lg: 0 24px 70px rgba(0,0,0,.48);
  --shadow-md: 0 18px 46px rgba(0,0,0,.34);
  --shadow-sm: 0 10px 24px rgba(0,0,0,.22);

  --radius-xl: 24px;
  --radius-lg: 18px;
  --radius-md: 14px;
  --radius-sm: 12px;

  --ring: 0 0 0 3px rgba(211,170,87,.18);

  --max: 1160px;
}

*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:"Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  overflow-x:hidden;
  background:
    radial-gradient(900px 420px at 14% 8%, rgba(211,170,87,.10), transparent 58%),
    radial-gradient(760px 380px at 85% 18%, rgba(90,140,255,.10), transparent 60%),
    linear-gradient(180deg, #07090d 0%, #0b0e14 45%, #0c1016 100%);
}

.container{
  width:min(var(--max), calc(100% - 40px));
  margin-inline:auto;
}

.bg-glow{
  position:fixed;
  width:520px;
  height:520px;
  filter:blur(90px);
  opacity:.22;
  pointer-events:none;
  z-index:-1;
}

.bg-glow--1{
  left:-180px;
  top:120px;
  background:radial-gradient(circle, rgba(211,170,87,.85), transparent 60%);
}

.bg-glow--2{
  right:-220px;
  top:260px;
  background:radial-gradient(circle, rgba(74,126,255,.72), transparent 60%);
}

/* HEADER */
.header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(10,12,17,.68);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.06);
}

.header__inner{
  min-height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

.header__actions{
  display:flex;
  align-items:center;
  gap:10px;
}

.brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--text);
  text-decoration:none;
}

.brand__mark{
  width:14px;
  height:14px;
  border-radius:999px;
  background: radial-gradient(circle at 30% 30%, var(--gold-2), var(--gold));
  box-shadow: 0 0 0 6px rgba(211,170,87,.14);
}

.brand__name{
  font-size:.95rem;
  font-weight:700;
  letter-spacing:.18em;
}

.brand--footer .brand__name{
  font-size:.92rem;
}

.nav{
  position:relative;
  display:flex;
  align-items:center;
}

.nav__toggle{
  display:none;
  width:44px;
  height:44px;
  border:none;
  border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  cursor:pointer;
}

.nav__bar{
  display:block;
  width:18px;
  height:2px;
  margin:4px auto;
  border-radius:999px;
  background:rgba(255,255,255,.86);
}

.nav__list{
  display:flex;
  align-items:center;
  gap:10px;
  list-style:none;
  margin:0;
  padding:0;
}

.nav__link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:0 12px;
  border-radius:12px;
  color:var(--muted);
  text-decoration:none;
  font-size:.93rem;
  transition:.2s ease;
}

.nav__link:hover{
  color:var(--text);
  background:rgba(255,255,255,.04);
}

/* BUTTONS */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:0 18px;
  border-radius:14px;
  border:1px solid transparent;
  text-decoration:none;
  font-weight:600;
  font-size:.94rem;
  cursor:pointer;
  transition:transform .12s ease, filter .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn:active{
  transform:translateY(0);
}

.btn--block{
  width:100%;
}

.btn--primary{
  color:#17120a;
  background:linear-gradient(135deg, var(--gold), var(--gold-2));
  box-shadow:0 16px 36px rgba(211,170,87,.22);
}

.btn--primary:hover{
  filter:brightness(1.03);
}

.btn--ghost{
  color:var(--text);
  background:rgba(255,255,255,.03);
  border-color:var(--line);
}

.btn--ghost:hover{
  background:rgba(255,255,255,.055);
}

.btn--whatsapp{
  color:#07110b;
  background:linear-gradient(135deg, var(--green-1), var(--green-2));
  border-color:rgba(255,255,255,.10);
  box-shadow:0 16px 36px rgba(37,211,102,.18);
}

.btn--whatsapp:hover{
  filter:brightness(1.02);
}

.btn__icon{
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:rgba(0,0,0,.16);
  font-size:.82rem;
  font-weight:800;
}

/* HERO */
.hero{
  position:relative;
  padding:52px 0 42px;
  overflow:hidden;
}

.hero__media{
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 500px at 50% -8%, rgba(211,170,87,.18), transparent 60%),
    radial-gradient(800px 400px at 12% 22%, rgba(86,125,255,.10), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.34));
}

.hero__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(8,10,14,.96) 0%, rgba(8,10,14,.76) 58%, rgba(8,10,14,.92) 100%);
}

.hero__texture{
  position:absolute;
  inset:-30px;
  background-image:
    radial-gradient(circle at 10% 20%, rgba(255,255,255,.05) 0 1px, transparent 1px),
    radial-gradient(circle at 60% 70%, rgba(255,255,255,.03) 0 1px, transparent 1px);
  background-size: 26px 26px, 36px 36px;
  opacity:.24;
}

.hero__inner{
  position:relative;
  display:grid;
  grid-template-columns: 1.35fr .85fr;
  gap:28px;
  align-items:start;
}

.chip{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:var(--muted);
  font-size:.84rem;
  margin:0 0 16px 0;
}

.hero__title{
  margin:0 0 14px;
  font-family:"Playfair Display", Georgia, serif;
  font-size:clamp(2.6rem, 5vw, 4.3rem);
  line-height:1.02;
  letter-spacing:-.02em;
  max-width:10ch;
}

.hero__subtitle{
  margin:0 0 22px;
  max-width:58ch;
  color:var(--muted);
  font-size:1rem;
  line-height:1.75;
}

.hero__actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:22px;
}

.hero__stats{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

.stat{
  min-width:170px;
  padding:14px 15px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  box-shadow:var(--shadow-sm);
}

.stat__num{
  display:block;
  font-size:1.15rem;
  font-weight:700;
  color:var(--text);
}

.stat__label{
  display:block;
  margin-top:3px;
  color:var(--muted);
  font-size:.84rem;
}

.hero__card{
  padding:22px;
  border-radius:var(--radius-xl);
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(19,24,32,.85), rgba(14,18,25,.76));
  box-shadow:var(--shadow-lg);
}

.hero-card__title{
  margin:0;
  font-size:1.12rem;
  font-weight:600;
}

.hero-card__desc{
  margin:8px 0 16px;
  color:var(--muted);
  font-size:.93rem;
  line-height:1.7;
}

.hero-card__meta{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid rgba(255,255,255,.08);
  display:grid;
  gap:12px;
}

.meta{
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size:.9rem;
  color:var(--muted);
}

.meta__k{
  color:rgba(255,255,255,.88);
}

/* SECTIONS */
.section{
  padding:62px 0;
}

.section--alt{
  background:rgba(255,255,255,.018);
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
}

.section__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  margin-bottom:26px;
}

.section__title{
  margin:0;
  font-family:"Playfair Display", Georgia, serif;
  font-size:clamp(1.8rem, 3vw, 2.5rem);
  line-height:1.1;
}

.section__subtitle{
  margin:0;
  max-width:62ch;
  color:var(--muted);
  font-size:.96rem;
  line-height:1.7;
}

/* GRID */
.grid{
  display:grid;
  gap:16px;
}

.grid--3{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}

/* CARD */
.card{
  position:relative;
  overflow:hidden;
  padding:20px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(17,22,29,.82), rgba(13,17,23,.74));
  box-shadow:var(--shadow-md);
}

.card::before{
  content:"";
  position:absolute;
  inset:-1px;
  pointer-events:none;
  opacity:.5;
  background:
    radial-gradient(420px 180px at 12% 12%, rgba(211,170,87,.12), transparent 60%),
    radial-gradient(420px 180px at 88% 24%, rgba(87,133,255,.08), transparent 60%);
}

.card > *{
  position:relative;
}

.card__icon{
  width:44px;
  height:44px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  font-size:18px;
}

.card__title{
  margin:0 0 8px;
  font-size:1.08rem;
  font-weight:600;
}

.card__text{
  margin:0;
  color:var(--muted);
  font-size:.93rem;
  line-height:1.7;
}

.card__foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top:16px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.07);
}

.price{
  font-weight:700;
  color:rgba(255,255,255,.96);
}

.tag{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 10px;
  border-radius:999px;
  font-size:.8rem;
  color:var(--gold-2);
  border:1px solid rgba(211,170,87,.24);
  background:rgba(211,170,87,.09);
}

/* BARBEIROS */
.avatar{
  width:56px;
  height:56px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:12px;
  background:linear-gradient(135deg, var(--gold), var(--gold-2));
  color:#17120a;
  font-weight:700;
  box-shadow:0 14px 34px rgba(211,170,87,.18);
}

.stars{
  margin-top:14px;
  color:var(--gold-2);
  letter-spacing:.18em;
  font-size:.95rem;
}

/* BOOKING */
.booking{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:16px;
  align-items:start;
}

.form{
  padding:22px;
}

.form__row{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-bottom:12px;
}

.field label{
  display:block;
  margin-bottom:7px;
  font-size:.88rem;
  color:rgba(255,255,255,.92);
}

.field input,
.field select{
  width:100%;
  min-height:50px;
  padding:0 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.025);
  color:var(--text);
  outline:none;
  font:inherit;
}

.field input::placeholder{
  color:rgba(167,176,191,.68);
}

.field input:focus,
.field select:focus{
  border-color:rgba(211,170,87,.34);
  box-shadow:var(--ring);
}

.form__actions{
  margin-top:12px;
}

/* SIDE */
.side__title{
  margin:0 0 10px;
  font-size:1.05rem;
  font-weight:600;
}

.side__text{
  margin:0 0 8px;
  color:var(--muted);
  line-height:1.7;
}

.list{
  margin:0;
  padding-left:18px;
  color:var(--muted);
  line-height:1.9;
}

.pill{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:0 12px;
  margin-right:8px;
  margin-top:8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:rgba(255,255,255,.9);
  text-decoration:none;
  font-size:.88rem;
}

.pill:hover{
  background:rgba(255,255,255,.05);
}

/* ALERTS PHP */
.success-message,
.error-message{
  margin-bottom:18px;
  padding:15px 16px;
  border-radius:16px;
  border:1px solid var(--line);
  font-size:.93rem;
  line-height:1.6;
}

.success-message{
  background:var(--success-bg);
  border-color:var(--success-line);
  color:var(--success-text);
}

.error-message{
  background:var(--danger-bg);
  border-color:var(--danger-line);
  color:var(--danger-text);
}

/* FOOTER */
.footer{
  border-top:1px solid rgba(255,255,255,.06);
  background:rgba(0,0,0,.14);
}

.footer__inner{
  padding:28px 0;
  display:flex;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}

.footer__cols{
  display:flex;
  gap:28px;
  flex-wrap:wrap;
}

.footer__title{
  margin:0 0 8px;
  font-size:.95rem;
  font-weight:600;
}

.footer__text{
  margin:0 0 6px;
  color:var(--muted);
  font-size:.9rem;
  line-height:1.7;
}

.footer__bottom{
  border-top:1px solid rgba(255,255,255,.06);
  padding:15px 0;
}

.footer__bottomInner{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  color:rgba(167,176,191,.76);
  font-size:.9rem;
}

.to-top{
  color:rgba(255,255,255,.88);
  text-decoration:none;
}

.to-top:hover{
  text-decoration:underline;
}

/* ANIMATION */
.reveal{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .6s ease, transform .6s ease;
}

.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}

/* RESPONSIVE */
@media (max-width: 980px){
  .hero__inner{
    grid-template-columns:1fr;
  }

  .booking{
    grid-template-columns:1fr;
  }

  .grid--3{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .section__head{
    flex-direction:column;
    align-items:flex-start;
  }
}

@media (max-width: 720px){
  .header__cta{
    display:none;
  }

  .nav__toggle{
    display:inline-flex;
  }

  .nav__list{
    position:absolute;
    top:58px;
    right:0;
    width:min(320px, calc(100vw - 40px));
    display:none;
    flex-direction:column;
    padding:10px;
    border-radius:18px;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(10,12,17,.96);
    box-shadow:var(--shadow-lg);
  }

  .nav__list.is-open{
    display:flex;
  }

  .grid--3{
    grid-template-columns:1fr;
  }

  .form__row{
    grid-template-columns:1fr;
  }

  .header__actions{
    gap:8px;
  }

  .btn--whatsapp{
    padding:0 12px;
  }

  .btn--whatsapp .btn__icon{
    display:none;
  }

  .hero{
    padding-top:38px;
  }

  .hero__title{
    max-width:none;
  }
}