/*
Theme Name: Pagani Residences Miami
Theme URI: https://example.com/pagani-residences
Author: Gromadzki Real Estate
Description: Ultra-luxury editorial WordPress theme for Pagani Residences Miami — faithful port of the React site. Custom logos (header + 2 footer), gold accents, Cormorant Garamond + Jost typography, full landing page front-page template.
Version: 1.5.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: pagani
*/

@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@300;400;500;600&family=Jost:wght@300;400;500;600&display=swap");

:root{
  --background:#ffffff;
  --foreground:#1a1a1a;
  --muted:#f4f4f4;
  --muted-foreground:#737373;
  --secondary:#f4f4f4;
  --border:#e5e5e5;
  --gold:#c9a14a;
  --font-display:"Cormorant Garamond",Georgia,serif;
  --font-sans:"Jost",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--background);
  color:var(--foreground);
  font-family:var(--font-sans);
  font-weight:300;
  letter-spacing:.01em;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
a:hover{color:var(--gold)}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:300;letter-spacing:-.01em;line-height:1.05;margin:0}
p{margin:0 0 1em}
ul{margin:0;padding:0;list-style:none}

/* utilities */
.container{max-width:1400px;margin:0 auto;padding:0 24px}
@media(min-width:1024px){.container{padding:0 40px}}
.container-sm{max-width:1200px;margin:0 auto;padding:0 24px}
@media(min-width:1024px){.container-sm{padding:0 40px}}
.eyebrow{font-family:var(--font-sans);font-weight:400;text-transform:uppercase;letter-spacing:.3em;font-size:.7rem;color:var(--muted-foreground);display:inline-block}
.display-xl{font-size:clamp(2.75rem,7vw,6rem)}
.display-lg{font-size:clamp(2.25rem,5vw,4rem)}
.display-md{font-size:clamp(1.75rem,3.5vw,2.75rem)}
.rule{width:48px;height:1px;background:var(--gold);border:0;margin:0}
.rule-center{margin-left:auto;margin-right:auto}
.text-center{text-align:center}
.text-muted{color:var(--muted-foreground)}
.gold{color:var(--gold)}

