/* John Dreaper Villa — Design System
   Editorial luxury hospitality. Cormorant Garamond + Jost.
   Palette: warm ink, parchment, aged brass.
*/
:root{
  --ink:#181614;
  --ink-2:#2a2520;
  --paper:#f4ede0;
  --paper-2:#ebe3d3;
  --warm-white:#fbf7ef;
  --brass:#a8824f;
  --brass-deep:#8a6a3d;
  --line:#cbb99c;
  --line-soft:#dccdb3;
  --muted:#6f6459;
  --muted-2:#8a7e72;
  --text:#1f1c18;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Jost',-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight:300;
  color:var(--text);
  background:var(--warm-white);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{cursor:pointer;border:0;background:transparent;font:inherit;color:inherit}
input,select,textarea{font:inherit;color:inherit}

/* Type */
.serif{font-family:'Cormorant Garamond','Cormorant',Georgia,serif;font-weight:400}
.eyebrow{
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--brass);font-weight:500;
}
.eyebrow-light{color:rgba(255,255,255,.7);}
h1,h2,h3,h4{
  font-family:'Cormorant Garamond','Cormorant',Georgia,serif;
  font-weight:300;line-height:1.05;letter-spacing:-.012em;color:var(--ink);
}
h1{font-size:clamp(46px,7.4vw,108px)}
h2{font-size:clamp(36px,5.6vw,72px)}
h3{font-size:clamp(26px,3.2vw,38px);font-weight:400}
h4{font-size:22px;font-weight:400}
p{font-size:16px;line-height:1.85;color:var(--text)}
.lead{font-size:clamp(17px,1.4vw,21px);line-height:1.75;color:var(--ink-2);font-weight:300}
.caption{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
em,.italic{font-style:italic;font-family:'Cormorant Garamond',serif;color:var(--ink-2)}

/* Buttons */
.btn{
  display:inline-block;padding:15px 32px;border-radius:999px;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  font-weight:500;transition:transform .25s ease,background .25s ease,color .25s ease;
}
.btn-dark{background:var(--ink);color:var(--warm-white)}
.btn-dark:hover{background:var(--brass-deep);transform:translateY(-1px)}
.btn-light{background:var(--warm-white);color:var(--ink)}
.btn-light:hover{background:var(--brass);color:var(--warm-white);transform:translateY(-1px)}
.btn-ghost{border:1px solid rgba(255,255,255,.5);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.btn-outline{border:1px solid var(--ink);color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--warm-white)}

/* Nav */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  height:74px;padding:0 6vw;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(24,22,20,.42);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  color:#fff;border-bottom:1px solid rgba(255,255,255,.08);
  transition:background .3s ease;
}
.nav.solid{background:rgba(24,22,20,.92)}
.nav.dark-page{background:rgba(24,22,20,.92);border-bottom-color:rgba(255,255,255,.06)}
.nav-brand{
  font-family:'Cormorant Garamond',serif;font-size:22px;letter-spacing:.06em;font-weight:400;
}
.nav-brand .mark{
  font-style:italic;color:var(--brass);
}
.nav-links{display:flex;gap:34px;align-items:center;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:400}
.nav-links a{color:rgba(255,255,255,.85);transition:color .2s ease}
.nav-links a:hover{color:var(--brass)}
.nav-links .nav-cta{
  background:var(--warm-white);color:var(--ink);padding:11px 22px;border-radius:999px;
}
.nav-links .nav-cta:hover{background:var(--brass);color:var(--warm-white)}
.nav-toggle{display:none;background:transparent;border:0;color:#fff;font-size:14px;letter-spacing:.18em}

/* Mobile menu */
.mobile-menu{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:50;
  background:var(--ink);color:#fff;
  padding:100px 8vw 40px;flex-direction:column;gap:24px;
  font-size:28px;font-family:'Cormorant Garamond',serif;font-weight:300;
}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1)}

