:root{
  --bg:#08090b; --bg-2:#0d0f12; --bg-3:#111317; --surface:#15181d; --line:#23272e;
  --text:#f4f1ea; --muted:#9a9388; --accent:#e0a64d; --accent-2:#caa873;
  --accent-soft:rgba(224,166,77,.14); --radius:14px; --maxw:1240px;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--bg); color:var(--text); font-family:'Sora',system-ui,sans-serif; font-weight:300; line-height:1.6; overflow-x:hidden; -webkit-font-smoothing:antialiased;}
h1,h2,h3,h4{font-family:'Cinzel',serif; line-height:1.1; letter-spacing:.01em;}
a{color:inherit; text-decoration:none;}
img{display:block; max-width:100%;}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px;}
.serif{font-family:'Cinzel',serif;}
.accent{color:var(--accent);}
.grain{position:fixed; inset:0; pointer-events:none; z-index:2; opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ===== HEADER (shared across all pages) ===== */
header{position:fixed; top:0; left:0; right:0; z-index:50; backdrop-filter:blur(14px); background:rgba(8,9,11,.55); border-bottom:1px solid transparent; transition:background .3s, border-color .3s;
  padding-top:env(safe-area-inset-top, 0);}
header.scrolled{border-bottom:1px solid var(--line); background:rgba(8,9,11,.92);}
.nav{display:flex; align-items:center; justify-content:space-between; height:76px; gap:24px;}
.brand{display:flex; align-items:center; gap:12px;}
.brand img{height:38px; width:auto;}
.nav-links{display:flex; gap:28px; align-items:center;}
.nav-links a{font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); transition:color .2s;}
.nav-links a:hover, .nav-links a.active{color:var(--text);}
.nav-cta{border:1px solid var(--accent); color:var(--accent); padding:11px 22px; border-radius:100px; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; transition:all .25s;}
.nav-cta:hover{background:var(--accent); color:#1a1206;}
.burger{display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:0; padding:8px;}
.burger span{width:24px; height:2px; background:var(--text); transition:.3s;}

/* ===== STICKY MOBILE CTA ===== */
.sticky-book{display:none; position:fixed; bottom:18px; left:18px; right:18px; z-index:60;
  background:var(--accent); color:#1a1206; text-align:center; padding:16px;
  border-radius:100px; font-family:'Sora'; font-weight:600; font-size:.88rem; letter-spacing:.18em; text-transform:uppercase;
  box-shadow:0 10px 36px rgba(0,0,0,.5), 0 0 0 1px rgba(224,166,77,.4);
  transform:translateY(140%); opacity:0; transition:transform .35s ease, opacity .35s ease;}
.sticky-book.show{transform:translateY(0); opacity:1;}
.sticky-book:active{transform:translateY(0) scale(.97);}

/* ===== BUTTONS ===== */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:18px 36px; border-radius:100px; font-weight:600; font-size:.88rem; letter-spacing:.14em; text-transform:uppercase;
  cursor:pointer; transition:transform .25s, box-shadow .25s, background .25s, color .25s, border-color .25s;
  border:0; font-family:'Sora'; min-height:54px;}
