/* =========================================================
   DEBBIE'S UPPERCLASS — STYLE SYSTEM
   Palette:  Navy #0B1F2E (ink)  Gold #D4A237 (accent)
             Leaf Green #6FA838  Deep Green #1F4D2C
             Cream #F7F4EC (paper)  Charcoal #181512 (text)
   Type: Display "Fraunces" / Body "Manrope" / Utility "Manrope" tracked
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..700;1,9..144,400..600&family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --ink:#0B1F2E;
  --ink-2:#102A3D;
  --gold:#D4A237;
  --gold-light:#F1C868;
  --green-deep:#1F4D2C;
  --green-leaf:#6FA838;
  --paper:#F7F4EC;
  --paper-dim:#EFE9D8;
  --charcoal:#181512;
  --white:#FFFFFF;
  --line: rgba(212,162,55,0.25);

  --shadow-soft: 0 20px 60px -20px rgba(11,31,46,0.45);
  --shadow-deep: 0 30px 80px -10px rgba(11,31,46,0.55);

  --ease: cubic-bezier(.2,.8,.2,1);
  --ease-soft: cubic-bezier(.16,1,.3,1);

  --maxw: 1240px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important;}
}
body{
  margin:0;
  font-family:'Manrope', sans-serif;
  background:var(--paper);
  color:var(--charcoal);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
ul{margin:0; padding:0; list-style:none;}
button{font-family:inherit; cursor:pointer;}
section{position:relative;}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px;}

h1,h2,h3,h4{
  font-family:'Fraunces', serif;
  font-weight:600;
  line-height:1.05;
  margin:0;
  letter-spacing:-0.01em;
  color:var(--ink);
}
.serif-italic{font-style:italic; font-weight:400;}

.eyebrow{
  font-family:'Manrope',sans-serif;
  font-weight:700;
  font-size:12.5px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold);
  display:flex;
  align-items:center;
  gap:12px;
}
.eyebrow::before{
  content:'';
  width:28px; height:1px;
  background:var(--gold);
  display:inline-block;
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 30px;
  border-radius:2px;
  font-weight:700;
  font-size:13.5px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  border:1px solid transparent;
  transition:transform .45s var(--ease-soft), box-shadow .45s var(--ease-soft), background .35s, color .35s, border-color .35s;
  will-change:transform;
}
.btn-gold{
  background:linear-gradient(135deg, var(--gold-light), var(--gold));
  color:var(--ink);
  box-shadow:0 10px 30px -8px rgba(212,162,55,0.55);
}
.btn-gold:hover{ transform:translateY(-3px); box-shadow:0 18px 40px -10px rgba(212,162,55,0.65); }
.btn-outline{
  background:transparent;
  border-color:rgba(255,255,255,0.4);
  color:var(--white);
}
.btn-outline:hover{ border-color:var(--gold); color:var(--gold-light); transform:translateY(-3px); }
.btn-outline-dark{
  background:transparent;
  border-color:rgba(11,31,46,0.25);
  color:var(--ink);
}
.btn-outline-dark:hover{border-color:var(--green-deep); color:var(--green-deep); transform:translateY(-3px);}

/* ============ SUNBURST SIGNATURE MOTIF ============ */
.sunburst{
  position:absolute;
  width:340px; height:340px;
  pointer-events:none;
  opacity:0.14;
  z-index:0;
}
.sunburst svg{width:100%; height:100%; animation:spin 60s linear infinite;}
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ============ PRELOADER ============ */
#preloader{
  position:fixed; inset:0; background:var(--ink);
  z-index:9999; display:flex; align-items:center; justify-content:center;
  transition:opacity .8s var(--ease), visibility .8s;
}
#preloader.done{opacity:0; visibility:hidden;}
.pre-mark{
  width:64px; height:64px;
  border:2px solid rgba(212,162,55,0.25);
  border-top-color:var(--gold);
  border-radius:50%;
  animation:rot 0.9s linear infinite;
}
@keyframes rot{to{transform:rotate(360deg);}}

