/* assets/styles.css */
@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800&family=Playfair+Display:wght@500;600;700&display=swap");

:root{
  --bg:#0c0c0e;
  --panel:#121216;
  --panel-2:#0f1114;
  --text:#f4f3ef;
  --muted:#b8b8b8;
  --line:rgba(244,243,239,.08);
  --accent:#8e8e8e;
  --accent-2:#b0b0b0;
  --shadow: 0 14px 32px rgba(0,0,0,.35);
  --radius: 16px;
  --transition: 240ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

*{box-sizing:border-box}
[hidden]{display:none !important}
html,body{margin:0;padding:0}
html{scroll-padding-top:96px}
body{
  font-family:"Manrope", ui-sans-serif, system-ui, -apple-system, Segoe UI, Arial;
  background:
    radial-gradient(900px 520px at 10% -10%, rgba(160,160,160,.16), transparent 60%),
    radial-gradient(800px 520px at 90% 0%, rgba(176,176,176,.1), transparent 60%),
    var(--bg);
  color:var(--text);
  line-height:1.6;
  position:relative;
  min-height:100vh;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.018), rgba(255,255,255,.018) 1px, transparent 1px, transparent 2px);
  opacity:.45;
  mix-blend-mode:soft-light;
  z-index:0;
}
main, header, footer{position:relative; z-index:1}

a{color:inherit;text-decoration:none}
code{background:rgba(255,255,255,.06); padding:.15rem .35rem; border-radius:.4rem; font-size:.9em}

.container{width:min(1120px, 92vw); margin:0 auto}
.section{padding:72px 0; gap:24px}
.section--alt{background:linear-gradient(180deg, transparent, rgba(255,255,255,.02), transparent)}
.section__head{display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:28px; flex-wrap:wrap}
.section__head h1,.section__head h2{margin:0; letter-spacing:-.02em; font-size:clamp(28px, 3.5vw, 42px)}
.section__head p{margin:0; color:var(--muted); max-width:64ch; font-size:.95rem}
.section__head--center{
  flex-direction:column;
  align-items:center;
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}

h1,h2,h3,.brand__text strong,.price{
  font-family:"Playfair Display", ui-serif, Georgia, "Times New Roman", serif;
  font-weight:600;
}

.header{
  position:sticky; top:0; z-index:50;
  background:rgba(12,12,14,.72);
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--line);
  transition: var(--transition);
}
.header__inner{display:flex; align-items:center; justify-content:space-between; padding:16px 0; gap:16px}

.brand{display:flex; gap:12px; align-items:center; transition: var(--transition)}
.brand:hover{opacity:0.9; transform:translateY(-1px)}
.brand__mark{
  width:38px; height:38px; border-radius:12px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(160,160,160,.95), rgba(176,176,176,.75));
  color:#111; font-weight:800;
  transition: var(--transition);
}
.brand__mark:hover{transform:scale(1.03)}
.brand__text strong{display:block; font-size:1rem}
.brand__text small{display:block; color:var(--muted); margin-top:2px; font-size:.75rem}

.nav__toggle{
  display:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:var(--text);
  border-radius:12px;
  padding:10px 12px;
  cursor:pointer;
  transition: var(--transition);
}
.nav__toggle:hover{background:rgba(255,255,255,.08); border-color:rgba(160,160,160,.3)}
.nav__menu{display:flex; align-items:center; gap:20px}
.nav__menu a{color:var(--muted); transition: var(--transition); font-weight:600; position:relative}
.nav__menu a:after{content:""; position:absolute; bottom:-4px; left:0; width:0; height:1px; background:var(--accent); transition:var(--transition)}
.nav__menu a:hover{color:var(--text)}
.nav__menu a:hover:after{width:100%}
.nav__menu a.active{color:var(--text)}
.nav__menu .btn{margin-left:8px}