/* Hero */
.hero{
  position:relative;min-height:100vh;min-height:100svh;
  display:flex;align-items:flex-end;
  padding:120px 7vw 6vh;color:#fff;overflow:hidden;
}
.hero-img{
  position:absolute;inset:0;z-index:0;
  background-position:center;background-size:cover;
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,.32) 0%,rgba(0,0,0,.18) 40%,rgba(0,0,0,.72) 100%);
}
.hero-inner{position:relative;z-index:2;max-width:920px;width:100%}
.hero h1{color:#fff;margin-top:18px}
.hero p{color:rgba(255,255,255,.8);max-width:580px;margin-top:24px;font-size:16px;line-height:1.85}
.hero .btns{margin-top:38px;display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{
  position:absolute;bottom:36px;right:7vw;z-index:2;
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.55);
  text-align:right;line-height:2;
}

/* Marquee */
.marquee{
  background:var(--ink);color:var(--brass);
  padding:14px 0;overflow:hidden;white-space:nowrap;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);
}
.marquee-track{display:inline-block;animation:scroll 38s linear infinite}
.marquee span{display:inline-block;padding-right:60px}
.marquee span::after{content:'·';color:rgba(168,130,79,.4);margin-left:60px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Sections */
.section{padding:140px 7vw}
.section-narrow{padding:120px 7vw}
.section-paper{background:var(--paper)}
.section-warm{background:var(--warm-white)}
.section-ink{background:var(--ink);color:var(--warm-white)}
.section-ink h1,.section-ink h2,.section-ink h3{color:var(--warm-white)}
.section-ink p{color:rgba(255,255,255,.72)}
.section-ink .eyebrow{color:var(--brass)}

.container{max-width:1280px;margin:0 auto}
.container-wide{max-width:1440px;margin:0 auto}
.container-narrow{max-width:920px;margin:0 auto}
.center{text-align:center}

/* Two-column editorial */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.two-col.flip > div:first-child{order:2}
.two-col-img{height:660px;background-size:cover;background-position:center}
.two-col h2{margin-top:18px}
.two-col p{margin-top:22px;color:var(--muted);line-height:1.95}

/* Stats / Specs */
.specs{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  margin-top:64px;
}
.spec{padding:40px 24px;border-right:1px solid var(--line)}
.spec:last-child{border-right:0}
.spec strong{
  display:block;font-family:'Cormorant Garamond',serif;font-size:46px;font-weight:300;
  color:var(--ink);line-height:1;margin-bottom:12px;
}
.spec small{
  display:block;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);
}

/* Cards / Experiences */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.card{position:relative;overflow:hidden}
.card-img{
  height:480px;background-size:cover;background-position:center;
  transition:transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.card:hover .card-img{transform:scale(1.06)}
.card-body{padding:28px 4px 0}
.card-body h3{margin:10px 0 12px;font-weight:400}
.card-body p{font-size:14px;color:var(--muted);line-height:1.8}
.card-link{
  display:inline-block;margin-top:18px;
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink);border-bottom:1px solid var(--brass);padding-bottom:3px;
}
.card-link:hover{color:var(--brass)}

/* Cinema photo grid */
.cinema-grid{
  display:grid;grid-template-columns:1.2fr .85fr 1fr;gap:3px;
  margin-top:64px;
}
.frame{
  position:relative;overflow:hidden;background:#0d0c0b;min-height:340px;
  display:block;
}
.frame.tall{grid-row:span 2;min-height:700px}
.frame.wide{grid-column:span 2}
.frame img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.85);transition:transform 1.2s ease,filter .5s ease;
}
.frame:hover img{transform:scale(1.05);filter:brightness(1)}
.frame .caption{
  position:absolute;left:24px;bottom:18px;color:rgba(255,255,255,.78);font-size:10px;
}

