/* ═══════════════════════════════════════════════════════════════
   ZANZIBAR PROPERTY — COMPLETE UNIFIED STYLESHEET v11
   Clean rewrite — single file, no dark mode, no theme toggle
   ═══════════════════════════════════════════════════════════════ */

/* ── TOKENS ──────────────────────────────────────────────────── */
:root {
  --bg:          #ffffff;
  --bg-alt:      #f8f6f1;
  --bg-card:     #ffffff;
  --input-bg:    #f4f2ee;
  --text:        #1a1a18;
  --text-sub:    #444440;
  --text-muted:  #888880;
  --border:      rgba(0,0,0,0.09);
  --shadow-sm:   0 2px 12px rgba(0,0,0,0.06);
  --shadow:      0 4px 24px rgba(0,0,0,0.09);
  --shadow-lg:   0 8px 48px rgba(0,0,0,0.13);
  --radius:      8px;
  --radius-lg:   14px;
  --radius-xl:   20px;
  --trans:       all 0.22s ease;
  --ff-head:     'Cormorant Garamond', Georgia, serif;
  --ff-body:     'Jost', system-ui, sans-serif;
  --nav-bg:      rgba(255,255,255,0.97);
  --footer-bg:   #0D1B3E;
}

/* ── RESET ───────────────────────────────────────────────────── */
*,*::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(--text); text-decoration:none; transition:var(--trans); }
a:hover { color:var(--text-muted); }
button { font-family:var(--ff-body); }

