/* ===== Réservation VTC Yvelines — feuille de style partagée ===== */
:root{
  --navy:#1f2a44; --navy-2:#172036; --navy-soft:#2c3a5c;
  --gold:#c2a46f; --gold-2:#d8c39a; --gold-deep:#a98a52;
  --cream:#f0f1f4; --stone:#e8e7e6; --ink:#1b1b1b; --muted:#5b6172; --line:#e7e4dd; --ok:#2f7d5b;
  --radius:16px; --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Open Sans',Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.7;font-size:16px;overflow-x:hidden;}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;color:var(--navy);line-height:1.14;font-weight:700;text-wrap:balance;}
a{text-decoration:none;color:inherit;}
p{text-wrap:pretty;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px;}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:12px;letter-spacing:.3em;text-transform:uppercase;font-weight:700;color:var(--navy);}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);}
.eyebrow.center{justify-content:center;}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--gold);}
.eyebrow.light{color:var(--gold-2);}
.eyebrow.light::before{background:var(--gold-2);}
.eyebrow.light.center::after{background:var(--gold-2);}

.btn{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:15px;padding:15px 28px;border-radius:50px;transition:.25s;cursor:pointer;border:1.5px solid transparent;font-family:'Open Sans',sans-serif;background:none;}
.btn-gold{background:var(--gold);color:var(--navy);}
.btn-gold:hover{background:var(--gold-deep);color:#fff;transform:translateY(-2px);box-shadow:0 12px 26px rgba(169,138,82,.35);}
.btn-ghost{border-color:rgba(255,255,255,.4);color:#fff;}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:#fff;}
.btn-outline{border-color:var(--navy);color:var(--navy);}
.btn-outline:hover{background:var(--navy);color:#fff;}
.btn svg{width:18px;height:18px;}

/* ===== Accessibilité : focus visible & placeholders ===== */
:focus-visible{outline:2px solid var(--navy);outline-offset:2px;border-radius:6px;}
.hero :focus-visible,.page-hero :focus-visible,.cta-band :focus-visible,footer :focus-visible{outline-color:var(--gold-2);}
input::placeholder,textarea::placeholder{color:var(--muted);}

/* ===== Header ===== */
header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--line);transition:all .35s ease;}
.nav{display:flex;align-items:center;justify-content:space-between;height:108px;transition:height .35s ease;}
.nav .logo img{height:66px;width:auto;transition:height .35s ease;}
header.scrolled{background:rgba(255,255,255,.6);backdrop-filter:blur(16px) saturate(140%);border-bottom-color:rgba(231,228,221,.35);box-shadow:none;}
header.scrolled .nav{height:74px;}
header.scrolled .nav .logo img{height:48px;}
.nav ul{list-style:none;display:flex;gap:30px;align-items:center;}
.nav ul a{font-size:14.5px;font-weight:600;color:var(--navy);position:relative;padding:4px 0;}
.nav ul a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--gold);transition:.25s;}
.nav ul a:hover::after,.nav ul a.current::after{width:100%;}
.nav-right{display:flex;align-items:center;gap:18px;}
.nav-phone{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--navy);font-size:15px;}
.nav-phone svg{width:17px;height:17px;color:var(--gold-deep);}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.burger span{width:24px;height:2px;background:var(--navy);transition:.3s;}

