/*
  Kwikly – Professional CSS (Refactor‑Safe Upgrade)
  Notes for Hicham:
  - Functional selectors preserved; no class/HTML changes required.
  - Introduces CSS variables and consistent palette (primary #000c7c, secondary #b6e7ff, neutral greys).
  - Accessibilty: improved contrast, focus states, and hover/active feedback.
  - Subtle radii, shadows, and transitions for a “big‑company” feel.
  - Legacy colors kept where they imply content (ratings, warnings), otherwise mapped to tokens.
  - You can override tokens per page if needed.
*/

/****************************
 * 0) Design Tokens
 ****************************/
:root{
  /* Brand */
  --kw-primary:#000c7c;              /* deep indigo */
  --kw-primary-600:#000a63;
  --kw-primary-700:#00084e;
  --kw-secondary:#b6e7ff;            /* sky */
  --kw-secondary-600:#9bdbff;

  /* Neutral scale */
  --kw-black:#000;
  --kw-white:#fff;
  --kw-gray-900:#0f1117;
  --kw-gray-800:#171923;
  --kw-gray-700:#1f2430;
  --kw-gray-600:#2a3040;
  --kw-gray-500:#3b4252;
  --kw-gray-400:#6b7280;
  --kw-gray-300:#9ca3af;
  --kw-gray-200:#e5e7eb;
  --kw-gray-100:#f3f4f6;

  /* Utility */
  --kw-radius-xs:4px;
  --kw-radius-sm:6px;
  --kw-radius-md:10px;
  --kw-radius-lg:14px;
  --kw-shadow-sm:0 1px 2px rgba(0,0,0,.06),0 1px 1px rgba(0,0,0,.04);
  --kw-shadow-md:0 8px 24px rgba(0,0,0,.12);
  --kw-focus: 0 0 0 3px rgba(182,231,255,.7), 0 0 0 6px rgba(0,12,124,.35);

  /* Type */
  --kw-heading:#111111;              /* kept for Lora headings */
  --kw-text:#1e293b;                  /* body text */
  --kw-muted:#6b6b6b;                 /* paragraphs from template */

  /* Semantic */
  --kw-success:#16a34a;
  --kw-warning:#f59e0b;
  --kw-danger:#dc2626;
  --kw-info:#2563eb;
}

/****************************
 * 1) Baseline (kept from template, lightly refined)
 ****************************/
html, body{height:100%;font-family:"Cabin",sans-serif;-webkit-font-smoothing:antialiased;font-smoothing:antialiased;color:var(--kw-text);background:var(--kw-white)}

h1,h2,h3,h4,h5,h6{margin:0;color:var(--kw-heading);font-weight:400;font-family:"Lora",serif}
h1{font-size:70px}
h2{font-size:36px}
h3{font-size:30px}
h4{font-size:24px}
h5{font-size:18px}
h6{font-size:16px}

p{font-size:16px;font-family:"Cabin",sans-serif;color:var(--kw-muted);font-weight:400;line-height:26px;margin:0 0 15px}
img{max-width:100%}
input:focus,select:focus,button:focus,textarea:focus{outline:none;box-shadow:var(--kw-focus)}
a:hover,a:focus{text-decoration:none;outline:none;color:var(--kw-white)}
ul,ol{padding:0;margin:0}

