/* ReShoot Creative — style.css */

/* ── RESET & ROOT ─────────────────────────────── */
:root {
  --cream: #E8E5E0;
  --ivory: #EDEAE4;
  --celeste: #8FA8B0;
  --dark: #525048;
  --mid: #7A7570;
  --stone: #A09890;
  --divider: #D4CEC7;
  --pink: #EDEAE4;
  --terra: #B8704A;
}
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'DM Sans', -apple-system, sans-serif;
  background: var(--cream);
  color: var(--dark);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

/* ── NAV ─────────────────────────────────────── */
nav {
  position: fixed; top: 0; width: 100%;
  background: var(--cream);
  border-bottom: 1px solid var(--divider);
  z-index: 1000;
  transition: box-shadow .3s;
}
.nav-inner {
  max-width: 1280px; margin: 0 auto; padding: 0 48px;
  display: flex; justify-content: space-between; align-items: center;
  height: 72px;
}
.logo {
  font-size: 14px; font-weight: 700; color: var(--dark);
  text-decoration: none; letter-spacing: 8px; text-transform: uppercase;
}
.logo strong { font-weight: 700; }
.logo span { font-weight: 300; }
.nav-links { display: flex; list-style: none; gap: 32px; align-items: center; }
.nav-links a {
  text-decoration: none; color: var(--mid);
  font-size: 11px; letter-spacing: 3px; text-transform: uppercase;
  font-weight: 400;
  transition: color .2s;
}
.nav-links a:hover, .nav-links a.active { color: var(--dark); }
.nav-cta {
  background: var(--terra) !important; color: var(--ivory) !important;
  padding: 10px 20px !important; font-size: 9px !important;
  letter-spacing: 4px !important; border-radius: 0 !important;
}
.nav-cta:hover { background: var(--celeste) !important; color: var(--ivory) !important; }
.hamburger {
  display: none; flex-direction: column; gap: 5px;
  cursor: pointer; background: none; border: none; padding: 8px;
}
.hamburger span { width: 22px; height: 1px; background: var(--dark); transition: all .3s; }
.hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(4px, 5px); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(4px, -5px); }

/* ── SHARED UTILS ────────────────────────────── */
.container { max-width: 1280px; margin: 0 auto; padding: 0 48px; }
.section-label {
  font-size: 11px; letter-spacing: 5px; text-transform: uppercase;
  color: var(--mid); margin-bottom: 20px;
}
.fade-up { opacity: 0; transform: translateY(20px); transition: opacity .6s ease, transform .6s ease; }
.fade-up.visible { opacity: 1; transform: translateY(0); }

.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 13px 32px; text-decoration: none;
  font-family: 'DM Sans', sans-serif; font-size: 10px;
  letter-spacing: 4px; text-transform: uppercase;
  cursor: pointer; border: none; transition: all .2s;
}
.btn-dark { background: var(--dark); color: var(--ivory); }
.btn-accent { background: var(--terra); color: var(--ivory); }
.btn-dark:hover { background: var(--terra); }
.btn-accent:hover { background: var(--dark); }
.btn-terra { background: var(--terra); color: var(--ivory); }
.btn-terra:hover { background: var(--dark); }
.btn-light { background: var(--ivory); color: var(--dark); }
.btn-light:hover { background: var(--cream); }
.btn-outline { background: transparent; color: var(--dark); border: 1px solid var(--divider); }
.btn-outline:hover { border-color: var(--dark); }

/* ── FOOTER ──────────────────────────────────── */
footer { background: var(--dark); color: var(--ivory); padding: 72px 0 32px; }
.footer-grid {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 48px; margin-bottom: 56px;
}
.footer-brand p { font-size: 14px; color: var(--mid); line-height: 1.8; margin-top: 16px; max-width: 260px; }
.footer-col h4 { font-size: 11px; letter-spacing: 4px; text-transform: uppercase; color: var(--mid); margin-bottom: 20px; }
.footer-col a { display: block; color: rgba(240,236,230,.6); text-decoration: none; font-size: 14px; font-weight: 300; line-height: 2.4; transition: color .2s; }
.footer-col a:hover { color: var(--ivory); }
.footer-bottom {
  padding-top: 24px; border-top: 1px solid rgba(240,236,230,.08);
  display: flex; justify-content: space-between; align-items: center;
  font-size: 14px; color: var(--mid);
}

/* ── PAGE HERO (shared) ───────────────────────── */
.page-hero { padding: 140px 0 72px; border-bottom: 1px solid var(--divider); }
.page-hero h1 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(44px, 5vw, 80px); font-weight: 300;
  color: var(--dark); line-height: 1.0; margin-bottom: 20px;
}
.page-hero h1 em { font-style: italic; }
.page-hero p { font-size: 14px; font-weight: 300; color: var(--mid); max-width: 500px; line-height: 1.8; }

/* ══════════════════════════════════════════════
   INDEX
══════════════════════════════════════════════ */
.welcome-split, .split-welcome { display: grid; grid-template-columns: 1fr 1fr; min-height: calc(100vh - 64px); margin-top: 64px; }
.panel { padding: 80px 56px; display: flex; flex-direction: column; justify-content: space-between; position: relative; overflow: hidden; border-bottom: 1px solid var(--divider); cursor: pointer; transition: background .3s; text-decoration: none; color: inherit; }
.panel-agents { background: var(--cream); border-right: 1px solid var(--divider); }
.panel-properties { background: var(--pink); }
.panel-tag { font-size: 11px; letter-spacing: 5px; text-transform: uppercase; color: var(--mid); margin-bottom: 24px; transition: color .3s; display: block; }
.panel-sub { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.8; max-width: 380px; margin-bottom: 32px; transition: color .3s; }
.panel-features { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 40px; }
.panel-feat { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--mid); border: 1px solid var(--divider); padding: 6px 14px; transition: all .3s; }
.panel:hover .panel-tag, .panel:hover .panel-sub { color: rgba(237,234,228,.35); }
.panel:hover .panel-feat { border-color: rgba(237,234,228,.15); color: rgba(237,234,228,.4); }
.panel:hover { background: var(--dark); }
.panel-num { font-size: 11px; letter-spacing: 5px; text-transform: uppercase; color: var(--mid); margin-bottom: 32px; transition: color .3s; }
.panel:hover .panel-num { color: rgba(240,236,230,.3); }
.panel-h { font-family: 'Cormorant Garamond', serif; font-size: clamp(36px, 4vw, 64px); font-weight: 300; color: var(--dark); line-height: 1.0; margin-bottom: 28px; transition: color .3s; }
.panel:hover .panel-h { color: var(--ivory); }
.panel-h em { font-style: italic; }
.panel-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 40px; }
.panel-tag { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--mid); border: 1px solid var(--divider); padding: 6px 12px; transition: all .3s; }
.panel:hover .panel-tag { border-color: rgba(240,236,230,.15); color: rgba(240,236,230,.4); }
.panel-cta { display: inline-flex; align-items: center; gap: 12px; font-size: 11px; letter-spacing: 4px; text-transform: uppercase; color: var(--mid); transition: color .3s; margin-top: auto; }
.panel:hover .panel-cta { color: rgba(240,236,230,.5); }
.panel-bar { position: absolute; bottom: 0; left: 0; width: 100%; height: 3px; background: var(--terra); transform: scaleX(0); transform-origin: left; transition: transform .4s; }
.panel:hover .panel-bar { transform: scaleX(1); }