/* ============ HEADER / NAV ============ */
header.site{
  position:fixed; top:0; left:0; right:0;
  z-index:500;
  padding:18px 0;
  transition:background .5s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
}
header.site .nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  max-width:var(--maxw); margin:0 auto; padding:0 28px;
}
header.site.scrolled{
  background:rgba(11,31,46,0.92);
  backdrop-filter:blur(14px);
  padding:12px 0;
  box-shadow:0 10px 30px -10px rgba(0,0,0,0.4);
}
.brand{display:flex; align-items:center; gap:12px;}
.brand img{height:52px; width:52px; border-radius:50%; transition:height .4s var(--ease);}
header.site.scrolled .brand img{height:42px; width:42px;}
.brand-text{display:flex; flex-direction:column; line-height:1.1;}
.brand-text .name{font-family:'Fraunces',serif; font-weight:600; font-size:18px; color:var(--white); letter-spacing:0.01em;}
.brand-text .tag{font-size:9.5px; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold-light); margin-top:3px;}

nav.main-links{display:flex; align-items:center; gap:38px;}
nav.main-links a{
  font-size:13.5px; font-weight:600; letter-spacing:0.03em;
  color:rgba(255,255,255,0.85);
  position:relative;
  padding:6px 0;
  transition:color .3s;
}
nav.main-links a::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:1px;
  background:var(--gold); transition:width .35s var(--ease);
}
nav.main-links a:hover, nav.main-links a.active{color:var(--gold-light);}
nav.main-links a:hover::after, nav.main-links a.active::after{width:100%;}

.nav-right{display:flex; align-items:center; gap:22px;}
.nav-cta{padding:13px 24px; font-size:12px;}
.burger{
  display:none; flex-direction:column; gap:5px; width:26px; background:none; border:none; padding:0;
}
.burger span{display:block; height:2px; width:100%; background:var(--white); transition:transform .3s, opacity .3s;}

.mobile-drawer{
  position:fixed; top:0; right:-100%; width:min(85vw,360px); height:100vh;
  background:var(--ink); z-index:600; padding:100px 32px 40px;
  transition:right .5s var(--ease-soft);
  box-shadow:-30px 0 60px rgba(0,0,0,0.4);
}
.mobile-drawer.open{right:0;}
.mobile-drawer a{
  display:block; padding:16px 0; font-family:'Fraunces',serif; font-size:22px; color:var(--white);
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.mobile-drawer a:hover{color:var(--gold-light);}
.drawer-close{position:absolute; top:32px; right:32px; background:none; border:none; color:var(--white); font-size:28px;}
.scrim{position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:590; opacity:0; visibility:hidden; transition:opacity .4s;}
.scrim.show{opacity:1; visibility:visible;}

/* ============ HERO ============ */
.hero{
  position:relative; min-height:100vh; display:flex; align-items:flex-end;
  overflow:hidden; background:var(--ink);
}
.hero .hero-bg{
  position:absolute; inset:0; z-index:0;
}
.hero .hero-bg img{
  width:100%; height:100%; object-fit:cover;
  transform:scale(1.08);
  will-change:transform;
}
.hero .hero-overlay{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(11,31,46,0.55) 0%, rgba(11,31,46,0.35) 35%, rgba(11,31,46,0.92) 100%),
    linear-gradient(100deg, rgba(11,31,46,0.85) 0%, rgba(11,31,46,0.2) 55%, rgba(11,31,46,0.6) 100%);
}
.hero-content{
  position:relative; z-index:2; padding:0 0 110px;
  max-width:var(--maxw); margin:0 auto; width:100%; padding-left:28px; padding-right:28px;
}
.hero-content .eyebrow{color:var(--gold-light);}
.hero-content .eyebrow::before{background:var(--gold-light);}
.hero h1{
  color:var(--white); font-size:clamp(40px,7vw,84px); margin-top:18px; max-width:820px;
}
.hero h1 em{color:var(--gold-light); font-style:italic; font-weight:400;}
.hero p.lead{
  color:rgba(255,255,255,0.8); font-size:17px; max-width:520px; margin-top:22px; line-height:1.7;
}
.hero-actions{display:flex; gap:18px; margin-top:42px; flex-wrap:wrap;}
.scroll-cue{
  position:absolute; right:28px; bottom:46px; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  color:rgba(255,255,255,0.6); font-size:11px; letter-spacing:0.18em; text-transform:uppercase;
}
.scroll-cue .line{width:1px; height:50px; background:linear-gradient(var(--gold), transparent); animation:cue 2s infinite;}
@keyframes cue{0%{opacity:0.2;} 50%{opacity:1;} 100%{opacity:0.2;}}

