/* ==== BASE ===== */
:root {
  --or: #C5A55A;
  --or-clair: #E8D5A3;
  --or-fonce: #8B6914;
  --navy: #0D1B2A;
  --navy-mid: #1A2F45;
  --navy-clair: #243B55;
  --blanc: #F8F4ED;
  --blanc-pur: #FEFCF8;
  --gris: #8A9BB0;
  --gris-clair: #D4DDED;
  --texte: #2C3E50;
  --ombre: 0 20px 60px rgba(0,0,0,0.15);
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Cormorant Garamond', serif; background: var(--blanc); color: var(--texte); overflow-x:hidden; }

a, button { font-family:inherit; }

/* ========== TOPBAR ========== */
.topbar { background: var(--or); padding: 8px 40px; display:flex; justify-content:space-between; font-family:'Libre Baskerville', serif; font-size:12px; color:var(--navy); letter-spacing:0.05em; }
.topbar a { color:var(--navy); text-decoration:none;font-weight:700; }
.topbar a:hover { text-decoration:underline; }

/* ========== NAV ========== */
nav { background:var(--navy); position:sticky; top:0; z-index:1000; padding:0 40px; display:flex; justify-content:space-between; align-items:center; box-shadow:0 2px 20px rgba(0,0,0,0.4); transition:box-shadow 0.3s ease; }
nav.scrolled { box-shadow:0 4px 30px rgba(0,0,0,0.5); }
.nav-logo { display:flex; align-items:center; gap:14px; padding:18px 0; }
.nav-logo-icon { width:44px;height:44px;background:var(--or);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:var(--navy);position:relative;overflow:hidden; }
.nav-logo-text .title { font-family:'Playfair Display',serif;font-size:15px;font-weight:700;color:var(--blanc-pur);letter-spacing:.03em;line-height:1.2; }
.nav-logo-text .subtitle { font-size:11px; color:var(--or-clair); letter-spacing:.12em; text-transform:uppercase; }
.nav-links { display:flex; gap:0; list-style:none; }
.nav-links a { display:block; padding:24px 20px; color:var(--gris-clair); text-decoration:none; font-family:'Libre Baskerville',serif; font-size:12px; letter-spacing:.1em; text-transform:uppercase; position:relative; transition:color .3s; }
.nav-links a::after { content:''; position:absolute; bottom:0; left:50%; width:0; height:2px; background:var(--or); transform:translateX(-50%); transition:width .3s ease; }
.nav-links a:hover { color:var(--or-clair); }
.nav-links a:hover::after { width:60%; }
.nav-cta { background:var(--or); color:var(--navy); padding:12px 24px; border-radius:2px; font-weight:700; margin-left:10px; text-decoration:none; transition:background .3s ease; }
.nav-cta:hover { background:var(--or-clair); }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:10px; }
.hamburger span { width:26px; height:2px; background:var(--or); transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ========== HERO ========== */
.hero { position:relative; min-height:92vh; display:flex; align-items:center; overflow:hidden; background:var(--navy); }
.hero-bg { position:absolute; inset:0; background: radial-gradient(ellipse at 70% 50%, rgba(197,165,90,0.12) 0%, transparent 60%), radial-gradient(ellipse at 10% 80%, rgba(197,165,90,0.06) 0%, transparent 50%), linear-gradient(135deg, #0D1B2A 0%, #1A2F45 50%, #0D1B2A 100%); }
.hero-pattern { position:absolute; inset:0; opacity:0.04; background-image: repeating-linear-gradient(0deg,var(--or) 0,var(--or) 1px,transparent 1px,transparent 60px), repeating-linear-gradient(90deg,var(--or) 0,var(--or) 1px,transparent 1px,transparent 60px); }
.hero-seal { position:absolute; right:8%; top:50%; transform:translateY(-50%); width:380px; height:380px; opacity:0.07; animation:rotate-slow 40s linear infinite; }
@keyframes rotate-slow { 0% { transform:translateY(-50%) rotate(0deg);} 100% { transform:translateY(-50%) rotate(360deg);} }
.hero-content { position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:80px 40px; width:100%; }
.hero-badge { display:inline-flex; align-items:center; gap:10px; background:rgba(197,165,90,0.15); border:1px solid rgba(197,165,90,0.3); color:var(--or-clair); padding:8px 18px; font-size:11px; letter-spacing:.2em; text-transform:uppercase; margin-bottom:32px; border-radius:2px; animation:fade-up .8s ease both; }
.hero-name { font-family:'Playfair Display',serif; font-size:clamp(42px,6vw,80px); font-weight:400; color:var(--blanc-pur); line-height:1.05; margin-bottom:12px; animation:fade-up .8s .1s ease both; }
.hero-name em { color:var(--or); font-style:italic; }
.hero-title { font-family:'Cormorant Garamond',serif; font-size:clamp(18px,2.5vw,28px); color:var(--or-clair); font-weight:300; letter-spacing:.08em; margin-bottom:30px; animation:fade-up .8s .2s ease both; }
.hero-divider { width:80px; height:1px; background:linear-gradient(90deg,var(--or),transparent); margin-bottom:28px; animation:fade-up .8s .3s ease both; }
.hero-desc { font-size:17px; color:var(--gris-clair); max-width:520px; line-height:1.8; margin-bottom:44px; animation:fade-up .8s .4s ease both; }
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; animation:fade-up .8s .5s ease both; }
.btn-primary { background:var(--or); color:var(--navy); padding:16px 36px; font-family:'Libre Baskerville', serif; font-size:13px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; border:none; cursor:pointer; text-decoration:none; border-radius:2px; transition:all .3s ease; position:relative; overflow:hidden; }
.btn-primary::before { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent); transition:left .4s; }
.btn-primary:hover::before { left:100%; }
.btn-primary:hover { background:var(--or-clair); transform:translateY(-2px); box-shadow:0 8px 30px rgba(197,165,90,0.3); }
.btn-outline { background:transparent; color:var(--or-clair); padding:16px 36px; font-family:'Libre Baskerville', serif; font-size:13px; letter-spacing:.08em; text-transform:uppercase; border:1px solid rgba(197,165,90,0.5); cursor:pointer; border-radius:2px; transition:all .3s ease; }
.btn-outline:hover { border-color:var(--or); color:var(--or); background:rgba(197,165,90,0.05); transform:translateY(-2px); }
.hero-stats { position:absolute; bottom:0; left:0; right:0; background:rgba(197,165,90,0.1); border-top:1px solid rgba(197,165,90,0.2); display:flex; animation:fade-up .8s .6s ease both; }
.hero-stat { flex:1; padding:24px 30px; text-align:center; border-right:1px solid rgba(197,165,90,0.15); }
.hero-stat:last-child { border-right:none; }
.hero-stat-num { font-family:'Playfair Display',serif; font-size:32px; color:var(--or); font-weight:700; display:block; line-height:1; margin-bottom:4px; }
.hero-stat-label { font-size:11px; color:var(--gris); letter-spacing:.12em; text-transform:uppercase; font-family:'Libre Baskerville',serif; }

@keyframes fade-up { from { opacity:0; transform:translateY(24px);} to { opacity:1; transform:translateY(0);} }

/* ========== SECTIONS POSTERIEUR ========== */
section { padding:90px 40px; }
.container { max-width:1200px; margin:0 auto; }
.section-label { display:flex; align-items:center; gap:12px; margin-bottom:16px; color:var(--or); font-family:'Libre Baskerville',serif; font-size:11px; letter-spacing:.25em; text-transform:uppercase; }
.section-label::before { content:''; width:30px; height:1px; background:var(--or); }
.section-title { font-family:'Playfair Display',serif; font-size:clamp(30px,4vw,48px); font-weight:400; color:var(--navy); margin-bottom:20px; };
.section-title em { color:var(--or-fonce); font-style:italic; }
.section-sub { font-size:17px; color:#5a6e80; line-height:1.8; max-width:600px; margin-bottom:56px; }

.about { background:var(--blanc-pur); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-img-wrap { position:relative; }
.about-img-frame { position:relative; aspect-ratio:4/5; background:var(--navy); border-radius:3px; overflow:hidden; }
.photo-placeholder { width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; background:linear-gradient(160deg,var(--navy-mid) 0%,var(--navy) 100%); color:var(--or); gap:16px; }
.portrait-icon { font-size:80px; opacity:0.6; }
.portrait-name { font-family:'Playfair Display',serif; font-size:20px; color:var(--or-clair); text-align:center; font-style:italic; }
.portrait-grade { font-size:12px; color:var(--gris); letter-spacing:.1em; text-transform:uppercase; }
.about-badge-card { position:absolute; bottom:-24px; right:-24px; background:var(--or); color:var(--navy); padding:20px 24px; border-radius:3px; text-align:center; box-shadow:var(--ombre); }
.about-badge-card .num { font-family:'Playfair Display',serif; font-size:36px; font-weight:700; }
.about-badge-card .lbl { font-size:11px; font-family:'Libre Baskerville',serif; letter-spacing:.08em; }
.about-frame-deco { position:absolute; top:-16px; left:-16px; width:60%; height:60%; border:1px solid var(--or); border-right:none; border-bottom:none; opacity:0.4; }
.about-info { display:flex; flex-direction:column; gap:28px; }
.about-text { font-size:17px; line-height:1.9; color:#4a5a6a; }
.info-cards { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:8px; }
.info-card { background:var(--blanc); border:1px solid var(--gris-clair); border-left:3px solid var(--or); padding:18px 20px; border-radius:2px; }
.ic-label { font-size:10px; letter-spacing:.15em; text-transform:uppercase; color:var(--gris); margin-bottom:6px; }
.ic-value { font-family:'Playfair Display',serif; font-size:15px; color:var(--navy); font-weight:600; }

.services { background:var(--navy); }
.services .section-title { color:var(--blanc-pur); }
.services .section-sub { color:var(--gris); }
.services .section-label, .services .section-label::before { color:var(--or); }
.services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:20px; }
.service-card { background:var(--navy-mid); border:1px solid rgba(197,165,90,0.1); padding:36px 30px; border-radius:3px; position:relative; overflow:hidden; transition:all .4s ease; cursor:pointer; }
.service-card:hover { border-color:rgba(197,165,90,0.3); transform:translateY(-6px); box-shadow:0 20px 50px rgba(0,0,0,0.3); }
.service-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--or),var(--or-clair)); transform:scaleX(0); transform-origin:left; transition:transform .4s ease; }
.service-card:hover::before { transform:scaleX(1); }
.service-icon { width:54px; height:54px; background:rgba(197,165,90,0.1); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:22px; transition:background .3s; }
.service-card:hover .service-icon { background:rgba(197,165,90,0.2); }
.service-name { font-family:'Playfair Display',serif; font-size:20px; color:var(--blanc-pur); margin-bottom:12px; }
.service-desc { font-size:15px; color:var(--gris); line-height:1.7; }
.service-arrow { display:inline-flex; align-items:center; gap:6px; color:var(--or); font-size:12px; font-family:'Libre Baskerville',serif; letter-spacing:.08em; text-transform:uppercase; margin-top:20px; opacity:0; transition:opacity .3s; }
.service-card:hover .service-arrow { opacity:1; }

