/* finlvc-france.cyou — Portail immobilier & crédit
   Palette: #6b1a2a (bordeaux), #d4a96a (or chaud), #f5ede0 (beige)
   Layout: sidebar-left | Nav: pills | Structure: comparison-table | SVG: architectural */
:root {
  --primary: #6b1a2a;
  --primary-light: #8b2a3a;
  --accent: #d4a96a;
  --accent-light: #e8c48a;
  --text-dark: #1a1010;
  --text-muted: #6a5a5a;
  --bg-light: #f5ede0;
  --bg-white: #ffffff;
  --border: #e0cfc0;
  --positive: #1b5e20;
  --negative: #b71c1c;
}
body { font-family: 'Georgia', serif; color: var(--text-dark); background: var(--bg-light); }
.navbar { background: var(--primary) !important; }
.navbar-brand { font-weight: 700; font-size: 1.4rem; color: #fff !important; }
.navbar-brand span { color: var(--accent-light); }
.nav-link { color: rgba(255,255,255,.85) !important; }
.nav-link:hover, .nav-link.active { color: var(--accent-light) !important; }
/* Pill nav */
.pill-nav .nav-link { border-radius: 20px; margin: 0 .2rem; color: var(--primary) !important; background: var(--bg-white); border: 1px solid var(--border); }
.pill-nav .nav-link.active { background: var(--primary); color: #fff !important; border-color: var(--primary); }
.hero-section { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%); color: #fff; padding: 4rem 0 3rem; }
.hero-section h1 { font-size: 2.4rem; font-weight: 700; line-height: 1.2; }
/* Sidebar layout */
.sidebar { background: var(--bg-white); border: 1px solid var(--border); border-radius: 8px; padding: 1.5rem; position: sticky; top: 80px; }
.sidebar h5 { color: var(--primary); font-weight: 700; border-bottom: 2px solid var(--accent); padding-bottom: .5rem; margin-bottom: 1rem; }
.sidebar ul li { padding: .3rem 0; border-bottom: 1px solid var(--border); }
.sidebar ul li:last-child { border-bottom: none; }
.sidebar a { color: var(--primary); text-decoration: none; }
.sidebar a:hover { color: var(--accent); }
.section-title { font-size: 1.7rem; font-weight: 700; color: var(--primary); margin-bottom: 1.5rem; }
.section-title::after { content: ''; display: block; width: 60px; height: 3px; background: var(--accent); margin-top: .3rem; }
.card { border: 1px solid var(--border); border-radius: 8px; background: var(--bg-white); }
.card-header { background: var(--primary); color: #fff; font-weight: 600; border-radius: 8px 8px 0 0 !important; }
.table-custom thead { background: var(--primary); color: #fff; }
.table-custom tbody tr:nth-child(even) { background: var(--bg-light); }
.table-custom td, .table-custom th { padding: .65rem 1rem; border: 1px solid var(--border); }
.table-custom .pos { color: var(--positive); font-weight: 600; }
.table-custom .neg { color: var(--negative); font-weight: 600; }
.related-block { background: var(--bg-light); border: 1px solid var(--border); border-radius: 8px; padding: 1.25rem; }
.related-block h5 { color: var(--primary); font-weight: 700; margin-bottom: .75rem; }
.seq-nav { display: flex; justify-content: space-between; align-items: center; padding: 1rem 0; border-top: 2px solid var(--border); margin-top: 2rem; }
.seq-nav a { color: var(--primary); font-weight: 600; text-decoration: none; }
.seq-nav a:hover { color: var(--accent); }
.checklist li { padding: .4rem 0; border-bottom: 1px solid var(--border); }
.checklist li:last-child { border-bottom: none; }
.checklist li::before { content: '✓ '; color: var(--positive); font-weight: 700; }
.alert-info-custom { background: #fdf0e0; border-left: 4px solid var(--accent); color: var(--text-dark); border-radius: 4px; padding: 1rem 1.25rem; }
.breadcrumb-custom { background: none; padding: .5rem 0; font-size: .9rem; }
.breadcrumb-item a { color: rgba(255,255,255,.8); }
footer { background: var(--primary); color: rgba(255,255,255,.85); padding: 3rem 0 1.5rem; }
footer a { color: var(--accent-light); text-decoration: none; }
footer a:hover { color: #fff; }
footer .footer-title { color: #fff; font-weight: 700; font-size: 1.05rem; margin-bottom: 1rem; }
#cookie-banner { position: fixed; bottom: 0; left: 0; right: 0; background: var(--primary); color: #fff; padding: 1rem 1.5rem; z-index: 9999; display: none; }
@media (max-width: 768px) { .hero-section h1 { font-size: 1.7rem; } .section-title { font-size: 1.3rem; } }