.btn-line{
  display:inline-flex;align-items:center;gap:.75rem;
  padding:1rem 2rem;border:1px solid currentColor;
  text-transform:uppercase;letter-spacing:.25em;font-size:.72rem;font-weight:400;
  transition:background-color .3s,color .3s;cursor:pointer;background:transparent;
}
.btn-line:hover{background:var(--foreground);color:var(--background)}
.btn-line.light{color:#fff;border-color:rgba(255,255,255,.8)}
.btn-line.light:hover{background:#fff;color:var(--foreground)}

/* header */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background-color .5s,border-color .5s,backdrop-filter .5s;
  background:transparent;border-bottom:1px solid transparent;
}
.site-header.scrolled{background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-bottom-color:var(--border)}
.site-header.scrolled .nav-link,.site-header.scrolled .site-logo__text,.site-header.scrolled .menu-toggle{color:var(--foreground)}
.site-header__inner{max-width:1400px;margin:0 auto;padding:0 24px;height:80px;display:flex;align-items:center;justify-content:space-between;gap:24px}
@media(min-width:1024px){.site-header__inner{padding:0 40px}}
.site-logo{display:flex;align-items:center;flex-shrink:0;line-height:1}
.site-logo img{height:40px;width:auto;object-fit:contain}
.site-logo__text{display:flex;flex-direction:column;line-height:1;color:#fff}
.site-logo__text .name{font-family:var(--font-display);font-size:1.5rem;letter-spacing:.35em}
.site-logo__text .tag{font-family:var(--font-sans);font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;margin-top:4px;opacity:.8}
.primary-nav{display:none;flex:1;justify-content:center;gap:32px;align-items:center}
@media(min-width:768px){.primary-nav{display:flex}}
.primary-nav a{font-size:.7rem;text-transform:uppercase;letter-spacing:.25em;color:#fff;white-space:nowrap;transition:color .3s}
.primary-nav a:hover{color:var(--gold)}
.header-cta{display:none;flex-shrink:0;color:#fff;border-color:rgba(255,255,255,.8)}
@media(min-width:1280px){.header-cta{display:inline-flex}}
.site-header.scrolled .primary-nav a,.site-header.scrolled .header-cta{color:var(--foreground);border-color:var(--foreground)}
.menu-toggle{display:inline-flex;align-items:center;justify-content:center;background:none;border:0;color:#fff;padding:8px;cursor:pointer}
@media(min-width:768px){.menu-toggle{display:none}}
.menu-toggle svg{width:32px;height:32px}
.mobile-nav{display:none;background:var(--background);border-top:1px solid var(--border)}
.mobile-nav.open{display:block}
.mobile-nav nav{display:flex;flex-direction:column;padding:24px;gap:16px}
.mobile-nav a{font-size:.85rem;text-transform:uppercase;letter-spacing:.25em;color:var(--foreground);padding:8px 0}

/* sections */
section{scroll-margin-top:96px}
.section{padding:96px 24px}
@media(min-width:1024px){.section{padding:144px 40px}}
.section.dark{background:var(--foreground);color:#fff}
.section.dark .text-muted,.section.dark p{color:rgba(255,255,255,.75)}
.section.secondary{background:var(--secondary)}

/* hero */
.hero{position:relative;height:100vh;min-height:680px;width:100%;overflow:hidden}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.4),rgba(0,0,0,.2) 50%,rgba(0,0,0,.7))}
.hero__inner{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:80px;text-align:center;color:#fff;padding-left:24px;padding-right:24px}
@media(min-width:1024px){.hero__inner{padding-bottom:112px}}
.hero h1{font-family:var(--font-display);max-width:64rem;color:#fff}
.hero .eyebrow{color:rgba(255,255,255,.8);margin-bottom:24px}
.hero p{max-width:42rem;color:rgba(255,255,255,.85);font-size:1.05rem;margin:24px 0 0}
.hero .actions{display:flex;flex-direction:column;gap:16px;margin-top:8px}
@media(min-width:640px){.hero .actions{flex-direction:row}}
.hero .rule{margin:40px auto}

/* overview */
.grid-overview{display:grid;grid-template-columns:1fr;gap:48px}
@media(min-width:1024px){.grid-overview{grid-template-columns:5fr 7fr}}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-top:80px}
@media(min-width:1024px){.stats{grid-template-columns:repeat(4,1fr)}}
.stats > div{background:var(--background);padding:32px;text-align:center}
.stats .k{font-family:var(--font-display);font-size:2rem}
@media(min-width:1024px){.stats .k{font-size:2.5rem}}
.stats .l{margin-top:12px}

/* two-col */
.two-col{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.two-col{grid-template-columns:1fr 1fr;gap:64px}}
.two-col.reverse > div:first-child{order:2}
@media(min-width:1024px){.two-col.reverse > div:first-child{order:1}}

/* feature list with gold dash */
.feature-list{border-top:1px solid var(--border);padding-top:24px;display:flex;flex-direction:column;gap:12px;font-size:.9rem}
.feature-list li{display:flex;gap:12px}
.feature-list li .dash{color:var(--gold)}
.grid-adj{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 24px}

/* amenities grid */
.grid-3{display:grid;grid-template-columns:1fr;gap:1px;background:var(--border);border:1px solid var(--border)}
@media(min-width:768px){.grid-3{grid-template-columns:repeat(3,1fr)}}
.grid-3 article{background:var(--background)}
.grid-3 .ratio{aspect-ratio:4/3;overflow:hidden}
.grid-3 .ratio img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s}
.grid-3 article:hover .ratio img{transform:scale(1.05)}
.grid-3 .body{padding:32px}
@media(min-width:1024px){.grid-3 .body{padding:40px}}
.grid-3 h3{font-family:var(--font-display);font-size:1.5rem;margin-bottom:12px}

/* why list */
.why-list{display:grid;grid-template-columns:1fr;gap:1px;background:var(--border);border:1px solid var(--border)}
@media(min-width:768px){.why-list{grid-template-columns:1fr 1fr}}
.why-list li{background:var(--background);padding:24px;display:flex;gap:12px;font-size:.9rem}
@media(min-width:1024px){.why-list li{padding:32px}}
.why-list .dash{color:var(--gold)}

/* neighborhood band */
.band{position:relative;height:60vh;min-height:420px}
.band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.band::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.4)}
.band__inner{position:relative;z-index:1;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;padding:0 24px;color:#fff}
.band__inner h2{color:#fff}
.band__inner p{color:rgba(255,255,255,.85)}

/* team */
.grid-4{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
@media(min-width:1024px){.grid-4{grid-template-columns:repeat(4,1fr)}}
.grid-4 > div{background:var(--background);padding:40px;text-align:center}
.grid-4 .name{font-family:var(--font-display);font-size:1.5rem}

/* FAQ */
.faq{max-width:900px;margin:0 auto}
.faq details{border-bottom:1px solid var(--border);padding:24px 0}
.faq summary{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;cursor:pointer;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary h3{font-family:var(--font-display);font-size:1.25rem;padding-right:1rem;margin:0}
.faq summary .icon{color:var(--gold);font-size:1.5rem;line-height:1;transition:transform .3s}
.faq details[open] summary .icon{transform:rotate(45deg)}
.faq details p{margin-top:16px;color:var(--muted-foreground)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr;gap:48px}
@media(min-width:1024px){.contact-grid{grid-template-columns:1fr 1fr;gap:64px}}
.contact-info p{font-size:.9rem}
.form-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.form-grid{grid-template-columns:1fr 1fr}}
.form input,.form textarea{
  width:100%;padding:14px 16px;border:1px solid var(--border);background:var(--background);
  font-family:inherit;font-size:.9rem;color:inherit;border-radius:0;
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--gold)}
.form textarea{min-height:140px;resize:vertical;grid-column:1/-1}
.form .full{grid-column:1/-1}

/* footer */
.site-footer{background:#fff;padding:80px 24px 40px;border-top:1px solid rgba(201,161,74,.2)}
@media(min-width:1024px){.site-footer{padding:80px 40px 40px}}
.footer-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:48px}
@media(min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-logo{height:56px;width:auto;object-fit:contain}
.footer-logo-secondary{height:48px;width:auto;object-fit:contain;opacity:.8;margin-top:32px}
.footer-grid h4{font-family:var(--font-sans);font-weight:400;text-transform:uppercase;letter-spacing:.3em;font-size:.7rem;color:var(--muted-foreground);margin:0 0 16px}
.footer-grid ul li{margin-bottom:8px;font-size:.85rem}
.footer-grid ul li a:hover{color:var(--gold)}
.footer-disclaimer{max-width:1400px;margin:48px auto 0;font-size:.72rem;color:#999;line-height:1.7}
.footer-disclaimer p{max-width:768px;margin:0 0 8px}
.footer-bottom{max-width:1400px;margin:64px auto 0;padding-top:32px;border-top:1px solid rgba(0,0,0,.1);display:flex;flex-direction:column;justify-content:space-between;font-size:.72rem;color:#999;gap:12px}
@media(min-width:768px){.footer-bottom{flex-direction:row;align-items:center}}
.footer-legal-links a:hover{color:var(--gold)!important}
.footer-bottom .legal{text-transform:uppercase;letter-spacing:.25em}

/* floor plans */
.plans-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:640px){.plans-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.plans-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1280px){.plans-grid{grid-template-columns:repeat(4,1fr)}}
.plan-card{border:1px solid var(--border);background:rgba(244,244,244,.4);transition:background .2s;display:block}
.plan-card:hover{background:var(--secondary)}
.plan-card .ratio{aspect-ratio:1/1;overflow:hidden;background:#fff}
.plan-card .ratio img{width:100%;height:100%;object-fit:contain}
.plan-card .body{padding:16px 20px;border-top:1px solid var(--border)}
.plan-card .body p:first-child{font-family:var(--font-display);font-size:1.5rem;line-height:1;margin:0}

/* ===== Page-wide galleries ===== */
.home-gallery{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
@media(min-width:640px){.home-gallery{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1024px){.home-gallery{grid-template-columns:repeat(6,1fr)}}
.home-gallery button{border:0;padding:0;margin:0;position:relative;overflow:hidden;background:var(--secondary);aspect-ratio:1/1;cursor:pointer}
.home-gallery button img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s ease}
.home-gallery button:hover img{transform:scale(1.05)}

.floor-gallery{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:640px){.floor-gallery{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.floor-gallery{grid-template-columns:repeat(3,1fr);gap:32px}}
@media(min-width:1280px){.floor-gallery{grid-template-columns:repeat(4,1fr)}}
.floor-gallery .plan-card{border:1px solid var(--border);background:rgba(244,244,244,.4);transition:background .2s;display:block;text-align:left;width:100%;padding:0;cursor:pointer;font:inherit;color:inherit}
.floor-gallery .plan-card:hover{background:var(--secondary)}
.floor-gallery .plan-card .ratio{aspect-ratio:1/1;overflow:hidden;background:#fff}
.floor-gallery .plan-card .ratio img{width:100%;height:100%;object-fit:contain;transition:transform .5s ease}
.floor-gallery .plan-card:hover .ratio img{transform:scale(1.03)}
.floor-gallery .plan-card .body{padding:16px 20px;border-top:1px solid var(--border)}
.floor-gallery .plan-card .body p:first-child{font-family:var(--font-display);font-size:1.5rem;line-height:1;margin:0}

/* ===== Lightbox ===== */
.pagani-lb{position:fixed;inset:0;z-index:9999;background:rgba(10,10,10,.95);backdrop-filter:blur(6px);display:none;flex-direction:column}
.pagani-lb.open{display:flex}
.pagani-lb__bar{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);color:#fff}
@media(min-width:1024px){.pagani-lb__bar{padding:20px 40px}}
.pagani-lb__count{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.pagani-lb__close{background:transparent;border:0;color:#fff;font-size:.85rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer}
.pagani-lb__close:hover{opacity:.6}
.pagani-lb__body{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;position:relative}
.pagani-lb__img{max-height:80vh;max-width:90vw;object-fit:contain}
.pagani-lb__nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:1.5rem;cursor:pointer;transition:background .2s}
.pagani-lb__nav:hover{background:#fff;color:#000}
.pagani-lb__nav.prev{left:16px}
.pagani-lb__nav.next{right:16px}
@media(min-width:1024px){.pagani-lb__nav{width:56px;height:56px}.pagani-lb__nav.prev{left:32px}.pagani-lb__nav.next{right:32px}}
.pagani-lb__caption{padding:16px 24px;border-top:1px solid rgba(255,255,255,.15);text-align:center;color:#bbb;font-size:.875rem}