.hero{
  padding:72px 0 24px;
  background:
    linear-gradient(135deg, rgba(12,12,14,.85), rgba(12,12,14,.65)),
    url('./IMG_6522.JPEG') center center / cover no-repeat;
  background-attachment:scroll;
  position:relative;
}
.hero__grid{display:grid; grid-template-columns: 1.3fr .9fr; gap:32px; align-items:start}
.pill{
  display:inline-flex; gap:8px; align-items:center;
  padding:10px 14px; border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  color:var(--accent-2);
  margin:0 0 18px;
  font-size:.85rem;
  font-weight:700;
  letter-spacing:.02em;
  text-transform:uppercase;
}
.hero h1{margin:0 0 16px; font-size: clamp(32px, 4.2vw, 54px); letter-spacing:-.03em; line-height:1.1}
.lead{color:var(--muted); font-size:1.05rem; margin:16px 0 24px; max-width:60ch; line-height:1.6}
.hero__actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:stretch;
}
.hero__actions .btn{
  flex:1 1 180px;
  min-height:52px;
  padding-inline:20px;
  white-space:nowrap;
}
.trust{display:flex; gap:14px; margin-top:24px; flex-wrap:wrap}
.trust__item{
  padding:12px 14px; border:0;
  border-radius:14px; background:rgba(255,255,255,.02);
  transition: var(--transition);
  min-width:min(100%, 360px);
}
.trust__item strong{display:block; font-size:.95rem}
.trust__item span{display:block; color:var(--muted); font-size:.85rem; margin-top:4px}

.grid{display:grid; gap:20px}
.cards{grid-template-columns: repeat(4, 1fr)}
.pricing{grid-template-columns: repeat(3, 1fr)}
.book{
  grid-template-columns: 1fr;
  justify-items:center;
}
.contact{grid-template-columns: repeat(3, 1fr)}

.card{
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:20px;
  box-shadow: 0 6px 18px rgba(0,0,0,.22);
  transition: var(--transition);
}
.card:hover{
  border-color:rgba(160,160,160,.35);
  transform:translateY(-4px);
  box-shadow: 0 10px 24px rgba(0,0,0,.32);
}
.card--bg{
  position:relative;
  overflow:hidden;
  background-size:cover;
  background-position:center;
  min-height:360px;
  padding:0;
  display:flex;
  align-items:stretch;
}
.card__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(8,9,12,.85), rgba(12,13,17,.88));
  z-index:1;
  border-radius:inherit;
}
.card__content{
  position:relative;
  z-index:2;
  padding:24px;
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;
}
.card__content .btn--full{
  margin-top:auto;
}
.card--bg:hover{
  transform:none;
}
.card--bg:hover .card__overlay{
  background:linear-gradient(135deg, rgba(8,9,12,.75), rgba(12,13,17,.78));
}
.card h2,.card h3{margin:0 0 12px; font-size:1.15rem}
.card p{margin:12px 0 0}
.card--featured{
  border-color: rgba(160,160,160,.5);
  background:rgba(160,160,160,.06);
}
.card--bg.card--featured{
  background:transparent;
  border-color:rgba(160,160,160,.42);
  box-shadow:
    0 0 0 1px rgba(160,160,160,.18) inset,
    0 8px 22px rgba(0,0,0,.28);
}
.card--bg.card--featured .card__overlay{
  background:linear-gradient(135deg, rgba(8,9,12,.8), rgba(12,13,17,.84));
}
.card--bg.card--featured:hover{
  border-color:rgba(160,160,160,.58);
  box-shadow:
    0 0 0 1px rgba(160,160,160,.28) inset,
    0 10px 26px rgba(0,0,0,.32);
}
.card--bg.card--featured:hover .card__overlay{
  background:linear-gradient(135deg, rgba(8,9,12,.72), rgba(12,13,17,.76));
}