/* Slider section */
.slider-section { padding: 88px 0; border-bottom: 1px solid var(--divider); background: var(--ivory); }
.slider-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 48px; flex-wrap: wrap; gap: 24px; }
.slider-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(36px, 4vw, 64px); font-weight: 300; color: var(--dark); line-height: 1.0; }
.slider-title em { font-style: italic; }
.slider-nav { display: flex; align-items: center; gap: 20px; }
.slider-nav button { background: none; border: 1px solid var(--divider); width: 40px; height: 40px; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--mid); font-size: 16px; transition: all .2s; }
.slider-nav button:hover { background: var(--dark); border-color: var(--dark); color: var(--ivory); }
.slider-counter { font-size: 12px; letter-spacing: 3px; color: var(--mid); }
.before-after-container { position: relative; width: 100%; aspect-ratio: 16/9; overflow: hidden; background: var(--celeste); cursor: col-resize; user-select: none; }
.ba-img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }
.ba-before { clip-path: inset(0 50% 0 0); }
.ba-after { clip-path: inset(0 0 0 0); }
.ba-handle { position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 3px; height: 100%; background: white; cursor: col-resize; z-index: 10; }
.ba-handle::before { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 40px; height: 40px; background: white; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 2px 12px rgba(0,0,0,.15); }
.ba-label { position: absolute; bottom: 20px; font-size: 12px; letter-spacing: 3px; text-transform: uppercase; background: rgba(240,236,230,.9); padding: 6px 12px; color: var(--dark); z-index: 5; }
.ba-label-after { left: 20px; }
.ba-label-before { right: 20px; }

/* Stats bar */
.stats-section { border-bottom: 1px solid var(--divider); }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat-card { padding: 40px 32px; background: var(--celeste); border-right: 1px solid rgba(240,236,230,.2); }
.stat-card:last-child { border-right: none; }
.stat-num { font-family: 'Cormorant Garamond', serif; font-size: 52px; font-weight: 300; color: var(--dark); line-height: 1; margin-bottom: 8px; }
.stat-label { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--dark); opacity: .5; }

/* Value cards */
.value-section { padding: 88px 0; border-bottom: 1px solid var(--divider); }
.value-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; margin-top: 40px; }
.value-card { background: var(--celeste); padding: 44px 36px; }
.value-card h3 { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 300; color: var(--dark); margin-bottom: 12px; }
.value-card p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.8; }

/* Featured work */
.featured-section { padding: 88px 0; background: var(--dark); border-bottom: 1px solid rgba(240,236,230,.08); }
.featured-section .section-label { color: var(--mid); }
.featured-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 48px; }
.featured-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.5vw, 52px); font-weight: 300; color: var(--ivory); line-height: 1.05; }
.featured-title em { font-style: italic; }
.featured-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.featured-card { background: rgba(240,236,230,.04); border: 1px solid rgba(240,236,230,.08); overflow: hidden; text-decoration: none; display: block; }
.featured-img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; transition: transform .4s; background: var(--celeste); }
.featured-card:hover .featured-img { transform: scale(1.03); }
.featured-info { padding: 24px; }
.featured-category { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--mid); margin-bottom: 8px; }
.featured-name { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 300; color: var(--ivory); }

/* How it works preview */
.hiw-section { padding: 88px 0; border-bottom: 1px solid var(--divider); }
.hiw-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px; margin-top: 48px; }
.hiw-step { background: var(--ivory); padding: 36px 28px; }
.hiw-num { font-family: 'Cormorant Garamond', serif; font-size: 56px; font-weight: 300; color: var(--divider); line-height: 1; margin-bottom: 12px; }
.hiw-title { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 300; color: var(--dark); margin-bottom: 8px; }
.hiw-text { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.7; }

/* Nina credentials */
.nina-section { padding: 88px 0; background: var(--ivory); border-bottom: 1px solid var(--divider); }
.nina-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.nina-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.5vw, 52px); font-weight: 300; color: var(--dark); line-height: 1.05; margin-bottom: 24px; }
.nina-title em { font-style: italic; }
.nina-text { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.8; margin-bottom: 20px; }
.nina-creds { display: flex; flex-direction: column; gap: 4px; }
.nina-cred { background: var(--celeste); padding: 20px 24px; display: flex; align-items: center; gap: 20px; }
.nina-cred-num { font-family: 'Cormorant Garamond', serif; font-size: 40px; font-weight: 300; color: var(--dark); line-height: 1; flex-shrink: 0; min-width: 64px; }
.nina-cred-text { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.5; }

/* CTA dark */
.cta-section { padding: 88px 0; }
.cta-box { text-align: center; padding: 0 60px; }
.cta-box p { font-size: 14px; font-weight: 300; color: var(--mid); max-width: 440px; margin: 0 auto; line-height: 1.8; }
.cta-dark { background: var(--dark); padding: 88px 60px; text-align: center; }
.cta-dark h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(36px, 4vw, 64px); font-weight: 300; color: var(--ivory); line-height: 1.0; margin-bottom: 16px; }
.cta-dark h2 em { font-style: italic; }
.cta-dark p { font-size: 14px; font-weight: 300; color: var(--mid); max-width: 440px; margin: 0 auto 40px; line-height: 1.8; }

/* Modal */
.modal-overlay { position: fixed; inset: 0; background: rgba(44,40,37,.8); z-index: 2000; display: flex; align-items: center; justify-content: center; padding: 24px; opacity: 0; pointer-events: none; transition: opacity .3s; }
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal { background: var(--ivory); width: 100%; max-width: 540px; padding: 48px; position: relative; max-height: 90vh; overflow-y: auto; }
.modal-close { position: absolute; top: 16px; right: 20px; background: none; border: none; font-size: 24px; cursor: pointer; color: var(--mid); line-height: 1; }
.modal h3 { font-family: 'Cormorant Garamond', serif; font-size: 36px; font-weight: 300; color: var(--dark); margin-bottom: 8px; }
.modal-sub { font-size: 14px; font-weight: 300; color: var(--mid); margin-bottom: 32px; line-height: 1.6; }
.form-group { margin-bottom: 20px; }
.form-group label { display: block; font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--mid); margin-bottom: 8px; }
.form-group input, .form-group select, .form-group textarea { width: 100%; padding: 12px 16px; background: var(--cream); border: 1px solid var(--divider); font-family: 'DM Sans', sans-serif; font-size: 14px; color: var(--dark); outline: none; transition: border-color .2s; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--terra); }
.form-group textarea { min-height: 80px; resize: vertical; }
.form-btn { width: 100%; padding: 14px; background: var(--dark); color: var(--ivory); border: none; font-family: 'DM Sans', sans-serif; font-size: 11px; letter-spacing: 4px; text-transform: uppercase; cursor: pointer; transition: background .2s; }
.form-btn:hover { background: var(--terra); }

/* ══════════════════════════════════════════════
   PORTFOLIO
══════════════════════════════════════════════ */
.portfolio-hero { padding: 140px 0 56px; border-bottom: 1px solid var(--divider); }
.portfolio-hero h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(44px, 5vw, 80px); font-weight: 300; color: var(--dark); line-height: 1.0; margin-bottom: 16px; }
.portfolio-hero h1 em { font-style: italic; }
.portfolio-hero p { font-size: 14px; font-weight: 300; color: var(--mid); max-width: 500px; line-height: 1.8; }