.hero-stats{
  position:relative; z-index:3;
  display:grid; grid-template-columns:repeat(4,1fr);
  max-width:var(--maxw); margin:0 auto; margin-top:-1px;
  border-top:1px solid rgba(255,255,255,0.12);
}
.hero-stats .stat{
  padding:26px 28px; border-right:1px solid rgba(255,255,255,0.1);
  background:rgba(11,31,46,0.55); backdrop-filter:blur(6px);
}
.hero-stats .stat:last-child{border-right:none;}
.hero-stats .num{font-family:'Fraunces',serif; font-size:32px; color:var(--gold-light); font-weight:600;}
.hero-stats .label{font-size:11.5px; letter-spacing:0.08em; text-transform:uppercase; color:rgba(255,255,255,0.65); margin-top:4px;}

/* ============ REVEAL ANIMATION ============ */
.reveal{opacity:0; transform:translateY(36px); transition:opacity .9s var(--ease-soft), transform .9s var(--ease-soft);}
.reveal.in{opacity:1; transform:translateY(0);}
.reveal-delay-1.in{transition-delay:.12s;}
.reveal-delay-2.in{transition-delay:.24s;}
.reveal-delay-3.in{transition-delay:.36s;}
.reveal-delay-4.in{transition-delay:.48s;}