.quote-widget{
  position:relative;
  overflow:hidden;
  border-color:rgba(160,160,160,.34);
  background:
    radial-gradient(120% 90% at 90% -10%, rgba(160,160,160,.2), transparent 56%),
    linear-gradient(165deg, rgba(8,9,12,.65), rgba(12,13,17,.68));
}
.quote-widget:hover{
  transform:none;
  border-color:rgba(160,160,160,.52);
  box-shadow:0 10px 26px rgba(0,0,0,.36);
}
.quote-widget__eyebrow{
  margin:0 0 10px;
  color:var(--accent-2);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.quote-widget h2{margin:0 0 8px}
.btn--quote{
  border-color: rgba(160,160,160,.7);
  background:linear-gradient(135deg, rgba(160,160,160,.95), rgba(176,176,176,.75));
  color:#111;
  box-shadow:0 10px 28px rgba(160,160,160,.2);
}
.btn--quote:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 28px rgba(160,160,160,.24);
}
.btn--quote-outline{
  border-color:rgba(160,160,160,.5);
  background:rgba(0,0,0,.24);
  color:var(--accent-2);
}
.btn--quote-outline:hover{
  border-color:rgba(160,160,160,.75);
  background:rgba(160,160,160,.14);
  color:#fff;
  transform:translateY(-2px);
}
.quote-form{
  display:grid;
  gap:12px;
}
.quote-progress{
  display:flex;
  align-items:center;
  gap:10px;
}
.quote-step{
  width:30px;
  height:30px;
  border-radius:999px;
  display:grid;
  place-items:center;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--muted);
  font-size:.85rem;
  font-weight:700;
}
.quote-step.is-active{
  background:var(--accent);
  border-color:var(--accent);
  color:#111;
}
.quote-step.is-done{
  background:var(--accent);
  border-color:var(--accent);
  color:transparent;
  position:relative;
}
.quote-step.is-done::after{
  content:"\2713";
  position:absolute;
  color:#111;
  font-size:.82rem;
}
.quote-line{
  flex:1 1 auto;
  height:3px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
}
.quote-line.is-done{background:var(--accent)}
.quote-step-label{
  margin:0;
  color:var(--muted);
  font-size:.84rem;
}
.quote-pane{
  border:0;
  margin:0;
  padding:0;
  min-inline-size:0;
  display:grid;
  gap:10px;
}
.quote-pane legend{
  margin:0 0 4px;
  padding:0;
  font-weight:700;
  font-size:1.03rem;
}
.quote-field{
  display:grid;
  gap:6px;
}
.quote-field label{
  color:#f0ede5;
  font-size:.9rem;
  font-weight:600;
}
.quote-input,
.quote-select,
.quote-textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  background:rgba(255,255,255,.06);
  color:var(--text);
  padding:11px 12px;
  font:inherit;
}
.quote-select option{
  color:#111;
  background:#fff;
}
.quote-input::placeholder,
.quote-textarea::placeholder{
  color:rgba(255,255,255,.52);
}
.quote-input:focus,
.quote-select:focus,
.quote-textarea:focus{
  outline:none;
  border-color:rgba(160,160,160,.72);
  box-shadow:0 0 0 3px rgba(160,160,160,.2);
}
.quote-textarea{
  resize:vertical;
  min-height:110px;
}
.quote-actions{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
  margin-top:4px;
}
.quote-actions .quote-back[hidden] ~ .quote-next,
.quote-actions .quote-back[hidden] ~ .quote-submit{
  grid-column:1 / -1;
}
.quote-status{
  margin:2px 0 0;
  min-height:1.3em;
}
.quote-status.is-success{
  color:#9fe0bc;
}
.quote-status.is-error{
  color:#ff9f9f;
}

.featured__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  flex-wrap:nowrap;
  margin-bottom:8px;
}
.featured__head h3{margin:0}
.badge{
  position:static;
  padding:6px 9px; border-radius:999px;
  background:rgba(160,160,160,.15);
  border:1px solid rgba(160,160,160,.35);
  color:var(--accent-2); font-size:.72rem; font-weight:700;
  text-transform:uppercase;
  letter-spacing:.05em;
  white-space:nowrap;
  flex:0 0 auto;
}

.info{list-style:none; padding:0; margin:14px 0 0; display:grid; gap:14px}
.info li{display:flex; align-items:baseline; justify-content:space-between; gap:12px; font-size:.95rem}
.info span{color:var(--muted); font-weight:600}
.muted{color:var(--muted)}
.tiny{font-size:.85rem}

.bullets{margin:12px 0 0; padding-left:20px; color:var(--muted); line-height:1.8}
.bullets li{margin:8px 0}

.price{font-size:2.1rem; margin:10px 0 0; letter-spacing:-.02em}
.price span{outline:1px dashed rgba(255,255,255,.2); padding:0 .3rem; border-radius:.3rem; cursor:pointer; transition:var(--transition)}
.price span:hover{outline-color:rgba(160,160,160,.5); background:rgba(160,160,160,.08)}

