/* Joody Concierge — shared styles. Gold on black, editorial luxury. */
:root{
  --black:#090909;
  --black-2:#101010;
  --panel:#15120B;
  --panel-2:#1B1710;
  --gold:#C8A24C;
  --gold-bright:#E6CC86;
  --gold-deep:#A07E2C;
  --cream:#EFE9DC;
  --cream-dim:#CFC7B5;
  --muted:#8E887A;
  --muted-2:#5F5A50;
  --line:rgba(200,162,76,0.20);
  --display:'Marcellus', serif;
  --body:'Jost', sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--black);
  color:var(--cream);
  font-family:var(--body);
  font-weight:300;
  font-size:18px;
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(1100px 700px at 50% -8%, rgba(200,162,76,0.10), transparent 62%),
    radial-gradient(800px 800px at 92% 108%, rgba(200,162,76,0.05), transparent 60%);
}
.wrap{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:0 40px}
@media(max-width:640px){.wrap{padding:0 22px}}
a{color:inherit;text-decoration:none}

/* gold text accent */
.gold{
  background:linear-gradient(100deg,var(--gold-deep),var(--gold-bright),var(--gold));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 48px;transition:background .4s, padding .4s;
  backdrop-filter:blur(10px);
  background:linear-gradient(to bottom, rgba(9,9,9,0.85), rgba(9,9,9,0));
}
nav.solid{background:rgba(9,9,9,0.94);padding:16px 48px}
.brand{display:flex;align-items:center;gap:14px}
.brand .mark{width:30px;height:34px}
.brand .name{font-family:var(--display);font-size:20px;letter-spacing:5px;color:var(--gold);text-transform:uppercase}
.navlinks{display:flex;gap:40px;align-items:center}
.navlinks a{font-family:var(--display);font-size:15px;letter-spacing:2.5px;text-transform:uppercase;color:var(--cream-dim);transition:color .3s;position:relative}
.navlinks a:hover{color:var(--gold)}
.navlinks a.cta{border:1px solid var(--line);padding:9px 20px;border-radius:2px;color:var(--gold)}
.navlinks a.cta:hover{background:var(--gold);color:var(--black)}
@media(max-width:760px){.navlinks{gap:20px}.navlinks a{font-size:12px;letter-spacing:1.5px}nav{padding:16px 22px}.brand .name{font-size:16px;letter-spacing:3px}}

/* HERO */
header.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:140px 24px 90px;position:relative;overflow:hidden}
header.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse 90% 70% at 50% 42%, rgba(9,9,9,0.55), rgba(9,9,9,0.86) 78%),
    linear-gradient(180deg, rgba(9,9,9,0.78) 0%, rgba(9,9,9,0.40) 40%, rgba(9,9,9,0.92) 100%),
    url("images/hero-positano.jpg");
  background-size:cover;background-position:center 38%;
  animation:heroZoom 18s ease-out forwards;
}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero .arch{width:clamp(110px,18vw,170px);height:auto;margin-bottom:30px;opacity:0;animation:rise 1.2s .1s cubic-bezier(.2,.7,.2,1) forwards}
.hero .logoword{font-family:var(--display);letter-spacing:10px;font-size:clamp(28px,5vw,46px);color:var(--gold);opacity:0;animation:rise 1.2s .3s cubic-bezier(.2,.7,.2,1) forwards}
.hero .logosub{font-family:var(--display);letter-spacing:8px;font-size:13px;color:var(--muted);text-transform:uppercase;margin-top:6px;opacity:0;animation:rise 1.2s .45s forwards}
.hero h1{font-family:var(--display);font-weight:400;font-size:clamp(30px,6vw,58px);line-height:1.1;margin-top:46px;color:var(--cream);opacity:0;animation:rise 1.2s .6s cubic-bezier(.2,.7,.2,1) forwards}
.hero .sub{margin-top:20px;font-size:20px;color:var(--cream-dim);letter-spacing:.5px;max-width:30ch;opacity:0;animation:rise 1.2s .8s forwards}
.hero .cta-row{margin-top:46px;opacity:0;animation:rise 1.2s 1s forwards}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);font-family:var(--display);letter-spacing:3px;font-size:11px;text-transform:uppercase;color:var(--muted-2);opacity:0;animation:rise 1.2s 1.4s forwards}
.scroll-cue span{display:block;width:1px;height:40px;background:linear-gradient(var(--gold),transparent);margin:12px auto 0}