/* ===== Page hero (bannière intérieure, image + overlay) ===== */
.page-hero{position:relative;background:var(--navy);background-size:cover;background-position:center;color:#fff;overflow:hidden;padding:104px 0 108px;text-align:center;}
.page-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(31,42,68,.86),rgba(16,23,42,.80));pointer-events:none;}
.page-hero .wrap{position:relative;z-index:2;}
.page-hero h1{color:#fff;font-size:clamp(34px,4.6vw,52px);font-weight:800;letter-spacing:-.5px;margin:0 0 14px;}
.page-hero p{color:#e7e9ef;font-weight:300;font-size:17px;max-width:56ch;margin:0 auto;}
.crumb{font-size:13px;color:#9aa2b5;margin-bottom:14px;}
.crumb a:hover{color:var(--gold-2);}

/* ===== Sections ===== */
section.block{padding:90px 0;}
.sec-head{max-width:680px;margin-bottom:46px;}
.sec-head.center{margin:0 auto 46px;text-align:center;}
.sec-head h2{font-size:clamp(28px,3.4vw,40px);margin:14px 0 14px;}
.sec-head p{color:var(--muted);font-size:16.5px;}
.bg-cream{background:var(--cream);}

/* Prose (pages texte / légal) */
.prose{max-width:75ch;margin:0 auto;}
.prose h2{font-size:24px;margin:38px 0 12px;}
.prose h3{font-size:18px;margin:24px 0 8px;}
.prose p{color:#3c4252;margin-bottom:14px;}
.prose ul{margin:0 0 16px 22px;color:#3c4252;}
.prose li{margin:6px 0;}
.prose .updated{color:var(--muted);font-size:13px;margin-bottom:24px;}
.prose .box{background:#faf6ee;border:1px solid rgba(194,164,111,.45);border-radius:12px;padding:16px 20px;margin:18px 0;font-size:14.5px;color:#3c4252;}
.prose a{color:var(--navy);font-weight:600;text-decoration:underline;}

/* Values */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.value{padding:38px 32px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;transition:.3s;}
.value:hover{box-shadow:0 18px 44px rgba(31,42,68,.1);transform:translateY(-4px);}
.value .vic{width:60px;height:60px;border-radius:50%;background:var(--cream);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold-deep);margin-bottom:20px;}
.value .vic svg{width:28px;height:28px;}
.value h3{font-size:22px;margin-bottom:12px;}
.value p{font-size:14.5px;color:var(--muted);}

/* Story */
.story{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center;}
.story .photo{border-radius:24px;overflow:hidden;position:relative;aspect-ratio:4/4.6;box-shadow:0 30px 60px rgba(31,42,68,.18);}
.story .photo img{width:100%;height:100%;object-fit:cover;}
.story .photo .badge{position:absolute;bottom:20px;left:20px;right:20px;background:rgba(23,32,54,.72);border:1px solid rgba(194,164,111,.4);border-radius:14px;padding:16px 20px;backdrop-filter:blur(8px);}
.story .photo .badge b{color:#fff;font-family:'Playfair Display',serif;font-size:18px;}
.story .photo .badge span{color:var(--gold-2);font-size:13px;}
.story h2{font-size:clamp(26px,3.2vw,38px);margin:14px 0 18px;}
.story p{color:var(--muted);margin-bottom:16px;}
.sign{font-family:'Playfair Display',serif;font-style:italic;font-size:22px;color:var(--gold-deep);}

/* Blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.post{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;transition:.3s;display:flex;flex-direction:column;}
.post:hover{transform:translateY(-5px);box-shadow:0 20px 46px rgba(31,42,68,.1);}
.post .thumb{height:200px;overflow:hidden;}
.post .thumb img{width:100%;height:100%;object-fit:cover;transition:.4s;}
.post:hover .thumb img{transform:scale(1.06);}
.post .body{padding:26px;display:flex;flex-direction:column;flex:1;}
.post .date{font-size:12px;color:var(--navy);font-weight:700;text-transform:uppercase;letter-spacing:.08em;}
.post h3{font-size:20px;margin:10px 0 10px;}
.post p{font-size:14px;color:var(--muted);margin-bottom:16px;}
.post .more{margin-top:auto;font-weight:700;color:var(--navy);font-size:14px;display:inline-flex;align-items:center;gap:7px;}
.post .more svg{width:16px;height:16px;color:var(--gold-deep);}
.badge-soon{display:inline-block;background:var(--cream);border:1px solid var(--line);color:var(--navy);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:4px 10px;border-radius:20px;}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:46px;align-items:start;}
.cinfo .ci{display:flex;gap:16px;align-items:center;padding:18px 0;border-bottom:1px solid var(--line);}
.cinfo .ci:last-child{border-bottom:none;}
.cinfo .ci .ic{width:50px;height:50px;border-radius:13px;background:var(--navy);color:var(--gold-2);display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.cinfo .ci .ic svg{width:23px;height:23px;}
.cinfo .ci b{display:block;font-family:'Playfair Display',serif;font-size:17px;color:var(--navy);margin-bottom:2px;}
.cinfo .ci a,.cinfo .ci span{color:var(--muted);font-size:14.5px;}
.cinfo .ci a:hover{color:var(--gold-deep);}
.form{background:#fff;border:1px solid var(--line);border-radius:20px;padding:34px;box-shadow:0 20px 50px rgba(31,42,68,.07);}
.form .label{display:block;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:0 0 8px;}
.form .fr{margin-bottom:18px;}
.form .two{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form input,.form textarea,.form select{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font-size:15px;font-family:'Open Sans',sans-serif;color:var(--navy);background:#fff;transition:.2s;}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--gold);}
.form textarea{resize:vertical;min-height:120px;}
.form .btn{width:100%;justify-content:center;margin-top:6px;}
.note{font-size:12.5px;color:var(--muted);margin-top:12px;text-align:center;}
.optchips{display:flex;flex-wrap:wrap;gap:10px;}
.optchips label{display:inline-flex;align-items:center;gap:9px;border:1.5px solid var(--line);border-radius:11px;padding:10px 15px;font-size:14px;color:var(--navy);cursor:pointer;transition:.2s;}
.optchips label:hover{border-color:var(--gold);}
.optchips input{accent-color:var(--gold-deep);width:16px;height:16px;}
.map{margin-top:24px;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(135deg,#e9eef5,#dde4ee);height:230px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px;text-align:center;padding:20px;}

/* CTA band */
.cta-band{position:relative;background:linear-gradient(135deg,#243150,var(--navy) 55%,#10172a);border-radius:28px;padding:64px 54px;overflow:hidden;text-align:center;box-shadow:inset 0 0 0 1px rgba(194,164,111,.22);}
.cta-band::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(194,164,111,.13) 1px,transparent 1px);background-size:22px 22px;opacity:.55;pointer-events:none;}
.cta-band::after{content:"";position:absolute;top:26px;right:36px;width:62px;height:62px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 0 L13.6 10.4 L24 12 L13.6 13.6 L12 24 L10.4 13.6 L0 12 L10.4 10.4 Z' fill='%23c2a46f'/%3E%3C/svg%3E") center/contain no-repeat;opacity:.22;pointer-events:none;}
.cta-band>*{position:relative;z-index:2;}
.cta-band h2{color:#fff;font-size:clamp(26px,3.2vw,38px);margin:12px 0 12px;}
.cta-band p{color:#cdd2de;max-width:46ch;margin:0 auto 26px;font-weight:300;}

/* Footer */
footer{background:var(--navy-2);color:#aeb5c6;padding:70px 0 0;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:50px;}
footer .logo img{height:64px;width:auto;margin-bottom:18px;}
footer p{font-size:14px;color:#9aa2b5;}
footer h4{color:#fff;font-size:15px;letter-spacing:.04em;margin-bottom:18px;font-family:'Open Sans',sans-serif;font-weight:700;text-transform:uppercase;}
footer ul{list-style:none;}
footer ul li{margin:10px 0;}
footer ul a{font-size:14px;color:#aeb5c6;transition:.2s;}
footer ul a:hover{color:var(--gold-2);}
.foot-contact div{display:flex;gap:11px;margin:12px 0;font-size:14px;align-items:flex-start;}
.foot-contact svg{width:17px;height:17px;color:var(--gold);flex:0 0 auto;margin-top:3px;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.08);padding:22px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12.5px;color:#7b8295;}
.foot-bottom a{color:#7b8295;}
.foot-bottom a:hover{color:var(--gold-2);}
.foot-bottom .legal-links a{margin-left:16px;}

@media(max-width:980px){
  .values,.blog-grid{grid-template-columns:1fr 1fr;}
  .story,.contact-grid{grid-template-columns:1fr;gap:36px;}
  .foot-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:680px){
  .nav ul,.nav-phone{display:none;}
  .burger{display:flex;}
  .nav ul.open{display:flex;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:20px 26px;gap:18px;box-shadow:0 18px 30px rgba(31,42,68,.12);border-top:1px solid var(--line);}
  .values,.blog-grid,.foot-grid,.form .two{grid-template-columns:1fr;}
  section.block{padding:60px 0;}
  .cta-band{padding:44px 26px;}
}

/* ===== Services détaillés ===== */
.svc-list{display:grid;gap:20px;max-width:920px;margin:0 auto;}
.svc-row{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;border:1px solid var(--line);border-radius:var(--radius);padding:28px 32px;background:#fff;transition:.25s;cursor:pointer;}
.svc-row:hover{box-shadow:0 18px 44px rgba(31,42,68,.1);border-color:var(--gold);}
.svc-row.open{box-shadow:0 18px 44px rgba(31,42,68,.1);border-color:var(--gold);}
.svc-top{display:flex;justify-content:space-between;align-items:center;gap:14px;}
.chev{flex:0 0 auto;width:32px;height:32px;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold-deep);transition:.3s;}
.chev svg{width:16px;height:16px;transition:transform .3s;}
.svc-row.open .chev{background:var(--gold);border-color:var(--gold);color:var(--navy);}
.svc-row.open .chev svg{transform:rotate(180deg);}
.svc-detail{max-height:0;overflow:hidden;transition:max-height .4s ease;}
.svc-row.open .svc-detail{max-height:820px;}
.svc-detail .lead-d{color:#3c4252;font-size:14.5px;margin:14px 0 2px;}
.svc-detail ul{margin:16px 0 2px;padding-left:20px;}
.svc-detail li{color:var(--muted);font-size:14px;margin:7px 0;}
.svc-hint{text-align:center;color:var(--muted);font-size:13.5px;margin-bottom:26px;display:flex;align-items:center;justify-content:center;gap:8px;}
.svc-hint svg{width:16px;height:16px;color:var(--gold-deep);}
.svc-row .ic{width:62px;height:62px;border-radius:15px;background:var(--navy);color:var(--gold-2);display:flex;align-items:center;justify-content:center;flex:0 0 auto;transition:.25s;}
.svc-row:hover .ic{background:var(--gold);color:var(--navy);}
.svc-row .ic svg{width:30px;height:30px;}
.svc-row h3{font-size:21px;margin-bottom:8px;}
.svc-row p{color:var(--muted);font-size:14.5px;margin:0;}
.zones{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:8px;}
.zones span,.zones a{background:#fff;border:1px solid var(--line);border-radius:30px;padding:9px 18px;font-size:13.5px;color:var(--navy);font-weight:600;cursor:default;transition:.25s;}
.zones a{cursor:pointer;}
.zones span:hover,.zones a:hover{background:var(--navy);color:var(--gold-2);border-color:var(--navy);transform:translateY(-3px);box-shadow:0 10px 22px rgba(31,42,68,.18);}
@media(max-width:600px){.svc-row{grid-template-columns:1fr;}}

/* ===== Animations d'apparition ===== */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);will-change:opacity,transform;}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important;}}

/* ===== Pages locales : trajets fréquents ===== */
.local-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.local-card{border:1px solid var(--line);border-radius:var(--radius);padding:24px;background:#fff;}
.local-card .ic{width:46px;height:46px;border-radius:11px;background:var(--cream);border:1px solid var(--line);color:var(--gold-deep);display:flex;align-items:center;justify-content:center;margin-bottom:14px;}
.local-card .ic svg{width:22px;height:22px;}
.local-card h3{font-size:17px;margin-bottom:6px;}
.local-card p{font-size:13.5px;color:var(--muted);margin:0;}
@media(max-width:980px){.local-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.local-grid{grid-template-columns:1fr;}}

/* ===== Effets & micro-interactions ===== */
.btn-gold{position:relative;overflow:hidden;}
.btn-gold::after{content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.3),transparent);transform:skewX(-18deg);transition:left .6s ease;pointer-events:none;}
.btn-gold:hover::after{left:150%;}
.svc .ic,.svc-row .ic,.local-card .ic,.value .vic,.strip .item .ic{transition:transform .3s ease,background .25s,color .25s;}
.svc:hover .ic,.svc-row:hover .ic,.local-card:hover .ic{transform:scale(1.08) rotate(-3deg);}
.value:hover .vic{transform:translateY(-3px) scale(1.06);}
.story .photo img,.feature .visual img{transition:transform .8s cubic-bezier(.22,1,.36,1);}
.story .photo:hover img,.feature .visual:hover img{transform:scale(1.05);}
.news .thumb img{transition:transform .5s cubic-bezier(.22,1,.36,1);}
.news:hover .thumb img{transform:scale(1.06);}
.post .more svg{transition:transform .3s ease;}
.post:hover .more svg{transform:translateX(4px);}
@media(prefers-reduced-motion:reduce){.btn-gold::after{display:none;}.svc:hover .ic,.svc-row:hover .ic,.local-card:hover .ic,.value:hover .vic,.story .photo:hover img,.feature .visual:hover img,.news:hover .thumb img,.post:hover .more svg{transform:none;}}
@media(max-width:680px){.nav-right .btn-gold{display:none;}}

@media(max-width:680px){.nav .logo img{height:50px;}}