.btn-primary{background:var(--accent); color:#1a1206;}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 12px 40px rgba(224,166,77,.4);}
.btn-ghost{background:rgba(255,255,255,.04); color:var(--text); border:1px solid rgba(255,255,255,.18);}
.btn-ghost:hover{border-color:var(--accent); color:var(--accent);}
.btn-xl{padding:22px 56px; font-size:1rem; letter-spacing:.18em; min-height:64px;}
.btn-sm{padding:14px 26px; font-size:.78rem; min-height:46px;}

/* ===== HERO (home) ===== */
.hero{position:relative; min-height:100vh; display:flex; align-items:center; justify-content:center; overflow:hidden; text-align:center;}
.hero video{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; filter:brightness(.42) saturate(.95);}
.hero .veil{position:absolute; inset:0; z-index:1;
  background:radial-gradient(120% 80% at 50% 40%, transparent 0%, rgba(8,9,11,.55) 55%, rgba(8,9,11,.95) 100%);}
.hero .inner{position:relative; z-index:3; padding:120px 24px 80px; max-width:780px;}
.hero-logo{margin-bottom:12px; opacity:0; animation:fadeUp 1s ease .2s forwards;}
.hero-logo img{height:clamp(140px,28vw,220px); width:auto; margin:0 auto; filter:drop-shadow(0 8px 30px rgba(0,0,0,.5));}
.hero-title{font-size:clamp(2.4rem,9vw,6.4rem); font-weight:800; text-transform:uppercase; letter-spacing:.04em; line-height:1.05;
  background:linear-gradient(180deg,#fff 0%,#e6dcc6 50%,#b8975a 100%); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  text-shadow:0 8px 30px rgba(0,0,0,.4);}
.hero .moto{font-family:'Cinzel',serif; font-size:clamp(1rem,2.4vw,1.35rem); color:var(--accent-2); letter-spacing:.06em; margin-top:8px;
  opacity:0; animation:fadeUp 1.1s ease .55s forwards;}
.hero .keywords{margin-top:18px; font-size:.78rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); opacity:0; animation:fadeUp 1.1s ease .8s forwards;}
.hero .keywords span{color:var(--accent-2);}
.hero .cta-stack{margin-top:44px; opacity:0; animation:fadeUp 1.1s ease 1.05s forwards;}
.hero .cta-main{display:inline-block;}
.hero .cta-row{display:flex; gap:14px; flex-wrap:wrap; justify-content:center; margin-top:18px;}
@keyframes fadeUp{from{opacity:0; transform:translateY(20px);} to{opacity:1; transform:none;}}

/* ===== PAGE HERO (lighter, for sub-pages) ===== */
.page-hero{position:relative; padding:160px 0 80px; text-align:center; overflow:hidden;
  background:linear-gradient(180deg, var(--bg-2) 0%, var(--bg) 100%);}
.page-hero::before{content:''; position:absolute; inset:0; background:radial-gradient(60% 50% at 50% 0%, rgba(224,166,77,.10), transparent 70%);}
.page-hero .tag{font-size:.74rem; letter-spacing:.34em; text-transform:uppercase; color:var(--accent); position:relative;}
.page-hero h1{font-size:clamp(2.2rem,6vw,4rem); font-weight:700; text-transform:uppercase; margin-top:18px; position:relative;}
.page-hero p{color:var(--muted); max-width:60ch; margin:20px auto 0; position:relative; font-size:1.05rem;}

/* ===== SECTIONS ===== */
.pad{padding:110px 0;}
.alt{background:var(--bg-2);}
.head{margin-bottom:54px; max-width:680px;}
.head.center{margin-left:auto; margin-right:auto; text-align:center;}
.head .tag{font-size:.74rem; letter-spacing:.26em; text-transform:uppercase; color:var(--accent);}
.head h2{font-size:clamp(1.9rem,5vw,3.1rem); font-weight:700; text-transform:uppercase; margin-top:14px;}
.head p{color:var(--muted); margin-top:16px;}

/* ===== STORY ===== */
.story{display:grid; grid-template-columns:1.1fr .9fr; gap:60px; align-items:center;}
.story p{color:var(--muted); margin-bottom:18px;}
.story .media{border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); aspect-ratio:4/5; background:#0a0c0f;}
.story .media video, .story .media img{width:100%; height:100%; object-fit:cover;}

/* ===== SERVICES ===== */
.svc-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.svc{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:36px 30px; position:relative; overflow:hidden; transition:border-color .3s, transform .3s;}
.svc::after{content:''; position:absolute; top:0; left:0; height:3px; width:0; background:var(--accent); transition:width .35s;}
.svc:hover{transform:translateY(-4px); border-color:#3a3a32;}
.svc:hover::after{width:100%;}
.svc .ico{font-size:1.5rem; margin-bottom:18px; color:var(--accent);}
.svc h3{font-size:1.05rem; font-weight:600; text-transform:uppercase; letter-spacing:.04em; margin-bottom:12px;}
.svc p{color:var(--muted); font-size:.92rem; margin-bottom:18px;}
.svc .price{font-family:'Cinzel',serif; color:var(--accent); font-size:1.1rem; font-weight:600;}
.svc .price small{color:var(--muted); font-family:'Sora'; font-weight:300; font-size:.66rem; letter-spacing:.1em;}

/* ===== PACKAGES (detailed bundles) ===== */
.pkg-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.pkg{background:linear-gradient(180deg, var(--surface), #101317); border:1px solid var(--line); border-radius:var(--radius); padding:38px 32px; position:relative;}
.pkg.featured{border-color:var(--accent); box-shadow:0 0 0 1px var(--accent) inset, 0 30px 60px -30px rgba(224,166,77,.35);}
.pkg.featured::before{content:'Most Popular'; position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--accent); color:#1a1206; padding:6px 14px; border-radius:100px; font-size:.65rem; letter-spacing:.18em; text-transform:uppercase; font-weight:700;}
.pkg .pname{font-family:'Cinzel',serif; font-weight:700; font-size:1.2rem; text-transform:uppercase; letter-spacing:.04em;}
.pkg .pprice{margin:18px 0; font-family:'Cinzel',serif; color:var(--accent); font-size:2rem; font-weight:700;}
.pkg .pprice small{font-family:'Sora'; font-weight:300; font-size:.7rem; letter-spacing:.14em; color:var(--muted); display:block; margin-top:2px;}
.pkg ul{list-style:none; margin:22px 0 26px;}
.pkg ul li{padding:10px 0; border-bottom:1px solid var(--line); font-size:.9rem; color:var(--text); position:relative; padding-left:24px;}
.pkg ul li::before{content:'✓'; position:absolute; left:0; color:var(--accent); font-weight:700;}
.pkg ul li:last-child{border-bottom:0;}

/* ===== PROCESS ===== */
.proc{display:grid; grid-template-columns:repeat(5,1fr); gap:16px;}
.step{padding:28px 22px; border:1px solid var(--line); border-radius:var(--radius); background:var(--surface);}
.step .n{font-family:'Cinzel',serif; font-weight:800; font-size:2.2rem; color:#33312a; line-height:1;}
.step h3{font-size:.92rem; font-weight:600; text-transform:uppercase; margin:12px 0 8px;}
.step p{font-size:.83rem; color:var(--muted);}

/* ===== GALLERY ===== */
.gal{display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:220px; gap:14px;}
.gal .cell{border-radius:12px; overflow:hidden; position:relative; border:1px solid var(--line); background:#101216;}
.gal .cell img, .gal .cell video{width:100%; height:100%; object-fit:cover; transition:transform .6s;}
.gal .cell:hover img, .gal .cell:hover video{transform:scale(1.04);}
.gal .tall{grid-row:span 2;}
.gal .wide{grid-column:span 2;}
.gal .cap{position:absolute; left:0; right:0; bottom:0; padding:14px; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; background:linear-gradient(transparent,rgba(0,0,0,.85)); opacity:0; transition:opacity .3s;}
.gal .cell:hover .cap{opacity:1;}

/* ===== REVIEWS (prominent) ===== */
.rev-feature{background:linear-gradient(180deg, var(--bg-3), var(--bg)); padding:80px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); text-align:center;}
.rev-feature .stars{color:var(--accent); font-size:1.4rem; letter-spacing:6px;}
.rev-feature blockquote{font-family:'Cinzel',serif; font-size:clamp(1.4rem,3.5vw,2.2rem); font-weight:500; max-width:60ch; margin:24px auto 22px; line-height:1.35;}
.rev-feature .author{color:var(--muted); font-size:.85rem; letter-spacing:.16em; text-transform:uppercase;}
.rev-feature .author b{color:var(--text);}

.rev-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.rev{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:32px 28px;}
.rev .stars{color:var(--accent); letter-spacing:3px; margin-bottom:16px;}
.rev p{font-size:.96rem; color:var(--text);}
.rev .who{margin-top:22px; display:flex; align-items:center; gap:12px;}
.rev .av{width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,var(--accent),#8a6a2c); display:flex; align-items:center; justify-content:center; font-family:'Cinzel'; font-weight:700; color:#1a1206;}
.rev .who .nm{font-weight:600; font-size:.9rem;}
.rev .who .car{font-size:.76rem; color:var(--muted);}

/* ===== TRUST SIGNALS ===== */
.trust{display:grid; grid-template-columns:repeat(4,1fr); gap:20px;}
.trust .card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:28px 22px; text-align:center; transition:border-color .3s, transform .3s;}
.trust .card:hover{border-color:#3a3a32; transform:translateY(-3px);}
.trust .card .ic{display:inline-flex; width:54px; height:54px; align-items:center; justify-content:center; background:var(--accent-soft); border:1px solid rgba(224,166,77,.3); border-radius:50%; color:var(--accent); font-size:1.5rem; margin-bottom:14px;}
.trust .card h3{font-size:.95rem; font-weight:600; text-transform:uppercase; letter-spacing:.06em; margin-bottom:8px;}
.trust .card p{font-size:.85rem; color:var(--muted);}
@media (max-width:980px){ .trust{grid-template-columns:repeat(2,1fr);} }
@media (max-width:480px){ .trust{grid-template-columns:1fr;} }

/* ===== STATS BAND ===== */
.stats-band{display:flex; gap:48px; padding:48px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); justify-content:center; flex-wrap:wrap; background:var(--bg-2);}
.stat{text-align:center;}
.stat .num{font-family:'Cinzel',serif; font-weight:700; font-size:2.4rem; color:var(--accent);}
.stat .lbl{font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-top:4px;}

/* ===== CONTACT / FORMS ===== */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:48px;}
.info-item{display:flex; gap:16px; align-items:flex-start; padding:22px 0; border-bottom:1px solid var(--line);}
.info-item .k{font-size:1.2rem; color:var(--accent); min-width:24px;}
.info-item .lbl{font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted);}
.info-item .val{font-size:1.02rem; margin-top:2px;}
.info-item .val a:hover{color:var(--accent);}

form.card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:36px;}
.field{margin-bottom:20px;}
.field label{display:block; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:8px;}
.field label .req{color:var(--accent);}
.field input, .field select, .field textarea{
  width:100%; background:var(--bg); border:1px solid var(--line); border-radius:10px;
  padding:15px 16px; color:var(--text); font-family:inherit; font-size:.96rem; transition:border-color .2s, background .2s;}
.field input:focus, .field select:focus, .field textarea:focus{outline:none; border-color:var(--accent); background:#0b0d10;}
.field textarea{resize:vertical; min-height:120px;}
.field-row{display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px;}
.field-row.cols-2{grid-template-columns:1fr 1fr;}
.upload-area{border:2px dashed var(--line); border-radius:12px; padding:28px; text-align:center; cursor:pointer; transition:border-color .25s, background .25s;}
.upload-area:hover{border-color:var(--accent); background:rgba(224,166,77,.04);}
.upload-area p{color:var(--muted); font-size:.88rem;}
.upload-area .ic{font-size:1.6rem; color:var(--accent); margin-bottom:8px;}
.upload-list{margin-top:14px; display:flex; flex-direction:column; gap:6px;}
.upload-status{font-size:.85rem; color:var(--muted); text-align:center; padding:10px 0;}
.upload-total{font-size:.78rem; color:var(--muted); text-align:center; padding:10px 0 4px; letter-spacing:.04em;}
.photo-row{display:flex; align-items:center; gap:12px; padding:10px 14px; background:var(--bg); border:1px solid var(--line); border-radius:10px; font-size:.86rem;}
.photo-row .check{width:22px; height:22px; flex-shrink:0; border-radius:50%; background:var(--accent); color:#1a1206; display:flex; align-items:center; justify-content:center; font-size:.78rem; font-weight:700;}
.photo-row .name{flex:1; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0;}
.photo-row .size{color:var(--muted); font-size:.78rem; flex-shrink:0;}
.photo-row.skipped .check{background:transparent; border:1px solid var(--muted); color:var(--muted);}
.photo-row.skipped .name, .photo-row.skipped .size{color:var(--muted);}

/* ===== SUCCESS STATE ===== */
.success-card{background:var(--surface); border:1px solid var(--accent); border-radius:var(--radius); padding:60px 40px; text-align:center; max-width:600px; margin:0 auto; box-shadow:0 30px 60px -30px rgba(224,166,77,.4);}
.success-card .check{width:72px; height:72px; border-radius:50%; background:var(--accent); display:flex; align-items:center; justify-content:center; margin:0 auto 24px; font-size:2rem; color:#1a1206; font-weight:700;}
.success-card h2{font-size:1.8rem; margin-bottom:14px;}
.success-card p{color:var(--muted); max-width:50ch; margin:0 auto 28px;}

/* ===== FOOTER ===== */
footer{background:#050608; border-top:1px solid var(--line); padding:60px 0 110px; position:relative;}
@media (min-width:641px){ footer{padding-bottom:40px;} }
.foot{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:24px;}
.foot .brand img{height:34px;}
.socials{display:flex; gap:12px;}
.socials a{width:42px; height:42px; border:1px solid var(--line); border-radius:50%; display:flex; align-items:center; justify-content:center; transition:all .25s; font-size:.78rem; font-weight:600;}
.socials a:hover{border-color:var(--accent); color:var(--accent); transform:translateY(-2px);}
.copyright{color:var(--muted); font-size:.8rem; margin-top:32px; text-align:center;}

/* ===== REVEAL ANIMATIONS (subtle) ===== */
.reveal{opacity:0; transform:translateY(14px); transition:opacity .6s ease, transform .6s ease;}
.reveal.in{opacity:1; transform:none;}

/* Tighten spacing on booknow page so the form appears immediately on mobile */
.booking-page .page-hero{padding-bottom:40px;}
.booking-page #bookSection{padding-top:30px;}
@media (max-width:640px){
  .booking-page .page-hero{padding:110px 0 24px;}
  .booking-page #bookSection{padding-top:16px;}
  .booking-page #bookSection form.card{padding:22px 18px;}
  .booking-page .page-hero p{font-size:.95rem;}
}

/* ===== RESPONSIVE ===== */
@media (max-width:980px){
  .story{grid-template-columns:1fr; gap:40px;}
  .story .media{aspect-ratio:16/10; max-height:420px;}
  .svc-grid, .rev-grid, .pkg-grid{grid-template-columns:repeat(2,1fr);}
  .proc{grid-template-columns:repeat(2,1fr);}
  .contact-grid{grid-template-columns:1fr;}
  .field-row{grid-template-columns:1fr;}
  .field-row.cols-2{grid-template-columns:1fr;}
}
@media (max-width:640px){
  .wrap{padding:0 18px;}
  .pad{padding:80px 0;}
  .page-hero{padding:130px 0 60px;}
  .nav{height:64px;}
  .brand img{height:30px;}
  .nav-links{position:fixed; inset:64px 0 auto 0; background:var(--bg-2); flex-direction:column; padding:24px; gap:18px; border-bottom:1px solid var(--line); transform:translateY(-130%); transition:transform .3s; align-items:flex-start;}
  .nav-links.open{transform:none;}
  .nav-links a{font-size:.92rem;}
  .burger{display:flex;}
  .nav .nav-cta{display:none;}
  .svc-grid, .rev-grid, .proc, .pkg-grid{grid-template-columns:1fr;}
  .pkg{padding:32px 24px;}
  .gal{grid-template-columns:repeat(2,1fr); grid-auto-rows:160px;}
  .gal .wide{grid-column:span 2;}
  .stats-band{gap:28px; padding:36px 0;}
  .stat .num{font-size:1.9rem;}
  .head{margin-bottom:40px;}
  .btn{padding:16px 28px; font-size:.82rem;}
  .btn-xl{padding:18px 36px; font-size:.88rem;}
  .hero .inner{padding:100px 18px 110px;}
  .hero .cta-row{gap:10px;}
  .hero .cta-row .btn{flex:1 1 calc(50% - 5px); min-width:0; padding:13px 16px; font-size:.72rem; letter-spacing:.1em;}
  form.card{padding:24px;}
  .sticky-book{display:block;}
  .rev-feature{padding:60px 18px;}
}