.temoignages { background:var(--blanc-pur); }
.temo-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; }
.temo-card { background:var(--blanc); border:1px solid var(--gris-clair); border-left:3px solid var(--or); padding:28px 26px; border-radius:3px; position:relative; }
.temo-quote { font-size:55px; color:rgba(13,27,42,0.15); margin-bottom:12px; }
.temo-stars { color:var(--or); font-size:14px; margin-bottom:14px; }
.temo-text { color:var(--navy); line-height:1.7; font-size:15px; margin-bottom:16px; }
.temo-author { display:flex; align-items:center; gap:12px; }
.temo-avatar { width:44px; height:44px; border-radius:50%; background:var(--navy); color:var(--blanc); display:flex; align-items:center; justify-content:center; font-weight:700; }
.temo-name { font-weight:700; color:var(--navy); }
.temo-loc { color:var(--gris); font-size:13px; }

.stats { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:0px; border-top:1px solid rgba(197,165,90,0.2); border-bottom:1px solid rgba(197,165,90,0.2); }
.stat-card { border-right:1px solid rgba(197,165,90,0.2); padding:24px 0; text-align:center; }
.stat-card:last-child { border-right:none; }
.stat-card h4 { font-family:'Playfair Display',serif; color:var(--or); font-size:2rem; margin:0; }
.stat-card p { color:var(--gris); margin:6px 0 0; }

