/* ── CPS Projects Shared Design System ──────────────────────── */
:root {
  --bg:          #ffffff;
  --bg-alt:      #f8f7f4;
  --bg-card:     #ffffff;
  --text:        #1a1a18;
  --text-sub:    #555550;
  --text-muted:  #888880;
  --border:      rgba(0,0,0,0.10);
  --shadow:      0 4px 24px rgba(0,0,0,0.08);
  --nav-bg:      rgba(255,255,255,0.96);
  --input-bg:    #f8f7f4;
  --radius:      8px;
  --radius-lg:   16px;
  --trans:       all 0.25s ease;
  --ff-head:     'Cormorant Garamond', Georgia, serif;
  --ff-body:     'Jost', system-ui, sans-serif;
  /* accent overridden per project */
  --accent:      #C9A84C;
  --accent-lt:   #e8c96a;
  --accent-dark: #0D1B3E;
}
[data-theme="dark"] {
  --bg:          #0f0f0e;
  --bg-alt:      #161614;
  --bg-card:     #1c1c1a;
  --text:        #f5f0e8;
  --text-sub:    #c8c4bc;
  --text-muted:  #888880;
  --border:      rgba(255,255,255,0.08);
  --shadow:      0 4px 24px rgba(0,0,0,0.4);
  --nav-bg:      rgba(15,15,14,0.96);
  --input-bg:    #0f0f0e;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:var(--ff-body);line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none;transition:var(--trans)}
a:hover{color:var(--accent-lt)}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:88px 0;background:var(--bg)}
.section-alt{padding:88px 0;background:var(--bg-alt)}
.section-dark{padding:88px 0;background:var(--accent-dark)}
.section-dark *{color:#fff}
.section-label{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.section-title{font-family:var(--ff-head);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:400;line-height:1.2;color:var(--text);margin-bottom:24px}
.section-title em{font-style:italic;color:var(--accent)}
.section-sub{font-size:16px;color:var(--text-muted);max-width:600px;margin-bottom:40px;line-height:1.8}
.hidden{display:none!important}
/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:var(--trans)}
.nav.scrolled{background:var(--nav-bg);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);box-shadow:var(--shadow)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;height:68px;gap:20px}
.nav-back{font-size:12px;color:rgba(255,255,255,0.7);white-space:nowrap;transition:var(--trans)}
.nav-back:hover{color:#fff}
.nav.scrolled .nav-back{color:var(--text-muted)}
.nav.scrolled .nav-back:hover{color:var(--accent)}
.nav-brand{font-family:var(--ff-head);font-size:1.2rem;font-weight:600;color:#fff;flex:1;transition:var(--trans)}
.nav.scrolled .nav-brand{color:var(--text)}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links a{font-size:13px;color:rgba(255,255,255,0.75);transition:var(--trans)}
.nav-links a:hover{color:#fff}
.nav.scrolled .nav-links a{color:var(--text-muted)}
.nav.scrolled .nav-links a:hover{color:var(--text)}
.nav-cta{background:var(--accent)!important;color:var(--accent-dark)!important;padding:8px 20px;border-radius:4px;font-weight:700;font-size:13px!important}
.nav-cta:hover{background:var(--accent-lt)!important;color:var(--accent-dark)!important}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-burger span{display:block;width:24px;height:2px;background:#fff;transition:var(--trans)}
.nav.scrolled .nav-burger span{background:var(--text)}
.nav-mobile{display:none;flex-direction:column;background:var(--nav-bg);border-bottom:1px solid var(--border);padding:16px 24px;gap:14px}
.nav-mobile.open{display:flex}
.nav-mobile a{font-size:14px;color:var(--text-muted)}
.nav-mobile a:hover{color:var(--accent)}
.theme-toggle{background:none;border:1px solid rgba(255,255,255,0.3);border-radius:20px;padding:4px 12px;cursor:pointer;display:flex;align-items:center;gap:6px;font-size:12px;color:rgba(255,255,255,0.7);transition:var(--trans)}
.nav.scrolled .theme-toggle{border-color:var(--border);color:var(--text-muted)}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}
.theme-float{position:fixed;bottom:90px;right:28px;z-index:998;background:var(--bg-card);border:1px solid var(--border);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow);transition:var(--trans);font-size:18px}
.theme-float:hover{border-color:var(--accent);transform:scale(1.08)}
.back-to-top{position:fixed;bottom:28px;left:28px;z-index:998;background:var(--accent-dark);color:#fff;border:none;border-radius:50%;width:44px;height:44px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease;box-shadow:var(--shadow)}
.back-to-top.btt-visible{opacity:1;pointer-events:all}
.back-to-top:hover{transform:translateY(-3px);background:var(--accent)}
.wa-float{position:fixed;bottom:28px;right:28px;z-index:999;background:#25D366;color:#fff;width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.4);transition:var(--trans)}
.wa-float:hover{transform:scale(1.08)}
@media(max-width:900px){.nav-links{display:none}.nav-burger{display:flex}}
/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.75) 0%,rgba(0,0,0,.4) 100%)}
.hero-content{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:120px 24px 80px}
.hero-badge{display:inline-block;font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--accent);border:1px solid rgba(201,168,76,.4);padding:6px 14px;border-radius:2px;margin-bottom:24px}
.hero-title{font-family:var(--ff-head);font-size:clamp(2.8rem,6vw,5rem);font-weight:400;line-height:1.05;color:#fff;margin-bottom:20px}
.hero-title em{font-style:italic;color:var(--accent)}
.hero-sub{font-size:18px;color:rgba(255,255,255,.8);max-width:560px;margin-bottom:40px;line-height:1.8}
.hero-stats{display:flex;gap:40px;margin-bottom:40px;flex-wrap:wrap}
.hero-stat .stat-num{font-family:var(--ff-head);font-size:1.8rem;font-weight:600;color:var(--accent);display:block;line-height:1}
.hero-stat .stat-lbl{font-size:11px;color:rgba(255,255,255,.65);letter-spacing:1px;margin-top:4px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{background:var(--accent);color:var(--accent-dark);padding:14px 32px;border-radius:4px;font-weight:700;font-size:14px;transition:var(--trans);display:inline-block}
.btn-primary:hover{background:var(--accent-lt);color:var(--accent-dark)}
.btn-outline{background:transparent;color:#fff;padding:13px 30px;border-radius:4px;font-size:14px;border:1px solid rgba(255,255,255,.4);transition:var(--trans);display:inline-block}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.5);font-size:20px;animation:bounce 2s infinite}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
/* OVERVIEW */
.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.overview-text p{color:var(--text-muted);font-size:15px;line-height:1.8;margin-bottom:18px}
.fact-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}
.fact-item{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--border);gap:12px}
.fact-item:last-child{border-bottom:none}
.fact-label{font-size:13px;color:var(--text-muted)}
.fact-val{font-size:13px;color:var(--text);font-weight:500;text-align:right}
@media(max-width:768px){.overview-grid{grid-template-columns:1fr;gap:32px}}
/* UNITS */
.units-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.unit-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--trans)}
.unit-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.unit-card.featured{border-color:var(--accent)}
.unit-img{height:180px;overflow:hidden;position:relative}
.unit-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.unit-card:hover .unit-img img{transform:scale(1.04)}
.unit-sold-out{position:absolute;top:12px;right:12px;background:rgba(200,50,50,.9);color:#fff;font-size:10px;font-weight:700;letter-spacing:1px;padding:3px 10px;border-radius:2px}
.unit-body{padding:20px}
.unit-type{font-size:11px;color:var(--accent);font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:6px}
.unit-price{font-family:var(--ff-head);font-size:1.5rem;color:var(--text);margin-bottom:12px}
.unit-features{list-style:none;margin-bottom:18px}
.unit-features li{font-size:13px;color:var(--text-muted);padding:3px 0 3px 14px;position:relative}
.unit-features li::before{content:'—';position:absolute;left:0;color:var(--accent)}
.unit-cta{display:block;text-align:center;border:1px solid var(--accent);color:var(--accent);padding:9px;border-radius:4px;font-size:13px;font-weight:600;transition:var(--trans)}
.unit-cta:hover{background:var(--accent);color:var(--accent-dark)}
@media(max-width:900px){.units-grid{grid-template-columns:1fr}}
/* ROI CALCULATOR */
.roi-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px}
.roi-box h3{font-family:var(--ff-head);font-size:1.5rem;color:var(--text);margin-bottom:24px}
.roi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}
.roi-field label{display:block;font-size:11px;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.roi-field select,.roi-field input{width:100%;background:var(--input-bg);border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:var(--radius);font-size:13px}
.roi-calc-btn{background:var(--accent);color:var(--accent-dark);border:none;padding:13px;border-radius:4px;font-size:14px;font-weight:700;cursor:pointer;width:100%;transition:var(--trans)}
.roi-calc-btn:hover{background:var(--accent-lt)}
.roi-results{margin-top:24px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.roi-stat{text-align:center;background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.roi-stat-num{display:block;font-family:var(--ff-head);font-size:1.4rem;color:var(--accent);margin-bottom:4px}
.roi-stat-lbl{font-size:11px;color:var(--text-muted)}
@media(max-width:768px){.roi-row{grid-template-columns:1fr}.roi-results{grid-template-columns:repeat(2,1fr)}}
/* VIDEO */
.video-wrap{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-alt)}
.video-thumb{width:100%;height:100%;cursor:pointer;position:relative}
.video-thumb img{width:100%;height:100%;object-fit:cover}
.video-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(201,168,76,.9);border:none;border-radius:50%;width:68px;height:68px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--accent-dark);transition:var(--trans);font-size:24px}
.video-play:hover{background:var(--accent-lt);transform:translate(-50%,-50%) scale(1.08)}
.video-frame{width:100%;height:100%}
/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gallery-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius);cursor:pointer;transition:transform .3s ease}
.gallery-grid img:hover{transform:scale(1.02)}
@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
/* FAQ */
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;text-align:left;background:none;border:none;color:var(--text);font-size:15px;font-weight:500;padding:18px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:var(--trans);font-family:var(--ff-body)}
.faq-q:hover{color:var(--accent)}
.faq-q .fq{color:var(--accent);font-size:18px;flex-shrink:0;transition:var(--trans)}
.faq-a{font-size:14px;color:var(--text-muted);line-height:1.8;padding-bottom:18px;display:none}
.faq-item.open .faq-a{display:block}
.faq-item.open .fq{transform:rotate(45deg)}
/* CHAT */
.chat-wrap{max-width:720px;margin:0 auto;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.chat-messages{height:320px;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px}
.chat-msg{display:flex;gap:10px}
.chat-msg-user{flex-direction:row-reverse}
.chat-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:var(--accent-dark);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}
.chat-msg-user .chat-avatar{background:var(--text-muted);color:#fff}
.chat-bubble{background:var(--bg-alt);border:1px solid var(--border);border-radius:10px;padding:10px 14px;font-size:13px;color:var(--text);line-height:1.6;max-width:85%}
.chat-msg-user .chat-bubble{background:rgba(201,168,76,.08);border-color:rgba(201,168,76,.15)}
.chat-input-wrap{display:flex;border-top:1px solid var(--border)}
.chat-input-wrap input{flex:1;background:transparent;border:none;color:var(--text);padding:14px 18px;font-size:13px;outline:none}
.chat-input-wrap input::placeholder{color:var(--text-muted)}
.chat-send{background:var(--accent);color:var(--accent-dark);border:none;padding:0 18px;cursor:pointer;font-size:18px}
.chat-disclaimer{font-size:11px;color:var(--text-muted);text-align:center;padding:8px;border-top:1px solid var(--border)}
/* ENQUIRY FORM */
.enquiry-grid{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:start}
.eq-form{display:flex;flex-direction:column;gap:14px}
.eq-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.eq-field{display:flex;flex-direction:column;gap:5px}
.eq-field label{font-size:11px;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase}
.eq-field input,.eq-field select,.eq-field textarea{background:var(--input-bg);border:1px solid var(--border);color:var(--text);padding:11px 14px;border-radius:var(--radius);font-size:14px;transition:border-color .2s;font-family:var(--ff-body)}
.eq-field input:focus,.eq-field select:focus,.eq-field textarea:focus{outline:none;border-color:var(--accent)}
.eq-field textarea{resize:vertical;min-height:80px}
.eq-submit{background:var(--accent);color:var(--accent-dark);border:none;padding:14px;border-radius:4px;font-size:14px;font-weight:700;cursor:pointer;transition:var(--trans)}
.eq-submit:hover{background:var(--accent-lt)}
.eq-success{background:rgba(50,150,50,.1);border:1px solid rgba(50,150,50,.3);border-radius:var(--radius);padding:14px;font-size:13px;color:#327832;text-align:center}
.eq-contact{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}
.eq-contact-item{padding:12px 0;border-bottom:1px solid var(--border)}
.eq-contact-item:last-child{border-bottom:none}
.eq-contact-label{font-size:11px;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:3px}
.eq-contact-item a,.eq-contact-item span{font-size:14px;color:var(--text)}
.calendly-link{display:block;text-align:center;border:1px solid var(--border);color:var(--accent);padding:12px;border-radius:4px;font-size:13px;margin-top:14px;transition:var(--trans)}
.calendly-link:hover{border-color:var(--accent)}
@media(max-width:900px){.enquiry-grid{grid-template-columns:1fr}.eq-row{grid-template-columns:1fr}}
/* FOOTER */
.footer{background:var(--accent-dark);color:rgba(255,255,255,.65);padding:60px 0 28px}
.footer-grid{display:grid;grid-template-columns:1fr 2fr;gap:48px;margin-bottom:40px}
.footer-brand-name{font-family:var(--ff-head);font-size:1.4rem;color:#fff}
.footer-brand-sub{font-size:12px;color:var(--accent);margin-bottom:10px}
.footer-brand-desc{font-size:13px;line-height:1.7}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.footer-col h4{font-size:11px;color:var(--accent);letter-spacing:2px;text-transform:uppercase;margin-bottom:14px}
.footer-col a{display:block;font-size:13px;color:rgba(255,255,255,.55);margin-bottom:9px;transition:var(--trans)}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:rgba(255,255,255,.3);flex-wrap:wrap;gap:10px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr;gap:32px}.footer-links{grid-template-columns:1fr 1fr}}
/* AMENITIES */
.amenities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.amenity-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;text-align:center;transition:var(--trans)}
.amenity-item:hover{border-color:var(--accent)}
.amenity-item .am-icon{font-size:22px;margin-bottom:8px}
.amenity-item span{font-size:12px;color:var(--text-muted);display:block}
@media(max-width:768px){.amenities-grid{grid-template-columns:repeat(2,1fr)}}
/* PARTNER BAR */
.partner-bar{background:var(--accent-dark);padding:16px 0;text-align:center}
.partner-bar p{font-size:13px;color:rgba(255,255,255,.7)}
.partner-bar strong{color:var(--accent)}
