/* ── Public / Marketing Website — USA Real Estate Theme ────────────── */
:root {
    --pub-primary:        #1d4ed8;   /* American Blue */
    --pub-primary-dark:   #1e3a8a;   /* Deep Navy Blue */
    --pub-primary-light:  #dbeafe;   /* Light Blue */
    --pub-accent:         #d97706;   /* Gold / Amber */
    --pub-accent-dark:    #92400e;
    --pub-accent-light:   #fef3c7;
    --pub-red:            #dc2626;   /* American Red */
    --pub-dark:           #0a1628;   /* Deep Navy */
    --pub-dark2:          #132238;   /* Medium Navy */
    --pub-text:           #1e293b;
    --pub-muted:          #64748b;
    --pub-border:         #e2e8f0;
    --pub-bg:             #f8fafc;
    --pub-radius:         14px;
    --pub-shadow:         0 4px 24px rgba(29,78,216,.1);
    --pub-shadow-lg:      0 12px 48px rgba(29,78,216,.18);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.pub-body { font-family: 'Segoe UI', -apple-system, sans-serif; color: var(--pub-text); background: #fff; margin: 0; }

/* ── NAV ─────────────────────────────────────────────────────────── */
.pub-nav { position: sticky; top: 0; z-index: 1000; background: rgba(255,255,255,.97); backdrop-filter: blur(12px); border-bottom: 1px solid var(--pub-border); }
.pub-nav-inner { max-width: 1200px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; height: 64px; gap: 40px; }
.pub-nav-brand { display: flex; align-items: center; gap: 10px; text-decoration: none; flex-shrink: 0; }
.pub-brand-icon { width: 36px; height: 36px; background: linear-gradient(135deg, var(--pub-primary) 0%, var(--pub-primary-dark) 100%); border-radius: 9px; display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 700; font-size: 18px; box-shadow: 0 2px 8px rgba(29,78,216,.3); }
.pub-brand-text { font-weight: 700; font-size: 18px; color: var(--pub-dark); }
.pub-nav-links { display: flex; gap: 32px; flex: 1; }
.pub-nav-links a { text-decoration: none; color: var(--pub-muted); font-size: 15px; font-weight: 500; transition: color .2s; }
.pub-nav-links a:hover { color: var(--pub-primary); }
.pub-nav-actions { display: flex; gap: 12px; align-items: center; flex-shrink: 0; }
.pub-btn { display: inline-flex; align-items: center; gap: 6px; padding: 9px 20px; border-radius: 8px; font-size: 14px; font-weight: 600; text-decoration: none; transition: all .2s; cursor: pointer; border: none; }
.pub-btn-ghost { color: var(--pub-text); background: transparent; }
.pub-btn-ghost:hover { background: var(--pub-bg); color: var(--pub-primary); }
.pub-btn-primary { background: var(--pub-primary); color: #fff; }
.pub-btn-primary:hover { background: var(--pub-primary-dark); color: #fff; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(29,78,216,.35); }
.pub-btn-outline { border: 1.5px solid var(--pub-primary); color: var(--pub-primary); background: transparent; }
.pub-btn-outline:hover { background: var(--pub-primary); color: #fff; }
.pub-btn-gold { background: var(--pub-accent); color: #fff; }
.pub-btn-gold:hover { background: var(--pub-accent-dark); color: #fff; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(217,119,6,.35); }
.pub-btn-lg { padding: 14px 32px; font-size: 16px; border-radius: 10px; }
.pub-btn-xl { padding: 16px 40px; font-size: 17px; border-radius: 12px; }

/* ── SECTIONS ─────────────────────────────────────────────────────── */
.pub-container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.pub-section { padding: 96px 0; }
.pub-section-sm { padding: 64px 0; }
.pub-section-label { font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--pub-primary); margin-bottom: 12px; }
.pub-section-title { font-size: clamp(28px, 4vw, 44px); font-weight: 800; color: var(--pub-dark); line-height: 1.15; margin: 0 0 20px; }
.pub-section-sub { font-size: 18px; color: var(--pub-muted); line-height: 1.6; max-width: 560px; margin: 0 auto 48px; }

/* ── HERO ─────────────────────────────────────────────────────────── */
.pub-hero {
    background: linear-gradient(150deg, #0a1628 0%, #0f2040 45%, #0a1628 100%);
    padding: 100px 0 80px;
    overflow: hidden;
    position: relative;
}
/* Subtle star / grid overlay */
.pub-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 90% 55% at 55% -5%, rgba(217,119,6,.18) 0%, transparent 65%),
        radial-gradient(ellipse 50% 40% at 10% 80%, rgba(29,78,216,.15) 0%, transparent 60%);
    pointer-events: none;
}
/* Fine dot grid for USA-star feel */
.pub-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle, rgba(255,255,255,.06) 1px, transparent 1px);
    background-size: 36px 36px;
    pointer-events: none;
}
.pub-hero-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(217,119,6,.15);
    border: 1px solid rgba(217,119,6,.4);
    color: #fbbf24;
    font-size: 13px; font-weight: 600;
    padding: 6px 14px; border-radius: 100px; margin-bottom: 28px;
}
.pub-hero-title { font-size: clamp(36px, 5.5vw, 68px); font-weight: 800; color: #fff; line-height: 1.08; letter-spacing: -.02em; margin: 0 0 24px; }
.pub-hero-title span { color: var(--pub-accent); }
.pub-hero-sub { font-size: 19px; color: #94a3b8; line-height: 1.6; max-width: 560px; margin-bottom: 40px; }
.pub-hero-actions { display: flex; gap: 16px; flex-wrap: wrap; }
.pub-hero-trust { display: flex; align-items: center; gap: 16px; margin-top: 48px; flex-wrap: wrap; }
.pub-hero-trust-text { font-size: 13px; color: #64748b; }
.pub-hero-avatars { display: flex; }
.pub-hero-avatars span { width: 32px; height: 32px; border-radius: 50%; background: var(--pub-primary); border: 2px solid #0a1628; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 11px; font-weight: 700; margin-left: -8px; }
.pub-hero-avatars span:first-child { margin-left: 0; }

/* USA trust ribbon */
.pub-hero-usa-bar {
    display: flex; align-items: center; gap: 24px; margin-top: 40px;
    padding: 14px 20px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 12px;
    flex-wrap: wrap;
}
.pub-hero-usa-bar span { font-size: 12px; color: #94a3b8; display: flex; align-items: center; gap: 6px; }
.pub-hero-usa-bar span i { color: var(--pub-accent); }

/* Hero mockup */
.pub-hero-visual { position: relative; }
.pub-hero-mockup { background: #132238; border-radius: 16px; border: 1px solid rgba(255,255,255,.12); overflow: hidden; box-shadow: 0 32px 80px rgba(0,0,0,.55), 0 0 0 1px rgba(217,119,6,.12); }
.pub-mock-bar { background: #0a1628; padding: 12px 16px; display: flex; gap: 6px; border-bottom: 1px solid rgba(255,255,255,.08); }
.pub-mock-dot { width: 10px; height: 10px; border-radius: 50%; }
.pub-mock-content { padding: 20px; }
.pub-stat-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-bottom: 16px; }
.pub-stat-mini { background: #0a1628; border-radius: 10px; padding: 12px; border: 1px solid rgba(255,255,255,.07); }
.pub-stat-mini-val { font-size: 20px; font-weight: 700; color: #f8fafc; }
.pub-stat-mini-label { font-size: 11px; color: #64748b; margin-top: 2px; }
.pub-chart-bar { display: flex; align-items: flex-end; gap: 6px; height: 80px; background: #0a1628; border-radius: 10px; padding: 12px; border: 1px solid rgba(255,255,255,.07); }
.pub-bar { flex: 1; border-radius: 4px 4px 0 0; background: var(--pub-primary); opacity: .75; }
.pub-lead-row { display: flex; align-items: center; gap: 8px; background: #0a1628; border-radius: 8px; padding: 8px 10px; margin-top: 10px; border: 1px solid rgba(255,255,255,.07); }
.pub-lead-dot { width: 8px; height: 8px; border-radius: 50%; background: #22c55e; flex-shrink: 0; }
.pub-lead-name { font-size: 12px; color: #94a3b8; flex: 1; }
.pub-lead-score { font-size: 11px; font-weight: 600; color: var(--pub-accent); background: rgba(217,119,6,.15); padding: 2px 8px; border-radius: 100px; }

/* ── STATS BAR ────────────────────────────────────────────────────── */
.pub-stats-bar { background: var(--pub-dark); border-top: 3px solid var(--pub-accent); border-bottom: none; padding: 40px 0; }
.pub-stats-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 32px; text-align: center; }
.pub-stat-num { font-size: 36px; font-weight: 800; color: var(--pub-accent); line-height: 1; }
.pub-stat-label { font-size: 14px; color: #94a3b8; margin-top: 6px; }

/* ── FEATURES ─────────────────────────────────────────────────────── */
.pub-features-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.pub-feature-card { background: #fff; border: 1px solid var(--pub-border); border-radius: var(--pub-radius); padding: 32px; transition: all .25s; }
.pub-feature-card:hover { border-color: var(--pub-primary); box-shadow: var(--pub-shadow); transform: translateY(-4px); }
.pub-feature-icon { width: 52px; height: 52px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 22px; margin-bottom: 20px; }
.pub-feature-title { font-size: 18px; font-weight: 700; color: var(--pub-dark); margin: 0 0 10px; }
.pub-feature-desc { font-size: 14px; color: var(--pub-muted); line-height: 1.6; margin: 0; }

/* ── HOW IT WORKS ─────────────────────────────────────────────────── */
.pub-how-bg { background: var(--pub-dark); }
.pub-steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 40px; position: relative; }
.pub-steps::before { content: ''; position: absolute; top: 28px; left: calc(16.67% + 20px); right: calc(16.67% + 20px); height: 2px; background: linear-gradient(90deg, var(--pub-accent), #fcd34d); }
.pub-step { text-align: center; }
.pub-step-num { width: 56px; height: 56px; border-radius: 50%; background: var(--pub-accent); color: #fff; font-size: 20px; font-weight: 700; display: flex; align-items: center; justify-content: center; margin: 0 auto 24px; position: relative; z-index: 1; box-shadow: 0 0 0 6px rgba(217,119,6,.2); }
.pub-step-title { font-size: 18px; font-weight: 700; color: #f8fafc; margin-bottom: 12px; }
.pub-step-desc { font-size: 14px; color: #94a3b8; line-height: 1.6; }

/* ── PRICING ──────────────────────────────────────────────────────── */
.pub-pricing-toggle { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 48px; }
.pub-toggle-label { font-size: 15px; color: var(--pub-muted); font-weight: 500; }
.pub-toggle-switch { position: relative; width: 52px; height: 28px; }
.pub-toggle-switch input { opacity: 0; width: 0; height: 0; }
.pub-toggle-slider { position: absolute; inset: 0; background: var(--pub-border); border-radius: 100px; cursor: pointer; transition: .3s; }
.pub-toggle-slider:before { content: ''; position: absolute; width: 20px; height: 20px; left: 4px; bottom: 4px; background: #fff; border-radius: 50%; transition: .3s; }
input:checked + .pub-toggle-slider { background: var(--pub-primary); }
input:checked + .pub-toggle-slider:before { transform: translateX(24px); }
.pub-save-badge { background: #dcfce7; color: #166534; font-size: 12px; font-weight: 600; padding: 3px 10px; border-radius: 100px; }
.pub-plans-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; align-items: start; }
.pub-plan-card { background: #fff; border: 1.5px solid var(--pub-border); border-radius: 18px; padding: 32px 28px; position: relative; transition: all .25s; }
.pub-plan-card:hover { box-shadow: var(--pub-shadow); transform: translateY(-4px); }
.pub-plan-card.popular { border-color: var(--pub-primary); background: linear-gradient(180deg, rgba(29,78,216,.04) 0%, #fff 40%); transform: scale(1.03); }
.pub-plan-card.popular:hover { transform: scale(1.03) translateY(-4px); }
.pub-popular-badge { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); background: linear-gradient(135deg, var(--pub-primary) 0%, var(--pub-primary-dark) 100%); color: #fff; font-size: 12px; font-weight: 700; padding: 4px 18px; border-radius: 100px; white-space: nowrap; }
.pub-plan-name { font-size: 20px; font-weight: 700; color: var(--pub-dark); margin-bottom: 6px; }
.pub-plan-desc { font-size: 13px; color: var(--pub-muted); margin-bottom: 24px; line-height: 1.4; }
.pub-plan-price { margin-bottom: 8px; }
.pub-plan-amount { font-size: 44px; font-weight: 800; color: var(--pub-dark); line-height: 1; }
.pub-plan-currency { font-size: 22px; font-weight: 600; vertical-align: top; margin-top: 8px; display: inline-block; color: var(--pub-dark); }
.pub-plan-period { font-size: 14px; color: var(--pub-muted); margin-bottom: 28px; }
.pub-plan-features { list-style: none; padding: 0; margin: 0 0 32px; display: flex; flex-direction: column; gap: 10px; }
.pub-plan-features li { font-size: 13px; color: var(--pub-text); display: flex; align-items: flex-start; gap: 8px; }
.pub-plan-features li::before { content: '✓'; color: #16a34a; font-weight: 700; flex-shrink: 0; margin-top: 1px; }
.pub-plan-limits { font-size: 12px; color: var(--pub-muted); border-top: 1px solid var(--pub-border); padding-top: 16px; margin-bottom: 24px; display: flex; flex-direction: column; gap: 4px; }
.pub-plan-cta { display: block; text-align: center; padding: 13px; border-radius: 10px; font-weight: 600; font-size: 15px; text-decoration: none; transition: all .2s; }
.pub-plan-cta-default { background: var(--pub-bg); color: var(--pub-primary); border: 1.5px solid var(--pub-primary); }
.pub-plan-cta-default:hover { background: var(--pub-primary); color: #fff; }
.pub-plan-cta-primary { background: var(--pub-primary); color: #fff; }
.pub-plan-cta-primary:hover { background: var(--pub-primary-dark); color: #fff; box-shadow: 0 4px 16px rgba(29,78,216,.4); }

/* Comparison table */
.pub-compare-table { width: 100%; border-collapse: collapse; margin-top: 64px; }
.pub-compare-table th { font-size: 14px; font-weight: 600; color: var(--pub-dark); padding: 16px 20px; text-align: left; background: var(--pub-bg); border-bottom: 2px solid var(--pub-primary); }
.pub-compare-table th:first-child { border-radius: 12px 0 0 0; }
.pub-compare-table th:last-child { border-radius: 0 12px 0 0; }
.pub-compare-table td { padding: 14px 20px; font-size: 14px; color: var(--pub-text); border-bottom: 1px solid var(--pub-border); }
.pub-compare-table tr:last-child td { border-bottom: none; }
.pub-compare-table tr:hover td { background: rgba(29,78,216,.03); }
.pub-check { color: #16a34a; font-size: 16px; font-weight: 700; }
.pub-dash { color: #cbd5e1; }

/* FAQ */
.pub-faq { max-width: 760px; margin: 0 auto; }
.pub-faq-item { border-bottom: 1px solid var(--pub-border); }
.pub-faq-q { width: 100%; background: none; border: none; padding: 20px 0; display: flex; justify-content: space-between; align-items: center; font-size: 16px; font-weight: 600; color: var(--pub-dark); cursor: pointer; text-align: left; gap: 16px; }
.pub-faq-q:hover { color: var(--pub-primary); }
.pub-faq-icon { font-size: 20px; color: var(--pub-accent); flex-shrink: 0; transition: transform .2s; }
.pub-faq-a { font-size: 15px; color: var(--pub-muted); line-height: 1.7; padding-bottom: 20px; display: none; }
.pub-faq-item.open .pub-faq-a { display: block; }
.pub-faq-item.open .pub-faq-icon { transform: rotate(45deg); }

/* ── TESTIMONIALS ─────────────────────────────────────────────────── */
.pub-testimonials-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.pub-testimonial { background: #fff; border: 1px solid var(--pub-border); border-radius: var(--pub-radius); padding: 28px; border-top: 3px solid var(--pub-primary); }
.pub-testimonial-stars { color: var(--pub-accent); font-size: 16px; margin-bottom: 16px; letter-spacing: 2px; }
.pub-testimonial-text { font-size: 15px; color: var(--pub-text); line-height: 1.7; margin-bottom: 20px; font-style: italic; }
.pub-testimonial-author { display: flex; align-items: center; gap: 12px; }
.pub-testimonial-avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--pub-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 16px; flex-shrink: 0; }
.pub-testimonial-name { font-weight: 700; font-size: 14px; color: var(--pub-dark); }
.pub-testimonial-role { font-size: 12px; color: var(--pub-muted); }

/* ── CTA SECTION ──────────────────────────────────────────────────── */
.pub-cta-section {
    background: linear-gradient(150deg, var(--pub-dark) 0%, #0f2040 60%, var(--pub-dark) 100%);
    padding: 96px 0;
    text-align: center;
    position: relative;
    overflow: hidden;
    border-top: 3px solid var(--pub-accent);
}
.pub-cta-section::before {
    content: '';
    position: absolute; inset: 0;
    background-image: radial-gradient(circle, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 36px 36px;
}
.pub-cta-section::after {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(ellipse 70% 50% at 50% 0%, rgba(217,119,6,.12) 0%, transparent 60%);
    pointer-events: none;
}
.pub-cta-title { font-size: clamp(28px, 4vw, 44px); font-weight: 800; color: #fff; margin-bottom: 16px; position: relative; z-index: 1; }
.pub-cta-sub { font-size: 18px; color: rgba(255,255,255,.75); margin-bottom: 40px; position: relative; z-index: 1; }
.pub-cta-actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; position: relative; z-index: 1; }
.pub-btn-white { background: #fff; color: var(--pub-primary); }
.pub-btn-white:hover { background: #f1f5f9; color: var(--pub-primary-dark); }
.pub-btn-white-outline { border: 2px solid rgba(255,255,255,.5); color: #fff; background: transparent; }
.pub-btn-white-outline:hover { background: rgba(255,255,255,.1); border-color: #fff; color: #fff; }

/* ── FOOTER ───────────────────────────────────────────────────────── */
.pub-footer { background: var(--pub-dark); padding: 64px 0 32px; border-top: 3px solid var(--pub-accent); }
.pub-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
.pub-footer-brand p { font-size: 14px; color: #64748b; line-height: 1.7; margin: 12px 0 0; max-width: 260px; }
.pub-footer-col-title { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: #94a3b8; margin-bottom: 16px; }
.pub-footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.pub-footer-col a { font-size: 14px; color: #64748b; text-decoration: none; transition: color .2s; }
.pub-footer-col a:hover { color: var(--pub-accent); }
.pub-footer-bottom { border-top: 1px solid rgba(255,255,255,.08); padding-top: 28px; display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; }
.pub-footer-copy { font-size: 13px; color: #475569; }
.pub-footer-links { display: flex; gap: 24px; }
.pub-footer-links a { font-size: 13px; color: #475569; text-decoration: none; }
.pub-footer-links a:hover { color: #94a3b8; }

/* USA trust bar in footer */
.pub-footer-trust { display: flex; flex-wrap: wrap; gap: 24px; align-items: center; padding: 20px 0; border-top: 1px solid rgba(255,255,255,.06); border-bottom: 1px solid rgba(255,255,255,.06); margin-bottom: 32px; }
.pub-footer-trust span { font-size: 12px; color: #64748b; display: flex; align-items: center; gap: 6px; }
.pub-footer-trust span i { color: var(--pub-accent); }
.pub-footer-trust .trust-flag { display: inline-flex; gap: 3px; align-items: center; }
.trust-flag-stripe { width: 5px; height: 14px; border-radius: 1px; }

/* ── PLAN SELECTED BANNER (in Register) ──────────────────────────── */
.plan-selected-banner { background: linear-gradient(135deg, rgba(29,78,216,.1) 0%, rgba(30,58,138,.06) 100%); border: 1.5px solid rgba(29,78,216,.3); border-radius: 12px; padding: 16px 20px; margin-bottom: 24px; }

/* ── RESPONSIVE ───────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .pub-plans-grid { grid-template-columns: repeat(2,1fr); }
    .pub-plan-card.popular { transform: none; }
    .pub-features-grid { grid-template-columns: repeat(2,1fr); }
    .pub-footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
    .pub-stats-grid { grid-template-columns: repeat(2,1fr); gap: 24px; }
}
@media (max-width: 768px) {
    .pub-nav-links { display: none; }
    .pub-plans-grid { grid-template-columns: 1fr; }
    .pub-features-grid { grid-template-columns: 1fr; }
    .pub-testimonials-grid { grid-template-columns: 1fr; }
    .pub-steps { grid-template-columns: 1fr; }
    .pub-steps::before { display: none; }
    .pub-footer-grid { grid-template-columns: 1fr; }
    .pub-stats-grid { grid-template-columns: repeat(2,1fr); }
    .pub-section { padding: 64px 0; }
    .pub-hero { padding: 64px 0; }
    .pub-hero-usa-bar { gap: 12px; }
}