.contact { background:var(--blanc); }
.contact-wrap { display:grid; grid-template-columns:1fr 1.1fr; gap:0; align-items:stretch; border-radius:4px; overflow:hidden; box-shadow:var(--ombre); }
.contact-map-wrap { position:relative; width:100%; height:500px; }
.contact-map { width:100%; height:100%; }
.contact-right { display:flex; flex-direction:column; gap:0; }
.contact-info { display:flex; flex-direction:column; gap:0; padding:36px 32px; border-bottom:1px solid var(--gris-clair); }
.contact-block { display:flex; gap:18px; padding:14px 0; align-items:flex-start; border-bottom:1px solid rgba(197,165,90,0.15); }
.contact-block:last-child { border-bottom:none; }
.contact-icon-wrap { width:48px; height:48px; background:var(--navy); border-radius:50%; color:var(--blanc); display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.contact-block-info .clabel { font-family:'Libre Baskerville',serif; font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--gris); margin-bottom:6px; }
.contact-block-info .cvalue { font-family:'Playfair Display',serif; font-size:17px; color:var(--navy); font-weight:600; }
.contact-block-info .cvalue a { color:var(--or); text-decoration:none; }
.contact-block-info .cvalue a:hover { text-decoration:underline; }
.contact-block-info .csub { font-size:13px; color:var(--gris); margin-top:3px; }
.contact-form-wrap { background:var(--navy); padding:32px 32px; position:relative; overflow:hidden; flex:1; display:flex; flex-direction:column; justify-content:flex-start; }
.contact-form-wrap::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--or-fonce),var(--or),var(--or-clair)); }
.form-title { font-family:'Playfair Display',serif; font-size:22px; color:var(--blanc-pur); margin-bottom:20px; font-style:italic; padding-top:4px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px; }
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:10px; }
.form-group label { font-family:'Libre Baskerville',serif; font-size:10px; letter-spacing:.15em; text-transform:uppercase; color:var(--gris); }
.form-group input, .form-group select, .form-group textarea { background:rgba(255,255,255,0.05); border:1px solid rgba(197,165,90,0.2); color:var(--blanc-pur); padding:11px 13px; font-family:'Cormorant Garamond',serif; font-size:14px; border-radius:2px; outline:none; transition:border-color .3s; width:100%; }
.form-group select option { background:var(--navy); color:var(--blanc-pur); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--or); background:rgba(197,165,90,0.08); }
.contact-form-wrap .btn-primary { margin-top:8px; padding:13px 32px; font-size:12px; }