/* Feature list */
.features-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:32px}
.feature{
  border-top:1px solid var(--line-soft);
  padding:18px 0;color:var(--ink-2);font-size:14px;
  display:flex;align-items:center;gap:14px;
}
.feature::before{
  content:'';width:6px;height:6px;background:var(--brass);
  border-radius:50%;flex-shrink:0;
}

/* Provenance band */
.provenance{
  background:var(--paper);padding:80px 7vw;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
}
.provenance-inner{
  max-width:1100px;margin:0 auto;display:grid;grid-template-columns:auto 1fr;gap:60px;align-items:center;
}
.provenance .seal{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;
  color:var(--brass);letter-spacing:.04em;text-align:center;
  border:1px solid var(--brass);padding:30px 22px;border-radius:50%;
  width:170px;height:170px;display:flex;align-items:center;justify-content:center;
  line-height:1.4;flex-shrink:0;
}
.provenance p{font-family:'Cormorant Garamond',serif;font-size:clamp(20px,2vw,28px);line-height:1.5;color:var(--ink);font-style:italic;font-weight:300}
.provenance p strong{font-style:normal;color:var(--brass);font-weight:400}

/* FIFA / Calendar callout */
.callout{
  background:var(--ink);color:#fff;padding:120px 7vw;
  position:relative;overflow:hidden;
}
.callout::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--brass),transparent);
}
.callout-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:90px;align-items:center}
.callout h2{color:#fff}
.callout p{color:rgba(255,255,255,.72);margin-top:22px;line-height:1.95}
.callout .dates{
  margin-top:36px;display:grid;grid-template-columns:auto 1fr;gap:20px 32px;
  border-top:1px solid rgba(255,255,255,.18);padding-top:30px;
}
.callout .dates dt{
  font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:300;color:var(--brass);
}
.callout .dates dd{font-size:13px;color:rgba(255,255,255,.78);align-self:center}

/* Pull quote */
.pull-quote{
  max-width:920px;margin:80px auto;padding:0 6vw;text-align:center;
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;
  font-size:clamp(24px,3vw,38px);line-height:1.4;color:var(--ink);
}
.pull-quote::before{content:'';display:block;width:48px;height:1px;background:var(--brass);margin:0 auto 28px}
.pull-quote::after{content:'';display:block;width:48px;height:1px;background:var(--brass);margin:28px auto 0}

/* Story prose */
.prose{max-width:780px;margin:0 auto}
.prose p{font-size:17px;line-height:1.95;color:var(--ink-2);margin-bottom:26px}
.prose p:first-of-type::first-letter{
  font-family:'Cormorant Garamond',serif;font-size:72px;float:left;line-height:1;
  margin-right:12px;margin-top:6px;color:var(--brass);
}
.prose h3{margin:50px 0 18px;color:var(--ink)}
.prose figure{margin:50px -10vw;}
.prose figure img{width:100%;height:auto}
.prose figure figcaption{
  text-align:center;margin-top:14px;font-size:12px;color:var(--muted);
  letter-spacing:.18em;text-transform:uppercase;
}

/* Form */
.form{display:grid;gap:0}
.field{margin-bottom:28px}
.field label{
  display:block;font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);margin-bottom:12px;
}
.field input,.field select,.field textarea{
  width:100%;border:0;border-bottom:1px solid var(--line);
  padding:14px 0;background:transparent;color:var(--ink);
  font-size:15px;font-weight:300;outline:0;transition:border-color .2s ease;
}
.field textarea{height:120px;resize:vertical}
.field select{cursor:pointer}
.field input:focus,.field select:focus,.field textarea:focus{border-bottom-color:var(--brass)}
.pair{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.form-note{font-size:11px;color:var(--muted);margin-top:18px;text-align:center;letter-spacing:.04em}
.honey{position:absolute;left:-9999px;}

/* Gallery */
.gallery-filters{display:flex;gap:32px;justify-content:center;margin-bottom:60px;flex-wrap:wrap}
.gallery-filters button{
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--muted);padding:10px 0;
  border-bottom:1px solid transparent;transition:color .2s ease,border-color .2s ease;
}
.gallery-filters button.active,.gallery-filters button:hover{
  color:var(--ink);border-bottom-color:var(--brass);
}
.gallery-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
}
.gallery-item{
  position:relative;overflow:hidden;background:#1a1714;
  aspect-ratio:3/2;cursor:pointer;
}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s cubic-bezier(.2,.8,.2,1),filter .3s ease;
}
.gallery-item:hover img{transform:scale(1.04);filter:brightness(1.05)}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:100;background:rgba(10,9,8,.96);
  display:none;align-items:center;justify-content:center;
  padding:40px;animation:fadeIn .25s ease;
}
.lightbox.open{display:flex}
.lightbox img{max-width:100%;max-height:100%;object-fit:contain}
.lightbox-close,.lightbox-nav{
  position:absolute;color:#fff;font-size:14px;letter-spacing:.18em;
  text-transform:uppercase;cursor:pointer;background:transparent;border:0;
}
.lightbox-close{top:24px;right:32px}
.lightbox-prev{left:32px;top:50%;transform:translateY(-50%)}
.lightbox-next{right:32px;top:50%;transform:translateY(-50%)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* Footer */
.footer{
  background:#0e0d0c;color:rgba(255,255,255,.72);
  padding:90px 7vw 36px;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;
  border-bottom:1px solid rgba(255,255,255,.12);padding-bottom:56px;margin-bottom:36px;
}
.footer h4{
  font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;color:#fff;margin-bottom:14px;
}
.footer h5{
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--brass);margin-bottom:18px;
}
.footer ul{list-style:none}
.footer li{padding:6px 0;font-size:13px}
.footer li a:hover{color:var(--brass)}
.footer p{font-size:13px;line-height:1.85;color:rgba(255,255,255,.62)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-size:11px;color:rgba(255,255,255,.42);letter-spacing:.04em;
}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .9s ease,transform .9s ease}
.reveal.on{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
}

