:root{
  --sapphire:#0d2147;
  --sapphire-deep:#081834;
  --sapphire-mid:#1a3a6b;
  --gold:#c9a227;
  --gold-light:#f4d58d;
  --ivory:#f7f3e9;
  --ivory-soft:#fbf8f0;
  --marble:#efe9dc;
  --ink:#1b1b24;
  --text:#33333d;
  --muted:#6a6a78;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);background:var(--ivory-soft);line-height:1.6;font-weight:300}
.container{width:min(1180px,92%);margin:0 auto}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;color:var(--sapphire);line-height:1.15}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(13,33,71,0.96);backdrop-filter:blur(8px);border-bottom:1px solid rgba(201,162,39,0.35)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:38px;height:38px}
.brand-name{font-family:var(--serif);font-size:1.45rem;font-weight:600;color:var(--ivory);letter-spacing:.5px}
.brand-name em{color:var(--gold-light);font-style:normal}
.main-nav{display:flex;gap:28px}
.main-nav a{color:var(--ivory);font-size:.92rem;letter-spacing:.5px;position:relative;padding:4px 0;transition:color .2s}
.main-nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold);transition:width .25s}
.main-nav a:hover{color:var(--gold-light)}
.main-nav a:hover::after{width:100%}
.nav-toggle{display:none;background:none;border:none;color:var(--ivory);font-size:1.6rem;cursor:pointer}

/* Hero */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;
  background:url('https://images.unsplash.com/photo-1519677100203-a0e668c92439?auto=format&fit=crop&w=1600&q=75') center/cover no-repeat;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(8,24,52,.94),rgba(13,33,71,.78) 55%,rgba(13,33,71,.5))}