.footer { background:var(--navy); color:var(--blanc-pur); padding:24px 40px; text-align:center; border-top:1px solid rgba(197,165,90,0.3); };
.float-phone { position:fixed; bottom:20px; right:20px; background:var(--or); color:var(--navy); border-radius:50%; padding:14px 16px; box-shadow:var(--ombre); text-decoration:none; font-size:20px; }

@media (max-width:992px) {
  .topbar { flex-wrap:wrap; align-items:center; padding:8px 16px; }
  .topbar span { width:100%; display:flex; justify-content:space-between; gap:8px; }
  .language-buttons { width:100%; justify-content:flex-start; margin-top:8px; }
  .about-grid { grid-template-columns:1fr; }
  .contact-wrap { grid-template-columns:1fr; }
  .contact-map-wrap { height:350px; }
  .nav-links { display:none; }
  .hamburger { display:flex; }
}

@media (max-width:768px) {
  section { padding:60px 20px; }
  .hero-content { padding:60px 20px; }
  .hero-stat { padding:18px 15px; }
  .form-row { grid-template-columns:1fr; }
  .contact-map-wrap { height:280px; }
  .contact-info { padding:24px 20px; }
  .contact-form-wrap { padding:24px 20px; }

  .nav-links.open { display:flex; position:absolute; top:100%; right:0; left:0; flex-direction:column; background:var(--navy); z-index:999; }
  .nav-links.open a { padding:16px 20px; border-top:1px solid rgba(255,255,255,0.08); }
  nav { padding:0 16px; }
  .nav-logo { padding:12px 0; }
}

/* classes existantes de boutons langue à rendre robuste sur mobile */
.language-buttons { display:flex; flex-wrap:wrap; gap:8px; }
.language-buttons button { background:var(--or); color: white; border: none; padding:6px 10px; border-radius:2px; cursor:pointer; }
.language-buttons button:hover { opacity:.9; }