/* Helper */
.section-title{text-align:center;margin-bottom:22px}
.section-title span{font-size:14px;color:var(--kw-gray-700);font-weight:700;text-transform:uppercase;letter-spacing:2px}
.section-title h2{font-size:44px;color:#19191a;line-height:58px;margin-top:10px}
.set-bg{background-repeat:no-repeat;background-size:cover;background-position:center}
.spad{padding-top:100px;padding-bottom:100px}
.spad-2{padding-top:50px;padding-bottom:70px}
.text-white h1,.text-white h2,.text-white h3,.text-white h4,.text-white h5,.text-white h6,.text-white p,.text-white span,.text-white li,.text-white a{color:#fff}

/* Buttons */
.primary-btn{display:inline-block;font-size:13px;color:#fff;text-transform:uppercase;letter-spacing:2px;font-weight:700;position:relative}
.primary-btn:after{position:absolute;left:0;bottom:-5px;width:100%;height:2px;background:var(--kw-primary);content:""}

/****************************
 * 2) Loader (kept, recolored)
 ****************************/
#preloder{position:fixed;width:100%;height:100%;top:0;left:0;z-index:999999;background:#ffffff}
.loader{width:40px;height:40px;position:absolute;top:50%;left:50%;margin-top:-13px;margin-left:-13px;border-radius:60px;animation:loader .8s linear infinite}
@keyframes loader{
  0%{transform:rotate(0deg);border:4px solid var(--kw-primary);border-left-color:transparent}
  50%{transform:rotate(180deg);border:3px solid var(--kw-secondary);border-left-color:transparent}
  100%{transform:rotate(360deg);border:4px solid var(--kw-primary);border-left-color:transparent}
}

/* Quick controls */
.spacial-controls{position:fixed;width:111px;height:91px;top:0;right:0;z-index:999}
.spacial-controls .search-switch{display:block;height:100%;padding-top:30px;background:var(--kw-gray-700);text-align:center;cursor:pointer;color:#fff}
.search-model{display:none;position:fixed;width:100%;height:100%;left:0;top:0;background:#000;z-index:99999}
.search-model-form{padding:0 15px}
.search-model-form input{width:500px;font-size:40px;border:none;border-bottom:2px solid var(--kw-gray-600);background:none;color:#cbd5e1}
.search-close-switch{position:absolute;width:50px;height:50px;background:var(--kw-gray-700);color:#fff;text-align:center;border-radius:50%;font-size:28px;line-height:28px;top:30px;cursor:pointer;display:flex;align-items:center;justify-content:center}

/****************************
 * 3) Header
 ****************************/
.header-section.header-normal .menu-item{box-shadow:0 12px 15px rgba(36,11,12,.05)}
.top-nav{border-bottom:1px solid var(--kw-gray-200)}
.top-nav .tn-left li{list-style:none;display:inline-block;font-size:16px;color:#19191a;font-weight:500;padding:14px 0 12px;margin-right:64px;position:relative}
.top-nav .tn-left li:after{position:absolute;right:-32px;top:0;width:1px;height:100%;background:var(--kw-gray-200);content:""}
.top-nav .tn-left li:last-child{margin-right:0}
.top-nav .tn-left li:last-child:after{display:none}
.top-nav .tn-left li i{color:var(--kw-primary);margin-right:4px}
.top-nav .tn-right{text-align:right}
.top-nav .tn-right .top-social{display:inline-block;margin-right:35px;padding:13px 0}
.top-nav .tn-right .top-social a{display:inline-block;font-size:16px;color:#19191a;margin-left:15px}
.top-nav .tn-right .bk-btn{display:inline-block;font-size:13px;font-weight:700;padding:16px 28px 15px;background:var(--kw-primary);color:#fff;text-transform:uppercase;letter-spacing:2px;border-radius:var(--kw-radius-sm);box-shadow:var(--kw-shadow-sm)}
.top-nav .tn-right .bk-btn:hover{filter:brightness(.95)}
.top-nav .tn-right .language-option{display:inline-block;margin-left:30px;cursor:pointer;padding:13px 0 11px;position:relative}
.top-nav .tn-right .language-option:hover .flag-dropdown{top:40px;opacity:1;visibility:visible}
.top-nav .tn-right .language-option img{height:26px;width:26px;border-radius:50%;margin-right:10px}
.top-nav .tn-right .language-option span{font-size:16px;color:#19191a;text-transform:uppercase;font-weight:500}
.top-nav .tn-right .language-option .flag-dropdown{position:absolute;left:0;top:60px;width:120px;background:#ffffff;display:block;padding:10px 12px;box-shadow:0 9px 10px rgba(25,25,26,.2);opacity:0;visibility:hidden;transition:.3s;z-index:99;border-radius:var(--kw-radius-sm)}
.top-nav .tn-right .language-option .flag-dropdown ul li{list-style:none;text-align:left}
.top-nav .tn-right .language-option .flag-dropdown ul li a{font-size:14px;text-transform:uppercase;font-weight:500;color:#19191a;transition:.3s}
.top-nav .tn-right .language-option .flag-dropdown ul li a:hover{color:var(--kw-primary)}

.menu-item{position:relative;z-index:9}
.menu-item .logo{padding:25px 0}
.menu-item .logo a{display:inline-block}
.menu-item .nav-menu{text-align:right}
.menu-item .nav-menu .mainmenu{display:inline-block}
.menu-item .nav-menu .mainmenu li{list-style:none;display:inline-block;position:relative;z-index:1}
.menu-item .nav-menu .mainmenu li.active a:after{opacity:1}
.menu-item .nav-menu .mainmenu li:hover> a:after{opacity:1}
.menu-item .nav-menu .mainmenu li:hover .dropdown{top:77px;opacity:1;visibility:visible}
.menu-item .nav-menu .mainmenu li a{font-size:16px;color:#19191a;margin-right:42px;font-weight:500;display:inline-block;padding:27px 0;position:relative;transition:.3s}
.menu-item .nav-menu .mainmenu li a:after{position:absolute;left:0;top:52px;width:100%;height:2px;background:var(--kw-primary);content:"";opacity:0;transition:.3s}
.menu-item .nav-menu .mainmenu li .dropdown{position:absolute;left:0;top:97px;width:200px;background:#ffffff;z-index:9;opacity:0;visibility:hidden;transition:.3s;box-shadow:0 9px 15px rgba(25,25,26,.08);border-radius:var(--kw-radius-sm);overflow:hidden}
.menu-item .nav-menu .mainmenu li .dropdown li{list-style:none;display:block}
.menu-item .nav-menu .mainmenu li .dropdown li a{font-size:16px;color:#19191a;display:block;text-align:left;padding:10px 16px;transition:.2s}
.menu-item .nav-menu .mainmenu li .dropdown li a:hover{color:var(--kw-primary);background:var(--kw-gray-100)}
.menu-item .nav-menu .mainmenu li .dropdown li a:after{display:none}
.menu-item .nav-menu .nav-right{display:inline-block;margin-left:43px;padding:27px 0}
.menu-item .nav-menu .nav-right i{font-size:16px;color:#19191a;cursor:pointer}
.canvas-open{display:none}
.offcanvas-menu-wrapper{display:none}

/****************************
 * 4) Hero
 ****************************/
.hero-section{position:relative;padding-top:60px;padding-bottom:100px}
.hero-section .container{position:relative;z-index:5}
.hero-text{padding-top:145px}
.hero-text h1{font-size:80px;line-height:90px;color:#fff;margin-bottom:16px;text-shadow:0 6px 24px rgba(0,0,0,.25)}
.hero-text p{font-size:18px;color:#fff;line-height:28px;margin-bottom:35px;opacity:.95}

.booking-form{background:#ffffff;padding:44px 40px 50px;border-radius:var(--kw-radius-md);box-shadow:var(--kw-shadow-md)}
.booking-form h3{color:#19191a;margin-bottom:36px}
.booking-form form .check-date{position:relative;margin-bottom:15px}
.booking-form form .check-date label{font-size:14px;color:#707079;display:block;margin-bottom:10px}
.booking-form form .check-date input{width:100%;height:50px;border:1px solid var(--kw-gray-200);border-radius:var(--kw-radius-sm);font-size:16px;color:#19191a;text-transform:uppercase;font-weight:500;padding-left:20px}
.booking-form form .check-date i{color:var(--kw-primary);position:absolute;right:18px;bottom:17px}

.booking-form form .select-option{margin-bottom:15px}
.booking-form form .select-option label{font-size:14px;color:#707079;display:block;margin-bottom:10px}
/* nice-select (kept, restyled) */
.booking-form form .select-option .nice-select{border-radius:7px;border:1px solid var(--kw-primary);height:50px;line-height:50px;outline:none;padding-left:20px;width:100%;float:none}
.booking-form form .select-option .nice-select.open{z-index:1000}
.booking-form form .select-option .nice-select .list{max-height:240px;overflow-y:auto;overscroll-behavior:contain}
.booking-form form .select-option .nice-select .list::-webkit-scrollbar{width:2px}
.booking-form form .select-option .nice-select .list::-webkit-scrollbar-track{background:#ffffff;border-radius:8px}
.booking-form form .select-option .nice-select .list::-webkit-scrollbar-thumb{background:var(--kw-primary);border-radius:6px}
.booking-form form .select-option .nice-select:after{border-bottom:2px solid var(--kw-primary);border-right:2px solid var(--kw-primary);height:10px;margin-top:0;right:20px;width:10px;top:36%}
.booking-form form .select-option .nice-select span{font-size:16px;color:#19191a;text-transform:uppercase;font-weight:500}
.booking-form form .select-option .nice-select .list{margin-top:0;width:100%}
.booking-form form button{display:block;font-size:14px;text-transform:uppercase;border:1px solid var(--kw-primary);border-radius:var(--kw-radius-sm);color:var(--kw-primary);font-weight:600;background:transparent;width:100%;height:46px;margin-top:30px;transition:.2s}
.booking-form form button:hover{background:var(--kw-primary);color:#fff}

.hero-slider{position:absolute;width:100%;height:100%;left:0;top:0}
.hero-slider.owl-carousel .owl-dots{position:absolute;left:0;bottom:23px;width:100%;text-align:center}
.hero-slider.owl-carousel .owl-dots button{height:6px;width:6px;background:#ffffff;opacity:.6;border-radius:50%;margin-right:10px;transition:.3s}
.hero-slider.owl-carousel .owl-dots button.active{width:30px;border-radius:50px;opacity:1;background:var(--kw-secondary)}
.hero-slider .owl-stage-outer,.hero-slider .owl-stage,.hero-slider .owl-item,.hero-slider .hs-item{height:100%}

/****************************
 * 5) About
 ****************************/
.about-text{text-align:center;padding:0 35px}
.about-text p{color:#595960;font-weight:500}
.about-text p.s-para{margin-bottom:35px}
.about-text .about-btn{color:#19191a}
.about-pic img{min-width:100%}

/****************************
 * 6) Services
 ****************************/
.services-section{padding-bottom:60px;border-top:1px solid var(--kw-gray-200)}
.services-section .section-title{margin-bottom:36px}
.service-item{text-align:center;padding:30px 35px 18px;transition:.3s;border-radius:var(--kw-radius-md)}
.service-item:hover{background:var(--kw-primary);box-shadow:var(--kw-shadow-md)}
.service-item:hover i,.service-item:hover h4,.service-item:hover p{color:#ffffff}
.service-item i{display:inline-block;color:var(--kw-primary);transition:.3s}
.service-item h4{color:#19191a;font-size:22px;margin-bottom:15px;margin-top:10px;transition:.3s}
.service-item p{color:#707079;transition:.3s}

/****************************
 * 7) Home Page Room
 ****************************/
.hp-room-items{margin-left:-15px;margin-right:-15px;overflow:hidden}
.hp-room-items .hp-room-item{height:600px;margin-right:-15px;position:relative;overflow:hidden;border-radius:var(--kw-radius-lg)}
.hp-room-items .hp-room-item:hover .hr-text{bottom:135px}
.hp-room-items .hp-room-item:hover .hr-text h2{margin-bottom:30px}
.hp-room-items .hp-room-item .hr-text{position:absolute;left:45px;right:25px;bottom:-250px;transition:.5s}
.hp-room-items .hp-room-item .hr-text h3{color:#ffffff;margin-bottom:15px;text-shadow:0 4px 16px rgba(0,0,0,.25)}
.hp-room-items .hp-room-item .hr-text h2{color:var(--kw-secondary);font-weight:700;margin-bottom:50px;transition:.2s}
.hp-room-items .hp-room-item .hr-text h2 span{font-family:"Cabin",sans-serif;font-size:16px;font-weight:400;color:#ffffff}
.hp-room-items .hp-room-item .hr-text table{margin-bottom:30px}
.hp-room-items .hp-room-item .hr-text table tbody tr td{font-size:16px;color:#ffffff;line-height:36px}
.hp-room-items .hp-room-item .hr-text table tbody tr td.r-o{width:120px}
.hp-room-items .hp-room-item .hr-text .primary-btn:after{background:#ffffff}

/****************************
 * 8) Testimonial
 ****************************/
.testimonial-section{background:#f9f9f9}
.testimonial-section .section-title{margin-bottom:30px}
.testimonial-slider.owl-carousel .owl-item img{width:auto;margin:0 auto}
.testimonial-slider.owl-carousel .owl-nav button{height:44px;width:44px;border:1px solid var(--kw-gray-200);font-size:24px;color:#707079;background:#ffffff;line-height:48px;text-align:center;border-radius:50%;position:absolute;left:-190px;top:50%;transform:translateY(-6px);transition:.3s}
.testimonial-slider.owl-carousel .owl-nav button:hover{border-color:var(--kw-primary);color:var(--kw-primary)}
.testimonial-slider.owl-carousel .owl-nav button.owl-next{left:auto;right:-190px}
.testimonial-slider .ts-item{text-align:center}
.testimonial-slider .ts-item p{font-size:20px;color:#707079;line-height:30px;margin-bottom:50px}
.testimonial-slider .ts-item .ti-author{margin-bottom:60px}
.testimonial-slider .ts-item .ti-author .rating i{color:#f5b917;font-size:16px}
.testimonial-slider .ts-item .ti-author h5{font-size:20px;color:#19191a;display:inline-block}

/****************************
 * 9) Blog & Event
 ****************************/
.blog-section{padding-bottom:70px}
.blog-section .section-title{margin-bottom:36px}

/****************************
 * 10) Footer
 ****************************/
.footer-section{background:var(--kw-gray-800)}
.footer-section .footer-text{padding:80px 0 30px}
.footer-section .footer-text .ft-about{margin-bottom:30px}
.footer-section .footer-text .ft-about .logo{margin-bottom:20px}
.footer-section .footer-text .ft-about p{color:#c7c9d1;margin-bottom:20px}
.footer-section .footer-text .ft-about .fa-social a{display:inline-block;height:40px;width:40px;font-size:16px;line-height:40px;text-align:center;color:#ffffff;border:1px solid rgba(182,231,255,.35);border-radius:50%;transition:.3s;margin-right:7px}
.footer-section .footer-text .ft-about .fa-social a:hover{background:var(--kw-primary);border-color:var(--kw-primary)}
.footer-section .footer-text .ft-contact{margin-bottom:30px}
.footer-section .footer-text .ft-contact h6{font-size:14px;color:var(--kw-secondary);text-transform:uppercase;font-weight:700;letter-spacing:3px;font-family:"Cabin",sans-serif;margin-bottom:20px}
.footer-section .footer-text .ft-contact ul li{font-size:16px;color:#c7c9d1;line-height:32px;list-style:none}
.footer-section .footer-text .ft-newslatter h6{font-size:14px;color:var(--kw-secondary);text-transform:uppercase;font-weight:700;letter-spacing:3px;font-family:"Cabin",sans-serif;margin-bottom:20px}
.footer-section .footer-text .ft-newslatter p{color:#c7c9d1;margin-bottom:20px}
.footer-section .footer-text .ft-newslatter .fn-form{position:relative}
.footer-section .footer-text .ft-newslatter .fn-form input{width:100%;height:50px;border-radius:var(--kw-radius-sm);background:#2a2e3a;border:1px solid transparent;padding-left:20px;font-size:16px;color:#e5e7eb}
.footer-section .footer-text .ft-newslatter .fn-form input:focus{border-color:var(--kw-secondary);box-shadow:var(--kw-focus)}
.footer-section .footer-text .ft-newslatter .fn-form button{position:absolute;right:0;top:0;font-size:16px;background:var(--kw-primary);color:#ffffff;padding:0 16px;height:50px;border:none;border-radius:0 var(--kw-radius-sm) var(--kw-radius-sm) 0}
.footer-section .copyright-option{background:rgba(16,20,31,.2);padding:20px 0}
.footer-section .copyright-option ul li{list-style:none;display:inline-block;margin-right:34px}
.footer-section .copyright-option ul li:last-child{margin-right:0}
.footer-section .copyright-option ul li a{font-size:16px;color:#c7c9d1}
.footer-section .copyright-option .co-text{font-size:16px;color:#9aa0aa;text-align:right}

/****************************
 * 11) Breadcrumb
 ****************************/
.breadcrumb-section{padding-top:70px;padding-bottom:80px}
.breadcrumb-text{text-align:center}
.breadcrumb-text h2{font-size:44px;color:#19191a;margin-bottom:12px}
.breadcrumb-text .bt-option a{display:inline-block;font-size:18px;color:#19191a;margin-right:20px;position:relative;font-weight:500}
.breadcrumb-text .bt-option a:after{position:absolute;right:-13px;top:1px;content:"\f105";font-size:18px;font-family:"FontAwesome";color:#aaaab3}
.breadcrumb-text .bt-option span{display:inline-block;font-size:18px;color:#aaaab3}

/****************************
 * 12) About Us Page
 ****************************/
.aboutus-page-section{padding-top:0;padding-bottom:70px}
.about-page-text{margin-bottom:65px}
.about-page-text .ap-title{margin-bottom:30px}
.about-page-text .ap-title h2{font-size:44px;color:#19191a;margin-bottom:18px}
.about-page-text .ap-title p{font-size:18px;color:#707079;line-height:28px}
.about-page-text .ap-services li{list-style:none;font-size:20px;color:#707079;line-height:42px}
.about-page-text .ap-services li i{color:var(--kw-primary);margin-right:5px}
.about-page-services .ap-service-item{position:relative;height:420px;border-radius:5px;margin-bottom:30px;overflow:hidden}
.about-page-services .ap-service-item .api-text{position:absolute;left:0;bottom:40px;width:100%;text-align:center}
.about-page-services .ap-service-item .api-text h3{color:#ffffff;text-shadow:0 4px 16px rgba(0,0,0,.3)}

/****************************
 * 13) Video
 ****************************/
.video-section{height:500px;padding-top:140px}
.video-section .video-text{text-align:center}
.video-section .video-text h2{font-size:48px;color:#ffffff;margin-bottom:16px}
.video-section .video-text p{font-size:20px;color:#ffffff;margin-bottom:40px}
.video-section .video-text .play-btn{display:inline-block}

/****************************
 * 14) Gallery
 ****************************/
.gallery-section{padding-bottom:80px}
.gallery-section .section-title{margin-bottom:38px}
.gallery-item{position:relative;height:279px;margin-bottom:20px;border-radius:5px;z-index:1;overflow:hidden}
.gallery-item:hover:after{opacity:1}
.gallery-item:hover .gi-text{opacity:1}
.gallery-item:after{position:absolute;left:0;top:0;width:100%;height:100%;background:rgba(25,25,26,.3);content:"";z-index:-1;border-radius:5px;transition:.3s;opacity:0}
.gallery-item.large-item{height:576px}
.gallery-item .gi-text{display:flex;align-items:center;justify-content:center;width:100%;height:100%;transition:.3s;opacity:0}
.gallery-item .gi-text h3{color:#ffffff}

/****************************
 * 15) Rooms (cards)
 ****************************/
.rooms-section{padding-top:0;padding-bottom:80px}
.room-item{margin-bottom:30px;border-radius:var(--kw-radius-md);overflow:hidden}
.room-item img{min-width:100%}
.room-item .ri-text{border:1px solid var(--kw-gray-200);border-top:none;padding:24px 24px 30px 28px}
.room-item .ri-text h4{color:#19191a;margin-bottom:17px}
.room-item .ri-text h3{color:var(--kw-primary);font-weight:700;margin-bottom:14px}
.room-item .ri-text h3 span{font-family:"Cabin",sans-serif;font-size:14px;font-weight:400;color:#19191a}
.room-item .ri-text table{margin-bottom:18px}
.room-item .ri-text table tbody tr td{font-size:16px;color:#707079;line-height:36px}
.room-item .ri-text table tbody tr td.r-o{width:125px}
.room-item .ri-text .primary-btn{color:#19191a}
.room-pagination{text-align:center;padding-top:20px}
.room-pagination a{font-size:16px;color:#475569;border:1px solid var(--kw-secondary);border-radius:var(--kw-radius-sm);padding:7px 13px 5px;margin-right:7px;display:inline-block;transition:.2s}
.room-pagination a:hover{background:var(--kw-primary);color:#ffffff;border-color:var(--kw-primary)}

/****************************
 * 16) Room Details
 ****************************/
.room-details-section{padding-top:0;padding-bottom:80px}
.room-details-item{margin-bottom:50px}
.room-details-item img{margin-bottom:40px;border-radius:var(--kw-radius-md)}
.room-details-item .rd-text .rd-title{overflow:hidden;margin-bottom:8px}
.room-details-item .rd-text .rd-title h3{color:#19191a;float:left}
.room-details-item .rd-text .rd-title .rdt-right{float:right;text-align:right}
.room-details-item .rd-text .rd-title .rdt-right .rating{display:inline-block;margin-right:25px;margin-bottom:10px}
.room-details-item .rd-text .rd-title .rdt-right .rating i{color:#f5b917}
.room-details-item .rd-text .rd-title .rdt-right a{display:inline-block;color:#ffffff;font-size:13px;text-transform:uppercase;font-weight:700;background:var(--kw-primary);padding:14px 28px 13px;border-radius:var(--kw-radius-sm)}
.room-details-item .rd-text h2{color:var(--kw-primary);font-weight:700;margin-bottom:25px}
.room-details-item .rd-text h2 span{font-family:"Cabin",sans-serif;font-size:16px;font-weight:400;color:#19191a}
.room-details-item .rd-text table{margin-bottom:32px}
.room-details-item .rd-text table tbody tr td{font-size:16px;color:#19191a;line-height:36px}
.room-details-item .rd-text table tbody tr td.r-o{width:120px;color:#707079}
.room-details-item .rd-text p{color:#707079}
.room-details-item .rd-text p.f-para{margin-bottom:22px}

.rd-reviews{padding-top:55px;border-top:1px solid var(--kw-gray-200);margin-bottom:50px}
.rd-reviews h4{color:#19191a;letter-spacing:1px;margin-bottom:45px}
.rd-reviews .review-item{margin-bottom:32px}
.rd-reviews .review-item .ri-pic{float:left;margin-right:30px}
.rd-reviews .review-item .ri-pic img{height:70px;width:70px;border-radius:50%}
.rd-reviews .review-item .ri-text{overflow:hidden;position:relative;padding-left:30px}
.rd-reviews .review-item .ri-text:before{position:absolute;left:0;top:0;width:1px;height:100%;background:#e9e9e9;content:""}
.rd-reviews .review-item .ri-text span{font-size:12px;color:var(--kw-primary);text-transform:uppercase;letter-spacing:3px}
.rd-reviews .review-item .ri-text .rating{position:absolute;right:0;top:0}
.rd-reviews .review-item .ri-text .rating i{color:#f5b917}
.rd-reviews .review-item .ri-text h5{color:#19191a;margin-top:4px;margin-bottom:8px}
.rd-reviews .review-item .ri-text p{color:#707079;margin-bottom:0}

.review-add h4{color:#19191a;letter-spacing:1px;margin-bottom:45px}
.review-add .ra-form input{width:100%;height:50px;border:1px solid var(--kw-gray-200);font-size:16px;color:#334155;padding-left:20px;margin-bottom:25px;border-radius:var(--kw-radius-sm)}
.review-add .ra-form input::placeholder{color:#94a3b8}
.review-add .ra-form h5{font-size:20px;color:#19191a;margin-bottom:24px;float:left;margin-right:10px}
.review-add .ra-form .rating{padding-top:3px;display:inline-block}
.review-add .ra-form .rating i{color:#f5b917;font-size:16px}
.review-add .ra-form textarea{width:100%;height:132px;border:1px solid var(--kw-gray-200);font-size:16px;color:#334155;padding:12px 20px;margin-bottom:24px;resize:none;border-radius:var(--kw-radius-sm)}
.review-add .ra-form textarea::placeholder{color:#94a3b8}
.review-add .ra-form button{font-size:13px;font-weight:700;text-transform:uppercase;color:#ffffff;letter-spacing:2px;background:var(--kw-primary);border:none;padding:14px 34px 13px;display:inline-block;border-radius:var(--kw-radius-sm)}

.room-booking{padding:0 30px 0 40px}
.room-booking h3{color:#19191a;margin-bottom:30px}
.room-booking form .check-date{position:relative;margin-bottom:15px}
.room-booking form .check-date label{font-size:14px;color:#707079;display:block;margin-bottom:10px}
.room-booking form .check-date input{width:100%;height:50px;border:1px solid var(--kw-gray-200);border-radius:var(--kw-radius-sm);font-size:16px;color:#19191a;text-transform:uppercase;font-weight:500;padding-left:20px}
.room-booking form .check-date i{color:var(--kw-primary);position:absolute;right:18px;bottom:17px}
.room-booking form .select-option{margin-bottom:15px}
.room-booking form .select-option label{font-size:14px;color:#707079;display:block;margin-bottom:10px}
.room-booking form .select-option .nice-select{border-radius:var(--kw-radius-sm);border:1px solid var(--kw-gray-200);height:50px;line-height:50px;outline:none;padding-left:20px;width:100%;float:none}
.room-booking form .select-option .nice-select:after{border-bottom:2px solid var(--kw-primary);border-right:2px solid var(--kw-primary);height:10px;margin-top:0;right:20px;width:10px;top:36%}
.room-booking form .select-option .nice-select span{font-size:16px;color:#19191a;text-transform:uppercase;font-weight:500}
.room-booking form .select-option .nice-select .list{margin-top:0;width:100%}
.room-booking form button{display:block;font-size:14px;text-transform:uppercase;border:1px solid var(--kw-primary);border-radius:var(--kw-radius-sm);color:var(--kw-primary);font-weight:600;background:transparent;width:100%;height:46px;margin-top:30px;transition:.2s}
.room-booking form button:hover{background:var(--kw-primary);color:#fff}

/****************************
 * 17) Blog
 ****************************/
.blog-section.blog-page{padding-top:0;padding-bottom:88px}
.blog-item{height:450px;position:relative;margin-bottom:30px;border-radius:5px;overflow:hidden}
.blog-item.small-size{height:400px}
.blog-item .bi-text{position:absolute;left:0;bottom:25px;width:100%;padding:0 30px}
.blog-item .bi-text .b-tag{display:inline-block;color:#ffffff;font-size:12px;text-transform:uppercase;letter-spacing:1px;background:var(--kw-primary);padding:3px 10px;border-radius:var(--kw-radius-xs)}
.blog-item .bi-text h4{margin:18px 0}
.blog-item .bi-text h4 a{color:#ffffff}
.blog-item .bi-text .b-time{font-size:12px;color:#ffffff;text-transform:uppercase;letter-spacing:3px}
.load-more{text-align:center;padding-top:30px}
.load-more .primary-btn{color:#19191a}

/****************************
 * 18) Blog Details
 ****************************/
.blog-details-hero{height:530px;padding-top:165px}
.bd-hero-text{text-align:center}
.bd-hero-text span{font-size:12px;color:#ffffff;background:var(--kw-primary);font-weight:500;text-transform:uppercase;letter-spacing:1px;display:inline-block;padding:4px 16px;border-radius:var(--kw-radius-xs)}
.bd-hero-text h2{font-size:44px;color:#ffffff;line-height:54px;margin-top:30px;margin-bottom:12px}
.bd-hero-text ul li{list-style:none;font-size:14px;color:var(--kw-secondary);margin-right:35px;display:inline-block}
.bd-hero-text ul li:last-child{margin-right:0}
.bd-hero-text ul li.b-time{text-transform:uppercase}

.blog-details-section{padding-top:55px}
.blog-details-text .bd-title{margin-bottom:52px}
.blog-details-text .bd-title p{font-size:18px;color:#707079;line-height:30px}
.blog-details-text .bd-pic{overflow:hidden;margin-bottom:35px}
.blog-details-text .bd-pic .bp-item{width:calc(33.33% - 10px);float:left;margin-right:15px}
.blog-details-text .bd-pic .bp-item:last-child{margin-right:0}
.blog-details-text .bd-pic .bp-item img{min-width:100%;border-radius:var(--kw-radius-sm)}
.blog-details-text .bd-more-text{margin-bottom:50px}
.blog-details-text .bd-more-text .bm-item{margin-bottom:30px}
.blog-details-text .bd-more-text .bm-item h4{color:#19191a;margin-bottom:20px}
.blog-details-text .bd-more-text .bm-item p{font-size:18px;color:#707079;line-height:30px}
.blog-details-text .tag-share{overflow:hidden;border-top:1px solid var(--kw-gray-200);padding-top:30px;margin-bottom:75px}
.blog-details-text .tag-share .tags{float:left}
.blog-details-text .tag-share .tags a{font-size:12px;color:#707079;background:#ebebeb;font-weight:500;text-transform:uppercase;letter-spacing:1px;display:inline-block;padding:4px 16px;border-radius:var(--kw-radius-xs);transition:.3s;margin-right:6px}
.blog-details-text .tag-share .tags a:hover{color:#ffffff;background:var(--kw-primary)}
.blog-details-text .tag-share .social-share{float:right}
.blog-details-text .tag-share .social-share span{display:inline-block;font-size:18px;color:#707079}
.blog-details-text .tag-share .social-share a{display:inline-block;font-size:16px;color:#707079;margin-left:30px}
.blog-details-text .comment-option{margin-bottom:75px}
.blog-details-text .comment-option h4{color:#19191a;margin-bottom:35px}
.blog-details-text .comment-option .single-comment-item{margin-bottom:30px}
.blog-details-text .comment-option .single-comment-item.first-comment .sc-text{padding-left:22px}
.blog-details-text .comment-option .single-comment-item.first-comment .sc-text:before{position:absolute;left:0;top:0;width:1px;height:255px;background:#ebebeb;content:""}
.blog-details-text .comment-option .single-comment-item.reply-comment{padding-left:120px;margin-bottom:52px}
.blog-details-text .comment-option .single-comment-item.second-comment .sc-text{padding-left:22px}
.blog-details-text .comment-option .single-comment-item.second-comment .sc-text:before{position:absolute;left:0;top:0;width:1px;height:100px;background:#ebebeb;content:""}
.blog-details-text .comment-option .single-comment-item .sc-author{float:left;margin-right:28px}
.blog-details-text .comment-option .single-comment-item .sc-author img{height:70px;width:70px;border-radius:50%}
.blog-details-text .comment-option .single-comment-item .sc-text{display:table;position:relative}
.blog-details-text .comment-option .single-comment-item .sc-text span{font-size:12px;color:var(--kw-primary);text-transform:uppercase;letter-spacing:2px}
.blog-details-text .comment-option .single-comment-item .sc-text h5{font-size:20px;color:#19191a;margin-top:4px;margin-bottom:8px}
.blog-details-text .comment-option .single-comment-item .sc-text p{color:#707079;margin-bottom:18px}
.blog-details-text .comment-option .single-comment-item .sc-text a{display:inline-block;color:#19191a;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:5px 24px;border:1px solid var(--kw-secondary);border-radius:50px;transition:.3s;margin-right:10px}
.blog-details-text .comment-option .single-comment-item .sc-text a:hover{background:var(--kw-primary);color:#ffffff;border-color:var(--kw-primary)}
.blog-details-text .leave-comment h4{color:#19191a;margin-bottom:35px}
.blog-details-text .leave-comment .comment-form input{width:100%;height:50px;color:#475569;font-size:16px;padding-left:20px;border:1px solid var(--kw-gray-200);border-radius:var(--kw-radius-sm);margin-bottom:20px;transition:.2s}
.blog-details-text .leave-comment .comment-form input:focus{border-color:var(--kw-primary)}
.blog-details-text .leave-comment .comment-form textarea{width:100%;height:116px;color:#475569;font-size:16px;padding-left:20px;border:1px solid var(--kw-gray-200);border-radius:var(--kw-radius-sm);transition:.2s;margin-bottom:42px;resize:none;padding-top:12px}
.blog-details-text .leave-comment .comment-form textarea:focus{border-color:var(--kw-primary)}
.blog-details-text .leave-comment .comment-form button{font-size:13px;font-weight:700;text-transform:uppercase;color:#ffffff;letter-spacing:2px;background:var(--kw-primary);border:none;padding:14px 42px 13px;display:inline-block;border-radius:var(--kw-radius-sm)}

/****************************
 * 19) Recommend Blog
 ****************************/
.recommend-blog-section{padding-top:65px;padding-bottom:50px}
.recommend-blog-section .section-title{margin-bottom:37px}
.recommend-blog-section .section-title h2{margin-top:0}

/****************************
 * 20) Contact
 ****************************/
.contact-section{padding-top:80px;padding-bottom:80px}
.contact-text h2{font-size:44px;color:#19191a;margin-bottom:24px}
.contact-text p{color:#707079}
.contact-text table tbody tr td{font-size:16px;color:#19191a;line-height:36px;font-weight:500}
.contact-text table tbody tr td.c-o{color:#707079;width:75px}
.contact-form input{width:100%;height:50px;border:1px solid #e1e1e1;font-size:16px;color:#475569;padding-left:25px;margin-bottom:28px;border-radius:var(--kw-radius-sm)}
.contact-form input::placeholder{color:#94a3b8}
.contact-form textarea{width:100%;height:150px;border:1px solid #e1e1e1;font-size:16px;color:#475569;padding:12px 25px;margin-bottom:33px;resize:none;border-radius:var(--kw-radius-sm)}
.contact-form textarea::placeholder{color:#94a3b8}
.contact-form button{font-size:13px;font-weight:700;text-transform:uppercase;color:#ffffff;letter-spacing:2px;background:var(--kw-primary);border:none;padding:14px 34px 13px;display:inline-block;border-radius:var(--kw-radius-sm)}
.map{height:470px;box-shadow:0 14px 35px rgba(0,0,0,.15);margin-top:75px}
.map iframe{width:100%}

/****************************
 * 21) Responsive (structure preserved, minor color tweaks)
 ****************************/
@media only screen and (min-width:1554px) and (max-width:1920px){.hp-room-items .hp-room-item .hr-text{bottom:-200px}}
@media only screen and (min-width:1200px) and (max-width:1250px){.hp-room-items .hp-room-item .hr-text{bottom:-288px}}
@media only screen and (min-width:1200px){.container{max-width:1170px}}
@media only screen and (min-width:992px) and (max-width:1199px){
  .testimonial-slider.owl-carousel .owl-nav button{left:-150px}
  .testimonial-slider.owl-carousel .owl-nav button.owl-next{right:-150px}
  .hp-room-items .hp-room-item .hr-text{bottom:-322px}
  .hp-room-items .hp-room-item:hover .hr-text{bottom:80px}
}
@media only screen and (max-width:991px){
  .top-nav{display:none}
  .menu-item .nav-menu{display:none}
  .offcanvas-menu-overlay{position:fixed;left:0;top:0;background:rgba(0,0,0,.7);z-index:98;height:100%;width:100%;visibility:hidden;transition:.3s}
  .offcanvas-menu-overlay.active{visibility:visible}
  .canvas-open{position:absolute;right:40px;top:25px;font-size:22px;width:30px;height:30px;color:#19191a;border:1px solid #19191a;border-radius:var(--kw-radius-xs);line-height:33px;text-align:center;z-index:100;display:block;cursor:pointer}
  .offcanvas-menu-wrapper{position:fixed;left:-300px;top:0;width:300px;z-index:999;background:#ffffff;text-align:center;overflow-y:auto;height:100%;opacity:0;visibility:hidden;transition:.5s;padding:80px 30px 30px;display:block}
  .offcanvas-menu-wrapper .canvas-close{height:30px;width:30px;border:1px solid #19191a;border-radius:50%;text-align:center;line-height:30px;cursor:pointer;position:absolute;right:30px;top:30px;padding-right:1px}
  .offcanvas-menu-wrapper .search-icon{color:#19191a;text-align:center;cursor:pointer;margin-bottom:10px}
  .offcanvas-menu-wrapper .header-configure-area{margin-bottom:30px}
  .offcanvas-menu-wrapper .header-configure-area .language-option{display:inline-block;cursor:pointer;padding:13px 0;position:relative;margin-bottom:10px}
  .offcanvas-menu-wrapper .header-configure-area .language-option:hover .flag-dropdown{top:40px;opacity:1;visibility:visible}
  .offcanvas-menu-wrapper .header-configure-area .language-option img{height:26px;width:26px;border-radius:50%;margin-right:10px}
  .offcanvas-menu-wrapper .header-configure-area .language-option span{font-size:16px;color:#19191a;text-transform:uppercase;font-weight:500}
  .offcanvas-menu-wrapper .header-configure-area .language-option .flag-dropdown{position:absolute;left:0;top:60px;width:100px;background:#ffffff;display:block;padding:10px 15px;box-shadow:0 9px 10px rgba(25,25,26,.2);opacity:0;visibility:hidden;transition:.3s;z-index:99}
  .offcanvas-menu-wrapper .header-configure-area .language-option .flag-dropdown ul li{list-style:none;text-align:left}
  .offcanvas-menu-wrapper .header-configure-area .language-option .flag-dropdown ul li a{font-size:14px;text-transform:uppercase;font-weight:500;color:#19191a;transition:.3s}
  .offcanvas-menu-wrapper .header-configure-area .language-option .flag-dropdown ul li a:hover{color:var(--kw-primary)}
  .offcanvas-menu-wrapper .header-configure-area .bk-btn{display:inline-block;font-size:13px;font-weight:700;padding:16px 28px 15px;background:var(--kw-primary);color:#ffffff;text-transform:uppercase;letter-spacing:2px;border-radius:var(--kw-radius-sm)}
  .offcanvas-menu-wrapper .mainmenu{display:none}
  .offcanvas-menu-wrapper .slicknav_menu{background:transparent;padding:0}
  .offcanvas-menu-wrapper .slicknav_menu .slicknav_btn{float:none;margin:0 0 10px 0;display:none}
  .offcanvas-menu-wrapper .slicknav_menu .slicknav_nav{display:block!important}
  .offcanvas-menu-wrapper .slicknav_menu .slicknav_nav ul{margin:0;text-align:left}
  .offcanvas-menu-wrapper .slicknav_menu .slicknav_nav ul li .dropdown{padding-left:20px}
  .offcanvas-menu-wrapper .slicknav_menu .slicknav_nav ul li a{margin:0;padding:10px;font-weight:600;font-size:14px;color:#19191a;border-bottom:1px solid var(--kw-gray-200);transition:.3s}
  .offcanvas-menu-wrapper .slicknav_menu .slicknav_nav ul li a:hover{border-radius:0;background:transparent;color:var(--kw-primary)}
  .offcanvas-menu-wrapper .slicknav_menu .slicknav_nav .slicknav_row a{border-bottom:0;padding-left:0;transition:.3s}
  .offcanvas-menu-wrapper .slicknav_menu .slicknav_nav .slicknav_row span{color:#19191a;transition:.3s}
  .offcanvas-menu-wrapper .slicknav_menu .slicknav_nav .slicknav_row:hover a{color:var(--kw-primary)}
  .offcanvas-menu-wrapper .slicknav_menu .slicknav_nav .slicknav_row:hover span{color:var(--kw-primary)}
  .offcanvas-menu-wrapper .top-social{display:inline-block;margin-top:30px;margin-bottom:20px}
  .offcanvas-menu-wrapper .top-social a{display:inline-block;font-size:16px;color:#19191a;margin-right:20px}
  .offcanvas-menu-wrapper .top-social a:last-child{margin-right:0}
  .offcanvas-menu-wrapper .top-widget li{list-style:none;font-size:16px;color:#19191a;font-weight:500;line-height:28px}
  .offcanvas-menu-wrapper .top-widget li i{color:var(--kw-primary);margin-right:4px}
  .offcanvas-menu-wrapper.show-offcanvas-menu-wrapper{left:0;opacity:1;visibility:visible}
  .about-text{margin-bottom:30px}
  .footer-section .copyright-option ul{text-align:center;margin-bottom:10px}
  .footer-section .copyright-option .co-text{text-align:center}
  .about-pic img{margin-bottom:20px}
  .room-booking{padding:0;margin-top:40px}
  .contact-form{padding-top:30px}
  .hero-text{margin-bottom:40px}
}
@media only screen and (min-width:768px) and (max-width:991px){
  .testimonial-slider.owl-carousel .owl-nav button{left:-30px}
  .testimonial-slider.owl-carousel .owl-nav button.owl-next{right:-30px}
  .hp-room-items{margin:0}
  .hp-room-item{margin-bottom:15px}
}
@media only screen and (max-width:767px){
  .testimonial-slider.owl-carousel .owl-nav{display:none}
  .room-details-item .rd-text .rd-title{margin-bottom:25px}
  .room-details-item .rd-text .rd-title h3{float:none;margin-bottom:30px}
  .room-details-item .rd-text .rd-title .rdt-right{float:none;text-align:left}
  .footer-section .copyright-option ul li{margin-right:25px}
  .blog-details-text .tag-share .tags{float:none;margin-bottom:20px}
  .blog-details-text .tag-share .social-share{float:none}
  .about-text .section-title h2{font-size:30px;line-height:40px}
  .hp-room-items{margin:0 -5px}
  .hp-room-item{margin-bottom:10px}
}
@media only screen and (max-width:479px){
  .footer-section .copyright-option ul li{margin-bottom:5px}
  .video-section{padding-top:80px}
  .rd-reviews .review-item .ri-pic,.blog-details-text .comment-option .single-comment-item .sc-author{float:none;margin-bottom:30px}
  .rd-reviews .review-item .ri-text .rating{position:relative}
  .rd-reviews .review-item .ri-text,.blog-details-text .comment-option .single-comment-item.second-comment .sc-text,.blog-details-text .comment-option .single-comment-item.first-comment .sc-text{padding-left:0}
  .blog-details-text .comment-option .single-comment-item.reply-comment{padding-left:30px}
  .rd-reviews .review-item .ri-text:before,.blog-details-text .comment-option .single-comment-item.first-comment .sc-text:before,.blog-details-text .comment-option .single-comment-item.second-comment .sc-text:before{display:none}
  .blog-details-hero{padding-top:70px}
  .blog-details-text .bd-pic .bp-item{width:100%;float:none;margin-right:0;margin-bottom:10px}
  .blog-details-text .tag-share .tags a{margin-bottom:6px}
  .blog-details-text .comment-option .single-comment-item .sc-text a{margin-bottom:10px}
}

/****************************
 * 22) Custom alerts (recolored)
 ****************************/
.custom-alert{padding:12px 20px;margin:15px 0;border-radius:6px;position:relative;font-size:15px;font-family:'Segoe UI',sans-serif;box-shadow:0 0 8px rgba(0,0,0,.08);animation:fadeIn .4s ease-in-out;background:var(--kw-gray-100);border-left:5px solid var(--kw-primary)}
.success-alert{background-color:#e6f9ed;color:#237a47;border-left-color:var(--kw-success)}
.error-alert{background-color:#fdecea;color:#a94442;border-left-color:var(--kw-danger)}
.close-btn{position:absolute;top:8px;right:15px;font-size:20px;cursor:pointer;color:#888}
.close-btn:hover{color:#333}
@keyframes fadeIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

/* ============================================
   Header dropdown overlay (desktop)
   - Dim/blur achtergrond wanneer dropdown open is
   - Geen HTML/JS nodig, puur CSS
   ============================================ */

/* Zorg dat header en dropdown boven overlay liggen */
.menu-item { z-index: 50 !important; }
.menu-item .nav-menu .mainmenu li .dropdown { z-index: 51 !important; }

/* Onzichtbare overlay, wordt geactiveerd via :has() */
.menu-item::before{
  content:"";
  position: fixed;
  inset: 0;
  background: rgba(0,12,124,.28);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;           /* visueel dimmen, page blijft klikbaar */
  transition: opacity .2s ease, visibility .2s ease;
  z-index: 49;                    /* net onder de dropdown */
}

/* Toon overlay ALS er een dropdown open/hover is (moderne browsers) */
@supports (selector(:has(*))) {
  .menu-item:has(.mainmenu li:hover .dropdown)::before,
  .menu-item:has(.mainmenu li:focus-within .dropdown)::before {
    opacity: 1;
    visibility: visible;
  }
}

/* Fallback (oude browsers zonder :has): toon overlay bij hover over het menu */
@supports not (selector(:has(*))) {
  .menu-item:hover::before { 
    opacity: 1; 
    visibility: visible; 
  }
}

/* =======================================================
   KW – Overlay zonder blur + dropdown altijd haarscherp
   ======================================================= */

/* 1) Kill blur globally (zekerheid met !important) */
.kw-sidebar-overlay,
#kw-sidebar-overlay,
.offcanvas-menu-overlay,
.standby-backdrop,
.standby-drawer,
.standby-alert,
.menu-item::before,
.menu-item,
.menu-item * ,
.dropdown,
.dropdown-menu {
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  filter: none !important;
}

/* 2) Header overlay: dimmen zonder blur, NIET over de navbar */
.menu-item { 
  --kw-nav-h: 86px;                 /* pas aan als je header hoger/lager is */
  z-index: 10002 !important;        /* header boven overlay */
}
.menu-item .mainmenu li .dropdown{
  z-index: 10003 !important;        /* dropdown boven overlay */
  background: #fff !important;      /* volledig opaque zodat niets “wazig” oogt */
}

/* Overlay die pas onder de navbar begint */
.menu-item::before{
  content:"";
  position: fixed;
  left: 0; right: 0;
  top: var(--kw-nav-h);             /* laat de header vrij */
  bottom: 0;
  background: rgba(17,24,39,.30) !important; /* alleen een subtiele dim, géén blur */
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .2s ease, visibility .2s ease;
  z-index: 10000;                   /* net onder header en dropdown */
}

/* Overlay aan/uit wanneer dropdown open is (moderne browsers) */
@supports (selector(:has(*))) {
  .menu-item:has(.mainmenu li:hover .dropdown)::before,
  .menu-item:has(.mainmenu li:focus-within .dropdown)::before{
    opacity: 1;
    visibility: visible;
  }
}

/* Fallback: toon overlay wanneer er over de header gegaan wordt */
@supports not (selector(:has(*))) {
  .menu-item:hover::before{
    opacity: 1;
    visibility: visible;
  }
}

/* ===============================
   Header dropdown: geen overlay
   =============================== */

/* zet de pseudo-overlay van de header uit */
.menu-item::before{
  content: none !important;
  display: none !important;
}

/* zelfs als :has() aanwezig is: nooit tonen */
@supports (selector(:has(*))) {
  .menu-item:has(.mainmenu li:hover .dropdown)::before,
  .menu-item:has(.mainmenu li:focus-within .dropdown)::before{
    content: none !important;
    display: none !important;
  }
}

/* dropdown zelf gewoon strak en boven alles */
.menu-item { z-index: 10002 !important; }
.menu-item .mainmenu li .dropdown{
  z-index: 10003 !important;
  background: #fff !important;      /* geen translucency/blur */
  box-shadow: 0 8px 18px rgba(0,0,0,.10); /* mag weg als je echt 0 schaduw wilt */
}

/* zekerheid: geen blur op de dropdown */
.menu-item .mainmenu li .dropdown,
.menu-item .mainmenu li .dropdown *{
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  filter: none !important;
}