.row{display:flex; gap:12px; margin-top:14px; flex-wrap:wrap}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 16px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
  color:var(--text);
  font-weight:700;
  font-size:.95rem;
  cursor:pointer;
  transition: var(--transition);
}
.btn--full{width:100%}
.btn--primary{
  border-color: rgba(160,160,160,.7);
  background:linear-gradient(135deg, rgba(160,160,160,.95), rgba(176,176,176,.75));
  color:#111;
}
.btn--primary:hover{transform:translateY(-2px); box-shadow: 0 8px 20px rgba(160,160,160,.22)}
.btn--book-gray{
  border-color:rgba(176,176,176,.8);
  background:linear-gradient(135deg, #8e8e8e, #b0b0b0);
  color:#111;
}
.btn--book-gray:hover{
  box-shadow:0 8px 20px rgba(160,160,160,.28);
}
.btn--ghost{background:transparent}
.btn--ghost:hover{background:rgba(255,255,255,.06); transform:translateY(-2px)}

.btn--social{
  padding:16px 24px;
  font-size:1.05rem;
  border-color:rgba(160,160,160,.5);
  background:linear-gradient(135deg, rgba(160,160,160,.12), rgba(176,176,176,.08));
  gap:12px;
  border-width:1.5px;
}
.btn--social:hover{
  border-color:rgba(160,160,160,.8);
  background:linear-gradient(135deg, rgba(160,160,160,.18), rgba(176,176,176,.12));
  transform:translateY(-3px);
  box-shadow: 0 10px 24px rgba(160,160,160,.15);
}
.btn--social svg{width:28px; height:28px; transition: var(--transition)}
.btn--social:hover svg{transform:scale(1.08)}

.callout{
  margin-top:24px;
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; padding:20px;
  border-radius:var(--radius);
  border:1px solid rgba(160,160,160,.22);
  background:rgba(160,160,160,.05);
  transition: var(--transition);
}
.callout h3{margin:0 0 4px; font-size:1.1rem}

.embed{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--line);
  background:rgba(0,0,0,.15);
  min-height:420px;
  transition: var(--transition);
}
.book__panel{
  width:min(100%, 920px);
  margin-inline:auto;
}
.book__panel h3,
.book__panel > p{
  text-align:center;
}
.book__actions{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0;
  margin:16px 0;
  flex-wrap:wrap;
}
.book__actions .btn{
  width:min(320px, 100%);
  min-width:220px;
}
.book__actions .tiny{
  margin:0;
  text-align:center;
}
.embed iframe{
  width:100%;
  height:420px;
  border:0;
  background:transparent;
}
.embed__fallback{
  position:absolute; inset:0;
  display:grid; place-items:center;
  padding:20px;
  text-align:center;
  background:rgba(12,12,14,.94);
}
.embed__fallback a{
  color:var(--accent-2);
  text-decoration:underline;
  font-weight:700;
}
.map{
  margin-top:12px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid var(--line);
  background:rgba(0,0,0,.18);
}
.map iframe{
  width:100%;
  height:240px;
  border:0;
  display:block;
}
.ig-preview{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:10px;
}
.ig-preview a{
  border-radius:12px;
  overflow:hidden;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
  display:block;
  transition:var(--transition);
}
.ig-preview a:hover{
  transform:translateY(-2px);
  border-color:rgba(160,160,160,.45);
}
.ig-preview img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  display:block;
  transition:var(--transition);
}
.ig-preview a:hover img{
  transform:scale(1.04);
  filter:brightness(1.03);
}

.accordion details{cursor:pointer}
.accordion summary{font-weight:700; padding:12px 0; user-select:none}
.accordion summary:hover{color:var(--accent-2)}
.accordion p{margin-top:12px; color:var(--muted)}

.footer{
  border-top:1px solid var(--line);
  padding:28px 0;
  background:rgba(0,0,0,.2);
}
.footer__inner{display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap}
.footer__links{display:flex; gap:18px; color:var(--muted)}
.footer__links a{transition:var(--transition)}
.footer__links a:hover{color:var(--text)}

.filters{display:flex; gap:12px; flex-wrap:wrap; margin:12px 0 20px}
.chip{
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--muted);
  font-weight:700;
  cursor:pointer;
  transition:var(--transition);
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.chip:hover{border-color:rgba(160,160,160,.3); background:rgba(160,160,160,.08)}
.chip.is-active{color:var(--text); border-color:rgba(160,160,160,.5); background:rgba(160,160,160,.12)}

