:root {
    --clr-primary: #0f766e;
    --clr-primary-2: #14b8a6;
    --clr-secondary: #f59e0b;
    --clr-accent: #ec4899;
    --clr-dark: #0f172a;
    --clr-dark-2: #1e293b;
    --clr-text: #334155;
    --clr-text-soft: #64748b;
    --clr-white: #ffffff;
    --clr-light: #f8fafc;
    --clr-light-2: #eef6f7;
    --clr-border: rgba(15, 23, 42, 0.08);
    --clr-border-strong: rgba(15, 23, 42, 0.12);
    --shadow-sm: 0 12px 30px rgba(15, 23, 42, 0.06);
    --shadow-md: 0 22px 50px rgba(15, 23, 42, 0.1);
    --shadow-lg: 0 34px 70px rgba(15, 23, 42, 0.16);
    --radius-sm: 14px;
    --radius-md: 22px;
    --radius-lg: 30px;
    --radius-xl: 40px;
    --container: 1280px;
    --transition: all .3s ease;
    --gradient-main: linear-gradient(135deg, #0f766e 0%, #14b8a6 52%, #22c55e 100%);
    --gradient-dark: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    --gradient-soft: linear-gradient(135deg, rgba(15, 118, 110, 0.1), rgba(245, 158, 11, 0.1));
}

*,:before,:after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:"Inter",sans-serif;
    color:var(--clr-text);
    background:
        radial-gradient(circle at top left, rgba(20,184,166,.09), transparent 28%),
        radial-gradient(circle at bottom right, rgba(245,158,11,.08), transparent 26%),
        var(--clr-light);
    line-height:1.6;
    overflow-x:hidden;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.site-main{min-height:60vh}
.container{width:min(100% - 32px, var(--container)); margin-inline:auto}
.section{padding:88px 0}
.section--alt{background:linear-gradient(180deg, rgba(255,255,255,.35), rgba(255,255,255,.8))}
.gradient-text{background:var(--gradient-main);-webkit-background-clip:text;background-clip:text;color:transparent}
.glass-card{background:rgba(255,255,255,.16);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.18)}
.reveal-up{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}
.reveal-up.is-visible{opacity:1;transform:none}
.delay-1{transition-delay:.12s}
.delay-2{transition-delay:.22s}
.floating-card{animation:floaty 5s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:10px;
    min-height:52px;padding:0 22px;border:none;border-radius:999px;
    font-weight:700;transition:var(--transition);white-space:nowrap
}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--gradient-main);color:var(--clr-white);box-shadow:var(--shadow-sm)}
.btn--primary:hover{box-shadow:var(--shadow-md)}
.btn--ghost{background:rgba(255,255,255,.85);color:var(--clr-dark);border:1px solid var(--clr-border)}
.btn--ghost:hover{border-color:rgba(15,118,110,.24)}
.btn--dark{background:var(--clr-dark);color:var(--clr-white)}
.btn--sm{min-height:44px;padding:0 16px;font-size:.95rem}
.btn--lg{min-height:58px;padding:0 28px}

.site-shell{position:relative;min-height:100vh}
.site-shell::before,.site-shell::after{
    content:"";position:fixed;z-index:-1;border-radius:50%;pointer-events:none;filter:blur(70px);opacity:.35
}
.site-shell::before{width:320px;height:320px;top:-60px;left:-80px;background:rgba(20,184,166,.34)}
.site-shell::after{width:360px;height:360px;bottom:-80px;right:-100px;background:rgba(245,158,11,.22)}