/* BUTTONS */
.btn{display:inline-block;font-family:var(--display);font-size:15px;letter-spacing:3px;text-transform:uppercase;padding:15px 38px;border-radius:2px;transition:all .35s;cursor:pointer;border:1px solid transparent}
.btn-gold{background:var(--gold);color:var(--black)}
.btn-gold:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 16px 44px rgba(200,162,76,0.22)}
.btn-ghost{border:1px solid var(--line);color:var(--gold)}
.btn-ghost:hover{border-color:var(--gold);background:rgba(200,162,76,0.06)}

/* SECTIONS */
section{padding:120px 0;position:relative}
.eyebrow{font-family:var(--display);letter-spacing:5px;text-transform:uppercase;font-size:13px;color:var(--gold);margin-bottom:24px;display:flex;align-items:center;gap:14px}
.eyebrow.center{justify-content:center}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--gold);opacity:.6}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--gold);opacity:.6}
h2{font-family:var(--display);font-weight:400;font-size:clamp(28px,4.6vw,46px);line-height:1.18;color:var(--cream);letter-spacing:.4px}
.section-head{text-align:center;max-width:760px;margin:0 auto 70px}
.section-head .sub{color:var(--cream-dim);font-size:20px;margin-top:18px}
.lede{font-size:21px;color:var(--cream-dim);line-height:1.85;max-width:62ch}
.prose p{max-width:64ch;margin:0 auto 26px;color:var(--cream-dim);text-align:center}
.prose.left p{margin-left:0;text-align:left}
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);max-width:1200px;margin:0 auto}

.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* CARDS / IMAGES */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:44px}
@media(max-width:860px){.grid-3,.grid-2{grid-template-columns:1fr;gap:40px}}
.card .ph-img,.feature .ph-img{
  width:100%;aspect-ratio:4/3;border-radius:6px;overflow:hidden;position:relative;
  background:linear-gradient(150deg,var(--panel-2),var(--black-2));
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;text-align:center;
  transition:transform .5s, box-shadow .5s;
}
.card:hover .ph-img,.feature:hover .ph-img{transform:translateY(-4px);box-shadow:0 26px 60px rgba(0,0,0,0.5)}
.ph-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.card:hover .ph-img img,.feature:hover .ph-img img{transform:scale(1.05)}
.ph-img .ph-label{font-family:var(--display);letter-spacing:2px;font-size:13px;color:var(--gold-deep);padding:0 20px;text-transform:uppercase}
.ph-img .ph-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-150%);opacity:.5}
.card h3,.feature h3{font-family:var(--display);font-size:25px;color:var(--cream);margin:22px 0 10px;letter-spacing:.5px}
.card h3 .dot,.feature h3 .dot{color:var(--gold)}
.card p,.feature p{color:var(--muted);font-size:17px;line-height:1.7}

/* alternating feature rows */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-bottom:110px}
.feature-row:nth-child(even) .feature-text{order:2}
.feature-row .ph-img{aspect-ratio:5/4}
.feature-text h3{font-family:var(--display);font-size:clamp(26px,4vw,40px);color:var(--cream);margin-bottom:18px}
.feature-text p{color:var(--cream-dim);font-size:19px;max-width:46ch}
@media(max-width:860px){.feature-row{grid-template-columns:1fr;gap:28px;margin-bottom:64px}.feature-row:nth-child(even) .feature-text{order:0}}