.filter-bar { padding: 32px 0; border-bottom: 1px solid var(--divider); display: flex; gap: 4px; }
/* filter-btn styles defined in portfolio section below */

.portfolio-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; padding: 24px 0; }
.portfolio-card { background: var(--ivory); overflow: hidden; cursor: pointer; border: 1px solid var(--divider); transition: box-shadow .3s, transform .2s; }
.portfolio-card:hover { box-shadow: 0 8px 32px rgba(28,25,23,.08); transform: translateY(-2px); }
.ba-slider { position: relative; width: 100%; padding-top: 56.25%; overflow: hidden; background: var(--dark); }
.ba-slider img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }
.ba-badge {
  position:absolute; top:16px; left:16px;
  font-size:12px; letter-spacing:3px; text-transform:uppercase;
  color:rgba(255,255,255,.8); background:rgba(0,0,0,.5);
  padding:6px 14px; font-family:'DM Sans',sans-serif; z-index:2;
}
.ba-slider .img-after { clip-path: inset(0 15% 0 0); }
.ba-slider .img-before { clip-path: inset(0 0 0 85%); }
.ba-slider .slider-handle { position: absolute; top: 0; left: 85%; transform: translateX(-50%); width: 3px; height: 100%; background: white; z-index: 10; pointer-events: none; }
.ba-slider .slider-handle::before { content: '⟷'; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 36px; height: 36px; background: white; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; color: var(--dark); box-shadow: 0 2px 10px rgba(0,0,0,.12); line-height: 36px; text-align: center; }
.portfolio-info { padding: 20px 24px; }
.portfolio-info h3 { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 300; color: var(--dark); margin-bottom: 6px; }
.portfolio-info p { font-size: 13px; font-weight: 300; color: var(--mid); line-height: 1.6; margin-bottom: 10px; }
.portfolio-tags { display: flex; gap: 8px; flex-wrap: wrap; }
.portfolio-tag { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--mid); border: 1px solid var(--divider); padding: 3px 8px; }

/* Lightbox */
.lightbox { display: none; position: fixed; inset: 0; background: rgba(44,40,37,.95); z-index: 3000; flex-direction: column; align-items: center; justify-content: center; }
.lightbox.open { display: flex; }
.lb-container { position: relative; width: 90vw; max-width: 1100px; aspect-ratio: 16/9; }
.lb-img { width: 100%; height: 100%; object-fit: contain; display: block; }
.lb-close { position: fixed; top: 24px; right: 32px; background: none; border: none; color: var(--ivory); font-size: 32px; cursor: pointer; opacity: .6; transition: opacity .2s; }
.lb-close:hover { opacity: 1; }
.lb-prev, .lb-next { position: fixed; top: 50%; transform: translateY(-50%); background: rgba(240,236,230,.1); border: none; color: var(--ivory); font-size: 24px; padding: 20px 16px; cursor: pointer; transition: background .2s; }
.lb-prev { left: 16px; } .lb-next { right: 16px; }
.lb-prev:hover, .lb-next:hover { background: rgba(240,236,230,.2); }
.lb-meta { margin-top: 20px; text-align: center; }
.lb-title { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 300; color: var(--ivory); margin-bottom: 6px; }
.lb-counter { font-size: 12px; letter-spacing: 3px; color: var(--mid); }
.lb-before-pip { position: absolute; bottom: 12px; left: 12px; width: 100px; height: 72px; overflow: hidden; border: 2px solid white; cursor: pointer; transition: all .3s; }
.lb-before-pip:hover { width: 200px; height: 144px; }
.lb-before-pip img { width: 100%; height: 100%; object-fit: cover; }
.lb-dots { display: flex; gap: 8px; justify-content: center; margin-top: 12px; }
.lb-dot { width: 6px; height: 6px; background: rgba(240,236,230,.3); border: none; border-radius: 50%; cursor: pointer; transition: background .2s; }
.lb-dot.active { background: var(--ivory); }

/* ══════════════════════════════════════════════
   CONTACT
══════════════════════════════════════════════ */
.contact-hero { padding: 140px 0 72px; border-bottom: 1px solid var(--divider); }
.contact-hero h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(44px, 5vw, 80px); font-weight: 300; color: var(--dark); line-height: 1.0; margin-bottom: 16px; }
.contact-hero h1 em { font-style: italic; }
.contact-hero .hero-note { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--mid); }
.contact-split { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.contact-left { padding: 64px 56px; background: var(--ivory); }
.contact-right { padding: 64px 56px; background: var(--dark); }
.contact-channels { display: flex; flex-direction: column; gap: 12px; }
.channel-card { background: rgba(184,112,74,.08); padding: 28px 24px; display: flex; align-items: center; gap: 20px; text-decoration: none; color: var(--dark); transition: background .2s; border:1px solid rgba(184,112,74,.15); }
.channel-card:hover { background: var(--dark); color: var(--ivory); }
.channel-icon { width: 40px; height: 40px; background: var(--ivory); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 18px; }
.channel-info h4 { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 4px; }
.channel-info span { font-size: 14px; font-weight: 300; font-family: 'Cormorant Garamond', serif; }
.contact-note { margin-top: 40px; padding: 24px; border: 1px solid var(--divider); }
.contact-note p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.7; font-style: italic; }
.contact-right h2 { font-family: 'Cormorant Garamond', serif; font-size: 36px; font-weight: 300; color: var(--ivory); margin-bottom: 8px; }
.contact-right .form-subtitle { font-size: 14px; font-weight: 300; color: var(--mid); margin-bottom: 36px; line-height: 1.6; }
.contact-right .form-group label { color: rgba(240,236,230,.4); }
.contact-right .form-group input, .contact-right .form-group select, .contact-right .form-group textarea { background: rgba(240,236,230,.05); border-color: rgba(240,236,230,.1); color: var(--ivory); }
.contact-right .form-group input:focus, .contact-right .form-group select:focus, .contact-right .form-group textarea:focus { border-color: var(--terra); }
.contact-right .form-group select option { background: var(--dark); }
.contact-right .form-btn { background: var(--terra); }
.contact-right .form-btn:hover { background: var(--ivory); color: var(--dark); }
.upload-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
.upload-card { padding: 32px; display: flex; align-items: center; gap: 20px; text-decoration: none; color: var(--dark); transition: background .2s; }
.upload-card.dark-card { background: var(--dark); color: var(--ivory); }
.upload-card.cream-card { background: rgba(184,112,74,.08); border:1px solid rgba(184,112,74,.15); }
.upload-card:hover { opacity: .85; }
.upload-icon { font-size: 32px; flex-shrink: 0; }
.upload-info h4 { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 4px; }
.upload-info p { font-size: 14px; font-weight: 300; opacity: .7; line-height: 1.5; }