.site-header{
    position:sticky;top:0;z-index:1000;
    background:rgba(248,250,252,.74);backdrop-filter:blur(16px);
    border-bottom:1px solid rgba(15,23,42,.05);transition:var(--transition)
}
.site-header.header-scrolled{box-shadow:0 14px 34px rgba(15,23,42,.08)}
.site-nav{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:84px}
.site-brand{display:inline-flex;align-items:center;gap:14px;min-width:0}
.site-brand__logo{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:var(--gradient-main);color:#fff;font-weight:800;box-shadow:0 14px 24px rgba(15,118,110,.2)}
.site-brand__text{display:flex;flex-direction:column;line-height:1.08}
.site-brand__title{font-weight:800;letter-spacing:-.03em;color:var(--clr-dark)}
.site-brand__subtitle{font-size:.84rem;color:var(--clr-text-soft)}
.site-nav__links{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.site-nav__link{padding:12px 16px;border-radius:999px;font-weight:600;color:var(--clr-dark-2);transition:var(--transition)}
.site-nav__link:hover,.site-nav__link.is-active{background:rgba(15,118,110,.1);color:var(--clr-primary)}
.site-nav__actions{display:flex;align-items:center;gap:12px}
.site-nav__toggle{display:none;width:50px;height:50px;border-radius:16px;border:1px solid var(--clr-border);background:#fff;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.site-nav__toggle span{display:block;width:22px;height:2px;border-radius:999px;background:var(--clr-dark)}
.site-mobile{display:none;padding:0 0 16px}
.site-mobile.is-open{display:block}
.site-mobile__panel{background:rgba(255,255,255,.96);border:1px solid var(--clr-border);border-radius:26px;padding:16px;box-shadow:var(--shadow-md)}
.site-mobile__links{display:flex;flex-direction:column;gap:8px}
.site-mobile__link{padding:14px 16px;border-radius:16px;background:var(--clr-light);font-weight:600;color:var(--clr-dark)}
.site-mobile__actions{display:grid;gap:10px;margin-top:14px}

.hero{padding:72px 0 48px;position:relative;overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}
.hero__eyebrow,.section-heading__eyebrow,.page-hero__eyebrow{
    display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border-radius:999px;
    background:rgba(15,118,110,.1);border:1px solid rgba(15,118,110,.14);color:var(--clr-primary);font-weight:700;font-size:.92rem
}
.hero__title{margin:18px 0 0;font-size:clamp(2.6rem,6vw,5rem);line-height:.98;letter-spacing:-.06em;color:var(--clr-dark)}
.hero__description{margin:24px 0 0;max-width:720px;font-size:1.08rem;color:var(--clr-text-soft)}
.hero__actions{margin-top:30px;display:flex;flex-wrap:wrap;gap:14px}
.hero__stats{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:14px;
    margin-top:32px;
}

.hero__stat{
    padding:18px 18px;
    border-radius:22px;
    color:var(--clr-dark);
    background:linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.68));
    border:1px solid rgba(255,255,255,.72);
    box-shadow:
        0 14px 34px rgba(15,23,42,.08),
        inset 0 1px 0 rgba(255,255,255,.7);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
}

.hero__stat strong{
    display:block;
    font-size:1.65rem;
    letter-spacing:-.03em;
    line-height:1;
    color:var(--clr-dark);
    text-shadow:none;
}

.hero__stat span{
    display:block;
    margin-top:8px;
    color:var(--clr-text);
    font-size:.96rem;
    font-weight:600;
}

.hero__stat:hover{
    transform:translateY(-2px);
    box-shadow:
        0 18px 40px rgba(15,23,42,.12),
        inset 0 1px 0 rgba(255,255,255,.78);
}

.hero__stat strong,
.hero__stat span{
    position:relative;
    z-index:1;
}

.hero-showcase{position:relative;min-height:580px}
.hero-showcase__image{
    position:absolute;inset:0;border-radius:34px;overflow:hidden;box-shadow:var(--shadow-lg);
    background:
      linear-gradient(180deg, rgba(15,23,42,.08), rgba(15,23,42,.56)),
      url("../img/lac-rose-aventure.112258017dce.png") center/cover no-repeat;
}
.hero-card{position:absolute;border-radius:28px;padding:22px;box-shadow:var(--shadow-lg)}
.hero-card--main{left:22px;bottom:26px;max-width:320px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(16px);color:#fff}
.hero-card--floating{right:0;top:34px;width:250px;background:#fff;color:var(--clr-dark)}
.hero-card__badge,.hero-card__mini-label{display:inline-flex;padding:8px 12px;border-radius:999px;font-size:.82rem;font-weight:700}
.hero-card__badge{background:rgba(255,255,255,.18);color:#fff}
.hero-card__mini-label{background:rgba(15,118,110,.1);color:var(--clr-primary)}
.hero-card h3,.hero-card h4{margin:14px 0 8px;font-size:1.3rem;letter-spacing:-.03em}
.hero-card p{margin:0;color:inherit;opacity:.88}
.hero-card strong{display:block;margin-top:16px;font-size:1.7rem;letter-spacing:-.04em}

.section-heading{max-width:760px;margin-bottom:30px}
.section-heading h2{margin:16px 0 12px;font-size:clamp(2rem,5vw,3.4rem);line-height:1.05;color:var(--clr-dark);letter-spacing:-.05em}
.section-heading p{margin:0;color:var(--clr-text-soft);font-size:1.04rem}
.section-cta-center{display:flex;justify-content:center;margin-top:34px}

.category-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.category-card{
    position:relative;display:flex;flex-direction:column;gap:12px;padding:26px;
    background:rgba(255,255,255,.88);border:1px solid var(--clr-border);border-radius:30px;
    box-shadow:var(--shadow-sm);transition:var(--transition);overflow:hidden
}
.category-card::before{content:"";position:absolute;inset:auto -20% -40% auto;width:180px;height:180px;border-radius:50%;background:rgba(20,184,166,.08);filter:blur(10px)}
.category-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.category-card__icon{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:var(--gradient-soft);color:var(--clr-primary);font-size:1.1rem}
.category-card__type{font-size:.86rem;font-weight:700;color:var(--clr-primary)}
.category-card h3{margin:0;color:var(--clr-dark);font-size:1.35rem;letter-spacing:-.03em}
.category-card p{margin:0;color:var(--clr-text-soft)}
.category-card__link{display:inline-flex;align-items:center;gap:8px;margin-top:6px;font-weight:700;color:var(--clr-dark)}

.page-hero{padding:72px 0 32px}
.page-hero--compact{padding:50px 0 16px}
.page-hero--gradient{background:linear-gradient(180deg, rgba(20,184,166,.08), rgba(255,255,255,0))}
.page-hero h1{margin:16px 0 10px;font-size:clamp(2.2rem,5vw,4rem);line-height:1.02;color:var(--clr-dark);letter-spacing:-.05em}
.page-hero p{margin:0;max-width:760px;color:var(--clr-text-soft);font-size:1.03rem}

.filter-panel{background:rgba(255,255,255,.9);border:1px solid var(--clr-border);border-radius:30px;padding:24px;box-shadow:var(--shadow-sm);backdrop-filter:blur(12px);margin-bottom:28px}
.filter-panel__grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px;align-items:end}
.filter-panel__field--wide{grid-column:span 2}
.filter-panel label{display:block;margin-bottom:8px;font-size:.9rem;font-weight:700;color:var(--clr-dark)}
.form-control,.form-select,input[type='text'],input[type='number'],select{
    width:100%;min-height:54px;border:1px solid rgba(15,23,42,.1);border-radius:18px;padding:0 16px;background:#fff;color:var(--clr-dark);outline:none;transition:var(--transition)
}
.form-control:focus,.form-select:focus,input[type='text']:focus,input[type='number']:focus,select:focus{border-color:rgba(15,118,110,.4);box-shadow:0 0 0 4px rgba(20,184,166,.1)}
.filter-panel__bottom{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:center;margin-top:16px}
.check-line{display:flex;align-items:center;gap:12px;min-height:54px;padding:0 14px;border-radius:18px;background:#fff;border:1px solid rgba(15,23,42,.1)}
.check-line input{width:18px;height:18px}
.filter-panel__actions{display:flex;gap:12px;flex-wrap:wrap}

.catalog-search{margin-bottom:28px;border-radius:32px;background:linear-gradient(135deg,rgba(255,255,255,.94),rgba(248,250,252,.96));border:1px solid rgba(148,163,184,.18);box-shadow:0 20px 60px rgba(15,23,42,.08);overflow:hidden}
.catalog-search[open]{box-shadow:0 26px 72px rgba(15,23,42,.12)}
.catalog-search__summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px 24px;cursor:pointer;background:linear-gradient(135deg,rgba(15,118,110,.08),rgba(56,189,248,.08));transition:var(--transition)}
.catalog-search__summary::-webkit-details-marker{display:none}
.catalog-search__summary:hover{background:linear-gradient(135deg,rgba(15,118,110,.11),rgba(56,189,248,.11))}
.catalog-search__summary-main{display:flex;align-items:center;gap:16px;min-width:0}
.catalog-search__icon{display:grid;place-items:center;width:58px;height:58px;border-radius:20px;background:linear-gradient(135deg,#0f766e,#14b8a6);color:#fff;box-shadow:0 18px 36px rgba(15,118,110,.22);flex-shrink:0}
.catalog-search__icon i{font-size:1.15rem}
.catalog-search__summary-text{display:grid;gap:4px;min-width:0}
.catalog-search__eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--clr-primary-dark)}
.catalog-search__summary-text strong{font-size:1.08rem;color:var(--clr-dark);line-height:1.3}
.catalog-search__summary-text small{font-size:.93rem;color:var(--clr-text-soft);line-height:1.55}
.catalog-search__summary-action{display:inline-flex;align-items:center;gap:12px;padding:12px 16px;border-radius:999px;background:rgba(255,255,255,.78);border:1px solid rgba(148,163,184,.16);color:var(--clr-dark);font-weight:800;flex-shrink:0;transition:var(--transition)}
.catalog-search__summary-action i{transition:transform .28s ease}
.catalog-search__summary-label--close{display:none}
.catalog-search[open] .catalog-search__summary-action{background:rgba(15,118,110,.10);color:var(--clr-primary-dark)}
.catalog-search[open] .catalog-search__summary-action i{transform:rotate(180deg)}
.catalog-search[open] .catalog-search__summary-label--open{display:none}
.catalog-search[open] .catalog-search__summary-label--close{display:inline}
.catalog-search__panel{padding:0 16px 16px;background:linear-gradient(180deg,rgba(255,255,255,.52),rgba(255,255,255,.92))}
.catalog-search .filter-panel{margin-bottom:0;border:none;box-shadow:none;background:transparent;padding:20px 8px 8px;backdrop-filter:none}
@media (max-width: 768px){.catalog-search__summary{padding:18px}.catalog-search__summary,.catalog-search__summary-main{align-items:flex-start}.catalog-search__summary{flex-direction:column}.catalog-search__summary-action{width:100%;justify-content:center}.catalog-search__icon{width:52px;height:52px;border-radius:18px}.catalog-search__panel{padding:0 12px 12px}.catalog-search .filter-panel{padding:16px 4px 4px}}
.form-errors{margin-top:14px;padding:14px 16px;border-radius:18px;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.14);color:#b91c1c}

.list-topbar{display:flex;justify-content:space-between;align-items:end;gap:16px;margin-bottom:20px}
.list-topbar__title{margin:0;color:var(--clr-dark);font-size:1.6rem;letter-spacing:-.03em}
.list-topbar__subtitle{margin:4px 0 0;color:var(--clr-text-soft)}

.offres-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.offre-card{background:rgba(255,255,255,.92);border:1px solid var(--clr-border);border-radius:30px;overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition)}
.offre-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.offre-card__image-wrap{display:block;position:relative;aspect-ratio:16/11;overflow:hidden;background:linear-gradient(135deg,#d1fae5,#fde68a)}
.offre-card__image{width:100%;height:100%;object-fit:cover;transition:transform .65s ease}
.offre-card:hover .offre-card__image{transform:scale(1.06)}
.offre-card__badge{position:absolute;top:18px;left:18px;display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:rgba(15,23,42,.78);color:#fff;font-size:.82rem;font-weight:700}
.offre-card__badge--soft{background:rgba(255,255,255,.88);color:var(--clr-dark)}
.offre-card__body{padding:24px}
.offre-card__top{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.offre-card__category{font-size:.88rem;font-weight:700;color:var(--clr-primary)}
.offre-card__type{font-size:.8rem;padding:6px 10px;border-radius:999px;background:var(--clr-light-2);color:var(--clr-dark)}
.offre-card__title{margin:0;font-size:1.34rem;line-height:1.2;letter-spacing:-.03em;color:var(--clr-dark)}
.offre-card__description{margin:14px 0 0;color:var(--clr-text-soft);display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.offre-card__features{display:flex;flex-wrap:wrap;gap:10px;list-style:none;padding:0;margin:16px 0 0}
.offre-card__features li{padding:8px 12px;border-radius:999px;background:var(--clr-light);border:1px solid var(--clr-border);font-size:.86rem}
.offre-card__footer{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:end;margin-top:18px}
.offre-card__price-box{display:flex;flex-direction:column;gap:4px}
.offre-card__old-price{font-size:.95rem;text-decoration:line-through;color:var(--clr-text-soft)}
.offre-card__price{font-size:1.46rem;line-height:1;color:var(--clr-dark);letter-spacing:-.04em}
.offre-card__unit{color:var(--clr-text-soft)}


.galerie-hero{
    padding-top: 72px;
    padding-bottom: 34px;
}

.galerie-hero__grid{
    display:grid;
    grid-template-columns: 1.08fr .92fr;
    gap: 28px;
    align-items: stretch;
}

.galerie-hero__actions{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin-top:28px;
}

.galerie-hero__stats{
    display:grid;
    grid-template-columns:repeat(3, minmax(0,1fr));
    gap:14px;
    margin-top:24px;
}

.galerie-stat{
    padding:18px;
    border-radius:22px;
    background:rgba(255,255,255,.58);
    border:1px solid rgba(255,255,255,.5);
}

.galerie-stat strong{
    display:block;
    font-size:1.45rem;
    line-height:1;
    color:var(--clr-dark);
    letter-spacing:-.04em;
}

.galerie-stat span{
    display:block;
    margin-top:8px;
    color:var(--clr-text-soft);
    font-size:.92rem;
}

.galerie-hero__visual{
    display:flex;
    align-items:stretch;
}

.galerie-hero-card{
    position:relative;
    overflow:hidden;
    width:100%;
    min-height:100%;
    border-radius:34px;
    padding:30px;
    background:
        radial-gradient(circle at top right, rgba(20,184,166,.16), transparent 28%),
        radial-gradient(circle at bottom left, rgba(245,158,11,.14), transparent 28%),
        linear-gradient(135deg, rgba(255,255,255,.92), rgba(248,250,252,.92));
    border:1px solid rgba(15,23,42,.08);
    box-shadow:var(--shadow-md);
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
}

.galerie-hero-card__badge{
    display:inline-flex;
    align-items:center;
    gap:10px;
    width:max-content;
    margin-bottom:18px;
    padding:10px 16px;
    border-radius:999px;
    background:rgba(15,118,110,.1);
    color:var(--clr-primary);
    font-weight:800;
    font-size:.86rem;
}

.galerie-hero-card h2{
    margin:0 0 12px;
    color:var(--clr-dark);
    font-size:clamp(1.7rem, 3vw, 2.5rem);
    line-height:1.08;
    letter-spacing:-.04em;
}

.galerie-hero-card p{
    margin:0;
    color:var(--clr-text-soft);
    max-width:560px;
}

.galerie-categories{
    padding:26px;
}

.galerie-categories__grid{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:18px;
}

.galerie-chip{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:12px 16px;
    border-radius:999px;
    background:linear-gradient(135deg, rgba(255,255,255,.95), rgba(248,250,252,.96));
    border:1px solid rgba(15,23,42,.08);
    box-shadow:0 10px 22px rgba(15,23,42,.05);
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.galerie-chip:hover{
    transform:translateY(-2px);
    box-shadow:0 16px 28px rgba(15,23,42,.08);
    border-color:rgba(15,118,110,.2);
}

.galerie-chip__name{
    font-weight:800;
    color:var(--clr-dark);
}

.galerie-chip__count{
    font-size:.84rem;
    color:var(--clr-text-soft);
}

.galerie-mosaic{
    display:grid;
    grid-template-columns:repeat(12, minmax(0,1fr));
    gap:18px;
}

.galerie-tile{
    grid-column:span 4;
    min-width:0;
}

.galerie-tile:nth-child(7n + 1),
.galerie-tile:nth-child(7n + 5){
    grid-column:span 6;
}

.galerie-tile__media{
    position:relative;
    display:block;
    overflow:hidden;
    min-height:320px;
    height:100%;
    border-radius:30px;
    background:linear-gradient(135deg,#d1fae5,#fde68a);
    box-shadow:var(--shadow-sm);
}

.galerie-tile__media img{
    width:100%;
    height:100%;
    min-height:320px;
    object-fit:cover;
    transition:transform .8s ease;
}

.galerie-tile:hover .galerie-tile__media img{
    transform:scale(1.07);
}

.galerie-tile__overlay{
    position:absolute;
    inset:0;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    padding:20px;
    background:linear-gradient(180deg, rgba(15,23,42,.16) 0%, rgba(15,23,42,.14) 28%, rgba(15,23,42,.82) 100%);
}

.galerie-tile__top{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:10px;
    flex-wrap:wrap;
}

.galerie-tile__category,
.galerie-tile__badge{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:9px 13px;
    border-radius:999px;
    font-size:.8rem;
    font-weight:800;
    backdrop-filter:blur(10px);
}

.galerie-tile__category{
    background:rgba(255,255,255,.9);
    color:var(--clr-dark);
}

.galerie-tile__badge{
    background:rgba(245,158,11,.92);
    color:#fff;
}

.galerie-tile__content h3{
    margin:0;
    color:#fff;
    font-size:1.45rem;
    line-height:1.12;
    letter-spacing:-.03em;
}

.galerie-tile__content p{
    margin:10px 0 0;
    color:rgba(255,255,255,.84);
    line-height:1.55;
    display:-webkit-box;
    -webkit-line-clamp:3;
    line-clamp:3;
    -webkit-box-orient:vertical;
    overflow:hidden;
}

.galerie-tile__bottom{
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap:16px;
    flex-wrap:wrap;
    margin-top:18px;
}

.galerie-tile__price{
    display:flex;
    flex-direction:column;
    gap:4px;
}

.galerie-tile__price small{
    color:rgba(255,255,255,.65);
    text-decoration:line-through;
    font-size:.92rem;
}

.galerie-tile__price strong{
    color:#fff;
    font-size:1.55rem;
    line-height:1;
    letter-spacing:-.04em;
}

.galerie-tile__price span{
    color:rgba(255,255,255,.78);
    font-size:.88rem;
}

.galerie-tile__cta{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:12px 16px;
    border-radius:999px;
    background:rgba(255,255,255,.14);
    color:#fff;
    border:1px solid rgba(255,255,255,.18);
    font-weight:800;
    transition:all .25s ease;
}

.galerie-tile:hover .galerie-tile__cta{
    background:rgba(255,255,255,.22);
    transform:translateY(-1px);
}

@media (max-width: 1100px){
    .galerie-hero__grid{
        grid-template-columns:1fr;
    }

    .galerie-mosaic{
        grid-template-columns:repeat(2, minmax(0,1fr));
    }

    .galerie-tile,
    .galerie-tile:nth-child(7n + 1),
    .galerie-tile:nth-child(7n + 5){
        grid-column:span 1;
    }
}

@media (max-width: 768px){
    .galerie-hero__stats{
        grid-template-columns:1fr;
    }

    .galerie-categories{
        padding:20px;
    }

    .galerie-categories__grid{
        gap:10px;
    }

    .galerie-chip{
        width:100%;
        justify-content:space-between;
    }

    .galerie-mosaic{
        grid-template-columns:1fr;
    }

    .galerie-tile__media,
    .galerie-tile__media img{
        min-height:280px;
    }

    .galerie-tile__content h3{
        font-size:1.22rem;
    }

    .galerie-tile__bottom{
        align-items:flex-start;
    }
}

.empty-box{text-align:center;padding:44px 20px;background:rgba(255,255,255,.88);border-radius:28px;border:1px dashed rgba(15,23,42,.12);grid-column:1/-1}
.empty-box h3{margin:0 0 10px;color:var(--clr-dark)}
.empty-box p{margin:0;color:var(--clr-text-soft)}

.pagination-wrap{display:flex;justify-content:center;margin-top:32px}
.pagination{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.pagination__link,.pagination__current{min-height:46px;padding:0 16px;border-radius:14px;background:#fff;border:1px solid var(--clr-border);display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:var(--clr-dark)}
.pagination__current{background:var(--gradient-main);color:#fff;border-color:transparent}

.detail-hero{padding:52px 0 28px}
.detail-hero__grid{display:grid;grid-template-columns:1.04fr .96fr;gap:30px;align-items:start}
.detail-hero__media{position:sticky;top:104px}
.detail-hero__image{width:100%;aspect-ratio:16/11;object-fit:cover;border-radius:32px;box-shadow:var(--shadow-lg);background:#dbeafe}
.detail-thumbs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:14px}
.detail-thumbs__item{padding:0;border:none;border-radius:18px;overflow:hidden;background:transparent;box-shadow:var(--shadow-sm)}
.detail-thumbs__item img{width:100%;aspect-ratio:1/1;object-fit:cover}
.breadcrumb-line{display:flex;flex-wrap:wrap;gap:8px;color:var(--clr-text-soft);margin-bottom:14px}
.breadcrumb-line a:hover{color:var(--clr-primary)}
.detail-hero__category{display:inline-flex;color:var(--clr-primary);font-weight:800;margin-bottom:12px}
.detail-hero__title{margin:0;color:var(--clr-dark);font-size:clamp(2rem,5vw,3.6rem);line-height:1.02;letter-spacing:-.05em}
.detail-hero__description{margin-top:18px;color:var(--clr-text-soft);font-size:1.04rem}
.detail-price-card{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center;margin-top:24px;padding:22px;border-radius:28px;background:var(--gradient-soft);border:1px solid rgba(15,118,110,.12)}
.detail-price-card__old{display:block;font-size:1rem;color:var(--clr-text-soft);text-decoration:line-through}
.detail-price-card__current{display:block;font-size:2rem;line-height:1;color:var(--clr-dark);letter-spacing:-.04em}
.detail-price-card__unit{color:var(--clr-text-soft)}
.detail-price-card__right{display:flex;gap:10px;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;padding:10px 14px;border-radius:999px;background:#fff;color:var(--clr-dark);font-weight:700;border:1px solid var(--clr-border)}
.pill--highlight{background:var(--gradient-main);color:#fff;border:none}
.detail-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.detail-layout{display:grid;grid-template-columns:1fr 360px;gap:26px;align-items:start}
.content-card,.sidebar-card{background:rgba(255,255,255,.92);border:1px solid var(--clr-border);border-radius:28px;padding:24px;box-shadow:var(--shadow-sm)}
.content-card + .content-card{margin-top:20px}
.content-card h2,.sidebar-card h3{margin:0 0 14px;color:var(--clr-dark);letter-spacing:-.03em}
.wysiwyg p{margin:0 0 12px;color:var(--clr-text-soft)}
.detail-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.detail-list li{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:16px;background:var(--clr-light);border:1px solid var(--clr-border)}
.detail-list li::before{content:'✓';display:grid;place-items:center;width:28px;height:28px;border-radius:50%;background:rgba(34,197,94,.12);color:#16a34a;font-weight:800;flex-shrink:0}
.price-variants{display:grid;gap:14px}
.price-variant{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:16px 18px;border-radius:18px;background:#fff;border:1px solid var(--clr-border)}
.price-variant h3{margin:0 0 4px;color:var(--clr-dark)}
.price-variant p{margin:0;color:var(--clr-text-soft)}
.price-variant__value{text-align:right;display:flex;flex-direction:column;gap:4px}
.price-variant__value span{text-decoration:line-through;color:var(--clr-text-soft)}
.price-variant__value strong{font-size:1.1rem;color:var(--clr-dark)}
.detail-sidebar{position:sticky;top:104px;display:grid;gap:18px}
.sidebar-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.sidebar-list li{padding:12px 0;border-bottom:1px solid var(--clr-border)}
.sidebar-list li:last-child{border-bottom:none;padding-bottom:0}
.sidebar-card--cta{background:var(--gradient-dark);color:#fff}
.sidebar-card--cta h3,.sidebar-card--cta p{color:#fff}
.sidebar-card--cta p{opacity:.82}
.sidebar-card--cta .btn--primary{background:#fff;color:var(--clr-dark)}

.messages-wrap{padding:16px 0 0}
.alert{display:flex;align-items:flex-start;gap:12px;padding:16px 18px;border-radius:18px;border:1px solid rgba(15,23,42,.08);background:#fff;box-shadow:var(--shadow-sm)}
.alert + .alert{margin-top:10px}
.alert--success{border-color:rgba(34,197,94,.18);background:rgba(34,197,94,.06)}
.alert--error,.alert--danger{border-color:rgba(239,68,68,.18);background:rgba(239,68,68,.06)}
.alert--warning{border-color:rgba(245,158,11,.18);background:rgba(245,158,11,.06)}

.scroll-top{
    position:fixed;right:18px;bottom:18px;width:52px;height:52px;border:none;border-radius:18px;
    background:var(--gradient-main);color:#fff;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transform:translateY(12px);transition:var(--transition);z-index:999
}
.scroll-top.is-visible{opacity:1;visibility:visible;transform:none}

@media (max-width: 1199px){
    .hero__grid,.detail-hero__grid,.detail-layout{grid-template-columns:1fr}
    .detail-hero__media,.detail-sidebar{position:static}
    .offres-grid,.category-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .filter-panel__grid{grid-template-columns:repeat(3,minmax(0,1fr))}
    .footer__grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 991px){
    .site-nav__links,.btn-desktop{display:none!important}
    .site-nav__toggle{display:inline-flex}
    .hero{padding-top:44px}
    .hero__stats{grid-template-columns:1fr}
    .hero-showcase{min-height:520px}
}
@media (max-width: 767px){
    .section{padding:68px 0}
    .offres-grid,.category-grid,.footer__grid,.filter-panel__grid{grid-template-columns:1fr}
    .filter-panel__field--wide{grid-column:auto}
    .detail-thumbs{grid-template-columns:repeat(3,minmax(0,1fr))}
    .site-brand__subtitle{display:none}
    .hero-showcase{min-height:420px}
    .hero-card--floating{width:220px;top:18px}
    .content-card,.sidebar-card,.filter-panel{padding:20px}
}
@media (max-width: 575px){
    .container{width:min(100% - 22px, var(--container))}
    .hero__actions,.detail-actions,.filter-panel__actions{flex-direction:column}
    .btn{width:100%}
    .detail-thumbs{grid-template-columns:repeat(2,minmax(0,1fr))}
}
.site-nav {
    min-height: 82px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: nowrap;
}

.site-brand {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    flex-shrink: 0;
    min-width: 0;
}

.site-brand__text {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
    min-width: 0;
}

.site-brand__title {
    font-weight: 800;
    color: #0f172a;
    letter-spacing: -0.03em;
    white-space: nowrap;
}

.site-brand__subtitle {
    font-size: 0.84rem;
    color: #64748b;
    line-height: 1.1;
}

.site-nav__links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    flex: 1 1 auto;
    min-width: 0;
    flex-wrap: nowrap;
    overflow: hidden;
}

.site-nav__link {
    padding: 10px 14px;
    border-radius: 999px;
    color: #1e293b;
    font-weight: 600;
    transition: all 0.3s ease;
    white-space: nowrap;
    flex-shrink: 0;
}

.site-nav__actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}
@media (max-width: 1280px) {
    .site-brand__subtitle {
        display: none;
    }

    .site-nav__link {
        padding: 10px 12px;
        font-size: 0.96rem;
    }
}

@media (max-width: 1150px) {
    .site-nav__links,
    .btn-desktop {
        display: none !important;
    }

    .site-nav__toggle {
        display: inline-flex;
    }
}

.site-nav__links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    flex: 1 1 auto;
    min-width: 0;
    flex-wrap: nowrap;
    overflow: hidden;
}

.site-nav__link {
    white-space: nowrap;
    flex-shrink: 0;
    padding: 10px 12px;
}

@media (max-width: 1150px) {
    .site-nav__links,
    .btn-desktop {
        display: none !important;
    }

    .site-nav__toggle {
        display: inline-flex;
    }
}
.pt-0{padding-top:0}
.text-center{text-align:center}
.booking-layout{display:grid;grid-template-columns:minmax(0,1.2fr) 380px;gap:28px;align-items:start}
.booking-single{max-width:760px}
.booking-main,.booking-sidebar,.content-card{min-width:0}
.content-card{background:rgba(255,255,255,.9);border:1px solid var(--clr-border);border-radius:30px;padding:26px;box-shadow:var(--shadow-sm)}
.booking-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.booking-form-grid--single{grid-template-columns:1fr}
.booking-field{display:flex;flex-direction:column;gap:8px}
.booking-field--full{grid-column:1/-1}
.booking-field label{font-weight:700;color:var(--clr-dark)}
.booking-field .errorlist{margin:0;padding-left:18px;color:#b91c1c}
.field-help{color:var(--clr-text-soft);font-size:.88rem}
.field-error{color:#b91c1c;font-size:.88rem}
.booking-form-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:4px}
.booking-estimate-amount{font-size:2rem;font-weight:800;letter-spacing:-.05em;color:var(--clr-dark);margin:8px 0}
.booking-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 18px;margin-top:12px}
.booking-summary-grid span{display:block;color:var(--clr-text-soft);font-size:.88rem}
.booking-summary-grid strong{display:block;color:var(--clr-dark);font-size:1rem}
.booking-field--payment-inline .booking-radio{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
}

.booking-radio{
    display:grid;
    gap:10px;
}

.booking-radio label{
    display:flex;
    align-items:center;
    gap:12px;
    min-height:72px;
    padding:14px 16px;
    border:1px solid var(--clr-border);
    border-radius:18px;
    background:var(--clr-light);
    cursor:pointer;
    transition:var(--transition);
}

.booking-radio label.is-selected{
    border-color:rgba(20,184,166,.4);
    background:rgba(20,184,166,.1);
    box-shadow:0 0 0 4px rgba(20,184,166,.08);
}

.booking-radio input{
    margin-top:0;
    accent-color:var(--clr-primary);
    flex-shrink:0;
}

.booking-radio label span{
    display:block;
    font-weight:800;
    line-height:1.35;
}

@media (max-width: 920px){
    .booking-field--payment-inline .booking-radio{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
}

@media (max-width: 640px){
    .booking-field--payment-inline .booking-radio{
        grid-template-columns:1fr;
    }
}
.dashboard-form-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;align-items:end}
.form-field{display:flex;flex-direction:column;gap:8px}
.form-field label{font-weight:600}
.form-actions-inline{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.btn-primary,.btn-secondary{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 18px;border-radius:14px;font-weight:700;border:1px solid transparent}
.btn-primary{background:linear-gradient(135deg,var(--primary,#3b82f6),var(--primary-2,#60a5fa));color:#fff}
.btn-secondary{background:rgba(148,163,184,.12);color:inherit;border-color:rgba(148,163,184,.18)}
.table-wrap{overflow:auto}
.data-table{width:100%;border-collapse:collapse}
.data-table th,.data-table td{padding:14px 12px;border-bottom:1px solid rgba(148,163,184,.16);text-align:left;vertical-align:top}
.data-table th{font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted,#64748b)}
.table-action{font-weight:700;color:var(--primary,#3b82f6)}
.detail-kv-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.detail-kv-grid span{display:block;font-size:.84rem;color:var(--muted,#64748b)}
.detail-kv-grid strong{display:block;margin-top:5px}
.prose-block{margin-top:18px;padding-top:18px;border-top:1px solid rgba(148,163,184,.18)}
.status-update-form{display:grid;gap:12px;margin-top:20px}
@media (max-width: 1080px){.booking-layout{grid-template-columns:1fr}.dashboard-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 768px){.booking-form-grid,.booking-summary-grid,.detail-kv-grid,.dashboard-form-grid{grid-template-columns:1fr}.booking-form-actions{flex-direction:column}.booking-form-actions .btn{width:100%}}

.booking-sidebar--form{
    --booking-sidebar-glow: rgba(14,165,233,.14);
    display:grid;
    gap:22px;
    padding-left:14px;
    align-self:start;
}
.booking-sidebar--form .sidebar-card{
    position:relative;
    margin:0;
    overflow:hidden;
    border:1px solid rgba(255,255,255,.58);
    background:
        linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,252,.92)),
        radial-gradient(circle at top right, rgba(45,212,191,.12), transparent 44%),
        radial-gradient(circle at bottom left, rgba(56,189,248,.10), transparent 42%);
    box-shadow:
        0 20px 50px rgba(15,23,42,.08),
        0 2px 10px rgba(15,23,42,.04),
        inset 0 1px 0 rgba(255,255,255,.72);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    transition: transform .32s ease, box-shadow .32s ease, border-color .32s ease, background .32s ease;
}
.booking-sidebar--form .sidebar-card::before{
    content:"";
    position:absolute;
    inset:0 0 auto 0;
    height:1px;
    background:linear-gradient(90deg, transparent, rgba(255,255,255,.92), transparent);
    pointer-events:none;
}
.booking-sidebar--form .sidebar-card::after{
    content:"";
    position:absolute;
    inset:auto 18px -12px 18px;
    height:30px;
    border-radius:999px;
    background:radial-gradient(circle, var(--booking-sidebar-glow), transparent 70%);
    opacity:0;
    transform:translateY(4px);
    transition:opacity .32s ease, transform .32s ease;
    pointer-events:none;
}
.booking-sidebar--form .sidebar-card + .sidebar-card::before{
    content:"";
    position:absolute;
    top:-12px;
    left:18px;
    right:18px;
    height:1px;
    background:linear-gradient(90deg, transparent, rgba(148,163,184,.34), transparent);
}
.booking-sidebar--form .sidebar-card:hover{
    transform:translateY(-4px);
    border-color:rgba(45,212,191,.24);
    box-shadow:
        0 24px 60px rgba(15,23,42,.12),
        0 12px 22px rgba(14,165,233,.10),
        inset 0 1px 0 rgba(255,255,255,.82);
}
.booking-sidebar--form .sidebar-card:hover::after{
    opacity:1;
    transform:translateY(0);
}
.booking-sidebar--form .sidebar-card h3{
    margin-bottom:16px;
    font-size:1.05rem;
    letter-spacing:-.03em;
}
.booking-sidebar--form .sidebar-card .detail-list,
.booking-sidebar--form .sidebar-card .sidebar-list{
    display:grid;
    gap:12px;
}
.booking-sidebar--form .sidebar-card .detail-list li,
.booking-sidebar--form .sidebar-card .sidebar-list li{
    position:relative;
    padding-left:0;
}
.booking-sidebar--form .sidebar-card .detail-list li + li,
.booking-sidebar--form .sidebar-card .sidebar-list li + li{
    padding-top:12px;
    border-top:1px solid rgba(148,163,184,.14);
}
.booking-sidebar--form .sidebar-card strong{
    color:var(--clr-dark);
}
.booking-sidebar--form .sidebar-card--cta{
    border-color:rgba(255,255,255,.22);
    background:
        linear-gradient(160deg, rgba(15,23,42,.96), rgba(15,118,110,.94) 58%, rgba(14,165,233,.88));
    box-shadow:
        0 24px 60px rgba(15,23,42,.20),
        inset 0 1px 0 rgba(255,255,255,.12);
}
.booking-sidebar--form .sidebar-card--cta::before{
    height:100%;
    background:linear-gradient(135deg, rgba(255,255,255,.18), transparent 42%, transparent 60%, rgba(255,255,255,.08));
    opacity:.9;
}
.booking-sidebar--form .sidebar-card--cta:hover{
    border-color:rgba(255,255,255,.28);
    box-shadow:
        0 28px 68px rgba(15,23,42,.24),
        0 12px 30px rgba(45,212,191,.16),
        inset 0 1px 0 rgba(255,255,255,.16);
}
.booking-sidebar--form .booking-estimate-amount{
    margin-top:8px;
    letter-spacing:-.04em;
    text-shadow:0 10px 24px rgba(15,23,42,.22);
}
@media (min-width: 1081px){
    .booking-sidebar--form{
        position:sticky;
        top:112px;
    }
}
@media (max-width: 1080px){
    .booking-sidebar--form{
        padding-left:0;
        margin-top:14px;
    }
    .booking-sidebar--form .sidebar-card{
        box-shadow:
            0 16px 34px rgba(15,23,42,.08),
            0 2px 8px rgba(15,23,42,.04),
            inset 0 1px 0 rgba(255,255,255,.72);
    }
}
@media (max-width: 768px){
    .booking-sidebar--form{
        gap:16px;
        margin-top:8px;
    }
    .booking-sidebar--form .sidebar-card{
        border-radius:24px;
    }
    .booking-sidebar--form .sidebar-card:hover{
        transform:none;
    }
}


.site-mobile-dropdown{width:100%}
.site-mobile-dropdown[open] .site-mobile-dropdown__summary .site-mobile-dropdown__icon{transform:rotate(180deg)}
.site-mobile-dropdown__summary{width:100%;justify-content:space-between;list-style:none}
.site-mobile-dropdown__summary::-webkit-details-marker{display:none}
.site-mobile-dropdown__icon{transition:var(--transition)}
.site-mobile-dropdown__menu{display:grid;gap:10px;margin-top:12px;padding:12px;border-radius:20px;background:rgba(255,255,255,.92);border:1px solid var(--clr-border)}
.site-mobile-dropdown__item,.site-mobile-dropdown__button{display:flex;align-items:center;justify-content:flex-start;width:100%;min-height:52px;padding:0 16px;border-radius:16px;background:var(--clr-light);border:1px solid var(--clr-border);font-weight:700;color:var(--clr-dark);transition:var(--transition)}
.site-mobile-dropdown__item:hover,.site-mobile-dropdown__button:hover{background:#fff;border-color:rgba(15,118,110,.22)}
.site-mobile-dropdown__item--highlight{background:rgba(20,184,166,.1);color:var(--clr-primary)}
.site-mobile-dropdown__form{margin:0}
.site-mobile-dropdown__button{cursor:pointer}
/* .booking-radio{display:grid;gap:10px}
.booking-radio label{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1px solid var(--clr-border);border-radius:18px;background:var(--clr-light);cursor:pointer;transition:var(--transition)}
.booking-radio label.is-selected{border-color:rgba(20,184,166,.4);background:rgba(20,184,166,.1);box-shadow:0 0 0 4px rgba(20,184,166,.08)}
.booking-radio input{margin-top:4px;accent-color:var(--clr-primary)} */
.sidebar-card--cta .booking-estimate-amount{color:var(--clr-white)}
.sidebar-card--cta .field-help{color:rgba(255,255,255,.82)}

.site-mobile__actions {
    margin-top: 1rem;
}

.mobile-dropdown {
    width: 100%;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    overflow: hidden;
    backdrop-filter: blur(8px);
}

.mobile-dropdown[open] {
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.18);
}

.mobile-dropdown__summary {
    list-style: none;
    cursor: pointer;
    padding: 1rem 1.1rem;
    font-weight: 700;
    font-size: 0.98rem;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
}

.mobile-dropdown__summary::-webkit-details-marker {
    display: none;
}

.mobile-dropdown__summary::after {
    content: "▾";
    font-size: 0.95rem;
    opacity: 0.8;
    transition: transform 0.25s ease;
}

.mobile-dropdown[open] .mobile-dropdown__summary::after {
    transform: rotate(180deg);
}

.mobile-dropdown__content {
    padding: 0.9rem;
    display: grid;
    gap: 0.9rem;
}

.mobile-dropdown__group {
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 14px;
    padding: 0.85rem;
    background: rgba(255,255,255,0.03);
}

.mobile-dropdown__title {
    margin: 0 0 0.65rem;
    font-size: 0.8rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255,255,255,0.65);
}

.mobile-dropdown__link,
.mobile-dropdown__link--button {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 0.82rem 0.95rem;
    border-radius: 12px;
    text-decoration: none;
    color: #fff;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    transition: all 0.25s ease;
    font-weight: 600;
    margin-bottom: 0.55rem;
}

.mobile-dropdown__link:last-child,
.mobile-dropdown__link--button:last-child {
    margin-bottom: 0;
}

.mobile-dropdown__link:hover,
.mobile-dropdown__link--button:hover {
    background: rgba(255,255,255,0.10);
    transform: translateY(-1px);
}

.mobile-dropdown__link--primary {
    background: linear-gradient(135deg, #ff8a00, #ff5e00);
    border-color: transparent;
    color: #fff;
}

.mobile-dropdown__form {
    margin: 0;
}

.mobile-dropdown__link--button {
    appearance: none;
    cursor: pointer;
    text-align: left;
    font: inherit;
}

.desktop-dropdown {
    position: relative;
}

.desktop-dropdown__summary {
    list-style: none;
    cursor: pointer;
    padding: 0.95rem 1.35rem;
    border-radius: 999px;
    border: 1px solid rgba(17, 24, 39, 0.08);
    background: #ffffff;
    font-weight: 700;
    color: #111827;
    min-width: 190px;
    text-align: center;
}

.desktop-dropdown__summary::-webkit-details-marker {
    display: none;
}

.desktop-dropdown__menu {
    position: absolute;
    top: calc(100% + 12px);
    right: 0;
    width: 320px;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 22px;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.14);
    padding: 1rem;
    z-index: 1000;
    display: grid;
    gap: 0.9rem;
}

.desktop-dropdown__group {
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 16px;
    padding: 0.9rem;
    background: #f8fafc;
}

.desktop-dropdown__title {
    margin: 0 0 0.7rem;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 800;
    color: #64748b;
}

.desktop-dropdown__link,
.desktop-dropdown__link--button {
    display: block;
    width: 100%;
    text-decoration: none;
    border: 0;
    background: #ffffff;
    color: #0f172a;
    padding: 0.82rem 0.95rem;
    border-radius: 12px;
    font-weight: 600;
    margin-bottom: 0.55rem;
}

.desktop-dropdown__link:last-child,
.desktop-dropdown__link--button:last-child {
    margin-bottom: 0;
}

.desktop-dropdown__link--primary {
    background: linear-gradient(135deg, #14b8a6, #22c55e);
    color: #ffffff;
}

.desktop-dropdown__form {
    margin: 0;
}

.desktop-dropdown__link--button {
    cursor: pointer;
    text-align: left;
    font: inherit;
}
/* === i18n / language switcher === */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.lang-switcher {
    display: inline-flex;
    align-items: center;
}

.lang-switcher__select {
    min-width: 82px;
    border: 1px solid rgba(15, 118, 110, 0.18);
    background: rgba(255, 255, 255, 0.88);
    color: #0f172a;
    border-radius: 999px;
    padding: 0.7rem 2.2rem 0.7rem 0.95rem;
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    backdrop-filter: blur(12px);
}

.lang-switcher--mobile {
    width: 100%;
    margin-bottom: 1rem;
}

.lang-switcher--mobile .lang-switcher__select {
    width: 100%;
    border-radius: 18px;
}

html[dir="rtl"] body,
html[dir="rtl"] input,
html[dir="rtl"] select,
html[dir="rtl"] textarea,
html[dir="rtl"] button {
    direction: rtl;
}

html[dir="rtl"] .site-brand,
html[dir="rtl"] .site-nav,
html[dir="rtl"] .site-nav__links,
html[dir="rtl"] .site-nav__actions,
html[dir="rtl"] .hero__actions,
html[dir="rtl"] .detail-actions,
html[dir="rtl"] .filter-panel__bottom,
html[dir="rtl"] .footer__bottom-inner {
    flex-direction: row-reverse;
}

html[dir="rtl"] .booking-summary-grid div,
html[dir="rtl"] .sidebar-list li,
html[dir="rtl"] .detail-list li,
html[dir="rtl"] .footer__infos li {
    text-align: right;
}

.booking-section{display:grid;gap:18px;padding:22px;border:1px solid rgba(15,118,110,.08);border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(248,250,252,.9))}
.booking-section__header{display:flex;gap:16px;align-items:flex-start}
.booking-section__header--compact{margin-bottom:2px}
.booking-section__header h2{margin:0;font-size:1.2rem;color:var(--clr-dark)}
.booking-section__header p{margin:6px 0 0;color:var(--clr-text-soft)}
.booking-step{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:16px;background:rgba(20,184,166,.12);color:var(--clr-primary);font-weight:800;flex:0 0 auto}
.booking-form-grid--inner{grid-template-columns:repeat(2,minmax(0,1fr))}
.booking-upsell-shell{gap:16px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(240,253,250,.78));border-color:rgba(20,184,166,.12)}
.booking-upsell-intro{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-radius:22px;background:rgba(255,255,255,.78);border:1px solid rgba(15,118,110,.08)}
.booking-upsell-intro__copy{display:grid;gap:4px}
.booking-upsell-intro__title{margin:0;font-weight:800;color:var(--clr-dark)}
.booking-upsell-intro__text{margin:0;color:var(--clr-text-soft)}
.booking-upsell-intro__meta{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}
.booking-upsell-pill{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:rgba(20,184,166,.08);border:1px solid rgba(20,184,166,.14);color:var(--clr-primary);font-size:.83rem;font-weight:700}
.booking-upsell-toggle{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;padding:18px 20px;border:1px solid rgba(15,118,110,.12);border-radius:24px;background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(248,250,252,.92));cursor:pointer;transition:var(--transition);text-align:left;box-shadow:var(--shadow-sm)}
.booking-upsell-toggle:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.booking-upsell-toggle:focus-visible{outline:3px solid rgba(20,184,166,.18);outline-offset:2px}
.booking-upsell-toggle__text{display:grid;gap:4px}
.booking-upsell-toggle__text strong{font-size:1rem;color:var(--clr-dark)}
.booking-upsell-toggle__text small{font-size:.92rem;color:var(--clr-text-soft)}
.booking-upsell-toggle__icon{position:relative;flex:0 0 42px;width:42px;height:42px;border-radius:16px;background:rgba(20,184,166,.1)}
.booking-upsell-toggle__icon::before,.booking-upsell-toggle__icon::after{content:"";position:absolute;top:50%;left:50%;width:16px;height:2px;border-radius:999px;background:var(--clr-primary);transform:translate(-50%,-50%);transition:transform .28s ease,opacity .28s ease}
.booking-upsell-toggle__icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.booking-upsell-shell.is-open .booking-upsell-toggle__icon::after{transform:translate(-50%,-50%) rotate(180deg);opacity:0}
.booking-upsell-shell.is-open .booking-upsell-toggle{border-color:rgba(20,184,166,.22);box-shadow:0 10px 30px rgba(15,23,42,.08)}
.booking-upsell-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease,opacity .28s ease;opacity:0}
.booking-upsell-panel:not([hidden]){opacity:1}
.booking-upsell-panel__inner{min-height:0;overflow:hidden;padding-top:2px}
.booking-upsell-shell.is-open .booking-upsell-panel{grid-template-rows:1fr}
.booking-upsell-tabs{display:grid;gap:18px;padding-top:8px}
.booking-upsell-tabs__nav{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;padding:8px;border-radius:24px;background:rgba(148,163,184,.09);border:1px solid rgba(148,163,184,.16)}
.booking-upsell-tab{position:relative;display:flex;align-items:center;gap:12px;padding:14px 16px;border:0;border-radius:20px;background:transparent;color:var(--clr-text-soft);font-weight:800;cursor:pointer;transition:transform .28s ease,background .28s ease,color .28s ease,box-shadow .28s ease;text-align:left}
.booking-upsell-tab__icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:15px;background:rgba(255,255,255,.82);font-size:1.1rem;box-shadow:inset 0 0 0 1px rgba(15,118,110,.08)}
.booking-upsell-tab__label-wrap{display:grid;gap:2px;flex:1;min-width:0}
.booking-upsell-tab__label-wrap small{color:inherit;opacity:.78;font-size:.78rem;font-weight:600}
.booking-upsell-tab__count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 8px;border-radius:999px;background:rgba(255,255,255,.75);color:var(--clr-primary);font-size:.78rem;font-weight:800}
.booking-upsell-tab:hover{color:var(--clr-dark);background:rgba(255,255,255,.78);transform:translateY(-1px)}
.booking-upsell-tab.is-active{background:linear-gradient(135deg,rgba(15,118,110,.96),rgba(20,184,166,.88));color:#fff;box-shadow:0 18px 40px rgba(15,118,110,.18)}
.booking-upsell-tab.is-active .booking-upsell-tab__icon{background:rgba(255,255,255,.16);box-shadow:inset 0 0 0 1px rgba(255,255,255,.15)}
.booking-upsell-tab.is-active .booking-upsell-tab__count{background:rgba(255,255,255,.18);color:#fff}
.booking-upsell-tabpanel{display:block}
.booking-upsell-tabpanel[hidden]{display:none}
.booking-upsell-tabs__content{display:grid}
.booking-upsell-tabpanel{animation:upsellFade .32s ease}
.booking-upsell-tabpanel__head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px;padding:6px 2px 0}
.booking-upsell-tabpanel__eyebrow{margin:0 0 6px;color:var(--clr-primary);font-weight:800;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}
.booking-upsell-tabpanel__head h3{margin:0;color:var(--clr-dark);font-size:1.12rem}
.booking-upsell-tabpanel__head p:last-child{margin:6px 0 0;color:var(--clr-text-soft)}
@keyframes upsellFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.booking-upsell-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;padding-top:8px}
.booking-upsell-card{position:relative;display:grid;grid-template-columns:110px minmax(0,1fr);cursor:pointer;border:1px solid var(--clr-border);border-radius:24px;background:#fff;box-shadow:var(--shadow-sm);transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease, opacity .25s ease;overflow:hidden}
.booking-upsell-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.booking-upsell-card.is-selected{border-color:rgba(20,184,166,.45);box-shadow:0 0 0 4px rgba(20,184,166,.08),var(--shadow-md)}
.booking-upsell-card__checkbox{position:absolute;top:18px;right:18px;width:18px;height:18px;accent-color:var(--clr-primary);z-index:2}
.booking-upsell-card__media{position:relative;min-height:100%;background:linear-gradient(135deg,rgba(15,118,110,.14),rgba(20,184,166,.08));overflow:hidden}
.booking-upsell-card__media img{width:100%;height:100%;display:block;object-fit:cover}
.booking-upsell-card__media.is-placeholder{display:flex;align-items:center;justify-content:center}
.booking-upsell-card__media.is-placeholder span{font-size:1.6rem;opacity:.75}
.booking-upsell-card__body{padding:20px 20px 18px;display:grid;gap:10px}
.booking-upsell-card__badge{display:inline-flex;align-items:center;justify-content:center;width:max-content;padding:6px 10px;border-radius:999px;background:rgba(20,184,166,.1);color:var(--clr-primary);font-weight:700;font-size:.78rem}
.booking-upsell-card__body h3{margin:0;color:var(--clr-dark);font-size:1.03rem;padding-right:26px}
.booking-upsell-card__body p{margin:0;color:var(--clr-text-soft);font-size:.95rem}
.booking-upsell-card__subtitle{font-weight:700;color:var(--clr-dark)!important}
.booking-upsell-card__footer{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-top:6px}
.booking-upsell-card__footer strong{font-size:1.05rem;color:var(--clr-dark)}
.booking-upsell-card__footer span{color:var(--clr-text-soft);font-size:.86rem;text-align:right}
.booking-upsell-card.is-collapsed{display:none}
.booking-upsell-grid.is-expanded .booking-upsell-card.is-collapsed{display:grid}
.booking-upsell-more-wrap{display:flex;justify-content:center;padding-top:10px}
.booking-upsell-more{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:999px;border:1px solid rgba(15,118,110,.14);background:rgba(255,255,255,.88);color:var(--clr-primary);font-weight:800;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}
.booking-upsell-more:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.booking-upsell-more::after{content:"";width:8px;height:8px;margin-left:10px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);transition:transform .25s ease}
.booking-upsell-grid.is-expanded + .booking-upsell-more-wrap .booking-upsell-more::after{transform:rotate(225deg)}

.booking-upsell-tabs__nav{position:relative;overflow:hidden;backdrop-filter:blur(10px)}
.booking-upsell-tabs__nav::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(20,184,166,.18),transparent 34%),radial-gradient(circle at bottom left,rgba(59,130,246,.08),transparent 30%);pointer-events:none}
.booking-upsell-tab{isolation:isolate}
.booking-upsell-tab::after{content:"";position:absolute;inset:auto 16px 10px;height:3px;border-radius:999px;background:linear-gradient(90deg,#fff,rgba(255,255,255,.45));opacity:0;transform:scaleX(.35);transform-origin:center;transition:transform .28s ease,opacity .28s ease}
.booking-upsell-tab.is-active::after{opacity:1;transform:scaleX(1)}
.booking-upsell-tabpanel__desc{margin:8px 0 0;color:var(--clr-text-soft)}
.booking-upsell-tabpanel__meta{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}
.booking-upsell-chip{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.86);border:1px solid rgba(15,118,110,.09);box-shadow:var(--shadow-sm);font-size:.8rem;font-weight:800;color:var(--clr-dark)}
.booking-upsell-chip--promo{background:rgba(254,242,242,.95);border-color:rgba(248,113,113,.18);color:#b91c1c}
.booking-upsell-chip--popular{background:rgba(255,247,237,.95);border-color:rgba(251,146,60,.18);color:#c2410c}
.booking-upsell-card__topline{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.booking-upsell-card__badges{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px;max-width:60%}
.booking-upsell-card__flag{display:inline-flex;align-items:center;justify-content:center;padding:6px 9px;border-radius:999px;font-size:.72rem;font-weight:800;line-height:1;border:1px solid transparent}
.booking-upsell-card__flag--popular{background:rgba(255,247,237,.95);border-color:rgba(251,146,60,.18);color:#c2410c}
.booking-upsell-card__flag--promo{background:rgba(254,242,242,.95);border-color:rgba(248,113,113,.18);color:#b91c1c}
.booking-upsell-card__flag--featured{background:rgba(236,253,245,.95);border-color:rgba(16,185,129,.16);color:#047857}
.booking-upsell-price-wrap{display:grid;gap:2px}
.booking-upsell-price-old{text-decoration:line-through;color:var(--clr-text-soft);font-size:.84rem}
.booking-upsell-card__body h3{padding-right:0}
.booking-upsell-card__media::after{content:"";position:absolute;inset:auto 0 0 0;height:44%;background:linear-gradient(180deg,transparent,rgba(15,23,42,.16));pointer-events:none}
.booking-upsell-card__media.is-placeholder::after{display:none}
@media (max-width:768px){
  .booking-upsell-tabpanel__head{flex-direction:column}
  .booking-upsell-tabpanel__meta{justify-content:flex-start}
  .booking-upsell-card__topline{flex-direction:column;align-items:flex-start}
  .booking-upsell-card__badges{max-width:none;justify-content:flex-start}
}

@media (max-width: 768px){
  .booking-form-grid--inner,.booking-upsell-grid{grid-template-columns:1fr}
  .booking-upsell-card{grid-template-columns:1fr}
  .booking-upsell-tabs__nav{padding:4px;gap:8px}
  .booking-upsell-tabs__nav{grid-template-columns:1fr}
  .booking-upsell-tab{padding:12px 13px}
  .booking-section{padding:18px}
  .booking-section__header{align-items:flex-start}
  .booking-upsell-intro{flex-direction:column;align-items:flex-start}
  .booking-upsell-intro__meta{justify-content:flex-start}
  .booking-upsell-toggle{padding:16px 16px 16px 18px}
}


.newsletter-band{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center;margin-top:-36px;margin-bottom:38px;padding:32px;border-radius:32px;background:linear-gradient(135deg, rgba(15,23,42,.92), rgba(15,118,110,.92));box-shadow:var(--shadow-lg);overflow:hidden}
.newsletter-band::before,.newsletter-band::after{content:"";position:absolute;border-radius:999px;background:rgba(255,255,255,.08);pointer-events:none}
.newsletter-band::before{width:260px;height:260px;top:-110px;right:-60px}
.newsletter-band::after{width:180px;height:180px;bottom:-90px;left:42%}
.newsletter-band > *{position:relative;z-index:1}
.newsletter-band__content h2{margin:10px 0 12px;color:#fff;font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.02;letter-spacing:-.04em}
.newsletter-band__content p{margin:0;color:rgba(255,255,255,.82);max-width:58ch}
.newsletter-band__eyebrow{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.12);color:#fff;font-size:.82rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em}
.newsletter-band__highlights{display:flex;flex-wrap:wrap;gap:12px;list-style:none;padding:0;margin:20px 0 0}
.newsletter-band__highlights li{display:inline-flex;align-items:center;gap:10px;padding:12px 14px;border-radius:999px;background:rgba(255,255,255,.1);color:#fff;font-weight:600}
.newsletter-band__form-wrap{background:rgba(255,255,255,.96);border:1px solid rgba(255,255,255,.16);border-radius:28px;padding:22px;box-shadow:0 30px 70px rgba(15,23,42,.18)}
.newsletter-form{display:grid;gap:16px}
.newsletter-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.newsletter-form__field label{display:block;margin-bottom:8px;color:var(--clr-dark);font-size:.92rem;font-weight:800}
.newsletter-form__consent{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:18px;background:var(--clr-light);border:1px solid var(--clr-border);color:var(--clr-text)}
.newsletter-form__consent input{margin-top:3px;width:18px;height:18px;flex-shrink:0}
.newsletter-form__actions{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.newsletter-form__submit{min-width:180px}
.newsletter-form__submit.is-loading{pointer-events:none;opacity:.8}
.newsletter-form__submit.is-loading i{animation:newsletterSpin 1s linear infinite}
.newsletter-form__note{margin:0;color:var(--clr-text-soft);font-size:.92rem;max-width:30rem}
.newsletter-form__feedback{padding:14px 16px;border-radius:18px;font-weight:600}
.newsletter-form__feedback.is-success{background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.2);color:#15803d}
.newsletter-form__feedback.is-error{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);color:#b91c1c}
.newsletter-state-card{max-width:780px;margin:0 auto;background:rgba(255,255,255,.96);border:1px solid var(--clr-border);border-radius:32px;padding:38px;text-align:center;box-shadow:var(--shadow-md)}
.newsletter-state-card h1{margin:14px 0 12px;color:var(--clr-dark);font-size:clamp(2rem,4vw,3rem);letter-spacing:-.04em}
.newsletter-state-card p{margin:0 auto;max-width:58ch;color:var(--clr-text-soft);font-size:1.03rem}
.newsletter-state-card__icon{display:inline-grid;place-items:center;width:76px;height:76px;margin:0 auto;border-radius:50%;background:rgba(15,118,110,.1);color:var(--clr-primary);font-size:2rem}
.newsletter-state-card__icon.success{background:rgba(34,197,94,.1);color:#16a34a}
@keyframes newsletterSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

@media (max-width: 1024px){.newsletter-band{grid-template-columns:1fr;gap:22px}.newsletter-band__content p{max-width:none}}
@media (max-width: 720px){.newsletter-band{padding:24px;border-radius:26px;margin-top:-18px}.newsletter-form__grid{grid-template-columns:1fr}.newsletter-form__actions{align-items:stretch}.newsletter-form__submit{width:100%}.newsletter-band__highlights li{width:100%;justify-content:flex-start}.newsletter-state-card{padding:28px 20px;border-radius:24px}}


/* Newsletter premium refresh */
.newsletter-band{grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);gap:34px;padding:38px 40px;border-radius:36px;background:radial-gradient(circle at top left, rgba(56,189,248,.16), transparent 34%),linear-gradient(135deg, rgba(8,47,73,.98), rgba(15,118,110,.96) 58%, rgba(16,185,129,.88));box-shadow:0 30px 80px rgba(2,6,23,.22)}
.newsletter-band::before{width:340px;height:340px;top:-150px;right:-80px;background:rgba(255,255,255,.08)}
.newsletter-band::after{width:220px;height:220px;bottom:-120px;left:46%;background:rgba(125,211,252,.12)}
.newsletter-band__content{display:grid;gap:18px;align-content:start}
.newsletter-band__content h2{max-width:12ch;line-height:.98;font-size:clamp(2rem,4.4vw,4.2rem)}
.newsletter-band__content p{font-size:1.05rem;line-height:1.65;color:rgba(255,255,255,.84)}
.newsletter-band__mini-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:2px}
.newsletter-band__mini-stats article{padding:16px 18px;border-radius:22px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.05));backdrop-filter:blur(10px)}
.newsletter-band__mini-stats strong,.newsletter-band__mini-stats span{display:block;color:#fff}
.newsletter-band__mini-stats strong{font-size:1.15rem;font-weight:800;margin-bottom:6px}
.newsletter-band__mini-stats span{font-size:.92rem;line-height:1.45;color:rgba(255,255,255,.74)}
.newsletter-band__highlights{margin:2px 0 0}
.newsletter-band__highlights li{padding:13px 16px;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.05)}
.newsletter-band__visual{position:relative;min-height:120px;margin-top:4px}
.newsletter-orb{position:absolute;border-radius:999px;filter:blur(2px)}
.newsletter-orb--one{width:120px;height:120px;left:6%;bottom:8px;background:radial-gradient(circle, rgba(125,211,252,.45), rgba(125,211,252,.06) 68%, transparent 72%)}
.newsletter-orb--two{width:160px;height:160px;left:35%;top:-10px;background:radial-gradient(circle, rgba(34,197,94,.34), rgba(34,197,94,.05) 68%, transparent 72%)}
.newsletter-card-floating{position:relative;z-index:2;display:flex;align-items:center;gap:14px;max-width:340px;padding:18px 20px;border-radius:24px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 48px rgba(15,23,42,.18);backdrop-filter:blur(12px)}
.newsletter-card-floating__icon{display:grid;place-items:center;width:52px;height:52px;border-radius:18px;background:linear-gradient(135deg, rgba(255,255,255,.22), rgba(255,255,255,.08));color:#fff;font-size:1.2rem;flex-shrink:0}
.newsletter-card-floating strong,.newsletter-card-floating span{display:block;color:#fff}
.newsletter-card-floating span{margin-top:4px;color:rgba(255,255,255,.74);font-size:.92rem}
.newsletter-band__form-wrap{padding:26px;border-radius:30px;background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,250,252,.98));box-shadow:0 28px 72px rgba(15,23,42,.20)}
.newsletter-band__form-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.newsletter-band__form-head p{margin:0;color:var(--clr-text-soft);max-width:24rem;font-size:.95rem}
.newsletter-band__form-badge{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:999px;background:rgba(15,118,110,.09);color:var(--clr-primary-dark);font-weight:800;font-size:.82rem}
.newsletter-form__field .form-control{height:64px;border-radius:18px;background:#fff;border:1px solid rgba(148,163,184,.22);box-shadow:none;transition:border-color .25s ease, transform .25s ease, box-shadow .25s ease}
.newsletter-form__field .form-control:focus{border-color:rgba(20,184,166,.6);box-shadow:0 0 0 4px rgba(20,184,166,.12);transform:translateY(-1px)}
.newsletter-form__consent{padding:16px 18px;border-radius:20px;background:linear-gradient(180deg, rgba(241,245,249,.78), rgba(248,250,252,.96))}
.newsletter-form__actions{align-items:flex-end}
.newsletter-form__submit{min-width:196px;border-radius:999px;padding-inline:26px;box-shadow:0 18px 40px rgba(20,184,166,.24)}
.footer{background:radial-gradient(circle at top left, rgba(34,197,94,.08), transparent 18%),linear-gradient(180deg, #08111f 0%, #09182a 100%)}
.footer__grid{padding-top:8px}
@media (max-width: 1100px){.newsletter-band{grid-template-columns:1fr;padding:30px}.newsletter-band__content h2{max-width:none}.newsletter-band__visual{min-height:90px}.newsletter-card-floating{max-width:none}}
@media (max-width: 720px){.newsletter-band{padding:24px 18px;border-radius:28px}.newsletter-band__mini-stats{grid-template-columns:1fr}.newsletter-band__form-wrap{padding:20px;border-radius:24px}.newsletter-band__form-head{display:grid}.newsletter-form__field .form-control{height:58px}.newsletter-card-floating{padding:16px 18px;border-radius:20px}}

/* =========================
   NAVBAR CLEAN PREMIUM
   ========================= */

.site-header{
    position:sticky;
    top:0;
    z-index:1200;
    background:rgba(248,250,252,.88);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border-bottom:1px solid rgba(15,23,42,.06);
    transform:translateY(0);
    transition:transform .34s ease, background-color .24s ease, box-shadow .24s ease, border-color .24s ease;
    will-change:transform;
    overflow:visible;
}
.site-header.site-header--hidden{transform:translateY(calc(-100% - 10px))}
.site-header.header-scrolled{
    background:rgba(248,250,252,.94);
    box-shadow:0 18px 38px rgba(15,23,42,.08);
}
.site-header .container{
    position:relative;
    width:min(100% - 24px, var(--container));
}

.site-nav{
    min-height:88px;
    display:grid;
    grid-template-columns:auto minmax(0,1fr) auto;
    align-items:center;
    gap:20px;
    overflow:visible;
}

.site-brand{
    min-width:0;
    display:inline-flex;
    align-items:center;
    gap:16px;
    flex:0 0 auto;
}

.site-brand__logo,
.site-brand__logo--image{
    width:176px;
    height:68px;
    min-width:176px;
    border-radius:24px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:transparent !important;
    border:none !important;
    box-shadow:none !important;
    padding:0 !important;
    overflow:visible !important;
}
.site-brand__logo--image{
    border-radius:24px !important;
}
.site-brand__logo-img{
    width:100%;
    height:100%;
    display:block;
    object-fit:contain;
    object-position:center left;
    border-radius:24px;
    background:transparent !important;
    filter:none !important;
}

.site-brand__text{
    min-width:0;
    display:flex;
    flex-direction:column;
    gap:2px;
    line-height:1.06;
}
.site-brand__title{
    margin:0;
    font-size:1.02rem;
    font-weight:800;
    letter-spacing:-.03em;
    color:var(--clr-dark);
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.site-brand__subtitle{
    margin:0;
    font-size:.84rem;
    color:var(--clr-text-soft);
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}

.site-nav__links{
    min-width:0;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    flex-wrap:wrap;
}
.site-nav__link{
    position:relative;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:46px;
    padding:0 15px;
    border-radius:999px;
    font-weight:700;
    color:var(--clr-dark-2);
    background:transparent;
    white-space:nowrap;
    transition:transform .22s ease, background .22s ease, color .22s ease, box-shadow .22s ease;
}
.site-nav__link:hover,
.site-nav__link.is-active{
    color:var(--clr-primary);
    background:rgba(20,184,166,.10);
    box-shadow:inset 0 0 0 1px rgba(20,184,166,.12);
}

.site-nav__actions{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:10px;
    overflow:visible;
    flex:0 0 auto;
}

.lang-switcher{display:inline-flex;align-items:center;margin:0}
.lang-switcher__select{
    min-width:82px;
    min-height:48px;
    padding:0 14px;
    border-radius:16px;
    border:1px solid rgba(15,23,42,.10);
    background:rgba(255,255,255,.92);
    color:var(--clr-dark);
    font-weight:700;
    box-shadow:0 10px 24px rgba(15,23,42,.05);
}
.lang-switcher--mobile{
    width:100%;
    margin-bottom:0;
}
.lang-switcher--mobile .lang-switcher__select{
    width:100%;
    min-height:54px;
    border-radius:18px;
    box-shadow:none;
}

.desktop-dropdown{
    position:relative;
    overflow:visible;
}
.desktop-dropdown__summary{
    list-style:none;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:48px;
    padding:0 18px;
    border-radius:999px;
    border:1px solid rgba(15,23,42,.08);
    background:rgba(255,255,255,.88);
    color:var(--clr-dark);
    font-weight:800;
    box-shadow:0 12px 28px rgba(15,23,42,.06);
    transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.desktop-dropdown__summary::-webkit-details-marker{display:none}
.desktop-dropdown__summary:hover{
    transform:translateY(-1px);
    border-color:rgba(20,184,166,.18);
    box-shadow:0 18px 32px rgba(15,23,42,.10);
}
.desktop-dropdown[open] .desktop-dropdown__summary{
    color:var(--clr-primary);
    border-color:rgba(20,184,166,.22);
}
.desktop-dropdown__menu{
    position:absolute;
    top:calc(100% + 14px);
    right:0;
    width:min(380px, calc(100vw - 32px));
    max-height:min(72vh, 680px);
    overflow-y:auto;
    overflow-x:hidden;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
    scrollbar-gutter:stable;
    padding:18px;
    border-radius:24px;
    border:1px solid rgba(15,23,42,.08);
    background:rgba(255,255,255,.97);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    box-shadow:0 24px 60px rgba(15,23,42,.14);
    z-index:1250;
    display:grid;
    gap:14px;
}
.desktop-dropdown__menu::-webkit-scrollbar{width:10px}
.desktop-dropdown__menu::-webkit-scrollbar-track{background:transparent}
.desktop-dropdown__menu::-webkit-scrollbar-thumb{
    background:rgba(15,118,110,.22);
    border-radius:999px;
    border:2px solid transparent;
    background-clip:padding-box;
}
.desktop-dropdown__menu::-webkit-scrollbar-thumb:hover{
    background:rgba(15,118,110,.35);
    border:2px solid transparent;
    background-clip:padding-box;
}
.desktop-dropdown__group{
    border:1px solid rgba(15,23,42,.06);
    border-radius:18px;
    padding:14px;
    background:#f8fafc;
}
.desktop-dropdown__title{
    margin:0 0 8px;
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--clr-text-soft);
}
.desktop-dropdown__link,
.desktop-dropdown__link--button{
    display:flex;
    width:100%;
    align-items:center;
    min-height:46px;
    padding:10px 14px;
    border-radius:16px;
    color:var(--clr-dark);
    background:transparent;
    border:none;
    font-weight:700;
    margin-bottom:6px;
    transition:background .22s ease, color .22s ease, transform .22s ease;
}
.desktop-dropdown__link:last-child,
.desktop-dropdown__link--button:last-child{margin-bottom:0}
.desktop-dropdown__link:hover,
.desktop-dropdown__link--button:hover{
    background:rgba(20,184,166,.10);
    color:var(--clr-primary);
}
.desktop-dropdown__link--primary{
    background:linear-gradient(135deg,#14b8a6,#22c55e);
    color:#fff;
}
.desktop-dropdown__form{margin:0}
.desktop-dropdown__link--button{cursor:pointer;text-align:left;font:inherit}

.site-nav__toggle,
.site-mobile__close{
    appearance:none;
    border:none;
    outline:none;
}
.site-nav__toggle{
    display:none;
    position:relative;
    width:54px;
    height:54px;
    border-radius:18px;
    background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.88));
    border:1px solid rgba(15,23,42,.09);
    box-shadow:0 16px 34px rgba(15,23,42,.08);
    align-items:center;
    justify-content:center;
    flex-direction:column;
    gap:5px;
    transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.site-nav__toggle:hover{
    transform:translateY(-1px);
    border-color:rgba(20,184,166,.22);
    box-shadow:0 22px 40px rgba(15,23,42,.12);
}
.site-nav__toggle span{
    display:block;
    width:22px;
    height:2.5px;
    border-radius:999px;
    background:var(--clr-dark);
    transition:transform .24s ease, opacity .24s ease;
}
.site-nav__toggle.is-active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.site-nav__toggle.is-active span:nth-child(2){opacity:0}
.site-nav__toggle.is-active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.site-mobile-overlay{
    position:fixed;
    inset:0;
    z-index:1190;
    background:rgba(15,23,42,.38);
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:opacity .28s ease, visibility .28s ease;
}
.site-mobile{
    position:fixed;
    inset:0;
    z-index:1195;
    display:block;
    pointer-events:none;
    visibility:hidden;
}
.site-mobile__panel{
    position:absolute;
    top:0;
    right:0;
    width:min(420px, 100vw);
    height:100dvh;
    padding:18px 18px calc(22px + env(safe-area-inset-bottom));
    background:linear-gradient(180deg, rgba(248,250,252,.98), rgba(255,255,255,.96));
    border-left:1px solid rgba(15,23,42,.07);
    box-shadow:-24px 0 60px rgba(15,23,42,.16);
    transform:translateX(100%);
    transition:transform .30s ease;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    border-radius:28px 0 0 28px;
}
.site-mobile__header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    padding-bottom:14px;
    border-bottom:1px solid rgba(15,23,42,.07);
}
.site-mobile__brand{
    min-width:0;
    display:flex;
    align-items:center;
    gap:12px;
}
.site-mobile__brand .site-brand__logo,
.site-mobile__brand .site-brand__logo--image{
    width:136px;
    height:52px;
    min-width:136px;
    border-radius:18px;
}
.site-mobile__brand .site-brand__logo-img{
    border-radius:18px;
}
.site-mobile__brand-text{
    display:flex;
    flex-direction:column;
    min-width:0;
}
.site-mobile__brand-text strong{
    color:var(--clr-dark);
    font-size:1rem;
    letter-spacing:-.03em;
}
.site-mobile__brand-text span{
    color:var(--clr-text-soft);
    font-size:.88rem;
}
.site-mobile__close{
    position:relative;
    flex:0 0 auto;
    width:48px;
    height:48px;
    border-radius:16px;
    background:rgba(15,23,42,.05);
    border:1px solid rgba(15,23,42,.06);
}
.site-mobile__close span{
    position:absolute;
    left:50%;
    top:50%;
    width:20px;
    height:2px;
    border-radius:999px;
    background:var(--clr-dark);
}
.site-mobile__close span:first-child{transform:translate(-50%, -50%) rotate(45deg)}
.site-mobile__close span:last-child{transform:translate(-50%, -50%) rotate(-45deg)}
.site-mobile__body{
    flex:1 1 auto;
    overflow-y:auto;
    padding-top:16px;
    display:flex;
    flex-direction:column;
    gap:16px;
    overscroll-behavior:contain;
}
.site-mobile__links,
.site-mobile__section{
    display:grid;
    gap:10px;
}
.site-mobile__section{
    padding:16px;
    border-radius:22px;
    background:rgba(255,255,255,.82);
    border:1px solid rgba(15,23,42,.06);
    box-shadow:0 14px 34px rgba(15,23,42,.05);
}
.site-mobile__section-title{
    margin:0 0 2px;
    font-size:.86rem;
    font-weight:800;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--clr-text-soft);
}
.site-mobile__link,
.site-mobile__button-link{
    display:flex;
    align-items:center;
    width:100%;
    min-height:54px;
    padding:0 16px;
    border-radius:18px;
    background:#fff;
    border:1px solid rgba(15,23,42,.06);
    color:var(--clr-dark);
    font-weight:700;
    box-shadow:0 10px 22px rgba(15,23,42,.04);
    transition:transform .22s ease, border-color .22s ease, background .22s ease, color .22s ease;
}
.site-mobile__link:hover,
.site-mobile__button-link:hover,
.site-mobile__link--primary{
    background:rgba(20,184,166,.10);
    border-color:rgba(20,184,166,.16);
    color:var(--clr-primary);
}
.site-mobile__button-link{cursor:pointer;text-align:left}

body.menu-open{
    overflow:hidden;
    touch-action:none;
}
body.menu-open .site-mobile-overlay{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
}
body.menu-open .site-mobile{
    visibility:visible;
    pointer-events:auto;
}
body.menu-open .site-mobile__panel{
    transform:translateX(0);
}

@media (max-width: 1280px){
    .site-brand__logo,
    .site-brand__logo--image{
        width:160px;
        height:62px;
        min-width:160px;
    }
    .site-brand__text{
        max-width:250px;
    }
    .site-brand__subtitle{
        display:none;
    }
    .site-nav__link{
        padding:0 12px;
        font-size:.96rem;
    }
}

@media (max-width: 1150px){
    .site-nav{
        grid-template-columns:auto auto;
        gap:14px;
    }
    .site-nav__links,
    .btn-desktop,
    .lang-switcher--desktop{
        display:none !important;
    }
    .site-nav__toggle{
        display:inline-flex !important;
    }
}

@media (min-width: 1151px){
    .site-mobile,
    .site-mobile-overlay{
        display:none !important;
    }
}

@media (max-width: 767px){
    .site-header .container{
        width:min(100% - 16px, var(--container));
    }
    .site-nav{
        min-height:78px;
        gap:12px;
    }
    .site-brand{
        gap:12px;
    }
    .site-brand__logo,
    .site-brand__logo--image{
        width:136px;
        height:54px;
        min-width:136px;
        border-radius:18px;
    }
    .site-brand__logo-img{
        border-radius:18px;
    }
    .site-brand__title{font-size:.98rem}
    .site-brand__subtitle{display:none}
    .site-mobile__panel{
        width:min(100vw, 100%);
        border-radius:24px 0 0 24px;
        padding:16px 16px calc(18px + env(safe-area-inset-bottom));
    }
}

@media (max-width: 404px){
    .site-header .container{
        width:min(100% - 14px, var(--container));
    }
    .site-nav{
        min-height:70px;
        gap:10px;
    }
    .site-brand{
        gap:10px;
    }
    .site-brand__logo,
    .site-brand__logo--image{
        width:116px;
        height:46px;
        min-width:116px;
        border-radius:16px;
    }
    .site-brand__logo-img{
        border-radius:16px;
    }
    .site-brand__text{
        max-width:132px;
    }
    .site-brand__title{
        font-size:.92rem;
    }
    .site-nav__toggle{
        width:48px;
        height:48px;
    }
    .site-mobile__panel{
        border-radius:20px 0 0 20px;
    }
}

/* === Recherche globale flottante === */
.site-search-fab{
    position:fixed;right:18px;bottom:84px;width:58px;height:58px;border:none;border-radius:20px;
    background:linear-gradient(135deg,#0f766e,#14b8a6);color:#fff;display:grid;place-items:center;
    box-shadow:0 18px 45px rgba(15,118,110,.28);z-index:1001;cursor:pointer;transition:transform .24s ease,box-shadow .24s ease,opacity .24s ease
}
.site-search-fab:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 22px 54px rgba(15,118,110,.34)}
.site-search-fab i{font-size:1.08rem}
.site-search-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;pointer-events:none;z-index:1200;transition:all .25s ease}
.site-search-modal.is-open{opacity:1;visibility:visible;pointer-events:auto}
.site-search-modal__backdrop{position:absolute;inset:0;background:rgba(2,6,23,.64);backdrop-filter:blur(10px)}
.site-search-modal__dialog{position:relative;width:min(760px,100%);border-radius:32px;background:rgba(255,255,255,.96);border:1px solid rgba(255,255,255,.7);box-shadow:0 34px 120px rgba(2,6,23,.28);overflow:hidden;transform:translateY(18px) scale(.98);transition:transform .28s ease}
.site-search-modal.is-open .site-search-modal__dialog{transform:translateY(0) scale(1)}
.site-search-modal__content{padding:38px 34px 30px}
.site-search-modal__eyebrow{display:inline-flex;padding:8px 14px;border-radius:999px;background:rgba(15,118,110,.1);color:#0f766e;font-weight:800;font-size:.84rem;margin-bottom:14px}
.site-search-modal__content h2{margin:0 0 10px;font-size:clamp(1.8rem,4vw,2.6rem);letter-spacing:-.04em;color:var(--clr-dark)}
.site-search-modal__content p{margin:0 0 22px;color:var(--clr-text-soft)}
.site-search-modal__close{position:absolute;top:18px;right:18px;width:46px;height:46px;border:none;border-radius:14px;background:rgba(15,23,42,.06);color:var(--clr-dark);display:grid;place-items:center;cursor:pointer;transition:var(--transition)}
.site-search-modal__close:hover{background:rgba(15,23,42,.1);transform:rotate(90deg)}
.site-search-form,.global-search-form{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.site-search-form__field,.global-search-form__field{position:relative;flex:1 1 420px}
.site-search-form__field i,.global-search-form__field i{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--clr-text-soft)}
.site-search-form__field input,.global-search-form__field input{width:100%;height:62px;border-radius:18px;border:1px solid var(--clr-border);background:#fff;padding:0 18px 0 48px;font-size:1rem;color:var(--clr-dark);outline:none;transition:var(--transition)}
.site-search-form__field input:focus,.global-search-form__field input:focus{border-color:rgba(15,118,110,.45);box-shadow:0 0 0 4px rgba(20,184,166,.12)}
.site-search-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.site-search-tags a{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:rgba(15,118,110,.08);color:#0f766e;font-weight:700;border:1px solid rgba(15,118,110,.12)}
.site-search-tags a:hover{background:rgba(15,118,110,.14)}
.global-search-box{margin-bottom:24px}
.search-section + .search-section{margin-top:26px}
.search-section__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.search-section__head h3{margin:0;color:var(--clr-dark);font-size:1.22rem}
.search-section__head span{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 12px;border-radius:999px;background:rgba(15,118,110,.09);color:#0f766e;font-weight:800}
.search-result-list{display:grid;gap:14px}
.search-result-card{display:grid;grid-template-columns:56px 1fr 26px;align-items:center;gap:16px;padding:18px 20px;border-radius:22px;background:rgba(255,255,255,.94);border:1px solid var(--clr-border);box-shadow:var(--shadow-sm);transition:var(--transition)}
.search-result-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.search-result-card__icon{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:var(--gradient-soft);color:#0f766e;font-size:1.12rem}
.search-result-card h4{margin:0 0 6px;color:var(--clr-dark)}
.search-result-card p{margin:0;color:var(--clr-text-soft)}
.search-result-card__arrow{color:var(--clr-text-soft);justify-self:end}
body.search-open{overflow:hidden}
@media (max-width: 767px){
    .site-search-fab{right:14px;bottom:78px;width:54px;height:54px;border-radius:18px}
    .site-search-modal{padding:14px}
    .site-search-modal__dialog{border-radius:24px}
    .site-search-modal__content{padding:28px 18px 20px}
    .site-search-form,.global-search-form{flex-direction:column;align-items:stretch}
    .site-search-form .btn,.global-search-form .btn{width:100%}
    .search-result-card{grid-template-columns:48px 1fr 18px;padding:16px}
    .search-result-card__icon{width:48px;height:48px;border-radius:16px}
}

/* ===== PREMIUM ERROR PAGES ===== */
.error-page-body{
    margin:0;
    min-height:100vh;
    font-family:'Inter',system-ui,sans-serif;
    background:
        radial-gradient(circle at top left, rgba(20,184,166,.20), transparent 34%),
        radial-gradient(circle at right center, rgba(251,191,36,.18), transparent 30%),
        linear-gradient(180deg, #f8fafc 0%, #eef6f7 100%);
    color:#0f172a;
}

.error-page-shell{
    position:relative;
    min-height:100vh;
    overflow:hidden;
}

.error-page-bg{
    position:absolute;
    inset:0;
    pointer-events:none;
}

.error-page-blob{
    position:absolute;
    border-radius:999px;
    filter:blur(18px);
    opacity:.55;
}

.error-page-blob--one{
    width:420px;
    height:420px;
    background:rgba(20,184,166,.18);
    top:-90px;
    left:-100px;
}

.error-page-blob--two{
    width:360px;
    height:360px;
    background:rgba(251,191,36,.15);
    right:-100px;
    bottom:-80px;
}

.error-page-grid{
    position:absolute;
    inset:0;
    background-image:linear-gradient(rgba(15,23,42,.03) 1px, transparent 1px), linear-gradient(90deg, rgba(15,23,42,.03) 1px, transparent 1px);
    background-size:34px 34px;
    mask-image:linear-gradient(180deg, rgba(0,0,0,.32), transparent 85%);
}

.error-page-main{
    position:relative;
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:28px;
}

.error-hero-card{
    position:relative;
    width:min(1180px, 100%);
    padding:28px;
    border-radius:36px;
    background:rgba(255,255,255,.82);
    border:1px solid rgba(255,255,255,.72);
    backdrop-filter:blur(16px);
    box-shadow:0 35px 120px rgba(15,23,42,.14);
}

.error-brand{
    display:inline-flex;
    align-items:center;
    gap:14px;
    text-decoration:none;
    color:inherit;
    margin-bottom:24px;
}

.error-brand__logo{
    width:68px;
    height:68px;
    border-radius:22px;
    overflow:hidden;
    border:1px solid rgba(15,23,42,.08);
    background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(241,245,249,.92));
    box-shadow:0 16px 44px rgba(15,23,42,.12);
}

.error-brand__logo img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.error-brand__text{
    display:flex;
    flex-direction:column;
}

.error-brand__text strong{
    font-size:1.1rem;
    letter-spacing:-.03em;
}

.error-brand__text span{
    color:#475569;
    font-size:.92rem;
}

.error-hero{
    display:grid;
    grid-template-columns:minmax(0, 1.2fr) minmax(280px, .7fr);
    gap:26px;
    align-items:stretch;
}

.error-hero__content,
.error-hero__aside{
    border-radius:30px;
    padding:clamp(24px, 4vw, 42px);
}

.error-hero__content{
    background:linear-gradient(145deg, rgba(255,255,255,.95), rgba(255,255,255,.82));
    border:1px solid rgba(15,23,42,.06);
    box-shadow:0 16px 46px rgba(15,23,42,.07);
}

.error-hero__content h1{
    margin:16px 0 14px;
    font-size:clamp(2rem, 5vw, 4rem);
    line-height:1.02;
    letter-spacing:-.05em;
    color:#0f172a;
    max-width:13ch;
}

.error-hero__content p{
    margin:0;
    max-width:62ch;
    color:#475569;
    font-size:1.03rem;
    line-height:1.8;
}

.error-badge{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:10px 16px;
    border-radius:999px;
    background:rgba(15,118,110,.10);
    border:1px solid rgba(15,118,110,.12);
    color:#0f766e;
    font-weight:800;
    font-size:.9rem;
}

.error-actions{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin-top:28px;
}

.error-hero__aside{
    position:relative;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    gap:20px;
    background:linear-gradient(180deg, #0f172a 0%, #10233e 100%);
    color:#fff;
    overflow:hidden;
    box-shadow:0 20px 60px rgba(15,23,42,.20);
}

.error-hero__aside::before,
.error-hero__aside::after{
    content:"";
    position:absolute;
    border-radius:999px;
    background:rgba(255,255,255,.06);
}

.error-hero__aside::before{
    width:180px;
    height:180px;
    top:-60px;
    right:-40px;
}

.error-hero__aside::after{
    width:120px;
    height:120px;
    bottom:-30px;
    left:-20px;
}

.error-code{
    position:relative;
    font-size:clamp(4rem, 9vw, 7rem);
    font-weight:900;
    line-height:.92;
    letter-spacing:-.08em;
    color:#fff;
}

.error-tips{
    position:relative;
    list-style:none;
    margin:0;
    padding:0;
    display:grid;
    gap:14px;
}

.error-tips li{
    display:flex;
    gap:12px;
    align-items:flex-start;
    color:rgba(255,255,255,.88);
    line-height:1.6;
}

.error-tips i{
    margin-top:4px;
    color:#5eead4;
}

@media (max-width: 900px){
    .error-hero{
        grid-template-columns:1fr;
    }

    .error-hero__content h1{
        max-width:none;
    }

    .error-code{
        font-size:clamp(3.5rem, 16vw, 6rem);
    }
}

@media (max-width: 640px){
    .error-page-main{
        padding:14px;
    }

    .error-hero-card{
        padding:18px;
        border-radius:28px;
    }

    .error-brand{
        gap:12px;
        margin-bottom:18px;
    }

    .error-brand__logo{
        width:58px;
        height:58px;
        border-radius:18px;
    }

    .error-hero__content,
    .error-hero__aside{
        border-radius:24px;
        padding:22px 18px;
    }

    .error-actions .btn{
        width:100%;
        justify-content:center;
    }
}


@media (prefers-reduced-motion: reduce){
    .site-header{
        transition:none;
    }
}

.category-card{
    display:flex;
    flex-direction:column;
    min-height:100%;
    overflow:hidden;
    border-radius:28px;
    background:#fff;
    border:1px solid rgba(15, 23, 42, 0.08);
    box-shadow:0 18px 45px rgba(15, 23, 42, 0.08);
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    text-decoration:none;
    color:inherit;
}

.category-card:hover{
    transform:translateY(-6px);
    box-shadow:0 24px 55px rgba(15, 23, 42, 0.14);
    border-color:rgba(15, 118, 110, 0.18);
}

.category-card__media{
    position:relative;
    aspect-ratio: 16 / 10;
    overflow:hidden;
    background:linear-gradient(135deg, rgba(15,118,110,.12), rgba(14,165,233,.10));
    display:flex;
    align-items:center;
    justify-content:center;
}

.category-card__image{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.category-card__content{
    padding:1.25rem 1.25rem 1.35rem;
    display:flex;
    flex-direction:column;
    gap:.75rem;
}

.category-card__type{
    display:inline-flex;
    align-self:flex-start;
    padding:.42rem .78rem;
    border-radius:999px;
    background:rgba(15,118,110,.08);
    color:#0f766e;
    font-weight:700;
    font-size:.86rem;
}

.category-card__content h3{
    margin:0;
    font-size:1.35rem;
    line-height:1.2;
}

.category-card__content p{
    margin:0;
    color:#64748b;
    line-height:1.7;
}

.category-card__link{
    margin-top:auto;
    font-weight:800;
    color:#0f172a;
}

/* =========================
   PACK SUR MESURE
========================= */
.custom-pack-form { gap: 1.5rem; }
.custom-pack-groups { display: grid; gap: 1rem; }
.custom-pack-group {
    border: 1px solid rgba(15, 118, 110, 0.12);
    border-radius: 26px;
    background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(246,250,251,0.98));
    box-shadow: 0 18px 48px rgba(15, 23, 42, 0.05);
    overflow: clip;
    transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease;
}
.custom-pack-group:hover {
    border-color: rgba(15, 118, 110, 0.22);
    box-shadow: 0 22px 56px rgba(15, 23, 42, 0.08);
}
.custom-pack-group.is-open {
    border-color: rgba(15, 118, 110, 0.28);
    box-shadow: 0 24px 60px rgba(15, 118, 110, 0.12);
}
.custom-pack-group__toggle {
    width: 100%;
    border: 0;
    background: transparent;
    padding: 1.15rem 1.2rem;
    text-align: left;
    cursor: pointer;
}
.custom-pack-group__toggle:focus-visible {
    outline: 3px solid rgba(15, 118, 110, 0.18);
    outline-offset: -3px;
}
.custom-pack-group__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}
.custom-pack-group__head-copy {
    min-width: 0;
    flex: 1 1 auto;
}
.custom-pack-group__head-copy > span {
    display: block;
}
.custom-pack-group__meta {
    display: inline-flex;
    align-items: center;
    gap: .7rem;
    flex-shrink: 0;
}
.custom-pack-group__eyebrow {
    margin: 0 0 .35rem;
    font-size: .8rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--color-primary, #0f766e);
}
.custom-pack-group__head h3 {
    margin: 0 0 .3rem;
    font-size: clamp(1.05rem, 1rem + .35vw, 1.3rem);
    color: #0f172a;
}
.custom-pack-group__head p {
    margin: 0;
    color: #475569;
    max-width: 60ch;
}
.custom-pack-group__chevron {
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 999px;
    background: rgba(15, 118, 110, 0.08);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform .28s ease, background-color .28s ease;
    position: relative;
}
.custom-pack-group__chevron::before {
    content: '';
    width: .68rem;
    height: .68rem;
    border-right: 2px solid #0f766e;
    border-bottom: 2px solid #0f766e;
    transform: rotate(45deg) translateY(-1px);
}
.custom-pack-group.is-open .custom-pack-group__chevron {
    transform: rotate(180deg);
    background: rgba(15, 118, 110, 0.14);
}
.custom-pack-group__panel {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows .34s ease;
}
.custom-pack-group.is-open .custom-pack-group__panel {
    grid-template-rows: 1fr;
}
.custom-pack-group__panel-inner {
    overflow: hidden;
    padding: 0 1.2rem;
}
.custom-pack-group.is-open .custom-pack-group__panel-inner {
    padding-bottom: 1.2rem;
}
.custom-pack-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    padding-top: .15rem;
}
.custom-pack-card {
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 22px;
    padding: 1rem;
    background: rgba(255,255,255,0.98);
    transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease, background-color .22s ease;
}
.custom-pack-card:hover {
    border-color: rgba(15, 118, 110, 0.24);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.06);
}
.custom-pack-card.is-selected {
    border-color: rgba(15, 118, 110, 0.52);
    box-shadow: 0 18px 40px rgba(15, 118, 110, 0.12);
    transform: translateY(-2px);
    background: linear-gradient(180deg, #ffffff, #f2fbf9);
}
.custom-pack-card__main {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: .85rem;
    align-items: flex-start;
    cursor: pointer;
}
.custom-pack-card__checkbox { position: absolute; opacity: 0; pointer-events: none; }
.custom-pack-card__checkmark {
    width: 1.25rem;
    height: 1.25rem;
    border-radius: 999px;
    border: 2px solid rgba(15, 118, 110, 0.4);
    margin-top: .2rem;
    position: relative;
    transition: border-color .2s ease, transform .2s ease;
}
.custom-pack-card.is-selected .custom-pack-card__checkmark {
    border-color: #0f766e;
    transform: scale(1.04);
}
.custom-pack-card.is-selected .custom-pack-card__checkmark::after {
    content: '';
    position: absolute;
    inset: 3px;
    border-radius: 999px;
    background: #0f766e;
}
.custom-pack-card__content strong { display:block; margin-bottom:.25rem; color:#0f172a; }
.custom-pack-card__content small { color:#64748b; }
.custom-pack-card__content p { margin:.4rem 0 0; color:#475569; }
.custom-pack-card__topline {
    display:flex; flex-wrap:wrap; gap:.45rem; margin-bottom:.35rem;
}
.custom-pack-card__type,
.custom-pack-card__category {
    display:inline-flex; align-items:center; padding:.22rem .58rem; border-radius:999px;
    background:#f1f5f9; font-size:.78rem;
}
.custom-pack-card__footer {
    margin-top: .95rem; display:flex; justify-content:space-between; align-items:end; gap:1rem;
}
.custom-pack-card__price { display:block; font-weight:700; color:#0f172a; }
.custom-pack-card__qty-wrap { display:grid; gap:.25rem; font-size:.82rem; color:#475569; }
.custom-pack-card__qty {
    width: 90px; border-radius: 12px; border: 1px solid rgba(15,23,42,.12); padding: .6rem .7rem; background:#fff;
}
.custom-pack-card__qty:disabled {
    opacity: .58;
    cursor: not-allowed;
    background: #f8fafc;
}
.custom-pack-summary-list { display:grid; gap:.85rem; }
.custom-pack-summary-item {
    display:flex; justify-content:space-between; align-items:center; gap:1rem;
    border:1px solid rgba(15,23,42,.08); border-radius:18px; padding:1rem 1.1rem; background:#fff;
}
@media (max-width: 900px) {
    .custom-pack-grid { grid-template-columns: 1fr; }
    .custom-pack-group__head, .custom-pack-summary-item { flex-direction: column; align-items: flex-start; }
    .custom-pack-group__meta { width: 100%; justify-content: space-between; }
}
@media (max-width: 640px) {
    .custom-pack-group__toggle { padding: 1rem; }
    .custom-pack-group__panel-inner { padding: 0 1rem; }
    .custom-pack-group.is-open .custom-pack-group__panel-inner { padding-bottom: 1rem; }
    .custom-pack-card { border-radius: 18px; }
    .custom-pack-card__footer {
        flex-direction: column;
        align-items: flex-start;
    }
    .custom-pack-card__qty { width: 100%; min-width: 110px; }
}

/* ===== HELP CENTER / SUPPORT ===== */
.site-help-fab,
.site-search-fab,
.scroll-top{display:grid;place-items:center}
.site-help-fab{
    position:fixed;right:18px;bottom:138px;width:52px;height:52px;border-radius:18px;
    background:linear-gradient(135deg,#0f172a,#0f766e);color:#fff;box-shadow:0 16px 38px rgba(15,23,42,.20);
    z-index:999;transition:transform .24s ease, box-shadow .24s ease, opacity .24s ease;
}
.site-help-fab:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 22px 46px rgba(15,23,42,.28)}
.site-help-fab i{font-size:1.08rem}
.footer__grid{grid-template-columns:1.15fr .85fr .85fr .85fr 1fr}
.help-hero{padding-bottom:32px}
.help-hero__grid{display:grid;grid-template-columns:minmax(0,1.2fr) 360px;gap:28px;align-items:start}
.help-hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.help-hero__card{background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.45);border-radius:28px;padding:24px;box-shadow:0 28px 64px rgba(15,23,42,.12)}
.help-hero__card h3{margin:0 0 14px;color:var(--clr-dark)}
.detail-list--light li{background:#fff}
.help-section{position:relative}
.help-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.help-card{background:rgba(255,255,255,.94);border:1px solid rgba(15,23,42,.08);border-radius:28px;padding:24px;box-shadow:0 18px 40px rgba(15,23,42,.06);transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease}
.help-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px rgba(15,23,42,.10);border-color:rgba(20,184,166,.16)}
.help-card__icon{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:var(--gradient-soft);color:var(--clr-primary);font-size:1.2rem;margin-bottom:16px}
.help-card h3{margin:0 0 10px;color:var(--clr-dark)}
.help-card p{margin:0 0 14px;color:var(--clr-text-soft)}
.help-card a{font-weight:800;color:var(--clr-primary)}
.help-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:start}
.help-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.help-steps--two{grid-template-columns:repeat(2,minmax(0,1fr))}
.help-steps article{padding:22px;border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,252,.98));border:1px solid rgba(15,23,42,.07);box-shadow:0 14px 30px rgba(15,23,42,.05)}
.help-steps strong{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:14px;background:rgba(20,184,166,.10);color:var(--clr-primary);font-size:1rem;margin-bottom:14px}
.help-steps h3{margin:0 0 8px;color:var(--clr-dark)}
.help-steps p{margin:0;color:var(--clr-text-soft)}
.help-faq-grid,.help-split-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.help-note{padding:18px 20px;border-radius:20px;background:var(--gradient-soft);border:1px solid rgba(15,118,110,.12);color:var(--clr-dark);font-weight:600}
.help-longform{display:grid;gap:22px}
.sidebar-list--light a{color:#fff}
.sidebar-list--light a:hover{color:rgba(255,255,255,.84)}
@media (max-width: 1199px){
    .footer__grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .help-hero__grid,.help-layout{grid-template-columns:1fr}
}
@media (max-width: 991px){
    .help-card-grid,.help-steps,.help-steps--two,.help-faq-grid,.help-split-grid{grid-template-columns:1fr}
}
@media (max-width: 767px){
    .site-help-fab{right:14px;bottom:138px;width:54px;height:54px;border-radius:18px}
    .site-search-fab{bottom:78px}
    .footer__bottom-links{justify-content:center}
    .help-hero__card,.help-card{border-radius:24px}
}

.category-links-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
    gap:1rem;
    margin-top:1.5rem;
}

.category-link-card{
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    gap:1rem;
    padding:1.1rem 1.1rem 1rem;
    border-radius:1.1rem;
    text-decoration:none;
    background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,252,.96));
    border:1px solid rgba(15,23,42,.08);
    box-shadow:0 14px 34px rgba(15,23,42,.07);
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    height:100%;
}

.category-link-card:hover{
    transform:translateY(-4px);
    box-shadow:0 20px 42px rgba(15,23,42,.12);
    border-color:rgba(14,165,233,.28);
}

.category-link-card__label{
    display:inline-flex;
    align-items:center;
    width:max-content;
    padding:.28rem .68rem;
    border-radius:999px;
    font-size:.76rem;
    font-weight:700;
    letter-spacing:.04em;
    text-transform:uppercase;
    background:rgba(14,165,233,.10);
    color:#0369a1;
    margin-bottom:.75rem;
}

.category-link-card h3{
    margin:0 0 .45rem;
    font-size:1.08rem;
    line-height:1.35;
    color:#0f172a;
}

.category-link-card p{
    margin:0;
    color:#475569;
    line-height:1.65;
}

.category-link-card__meta{
    display:inline-flex;
    align-items:center;
    gap:.45rem;
    font-size:.9rem;
    font-weight:700;
    color:#0f766e;
}

@media (max-width: 640px){
    .category-links-grid{
        grid-template-columns:1fr;
    }

    .category-link-card{
        padding:1rem;
        border-radius:1rem;
    }
}

/* =========================
   FOOTER PREMIUM RESPONSIVE
   ========================= */

.footer{
    position:relative;
    margin-top:70px;
    color:#fff;
    overflow:hidden;
    background:
        radial-gradient(circle at top left, rgba(34,197,94,.08), transparent 18%),
        radial-gradient(circle at bottom right, rgba(56,189,248,.08), transparent 22%),
        linear-gradient(180deg, #08111f 0%, #09182a 100%);
}

.footer::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at top left, rgba(20,184,166,.16), transparent 34%),
        radial-gradient(circle at bottom right, rgba(245,158,11,.14), transparent 34%);
    pointer-events:none;
}

.footer > *{
    position:relative;
    z-index:1;
}

.footer__grid{
    display:grid;
    grid-template-columns:minmax(0,1.15fr) repeat(4, minmax(0,.85fr));
    gap:24px;
    padding:12px 0 36px;
    align-items:start;
}

.footer__col{
    min-width:0;
}

.footer__col--brand{
    display:grid;
    gap:18px;
}

.footer__brandline{
    display:flex;
    align-items:flex-start;
    gap:14px;
}

.footer__logo-wrap{
    flex:0 0 auto;
}

.footer__brandline h3{
    margin:0;
    color:#fff;
    font-size:1.18rem;
    letter-spacing:-.03em;
}

.footer__brand-subtitle{
    margin:6px 0 0;
    color:rgba(255,255,255,.72);
    line-height:1.55;
}

.footer__col h4{
    margin:0 0 14px;
    color:#fff;
    font-size:1rem;
    font-weight:800;
    letter-spacing:-.02em;
}

.footer__col p,
.footer__col li{
    color:rgba(255,255,255,.74);
}

.footer__links,
.footer__infos{
    list-style:none;
    padding:0;
    margin:0;
    display:grid;
    gap:10px;
}

.footer__links li,
.footer__infos li{
    min-width:0;
}

.footer__links a,
.footer__infos a{
    color:rgba(255,255,255,.78);
    transition:color .22s ease, transform .22s ease;
    word-break:break-word;
}

.footer__links a:hover,
.footer__infos a:hover{
    color:#fff;
}

.footer__infos li{
    display:flex;
    align-items:flex-start;
    gap:10px;
    line-height:1.65;
}

.footer__infos li i{
    flex:0 0 18px;
    margin-top:4px;
    color:rgba(94,234,212,.88);
}

.footer__socials{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
}

.footer__socials a{
    width:46px;
    height:46px;
    border-radius:16px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.06);
    display:grid;
    place-items:center;
    transition:transform .22s ease, background .22s ease, border-color .22s ease;
}

.footer__socials a:hover{
    transform:translateY(-2px);
    background:rgba(255,255,255,.14);
    border-color:rgba(255,255,255,.14);
}

.footer__col .btn{
    margin-top:8px;
}

.footer__bottom{
    border-top:1px solid rgba(255,255,255,.10);
}

.footer__bottom-inner{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:14px 20px;
    flex-wrap:wrap;
    padding:18px 0 22px;
    color:rgba(255,255,255,.68);
}

.footer__bottom-inner p{
    margin:0;
}

.footer__bottom-links{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:10px;
    flex-wrap:wrap;
    margin:0;
}

.footer__bottom-links a{
    color:rgba(255,255,255,.82);
    transition:color .22s ease;
}

.footer__bottom-links a:hover{
    color:#fff;
}

/* ===== TABLET ===== */
@media (max-width: 1199px){
    .footer__grid{
        grid-template-columns:repeat(2, minmax(0,1fr));
        gap:22px;
    }

    .footer__col--brand{
        grid-column:1 / -1;
    }
}

/* ===== MOBILE LARGE ===== */
@media (max-width: 767px){
    .footer{
        margin-top:56px;
    }

    .footer__grid{
        grid-template-columns:1fr;
        gap:16px;
        padding:4px 0 26px;
    }

    .footer__col{
        padding:18px 18px;
        border-radius:22px;
        background:rgba(255,255,255,.04);
        border:1px solid rgba(255,255,255,.06);
        backdrop-filter:blur(8px);
        -webkit-backdrop-filter:blur(8px);
    }

    .footer__col--brand{
        gap:16px;
    }

    .footer__brandline{
        align-items:center;
    }

    .footer__brandline h3{
        font-size:1.08rem;
    }

    .footer__brand-subtitle{
        font-size:.95rem;
    }

    .footer__socials{
        gap:10px;
    }

    .footer__socials a{
        width:44px;
        height:44px;
        border-radius:14px;
    }

    .footer__links,
    .footer__infos{
        gap:9px;
    }

    .footer__infos li{
        font-size:.97rem;
    }

    .footer__bottom-inner{
        flex-direction:column;
        align-items:flex-start;
        padding:16px 0 18px;
    }

    .footer__bottom-links{
        justify-content:flex-start;
        gap:8px 10px;
    }

    .footer__bottom-links span{
        opacity:.5;
    }
}

/* ===== SMALL MOBILE ===== */
@media (max-width: 480px){
    .footer__grid{
        gap:14px;
    }

    .footer__col{
        padding:16px 15px;
        border-radius:20px;
    }

    .footer__brandline{
        gap:12px;
    }

    .footer__brandline h3{
        font-size:1rem;
    }

    .footer__brand-subtitle{
        font-size:.9rem;
        line-height:1.45;
    }

    .footer__col h4{
        font-size:.95rem;
        margin-bottom:12px;
    }

    .footer__links a,
    .footer__infos,
    .footer__col p{
        font-size:.95rem;
    }

    .footer__bottom-inner{
        font-size:.9rem;
    }
}

@media (max-width: 767px){
    .footer{
        padding-bottom:88px;
    }

    .site-search-fab{
        right:12px;
        bottom:86px;
    }

    .scroll-top{
        right:12px;
        bottom:18px;
    }

    .site-help-fab{
        right:12px;
        bottom:154px;
    }
}

@media (max-width: 480px){
    .footer{
        padding-bottom:96px;
    }

    .site-search-fab,
    .scroll-top,
    .site-help-fab{
        transform:scale(.94);
        transform-origin:bottom right;
    }
}

.newsletter-premium{
    position:relative;
    padding:42px 0 18px;
}

.newsletter-premium__shell{
    display:block;
}

.newsletter-premium__shell--compact{
    max-width:980px;
    margin:0 auto;
}

.newsletter-premium__form-card{
    position:relative;
    overflow:hidden;
    padding:28px;
    border-radius:34px;
    background:
        radial-gradient(circle at top right, rgba(20,184,166,.10), transparent 24%),
        radial-gradient(circle at bottom left, rgba(59,130,246,.08), transparent 24%),
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
    border:1px solid rgba(15,23,42,.08);
    box-shadow:0 26px 70px rgba(15,23,42,.10);
}

.newsletter-premium__form-card--single{
    max-width:100%;
}

.newsletter-premium__form-head{
    display:grid;
    gap:12px;
    margin-bottom:18px;
}

.newsletter-premium__badge{
    display:inline-flex;
    align-items:center;
    gap:8px;
    width:max-content;
    padding:10px 14px;
    border-radius:999px;
    background:rgba(15,118,110,.08);
    color:var(--clr-primary);
    font-size:.84rem;
    font-weight:800;
}

.newsletter-premium__form-head p{
    margin:0;
    color:var(--clr-text-soft);
    font-size:1rem;
    line-height:1.65;
}

.newsletter-form--premium{
    display:grid;
    gap:18px;
}

.newsletter-form__grid--premium{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:16px;
}

.newsletter-form--premium .newsletter-form__field label{
    display:block;
    margin-bottom:8px;
    color:var(--clr-dark);
    font-size:.95rem;
    font-weight:800;
}

.newsletter-form--premium .form-control{
    min-height:62px;
    border-radius:20px;
    border:1px solid rgba(148,163,184,.18);
    background:#fff;
    padding:0 18px;
    box-shadow:none;
    transition:border-color .25s ease, box-shadow .25s ease, transform .25s ease;
}

.newsletter-form--premium .form-control:focus{
    border-color:rgba(20,184,166,.52);
    box-shadow:0 0 0 4px rgba(20,184,166,.10);
    transform:translateY(-1px);
}

.newsletter-form__consent--premium{
    display:flex;
    align-items:flex-start;
    gap:14px;
    padding:18px 18px;
    border-radius:22px;
    background:linear-gradient(180deg, rgba(241,245,249,.84), rgba(248,250,252,.98));
    border:1px solid rgba(15,23,42,.08);
    color:var(--clr-text);
}

.newsletter-form__consent--premium input{
    width:19px;
    height:19px;
    margin-top:3px;
    flex-shrink:0;
}

.newsletter-form__consent--premium span{
    line-height:1.7;
    font-size:1rem;
}

.newsletter-form__actions--premium{
    display:grid;
    gap:14px;
    align-items:start;
}

.newsletter-form--premium .newsletter-form__submit{
    width:max-content;
    min-width:220px;
    box-shadow:0 18px 40px rgba(20,184,166,.20);
}

.newsletter-form--premium .newsletter-form__note{
    margin:0;
    color:var(--clr-text-soft);
    font-size:.98rem;
    line-height:1.65;
    max-width:52rem;
}

.newsletter-form--premium .newsletter-form__feedback{
    padding:14px 16px;
    border-radius:18px;
    font-weight:700;
}

.newsletter-form--premium .newsletter-form__feedback.is-success{
    background:rgba(34,197,94,.08);
    border:1px solid rgba(34,197,94,.18);
    color:#15803d;
}

.newsletter-form--premium .newsletter-form__feedback.is-error{
    background:rgba(239,68,68,.08);
    border:1px solid rgba(239,68,68,.18);
    color:#b91c1c;
}

@media (max-width: 767px){
    .newsletter-premium{
        padding:28px 0 14px;
    }

    .newsletter-premium__form-card{
        padding:18px;
        border-radius:26px;
    }

    .newsletter-form__grid--premium{
        grid-template-columns:1fr;
        gap:14px;
    }

    .newsletter-form__consent--premium{
        padding:16px;
        border-radius:20px;
    }

    .newsletter-form__consent--premium span{
        font-size:.98rem;
    }

    .newsletter-form--premium .newsletter-form__submit{
        width:100%;
        min-width:0;
    }

    .newsletter-form--premium .newsletter-form__note{
        font-size:.95rem;
    }
}

@media (max-width: 480px){
    .newsletter-premium__form-card{
        padding:16px;
        border-radius:22px;
    }

    .newsletter-premium__form-head p{
        font-size:.95rem;
    }

    .newsletter-form--premium .form-control{
        min-height:58px;
        border-radius:18px;
    }
}

.newsletter-premium__intro{
    margin-bottom: 1.25rem;
    text-align: center;
}

.newsletter-premium__eyebrow{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: .5rem;
    padding: .35rem .85rem;
    border-radius: 999px;
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    background: rgba(255,255,255,.08);
    color: var(--color-primary, #0f766e);
}

.newsletter-premium__title{
    margin: 0;
    font-size: clamp(1.5rem, 2vw, 2.3rem);
    font-weight: 800;
    line-height: 1.15;
}

.newsletter-premium__subtitle{
    margin: .75rem auto 0;
    max-width: 720px;
    font-size: 1rem;
    line-height: 1.7;
    opacity: .88;
}

.payment-page-hero .page-hero__eyebrow {
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.payment-choice-section-wrap {
    position: relative;
}

.payment-layout-enhanced {
    align-items: start;
    gap: 1.5rem;
}

.payment-summary-card,
.payment-methods-card,
.sidebar-card--premium {
    border-radius: 26px;
    border: 1px solid rgba(148, 163, 184, 0.16);
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.98));
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.07);
}

.payment-summary-card {
    padding: clamp(1.1rem, 2vw, 1.8rem);
    margin-bottom: 1.5rem;
}

.payment-summary-card__header {
    display: flex;
    justify-content: space-between;
    gap: 1.25rem;
    align-items: flex-start;
    margin-bottom: 1.25rem;
}

.payment-summary-card__eyebrow,
.payment-section-heading__eyebrow,
.sidebar-card__eyebrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .45rem .9rem;
    border-radius: 999px;
    background: rgba(16, 185, 129, 0.10);
    color: #059669;
    font-size: .84rem;
    font-weight: 800;
    letter-spacing: .02em;
    margin-bottom: .85rem;
}

.payment-summary-card__header h2,
.payment-section-heading h2 {
    margin: 0 0 .55rem;
    color: #0f172a;
    font-weight: 800;
    line-height: 1.15;
}

.payment-summary-card__header p,
.payment-section-heading p,
.sidebar-card--premium p {
    margin: 0;
    color: #475569;
    line-height: 1.75;
}

.payment-summary-card__amount {
    min-width: 220px;
    padding: 1rem 1.15rem;
    border-radius: 22px;
    background: linear-gradient(135deg, #0f172a, #1e293b);
    color: #fff;
    box-shadow: 0 18px 34px rgba(15, 23, 42, 0.20);
}

.payment-summary-card__amount span {
    display: block;
    font-size: .9rem;
    color: rgba(255,255,255,.76);
    margin-bottom: .35rem;
}

.payment-summary-card__amount strong {
    display: block;
    font-size: 1.35rem;
    font-weight: 800;
    line-height: 1.1;
}

.booking-summary-grid--premium {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.booking-summary-item {
    padding: 1rem 1rem;
    border-radius: 18px;
    background: #f8fafc;
    border: 1px solid rgba(148, 163, 184, 0.14);
}

.booking-summary-item span {
    display: block;
    color: #64748b;
    font-size: .92rem;
    margin-bottom: .4rem;
}

.booking-summary-item strong {
    display: block;
    color: #0f172a;
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.35;
}

.payment-methods-card {
    padding: clamp(1.1rem, 2vw, 1.8rem);
}

.payment-section-heading {
    text-align: center;
    max-width: 900px;
    margin: 0 auto 1.8rem;
}

.payment-choice-grid--premium {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem;
    align-items: stretch;
}

.payment-choice-card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    padding: 1.35rem;
    border-radius: 24px;
    border: 1px solid rgba(148, 163, 184, 0.18);
    background: rgba(255,255,255,0.96);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.06);
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    overflow: hidden;
}

.payment-choice-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 42px rgba(15, 23, 42, 0.10);
}

.payment-choice-card--paytech::before,
.payment-choice-card--paydunya::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 5px;
}

.payment-choice-card--paytech::before {
    background: linear-gradient(90deg, #10b981, #14b8a6);
}

.payment-choice-card--paydunya::before {
    background: linear-gradient(90deg, #2563eb, #7c3aed);
}

.payment-choice-card__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1rem;
}

.payment-choice-card__brand {
    display: flex;
    align-items: center;
    gap: .95rem;
}

.payment-choice-card__icon {
    width: 58px;
    height: 58px;
    display: grid;
    place-items: center;
    border-radius: 18px;
    font-size: 1.45rem;
    background: linear-gradient(135deg, rgba(16,185,129,.14), rgba(59,130,246,.10));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
}

.payment-choice-card__brand h3 {
    margin: 0;
    font-size: 1.4rem;
    font-weight: 800;
    line-height: 1.15;
    color: #0f172a;
}

.payment-choice-card__brand p {
    margin: .3rem 0 0;
    color: #64748b;
    font-size: .96rem;
}

.payment-choice-card__badge {
    flex-shrink: 0;
    padding: .5rem .8rem;
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 800;
    white-space: nowrap;
}

.payment-choice-card__badge--success {
    background: rgba(16, 185, 129, 0.12);
    color: #059669;
}

.payment-choice-card__badge--info {
    background: rgba(37, 99, 235, 0.12);
    color: #1d4ed8;
}

.payment-choice-card__description {
    color: #475569;
    line-height: 1.75;
    margin: 0 0 1.1rem;
}

.payment-feature-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: .85rem;
}

.payment-feature-list li {
    display: flex;
    align-items: center;
    gap: .8rem;
    padding: .95rem 1rem;
    border-radius: 16px;
    background: #f8fafc;
    border: 1px solid rgba(148, 163, 184, 0.14);
    color: #334155;
    font-weight: 600;
}

.payment-feature-list__icon {
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: rgba(34, 197, 94, 0.14);
    color: #16a34a;
    font-weight: 900;
    flex-shrink: 0;
}

.payment-choice-card__footer {
    margin-top: 1.2rem;
}

.payment-btn {
    width: 100%;
    border: none;
    border-radius: 18px;
    padding: 1rem 1.2rem;
    font-size: 1rem;
    font-weight: 800;
    cursor: pointer;
    transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease;
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.10);
}

.payment-btn:hover {
    transform: translateY(-2px);
}

.payment-btn--paytech {
    color: #fff;
    background: linear-gradient(135deg, #10b981, #14b8a6);
}

.payment-btn--paydunya {
    color: #fff;
    background: linear-gradient(135deg, #2563eb, #7c3aed);
}

.payment-inline-alert {
    padding: 1rem 1rem;
    border-radius: 16px;
    background: rgba(245, 158, 11, 0.12);
    border: 1px solid rgba(245, 158, 11, 0.22);
    color: #92400e;
    font-weight: 600;
    line-height: 1.6;
}

.sidebar-card--premium {
    padding: 1.2rem;
}

.sidebar-card--premium h3 {
    margin: 0 0 .7rem;
    color: #0f172a;
    font-size: 1.15rem;
    font-weight: 800;
}

.payment-help-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin-top: 1rem;
    text-align: center;
    text-decoration: none;
    border-radius: 16px;
    padding: .95rem 1rem;
    font-weight: 800;
    color: #0f172a;
    background: linear-gradient(135deg, rgba(255,255,255,.95), rgba(241,245,249,.95));
    border: 1px solid rgba(148, 163, 184, 0.18);
    transition: transform .2s ease, box-shadow .2s ease;
}

.payment-help-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
}

@media (max-width: 1199.98px) {
    .booking-summary-grid--premium {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .payment-choice-grid--premium {
        grid-template-columns: 1fr;
    }

    .payment-summary-card__header {
        flex-direction: column;
    }

    .payment-summary-card__amount {
        width: 100%;
        min-width: 0;
    }

    .payment-choice-card__top {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 575.98px) {
    .booking-summary-grid--premium {
        grid-template-columns: 1fr;
    }

    .payment-summary-card,
    .payment-methods-card,
    .sidebar-card--premium {
        border-radius: 20px;
    }

    .payment-choice-card {
        padding: 1rem;
        border-radius: 20px;
    }

    .payment-choice-card__icon {
        width: 52px;
        height: 52px;
        border-radius: 16px;
    }

    .payment-feature-list li {
        padding: .85rem .9rem;
        font-size: .95rem;
    }

    .payment-btn {
        border-radius: 16px;
    }
}

.payment-choice-card {
    gap: 0;
}

.payment-choice-card__description {
    margin-bottom: 1rem;
}

.payment-choice-card__cta {
    margin-bottom: 1rem;
}

.payment-choice-card__cta form {
    margin: 0;
}

.payment-feature-list--compact {
    gap: .7rem;
    margin-top: .2rem;
}

.payment-feature-list--compact li {
    padding: .82rem .95rem;
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(248,250,252,.96), rgba(255,255,255,.96));
}

.payment-btn {
    min-height: 56px;
}

.payment-btn--paytech,
.payment-btn--paydunya {
    position: relative;
    overflow: hidden;
}

.payment-btn--paytech::after,
.payment-btn--paydunya::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(255,255,255,.00), rgba(255,255,255,.18), rgba(255,255,255,.00));
    transform: translateX(-100%);
    transition: transform .55s ease;
}

.payment-btn--paytech:hover::after,
.payment-btn--paydunya:hover::after {
    transform: translateX(100%);
}

@media (max-width: 575.98px) {
    .payment-choice-card__cta {
        margin-bottom: .9rem;
    }

    .payment-feature-list--compact li {
        padding: .8rem .85rem;
    }
}
/* =========================
   PAYMENT CHECKOUT UPGRADE
   ========================= */

.payment-page-hero--premium{
    padding-top:56px;
    padding-bottom:24px;
}

.payment-page-hero__inner{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:24px;
}

.payment-page-hero__content{
    max-width:920px;
}

.payment-page-hero--premium h1{
    max-width:12ch;
}

.payment-trust-strip{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:22px;
}

.payment-trust-pill{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:12px 16px;
    border-radius:999px;
    background:rgba(255,255,255,.86);
    border:1px solid rgba(148,163,184,.16);
    box-shadow:0 12px 28px rgba(15,23,42,.05);
    color:#0f172a;
    font-weight:700;
}

.payment-choice-section-wrap--premium{
    padding-bottom:72px;
}

.payment-checkout-layout{
    display:grid;
    grid-template-columns:minmax(0,1fr) 360px;
    gap:24px;
    align-items:start;
}

.payment-checkout-main{
    min-width:0;
}

.payment-checkout-sidebar{
    position:sticky;
    top:110px;
    display:grid;
    gap:18px;
}

.payment-summary-card--premium,
.payment-methods-card--premium,
.sidebar-card--checkout-highlight{
    overflow:hidden;
}

.payment-summary-card__header--premium{
    align-items:stretch;
}

.payment-summary-card__amount--premium{
    display:flex;
    flex-direction:column;
    justify-content:center;
    min-width:250px;
}

.payment-summary-card__amount--premium small{
    display:block;
    margin-top:.45rem;
    color:rgba(255,255,255,.72);
    font-size:.86rem;
}

.booking-summary-grid--checkout{
    margin-top:4px;
}

.payment-section-heading--left{
    text-align:left;
    margin:0 0 1.5rem;
    max-width:none;
}

.payment-choice-grid--checkout{
    margin-top:0;
}

.payment-choice-card--featured{
    border-color:rgba(16,185,129,.28);
    box-shadow:
        0 22px 46px rgba(15,23,42,.10),
        0 0 0 1px rgba(16,185,129,.08);
}

.payment-choice-card--featured::after{
    content:"";
    position:absolute;
    top:16px;
    right:-44px;
    width:140px;
    height:34px;
    display:block;
    background:linear-gradient(135deg,#10b981,#14b8a6);
    transform:rotate(35deg);
    opacity:.08;
    pointer-events:none;
}

.payment-choice-card__highlights{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin:0 0 1rem;
}

.payment-choice-card__highlights span{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:.5rem .8rem;
    border-radius:999px;
    background:rgba(15,118,110,.08);
    color:#0f766e;
    font-size:.8rem;
    font-weight:800;
}

.payment-reassurance-bar{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:14px;
    margin-top:1.6rem;
    padding-top:1.4rem;
    border-top:1px solid rgba(148,163,184,.16);
}

.payment-reassurance-bar__item{
    padding:1rem;
    border-radius:18px;
    background:linear-gradient(180deg,rgba(248,250,252,.96),rgba(255,255,255,.98));
    border:1px solid rgba(148,163,184,.14);
}

.payment-reassurance-bar__item strong{
    display:block;
    margin-bottom:.35rem;
    color:#0f172a;
    font-size:.98rem;
}

.payment-reassurance-bar__item span{
    display:block;
    color:#64748b;
    line-height:1.65;
    font-size:.92rem;
}

.sidebar-card--checkout-highlight{
    background:linear-gradient(135deg,#0f172a,#1e293b);
    color:#fff;
    box-shadow:0 22px 54px rgba(15,23,42,.20);
}

.sidebar-card--checkout-highlight h3{
    color:#fff;
    font-size:1.7rem;
    line-height:1.05;
}

.sidebar-card--checkout-highlight p{
    color:rgba(255,255,255,.82);
}

.sidebar-card--checkout-highlight .sidebar-card__eyebrow{
    background:rgba(255,255,255,.10);
    color:#fff;
}

.sidebar-card--mini-guarantees{
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,252,.98));
}

.payment-mini-guarantees{
    list-style:none;
    padding:0;
    margin:0;
    display:grid;
    gap:12px;
}

.payment-mini-guarantees li{
    position:relative;
    padding-left:28px;
    color:#334155;
    line-height:1.65;
    font-weight:600;
}

.payment-mini-guarantees li::before{
    content:"✓";
    position:absolute;
    left:0;
    top:0;
    width:20px;
    height:20px;
    display:grid;
    place-items:center;
    border-radius:999px;
    background:rgba(34,197,94,.14);
    color:#16a34a;
    font-size:.78rem;
    font-weight:900;
}

@media (max-width: 1199px){
    .payment-checkout-layout{
        grid-template-columns:1fr;
    }

    .payment-checkout-sidebar{
        position:static;
        grid-template-columns:repeat(2,minmax(0,1fr));
    }

    .payment-reassurance-bar{
        grid-template-columns:1fr;
    }
}

@media (max-width: 991px){
    .payment-checkout-sidebar{
        grid-template-columns:1fr;
    }

    .payment-page-hero--premium h1{
        max-width:none;
    }
}

@media (max-width: 575px){
    .payment-trust-strip{
        display:grid;
        grid-template-columns:1fr;
    }

    .payment-trust-pill{
        width:100%;
        justify-content:flex-start;
    }

    .payment-summary-card__amount--premium{
        min-width:0;
    }

    .payment-choice-card__brand h3{
        font-size:1.22rem;
    }
}

/* =========================
   ULTRA PREMIUM PAYMENT PAGE
   ========================= */

.payment-page-hero--ultra{
    padding-top:60px;
    padding-bottom:26px;
}

.payment-page-hero__inner--ultra{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:24px;
}

.payment-page-hero__eyebrow--premium{
    box-shadow:0 14px 30px rgba(15,23,42,.08);
}

.payment-page-hero--ultra h1{
    max-width:12ch;
}

.payment-trust-strip--hero{
    margin-top:22px;
}

.payment-choice-section-wrap--ultra{
    padding-bottom:78px;
}

.payment-checkout-layout--ultra{
    display:grid;
    grid-template-columns:minmax(0,1fr) 360px;
    gap:24px;
    align-items:start;
}

.payment-progress-card{
    margin-bottom:1.5rem;
    border-radius:28px;
    border:1px solid rgba(148,163,184,.16);
    background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
    box-shadow:0 18px 40px rgba(15,23,42,.07);
}

.payment-progress-card__header{
    margin-bottom:1rem;
}

.payment-progress-card__header h2{
    margin:0;
    color:#0f172a;
    font-size:1.35rem;
    font-weight:800;
    letter-spacing:-.03em;
}

.payment-progress-steps{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:14px;
}

.payment-progress-step{
    position:relative;
    display:flex;
    align-items:flex-start;
    gap:12px;
    padding:1rem;
    border-radius:20px;
    background:#f8fafc;
    border:1px solid rgba(148,163,184,.14);
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.payment-progress-step:hover{
    transform:translateY(-2px);
    box-shadow:0 16px 30px rgba(15,23,42,.06);
}

.payment-progress-step__icon{
    width:42px;
    height:42px;
    flex:0 0 42px;
    display:grid;
    place-items:center;
    border-radius:14px;
    background:rgba(15,118,110,.10);
    color:#0f766e;
    font-size:1rem;
    font-weight:800;
}

.payment-progress-step strong{
    display:block;
    color:#0f172a;
    font-size:.98rem;
    margin-bottom:.2rem;
}

.payment-progress-step small{
    display:block;
    color:#64748b;
    line-height:1.5;
}

.payment-progress-step.is-complete{
    border-color:rgba(16,185,129,.22);
    background:linear-gradient(180deg, rgba(236,253,245,.92), rgba(255,255,255,.98));
}

.payment-progress-step.is-complete .payment-progress-step__icon{
    background:rgba(16,185,129,.14);
    color:#059669;
}

.payment-progress-step.is-current{
    border-color:rgba(37,99,235,.22);
    background:linear-gradient(180deg, rgba(239,246,255,.92), rgba(255,255,255,.98));
    box-shadow:0 18px 34px rgba(37,99,235,.08);
}

.payment-progress-step.is-current .payment-progress-step__icon{
    background:rgba(37,99,235,.12);
    color:#2563eb;
}

.payment-summary-card--ultra,
.payment-methods-card--ultra{
    border-radius:28px;
}

.payment-summary-card__header--ultra{
    align-items:stretch;
}

.payment-summary-card__amount--ultra{
    min-width:260px;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

.payment-choice-card{
    position:relative;
}

.payment-card-animated{
    will-change:transform;
}

.payment-choice-card__glow{
    position:absolute;
    inset:auto auto -55px -30px;
    width:160px;
    height:160px;
    border-radius:50%;
    filter:blur(28px);
    opacity:.18;
    pointer-events:none;
    transition:opacity .28s ease, transform .28s ease;
}

.payment-choice-card--paytech .payment-choice-card__glow{
    background:rgba(16,185,129,.55);
}

.payment-choice-card--paydunya .payment-choice-card__glow{
    background:rgba(59,130,246,.45);
}

.payment-choice-card:hover .payment-choice-card__glow{
    opacity:.28;
    transform:scale(1.06);
}

.payment-choice-card__icon--paytech{
    background:linear-gradient(135deg, rgba(16,185,129,.16), rgba(20,184,166,.12));
    color:#059669;
}

.payment-choice-card__icon--paydunya{
    background:linear-gradient(135deg, rgba(37,99,235,.14), rgba(124,58,237,.12));
    color:#2563eb;
}

.payment-choice-card__logos{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin:0 0 1rem;
}

.payment-logo-chip{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:.55rem .8rem;
    border-radius:999px;
    background:rgba(255,255,255,.92);
    border:1px solid rgba(148,163,184,.16);
    color:#0f172a;
    font-size:.8rem;
    font-weight:800;
    box-shadow:0 8px 18px rgba(15,23,42,.04);
}

.payment-logo-chip--card i{
    font-size:1rem;
}

.payment-choice-card__highlights span{
    gap:8px;
}

.payment-choice-card__highlights span i{
    color:inherit;
}

.payment-btn--ultra{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-height:58px;
    font-size:1rem;
    letter-spacing:-.01em;
}

.payment-btn--ultra i{
    font-size:1rem;
}

.payment-inline-alert{
    display:flex;
    align-items:flex-start;
    gap:10px;
}

.payment-reassurance-bar--ultra .payment-reassurance-bar__item strong i{
    margin-right:8px;
    color:#0f766e;
}

.payment-help-btn--ultra{
    gap:10px;
}

.payment-help-btn--ultra i{
    color:#16a34a;
    font-size:1rem;
}

.sidebar-card--checkout-highlight h3{
    font-size:1.8rem;
    line-height:1.04;
    letter-spacing:-.04em;
}

.payment-mini-guarantees li{
    font-size:.96rem;
}

@media (max-width: 1199px){
    .payment-checkout-layout--ultra{
        grid-template-columns:1fr;
    }

    .payment-progress-steps{
        grid-template-columns:1fr;
    }

    .payment-checkout-sidebar{
        position:static;
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
}

@media (max-width: 991px){
    .payment-page-hero--ultra h1{
        max-width:none;
    }

    .payment-checkout-sidebar{
        grid-template-columns:1fr;
    }
}

@media (max-width: 575px){
    .payment-progress-card,
    .payment-summary-card--ultra,
    .payment-methods-card--ultra{
        border-radius:22px;
    }

    .payment-progress-step{
        border-radius:18px;
    }

    .payment-logo-chip{
        font-size:.76rem;
    }
}

/* micro-animations */
@media (prefers-reduced-motion: no-preference){
    .payment-card-animated{
        transition:transform .26s ease, box-shadow .26s ease, border-color .26s ease;
    }

    .payment-card-animated:hover{
        transform:translateY(-6px);
    }

    .payment-btn--ultra{
        position:relative;
        overflow:hidden;
    }

    .payment-btn--ultra::after{
        content:"";
        position:absolute;
        inset:0;
        background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.18), rgba(255,255,255,0));
        transform:translateX(-100%);
        transition:transform .65s ease;
    }

    .payment-btn--ultra:hover::after{
        transform:translateX(100%);
    }
}

/* =========================
   SIMPLE PRO PAYMENT PAGE
   ========================= */

.payment-simple-page{
    padding-top:48px;
    padding-bottom:72px;
}

.payment-simple-shell{
    max-width:1240px;
}

.payment-simple-main{
    padding:34px;
    border-radius:26px;
    background:#fff;
    border:1px solid rgba(15,23,42,.08);
    box-shadow:0 18px 46px rgba(15,23,42,.06);
}

.payment-simple-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:24px;
    margin-bottom:26px;
}

.payment-simple-head h1{
    margin:0 0 10px;
    color:#0f172a;
    font-size:clamp(2rem, 4vw, 3rem);
    line-height:1.08;
    letter-spacing:-.04em;
}

.payment-simple-head p{
    margin:0;
    max-width:720px;
    color:#64748b;
    font-size:1rem;
    line-height:1.7;
}

.payment-simple-ref{
    min-width:180px;
    text-align:right;
}

.payment-simple-ref span{
    display:block;
    color:#64748b;
    font-size:.92rem;
    margin-bottom:4px;
}

.payment-simple-ref strong{
    display:block;
    color:#0f172a;
    font-size:1.2rem;
    font-weight:800;
}

.payment-simple-options{
    display:grid;
    gap:18px;
}

.payment-simple-option{
    display:grid;
    gap:16px;
    padding:22px 24px;
    border-radius:20px;
    border:1px solid rgba(148,163,184,.22);
    background:#fff;
    transition:border-color .22s ease, box-shadow .22s ease, transform .22s ease;
}

.payment-simple-option:hover{
    border-color:rgba(59,130,246,.30);
    box-shadow:0 16px 34px rgba(15,23,42,.06);
    transform:translateY(-2px);
}

.payment-simple-option--recommended{
    border:2px solid #4f86f7;
    box-shadow:0 12px 32px rgba(79,134,247,.10);
}

.payment-simple-option__left{
    display:flex;
    align-items:center;
    gap:14px;
}

.payment-simple-option__radio{
    width:26px;
    height:26px;
    border-radius:999px;
    border:2px solid #94a3b8;
    display:inline-block;
    position:relative;
    flex:0 0 26px;
}

.payment-simple-option__radio.is-active{
    border-color:#4f86f7;
}

.payment-simple-option__radio.is-active::after{
    content:"";
    position:absolute;
    inset:4px;
    border-radius:999px;
    background:#4f86f7;
}

.payment-simple-option__copy strong{
    display:block;
    color:#0f172a;
    font-size:1.5rem;
    font-weight:800;
    line-height:1.15;
}

.payment-simple-option__copy small{
    display:block;
    margin-top:4px;
    color:#64748b;
    font-size:.96rem;
}

.payment-simple-option__right{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    flex-wrap:wrap;
}

.payment-simple-option__logos{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}

.payment-chip{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:34px;
    padding:0 12px;
    border-radius:999px;
    background:#f8fafc;
    border:1px solid rgba(148,163,184,.18);
    color:#0f172a;
    font-size:.82rem;
    font-weight:800;
}

.payment-simple-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:34px;
    padding:0 12px;
    border-radius:999px;
    background:rgba(16,185,129,.12);
    color:#059669;
    font-size:.82rem;
    font-weight:800;
}

.payment-simple-option__footer{
    display:grid;
    gap:14px;
}

.payment-simple-option__footer p{
    margin:0;
    color:#475569;
    line-height:1.7;
}

.payment-simple-option__footer form{
    margin:0;
}

.payment-simple-submit{
    min-height:58px;
    padding:0 22px;
    border:none;
    border-radius:14px;
    font-size:1rem;
    font-weight:800;
    color:#fff;
    cursor:pointer;
    transition:transform .2s ease, box-shadow .2s ease, opacity .2s ease;
    box-shadow:0 14px 26px rgba(15,23,42,.10);
}

.payment-simple-submit:hover{
    transform:translateY(-2px);
}

.payment-simple-submit--paytech{
    background:linear-gradient(135deg,#10b981,#14b8a6);
}

.payment-simple-submit--paydunya{
    background:linear-gradient(135deg,#2563eb,#7c3aed);
}

.payment-simple-alert{
    padding:14px 16px;
    border-radius:14px;
    background:rgba(245,158,11,.10);
    border:1px solid rgba(245,158,11,.18);
    color:#92400e;
    font-weight:600;
}

.payment-bottom-grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:20px;
    margin-top:22px;
}

.payment-bottom-card{
    border-radius:22px;
    background:#fff;
    border:1px solid rgba(15,23,42,.08);
    box-shadow:0 14px 36px rgba(15,23,42,.05);
    overflow:hidden;
}

.payment-bottom-card__head{
    padding:18px 22px;
    background:#1d4fa8;
}

.payment-bottom-card__head h2{
    margin:0;
    color:#fff;
    font-size:1.3rem;
    font-weight:800;
    letter-spacing:-.02em;
}

.payment-recap-list{
    padding:22px;
    display:grid;
    gap:16px;
}

.payment-recap-row{
    display:flex;
    justify-content:space-between;
    gap:16px;
    padding-bottom:12px;
    border-bottom:1px solid rgba(148,163,184,.16);
}

.payment-recap-row:last-child{
    border-bottom:none;
    padding-bottom:0;
}

.payment-recap-row span{
    color:#64748b;
}

.payment-recap-row strong{
    color:#0f172a;
    text-align:right;
}

.payment-recap-row--total span,
.payment-recap-row--total strong{
    color:#059669;
    font-size:1.08rem;
    font-weight:800;
}

.payment-trust-card{
    padding-bottom:22px;
}

.payment-trust-list{
    list-style:none;
    margin:0;
    padding:22px 22px 16px;
    display:grid;
    gap:12px;
}

.payment-trust-list li{
    position:relative;
    padding-left:28px;
    color:#334155;
    font-weight:600;
}

.payment-trust-list li::before{
    content:"✓";
    position:absolute;
    left:0;
    top:0;
    width:20px;
    height:20px;
    border-radius:999px;
    display:grid;
    place-items:center;
    background:rgba(34,197,94,.14);
    color:#16a34a;
    font-size:.78rem;
    font-weight:900;
}

.payment-support-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin:0 22px;
    min-height:52px;
    padding:0 18px;
    border-radius:14px;
    background:#f8fafc;
    border:1px solid rgba(148,163,184,.18);
    color:#0f172a;
    font-weight:800;
    text-decoration:none;
    transition:transform .2s ease, box-shadow .2s ease;
}

.payment-support-link:hover{
    transform:translateY(-2px);
    box-shadow:0 12px 24px rgba(15,23,42,.06);
}

@media (max-width: 991px){
    .payment-simple-head{
        flex-direction:column;
    }

    .payment-simple-ref{
        text-align:left;
        min-width:0;
    }

    .payment-bottom-grid{
        grid-template-columns:1fr;
    }
}

@media (max-width: 640px){
    .payment-simple-main{
        padding:20px;
        border-radius:20px;
    }

    .payment-simple-option{
        padding:18px;
        border-radius:18px;
    }

    .payment-simple-option__copy strong{
        font-size:1.2rem;
    }

    .payment-bottom-card{
        border-radius:18px;
    }

    .payment-bottom-card__head{
        padding:16px 18px;
    }

    .payment-recap-list,
    .payment-trust-list{
        padding-left:18px;
        padding-right:18px;
    }

    .payment-support-link{
        margin:0 18px;
        width:calc(100% - 36px);
    }
}

/* =========================
   PAYMENT PAGE EXACT SIMPLE
   ========================= */

.payment-clean-page{
    padding:38px 0 72px;
    background:#f3f4f6;
}

.payment-clean-layout{
    display:grid;
    grid-template-columns:minmax(0, 1fr) 420px;
    gap:36px;
    align-items:start;
    max-width:1440px;
}

.payment-clean-main,
.payment-clean-side{
    min-width:0;
}

.payment-clean-box{
    background:#fff;
    border:1px solid #e5e7eb;
    border-radius:18px;
    padding:30px 38px 38px;
    box-shadow:none;
}

.payment-clean-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:24px;
    margin-bottom:28px;
}

.payment-clean-head h1{
    margin:0;
    color:#1f2937;
    font-size:clamp(2rem, 3vw, 3rem);
    line-height:1.08;
    font-weight:800;
    letter-spacing:-.03em;
}

.payment-clean-ref{
    text-align:right;
    white-space:nowrap;
    padding-top:6px;
}

.payment-clean-ref span{
    color:#374151;
    font-size:1rem;
    margin-right:6px;
}

.payment-clean-ref strong{
    color:#1f2937;
    font-size:1.05rem;
    font-weight:800;
}

.payment-clean-list{
    display:grid;
    gap:18px;
}

.payment-clean-item{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    min-height:96px;
    padding:20px 24px;
    border:1px solid #cfd6e0;
    border-radius:8px;
    background:#fff;
}

.payment-clean-item--active{
    border:2px solid #4f86f7;
}

.payment-clean-item__left{
    display:flex;
    align-items:center;
    gap:18px;
    min-width:0;
}

.payment-clean-radio{
    width:28px;
    height:28px;
    border-radius:999px;
    border:1.8px solid #374151;
    position:relative;
    flex:0 0 28px;
}

.payment-clean-radio--active{
    border-color:#4f86f7;
}

.payment-clean-radio--active::before{
    content:"";
    position:absolute;
    inset:4px;
    border-radius:999px;
    border:2px solid #4f86f7;
}

.payment-clean-radio--active::after{
    content:"";
    position:absolute;
    inset:8px;
    border-radius:999px;
    background:#4f86f7;
}

.payment-clean-item__content strong{
    display:block;
    color:#1f2937;
    font-size:1.2rem;
    font-weight:800;
    line-height:1.2;
}

.payment-clean-item__content small{
    display:block;
    margin-top:4px;
    color:#6b7280;
    font-size:.95rem;
}

.payment-clean-item__logos{
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
    justify-content:flex-end;
}

.payment-clean-logo{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:58px;
    min-height:34px;
    padding:0 12px;
    border:1px solid #e5e7eb;
    border-radius:6px;
    background:#fff;
    color:#1f2937;
    font-size:.84rem;
    font-weight:800;
}

.payment-clean-action{
    display:flex;
    justify-content:center;
    margin-top:22px;
    margin-bottom:8px;
}

.payment-clean-submit{
    min-width:278px;
    min-height:62px;
    padding:0 28px;
    border:none;
    border-radius:6px;
    background:#07b34b;
    color:#fff;
    font-size:1.1rem;
    font-weight:800;
    cursor:pointer;
    transition:background .2s ease, transform .2s ease;
}

.payment-clean-submit:hover{
    background:#069a40;
    transform:translateY(-1px);
}

.payment-clean-secondary-action{
    margin-top:6px;
}

.payment-clean-secondary-btn{
    width:100%;
    min-height:54px;
    border:none;
    border-radius:6px;
    background:#2346a0;
    color:#fff;
    font-weight:800;
    cursor:pointer;
}

.payment-clean-alert{
    padding:14px 16px;
    border-radius:8px;
    background:#fff7ed;
    border:1px solid #fdba74;
    color:#9a3412;
    font-weight:600;
}

.payment-clean-side{
    display:grid;
    gap:24px;
}

.payment-clean-card{
    background:#fff;
    border:1px solid #e5e7eb;
    border-radius:16px;
    overflow:hidden;
}

.payment-clean-card__head{
    padding:18px 24px;
    background:#244ea5;
}

.payment-clean-card__head h2{
    margin:0;
    color:#fff;
    font-size:1.2rem;
    font-weight:800;
}

.payment-clean-summary{
    padding:22px 24px 24px;
}

.payment-clean-summary__section{
    padding-bottom:18px;
    border-bottom:1px solid #e5e7eb;
    margin-bottom:18px;
}

.payment-clean-summary__section h3{
    margin:0 0 16px;
    color:#1f2937;
    font-size:1rem;
    font-weight:800;
}

.payment-clean-summary__row{
    display:flex;
    justify-content:space-between;
    gap:16px;
    margin-bottom:12px;
}

.payment-clean-summary__row:last-child{
    margin-bottom:0;
}

.payment-clean-summary__row span{
    color:#374151;
    line-height:1.5;
}

.payment-clean-summary__row strong{
    color:#111827;
    text-align:right;
    line-height:1.5;
    font-weight:800;
}

.payment-clean-summary__row--total span,
.payment-clean-summary__row--total strong{
    color:#00a63e;
    font-size:1.12rem;
    font-weight:900;
}

.payment-clean-trust{
    list-style:none;
    margin:0;
    padding:22px 24px 10px;
    display:grid;
    gap:12px;
}

.payment-clean-trust li{
    position:relative;
    padding-left:28px;
    color:#1f2937;
    font-size:1rem;
    font-weight:600;
}

.payment-clean-trust li::before{
    content:"✓";
    position:absolute;
    left:0;
    top:0;
    width:20px;
    height:20px;
    display:grid;
    place-items:center;
    border-radius:999px;
    background:#e8f8ee;
    color:#07b34b;
    font-size:.78rem;
    font-weight:900;
}

.payment-clean-help{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin:14px 24px 24px;
    min-height:50px;
    border-radius:8px;
    background:#f8fafc;
    border:1px solid #dbe3ed;
    color:#111827;
    text-decoration:none;
    font-weight:800;
}

@media (max-width: 1199px){
    .payment-clean-layout{
        grid-template-columns:1fr;
    }
}

@media (max-width: 767px){
    .payment-clean-box{
        padding:22px 18px 24px;
        border-radius:14px;
    }

    .payment-clean-head{
        flex-direction:column;
        gap:12px;
        margin-bottom:20px;
    }

    .payment-clean-ref{
        text-align:left;
        white-space:normal;
        padding-top:0;
    }

    .payment-clean-item{
        flex-direction:column;
        align-items:flex-start;
        padding:18px 16px;
        min-height:auto;
    }

    .payment-clean-item__logos{
        justify-content:flex-start;
    }

    .payment-clean-submit{
        width:100%;
        min-width:0;
    }

    .payment-clean-card__head{
        padding:16px 18px;
    }

    .payment-clean-summary,
    .payment-clean-trust{
        padding-left:18px;
        padding-right:18px;
    }

    .payment-clean-help{
        margin-left:18px;
        margin-right:18px;
        width:calc(100% - 36px);
    }
}

/* === Payment selection radio behavior === */

.payment-clean-form {
    margin: 0;
}

.payment-clean-item--selectable {
    cursor: pointer;
    user-select: none;
}

.payment-clean-native-radio {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.payment-clean-item--selectable.is-selected {
    border: 2px solid #4f86f7;
    box-shadow: 0 12px 32px rgba(79, 134, 247, 0.10);
}

.payment-clean-item--selectable.is-selected .payment-clean-radio {
    border-color: #4f86f7;
}

.payment-clean-item--selectable.is-selected .payment-clean-radio::before {
    content: "";
    position: absolute;
    inset: 4px;
    border-radius: 999px;
    border: 2px solid #4f86f7;
}

.payment-clean-item--selectable.is-selected .payment-clean-radio::after {
    content: "";
    position: absolute;
    inset: 8px;
    border-radius: 999px;
    background: #4f86f7;
}

.payment-clean-item--selectable input[disabled] ~ .payment-clean-radio,
.payment-clean-item--selectable input[disabled] ~ .payment-clean-item__content {
    opacity: .55;
}

.payment-clean-item--selectable:has(input[disabled]) {
    opacity: .7;
    cursor: not-allowed;
}

/* =========================
   REQUIRED FIELDS - BOOKING FORM
   ========================= */

.booking-required-note{
    display:flex;
    align-items:center;
    gap:8px;
    margin:10px 0 0;
    color:var(--clr-text-soft);
    font-size:.92rem;
    line-height:1.6;
}

.booking-label{
    display:flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
    font-weight:800;
    color:var(--clr-dark);
    margin-bottom:8px;
}

.booking-label.is-required{
    color:var(--clr-dark);
}

.booking-required-star{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    color:#dc2626;
    font-weight:900;
    font-size:1rem;
    line-height:1;
}

.booking-optional-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:24px;
    padding:0 10px;
    border-radius:999px;
    background:rgba(148,163,184,.12);
    color:var(--clr-text-soft);
    font-size:.75rem;
    font-weight:800;
    letter-spacing:.01em;
}

.booking-field .form-control:required,
.booking-field .form-select:required,
.booking-field input:required,
.booking-field select:required,
.booking-field textarea:required{
    border-color:rgba(15,23,42,.12);
}

.booking-field .form-control:required:focus,
.booking-field .form-select:required:focus,
.booking-field input:required:focus,
.booking-field select:required:focus,
.booking-field textarea:required:focus{
    box-shadow:0 0 0 4px rgba(220,38,38,.08);
}

.booking-field .field-help{
    margin-top:2px;
}

@media (max-width: 640px){
    .booking-label{
        align-items:flex-start;
    }

    .booking-optional-badge{
        min-height:22px;
        padding:0 9px;
    }
}

/* =========================
   HERO TYPEWRITER + SHOWCASE ANIMATION
   ========================= */

.hero__title--typed{
    display:grid;
    gap:.08em;
    min-height:2.15em;
}

.hero__title-line{
    display:block;
    width:100%;
}

.hero__title-line--dynamic{
    min-height:1.08em;
    display:flex;
    align-items:flex-end;
    flex-wrap:nowrap;
    min-width:0;
}

.hero__typed-text{
    display:inline-block;
    min-width:0;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:clip;
    max-width:100%;
}

.hero__typed-cursor{
    display:inline-block;
    width:.08em;
    height:.9em;
    margin-left:.08em;
    border-radius:999px;
    background:var(--clr-dark);
    flex:0 0 auto;
    animation:heroCaretBlink .95s steps(1) infinite;
    transform:translateY(-.02em);
}

.hero__title-line--static{
    display:block;
}

@keyframes heroCaretBlink{
    0%, 48%{opacity:1}
    49%, 100%{opacity:0}
}

/* Empêche le débordement sur mobile tout en gardant le rendu propre */
@media (max-width: 767px){
    .hero__title--typed{
        min-height:2.45em;
    }

    .hero__typed-text{
        white-space:normal;
        display:-webkit-box;
        -webkit-line-clamp:2;
        line-clamp:2;
        -webkit-box-orient:vertical;
    }

    .hero__typed-cursor{
        align-self:flex-end;
    }
}

/* Showcase image animation */
.hero-showcase{
    position:relative;
    isolation:isolate;
    overflow:visible;
}

.hero-showcase__image{
    position:absolute;
    inset:0;
    border-radius:34px;
    overflow:hidden;
    box-shadow:var(--shadow-lg);
    background:
      linear-gradient(180deg, rgba(15,23,42,.08), rgba(15,23,42,.56)),
      url("../img/lac-rose-aventure.112258017dce.png") center/cover no-repeat;
    transform-origin:center center;
    animation:heroKenBurns 14s ease-in-out infinite alternate;
    will-change:transform, filter;
}

.hero-showcase__image::after{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 18% 24%, rgba(255,255,255,.18), transparent 22%),
        radial-gradient(circle at 78% 18%, rgba(255,255,255,.10), transparent 18%),
        linear-gradient(135deg, rgba(20,184,166,.10), transparent 36%, rgba(245,158,11,.08) 78%, transparent 100%);
    mix-blend-mode:screen;
    pointer-events:none;
    animation:heroOverlayPulse 7s ease-in-out infinite;
}

.hero-showcase__shine{
    position:absolute;
    inset:18px;
    border-radius:30px;
    pointer-events:none;
    z-index:1;
    background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.08) 24%, transparent 46%);
    transform:translateX(-120%) skewX(-16deg);
    animation:heroShineSweep 8s ease-in-out infinite;
}

.hero-card--main,
.hero-card--floating{
    z-index:2;
}

@keyframes heroKenBurns{
    0%{
        transform:scale(1) translate3d(0,0,0);
        filter:saturate(1) contrast(1);
    }
    50%{
        transform:scale(1.045) translate3d(-0.6%, -0.8%, 0);
        filter:saturate(1.06) contrast(1.02);
    }
    100%{
        transform:scale(1.08) translate3d(0.8%, 0.6%, 0);
        filter:saturate(1.1) contrast(1.04);
    }
}

@keyframes heroOverlayPulse{
    0%,100%{opacity:.72}
    50%{opacity:1}
}

@keyframes heroShineSweep{
    0%, 20%{
        opacity:0;
        transform:translateX(-120%) skewX(-16deg);
    }
    28%{
        opacity:1;
    }
    46%{
        opacity:.75;
        transform:translateX(125%) skewX(-16deg);
    }
    100%{
        opacity:0;
        transform:translateX(125%) skewX(-16deg);
    }
}

@media (prefers-reduced-motion: reduce){
    .hero__typed-cursor,
    .hero-showcase__image,
    .hero-showcase__image::after,
    .hero-showcase__shine{
        animation:none !important;
    }
}

/* =========================
   HERO FULL CATEGORIES SHOWCASE
   ========================= */

.hero__visual{
    min-width:0;
}

.hero-categories-showcase{
    position:relative;
    min-height:580px;
    display:grid;
    grid-template-rows:1fr auto;
    gap:16px;
}

.hero-categories-showcase__viewport{
    position:relative;
    min-height:0;
    overflow:hidden;
    border-radius:34px;
    box-shadow:var(--shadow-lg);
}

.hero-categories-showcase__track{
    position:relative;
    width:100%;
    height:100%;
    min-height:580px;
}

.hero-category-slide{
    position:absolute;
    inset:0;
    display:block;
    color:#fff;
    overflow:hidden;
    text-decoration:none;
    opacity:0;
    visibility:hidden;
    transform:scale(1.02);
    transition:
        opacity .55s ease,
        transform .55s ease,
        visibility .55s ease;
    background:#0f172a;
}

.hero-category-slide.is-active{
    opacity:1;
    visibility:visible;
    transform:scale(1);
    z-index:1;
}

.hero-category-slide__media{
    position:absolute;
    inset:0;
    overflow:hidden;
}

.hero-category-slide__media img,
.hero-category-slide__placeholder{
    width:100%;
    height:100%;
    display:block;
}

.hero-category-slide__media img{
    object-fit:cover;
    transform:scale(1.01);
}

.hero-category-slide__placeholder{
    display:grid;
    place-items:center;
    background:linear-gradient(135deg,#0f766e,#14b8a6,#22c55e);
    font-size:3rem;
    color:rgba(255,255,255,.92);
}

.hero-category-slide__overlay{
    position:absolute;
    inset:0;
    background:
        linear-gradient(180deg, rgba(15,23,42,.12) 0%, rgba(15,23,42,.24) 34%, rgba(15,23,42,.84) 100%);
    z-index:1;
}

.hero-category-slide__content{
    position:absolute;
    inset:0;
    z-index:2;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    padding:26px;
}

.hero-category-slide__top{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    flex-wrap:wrap;
}

.hero-category-slide__badge,
.hero-category-slide__count{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:36px;
    padding:0 14px;
    border-radius:999px;
    font-size:.84rem;
    font-weight:800;
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
}

.hero-category-slide__badge{
    background:rgba(255,255,255,.16);
    border:1px solid rgba(255,255,255,.14);
    color:#fff;
}

.hero-category-slide__count{
    background:rgba(20,184,166,.18);
    border:1px solid rgba(255,255,255,.10);
    color:#ecfeff;
}

.hero-category-slide__bottom{
    display:grid;
    gap:12px;
    max-width:82%;
}

.hero-category-slide__bottom h3{
    margin:0;
    color:#fff;
    font-size:clamp(2rem, 3vw, 3rem);
    line-height:1.02;
    letter-spacing:-.05em;
}

.hero-category-slide__bottom p{
    margin:0;
    color:rgba(255,255,255,.84);
    font-size:1rem;
    line-height:1.7;
    max-width:56ch;
}

.hero-category-slide__cta{
    display:inline-flex;
    align-items:center;
    gap:10px;
    width:max-content;
    margin-top:4px;
    min-height:50px;
    padding:0 18px;
    border-radius:999px;
    background:rgba(255,255,255,.14);
    border:1px solid rgba(255,255,255,.14);
    color:#fff;
    font-weight:800;
    transition:transform .22s ease, background .22s ease;
}

.hero-category-slide:hover .hero-category-slide__cta{
    transform:translateY(-1px);
    background:rgba(255,255,255,.22);
}

.hero-categories-showcase__controls{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    flex-wrap:wrap;
}

.hero-categories-showcase__arrow{
    width:44px;
    height:44px;
    border:none;
    border-radius:14px;
    display:grid;
    place-items:center;
    background:rgba(255,255,255,.92);
    color:var(--clr-dark);
    box-shadow:0 12px 28px rgba(15,23,42,.08);
    transition:transform .22s ease, box-shadow .22s ease;
}

.hero-categories-showcase__arrow:hover{
    transform:translateY(-1px);
    box-shadow:0 18px 34px rgba(15,23,42,.12);
}

.hero-categories-showcase__dots{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    flex-wrap:wrap;
}

.hero-categories-showcase__dot{
    width:10px;
    height:10px;
    border:none;
    padding:0;
    border-radius:999px;
    background:rgba(15,23,42,.18);
    transition:width .22s ease, background .22s ease, transform .22s ease;
}

.hero-categories-showcase__dot.is-active{
    width:26px;
    background:var(--clr-primary);
}

@media (max-width: 1199px){
    .hero-categories-showcase,
    .hero-categories-showcase__track{
        min-height:520px;
    }

    .hero-category-slide__bottom{
        max-width:92%;
    }
}

@media (max-width: 991px){
    .hero-categories-showcase,
    .hero-categories-showcase__track{
        min-height:460px;
    }

    .hero-category-slide__content{
        padding:20px;
    }

    .hero-category-slide__bottom{
        max-width:100%;
    }

    .hero-category-slide__bottom h3{
        font-size:clamp(1.6rem, 5vw, 2.4rem);
    }
}

@media (max-width: 767px){
    .hero-categories-showcase,
    .hero-categories-showcase__track{
        min-height:400px;
    }

    .hero-categories-showcase__viewport{
        border-radius:24px;
    }

    .hero-category-slide__content{
        padding:16px;
    }

    .hero-category-slide__badge,
    .hero-category-slide__count{
        min-height:32px;
        padding:0 12px;
        font-size:.78rem;
    }

    .hero-category-slide__bottom{
        gap:10px;
    }

    .hero-category-slide__bottom h3{
        font-size:1.5rem;
        line-height:1.08;
    }

    .hero-category-slide__bottom p{
        font-size:.95rem;
        line-height:1.6;
    }

    .hero-category-slide__cta{
        min-height:46px;
        padding:0 16px;
        font-size:.95rem;
    }

    .hero-categories-showcase__arrow{
        width:40px;
        height:40px;
        border-radius:12px;
    }
}

/* =========================
   CATEGORIES SHOWCASE OVAL
   ========================= */

.categories-showcase-section{
    background:#f4f1db;
    padding-top:68px;
    padding-bottom:72px;
}

.categories-showcase-head{
    margin-bottom:34px;
}

.categories-showcase-head h2{
    margin:0;
    color:#111827;
    font-size:clamp(2rem, 4vw, 3.5rem);
    line-height:1.04;
    letter-spacing:-.04em;
    font-weight:500;
}

.categories-showcase-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:36px;
    align-items:start;
}

.categories-showcase-item{
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    color:#111827;
    text-decoration:none;
    transition:transform .22s ease, opacity .22s ease;
}

.categories-showcase-item:hover{
    transform:translateY(-4px);
}

.categories-showcase-item__media{
    width:100%;
    max-width:290px;
    aspect-ratio: 3 / 4;
    border-radius:999px;
    overflow:hidden;
    background:#e9e5cf;
    box-shadow:0 10px 24px rgba(15,23,42,.06);
}

.categories-showcase-item__media img,
.categories-showcase-item__placeholder{
    width:100%;
    height:100%;
    display:block;
}

.categories-showcase-item__media img{
    object-fit:cover;
}

.categories-showcase-item__placeholder{
    display:grid;
    place-items:center;
    background:linear-gradient(135deg,#d8d2b5,#ebe6d2);
    color:#6b7280;
    font-size:2.6rem;
}

.categories-showcase-item__content{
    margin-top:20px;
}

.categories-showcase-item__content h3{
    margin:0 0 8px;
    color:#111827;
    font-size:clamp(1.4rem, 2vw, 1.9rem);
    line-height:1.18;
    font-weight:500;
}

.categories-showcase-item__content p{
    margin:0;
    color:#57534e;
    font-size:1.05rem;
    line-height:1.5;
    font-weight:400;
}

@media (max-width: 1100px){
    .categories-showcase-grid{
        gap:28px;
    }

    .categories-showcase-item__media{
        max-width:250px;
    }
}

@media (max-width: 767px){
    .categories-showcase-section{
        padding-top:54px;
        padding-bottom:58px;
    }

    .categories-showcase-grid{
        grid-template-columns:1fr;
        gap:26px;
        justify-items:center;
    }

    .categories-showcase-head{
        margin-bottom:24px;
    }

    .categories-showcase-item__media{
        max-width:260px;
    }

    .categories-showcase-item__content{
        margin-top:16px;
    }
}

/* =========================
   CATEGORIES SLIDER CLASSIC
   ========================= */

.categories-slider-section{
    padding-top:88px;
    padding-bottom:88px;
}

.categories-slider-heading{
    max-width:820px;
}

.categories-slider-title{
    position:relative;
    margin:16px 0 12px;
    font-size:clamp(2rem,5vw,3.4rem);
    line-height:1.05;
    color:var(--clr-dark);
    letter-spacing:-.05em;
    min-height:2.25em;
}

.categories-slider-title__text{
    display:inline-block;
    max-width:100%;
    vertical-align:top;
}

.categories-slider-title__cursor{
    display:inline-block;
    width:.08em;
    height:.9em;
    margin-left:.08em;
    border-radius:999px;
    background:var(--clr-dark);
    vertical-align:baseline;
    animation:categoriesCaretBlink .95s steps(1) infinite;
}

@keyframes categoriesCaretBlink{
    0%,48%{opacity:1}
    49%,100%{opacity:0}
}

.categories-slider{
    display:grid;
    grid-template-columns:56px minmax(0,1fr) 56px;
    gap:18px;
    align-items:center;
}

.categories-slider__viewport{
    overflow:hidden;
    min-width:0;
}

.categories-slider__track{
    display:flex;
    gap:24px;
    transition:transform .55s ease;
    will-change:transform;
}

.categories-slider__item{
    flex:0 0 calc((100% - 48px) / 3);
    min-width:0;
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    text-decoration:none;
    color:inherit;
}

.categories-slider__item:hover .categories-slider__media{
    transform:translateY(-4px);
    box-shadow:0 20px 42px rgba(15,23,42,.10);
}

.categories-slider__media{
    width:100%;
    max-width:290px;
    aspect-ratio:3 / 4;
    border-radius:999px;
    overflow:hidden;
    background:rgba(255,255,255,.72);
    box-shadow:0 12px 30px rgba(15,23,42,.06);
    transition:transform .25s ease, box-shadow .25s ease;
}

.categories-slider__media img,
.categories-slider__placeholder{
    width:100%;
    height:100%;
    display:block;
}

.categories-slider__media img{
    object-fit:cover;
}

.categories-slider__placeholder{
    display:grid;
    place-items:center;
    background:linear-gradient(135deg, rgba(15,118,110,.10), rgba(245,158,11,.10));
    color:var(--clr-primary);
    font-size:2.2rem;
}

.categories-slider__content{
    margin-top:20px;
}

.categories-slider__content h3{
    margin:0 0 8px;
    color:var(--clr-dark);
    font-size:clamp(1.3rem, 2vw, 1.8rem);
    line-height:1.18;
    font-weight:500;
}

.categories-slider__content p{
    margin:0;
    color:var(--clr-text-soft);
    font-size:1rem;
    line-height:1.5;
}

.categories-slider__arrow{
    width:56px;
    height:56px;
    border:none;
    border-radius:999px;
    display:grid;
    place-items:center;
    background:rgba(15,23,42,.06);
    color:var(--clr-dark);
    transition:transform .22s ease, background .22s ease;
}

.categories-slider__arrow:hover{
    transform:translateY(-1px);
    background:rgba(15,23,42,.10);
}

.categories-slider__dots{
    display:flex;
    justify-content:center;
    gap:8px;
    flex-wrap:wrap;
    margin-top:26px;
}

.categories-slider__dot{
    width:10px;
    height:10px;
    border:none;
    border-radius:999px;
    padding:0;
    background:rgba(15,23,42,.16);
    transition:width .22s ease, background .22s ease;
}

.categories-slider__dot.is-active{
    width:26px;
    background:var(--clr-primary);
}

@media (max-width: 991px){
    .categories-slider{
        grid-template-columns:44px minmax(0,1fr) 44px;
        gap:12px;
    }

    .categories-slider__item{
        flex:0 0 calc((100% - 24px) / 2);
    }

    .categories-slider__media{
        max-width:240px;
    }

    .categories-slider__arrow{
        width:44px;
        height:44px;
    }
}

@media (max-width: 640px){
    .categories-slider-title{
        min-height:2.9em;
    }

    .categories-slider-title__text{
        display:-webkit-box;
        -webkit-line-clamp:2;
        line-clamp:2;
        -webkit-box-orient:vertical;
        overflow:hidden;
    }

    .categories-slider{
        grid-template-columns:1fr;
    }

    .categories-slider__arrow{
        display:none;
    }

    .categories-slider__item{
        flex:0 0 100%;
    }

    .categories-slider__media{
        max-width:260px;
    }
}

/* =========================
   CATEGORIES INFINITE SMOOTH
   ========================= */

.categories-slider__viewport{
    overflow:hidden;
    min-width:0;
    mask-image:linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%);
    -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%);
}

.categories-slider__track{
    display:flex;
    gap:24px;
    will-change:transform;
    transform:translate3d(0,0,0);
}

.categories-slider__item{
    backface-visibility:hidden;
    -webkit-backface-visibility:hidden;
}

@media (max-width: 640px){
    .categories-slider__viewport{
        mask-image:none;
        -webkit-mask-image:none;
    }
}

/* =========================
   FOOTER BRAND STACK
   Logo en haut, textes en dessous
   ========================= */

.footer__brandstack{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
    width:100%;
}

.footer__logo-wrap--brand{
    width:220px;
    max-width:100%;
    height:auto;
    min-width:0 !important;
    display:block;
}

.footer__logo-wrap--brand .site-brand__logo-img{
    width:100%;
    height:auto;
    object-fit:contain;
    object-position:left center;
    display:block;
}

.footer__brandcopy{
    display:grid;
    gap:8px;
    width:100%;
    max-width:420px;
}

.footer__brandcopy h3{
    margin:0;
    color:#fff;
    font-size:1.35rem;
    line-height:1.1;
    letter-spacing:-0.03em;
    font-weight:800;
}

.footer__brand-subtitle{
    margin:0;
    color:rgba(255,255,255,.78);
    font-size:1rem;
    line-height:1.6;
}

.footer__brand-text{
    margin:0;
    max-width:560px;
    color:rgba(255,255,255,.78);
    font-size:1rem;
    line-height:1.8;
}

/* tablette */
@media (max-width: 991px){
    .footer__logo-wrap--brand{
        width:200px;
    }

    .footer__brandcopy h3{
        font-size:1.22rem;
    }

    .footer__brand-subtitle,
    .footer__brand-text{
        font-size:.97rem;
    }
}

/* mobile */
@media (max-width: 767px){
    .footer__brandstack{
        gap:12px;
    }

    .footer__logo-wrap--brand{
        width:180px;
    }

    .footer__brandcopy{
        gap:6px;
    }

    .footer__brandcopy h3{
        font-size:1.08rem;
    }

    .footer__brand-subtitle{
        font-size:.94rem;
        line-height:1.55;
    }

    .footer__brand-text{
        font-size:.95rem;
        line-height:1.72;
    }
}

/* petits mobiles */
@media (max-width: 480px){
    .footer__logo-wrap--brand{
        width:160px;
    }

    .footer__brandcopy h3{
        font-size:1rem;
    }

    .footer__brand-subtitle,
    .footer__brand-text{
        font-size:.92rem;
    }
}

.footer__brandline{
    display:block;
}

.detail-meta-line {
    margin: 0.75rem 0 1rem;
}

.detail-meta-line .pill a {
    color: inherit;
    text-decoration: none;
    font-weight: 600;
}

.detail-meta-line .pill a:hover {
    text-decoration: underline;
}