/* ============ SECTION HEADERS ============ */
.section-head{
  display:flex; justify-content:space-between; align-items:flex-end; gap:40px;
  margin-bottom:56px; flex-wrap:wrap;
}
.section-head h2{font-size:clamp(30px,4vw,48px); max-width:640px;}
.section-head .desc{max-width:380px; color:#5b554c; font-size:15px; line-height:1.7; padding-bottom:4px;}
.pad{padding:120px 0;}
.pad-sm{padding:80px 0;}
.bg-ink{background:var(--ink); color:var(--white);}
.bg-ink h2, .bg-ink h3, .bg-ink h4{color:var(--white);}
.bg-paper-dim{background:var(--paper-dim);}

/* ============ WELCOME / INTRO ============ */
.intro-grid{display:grid; grid-template-columns:1.1fr 1fr; gap:70px; align-items:center;}
.intro-media{position:relative;}
.intro-media .frame{
  position:relative; border-radius:4px; overflow:hidden; box-shadow:var(--shadow-deep);
  transform:perspective(1200px) rotateY(-4deg) rotateX(1deg);
  transition:transform .6s var(--ease-soft);
}
.intro-media:hover .frame{transform:perspective(1200px) rotateY(0deg) rotateX(0deg);}
.intro-media .frame img{aspect-ratio:4/5; object-fit:cover;}
.intro-media .badge{
  position:absolute; bottom:-28px; left:-28px; background:var(--gold);
  color:var(--ink); padding:24px 26px; border-radius:4px; box-shadow:var(--shadow-soft);
  max-width:200px;
}
.intro-media .badge .num{font-family:'Fraunces',serif; font-size:38px; font-weight:600; line-height:1;}
.intro-media .badge .txt{font-size:12px; margin-top:6px; letter-spacing:0.02em;}
.intro-text p{color:#4a453c; line-height:1.85; font-size:16px; margin-top:20px;}
.intro-list{margin-top:30px; display:grid; gap:16px;}
.intro-list li{display:flex; gap:14px; align-items:flex-start; font-size:14.5px; color:var(--ink);}
.intro-list .dot{
  width:22px; height:22px; border-radius:50%; background:var(--green-deep); flex-shrink:0;
  display:flex; align-items:center; justify-content:center; margin-top:1px;
}
.intro-list .dot svg{width:11px; height:11px; fill:var(--gold-light);}

/* ============ SERVICES / CARDS (3D TILT) ============ */
.services-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px;}
.service-card{
  background:var(--white); border-radius:6px; overflow:hidden;
  box-shadow:0 14px 40px -18px rgba(11,31,46,0.25);
  transition:transform .55s var(--ease-soft), box-shadow .55s var(--ease-soft);
  transform-style:preserve-3d;
  position:relative;
}
.service-card:hover{ box-shadow:0 30px 60px -20px rgba(11,31,46,0.4); }
.service-card .thumb{position:relative; aspect-ratio:5/4; overflow:hidden;}
.service-card .thumb img{width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease-soft);}
.service-card:hover .thumb img{transform:scale(1.08);}
.service-card .thumb::after{
  content:''; position:absolute; inset:0; background:linear-gradient(180deg, transparent 50%, rgba(11,31,46,0.7));
}
.service-card .num-tag{
  position:absolute; top:16px; left:16px; z-index:2;
  font-family:'Fraunces',serif; color:var(--white); font-size:13px;
  background:rgba(11,31,46,0.55); padding:6px 12px; border-radius:30px; letter-spacing:0.05em;
}
.service-card .body{padding:28px 26px 30px;}
.service-card h3{font-size:21px;}
.service-card p{color:#5b554c; font-size:14px; line-height:1.7; margin-top:10px;}
.service-card .more{
  display:inline-flex; align-items:center; gap:8px; margin-top:18px; font-size:12.5px; font-weight:700;
  letter-spacing:0.06em; text-transform:uppercase; color:var(--green-deep);
}
.service-card .more svg{width:14px; height:14px; transition:transform .35s var(--ease);}
.service-card:hover .more svg{transform:translateX(5px);}

/* ============ AMENITIES STRIP ============ */
.amenity-strip{display:grid; grid-template-columns:repeat(6,1fr); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.amenity{padding:34px 18px; text-align:center; border-right:1px solid var(--line);}
.amenity:last-child{border-right:none;}
.amenity svg{width:30px; height:30px; fill:none; stroke:var(--gold); stroke-width:1.4; margin:0 auto 12px;}
.amenity .t{font-size:12.5px; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink);}

/* ============ GALLERY ============ */
.filter-bar{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:50px;}
.filter-btn{
  padding:10px 20px; border:1px solid rgba(11,31,46,0.18); border-radius:30px;
  font-size:12.5px; font-weight:700; letter-spacing:0.05em; text-transform:uppercase;
  background:transparent; color:var(--ink); transition:all .35s var(--ease);
}
.filter-btn.active, .filter-btn:hover{background:var(--ink); color:var(--white); border-color:var(--ink);}
.gallery-grid{
  display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:230px; gap:16px;
}
.g-item{position:relative; overflow:hidden; border-radius:4px; cursor:pointer;}
.g-item img{width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease-soft);}
.g-item:hover img{transform:scale(1.1);}
.g-item .tag{
  position:absolute; bottom:14px; left:14px; color:var(--white); font-size:12.5px; font-weight:700;
  letter-spacing:0.04em; text-transform:uppercase; z-index:2; opacity:0; transform:translateY(8px);
  transition:all .4s var(--ease);
}
.g-item:hover .tag{opacity:1; transform:translateY(0);}
.g-item::after{content:''; position:absolute; inset:0; background:linear-gradient(180deg, transparent 55%, rgba(11,31,46,0.75)); opacity:0; transition:opacity .4s;}
.g-item:hover::after{opacity:1;}
.g-item.tall{grid-row:span 2;}
.g-item.wide{grid-column:span 2;}