.hero-content{position:relative;color:var(--ivory);padding:90px 0;max-width:760px}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:3px;font-size:.78rem;color:var(--gold-light);margin-bottom:18px;font-weight:500}
.eyebrow.center{text-align:center}
.hero h1{font-size:clamp(2.5rem,5.5vw,4.3rem);color:var(--ivory);font-weight:600;margin-bottom:22px}
.hero-sub{font-size:1.2rem;color:#e4ddcb;max-width:600px;margin-bottom:36px;font-weight:300}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}

/* Buttons */
.btn{display:inline-block;padding:14px 30px;font-family:var(--sans);font-size:.9rem;letter-spacing:1px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .25s;text-align:center}
.btn-gold{background:linear-gradient(135deg,var(--gold-light),var(--gold));color:var(--sapphire-deep)}
.btn-gold:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn-ghost{background:transparent;border-color:var(--gold);color:var(--gold-light)}
.btn-ghost:hover{background:rgba(201,162,39,.12)}
.btn.full{width:100%}
.btn.small{padding:10px 20px;font-size:.82rem}

/* Trust bar */
.trust{background:var(--sapphire);color:var(--ivory);padding:34px 0;border-bottom:3px solid var(--gold)}
.trust-row{display:flex;justify-content:space-around;gap:20px;flex-wrap:wrap;text-align:center}
.trust-row strong{display:block;font-family:var(--serif);font-size:2rem;color:var(--gold-light)}
.trust-row span{font-size:.85rem;letter-spacing:1px;color:#cfd6e6}

/* Sections */
.section{padding:90px 0}
.section-alt{background:var(--marble)}
.section-title{font-size:clamp(2rem,4vw,2.9rem);text-align:center;margin-bottom:14px}
.section-lead,.section-title+.section-lead{text-align:center;max-width:680px;margin:0 auto 50px;color:var(--muted)}
.center{text-align:center}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:28px;margin-top:46px}
.card{background:#fff;border:1px solid #e8e0cd;overflow:hidden;transition:transform .3s,box-shadow .3s}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(13,33,71,.13)}
.card img{height:190px;object-fit:cover;width:100%}
.card h3{font-size:1.4rem;margin:22px 24px 10px}
.card p{margin:0 24px 26px;color:var(--muted);font-size:.96rem}

/* Approche */
.approche-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.approche-img img{width:100%;height:100%;object-fit:cover;border:6px solid #fff;box-shadow:0 14px 40px rgba(13,33,71,.18)}
.steps{list-style:none;margin-top:30px;display:flex;flex-direction:column;gap:24px}
.steps li{display:flex;gap:18px;align-items:flex-start}
.steps span{font-family:var(--serif);font-size:1.6rem;color:var(--gold);min-width:42px}
.steps h4{font-size:1.25rem;margin-bottom:4px}
.steps p{color:var(--muted);font-size:.95rem}

/* Pricing */
.pricing{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px;margin-top:20px}
.plan{background:#fff;border:1px solid #e3d9c2;padding:38px 32px;position:relative;display:flex;flex-direction:column}
.plan.featured{border:2px solid var(--gold);box-shadow:0 16px 44px rgba(201,162,39,.18);transform:scale(1.02)}
.badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--gold-light),var(--gold));color:var(--sapphire-deep);font-size:.72rem;letter-spacing:1px;padding:6px 18px;text-transform:uppercase;font-weight:600}
.plan h3{font-size:1.6rem;margin-bottom:10px}
.price{font-family:var(--serif);font-size:2.4rem;color:var(--sapphire);font-weight:600;margin-bottom:6px}
.price span{font-size:1rem;color:var(--muted);font-family:var(--sans)}
.plan-desc{color:var(--muted);font-size:.92rem;margin-bottom:22px;min-height:48px}
.plan ul{list-style:none;margin-bottom:28px;flex-grow:1}
.plan ul li{padding:9px 0 9px 26px;position:relative;font-size:.95rem;border-bottom:1px solid #f0ebde}
.plan ul li::before{content:"❖";position:absolute;left:0;color:var(--gold)}
.pricing-note{text-align:center;margin-top:34px;color:var(--muted);font-size:.92rem}
.pricing-note a{color:var(--sapphire-mid);text-decoration:underline}

/* Quotes */
.quotes{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px;margin-top:46px}
blockquote{background:#fff;border-top:3px solid var(--gold);padding:34px 30px}
blockquote p{font-family:var(--serif);font-size:1.2rem;font-style:italic;color:var(--ink);margin-bottom:18px}
blockquote footer{font-size:.88rem;color:var(--muted);letter-spacing:.5px}

/* Contact */
.contact-section{background:var(--sapphire);color:var(--ivory)}
.contact-section .section-title,.contact-section h2{color:var(--ivory)}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:start}
.contact-info h2{text-align:left}
.contact-info p{color:#d4dbeb;margin-bottom:28px}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:20px}
.contact-list li{display:flex;flex-direction:column}
.contact-list strong{color:var(--gold-light);font-family:var(--serif);font-size:1.15rem;margin-bottom:2px}
.contact-list a,.contact-list span{color:#e4ddcb}
.contact-form{background:#fff;padding:38px 34px;color:var(--text)}
.field{margin-bottom:18px}
.field label{display:block;font-size:.85rem;letter-spacing:.5px;margin-bottom:6px;color:var(--sapphire);font-weight:500}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid #d8d0bd;font-family:var(--sans);font-size:.95rem;background:var(--ivory-soft);transition:border .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;color:var(--muted);margin-bottom:22px}
.consent a{color:var(--sapphire-mid);text-decoration:underline}
.form-status{margin-top:14px;font-size:.9rem;font-weight:500;color:var(--sapphire-mid)}

/* Footer */
.site-footer{background:var(--sapphire-deep);color:#c2cadb;padding:60px 0 26px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1.2fr 1fr;gap:36px}
.footer-brand .brand-name{font-size:1.3rem}
.footer-note{margin-top:14px;font-size:.9rem;max-width:280px;color:#9aa4ba}
.site-footer h4{color:var(--gold-light);font-size:1.1rem;margin-bottom:14px}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.site-footer ul a:hover{color:var(--gold-light)}
.site-footer li{font-size:.9rem;line-height:1.5}
.footer-bottom{display:flex;justify-content:space-between;border-top:1px solid rgba(201,162,39,.25);margin-top:44px;padding-top:22px;font-size:.85rem;color:#8a93a8}

/* Cookie banner */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:100;background:rgba(8,24,52,.98);border-top:2px solid var(--gold);color:var(--ivory);padding:18px 0;display:none;align-items:center;justify-content:center;gap:26px;flex-wrap:wrap}
.cookie-banner.show{display:flex}
.cookie-banner p{font-size:.9rem;max-width:680px;color:#dde3f0}
.cookie-banner a{color:var(--gold-light);text-decoration:underline}
.cookie-actions{display:flex;gap:12px}

/* Legal pages */
.legal-hero{background:var(--sapphire);color:var(--ivory);padding:70px 0 50px}
.legal-hero h1{color:var(--ivory);font-size:clamp(2rem,4vw,3rem)}
.legal-hero p{color:#cfd6e6;margin-top:10px}
.legal-body{padding:60px 0;max-width:840px}
.legal-body h2{font-size:1.7rem;margin:36px 0 12px}
.legal-body p,.legal-body li{color:var(--text);margin-bottom:12px}
.legal-body ul{padding-left:24px;margin-bottom:14px}
.legal-back{display:inline-block;margin-top:30px;color:var(--sapphire-mid);text-decoration:underline}

@media(max-width:860px){
  .main-nav{position:absolute;top:100%;right:0;left:0;background:var(--sapphire-deep);flex-direction:column;gap:0;padding:0;max-height:0;overflow:hidden;transition:max-height .3s}
  .main-nav.open{max-height:340px;padding:10px 0}
  .main-nav a{padding:14px 24px;border-bottom:1px solid rgba(201,162,39,.15)}
  .nav-toggle{display:block}
  .approche-grid,.contact-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .plan.featured{transform:none}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:6px;text-align:center}
  .hero{min-height:80vh}
}