/* Subtle paper texture */
.section-paper,.section-warm{
  position:relative;
}

/* Responsive */
@media (max-width:1024px){
  .cards{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media (max-width:760px){
  .nav{padding:0 22px;height:64px}
  .nav-links a:not(.nav-cta){display:none}
  .nav-toggle{display:block}
  .section{padding:90px 22px}
  .section-narrow{padding:80px 22px}
  .hero{padding:100px 22px 6vh}
  .hero-meta{display:none}
  .two-col{grid-template-columns:1fr;gap:50px}
  .two-col.flip > div:first-child{order:initial}
  .two-col-img{height:380px}
  .specs{grid-template-columns:1fr 1fr}
  .spec{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .spec:nth-child(2n){border-right:0}
  .spec:nth-last-child(-n+2){border-bottom:0}
  .cards{grid-template-columns:1fr;gap:50px}
  .cinema-grid{grid-template-columns:1fr}
  .frame.tall,.frame.wide{grid-row:auto;grid-column:auto;min-height:380px}
  .features-grid{grid-template-columns:1fr}
  .pair{grid-template-columns:1fr;gap:0}
  .callout{padding:80px 22px}
  .callout-inner{grid-template-columns:1fr;gap:40px}
  .provenance{padding:60px 22px}
  .provenance-inner{grid-template-columns:1fr;gap:32px;text-align:center}
  .provenance .seal{margin:0 auto}
  .gallery-grid{grid-template-columns:1fr;gap:8px}
  .footer-grid{grid-template-columns:1fr;gap:40px;padding-bottom:40px}
  .footer-bottom{flex-direction:column;text-align:center}
  .prose figure{margin:40px 0}
  h1{font-size:clamp(40px,11vw,68px)}
  h2{font-size:clamp(32px,8vw,52px)}
}