.masonry{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:16px;
}
.shot{
  margin:0;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
  transition:var(--transition);
  cursor:pointer;
}
.shot:hover{
  transform:translateY(-3px);
  border-color:rgba(160,160,160,.3);
}
.shot img{
  width:100%;
  height:260px;
  object-fit:cover;
  display:block;
  transition:var(--transition);
}
.shot:hover img{filter:brightness(1.05)}
.shot figcaption{
  padding:12px 14px;
  color:var(--muted);
  font-weight:600;
  font-size:.85rem;
}

.lightbox{
  position:fixed; inset:0; z-index:999;
  display:grid; place-items:center;
  background:rgba(0,0,0,.88);
  padding:20px;
  animation: fadeIn 0.2s ease-out;
}
.lightbox[hidden]{
  display:none !important;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.lightbox img{
  width:min(1100px, 92vw);
  height:auto;
  max-height:78vh;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.15);
  animation: slideUp 0.3s ease-out;
}
@keyframes slideUp{from{transform:translateY(20px); opacity:0}to{transform:translateY(0); opacity:1}}
.lightbox__cap{color:var(--muted); margin:16px 0 0; text-align:center; font-size:.95rem}
.lightbox__close{
  position:fixed; top:20px; right:20px;
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.06);
  color:var(--text);
  font-size:20px;
  line-height:1;
  cursor:pointer;
  transition:var(--transition);
  display:grid; place-items:center;
}
.lightbox__close:hover{background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.3)}

.reveal{
  opacity:0;
  transform:translateY(14px);
  transition: opacity 560ms ease, transform 560ms ease;
  transition-delay: var(--delay, 0ms);
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}

@media (prefers-reduced-motion: reduce){
  *{
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .reveal{opacity:1; transform:none}
}

@media (max-width: 980px){
  .hero{
    background:
      linear-gradient(150deg, rgba(12,12,14,.88), rgba(12,12,14,.7)),
      url('./IMG_6522.JPEG') 62% center / cover no-repeat;
    background-attachment:scroll;
  }
  .cards{grid-template-columns: repeat(2, 1fr)}
  .hero__grid{grid-template-columns: 1fr}
  .contact{grid-template-columns: 1fr}
  .masonry{grid-template-columns: repeat(2, 1fr)}
  .callout{flex-direction:column; text-align:center}
  .nav__toggle{display:inline-flex}
  .nav__menu{
    position:absolute;
    right:4vw;
    top:64px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    min-width: 220px;
    padding:14px;
    border-radius:16px;
    border:1px solid var(--line);
    background:rgba(12,12,14,.94);
    box-shadow: 0 12px 40px rgba(0,0,0,.4);
    animation:slideDown 0.2s ease-out;
  }
  @keyframes slideDown{from{opacity:0; transform:translateY(-10px)}to{opacity:1; transform:translateY(0)}}
  .nav__menu.is-open{display:flex}
  .nav__menu a{padding:12px 12px; border-radius:12px}
  .nav__menu a:hover{background:rgba(160,160,160,.1)}
  .section__head{flex-direction:column; align-items:flex-start}
  .section__head--center{align-items:center}
  .book__panel{width:100%}
}

@media (max-width: 560px){
  .hero{
    background:
      linear-gradient(165deg, rgba(12,12,14,.9), rgba(12,12,14,.74)),
      url('./IMG_6522.JPEG') 68% center / cover no-repeat;
    background-attachment:scroll;
  }
  .section{padding:56px 0}
  .cards{grid-template-columns: 1fr}
  .pricing{grid-template-columns: 1fr}
  .masonry{grid-template-columns: 1fr}
  .nav__menu{left:4vw; right:4vw; min-width:0}
  .shot img{height:220px}
  .hero__actions{flex-direction:column}
  .hero__actions .btn{
    flex:0 0 auto;
    width:100%;
  }
  .trust__item{width:100%}
  .featured__head{align-items:center}
  .brand__text strong{font-size:.92rem}
  .brand__text small{font-size:.68rem}
  .embed{min-height:520px}
  .embed iframe{height:520px}
  .book__actions .btn{width:100%}
  .ig-preview{grid-template-columns:repeat(2, 1fr)}
  .btn--full:not(:only-child){width:auto}
  .contact{grid-template-columns:1fr}
  .quote-actions{grid-template-columns:1fr}
}