/* ══════════════════════════════════════════════
   HOW IT WORKS
══════════════════════════════════════════════ */
.process-section { padding: 0; }
.process-step { display: grid; grid-template-columns: 1fr 1fr; min-height: 440px; border-bottom: 1px solid var(--divider); }
.process-step:nth-child(even) .step-visual { order: -1; }
.step-content { padding: 72px 64px; display: flex; flex-direction: column; justify-content: center; }
.process-step:nth-child(even) .step-content { background: var(--ivory); }
.step-number { font-family: 'Cormorant Garamond', serif; font-size: 80px; font-weight: 300; color: var(--divider); line-height: 1; margin-bottom: 20px; }
.step-content h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(28px, 3vw, 44px); font-weight: 300; color: var(--dark); margin-bottom: 16px; line-height: 1.1; }
.step-content h2 em { font-style: italic; }
.step-content > p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.9; margin-bottom: 28px; max-width: 440px; }
.step-features { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.step-features li { display: flex; align-items: center; gap: 12px; font-size: 14px; font-weight: 300; color: var(--mid); }
.step-features li::before { content: '—'; color: var(--divider); flex-shrink: 0; }
.step-visual { position: relative; overflow: hidden; background: var(--celeste); }
.step-visual img { width: 100%; height: 100%; object-fit: cover; display: block; }
.img-placeholder { width: 100%; height: 100%; min-height: 360px; display: flex; flex-direction: column; align-items: center; justify-content: center; background: var(--celeste); color: var(--mid); font-size: 14px; text-align: center; gap: 8px; }

.timeline-section { padding: 88px 0; background: var(--dark); }
.timeline-section .section-label { color: var(--mid); }
.timeline-h { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.5vw, 52px); font-weight: 300; color: var(--ivory); margin-bottom: 12px; line-height: 1.05; }
.timeline-h em { font-style: italic; }
.timeline-sub { font-size: 14px; font-weight: 300; color: var(--mid); margin-bottom: 56px; }
.timeline-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.timeline-card { padding: 40px 36px; background: rgba(240,236,230,.04); border: 1px solid rgba(240,236,230,.08); }
.timeline-time { font-size: 11px; letter-spacing: 4px; text-transform: uppercase; color: var(--terra); margin-bottom: 16px; }
.timeline-card h3 { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 300; color: var(--ivory); margin-bottom: 10px; }
.timeline-card p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.7; }

.guarantee-section { padding: 88px 0; border-bottom: 1px solid var(--divider); }
.guarantee-box { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; background: var(--celeste); }
.guarantee-left { padding: 64px; }
.guarantee-left h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.5vw, 52px); font-weight: 300; color: var(--dark); margin-bottom: 16px; line-height: 1.05; }
.guarantee-left h2 em { font-style: italic; }
.guarantee-left p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.8; margin-bottom: 28px; max-width: 400px; }
.guarantee-right { padding: 64px; background: var(--dark); display: flex; flex-direction: column; justify-content: center; gap: 24px; }
.guarantee-item { display: flex; align-items: flex-start; gap: 16px; }
.guarantee-check { width: 32px; height: 32px; background: var(--terra); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--ivory); font-size: 14px; }
.guarantee-text h4 { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--ivory); margin-bottom: 4px; }
.guarantee-text p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.6; }

/* ══════════════════════════════════════════════
   PRICING
══════════════════════════════════════════════ */
.hero-badge { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--terra); border: 1px solid rgba(184,112,74,.3); padding: 8px 16px; }
.pricing-section { padding: 88px 0; border-bottom: 1px solid var(--divider); }
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.pricing-card { background: var(--ivory); padding: 48px 40px; display: flex; flex-direction: column; justify-content: space-between; min-height: 560px; }
.pricing-card.featured { background: var(--dark); }
.plan-tier { font-size: 11px; letter-spacing: 4px; text-transform: uppercase; color: var(--mid); margin-bottom: 16px; }
.pricing-card.featured .plan-tier { color: rgba(240,236,230,.4); }
.plan-name { font-family: 'Cormorant Garamond', serif; font-size: 36px; font-weight: 300; color: var(--dark); margin-bottom: 12px; }
.pricing-card.featured .plan-name { color: var(--ivory); }
.plan-price { font-family: 'Cormorant Garamond', serif; font-size: 64px; font-weight: 300; color: var(--dark); line-height: 1; margin-bottom: 4px; }
.pricing-card.featured .plan-price { color: var(--ivory); }
.plan-price-detail { font-size: 14px; font-weight: 300; color: var(--mid); margin-bottom: 32px; }
.plan-divider { height: 1px; background: var(--divider); margin-bottom: 32px; }
.pricing-card.featured .plan-divider { background: rgba(240,236,230,.1); }
.plan-features { list-style: none; display: flex; flex-direction: column; gap: 12px; margin-bottom: 40px; }
.plan-features li { font-size: 14px; font-weight: 300; color: var(--mid); display: flex; align-items: flex-start; gap: 12px; line-height: 1.5; }
.pricing-card.featured .plan-features li { color: rgba(240,236,230,.6); }
.plan-features li::before { content: '—'; color: var(--divider); flex-shrink: 0; }
.pricing-card.featured .plan-features li::before { color: rgba(240,236,230,.2); }
.pricing-btn { display: block; width: 100%; padding: 14px; background: var(--dark); color: var(--ivory); border: none; font-family: 'DM Sans', sans-serif; font-size: 11px; letter-spacing: 4px; text-transform: uppercase; cursor: pointer; transition: background .2s; }
.pricing-btn:hover { background: var(--terra); }
.pricing-card.featured .pricing-btn { background: var(--terra); }
.pricing-card.featured .pricing-btn:hover { background: var(--ivory); color: var(--dark); }

.included-section { padding: 88px 0; background: var(--ivory); border-bottom: 1px solid var(--divider); }
.included-h { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.5vw, 52px); font-weight: 300; color: var(--dark); line-height: 1.05; margin-bottom: 56px; text-align: center; }
.included-h em { font-style: italic; }
.included-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.included-item { background: var(--celeste); padding: 40px 36px; }
.included-item h3 { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 300; color: var(--dark); margin-bottom: 10px; }
.included-item p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.7; }

.addons-section { padding: 88px 0; border-bottom: 1px solid var(--divider); }
.addons-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 4px; margin-top: 48px; }
.addon-card { padding: 40px; background: var(--ivory); display: flex; justify-content: space-between; align-items: center; gap: 32px; }
.addon-info h3 { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 300; color: var(--dark); margin-bottom: 6px; }
.addon-info p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.7; max-width: 380px; }
.addon-price { text-align: right; flex-shrink: 0; }
.addon-price-num { font-family: 'Cormorant Garamond', serif; font-size: 48px; font-weight: 300; color: var(--dark); line-height: 1; }
.addon-price-label { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--mid); }
.sample-section { padding: 88px 0; }
.sample-box { background: var(--dark); padding: 88px 60px; text-align: center; }
.sample-box h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(36px, 4vw, 60px); font-weight: 300; color: var(--ivory); margin-bottom: 16px; line-height: 1.05; }
.sample-box h2 em { font-style: italic; }
.sample-box p { font-size: 14px; font-weight: 300; color: var(--mid); max-width: 440px; margin: 0 auto 40px; line-height: 1.8; }