/* ── LAYOUT ──────────────────────────────────────────────────── */
.container,
.section-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(--footer-bg); }
.section-dark * { color:#fff !important; }
.hidden { display:none !important; }
@media(max-width:768px){ .section,.section-alt,.section-dark{ padding:56px 0; } }

/* ── TYPOGRAPHY ──────────────────────────────────────────────── */
.section-label { font-size:11px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--text-muted); margin-bottom:16px; display:block; }
.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(--text-sub); }
.section-sub { font-size:16px; color:var(--text-muted); max-width:600px; margin-bottom:40px; line-height:1.8; }
.section-label-dark { font-size:11px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,0.5); margin-bottom:16px; display:block; }
.section-title-dark { font-family:var(--ff-head); font-size:clamp(1.8rem,3.5vw,2.8rem); font-weight:400; line-height:1.2; color:#fff; margin-bottom:24px; }
.section-title-dark em { font-style:italic; color:rgba(255,255,255,0.7); }
.section-header-center { text-align:center; margin-bottom:56px; }

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:8px; padding:13px 28px; border-radius:4px; font-size:14px; font-weight:600; transition:var(--trans); text-decoration:none; cursor:pointer; border:none; font-family:var(--ff-body); }
.btn-gold,.btn-primary { background:#1a1a18; color:#fff; }
.btn-gold:hover,.btn-primary:hover { background:#444; color:#fff; }
.btn-outline { background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,0.5); }
.btn-outline:hover { border-color:#fff; color:#fff; background:rgba(255,255,255,0.08); }
.btn-outline-dark { background:transparent; color:var(--text); border:1.5px solid var(--border); }
.btn-outline-dark:hover { border-color:var(--text); }
.btn-large { padding:16px 40px; font-size:15px; }
.btn-full { width:100%; justify-content:center; }

/* ── 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-sm); }
.nav-inner,
.nav-container { 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; }
.nav-back:hover { color:#fff; }
.nav.scrolled .nav-back { color:var(--text-muted); }
.nav-brand,
.nav-brand-name { font-family:var(--ff-head); font-size:1.2rem; font-weight:600; color:#fff; flex:1; letter-spacing:.5px; text-decoration:none; transition:var(--trans); }
.nav.scrolled .nav-brand,
.nav.scrolled .nav-brand-name { color:var(--text); }
.nav-brand-dot { color:rgba(255,255,255,0.5); font-size:16px; margin:0 2px; transition:var(--trans); }
.nav.scrolled .nav-brand-dot { color:var(--text-muted); }
.nav-brand-sub { font-size:11px; font-weight:400; color:rgba(255,255,255,0.45); letter-spacing:.5px; transition:var(--trans); }
.nav.scrolled .nav-brand-sub { color:var(--text-muted); }
.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,
.nav-links .nav-cta { background:#1a1a18 !important; color:#fff !important; padding:8px 20px; border-radius:4px; font-weight:600; font-size:13px !important; }
.nav-cta:hover { background:#444 !important; }
.nav.scrolled .nav-cta { background:#1a1a18 !important; }
.nav-portal-link { font-size:13px; }
.nav-burger,
.nav-hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.nav-burger span,
.nav-hamburger span { display:block; width:24px; height:2px; background:#fff; transition:var(--trans); }
.nav.scrolled .nav-burger span,
.nav.scrolled .nav-hamburger 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(--text); }
.nav-cta-mob,
.nav-cta-mobile { background:#1a1a18; color:#fff !important; padding:10px 20px; border-radius:4px; font-weight:600; text-align:center; }
@media(max-width:900px){ .nav-links{ display:none; } .nav-burger,.nav-hamburger{ display:flex; } }

/* ── BACK TO TOP ─────────────────────────────────────────────── */
.back-to-top { position:fixed; bottom:28px; left:28px; z-index:998; background:var(--text); 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,transform .25s; box-shadow:var(--shadow); }
.back-to-top.btt-visible { opacity:1; pointer-events:all; }
.back-to-top:hover { transform:translateY(-3px); }

/* ── FADE UP ANIMATION (main.js adds .fade-up then .visible) ── */
.fade-up { opacity:0; transform:translateY(24px); transition:opacity .5s ease, transform .5s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }

/* ═══════════════════════════════════════════════════════════════
   HOMEPAGE SECTIONS
   ═══════════════════════════════════════════════════════════════ */

/* ── HERO ────────────────────────────────────────────────────── */
.hero { position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; background:#111; }
.hero-media { position:absolute; inset:0; }
.hero-image { position:absolute; inset:0; background-size:cover; background-position:center; background-repeat:no-repeat; }
.hero-video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(0,0,0,0.75) 0%,rgba(0,0,0,0.4) 60%,rgba(0,0,0,0.2) 100%); }
.hero-grain { position:absolute; inset:0; opacity:0.03; pointer-events:none; }
.hero-container { position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:120px 24px 80px; display:grid; grid-template-columns:1fr 400px; gap:64px; align-items:center; width:100%; }
.hero-eyebrow { display:flex; align-items:center; gap:12px; font-size:11px; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,0.5); margin-bottom:24px; }
.eyebrow-line { width:32px; height:1px; background:rgba(255,255,255,0.3); }
.hero-title { font-family:var(--ff-head); font-size:clamp(3rem,6.5vw,5.5rem); font-weight:400; line-height:1.0; color:#fff; margin-bottom:24px; }
.hero-title em { font-style:italic; color:rgba(255,255,255,0.8); }
.hero-sub { font-size:17px; color:rgba(255,255,255,0.68); max-width:520px; line-height:1.8; margin-bottom:36px; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:48px; }
.hero-trust { display:flex; align-items:center; flex-wrap:wrap; gap:0; }
.trust-item { display:flex; flex-direction:column; padding-right:24px; }
.trust-num { font-family:var(--ff-head); font-size:1.6rem; font-weight:600; color:#fff; line-height:1; }
.trust-label { font-size:10px; color:rgba(255,255,255,0.45); letter-spacing:1px; text-transform:uppercase; margin-top:3px; }
.trust-divider { width:1px; height:36px; background:rgba(255,255,255,0.15); margin-right:24px; }
.hero-scroll { position:absolute; bottom:32px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; color:rgba(255,255,255,0.35); font-size:10px; letter-spacing:2px; text-transform:uppercase; }
.scroll-line { width:1px; height:40px; background:linear-gradient(to bottom,rgba(255,255,255,0.4),transparent); }
@media(max-width:1024px){ .hero-container{ grid-template-columns:1fr; } .hero-visual{ display:none; } }
@media(max-width:600px){ .hero-container{ padding:100px 24px 60px; } .trust-divider{ display:none; } .trust-item{ padding-right:16px; } }

/* ── HERO CARD ───────────────────────────────────────────────── */
.hero-visual { display:flex; align-items:center; }
.hero-card { background:rgba(255,255,255,0.07); backdrop-filter:blur(20px); border:1px solid rgba(255,255,255,0.13); border-radius:var(--radius-lg); padding:28px; width:100%; }
.hero-card-label { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.4); margin-bottom:20px; }
.hero-card-stats { display:flex; flex-direction:column; }
.card-stat { display:grid; grid-template-columns:1fr auto auto; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid rgba(255,255,255,0.07); }
.card-stat:last-child { border-bottom:none; }
.stat-area { font-size:14px; color:rgba(255,255,255,0.85); font-weight:500; }
.stat-yield { font-size:13px; color:rgba(255,255,255,0.5); }
.stat-from { font-size:12px; color:rgba(255,255,255,0.3); }
.hero-card-cta { display:block; text-align:center; font-size:12px; color:rgba(255,255,255,0.45); margin-top:20px; padding-top:16px; border-top:1px solid rgba(255,255,255,0.08); transition:var(--trans); }
.hero-card-cta:hover { color:#fff; }

/* ── ABOUT ───────────────────────────────────────────────────── */
.about { padding:96px 0; background:var(--bg); }
.about-grid { display:grid; grid-template-columns:340px 1fr; gap:80px; align-items:start; }
.about-bio { font-size:15px; color:var(--text-sub); line-height:1.85; margin-bottom:18px; }
.portrait-frame { position:relative; border-radius:var(--radius-lg); overflow:hidden; background:var(--bg-alt); margin-bottom:20px; }
.portrait-photo { width:100%; height:auto; display:block; }
.portrait-placeholder { width:100%; aspect-ratio:3/4; display:flex; align-items:center; justify-content:center; background:var(--bg-alt); }
.portrait-initial { font-family:var(--ff-head); font-size:5rem; color:var(--text-muted); }
.portrait-badge { display:inline-block; background:#0D1B3E; color:#fff; font-size:11px; font-weight:600; letter-spacing:1px; padding:5px 14px; border-radius:20px; margin-bottom:12px; }
.about-social { display:flex; gap:10px; flex-wrap:wrap; }
.social-pill { display:inline-flex; align-items:center; gap:7px; font-size:12px; color:var(--text-muted); border:1px solid var(--border); border-radius:20px; padding:6px 14px; transition:var(--trans); }
.social-pill:hover { border-color:var(--text); color:var(--text); }
.about-services { display:flex; flex-direction:column; gap:14px; margin-top:36px; }
.service-card { display:flex; gap:16px; align-items:flex-start; padding:20px; background:var(--bg-alt); border-radius:var(--radius); border:1px solid var(--border); }
.service-icon { flex-shrink:0; width:44px; height:44px; background:var(--bg); border:1px solid var(--border); border-radius:var(--radius); display:flex; align-items:center; justify-content:center; color:var(--text-sub); }
.service-icon svg { width:20px; height:20px; }
.service-body h3 { font-size:15px; font-weight:500; color:var(--text); margin-bottom:4px; }
.service-body p { font-size:13px; color:var(--text-muted); line-height:1.6; }
@media(max-width:900px){ .about-grid{ grid-template-columns:1fr; gap:40px; } }

/* ── AREAS GRID ──────────────────────────────────────────────── */
.areas { padding:96px 0; background:var(--bg-alt); }
.areas-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.area-card { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; transition:var(--trans); display:flex; flex-direction:column; }
.area-card:hover { transform:translateY(-4px); box-shadow:var(--shadow); border-color:#ccc; }
.area-card-image { position:relative; height:200px; overflow:hidden; background:var(--bg-alt); flex-shrink:0; }
.area-card-image img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.area-card:hover .area-card-image img { transform:scale(1.05); }
.area-card-image-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,0.5) 0%,transparent 60%); }
.area-yield-badge { position:absolute; bottom:12px; left:12px; background:rgba(0,0,0,0.72); color:#fff; font-size:11px; font-weight:700; padding:4px 10px; border-radius:20px; letter-spacing:.5px; }
.area-card-body { padding:18px; display:flex; flex-direction:column; flex:1; }
.area-top { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:8px; }
.area-name { font-family:var(--ff-head); font-size:1.1rem; color:var(--text); font-weight:600; }
.area-from { font-size:12px; color:var(--text-muted); }
.area-desc { font-size:13px; color:var(--text-muted); line-height:1.6; margin-bottom:14px; flex:1; }
.area-card-links { display:flex; justify-content:space-between; align-items:center; padding-top:12px; border-top:1px solid var(--border); }
.area-link-primary { font-size:13px; font-weight:500; color:var(--text); }
.area-link-primary:hover { color:var(--text-muted); }
.area-link-secondary { font-size:12px; color:var(--text-muted); }
.area-link-secondary:hover { color:var(--text); }
@media(max-width:1100px){ .areas-grid{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:768px){ .areas-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:480px){ .areas-grid{ grid-template-columns:1fr; } }

/* ── HOW IT WORKS ────────────────────────────────────────────── */
.how { padding:96px 0; background:var(--bg); }
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-bottom:56px; }
.step-card { text-align:center; padding:40px 24px; background:var(--bg-alt); border:1px solid var(--border); border-radius:var(--radius-lg); }
.step-number { font-family:var(--ff-head); font-size:3rem; color:var(--border); font-weight:700; line-height:1; margin-bottom:16px; }
.step-line { width:40px; height:2px; background:var(--text); margin:0 auto 20px; }
.step-card h3 { font-family:var(--ff-head); font-size:1.3rem; color:var(--text); margin-bottom:10px; font-weight:600; }
.step-card p { font-size:14px; color:var(--text-muted); line-height:1.7; }
.how-cta { text-align:center; }
.how-cta-note { font-size:13px; color:var(--text-muted); margin-top:16px; max-width:500px; margin-left:auto; margin-right:auto; line-height:1.7; }
@media(max-width:768px){ .steps-grid{ grid-template-columns:1fr; gap:16px; } }

/* ── INTEREST FORM ───────────────────────────────────────────── */
.interest { padding:96px 0; background:var(--bg-alt); }
.interest-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.interest-sub { font-size:15px; color:var(--text-muted); line-height:1.8; margin-bottom:32px; }
.interest-contact { display:flex; flex-direction:column; gap:12px; margin-bottom:28px; }
.contact-line { display:flex; align-items:center; gap:10px; font-size:14px; color:var(--text-sub); }
.contact-line:hover { color:var(--text); }
.contact-line svg { flex-shrink:0; }
.guide-download { margin-top:8px; }
.guide-btn { display:inline-flex; align-items:center; gap:10px; font-size:13px; color:var(--text); border:1px solid var(--border); border-radius:var(--radius); padding:12px 18px; transition:var(--trans); }
.guide-btn:hover { border-color:var(--text); }
.form-card { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-lg); padding:36px; }
.form-group { display:flex; flex-direction:column; gap:5px; margin-bottom:16px; }
.form-group label { font-size:11px; color:var(--text-muted); letter-spacing:1px; text-transform:uppercase; font-weight:500; }
.form-group input,
.form-group select,
.form-group textarea { background:var(--input-bg); border:1px solid var(--border); color:var(--text); padding:11px 14px; border-radius:var(--radius); font-size:14px; font-family:var(--ff-body); transition:border-color .2s; width:100%; }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { outline:none; border-color:var(--text-sub); }
.form-group textarea { resize:vertical; min-height:80px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-privacy { font-size:11px; color:var(--text-muted); text-align:center; margin-top:12px; }
.form-success { text-align:center; padding:40px 20px; }
.success-icon { color:var(--text-sub); margin-bottom:16px; }
.form-success h3 { font-family:var(--ff-head); font-size:1.4rem; color:var(--text); margin-bottom:8px; }
.form-success p { font-size:14px; color:var(--text-muted); margin-bottom:24px; line-height:1.7; }
@media(max-width:900px){ .interest-grid{ grid-template-columns:1fr; gap:40px; } .form-row{ grid-template-columns:1fr; } }

/* ═══════════════════════════════════════════════════════════════
   AREA PAGES — Paje, Nungwi, Fumba, Stone Town, etc.
   ═══════════════════════════════════════════════════════════════ */

/* ── AREA HERO ───────────────────────────────────────────────── */
.area-hero { position:relative; min-height:90vh; display:flex; align-items:flex-end; overflow:hidden; }
.area-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; background-color:#1a1a18; }
.area-hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,0.82) 0%,rgba(0,0,0,0.35) 55%,rgba(0,0,0,0.1) 100%); }
.area-hero-content { position:relative; z-index:2; width:100%; padding:80px 0 60px; }
.area-breadcrumb { font-size:12px; color:rgba(255,255,255,0.45); margin-bottom:20px; display:flex; align-items:center; gap:8px; }
.area-breadcrumb a { color:rgba(255,255,255,0.45); }
.area-breadcrumb a:hover { color:#fff; }
.area-breadcrumb span { color:rgba(255,255,255,0.25); }
.area-hero-title { font-family:var(--ff-head); font-size:clamp(3rem,7vw,5.5rem); font-weight:400; line-height:1.0; color:#fff; margin-bottom:20px; }
.area-hero-title em { font-style:italic; color:rgba(255,255,255,0.72); }
.area-hero-sub { font-size:17px; color:rgba(255,255,255,0.68); max-width:620px; line-height:1.8; margin-bottom:40px; }

/* ── AREA STATS ROW ──────────────────────────────────────────── */
.area-stats-row { display:flex; flex-wrap:wrap; align-items:stretch; }
.area-stat { display:flex; flex-direction:column; padding-right:32px; }
.area-stat-num { font-family:var(--ff-head); font-size:2rem; font-weight:600; color:#fff; line-height:1; margin-bottom:4px; }
.area-stat-label { font-size:11px; color:rgba(255,255,255,0.45); letter-spacing:1px; text-transform:uppercase; }
.area-stat-divider { width:1px; background:rgba(255,255,255,0.15); margin-right:32px; min-height:40px; }
@media(max-width:600px){ .area-stat-divider{ display:none; } .area-stat{ padding-right:20px; } .area-stats-row{ gap:16px; } }

/* ── AREA NAV BAR ────────────────────────────────────────────── */
.area-nav { background:var(--bg); border-bottom:1px solid var(--border); position:sticky; top:68px; z-index:900; }
.area-nav-inner { display:flex; overflow-x:auto; }
.area-nav-link { font-size:13px; color:var(--text-muted); padding:14px 20px; white-space:nowrap; border-bottom:2px solid transparent; transition:var(--trans); text-decoration:none; }
.area-nav-link:hover { color:var(--text); }
.area-nav-link.active { color:var(--text); border-bottom-color:var(--text); font-weight:500; }

/* ── AREA INTRO ──────────────────────────────────────────────── */
.area-intro-section { padding:64px 0; background:var(--bg); }
.area-intro p { font-size:16px; color:var(--text-sub); line-height:1.9; margin-bottom:20px; max-width:800px; }
.area-intro p:last-child { margin-bottom:0; }

/* ── UNESCO BAND ─────────────────────────────────────────────── */
.unesco-band { background:var(--bg-alt); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:40px 0; }
.unesco-inner { display:flex; gap:28px; align-items:flex-start; }
.unesco-badge { font-size:2.5rem; flex-shrink:0; }
.unesco-text h3 { font-family:var(--ff-head); font-size:1.3rem; color:var(--text); margin-bottom:10px; font-weight:600; }
.unesco-text p { font-size:14px; color:var(--text-muted); line-height:1.8; }

/* ── DEVELOPMENTS SECTION ────────────────────────────────────── */
.developments-section { padding:88px 0; background:#0D1B3E; }
.developments-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:48px; }
.developments-grid .dev-card.full-width { grid-column:1/-1; }
@media(max-width:900px){ .developments-grid{ grid-template-columns:1fr; } }

/* ── DEV CARD ────────────────────────────────────────────────── */
.dev-card { background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.1); border-radius:var(--radius-lg); overflow:hidden; transition:var(--trans); }
.dev-card:hover { border-color:rgba(255,255,255,0.22); transform:translateY(-2px); }
.dev-card-img-wrap { position:relative; height:220px; overflow:hidden; background:rgba(255,255,255,0.05); }
.dev-card.full-width .dev-card-img-wrap { height:280px; }
.dev-card-img-wrap img { width:100%; height:100%; object-fit:cover; }
.dev-card-img-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,0.5) 0%,transparent 60%); }
.dev-card-header { padding:20px 24px 0; }
.dev-card-tag { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.4); margin-bottom:6px; }
.dev-card-name { font-family:var(--ff-head); font-size:1.5rem; font-weight:600; color:#fff; margin-bottom:4px; }
.dev-card-developer { font-size:12px; color:rgba(255,255,255,0.4); margin-bottom:16px; }
.dev-card-body { padding:0 24px 24px; }
.dev-card-body.two-col { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
@media(max-width:768px){ .dev-card-body.two-col{ grid-template-columns:1fr; } }
.dev-card-desc { font-size:14px; color:rgba(255,255,255,0.62); line-height:1.8; margin-bottom:14px; }
.dev-card-meta { display:flex; flex-direction:column; margin:16px 0; border:1px solid rgba(255,255,255,0.08); border-radius:var(--radius); overflow:hidden; }
.dev-meta-item { display:flex; justify-content:space-between; align-items:center; padding:10px 14px; border-bottom:1px solid rgba(255,255,255,0.06); gap:12px; }
.dev-meta-item:last-child { border-bottom:none; }
.dev-meta-label { font-size:12px; color:rgba(255,255,255,0.4); }
.dev-meta-value { font-size:13px; color:rgba(255,255,255,0.85); font-weight:500; text-align:right; }
.dev-meta-value.gold { color:#C9A84C; }
.dev-card-tags { display:flex; flex-wrap:wrap; gap:6px; margin-top:14px; }
.tag { font-size:11px; font-weight:600; padding:3px 10px; border-radius:20px; letter-spacing:.3px; }
.tag-navy { background:rgba(13,27,62,0.6); color:rgba(255,255,255,0.75); border:1px solid rgba(255,255,255,0.12); }
.tag-cream { background:rgba(255,255,255,0.07); color:rgba(255,255,255,0.55); border:1px solid rgba(255,255,255,0.08); }

/* ── HERITAGE / GOVT CARDS ───────────────────────────────────── */
.heritage-section { padding:88px 0; background:#111210; }
.govt-card { display:flex; gap:28px; align-items:flex-start; padding:32px 0; border-bottom:1px solid rgba(255,255,255,0.07); }
.govt-card:last-child { border-bottom:none; }
.govt-card-num { font-family:var(--ff-head); font-size:2.5rem; color:rgba(255,255,255,0.15); font-weight:600; flex-shrink:0; min-width:48px; line-height:1; }
.govt-card-content h3 { font-family:var(--ff-head); font-size:1.2rem; color:#fff; margin-bottom:10px; font-weight:600; }
.govt-card-content p { font-size:14px; color:rgba(255,255,255,0.58); line-height:1.85; }

/* ── INVESTMENT SECTION ──────────────────────────────────────── */
.investment-section { padding:88px 0; background:#0a0a08; }
.invest-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; margin-top:48px; }
.invest-block h3 { font-family:var(--ff-head); font-size:1.2rem; color:#fff; margin-bottom:16px; font-weight:600; }
.invest-block p { font-size:14px; color:rgba(255,255,255,0.6); line-height:1.85; margin-bottom:16px; }
.invest-list { list-style:none; display:flex; flex-direction:column; gap:12px; }
.invest-list li { font-size:14px; color:rgba(255,255,255,0.6); line-height:1.7; padding-left:20px; position:relative; }
.invest-list li::before { content:'→'; position:absolute; left:0; color:rgba(255,255,255,0.3); font-size:12px; top:2px; }
@media(max-width:768px){ .invest-grid{ grid-template-columns:1fr; gap:32px; } }

/* ── CTA SECTION ─────────────────────────────────────────────── */
.cta-section { padding:88px 0; background:var(--bg-alt); }
.cta-inner { display:grid; grid-template-columns:1fr auto; gap:48px; align-items:center; }
.cta-title { font-family:var(--ff-head); font-size:clamp(2rem,4vw,3rem); font-weight:400; color:var(--text); line-height:1.15; margin-bottom:16px; }
.cta-title em { font-style:italic; color:var(--text-sub); }
.cta-sub { font-size:15px; color:var(--text-muted); line-height:1.8; max-width:540px; }
.cta-buttons { display:flex; flex-direction:column; gap:12px; min-width:200px; }
.cta-buttons .btn { text-align:center; justify-content:center; }
.cta-buttons .btn-outline { color:var(--text); border-color:var(--border); }
.cta-buttons .btn-outline:hover { border-color:var(--text); background:transparent; }
@media(max-width:768px){ .cta-inner{ grid-template-columns:1fr; } .cta-buttons{ flex-direction:row; flex-wrap:wrap; } }

/* ── FACT BOX / 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:#888; transform:translateY(-3px); box-shadow:var(--shadow); }
.unit-card.featured { border-color:var(--text-sub); }
.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,0.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(--text-muted); 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(--text-muted); }
.unit-cta { display:block; text-align:center; border:1px solid var(--text); color:var(--text); padding:9px; border-radius:4px; font-size:13px; font-weight:600; transition:var(--trans); }
.unit-cta:hover { background:var(--text); color:#fff; }
@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; font-family:var(--ff-body); }
.roi-field select:focus,
.roi-field input:focus { outline:none; border-color:var(--text-sub); }
.roi-calc-btn { background:#1a1a18; color:#fff; border:none; padding:13px; border-radius:4px; font-size:14px; font-weight:600; cursor:pointer; width:100%; transition:var(--trans); font-family:var(--ff-body); }
.roi-calc-btn:hover { background:#444; }
.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(--text); 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-play { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); background:rgba(255,255,255,0.92); border:none; border-radius:50%; width:68px; height:68px; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--text); transition:var(--trans); font-size:24px; }
.video-play:hover { background:#fff; 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; font-family:var(--ff-body); }
.faq-q:hover { color:var(--text-sub); }
.faq-q .fq { color:var(--text-muted); 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 WIDGET ─────────────────────────────────────────────── */
.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(--text); color:#fff; 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); }
.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:#f0ede8; }
.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; font-family:var(--ff-body); }
.chat-send { background:var(--text); color:#fff; 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; font-family:var(--ff-body); transition:border-color .2s; }
.eq-field input:focus,
.eq-field select:focus,
.eq-field textarea:focus { outline:none; border-color:var(--text-sub); }
.eq-field textarea { resize:vertical; min-height:80px; }
.eq-submit { background:#1a1a18; color:#fff; border:none; padding:14px; border-radius:4px; font-size:14px; font-weight:600; cursor:pointer; transition:var(--trans); width:100%; font-family:var(--ff-body); }
.eq-submit:hover { background:#444; }
.eq-success { background:rgba(50,150,50,0.08); border:1px solid rgba(50,150,50,0.25); 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(--text); padding:12px; border-radius:4px; font-size:13px; margin-top:14px; transition:var(--trans); }
.calendly-link:hover { border-color:var(--text); }
@media(max-width:900px){ .enquiry-grid{ grid-template-columns:1fr; } .eq-row{ grid-template-columns: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:#888; box-shadow:var(--shadow-sm); }
.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(--footer-bg); padding:16px 0; text-align:center; }
.partner-bar p { font-size:13px; color:rgba(255,255,255,0.7); }
.partner-bar strong { color:#fff; }

/* ── FOOTER ──────────────────────────────────────────────────── */
.site-footer,
.footer { background:var(--footer-bg); color:rgba(255,255,255,0.65); padding:56px 0 0; }
.footer-inner,
.footer-container { max-width:1200px; margin:0 auto; padding:0 24px; }
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,0.08); }
.footer-name,
.footer-brand-name,
.fb-name { font-family:var(--ff-head); font-size:1.5rem; color:#fff; font-weight:600; margin-bottom:2px; display:block; }
.footer-tagline,
.footer-brand-sub,
.fb-sub { font-size:11px; color:rgba(255,255,255,0.4); letter-spacing:1.5px; text-transform:uppercase; margin-bottom:12px; display:block; }
.footer-desc,
.footer-brand-desc,
.fb-desc { font-size:13px; color:rgba(255,255,255,0.45); line-height:1.8; margin-bottom:16px; }
.footer-powered { font-size:12px; color:rgba(255,255,255,0.3); margin-top:12px; }
.footer-powered a { color:rgba(255,255,255,0.5); }
.footer-powered a:hover { color:#fff; }
.footer-col h4,
.fl-col h4 { font-size:10px; color:rgba(255,255,255,0.4); letter-spacing:2.5px; text-transform:uppercase; font-weight:700; margin-bottom:16px; padding-bottom:8px; border-bottom:1px solid rgba(255,255,255,0.08); }
.footer-col a,
.fl-col a { display:block; font-size:13px; color:rgba(255,255,255,0.5); margin-bottom:9px; transition:color .2s; line-height:1.4; }
.footer-col a:hover,
.fl-col a:hover { color:#fff; }
.footer-col a.admin-link,
.fl-col a.admin-link { color:rgba(255,255,255,0.3); font-size:11px; margin-top:8px; }
.footer-social { display:flex; gap:10px; margin-top:4px; flex-wrap:wrap; }
.footer-social a { display:inline-flex; align-items:center; gap:5px; font-size:12px; color:rgba(255,255,255,0.4); margin-bottom:6px; }
.footer-social a:hover { color:#fff; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding:16px 0; font-size:11px; color:rgba(255,255,255,0.25); flex-wrap:wrap; gap:8px; }
.footer-bottom a { color:rgba(255,255,255,0.35); }
.footer-bottom a:hover { color:rgba(255,255,255,0.7); }
@media(max-width:1024px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; } }
@media(max-width:600px){ .footer-grid{ grid-template-columns:1fr; gap:28px; } }

/* ── PORTAL & ADMIN ──────────────────────────────────────────── */
.admin-wrap { max-width:960px; margin:100px auto 60px; padding:0 24px; }
.card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:28px; margin-bottom:20px; }
.card h2 { font-family:var(--ff-head); font-size:1.4rem; color:var(--text); margin-bottom:16px; }
.badge { display:inline-block; font-size:11px; font-weight:600; padding:3px 10px; border-radius:20px; }
.badge-new { background:#f0f9f0; color:#2d7a2d; border:1px solid rgba(45,122,45,0.2); }
.badge-warm { background:#fff8ed; color:#b85c00; border:1px solid rgba(184,92,0,0.2); }
.badge-hot { background:#fff0f0; color:#c0392b; border:1px solid rgba(192,57,43,0.2); }
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:13px; }
th { text-align:left; font-size:11px; color:var(--text-muted); letter-spacing:1px; text-transform:uppercase; padding:10px 12px; border-bottom:2px solid var(--border); font-weight:600; }
td { padding:12px; border-bottom:1px solid var(--border); color:var(--text); vertical-align:top; }
tr:hover td { background:var(--bg-alt); }

/* ═══════════════════════════════════════════════════════════════
   NUNGWI — Hotel market section + shared hospitality classes
   ═══════════════════════════════════════════════════════════════ */

.hotel-market-section {
  padding:88px 0;
  background:#0a1628;
}
.hotel-market-section .section-label-dark,
.hotel-market-section .section-title-dark {
  color:#fff;
}
.hotel-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:48px;
}
.hotel-card {
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.09);
  border-radius:var(--radius-lg);
  padding:24px;
  transition:var(--trans);
}
.hotel-card:hover {
  border-color:rgba(255,255,255,0.18);
  background:rgba(255,255,255,0.06);
}
.hotel-name {
  font-family:var(--ff-head);
  font-size:1.1rem;
  font-weight:600;
  color:#fff;
  margin-bottom:4px;
}
.hotel-tier {
  font-size:10px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,0.35);
  margin-bottom:14px;
  padding-bottom:12px;
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.hotel-desc {
  font-size:13px;
  color:rgba(255,255,255,0.58);
  line-height:1.75;
}
@media(max-width:900px) { .hotel-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px) { .hotel-grid { grid-template-columns:1fr; } }

/* ── 3-card developments grid variant ───────────────────────── */
.developments-grid.three-col {
  grid-template-columns:repeat(3,1fr);
}
@media(max-width:1024px) { .developments-grid.three-col { grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px)  { .developments-grid.three-col { grid-template-columns:1fr; } }

/* ── CTA inline gold label fix (used in nungwi/paje/stone-town) */
.cta-area-label {
  font-size:11px;
  font-weight:600;
  letter-spacing:2.5px;
  text-transform:uppercase;
  color:var(--text-muted);
  display:block;
  margin-bottom:14px;
}

/* ═══════════════════════════════════════════════════════════════
   FUMBA — Mega projects + road section
   ═══════════════════════════════════════════════════════════════ */

.mega-projects-section {
  padding:88px 0;
  background:#0D1B3E;
}
.mega-projects-section .section-label-dark {
  color:rgba(255,255,255,0.5);
}
.mega-projects-section h2 {
  font-family:var(--ff-head);
  font-size:clamp(2rem,4vw,3.2rem);
  font-weight:400;
  color:#fff;
  line-height:1.15;
  margin-bottom:48px;
}
.mega-projects-section h2 em {
  font-style:italic;
  color:rgba(255,255,255,0.65);
}
.mega-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.mega-card {
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.09);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:var(--trans);
}
.mega-card:hover {
  border-color:rgba(255,255,255,0.18);
  transform:translateY(-2px);
}
.mega-card-img-wrap {
  position:relative;
  height:200px;
  overflow:hidden;
  background:rgba(255,255,255,0.05);
}
.mega-card-img-wrap img {
  width:100%;
  height:100%;
  object-fit:cover;
}
.mega-card-img-overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(0,0,0,0.5) 0%,transparent 60%);
}
.mega-card-img-placeholder {
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:3rem;
  background:rgba(255,255,255,0.04);
}
.mega-card-tag {
  font-size:10px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,0.35);
  padding:20px 24px 6px;
}
.mega-card-name {
  font-family:var(--ff-head);
  font-size:1.4rem;
  font-weight:600;
  color:#fff;
  padding:0 24px 12px;
  line-height:1.2;
}
.mega-card-desc {
  font-size:13px;
  color:rgba(255,255,255,0.58);
  line-height:1.8;
  padding:0 24px 20px;
}
.mega-card-stats {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:0;
  border-top:1px solid rgba(255,255,255,0.07);
  margin:0 24px 24px;
  border-radius:var(--radius);
  overflow:hidden;
}
.mega-stat-item {
  display:flex;
  flex-direction:column;
  padding:12px 16px;
  border-right:1px solid rgba(255,255,255,0.06);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.mega-stat-item:nth-child(even) { border-right:none; }
.mega-stat-item:nth-last-child(-n+2) { border-bottom:none; }
.mega-stat-val {
  font-family:var(--ff-head);
  font-size:1.1rem;
  font-weight:600;
  color:#fff;
  line-height:1.2;
  margin-bottom:2px;
}
.mega-stat-label {
  font-size:10px;
  color:rgba(255,255,255,0.35);
  letter-spacing:1px;
  text-transform:uppercase;
}
@media(max-width:768px) { .mega-grid { grid-template-columns:1fr; } }

/* ── ROAD SECTION ────────────────────────────────────────────── */
.road-section {
  padding:88px 0;
  background:#111210;
}
.road-section .section-label-dark,
.road-section .section-title-dark { color:#fff; }
.road-card {
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.09);
  border-radius:var(--radius-lg);
  padding:36px;
  margin-top:40px;
}
.road-card-label {
  font-size:10px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,0.35);
  margin-bottom:10px;
  display:block;
}
.road-card-title {
  font-family:var(--ff-head);
  font-size:1.5rem;
  font-weight:600;
  color:#fff;
  margin-bottom:16px;
}
.road-card-desc {
  font-size:14px;
  color:rgba(255,255,255,0.58);
  line-height:1.9;
  max-width:800px;
}

/* ═══════════════════════════════════════════════════════════════
   INVESTOR PORTAL — /portal specific classes
   ═══════════════════════════════════════════════════════════════ */

/* ── LISTING CARD (lc-*) ─────────────────────────────────────── */
.portal-listings { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:24px; }
.portal-listing-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; transition:var(--trans); }
.portal-listing-card:hover { transform:translateY(-3px); box-shadow:var(--shadow); }
.lc-body { padding:18px; }
.lc-badge { display:inline-block; font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; padding:3px 10px; border-radius:20px; margin-bottom:10px; background:var(--bg-alt); color:var(--text-muted); border:1px solid var(--border); }
.lc-title { font-family:var(--ff-head); font-size:1.15rem; font-weight:600; color:var(--text); margin-bottom:6px; }
.lc-meta { font-size:12px; color:var(--text-muted); margin-bottom:12px; }
.lc-price { font-family:var(--ff-head); font-size:1.4rem; color:var(--text); font-weight:600; margin-bottom:14px; }
.lc-stats { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:16px; }
.lc-stat { background:var(--bg-alt); border-radius:var(--radius); padding:10px 12px; }
.lc-stat .stat-label { font-size:10px; color:var(--text-muted); text-transform:uppercase; letter-spacing:.8px; margin-bottom:3px; }
.lc-stat .stat-val { font-size:14px; font-weight:600; color:var(--text); }
.lc-countdown { font-size:12px; color:var(--text-muted); padding:8px 0; border-top:1px solid var(--border); margin-top:4px; }
.lc-footer { padding:14px 18px; border-top:1px solid var(--border); display:flex; gap:8px; }
.btn-portal { background:#1a1a18; color:#fff; border:none; padding:9px 16px; border-radius:var(--radius); font-size:13px; font-weight:500; cursor:pointer; transition:var(--trans); font-family:var(--ff-body); flex:1; text-align:center; }
.btn-portal:hover { background:#444; }
.btn-portal-outline { background:transparent; color:var(--text); border:1px solid var(--border); padding:9px 16px; border-radius:var(--radius); font-size:13px; font-weight:500; cursor:pointer; transition:var(--trans); font-family:var(--ff-body); flex:1; text-align:center; }
.btn-portal-outline:hover { border-color:var(--text); }
.btn-interest { background:#0D1B3E; color:#fff; border:none; padding:9px 16px; border-radius:var(--radius); font-size:13px; font-weight:500; cursor:pointer; transition:var(--trans); font-family:var(--ff-body); }
.btn-interest:hover { background:#1a2f5e; }
@media(max-width:900px) { .portal-listings { grid-template-columns:1fr 1fr; } }
@media(max-width:600px) { .portal-listings { grid-template-columns:1fr; } }

/* ── DEAL TIMELINE (dt-*) ────────────────────────────────────── */
.deal-timeline { display:flex; flex-direction:column; gap:0; margin-top:16px; }
.dt-item { display:flex; gap:16px; align-items:flex-start; padding:12px 0; position:relative; }
.dt-item:not(:last-child)::after { content:''; position:absolute; left:11px; top:32px; bottom:0; width:2px; background:var(--border); }
.dt-dot { width:24px; height:24px; border-radius:50%; background:var(--bg-alt); border:2px solid var(--border); flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:10px; position:relative; z-index:1; }
.dt-item.done .dt-dot { background:#1a1a18; border-color:#1a1a18; color:#fff; }
.dt-item.active .dt-dot { background:#0D1B3E; border-color:#0D1B3E; color:#fff; }
.dt-label { font-size:14px; font-weight:500; color:var(--text); margin-bottom:2px; }
.dt-desc { font-size:12px; color:var(--text-muted); line-height:1.5; }

/* ── ACHIEVEMENTS (ach-*) ────────────────────────────────────── */
.achievements-row { display:flex; gap:12px; flex-wrap:wrap; margin-top:16px; }
.ach-badge { display:flex; flex-direction:column; align-items:center; gap:6px; padding:14px 16px; background:var(--bg-alt); border:1px solid var(--border); border-radius:var(--radius-lg); min-width:80px; text-align:center; transition:var(--trans); }
.ach-badge.earned { background:#f0f9f0; border-color:rgba(45,122,45,0.2); }
.ach-badge.locked { opacity:0.45; }
.ach-icon { font-size:1.6rem; }
.ach-label { font-size:11px; color:var(--text-muted); font-weight:500; line-height:1.3; }
.ach-badge.earned .ach-label { color:#2d7a2d; }

/* ── INVESTOR BADGES ─────────────────────────────────────────── */
.badge-investor { background:#e8f0fe; color:#1a56db; border:1px solid rgba(26,86,219,0.2); font-size:11px; font-weight:600; padding:3px 10px; border-radius:20px; display:inline-block; }
.badge-vip { background:#fff8e1; color:#b8860b; border:1px solid rgba(184,134,11,0.2); font-size:11px; font-weight:600; padding:3px 10px; border-radius:20px; display:inline-block; }

/* ── BLOG ITEMS ──────────────────────────────────────────────── */
.blog-item { padding:16px 0; border-bottom:1px solid var(--border); }
.blog-item:last-child { border-bottom:none; }
.blog-item-title { font-size:15px; font-weight:500; color:var(--text); margin-bottom:4px; }
.blog-item-title a { color:var(--text); }
.blog-item-title a:hover { color:var(--text-muted); }
.blog-item-meta { font-size:12px; color:var(--text-muted); }

/* ── NOTIFICATION BADGE ──────────────────────────────────────── */
.unread { font-weight:600; }
.expressed { color:#2d7a2d; font-size:12px; font-weight:600; }

/* ═══════════════════════════════════════════════════════════════
   PORTAL — CSS variable aliases + login form classes
   ═══════════════════════════════════════════════════════════════ */

:root {
  --card-bg:  #ffffff;
  --navy:     #0D1B3E;
  --gold:     #C9A84C;
  --gold-lt:  #e8c96a;
}

/* ── PORTAL LOGIN FORM ───────────────────────────────────────── */
.portal-form { display:flex; flex-direction:column; gap:14px; }
.pf-field { display:flex; flex-direction:column; gap:5px; }
.pf-field label { font-size:11px; color:var(--text-muted); letter-spacing:1px; text-transform:uppercase; font-weight:500; }
.pf-field input,
.pf-field select,
.pf-field textarea { background:var(--input-bg); border:1px solid var(--border); color:var(--text); padding:11px 14px; border-radius:var(--radius); font-size:14px; font-family:var(--ff-body); transition:border-color .2s; width:100%; }
.pf-field input:focus,
.pf-field select:focus { outline:none; border-color:var(--navy); }

/* ── PORTAL SIDEBAR NAV ──────────────────────────────────────── */
.portal-sidebar { position:fixed; top:0; left:0; bottom:0; width:260px; background:var(--navy); z-index:100; overflow-y:auto; padding:0; }
.ps-header { padding:24px 20px; border-bottom:1px solid rgba(255,255,255,0.08); }
.ps-brand { font-family:var(--ff-head); font-size:1.1rem; color:#fff; font-weight:600; }
.ps-sub { font-size:11px; color:rgba(255,255,255,0.4); margin-top:2px; }
.ps-nav { padding:16px 0; }
.ps-nav-item { display:flex; align-items:center; gap:10px; padding:11px 20px; font-size:13px; color:rgba(255,255,255,0.65); cursor:pointer; transition:var(--trans); border:none; background:none; width:100%; text-align:left; font-family:var(--ff-body); }
.ps-nav-item:hover { background:rgba(255,255,255,0.06); color:#fff; }
.ps-nav-item.active { background:rgba(255,255,255,0.1); color:#fff; }
.ps-nav-badge { margin-left:auto; background:var(--gold); color:var(--navy); font-size:10px; font-weight:700; padding:2px 6px; border-radius:10px; }
.ps-nav-divider { height:1px; background:rgba(255,255,255,0.08); margin:8px 16px; }
.portal-main { flex:1; min-height:100vh; }
.sidebar-toggle { display:none; position:fixed; top:16px; left:16px; z-index:200; background:var(--navy); color:#fff; border:none; border-radius:6px; padding:8px 10px; cursor:pointer; font-size:18px; }
@media(max-width:768px) {
  .portal-sidebar { transform:translateX(-100%); transition:transform .3s ease; }
  .portal-sidebar.open { transform:translateX(0); }
  .portal-main { margin-left:0; padding:20px; }
  .sidebar-toggle { display:block; }
}

/* ── PORTAL CONTENT SECTIONS ─────────────────────────────────── */
.portal-section { display:none; }
.portal-section.active { display:block; }
.portal-section-title { font-family:var(--ff-head); font-size:1.5rem; color:var(--text); margin-bottom:4px; font-weight:600; }
.portal-section-sub { font-size:14px; color:var(--text-muted); margin-bottom:24px; }
.portal-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:24px; }
.portal-stat-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px; }
.portal-stat-card.featured { background:var(--navy); border-color:var(--navy); }
.portal-stat-card.featured .psc-label,
.portal-stat-card.featured .psc-sub { color:rgba(255,255,255,0.55); }
.portal-stat-card.featured .psc-val { color:#fff; }
.psc-label { font-size:11px; color:var(--text-muted); text-transform:uppercase; letter-spacing:.8px; margin-bottom:6px; }
.psc-val { font-family:var(--ff-head); font-size:1.6rem; color:var(--text); font-weight:600; line-height:1; margin-bottom:4px; }
.psc-sub { font-size:12px; color:var(--text-muted); }
@media(max-width:768px) { .portal-grid { grid-template-columns:1fr 1fr; } }

/* ── PORTAL MISSING VARIABLES FIX ───────────────────────────── */
:root {
  --card-bg:      #ffffff;
  --navy:         #0D1B3E;
  --gold:         #C9A84C;
  --gold-lt:      #e8c96a;
  --input-border: rgba(0,0,0,0.09);
}

/* ═══════════════════════════════════════════════════════════════
   CPS PROJECT SITES — Hero + Layout classes
   burj, bustani, cheichei, moyoni, pajesquare, soulfumba
   ═══════════════════════════════════════════════════════════════ */

/* ── CPS 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; background-repeat:no-repeat; }
.hero-overlay { position:absolute; inset:0; }
.hero-content { position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:120px 40px 80px; width:100%; }
.hero-badge { display:inline-block; font-size:11px; font-weight:600; letter-spacing:2.5px; text-transform:uppercase; color:rgba(255,255,255,0.6); border:1px solid rgba(255,255,255,0.2); padding:6px 16px; border-radius:2px; margin-bottom:28px; }
.hero-title { font-family:var(--ff-head); font-size:clamp(3rem,7vw,5.5rem); font-weight:400; line-height:1.0; color:#fff; margin-bottom:20px; }
.hero-title em { font-style:italic; color:rgba(255,255,255,0.75); }
.hero-sub { font-size:17px; color:rgba(255,255,255,0.7); max-width:580px; line-height:1.8; margin-bottom:40px; }
.hero-stats { display:flex; gap:40px; margin-bottom:40px; flex-wrap:wrap; }
.hero-stat { display:flex; flex-direction:column; }
.stat-num { font-family:var(--ff-head); font-size:1.6rem; font-weight:600; color:#fff; line-height:1; }
.stat-lbl { font-size:11px; color:rgba(255,255,255,0.5); letter-spacing:1px; text-transform:uppercase; margin-top:4px; }
.hero-ctas { display:flex; gap:14px; flex-wrap:wrap; }
.hero-scroll { position:absolute; bottom:32px; left:50%; transform:translateX(-50%); color:rgba(255,255,255,0.4); font-size:20px; text-decoration:none; transition:var(--trans); }
.hero-scroll:hover { color:rgba(255,255,255,0.8); }

/* ── CPS NAV ─────────────────────────────────────────────────── */
.nav-back { font-size:12px; color:rgba(255,255,255,0.6); white-space:nowrap; text-decoration:none; transition:var(--trans); }
.nav-back:hover { color:#fff; }
.nav.scrolled .nav-back { color:var(--text-muted); }

/* ── CPS SECTIONS ────────────────────────────────────────────── */
.overview-section { padding:88px 0; background:var(--bg); }
.overview-section .container { max-width:1200px; margin:0 auto; padding:0 40px; }
.units-section { padding:88px 0; background:var(--bg-alt); }
.units-section .container { max-width:1200px; margin:0 auto; padding:0 40px; }
.returns-section { padding:88px 0; background:var(--bg); }
.amenities-section { padding:88px 0; background:var(--bg-alt); }
.faq-section { padding:88px 0; background:var(--bg); }
.enquiry-section { padding:88px 0; background:#0D1B3E; }
.enquiry-section * { color:#fff; }

/* ── CPS BUTTONS ─────────────────────────────────────────────── */
.btn-primary { background:#1a1a18; color:#fff; padding:14px 32px; border-radius:4px; font-weight:600; font-size:14px; transition:var(--trans); display:inline-block; border:none; cursor:pointer; font-family:var(--ff-body); text-decoration:none; }
.btn-primary:hover { background:#444; color:#fff; }
.btn-outline { background:transparent; color:#fff; padding:13px 30px; border-radius:4px; font-size:14px; border:1.5px solid rgba(255,255,255,0.5); transition:var(--trans); display:inline-block; text-decoration:none; }
.btn-outline:hover { border-color:#fff; background:rgba(255,255,255,0.08); color:#fff; }

/* ── CPS UNIT CARDS ──────────────────────────────────────────── */
.units-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.unit-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; transition:var(--trans); }
.unit-card:hover { transform:translateY(-3px); box-shadow:var(--shadow); }
.unit-img { height:200px; overflow:hidden; }
.unit-body { padding:24px; }
.unit-type { font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); margin-bottom:8px; }
.unit-name { font-family:var(--ff-head); font-size:1.4rem; color:var(--text); margin-bottom:6px; font-weight:600; }
.unit-price { font-size:1.1rem; color:var(--text-sub); margin-bottom:14px; font-weight:500; }
.unit-features { list-style:none; margin-bottom:20px; }
.unit-features li { font-size:13px; color:var(--text-muted); padding:4px 0; }
.unit-cta { display:block; text-align:center; border:1px solid var(--text); color:var(--text); padding:10px; border-radius:4px; font-size:13px; font-weight:600; transition:var(--trans); text-decoration:none; }
.unit-cta:hover { background:var(--text); color:#fff; }
@media(max-width:900px) { .units-grid { grid-template-columns:1fr; } }

/* ── CPS ENQUIRY FORM ────────────────────────────────────────── */
.eq-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:rgba(255,255,255,0.5); letter-spacing:1px; text-transform:uppercase; }
.eq-field input,.eq-field select,.eq-field textarea { background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.15); color:#fff; padding:11px 14px; border-radius:var(--radius); font-size:14px; font-family:var(--ff-body); }
.eq-field input:focus,.eq-field select:focus,.eq-field textarea:focus { outline:none; border-color:rgba(255,255,255,0.4); }
.eq-field textarea { resize:vertical; min-height:80px; }
.eq-submit { background:#fff; color:#1a1a18; border:none; padding:14px; border-radius:4px; font-size:14px; font-weight:600; cursor:pointer; transition:var(--trans); width:100%; font-family:var(--ff-body); }
.eq-submit:hover { background:rgba(255,255,255,0.9); }
.eq-contact { background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12); border-radius:var(--radius-lg); padding:28px; }
.eq-contact-item { padding:12px 0; border-bottom:1px solid rgba(255,255,255,0.08); }
.eq-contact-item:last-child { border-bottom:none; }
.eq-contact-label { font-size:11px; color:rgba(255,255,255,0.4); letter-spacing:1px; text-transform:uppercase; margin-bottom:3px; }
.eq-contact-item a,.eq-contact-item span { font-size:14px; color:rgba(255,255,255,0.8); }
@media(max-width:900px) { .eq-grid { grid-template-columns:1fr; } .eq-row { grid-template-columns:1fr; } }

/* ── CPS RETURNS / ROI ───────────────────────────────────────── */
.returns-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:40px; }
.return-card { background:var(--bg-alt); border:1px solid var(--border); border-radius:var(--radius-lg); padding:24px; text-align:center; }
.return-num { font-family:var(--ff-head); font-size:2rem; color:var(--text); font-weight:600; display:block; margin-bottom:6px; }
.return-lbl { font-size:12px; color:var(--text-muted); }
@media(max-width:768px) { .returns-grid { grid-template-columns:repeat(2,1fr); } }

/* ── CPS NAV SCROLLED STATE ──────────────────────────────────── */
.nav { background:transparent; }
.nav.scrolled { background:rgba(255,255,255,0.97) !important; }
.nav-inner { max-width:1200px; margin:0 auto; padding:0 40px; display:flex; align-items:center; height:68px; gap:20px; }

/* ── GLOBAL MOBILE FIXES ─────────────────────────────────────── */
@media(max-width:768px){
  .hero-container{grid-template-columns:1fr!important;padding:100px 20px 60px!important;}
  .hero-title{font-size:clamp(2.2rem,8vw,3.5rem)!important;}
  .hero-actions{flex-direction:column!important;}
  .footer-grid{grid-template-columns:1fr!important;gap:24px!important;}
  .footer-bottom{flex-direction:column!important;text-align:center!important;gap:6px!important;}
  .areas-grid{grid-template-columns:1fr 1fr!important;}
  .nav-links{display:none!important;}
  .nav-burger,.nav-hamburger{display:flex!important;}
  .hero-trust{gap:8px!important;}
  .trust-divider{display:none!important;}
  .container,.section-container{padding:0 16px!important;}
  .btn{padding:11px 20px!important;font-size:13px!important;}
  .section,.section-alt,.section-dark{padding:48px 0!important;}
}
@media(max-width:480px){
  .areas-grid{grid-template-columns:1fr!important;}
  .hero-title{font-size:2rem!important;}
  .footer-grid{gap:20px!important;}
}