.lightbox{
  position:fixed; inset:0; background:rgba(8,16,24,0.95); z-index:800;
  display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden;
  transition:opacity .4s;
}
.lightbox.show{opacity:1; visibility:visible;}
.lightbox img{max-width:88vw; max-height:84vh; border-radius:4px; box-shadow:0 40px 90px rgba(0,0,0,0.5);}
.lightbox .lb-close{position:absolute; top:30px; right:38px; color:var(--white); font-size:32px; background:none; border:none;}
.lightbox .lb-nav{position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.2); color:var(--white); width:48px; height:48px; border-radius:50%; font-size:20px;}
.lb-prev{left:30px;} .lb-next{right:30px;}

/* ============ TESTIMONIALS ============ */
.testi-track{display:grid; grid-template-columns:repeat(3,1fr); gap:28px;}
.testi-card{
  background:var(--white); padding:36px 32px; border-radius:6px;
  border-top:3px solid var(--gold); box-shadow:0 14px 36px -20px rgba(11,31,46,0.25);
}
.testi-card .stars{color:var(--gold); font-size:14px; letter-spacing:3px;}
.testi-card p{font-size:15px; line-height:1.8; color:#4a453c; margin-top:16px; font-style:italic;}
.testi-card .who{display:flex; align-items:center; gap:12px; margin-top:22px;}
.testi-card .who .ini{
  width:42px; height:42px; border-radius:50%; background:var(--green-deep); color:var(--gold-light);
  display:flex; align-items:center; justify-content:center; font-family:'Fraunces',serif; font-weight:600;
}
.testi-card .who .nm{font-weight:700; font-size:13.5px; color:var(--ink);}
.testi-card .who .rl{font-size:12px; color:#8a8478;}

/* ============ CTA BAND ============ */
.cta-band{
  position:relative; background:linear-gradient(120deg, var(--green-deep), #143420);
  padding:90px 0; overflow:hidden;
}
.cta-band .wrap{display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap; position:relative; z-index:2;}
.cta-band h2{color:var(--white); font-size:clamp(26px,3.6vw,40px); max-width:560px;}
.cta-band p{color:rgba(255,255,255,0.75); margin-top:10px; max-width:480px;}

/* ============ FOOTER ============ */
footer.site{background:var(--ink); color:rgba(255,255,255,0.75); padding-top:90px;}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:50px; padding-bottom:60px; border-bottom:1px solid rgba(255,255,255,0.1);}
.footer-brand .brand{margin-bottom:18px;}
.footer-brand p{font-size:14px; line-height:1.8; color:rgba(255,255,255,0.6); max-width:280px;}
.footer-social{display:flex; gap:12px; margin-top:22px;}
.footer-social a{
  width:40px; height:40px; border:1px solid rgba(255,255,255,0.18); border-radius:50%;
  display:flex; align-items:center; justify-content:center; transition:all .35s var(--ease);
}
.footer-social a:hover{background:var(--gold); border-color:var(--gold); color:var(--ink);}
.footer-social svg{width:17px; height:17px; fill:currentColor;}
.f-col h4{color:var(--white); font-size:14px; letter-spacing:0.06em; text-transform:uppercase; margin-bottom:20px; font-family:'Manrope',sans-serif; font-weight:700;}
.f-col ul li{margin-bottom:12px; font-size:14px;}
.f-col ul li a:hover{color:var(--gold-light);}
.f-col .contact-line{display:flex; gap:10px; margin-bottom:14px; font-size:13.5px; align-items:flex-start;}
.f-col .contact-line svg{width:16px; height:16px; stroke:var(--gold); flex-shrink:0; margin-top:2px;}
.footer-bottom{display:flex; justify-content:space-between; padding:26px 0; font-size:12.5px; color:rgba(255,255,255,0.45); flex-wrap:wrap; gap:10px;}

/* ============ PAGE HEADER (sub pages) ============ */
.page-header{
  position:relative; padding:200px 0 90px; background:var(--ink); overflow:hidden;
}
.page-header .wrap{position:relative; z-index:2;}
.page-header h1{color:var(--white); font-size:clamp(36px,6vw,64px);}
.page-header .crumb{display:flex; gap:10px; align-items:center; margin-top:18px; font-size:13px; color:rgba(255,255,255,0.6);}
.page-header .crumb a{color:var(--gold-light);}
.page-header-bg{position:absolute; inset:0; opacity:0.18; background-size:cover; background-position:center;}

/* ============ ABOUT PAGE EXTRAS ============ */
.values-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:24px;}
.value-card{padding:34px 26px; background:var(--white); border-radius:6px; box-shadow:0 14px 36px -22px rgba(11,31,46,0.25);}
.value-card .ic{width:46px; height:46px; border-radius:50%; background:var(--paper-dim); display:flex; align-items:center; justify-content:center; margin-bottom:18px;}
.value-card .ic svg{width:22px; height:22px; stroke:var(--green-deep); fill:none; stroke-width:1.5;}
.value-card h3{font-size:18px;}
.value-card p{font-size:13.5px; color:#5b554c; margin-top:8px; line-height:1.7;}

.timeline{position:relative; padding-left:40px; border-left:1px solid var(--line);}
.t-item{position:relative; padding-bottom:46px;}
.t-item::before{content:''; position:absolute; left:-46px; top:2px; width:11px; height:11px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 4px var(--paper);}
.t-item .yr{font-family:'Fraunces',serif; color:var(--gold); font-size:20px; font-weight:600;}
.t-item h4{margin-top:6px; font-size:18px;}
.t-item p{font-size:14px; color:#5b554c; margin-top:6px; line-height:1.7; max-width:560px;}

.team-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:24px;}
.team-card{text-align:center;}
.team-card .ph{aspect-ratio:1; border-radius:6px; overflow:hidden; margin-bottom:16px;}
.team-card .ph img{width:100%; height:100%; object-fit:cover;}
.team-card h4{font-size:16px;}
.team-card .rl{font-size:12px; color:var(--gold); text-transform:uppercase; letter-spacing:0.05em; margin-top:4px;}

/* ============ SERVICES PAGE DETAIL ============ */
.detail-row{display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center; padding:90px 0; border-bottom:1px solid var(--line);}
.detail-row:last-child{border-bottom:none;}
.detail-row.rev{direction:rtl;}
.detail-row.rev > *{direction:ltr;}
.detail-media{position:relative;}
.detail-media img{border-radius:6px; aspect-ratio:6/5; object-fit:cover; box-shadow:var(--shadow-soft);}
.detail-tagnum{
  position:absolute; top:-22px; left:-22px; background:var(--ink); color:var(--gold-light);
  font-family:'Fraunces',serif; font-size:18px; padding:14px 20px; border-radius:4px; box-shadow:var(--shadow-soft);
}
.detail-text h2{font-size:clamp(26px,3.4vw,38px);}
.detail-text p{color:#4a453c; line-height:1.8; margin-top:18px; font-size:15.5px;}
.feat-tags{display:flex; flex-wrap:wrap; gap:10px; margin-top:24px;}
.feat-tags span{
  font-size:12px; font-weight:700; letter-spacing:0.03em; padding:8px 16px; border-radius:30px;
  background:var(--paper-dim); color:var(--green-deep);
}

/* ============ CONTACT / BOOKING ============ */
.contact-wrap{display:grid; grid-template-columns:0.85fr 1.15fr; gap:60px;}
.contact-info-card{background:var(--ink); color:var(--white); border-radius:8px; padding:46px 38px;}
.contact-info-card h3{color:var(--white); font-size:24px;}
.contact-info-card p{color:rgba(255,255,255,0.65); margin-top:10px; font-size:14px; line-height:1.7;}
.ci-line{display:flex; gap:14px; margin-top:26px; align-items:flex-start;}
.ci-line .ic{width:38px; height:38px; border-radius:50%; background:rgba(212,162,55,0.15); display:flex; align-items:center; justify-content:center; flex-shrink:0;}
.ci-line .ic svg{width:17px; height:17px; stroke:var(--gold-light); fill:none; stroke-width:1.5;}
.ci-line .tt{font-size:12px; color:rgba(255,255,255,0.5); text-transform:uppercase; letter-spacing:0.05em;}
.ci-line .vv{font-size:14.5px; margin-top:3px;}
.ci-line .vv a:hover{color:var(--gold-light);}
.ci-map{margin-top:30px; border-radius:6px; overflow:hidden; border:1px solid rgba(255,255,255,0.12);}
.ci-map iframe{width:100%; height:200px; border:0; filter:grayscale(0.2) contrast(1.05);}

.booking-card{background:var(--white); border-radius:8px; padding:46px 42px; box-shadow:0 24px 60px -25px rgba(11,31,46,0.3);}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:30px;}
.form-grid .full{grid-column:1/-1;}
.field label{display:block; font-size:12px; font-weight:700; letter-spacing:0.05em; text-transform:uppercase; color:var(--ink); margin-bottom:9px;}
.field input, .field select, .field textarea{
  width:100%; border:1px solid rgba(11,31,46,0.15); border-radius:4px; padding:14px 16px;
  font-family:'Manrope',sans-serif; font-size:14.5px; background:var(--paper); color:var(--charcoal);
  transition:border-color .3s, box-shadow .3s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(212,162,55,0.15);
}
.field textarea{resize:vertical; min-height:110px;}
.form-note{font-size:12.5px; color:#8a8478; margin-top:18px;}
.submit-row{margin-top:28px; display:flex; align-items:center; gap:18px; flex-wrap:wrap;}
.form-success{
  display:none; background:#eef6e8; border:1px solid var(--green-leaf); color:var(--green-deep);
  padding:16px 20px; border-radius:6px; font-size:14px; margin-top:20px;
}
.form-success.show{display:block;}

/* FAQ accordion */
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{
  display:flex; justify-content:space-between; align-items:center; padding:24px 0; cursor:pointer;
  font-family:'Fraunces',serif; font-size:18px; color:var(--ink);
}
.faq-q .plus{font-size:22px; color:var(--gold); transition:transform .35s var(--ease);}
.faq-item.open .plus{transform:rotate(45deg);}
.faq-a{max-height:0; overflow:hidden; transition:max-height .45s var(--ease-soft);}
.faq-a p{padding:0 0 24px; color:#5b554c; font-size:14.5px; line-height:1.75; max-width:680px;}

/* ============ MISC ============ */
.divider-gold{height:1px; background:linear-gradient(90deg, transparent, var(--gold), transparent); margin:0 0 60px;}
.back-to-top{
  position:fixed; bottom:28px; right:28px; width:50px; height:50px; border-radius:50%;
  background:var(--ink); border:1px solid var(--gold); color:var(--gold-light); z-index:400;
  display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden;
  transition:all .4s var(--ease); box-shadow:var(--shadow-soft);
}
.back-to-top.show{opacity:1; visibility:visible;}
.back-to-top:hover{background:var(--gold); color:var(--ink);}

/* ============ RESPONSIVE ============ */
@media (max-width:1080px){
  .intro-grid{grid-template-columns:1fr;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .gallery-grid{grid-template-columns:repeat(3,1fr);}
  .testi-track{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:repeat(2,1fr);}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .contact-wrap{grid-template-columns:1fr;}
  .detail-row, .detail-row.rev{grid-template-columns:1fr; direction:ltr;}
}
@media (max-width:860px){
  nav.main-links, .nav-cta{display:none;}
  .burger{display:flex;}
  .hero-stats{grid-template-columns:repeat(2,1fr);}
  .hero-stats .stat:nth-child(2){border-right:none;}
  .amenity-strip{grid-template-columns:repeat(3,1fr);}
  .amenity:nth-child(3){border-right:none;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .g-item.wide{grid-column:span 2;}
  .form-grid{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .pad{padding:80px 0;}
  .hero-stats{grid-template-columns:repeat(2,1fr);}
  .amenity-strip{grid-template-columns:repeat(2,1fr);}
  .amenity:nth-child(2n){border-right:none;}
  .values-grid, .team-grid{grid-template-columns:1fr;}
  .gallery-grid{grid-template-columns:repeat(2,1fr); grid-auto-rows:160px;}
  .footer-grid{grid-template-columns:1fr;}
  .cta-band .wrap{flex-direction:column; align-items:flex-start;}
}