/* ══════════════════════════════════════════════
   TEAM
══════════════════════════════════════════════ */
.office-section { padding: 0; border-bottom: 1px solid var(--divider); }
.office-photo { width: 100%; height: 480px; overflow: hidden; background: var(--celeste); }
.office-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.office-placeholder { width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--mid); font-size: 14px; gap: 6px; }
.team-section { padding: 88px 0; border-bottom: 1px solid var(--divider); }
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.team-card { background: var(--ivory); overflow: hidden; }
.team-photo { width: 100%; aspect-ratio: 3/4; overflow: hidden; background: var(--celeste); }
.team-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 20%; transition: transform .4s; }
.team-card:hover .team-photo img { transform: scale(1.03); }
.team-info { padding: 32px; }
.team-name { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 300; color: var(--dark); margin-bottom: 4px; }
.team-role { font-size: 11px; letter-spacing: 4px; text-transform: uppercase; color: var(--terra); margin-bottom: 16px; }
.team-bio { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.8; }
.values-section { padding: 88px 0; background: var(--dark); }
.values-section .section-label { color: var(--mid); }
.values-h { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.5vw, 52px); font-weight: 300; color: var(--ivory); margin-bottom: 56px; line-height: 1.05; }
.values-h em { font-style: italic; }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.value-card-dark { background: rgba(240,236,230,.04); border: 1px solid rgba(240,236,230,.08); padding: 40px 36px; }
.value-card-dark h3 { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 300; color: var(--ivory); margin-bottom: 12px; }
.value-card-dark p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.7; }
.cta-section-light { padding: 88px 0; text-align: center; }
.cta-box-light { background: var(--dark); padding: 88px 60px; }
.cta-box-light h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(36px, 4vw, 60px); font-weight: 300; color: var(--ivory); margin-bottom: 16px; line-height: 1.05; }
.cta-box-light h2 em { font-style: italic; }
.cta-box-light p { font-size: 14px; font-weight: 300; color: var(--mid); max-width: 440px; margin: 0 auto 40px; line-height: 1.8; }

/* ══════════════════════════════════════════════
   AGENTS
══════════════════════════════════════════════ */
.hero-split { display: grid; grid-template-columns: 1fr 1fr; min-height: calc(100vh - 72px); margin-top: 72px; }
.hero-left { padding: 80px 56px; background: var(--ivory); display: flex; flex-direction: column; justify-content: space-between; border-right: 1px solid var(--divider); border-bottom: 1px solid var(--divider); }
.hero-right { padding: 80px 56px; background: var(--cream); display: flex; flex-direction: column; justify-content: space-between; border-bottom: 1px solid var(--divider); }
.hero-tag { font-size: 11px; letter-spacing: 5px; text-transform: uppercase; color: var(--mid); margin-bottom: 32px; display: block; }
.hero-h { font-family: 'Cormorant Garamond', serif; font-size: clamp(40px, 5vw, 72px); font-weight: 300; color: var(--dark); line-height: 1.0; margin-bottom: 24px; }
.hero-h em { font-style: italic; }
.hero-cta-btn { display: inline-flex; align-items: center; gap: 12px; padding: 13px 28px; background: var(--dark); color: var(--ivory); text-decoration: none; font-size: 11px; letter-spacing: 4px; text-transform: uppercase; transition: background .2s; align-self: flex-start; }
.hero-cta-btn:hover { background: var(--terra); }
.hero-sub { font-size: 14px; font-weight: 300; line-height: 1.9; color: var(--mid); max-width: 380px; margin-bottom: 48px; }
.stats-4 { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
.stat-4 { background: var(--celeste); padding: 24px 20px; }
.stat-4-num { font-family: 'Cormorant Garamond', serif; font-size: 44px; font-weight: 300; color: var(--dark); line-height: 1; margin-bottom: 6px; }
.stat-4-label { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--dark); opacity: .5; }
.how-section { padding: 88px 0; border-bottom: 1px solid var(--divider); }
.how-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px; margin-top: 40px; }
.how-step { background: var(--ivory); padding: 36px 28px; }
.how-step-num { font-family: 'Cormorant Garamond', serif; font-size: 56px; font-weight: 300; color: var(--divider); line-height: 1; margin-bottom: 12px; }
.how-step-title { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 300; color: var(--dark); margin-bottom: 8px; }
.how-step-text { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.7; }
.packages-section { padding: 88px 0; background: var(--ivory); border-bottom: 1px solid var(--divider); }
.pkg-g { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.pkg { background: var(--cream); padding: 44px 36px; display: flex; flex-direction: column; justify-content: space-between; min-height: 480px; }
.pkg.pkg-featured { background: var(--dark); }
.pkg-label { font-size: 11px; letter-spacing: 4px; text-transform: uppercase; color: var(--mid); margin-bottom: 12px; }
.pkg-featured .pkg-label { color: rgba(240,236,230,.4); }
.pkg-name { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 300; color: var(--dark); margin-bottom: 8px; }
.pkg-featured .pkg-name { color: var(--ivory); }
.pkg-price { font-family: 'Cormorant Garamond', serif; font-size: 52px; font-weight: 300; color: var(--dark); line-height: 1; margin-bottom: 24px; }
.pkg-featured .pkg-price { color: var(--ivory); }
.pkg-list { list-style: none; display: flex; flex-direction: column; gap: 10px; margin-bottom: 32px; }
.pkg-list li { font-size: 14px; font-weight: 300; color: var(--mid); display: flex; align-items: flex-start; gap: 10px; }
.pkg-featured .pkg-list li { color: rgba(240,236,230,.6); }
.pkg-list li::before { content: '—'; color: var(--divider); flex-shrink: 0; }
.pkg-featured .pkg-list li::before { color: rgba(240,236,230,.2); }
.pkg-cta { display: block; padding: 13px; text-align: center; background: var(--dark); color: var(--ivory); text-decoration: none; font-size: 11px; letter-spacing: 4px; text-transform: uppercase; transition: background .2s; }
.pkg-cta:hover { background: var(--terra); }
.pkg-featured .pkg-cta { background: var(--terra); }
.pkg-featured .pkg-cta:hover { background: var(--ivory); color: var(--dark); }
.testimonials-section { padding: 88px 0; background: var(--dark); border-bottom: 1px solid rgba(240,236,230,.08); }
.testimonials-section .section-label { color: var(--mid); }
.testimonials-section .section-h { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.5vw, 52px); font-weight: 300; color: var(--ivory); line-height: 1.05; margin-bottom: 48px; }
.testimonials-section .section-h em { font-style: italic; }
.t3-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.t3-card { background: var(--celeste); padding: 36px; }
.t3-text { font-family: 'Cormorant Garamond', serif; font-size: 18px; font-weight: 300; font-style: italic; color: var(--dark); line-height: 1.5; margin-bottom: 20px; }
.t3-author { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--mid); }
.cta-agents { background: var(--dark); padding: 88px 0; text-align: center; }
.cta-agents h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(36px, 5vw, 72px); font-weight: 300; color: var(--ivory); line-height: 1.0; margin-bottom: 16px; }
.cta-agents h2 em { font-style: italic; }
.cta-agents p { font-size: 14px; font-weight: 300; color: var(--mid); max-width: 440px; margin: 0 auto 36px; line-height: 1.8; }
.btn-ghost { display: inline-flex; align-items: center; gap: 10px; padding: 13px 32px; background: transparent; color: rgba(240,236,230,.6); border: 1px solid rgba(240,236,230,.2); text-decoration: none; font-size: 11px; letter-spacing: 4px; text-transform: uppercase; transition: all .2s; }
.btn-ghost:hover { border-color: rgba(240,236,230,.4); color: var(--ivory); }
.btn-ivory { display: inline-flex; align-items: center; gap: 10px; padding: 13px 28px; background: var(--ivory); color: var(--dark); text-decoration: none; font-size: 11px; letter-spacing: 4px; text-transform: uppercase; transition: all .2s; }
.btn-ivory:hover { background: var(--terra); color: var(--ivory); }

