:root{
    --premium-gold:#c9a87c;
    --premium-gold-deep:#b89364;
    --premium-ink:#181615;
    --premium-soft:#f8f4ef;
    --premium-line:rgba(201,168,124,.18);
    --premium-shadow:0 18px 60px rgba(18,14,10,.10);
    --premium-shadow-hover:0 22px 72px rgba(18,14,10,.14);
}
body{
    background:linear-gradient(180deg,#fff 0%,#fbf8f4 100%);
}
.header.scrolled{
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border-bottom:1px solid rgba(0,0,0,.05);
}
.nav-link::after,.dropdown-link::after{
    content:'';
    position:absolute;
    left:0;
    bottom:-2px;
    width:0;
    height:1px;
    background:var(--premium-gold);
    transition:width .25s ease;
}
.nav-link:hover::after{width:100%;}
.logo{letter-spacing:4px;text-shadow:0 2px 14px rgba(0,0,0,.12);}
.header.scrolled .logo{text-shadow:none;}
.btn,
.contact-form button,
button[type="submit"]{
    border-radius:999px!important;
    padding:16px 30px!important;
    font-weight:600!important;
    letter-spacing:1.8px!important;
    box-shadow:0 10px 30px rgba(201,168,124,.18);
}
.btn:hover,
.contact-form button:hover,
button[type="submit"]:hover{
    transform:translateY(-2px);
    box-shadow:0 16px 38px rgba(201,168,124,.24);
}
.section-title,
.resa-step-title{
    letter-spacing:2px;
}
.section-subtitle{
    letter-spacing:3px;
}
.service-card,
.tarif-card,
.partner-card,
.about-home-content,
.testimonial-slide,
.portfolio-item,
.gallery-item,
.booking-card,
.booking-side,
.contact-form,
.contact-info,
.resa-form-wrap,
.resa-price-recap,
.resa-pay-options,
.resa-cgv-block,
.resa-cgv-check{
    border-radius:28px!important;
    box-shadow:var(--premium-shadow);
    border:1px solid var(--premium-line)!important;
}
.service-card,
.portfolio-item,
.gallery-item,
.tarif-card,
.partner-card,
.testimonial-slide,
.resa-pay-card,
.resa-form-wrap,
.resa-price-recap,
.resa-pay-options,
.resa-cgv-block{
    transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.service-card:hover,
.portfolio-item:hover,
.gallery-item:hover,
.tarif-card:hover,
.partner-card:hover,
.testimonial-slide:hover,
.resa-pay-card:hover,
.resa-form-wrap:hover,
.resa-price-recap:hover,
.resa-pay-options:hover,
.resa-cgv-block:hover{
    transform:translateY(-4px);
    box-shadow:var(--premium-shadow-hover);
    border-color:rgba(201,168,124,.28)!important;
}
.about-home-section,
.tarifs-home,
.partner-section,
.portfolio-section,
.testimonials-slider-section,
.contact-section,
.booking-section,
.resa-section{
    position:relative;
}
.footer{
    border-top:1px solid rgba(255,255,255,.08);
}
.footer-overlay{
    background:linear-gradient(180deg, rgba(10,10,10,.72), rgba(10,10,10,.88));
}
.footer-content{
    position:relative;
    z-index:2;
}
.footer-about,
.footer-nav,
.footer-contact{
    padding:8px 0;
}
.social-links a{
    backdrop-filter:blur(6px);
    -webkit-backdrop-filter:blur(6px);
    box-shadow:0 10px 28px rgba(0,0,0,.18);
}
input, textarea, select{
    border-radius:18px!important;
}
input:focus, textarea:focus, select:focus{
    outline:none;
    border-color:rgba(201,168,124,.75)!important;
    box-shadow:0 0 0 5px rgba(201,168,124,.12);
}
body.dark .service-card,
body.dark .tarif-card,
body.dark .partner-card,
body.dark .about-home-content,
body.dark .testimonial-slide,
body.dark .portfolio-item,
body.dark .gallery-item,
body.dark .booking-card,
body.dark .booking-side,
body.dark .contact-form,
body.dark .contact-info,
body.dark .resa-form-wrap,
body.dark .resa-price-recap,
body.dark .resa-pay-options,
body.dark .resa-cgv-block,
body.dark .resa-cgv-check{
    box-shadow:0 18px 48px rgba(0,0,0,.26);
    border-color:rgba(255,255,255,.08)!important;
}
.v2-premium-panel{
    max-width:1280px;
    margin:0 auto;
    padding:0 40px;
}
.v2-trust-bar{
    margin:-54px auto 0;
    position:relative;
    z-index:5;
}
.v2-trust-card{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:18px;
    background:rgba(255,255,255,.92);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border:1px solid rgba(201,168,124,.22);
    box-shadow:0 20px 60px rgba(14,10,7,.12);
    border-radius:30px;
    padding:20px;
}
.v2-trust-item{
    padding:18px 18px 16px;
    border-radius:22px;
    background:linear-gradient(180deg,#fff,#faf6f1);
    border:1px solid rgba(201,168,124,.12);
}
.v2-trust-item strong{
    display:block;
    margin-bottom:6px;
    font-family:'Playfair Display',serif;
    font-size:22px;
    color:#171513;
}
.v2-trust-item span{
    display:block;
    color:#5f564f;
    font-size:14px;
    line-height:1.7;
}
.v2-hero-actions{
    display:flex;
    gap:14px;
    justify-content:center;
    align-items:center;
    margin-top:26px;
    flex-wrap:wrap;
}
.v2-btn-ghost{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:15px 26px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.32);
    color:#fff;
    text-decoration:none;
    letter-spacing:1.6px;
    text-transform:uppercase;
    font-size:12px;
    background:rgba(255,255,255,.08);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    transition:all .25s ease;
}
.v2-btn-ghost:hover{transform:translateY(-2px);background:rgba(255,255,255,.14);}
.v2-hero-kicker{
    margin-top:18px;
    color:rgba(255,255,255,.88);
    font-size:13px;
    letter-spacing:1.2px;
}
.v2-booking-intro{
    margin:0 0 26px;
    padding:22px;
    border-radius:28px;
    background:linear-gradient(135deg, rgba(201,168,124,.10), rgba(255,255,255,.92));
    border:1px solid rgba(201,168,124,.20);
    box-shadow:var(--premium-shadow);
}
.v2-booking-intro h3{
    font-family:'Playfair Display',serif;
    font-size:28px;
    line-height:1.2;
    margin-bottom:10px;
    color:#151311;
}
.v2-booking-intro p{
    color:#5f564f;
    line-height:1.85;
    margin-bottom:16px;
}
.v2-booking-points{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:12px;
}
.v2-booking-point{
    background:#fff;
    border:1px solid rgba(201,168,124,.14);
    border-radius:18px;
    padding:14px 16px;
}
.v2-booking-point strong{
    display:block;
    margin-bottom:5px;
    font-size:14px;
    color:#1a1714;
}
.v2-booking-point span{
    display:block;
    font-size:13px;
    color:#6a625b;
    line-height:1.7;
}
.resa-pay-card{
    border-radius:24px!important;
    overflow:hidden;
}
.resa-pay-card input:checked + .resa-pay-card-inner,
.resa-pay-card.active .resa-pay-card-inner{
    background:linear-gradient(180deg,rgba(201,168,124,.16),rgba(255,255,255,.96));
    border-color:rgba(201,168,124,.40)!important;
}
.resa-pay-card-inner{
    border-radius:24px;
}
.resa-pay-btn-main,
.resa-pay-btn-secondary,
.resa-pay-btn-ghost{
    border-radius:999px!important;
    min-height:58px;
    font-size:12px!important;
    letter-spacing:1.4px!important;
    box-shadow:0 14px 30px rgba(18,14,10,.10);
}
.resa-payment-note,
.resa-form-hint,
.resa-recap-note{
    background:rgba(201,168,124,.08);
    border:1px solid rgba(201,168,124,.18);
    border-radius:20px;
    padding:14px 16px;
}
.resa-form-hint{margin-top:18px;}
#resa-status{border-radius:20px!important;}
body.dark .v2-trust-card{background:rgba(22,22,22,.90); border-color:rgba(255,255,255,.08);}
body.dark .v2-trust-item,
body.dark .v2-booking-point,
body.dark .v2-booking-intro{background:#171717; border-color:rgba(255,255,255,.08);}
body.dark .v2-trust-item strong,
body.dark .v2-booking-intro h3,
body.dark .v2-booking-point strong{color:#f4f0ea;}
body.dark .v2-trust-item span,
body.dark .v2-booking-intro p,
body.dark .v2-booking-point span{color:#cec5bb;}
@media (max-width: 980px){
    .v2-premium-panel{padding:0 22px;}
    .v2-trust-card,
    .v2-booking-points{grid-template-columns:1fr;}
    .v2-trust-bar{margin:-36px auto 0;}
}
@media (max-width: 640px){
    .v2-hero-actions{flex-direction:column;}
    .v2-btn-ghost,.btn{width:100%; max-width:320px;}
    .v2-booking-intro{padding:18px;}
    .v2-booking-intro h3{font-size:24px;}
}

/* === V2 polished: light/dark/mobile refinements === */
html{scroll-behavior:smooth;}
body{
    background:#f8f5f1;
    color:#1f1b17;
    transition:background-color .25s ease,color .25s ease;
}
body.dark{
    background:#111111;
    color:#f3ede5;
}
.header{
    backdrop-filter:saturate(180%) blur(10px);
}
.header.scrolled{
    background:rgba(250,247,242,.88);
    border-bottom:1px solid rgba(60,40,20,.08);
    box-shadow:0 10px 35px rgba(20,12,6,.08);
}
body.dark .header.scrolled{
    background:rgba(13,13,14,.88);
    border-bottom:1px solid rgba(255,255,255,.07);
    box-shadow:0 10px 35px rgba(0,0,0,.34);
}
.hero-overlay{
    background:linear-gradient(180deg, rgba(0,0,0,.24) 0%, rgba(0,0,0,.44) 100%);
}
.v2-hero-actions{display:none !important;}
.v2-hero-kicker{
    margin-top:22px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:10px 18px;
    border-radius:999px;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.18);
    backdrop-filter:blur(8px);
}
.service-card,
.portfolio-item,
.contact-form,
.v2-trust-card,
.v2-booking-intro,
.v2-booking-point,
.resa-form-hint,
.resa-recap-note,
.testimonial-slide,
.testimonial-card,
.payment-option,
.pricing-card{
    box-shadow:0 18px 45px rgba(40,23,11,.07);
}
input, textarea, select{
    border-radius:14px !important;
    background:rgba(255,255,255,.92);
    border:1px solid rgba(80,52,28,.14);
    color:#221b16;
}
input:focus, textarea:focus, select:focus{
    outline:none;
    border-color:rgba(201,168,124,.72);
    box-shadow:0 0 0 4px rgba(201,168,124,.15);
}
.contact-form button,
button[type="submit"],
.btn,
.v2-btn-ghost{
    min-height:48px;
}
.footer-overlay{
    background:linear-gradient(180deg, rgba(12,10,8,.56) 0%, rgba(12,10,8,.74) 100%) !important;
}
body.dark .service-card,
body.dark .portfolio-item,
body.dark .contact-form,
body.dark .v2-trust-card,
body.dark .v2-booking-intro,
body.dark .v2-booking-point,
body.dark .resa-form-hint,
body.dark .resa-recap-note,
body.dark .payment-option,
body.dark .pricing-card,
body.dark .testimonial-slide,
body.dark .testimonial-card{
    background:#171717;
    border-color:rgba(255,255,255,.08);
    box-shadow:0 18px 45px rgba(0,0,0,.28);
}
body.dark input,
body.dark textarea,
body.dark select{
    background:#171717;
    color:#f5efe8;
    border-color:rgba(255,255,255,.09);
}
body.dark .mobile-menu{
    background:rgba(15,15,16,.98);
}
body.dark .dark-toggle{
    background:#171717;
    color:#f5efe8;
    border-color:rgba(255,255,255,.10);
}
@media (max-width: 900px){
    .nav-container{padding:18px 18px;}
    .hero{min-height:84svh;height:84svh;}
    .hero-content{width:min(92vw,720px);padding:0 16px;text-align:center;}
    .hero-title{font-size:clamp(2rem,9vw,3.2rem) !important;line-height:1.04;}
    .hero-subtitle{font-size:12px;letter-spacing:3px;}
    .contact-form{padding:22px !important;}
    .footer{padding:68px 0 26px !important;}
    .footer-content{padding:0 20px !important;}
}
@media (max-width: 640px){
    body{font-size:15px;}
    .logo{font-size:24px;}
    .hero{min-height:78svh;height:78svh;}
    .hero-content{top:52%;}
    .v2-hero-kicker{
        font-size:11px;
        letter-spacing:1px;
        padding:10px 14px;
        max-width:92vw;
        flex-wrap:wrap;
    }
    .hero-dots{bottom:24px;}
    .dark-toggle{top:86px;right:16px;}
}