/* ENQUIRY FORM */
.enquire{text-align:center}
.enquire-form{max-width:580px;margin:46px auto 0;display:flex;flex-direction:column;gap:16px;text-align:left}
.enquire-form .row{display:flex;gap:16px}
@media(max-width:560px){.enquire-form .row{flex-direction:column}}
.enquire-form input,.enquire-form textarea{
  width:100%;background:var(--black-2);border:1px solid var(--line);border-radius:6px;color:var(--cream);
  font-family:var(--body);font-size:17px;padding:14px 17px;outline:none;transition:border .3s;resize:vertical;
}
.enquire-form input::placeholder,.enquire-form textarea::placeholder{color:var(--muted-2)}
.enquire-form input:focus,.enquire-form textarea:focus{border-color:var(--gold)}
.enquire-form button{align-self:center;margin-top:6px}
.enquire-note{text-align:center;font-size:13px;color:var(--muted-2);margin-top:4px;line-height:1.6}
.enquire-thanks{max-width:580px;margin:46px auto 0;text-align:center;padding:44px;border:1px solid var(--line);border-radius:8px;background:rgba(200,162,76,0.04)}
.enquire-thanks h3{font-family:var(--display);font-size:30px;color:var(--gold);margin-bottom:12px}
.enquire-thanks p{color:var(--cream-dim);max-width:40ch;margin:0 auto}

/* FOOTER */
footer{padding:80px 0 50px;border-top:1px solid var(--line);position:relative;z-index:1}
.foot-grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:center}
.foot-brand{display:flex;align-items:center;gap:16px}
.foot-brand .mark{width:34px;height:38px}
.foot-brand .name{font-family:var(--display);letter-spacing:5px;color:var(--gold);font-size:20px;text-transform:uppercase}
.foot-links{display:flex;gap:30px}
.foot-links a{font-family:var(--display);letter-spacing:2px;text-transform:uppercase;font-size:13px;color:var(--muted);transition:color .3s}
.foot-links a:hover{color:var(--gold)}
.copyright{margin-top:46px;text-align:center;color:var(--muted-2);font-size:12px;letter-spacing:1px;font-family:var(--display)}

/* hero feature image collage on home */
.hero-img{width:100%;max-width:560px;aspect-ratio:16/10;border-radius:8px;margin:0 auto;background:linear-gradient(150deg,var(--panel-2),var(--black-2));border:1px solid var(--line);display:flex;align-items:center;justify-content:center}

/* DESTINATIONS strip (home) */
.destinations .grid-3{gap:24px}
.dest{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:3/4;border:1px solid var(--line)}
.dest img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.2,.7,.2,1)}
.dest:hover img{transform:scale(1.06)}
.dest::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,9,9,0) 40%,rgba(9,9,9,0.72) 100%)}
.dest .cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:22px 24px;font-family:var(--display);letter-spacing:3px;text-transform:uppercase;font-size:14px;color:var(--cream)}
.dest .cap span{display:block;font-size:11px;letter-spacing:2px;color:var(--gold-bright);margin-bottom:4px}

/* full-width image band (about) */
.imgband{position:relative;width:100%;height:clamp(300px,52vh,520px);border-radius:8px;overflow:hidden;border:1px solid var(--line);margin:0 auto}
.imgband img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.imgband::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(9,9,9,0.10),rgba(9,9,9,0.45))}

/* service teaser list (home) */
.svc-list{display:grid;grid-template-columns:repeat(3,auto);justify-content:center;gap:20px 0;max-width:840px;margin:0 auto;font-family:var(--display);letter-spacing:3px;text-transform:uppercase;font-size:clamp(13px,1.5vw,16px);color:var(--cream)}
.svc-list span{padding:8px 32px;position:relative;transition:color .3s}
.svc-list span:hover{color:var(--gold)}
.svc-list span:not(:nth-child(3n))::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:18px;background:var(--gold);opacity:.4}
@media(max-width:640px){.svc-list{grid-template-columns:1fr;gap:0}.svc-list span{padding:13px 0}.svc-list span::after{display:none!important}}