/* ══════════════════════════════════════════════
   PROPERTIES
══════════════════════════════════════════════ */
.prop-hero { background: var(--dark); padding: 140px 0 88px; margin-top: 72px; border-bottom: 1px solid rgba(240,236,230,.08); }
.prop-hero-tag { font-size: 11px; letter-spacing: 5px; text-transform: uppercase; color: var(--mid); margin-bottom: 24px; display: block; }
.prop-hero-h { font-family: 'Cormorant Garamond', serif; font-size: clamp(44px, 6vw, 88px); font-weight: 300; color: var(--ivory); line-height: 1.0; margin-bottom: 40px; }
.prop-hero-h em { font-style: italic; }
.prop-hero-bottom { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: end; }
.prop-hero-sub { font-size: 14px; font-weight: 300; line-height: 1.9; color: var(--mid); max-width: 400px; }
.prop-hero-ctas { display: flex; flex-direction: column; gap: 12px; align-items: flex-end; }
.prop-block { padding: 88px 0; border-bottom: 1px solid var(--divider); }
.prop-block.ivory { background: var(--ivory); }
.prop-block.dark { background: var(--dark); border-bottom: 1px solid rgba(240,236,230,.08); }
.prop-h { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 4vw, 56px); font-weight: 300; color: var(--dark); line-height: 1.05; margin-bottom: 20px; }
.prop-h em { font-style: italic; }
.prop-dark .prop-h { color: var(--ivory); }
.prop-p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.8; max-width: 640px; }
.prop-dark .prop-p { color: var(--mid); }
.pkg-rows { display: flex; flex-direction: column; gap: 4px; margin-top: 48px; }
.pkg-row { display: grid; grid-template-columns: 220px 1fr auto auto; gap: 40px; align-items: center; padding: 32px 40px; background: var(--cream); text-decoration: none; color: var(--dark); transition: background .2s; }
.pkg-row:hover { background: var(--dark); }
.pkg-row:hover .pkg-tag { color: rgba(240,236,230,.3); }
.pkg-row:hover .pkg-row-name { color: var(--ivory); }
.pkg-row:hover .pkg-item { color: rgba(240,236,230,.5); }
.pkg-row:hover .pkg-price { color: var(--ivory); }
.pkg-row:hover .pkg-arrow { color: rgba(240,236,230,.5); transform: translateX(4px); }
.pkg-tag { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--mid); margin-bottom: 6px; transition: color .2s; }
.pkg-row-name { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 300; color: var(--dark); transition: color .2s; }
.pkg-inc { display: flex; flex-direction: column; gap: 6px; }
.pkg-item { font-size: 14px; font-weight: 300; color: var(--mid); transition: color .2s; }
.pkg-price { font-family: 'Cormorant Garamond', serif; font-size: 44px; font-weight: 300; color: var(--dark); line-height: 1; transition: color .2s; white-space: nowrap; }
.pkg-arrow { font-size: 20px; color: var(--divider); transition: all .2s; }
.nina-prop { display: grid; grid-template-columns: 1fr 1fr; border-bottom: 1px solid var(--divider); }
.nina-img-col { overflow: hidden; background: var(--celeste); min-height: 560px; }
.nina-img-col img { width: 100%; height: 100%; object-fit: cover; display: block; }
.nina-text-col { padding: 80px 64px; display: flex; flex-direction: column; justify-content: center; background: var(--ivory); }
.nina-tag { font-size: 11px; letter-spacing: 4px; text-transform: uppercase; color: var(--mid); margin-bottom: 24px; display: block; }
.nina-h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(32px, 3.5vw, 52px); font-weight: 300; color: var(--dark); line-height: 1.05; margin-bottom: 24px; }
.nina-h2 em { font-style: italic; }
.nina-p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.8; margin-bottom: 16px; max-width: 440px; }
.nina-stats { display: flex; gap: 4px; margin-top: 32px; }
.nina-stat { background: var(--celeste); padding: 24px 32px; }
.nina-stat-num { font-family: 'Cormorant Garamond', serif; font-size: 44px; font-weight: 300; color: var(--dark); line-height: 1; margin-bottom: 6px; }
.nina-stat-label { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--dark); opacity: .5; }
.t2-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; margin-top: 48px; }
.t2-card { background: rgba(240,236,230,.04); border: 1px solid rgba(240,236,230,.08); padding: 44px; }
.t2-text { font-family: 'Cormorant Garamond', serif; font-size: 20px; font-weight: 300; font-style: italic; color: var(--ivory); line-height: 1.5; margin-bottom: 24px; }
.t2-author { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: var(--mid); margin-bottom: 6px; }
.t2-result { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--terra); }
.cta-prop { padding: 88px 0; text-align: center; background: var(--dark); }

/* ══════════════════════════════════════════════
   SEO PAGES (airbnb / hotel / real estate)
══════════════════════════════════════════════ */
.seo-hero { padding: 140px 0 80px; text-align: center; border-bottom: 1px solid var(--divider); background: var(--ivory); }
.seo-hero h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(40px, 5vw, 72px); font-weight: 300; color: var(--dark); line-height: 1.0; margin-bottom: 20px; }
.seo-hero h1 em { font-style: italic; }
.seo-hero p { font-size: 14px; font-weight: 300; color: var(--mid); max-width: 540px; margin: 0 auto 32px; line-height: 1.8; }
.seo-block { padding: 88px 0; border-bottom: 1px solid var(--divider); }
.seo-block.seo-dark { background: var(--dark); border-bottom: none; }
.seo-block.seo-alt { background: var(--ivory); }
.seo-h { font-family: 'Cormorant Garamond', serif; font-size: clamp(28px, 3.5vw, 48px); font-weight: 300; color: var(--dark); line-height: 1.05; margin-bottom: 16px; }
.seo-h em { font-style: italic; }
.seo-dark .seo-h { color: var(--ivory); }
.seo-dark .section-label { color: var(--mid); }
.seo-p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.8; max-width: 500px; margin-bottom: 20px; }
.seo-dark .seo-p { color: var(--mid); }
.pain-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; margin-top: 48px; }
.pain-card { background: var(--celeste); padding: 40px 32px; }
.pain-icon { font-size: 24px; margin-bottom: 16px; }
.pain-card h3 { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 300; color: var(--dark); margin-bottom: 10px; }
.pain-card p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.7; }
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.two-col h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(28px, 3.5vw, 44px); font-weight: 300; color: var(--dark); margin-bottom: 16px; line-height: 1.05; }
.two-col h2 em { font-style: italic; }
.two-col p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.8; margin-bottom: 12px; }
.img-box { overflow: hidden; background: var(--celeste); }
.img-box img { width: 100%; height: 100%; object-fit: cover; display: block; min-height: 360px; }
.comparison-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; margin-top: 48px; }
.comparison-col { padding: 40px 36px; }
.comparison-col.bad { background: rgba(240,236,230,.04); border: 1px solid rgba(240,236,230,.08); }
.comparison-col.good { background: var(--terra); }
.comparison-col h3 { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 300; margin-bottom: 16px; }
.comparison-col.bad h3 { color: rgba(240,236,230,.5); }
.comparison-col.good h3 { color: var(--ivory); }
.comp-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.comp-list li { font-size: 14px; font-weight: 300; display: flex; align-items: flex-start; gap: 10px; line-height: 1.5; }
.comparison-col.bad .comp-list li { color: rgba(240,236,230,.5); }
.comparison-col.good .comp-list li { color: rgba(240,236,230,.9); }
.comp-list li::before { flex-shrink: 0; font-size: 14px; }
.comparison-col.bad .comp-list li::before { content: '✗'; color: rgba(240,236,230,.3); }
.comparison-col.good .comp-list li::before { content: '✓'; color: rgba(240,236,230,.6); }
.steps-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px; margin-top: 48px; background: var(--dark); }
.step-4 { background: rgba(240,236,230,.04); border: 1px solid rgba(240,236,230,.08); padding: 36px 28px; }
.step-4-n { font-family: 'Cormorant Garamond', serif; font-size: 56px; font-weight: 300; color: rgba(240,236,230,.15); line-height: 1; margin-bottom: 12px; }
.step-4 h4 { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 300; color: var(--ivory); margin-bottom: 8px; }
.step-4 p { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.7; }
.pkg-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; margin-top: 48px; }
.pkg3 { background: var(--ivory); padding: 40px 36px; }
.pkg3-name { font-size: 11px; letter-spacing: 4px; text-transform: uppercase; color: var(--mid); margin-bottom: 12px; }
.pkg3-price { font-family: 'Cormorant Garamond', serif; font-size: 56px; font-weight: 300; color: var(--dark); line-height: 1; margin-bottom: 4px; }
.pkg3-detail { font-size: 14px; font-weight: 300; color: var(--mid); margin-bottom: 24px; }
.pkg3-features { list-style: none; display: flex; flex-direction: column; gap: 8px; margin-bottom: 28px; }
.pkg3-features li { font-size: 14px; font-weight: 300; color: var(--mid); display: flex; align-items: flex-start; gap: 10px; }
.pkg3-features li::before { content: '—'; color: var(--divider); flex-shrink: 0; }
.cta-box-seo { background: var(--dark); padding: 88px 60px; text-align: center; }
.cta-box-seo h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(36px, 4vw, 60px); font-weight: 300; color: var(--ivory); line-height: 1.05; margin-bottom: 16px; }
.cta-box-seo h2 em { font-style: italic; }
.cta-box-seo p { font-size: 14px; font-weight: 300; color: var(--mid); max-width: 440px; margin: 0 auto 40px; line-height: 1.8; }

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media (max-width: 900px) {
  .nav-inner { padding: 0 24px; }
  .nav-links { position: fixed; top: 72px; left: 0; right: 0; background: var(--cream); flex-direction: column; gap: 0; border-bottom: 1px solid var(--divider); max-height: 0; overflow: hidden; transition: max-height .4s ease; }
  .nav-links.open { max-height: 600px; }
  .nav-links li { border-bottom: 1px solid var(--divider); }
  .nav-links a { display: block; padding: 14px 24px; font-size: 11px; }
  .nav-cta { margin: 16px 24px !important; text-align: center !important; display: block !important; }
  .hamburger { display: flex; }
  .container { padding: 0 24px; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-bottom { flex-direction: column; gap: 12px; text-align: center; }
  .welcome-split { grid-template-columns: 1fr; min-height: auto; }
  .panel { padding: 56px 24px; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .value-grid { grid-template-columns: 1fr; }
  .featured-grid { grid-template-columns: 1fr; }
  .hiw-grid { grid-template-columns: 1fr 1fr; }
  .nina-grid { grid-template-columns: 1fr; }
  .portfolio-grid { grid-template-columns: 1fr; gap: 16px; padding: 16px 0; }
  .process-step { grid-template-columns: 1fr; }
  .process-step:nth-child(even) .step-visual { order: 0; }
  .step-content { padding: 48px 24px; }
  .step-visual { min-height: 260px; }
  .timeline-grid { grid-template-columns: 1fr; }
  .guarantee-box { grid-template-columns: 1fr; }
  .guarantee-left, .guarantee-right { padding: 40px 24px; }
  .pricing-grid { grid-template-columns: 1fr; }
  .included-grid { grid-template-columns: 1fr; }
  .addons-grid { grid-template-columns: 1fr; }
  .addon-card { flex-direction: column; gap: 16px; align-items: flex-start; }
  .sample-box { padding: 48px 24px; }
  .cta-dark { padding: 48px 24px; }
  .cta-box { padding: 0 24px; }
  .cta-section { padding: 48px 0; }
  .team-grid { grid-template-columns: 1fr; }
  .values-grid { grid-template-columns: 1fr; }
  .hero-split { grid-template-columns: 1fr; }
  .hero-left, .hero-right { padding: 56px 24px; }
  .how-steps { grid-template-columns: 1fr 1fr; }
  .pkg-g { grid-template-columns: 1fr; }
  .t3-grid { grid-template-columns: 1fr; }
  .prop-hero-bottom { grid-template-columns: 1fr; gap: 32px; }
  .prop-hero-ctas { align-items: flex-start; }
  .pkg-row { grid-template-columns: 1fr 1fr; gap: 16px; padding: 24px; }
  .pkg-arrow { display: none; }
  .nina-prop { grid-template-columns: 1fr; }
  .nina-img-col { min-height: 320px; }
  .nina-text-col { padding: 48px 24px; }
  .t2-grid { grid-template-columns: 1fr; }
  .pain-grid { grid-template-columns: 1fr; }
  .two-col { grid-template-columns: 1fr; gap: 32px; }
  .comparison-grid { grid-template-columns: 1fr; }
  .steps-4 { grid-template-columns: 1fr 1fr; }
  .pkg-3 { grid-template-columns: 1fr; }
  .cta-box-seo { padding: 48px 24px; }
  .office-photo { height: 320px; }
  .contact-split { grid-template-columns: 1fr; }
  .contact-left, .contact-right { padding: 48px 24px; }
  .upload-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .footer-grid { grid-template-columns: 1fr; }
  .stats-4 { grid-template-columns: 1fr; }
  .hiw-grid { grid-template-columns: 1fr; }
  .how-steps { grid-template-columns: 1fr; }
  .steps-4 { grid-template-columns: 1fr; }
  .pkg-row { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════
   NEW SPLIT INDEX
══════════════════════════════════════════════ */
.split-welcome {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: calc(100vh - 64px);
  margin-top: 64px;
}
.split-welcome .panel {
  padding: 80px 64px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  border-bottom: none;
}
.split-welcome .panel > div { max-width: 440px; }
.split-welcome .panel-agents { background: var(--cream); border-right: 1px solid var(--divider); }
.split-welcome .panel-properties { background: var(--pink); }
.split-welcome .panel:hover .panel-cta { background: var(--celeste); color: #fff; border-color: var(--terra); }

.panel-tag { font-size: 11px; letter-spacing: 5px; text-transform: uppercase; color: var(--mid); margin-bottom: 24px; transition: color .3s; }
.panel-sub { font-size: 14px; font-weight: 300; color: var(--mid); line-height: 1.8; max-width: 380px; margin-bottom: 32px; transition: color .3s; }
.panel-features { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 40px; }
.panel-feat {
  font-size: 12px; letter-spacing: 3px; text-transform: uppercase;
  color: var(--mid); border: 1px solid var(--divider);
  padding: 6px 14px; transition: all .3s;
}

/* Nav height fix */
nav { height: 64px; }
.nav-inner { height: 64px; }

@media (max-width: 900px) {
  .split-welcome { grid-template-columns: 1fr; min-height: auto; }
  .split-welcome .panel { padding: 56px 24px; min-height: 50vh; }
}

/* detail-expanded overlay */
.detail-expanded { display:none; position:fixed; inset:0; background:rgba(44,40,37,.96); z-index:6000; align-items:center; justify-content:center; flex-direction:column; cursor:pointer; }
.detail-expanded.open { display:flex; }
.detail-expanded img { max-width:90vw; max-height:85vh; object-fit:contain; }
.dch { color:rgba(240,236,230,.4); font-size:12px; letter-spacing:3px; text-transform:uppercase; margin-top:20px; }

/* ══════════════════════════════════════════════
   LIGHTBOX SYSTEM
══════════════════════════════════════════════ */
.lightbox {
  display:none; position:fixed; inset:0; z-index:5000;
  background:rgba(44,40,37,.97); overflow-y:auto;
}
.lightbox.open { display:flex; flex-direction:column; }
.lightbox-close {
  position:fixed; top:24px; right:28px; z-index:5010;
  background:none; border:none; color:rgba(240,236,230,.5);
  font-size:28px; cursor:pointer; width:48px; height:48px;
  display:flex; align-items:center; justify-content:center;
  transition:color .2s;
}
.lightbox-close:hover { color:var(--ivory); }
.lightbox-header {
  padding:32px 64px 0; flex-shrink:0;
}
.lightbox-header h3 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(28px,3vw,44px); font-weight:300;
  color:var(--ivory); line-height:1.1;
}
.lightbox-body {
  flex:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  padding:24px 64px 40px;
}
.lightbox-slide { display:none; width:100%; }
.lightbox-slide.active { display:block; }
.slide-content { width:100%; }
.slide-main { width:100%; }
.lightbox-ba {
  position:relative; width:100%;
  max-width:900px; margin:0 auto;
}
.lb-hero {
  width:100%; display:block; object-fit:contain;
  max-height:65vh;
}
.before-pip {
  position:absolute; bottom:16px; left:16px;
  width:120px; cursor:pointer; border:2px solid rgba(255,255,255,.3);
  transition:border-color .2s, transform .2s;
  background:rgba(0,0,0,.4);
}
.before-pip:hover {
  border-color:var(--terra); transform:scale(1.05);
}
.before-pip img {
  width:100%; display:block;
}
.pip-label {
  position:absolute; bottom:0; left:0; right:0;
  background:rgba(0,0,0,.7); color:rgba(255,255,255,.8);
  font-size:12px; letter-spacing:3px; text-transform:uppercase;
  text-align:center; padding:6px 0 4px;
  font-family:'DM Sans',sans-serif;
}
.pip-label small {
  display:block; font-size:7px; letter-spacing:1px;
  color:rgba(255,255,255,.4); margin-top:2px;
  text-transform:none;
}
.slide-badge {
  position:absolute; top:16px; right:16px;
  font-size:12px; letter-spacing:3px; text-transform:uppercase;
  color:rgba(255,255,255,.7); background:rgba(0,0,0,.5);
  padding:6px 14px; font-family:'DM Sans',sans-serif;
}
.lightbox-nav {
  display:flex; align-items:center; gap:24px;
  margin-top:24px;
}
.lightbox-btn {
  background:none; border:1px solid rgba(240,236,230,.2);
  color:rgba(240,236,230,.6); font-size:28px; width:48px; height:48px;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .2s;
}
.lightbox-btn:hover {
  border-color:var(--terra); color:var(--terra);
}
.lightbox-counter {
  font-family:'DM Sans',sans-serif; font-size:14px;
  letter-spacing:3px; color:rgba(240,236,230,.4);
}
.lightbox-dots {
  display:flex; gap:8px; margin-top:16px; justify-content:center;
}
.lightbox-dot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(240,236,230,.15); border:none;
  cursor:pointer; transition:background .2s;
}
.lightbox-dot.active { background:var(--terra); }
.lightbox-dot:hover { background:rgba(240,236,230,.4); }

@media(max-width:768px){
  .lightbox-header { padding:24px 24px 0; }
  .lightbox-body { padding:16px 16px 32px; }
  .before-pip { width:80px; bottom:8px; left:8px; }
  .lb-hero { max-height:55vh; }
}

/* ══════════════════════════════════════════════
   PORTFOLIO SECTION
══════════════════════════════════════════════ */
.portfolio-section { padding:0; }
.portfolio-filters {
  display:flex; gap:0; border-bottom:1px solid var(--divider);
  padding:0 48px; flex-wrap:wrap;
}
.filter-btn {
  background:none; border:none; border-bottom:2px solid transparent;
  padding:20px 24px; font-family:'DM Sans',sans-serif;
  font-size:12px; letter-spacing:3px; text-transform:uppercase;
  color:var(--mid); cursor:pointer; transition:all .2s;
}
.filter-btn.active,
.filter-btn:hover {
  color:var(--dark); border-bottom-color:var(--terra);
}
.portfolio-info { padding:24px 28px 32px; }
.room-count {
  display:flex; align-items:center; gap:8px;
  font-size:11px; letter-spacing:2px; color:var(--celeste);
  text-transform:uppercase; margin-bottom:12px;
  font-family:'DM Sans',sans-serif;
}
.portfolio-info h3 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(24px,2vw,32px); font-weight:300;
  color:var(--dark); margin-bottom:8px;
}
.portfolio-info p {
  font-size:13px; font-weight:300; color:var(--mid);
  line-height:1.8; margin-bottom:16px;
}
.portfolio-tags { display:flex; gap:8px; flex-wrap:wrap; }
.portfolio-tag {
  font-size:12px; letter-spacing:3px; text-transform:uppercase;
  color:var(--mid); border:1px solid var(--divider);
  padding:6px 14px; font-family:'DM Sans',sans-serif;
}

@media(max-width:768px){
  .portfolio-section { padding:0; }
  .portfolio-filters { padding:0 16px; }
  .portfolio-info { padding:24px 24px 32px; }
  .filter-btn { padding:16px 16px; font-size:13px; }
}

/* ══════════════════════════════════════════════
   SECTION-TITLE (used in CTA boxes)
══════════════════════════════════════════════ */
.section-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(32px,3vw,48px); font-weight:300;
  line-height:1.1; color:var(--dark); margin-bottom:16px;
}
.section-title em { font-style:italic; }

/* ══════════════════════════════════════════════
   INDEX FREE TRIAL BANNER
══════════════════════════════════════════════ */
.ix-trial {
  display:flex; align-items:center; justify-content:center;
  gap:24px; padding:28px 32px;
  border-top:1px solid var(--divider);
  border-bottom:1px solid var(--divider);
  background:var(--cream); flex-wrap:wrap;
}
.ix-trial p {
  font-family:'DM Sans',sans-serif; font-size:14px;
  font-weight:300; color:var(--mid); margin:0;
}
.ix-trial a {
  font-family:'DM Sans',sans-serif; font-size:10px;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--ivory) !important; background:var(--terra);
  padding:14px 28px; text-decoration:none !important;
  transition:background .2s; white-space:nowrap;
}
.ix-trial a:hover { background:var(--dark); }
