/*
Theme Name: Top Luxury Services
Theme URI: https://example.com/
Author: Top Luxury Services
Author URI: https://example.com/
Description: Clean, fast, RTL-ready WordPress theme style for service websites. Burger menu friendly, Polylang friendly, mobile-first, no forced page templates.
Version: 1.0.16
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: top-luxury-services
*/

/* =========================================================
   Top Luxury Services - Clean Final CSS
   الهدف: إزالة التضارب والتكرار، تثبيت البنر، منع السحب يمين/يسار،
   ترتيب الهيدر، جدول المحتوى، التقييمات، المشاركة، الكروت، والفوتر.
   ========================================================= */

/* ------------------------------
   Variables / Reset
------------------------------ */
:root{
  --tls-navy:#062f3d;
  --tls-navy-2:#0a4354;
  --tls-teal:#0f7890;
  --tls-aqua:#eaf7f8;
  --tls-gold:#d8b46a;
  --tls-orange:#f5a400;
  --tls-ivory:#fbfaf7;
  --tls-white:#ffffff;
  --tls-text:#23313d;
  --tls-muted:#697786;
  --tls-border:#e4edf2;
  --tls-soft:#f4f8fa;
  --tls-shadow:0 18px 55px rgba(6,47,61,.10);
  --tls-shadow-soft:0 10px 30px rgba(6,47,61,.08);
  --tls-radius:24px;
  --tls-radius-sm:16px;
  --tls-container:1180px;
  --tls-header-h:78px;
  --tls-offer-h:42px;
  --tls-sticky-cta-h:62px;
  --tls-font:system-ui,-apple-system,"Segoe UI",Roboto,Arial,"Noto Sans",sans-serif;
}

*,
*::before,
*::after{box-sizing:border-box}

html{
  width:100%;
  max-width:100%;
  overflow-x:hidden!important;
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
}

body{
  width:100%;
  max-width:100%;
  margin:0;
  overflow-x:hidden!important;
  font-family:var(--tls-font);
  color:var(--tls-text);
  background:linear-gradient(180deg,#fff 0%,var(--tls-ivory) 100%);
  line-height:1.75;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  padding-bottom:calc(var(--tls-offer-h) + var(--tls-sticky-cta-h) + 18px);
}

html[lang^="ar"],
html[dir="rtl"],
body.rtl{
  direction:rtl;
  text-align:right;
}

html[lang^="ar"] body,
body.rtl{
  font-family:Tahoma,Arial,"Noto Kufi Arabic",var(--tls-font);
}

a{
  color:var(--tls-teal);
  text-decoration:none;
  text-underline-offset:4px;
}

a:hover{text-decoration:underline}

img,
svg,
video,
canvas,
iframe{
  max-width:100%;
  height:auto;
  display:block;
}

button,
input,
textarea,
select{font:inherit}

button{cursor:pointer}

table{max-width:100%}

.screen-reader-text,
.sr-only{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  padding:0!important;
  margin:-1px!important;
  overflow:hidden!important;
  clip:rect(0,0,0,0)!important;
  white-space:nowrap!important;
  border:0!important;
}

.site,
#page,
.tls-site,
.tls-main,
.tls-main-content,
.tls-page-main,
.tls-single-main,
.tls-content-shell,
.tls-entry-content{
  max-width:100%;
}

.tls-container{
  width:min(var(--tls-container),calc(100% - 32px));
  margin-inline:auto;
}

/* ------------------------------
   Accessibility
------------------------------ */
.tls-skip-link{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}

.tls-skip-link:focus{
  left:16px;
  top:16px;
  width:auto;
  height:auto;
  z-index:99999;
  background:#fff;
  color:var(--tls-navy);
  border:2px solid var(--tls-gold);
  border-radius:12px;
  padding:10px 14px;
}

/* ------------------------------
   Header - Burger Always
------------------------------ */
.tls-site-header{
  position:sticky;
  top:0;
  z-index:999;
  min-height:var(--tls-header-h);
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(228,237,242,.95);
  box-shadow:0 10px 28px rgba(6,47,61,.055);
  direction:ltr!important;
}

body.admin-bar .tls-site-header{top:32px}
@media(max-width:782px){body.admin-bar .tls-site-header{top:46px}}

.tls-header-inner{
  width:min(1180px,calc(100% - 32px));
  min-height:var(--tls-header-h);
  margin:0 auto;
  padding:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:14px!important;
  direction:ltr!important;
}

.tls-brand-wrap{
  order:1!important;
  display:flex!important;
  align-items:center!important;
  flex:0 1 auto!important;
  min-width:0!important;
  max-width:260px!important;
  overflow:hidden!important;
  margin:0!important;
}

.custom-logo-link,
.tls-logo,
.site-logo{
  display:flex;
  align-items:center;
  min-width:0;
  color:var(--tls-navy);
  text-decoration:none;
}

.tls-brand-wrap img,
.tls-brand-wrap .custom-logo,
.custom-logo{
  display:block!important;
  max-height:52px!important;
  width:auto!important;
  max-width:220px!important;
  object-fit:contain!important;
}

.tls-text-logo,
.site-title{
  display:inline-flex!important;
  align-items:center!important;
  min-height:44px!important;
  color:var(--tls-navy)!important;
  font-size:23px!important;
  line-height:1!important;
  font-weight:950!important;
  letter-spacing:-.04em!important;
  white-space:nowrap!important;
  text-decoration:none!important;
}

.site-description{
  margin:0;
  color:var(--tls-muted);
  font-size:13px;
}

.tls-header-spacer{
  order:2;
  flex:1 1 auto;
  min-width:12px;
}

.tls-desktop-nav{
  display:none!important;
}

.tls-header-actions{
  order:3!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px!important;
  margin:0!important;
  flex:0 0 auto!important;
  min-width:0!important;
  direction:ltr!important;
}

html[lang^="ar"] .tls-header-actions,
body.rtl .tls-header-actions,
[dir="rtl"] .tls-header-actions{
  margin:0!important;
}

.tls-round-action,
.tls-call-btn,
.tls-whatsapp-btn{
  display:none!important;
}

/* Book button */
.tls-book-btn{
  order:1!important;
  min-width:124px!important;
  height:48px!important;
  padding:0 18px!important;
  border-radius:999px!important;
  border:0!important;
  background:linear-gradient(135deg,#f5a400,#ffc247)!important;
  color:#101820!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  font-weight:900!important;
  line-height:1!important;
  text-decoration:none!important;
  box-shadow:0 12px 24px rgba(245,164,0,.22)!important;
  white-space:nowrap!important;
}

.tls-book-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 32px rgba(245,164,0,.28)!important;
  text-decoration:none;
}

.tls-book-btn .tls-book-icon{
  display:inline-flex!important;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  border-radius:50%;
  background:rgba(255,255,255,.45);
  font-size:12px;
  line-height:1;
  flex:0 0 18px;
}

.tls-book-btn .tls-book-text,
.tls-book-btn span:not(.tls-book-icon){
  position:static!important;
  width:auto!important;
  height:auto!important;
  clip:auto!important;
  clip-path:none!important;
  overflow:visible!important;
  white-space:nowrap!important;
  line-height:1!important;
  opacity:1!important;
  visibility:visible!important;
}

/* Language switcher */
.tls-language-switcher,
.tls-lang-switcher{
  order:2!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px;
  flex:0 0 auto!important;
  min-width:0!important;
  direction:ltr!important;
}

.tls-language-switcher a,
.tls-language-switcher.tls-lang-disabled,
.tls-lang-switcher a{
  height:44px!important;
  min-height:44px!important;
  padding:0 11px!important;
  border-radius:999px!important;
  border:1px solid #dbe8ee!important;
  background:#fff!important;
  color:#23313d!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:7px!important;
  font-size:13px!important;
  font-weight:850!important;
  text-decoration:none!important;
  box-shadow:0 8px 18px rgba(6,47,61,.055)!important;
  white-space:nowrap!important;
}

.tls-language-switcher a:hover,
.tls-lang-switcher a:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 28px rgba(6,47,61,.12)!important;
}

.tls-language-switcher .tls-lang-name,
.tls-lang-name{
  display:inline-block!important;
  max-width:82px;
  overflow:hidden;
  text-overflow:ellipsis;
  line-height:1!important;
  white-space:nowrap;
}

/* UAE flag */
.tls-uae-flag,
.tls-language-switcher .tls-uae-flag,
.tls-lang-switcher .tls-uae-flag{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:22px!important;
  height:22px!important;
  flex:0 0 22px!important;
  border-radius:50%!important;
  overflow:hidden!important;
  background:transparent!important;
  box-shadow:0 0 0 1px rgba(0,0,0,.08)!important;
}

.tls-uae-flag::before,
.tls-uae-flag::after{display:none!important;content:none!important}

.tls-uae-flag svg{
  display:block!important;
  width:22px!important;
  height:22px!important;
  border-radius:50%!important;
  flex:0 0 22px!important;
}

/* Menu button */
.tls-menu-toggle{
  order:3!important;
  width:48px!important;
  min-width:48px!important;
  height:48px!important;
  min-height:48px!important;
  padding:0!important;
  border-radius:50%!important;
  border:1px solid #dbe8ee!important;
  background:#fff!important;
  color:var(--tls-navy);
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  flex-direction:column!important;
  gap:5px!important;
  box-shadow:0 8px 18px rgba(6,47,61,.055)!important;
  cursor:pointer!important;
}

.tls-menu-toggle:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 28px rgba(6,47,61,.12)!important;
}

.tls-menu-toggle>span{
  display:block!important;
  width:21px!important;
  height:2px!important;
  background:var(--tls-navy)!important;
  border-radius:999px!important;
  margin:0!important;
  transform:none!important;
  opacity:1!important;
}

.tls-menu-toggle[aria-expanded="true"]>span:nth-child(1){transform:translateY(7px) rotate(45deg)!important}
.tls-menu-toggle[aria-expanded="true"]>span:nth-child(2){opacity:0!important}
.tls-menu-toggle[aria-expanded="true"]>span:nth-child(3){transform:translateY(-7px) rotate(-45deg)!important}

/* ------------------------------
   Drawer
------------------------------ */
.tls-mobile-drawer[hidden]{display:none!important}

.tls-mobile-overlay,
.tls-drawer-backdrop{
  position:fixed;
  inset:0;
  background:rgba(6,47,61,.44);
  z-index:1000;
  backdrop-filter:blur(4px);
  opacity:0;
  visibility:hidden;
  transition:.18s ease;
}

.tls-mobile-open .tls-mobile-overlay,
.tls-mobile-open .tls-drawer-backdrop{
  opacity:1;
  visibility:visible;
}

.tls-mobile-drawer{
  position:fixed;
  inset:0 0 0 auto;
  width:min(420px,92vw);
  z-index:1001;
  background:#fff;
  box-shadow:-20px 0 70px rgba(6,47,61,.22);
  padding:22px;
  overflow:auto;
  transform:translateX(105%);
  transition:transform .22s ease;
}

[dir="rtl"] .tls-mobile-drawer{
  inset:0 auto 0 0;
  box-shadow:20px 0 70px rgba(6,47,61,.22);
  transform:translateX(-105%);
}

.tls-mobile-open .tls-mobile-drawer,
[dir="rtl"] .tls-mobile-open .tls-mobile-drawer{
  transform:translateX(0);
}

.tls-drawer-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:18px;
}

.tls-drawer-logo .custom-logo{max-height:58px}

.tls-drawer-close{
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid var(--tls-border);
  background:var(--tls-soft);
  font-size:24px;
  line-height:1;
  color:var(--tls-navy);
}

.tls-drawer-book{
  display:flex;
  align-items:center;
  justify-content:center;
  margin:16px 0;
  padding:14px 18px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--tls-orange),#ffbd35);
  color:#101820;
  font-weight:900;
  text-decoration:none;
}

.tls-drawer-menu,
.tls-drawer-menu ul,
.tls-mobile-nav .tls-primary-menu,
.tls-mobile-nav .tls-primary-menu ul{
  list-style:none;
  margin:0;
  padding:0;
}

.tls-drawer-menu a,
.tls-mobile-nav .tls-menu-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:13px 4px;
  border-bottom:1px solid var(--tls-border);
  color:var(--tls-text);
  font-weight:800;
  text-decoration:none;
}

.tls-drawer-menu ul,
.tls-mobile-nav .tls-submenu{
  display:none;
  padding-inline-start:18px;
  background:#fbfdfe;
  border-radius:14px;
}

.tls-drawer-menu .is-open>ul,
.tls-mobile-nav .is-open>.tls-submenu{
  display:block;
}

.tls-caret{
  width:7px;
  height:7px;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:rotate(45deg);
  margin-inline-start:8px;
  margin-top:-3px;
  flex:0 0 7px;
}

/* ------------------------------
   Layout Shells
------------------------------ */
.tls-main,
.tls-main-content{
  min-height:54vh;
  padding:44px 16px 80px;
  background:linear-gradient(180deg,#fff,var(--tls-ivory));
}

.tls-page-main,
.tls-single-main{
  width:100%;
}

.tls-content-shell{
  width:min(1180px,calc(100% - 32px));
  margin:32px auto;
  background:#fff;
  border:1px solid rgba(11,47,58,.08);
  border-radius:28px;
  box-shadow:0 18px 60px rgba(15,23,42,.06);
  padding:clamp(22px,4vw,46px);
}

.tls-page-header,
.tls-single-header{
  text-align:center;
  margin-bottom:26px;
  padding-bottom:22px;
  border-bottom:1px solid rgba(11,47,58,.08);
}

.tls-breadcrumbs{
  font-size:14px;
  color:#667085;
  margin-bottom:14px;
}

.tls-breadcrumbs a{color:#667085}

.tls-page-title,
.tls-single-title,
h1{
  margin:0;
  color:#0b2f3a;
  font-size:clamp(30px,4vw,56px);
  line-height:1.25;
  font-weight:950;
  letter-spacing:-.02em;
}

.tls-page-meta,
.tls-post-meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:9px;
  margin-top:12px;
  color:#667085;
  font-size:14px;
}

.tls-post-meta a{
  color:#0e6373;
  font-weight:700;
  text-decoration:none;
}

.tls-page-excerpt,
.tls-single-excerpt{
  margin:18px auto 0;
  max-width:880px;
  color:#475467;
  font-size:18px;
  line-height:1.9;
}

.tls-featured-image{
  margin:28px auto;
  max-width:980px;
  border-radius:24px;
  overflow:hidden;
  background:#eaf7f8;
  box-shadow:0 18px 50px rgba(15,23,42,.08);
}

.tls-featured-image img{
  display:block;
  width:100%;
  height:auto!important;
  object-fit:cover;
}

/* ------------------------------
   Content Typography
------------------------------ */
.tls-entry-content,
.tls-article-content{
  color:#253241;
  font-size:18px;
  line-height:2;
}

.tls-entry-content>*:first-child{margin-top:0}
.tls-entry-content>*:last-child{margin-bottom:0}

.tls-entry-content p{margin:0 0 18px}

.tls-entry-content h2,
.tls-article-content h2{
  margin-top:44px;
  margin-bottom:16px;
  color:#0b2f3a;
  font-size:clamp(26px,3vw,38px);
  line-height:1.35;
  font-weight:900;
  letter-spacing:-.025em;
  scroll-margin-top:120px;
}

.tls-entry-content h3,
.tls-article-content h3{
  margin-top:30px;
  margin-bottom:12px;
  color:#0e6373;
  font-size:clamp(22px,2.3vw,30px);
  line-height:1.4;
  font-weight:850;
  letter-spacing:-.02em;
  scroll-margin-top:120px;
}

.tls-entry-content h4{
  color:#0b2f3a;
  font-size:21px;
  line-height:1.35;
  font-weight:900;
  margin:1.4em 0 .7em;
}

.tls-entry-content ul,
.tls-entry-content ol{
  margin:0 0 22px;
  padding-inline-start:26px;
}

.tls-entry-content li{margin-bottom:8px}

.tls-entry-content strong{
  color:#0b2f3a;
  font-weight:900;
}

.tls-entry-content blockquote{
  margin:1.4em 0;
  padding:22px 24px;
  border-inline-start:5px solid var(--tls-gold);
  background:var(--tls-soft);
  border-radius:18px;
  color:var(--tls-navy);
  font-weight:700;
}

.tls-entry-content img{
  max-width:100%;
  height:auto!important;
  border-radius:18px;
  box-shadow:0 10px 30px rgba(6,47,61,.08);
}

.tls-entry-content table{
  width:100%;
  max-width:100%;
  border-collapse:collapse;
  margin:26px 0;
  overflow-x:auto;
  display:block;
  border-radius:18px;
  background:#fff;
}

.tls-entry-content th,
.tls-entry-content td{
  border:1px solid #e6eef2;
  padding:14px;
  text-align:start;
}

.tls-entry-content th{
  background:#eaf7f8;
  color:#0b2f3a;
  font-weight:850;
}

.tls-entry-content .alignwide{
  max-width:calc(var(--tls-container) + 120px);
  margin-inline:auto;
}

.tls-entry-content .alignfull{
  width:100vw;
  max-width:100vw;
  margin-inline:calc(50% - 50vw);
}

.tls-entry-content .wp-block-button__link,
.tls-entry-content a.button,
.tls-entry-content .button{
  border-radius:999px;
  background:linear-gradient(135deg,var(--tls-teal),var(--tls-navy));
  color:#fff!important;
  padding:13px 24px;
  font-weight:900;
  text-decoration:none;
  box-shadow:var(--tls-shadow-soft);
}

/* ------------------------------
   Table of Contents - closed by default with details/summary
------------------------------ */
.tls-toc{
  margin:26px 0 34px;
  border-radius:22px;
  background:linear-gradient(135deg,#eef9fb,#fff);
  border:1px solid rgba(14,99,115,.16);
  box-shadow:0 12px 34px rgba(14,99,115,.08);
  overflow:hidden;
}

.tls-toc summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  cursor:pointer;
  list-style:none;
  padding:18px 22px;
  color:#0b2f3a;
  font-size:20px;
  font-weight:950;
}

.tls-toc summary::-webkit-details-marker{display:none}

.tls-toc summary b{
  width:32px;
  height:32px;
  border-radius:50%;
  background:#0e6373;
  position:relative;
  flex:0 0 auto;
}

.tls-toc summary b::before,
.tls-toc summary b::after{
  content:"";
  position:absolute;
  left:9px;
  right:9px;
  top:15px;
  height:2px;
  background:#fff;
  border-radius:5px;
}

.tls-toc summary b::after{
  transform:rotate(90deg);
  transition:.2s ease;
}

.tls-toc[open] summary b::after{transform:rotate(0)}

.tls-toc-list{
  margin:0;
  padding:0 22px 22px 44px;
  display:grid;
  gap:9px;
}

.rtl .tls-toc-list,
html[dir="rtl"] .tls-toc-list{
  padding:0 44px 22px 22px;
}

.tls-toc-list a{
  color:#0e6373;
  text-decoration:none;
  font-weight:750;
}

.tls-toc-list a:hover{color:#f5a400}

.tls-toc-subitem{
  margin-inline-start:18px;
  font-size:95%;
  opacity:.92;
}

/* ------------------------------
   Ratings
------------------------------ */
.tls-rating-box{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:22px;
  align-items:center;
  margin:24px 0 30px;
  padding:22px;
  border:1px solid rgba(14,99,115,.16);
  border-radius:24px;
  background:linear-gradient(135deg,#fff,#fbfaf7);
  box-shadow:0 14px 42px rgba(15,23,42,.06);
}

.tls-rating-summary{
  display:grid;
  gap:4px;
}

.tls-rating-summary strong{
  font-size:52px;
  line-height:1;
  color:#0b2f3a;
}

.tls-stars{
  letter-spacing:2px;
  color:#ffc400;
  font-size:26px;
}

.tls-rating-summary small{color:#667085}

.tls-rating-form{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:12px;
  justify-content:flex-end;
}

.tls-rating-form>span{
  font-weight:850;
  color:#0b2f3a;
}

.tls-rate-stars{
  direction:ltr;
  display:inline-flex;
  flex-direction:row-reverse;
  gap:2px;
}

.tls-rate-stars input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.tls-rate-stars label{
  cursor:pointer;
  font-size:34px;
  color:#d7dbe0;
  line-height:1;
  transition:.15s ease;
}

.tls-rate-stars label:hover,
.tls-rate-stars label:hover~label,
.tls-rate-stars input:checked~label{color:#ffc400}

.tls-rating-form button,
.tls-copy-link{
  border:0;
  border-radius:999px;
  background:#0b2f3a;
  color:#fff;
  font-weight:900;
  padding:11px 18px;
  cursor:pointer;
}

.tls-rating-form em{
  color:#0e6373;
  font-style:normal;
  font-weight:800;
}

/* ------------------------------
   Sharing
------------------------------ */
.tls-share-box{
  margin:38px 0 34px;
  padding:24px;
  border:1px solid #e6eef2;
  border-radius:24px;
  background:#fff;
  box-shadow:0 14px 38px rgba(15,23,42,.05);
}

.tls-share-box h2{
  margin:0 0 18px;
  color:#0b2f3a;
  font-size:clamp(24px,3vw,34px);
  font-weight:950;
}

.tls-share-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.tls-share-buttons a,
.tls-share-buttons button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:11px 16px;
  border-radius:14px;
  color:#fff;
  text-decoration:none;
  font-weight:850;
  border:0;
  cursor:pointer;
}

.tls-share-buttons .facebook{background:#3b5998}
.tls-share-buttons .whatsapp{background:#25d366}
.tls-share-buttons .telegram{background:#2ca5e0}
.tls-share-buttons .twitter{background:#1da1f2}
.tls-share-buttons .linkedin{background:#0077b5}
.tls-share-buttons .tls-copy-link{background:#0b2f3a}

/* ------------------------------
   Tags / Author / Navigation / Related
------------------------------ */
.tls-single-footer{
  margin-top:34px;
  padding-top:24px;
  border-top:1px solid rgba(11,47,58,.08);
}

.tls-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}

.tls-tags a{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:7px 13px;
  border-radius:999px;
  background:#eaf7f8;
  color:#0e6373;
  text-decoration:none;
  font-size:14px;
  font-weight:800;
}

.tls-tags a:hover{
  background:#0e6373;
  color:#fff;
}

.tls-author-box{
  display:flex;
  gap:16px;
  align-items:center;
  margin-top:24px;
  padding:20px;
  border-radius:22px;
  background:linear-gradient(135deg,#fbfaf7,#fff);
  border:1px solid rgba(11,47,58,.08);
}

.tls-author-avatar img{border-radius:50%}

.tls-author-info strong{
  display:block;
  color:#0b2f3a;
  font-size:18px;
  margin-bottom:6px;
}

.tls-author-info p{
  margin:0;
  color:#667085;
  line-height:1.8;
}

.tls-post-nav{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:30px;
}

.tls-post-nav a{
  display:flex;
  align-items:center;
  min-height:70px;
  padding:16px 18px;
  border-radius:18px;
  background:#fff;
  border:1px solid #e6eef2;
  color:#0b2f3a;
  text-decoration:none;
  font-weight:850;
  box-shadow:0 10px 26px rgba(15,23,42,.05);
}

.tls-post-nav a:hover{
  border-color:rgba(245,164,0,.55);
  box-shadow:0 16px 38px rgba(15,23,42,.08);
}

.tls-post-nav-next{text-align:end}

.tls-related-pages,
.tls-child-pages,
.tls-related-posts{
  margin-top:42px;
  padding-top:30px;
  border-top:1px solid rgba(11,47,58,.08);
}

.tls-section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:18px;
}

.tls-section-head h2,
.tls-child-pages h2,
.tls-related-posts h2{
  margin:0 0 18px;
  color:#0b2f3a;
  font-size:clamp(25px,3vw,36px);
  font-weight:950;
}

.tls-related-page-grid,
.tls-child-grid,
.tls-related-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}

.tls-service-card,
.tls-child-card,
.tls-related-card{
  display:block;
  overflow:hidden;
  border-radius:22px;
  background:#fff;
  border:1px solid #e6eef2;
  text-decoration:none;
  color:#0b2f3a;
  box-shadow:0 12px 34px rgba(15,23,42,.06);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}

.tls-service-card:hover,
.tls-child-card:hover,
.tls-related-card:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 46px rgba(15,23,42,.1);
  border-color:rgba(245,164,0,.55);
}

.tls-service-thumb,
.tls-related-thumb{
  display:block;
  aspect-ratio:16/9;
  background:#eaf7f8;
  overflow:hidden;
}

.tls-service-thumb img,
.tls-related-thumb img{
  width:100%;
  height:100%!important;
  object-fit:cover;
}

.tls-service-card strong,
.tls-related-title,
.tls-child-card span{
  display:block;
  padding:16px 16px 6px;
  font-size:17px;
  font-weight:950;
  line-height:1.5;
}

.tls-service-card small,
.tls-related-date{
  display:block;
  padding:0 16px 16px;
  color:#667085;
  font-size:13px;
}

.tls-child-card{
  min-height:78px;
  padding:16px 18px;
  display:flex;
  align-items:center;
}

.tls-child-card span{padding:0}

/* ------------------------------
   Footer
------------------------------ */
.tls-site-footer{
  background:#fff;
  border-top:1px solid var(--tls-border);
  padding:42px 16px calc(34px + var(--tls-offer-h));
  contain:layout paint;
  min-height:330px;
}

.tls-footer-inner{
  max-width:var(--tls-container);
  margin:0 auto;
  text-align:center;
}

.tls-footer-top{
  max-width:var(--tls-container);
  margin:0 auto 26px;
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:28px;
  align-items:start;
  border-bottom:1px solid var(--tls-border);
  padding-bottom:26px;
}

.tls-footer-help h2{
  margin:0 0 6px;
  color:var(--tls-navy);
  font-size:24px;
  font-weight:950;
  line-height:1.2;
}

.tls-footer-help p{
  margin:0;
  color:var(--tls-muted);
}

.tls-contact-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:22px;
}

.tls-contact-grid a,
.tls-footer-actions a{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:58px;
  padding:12px 14px;
  border-radius:16px;
  background:var(--tls-soft);
  color:var(--tls-text);
  font-weight:850;
  border:1px solid var(--tls-border);
  text-decoration:none;
}

.tls-contact-grid a:hover,
.tls-footer-actions a:hover{
  background:var(--tls-aqua);
  text-decoration:none;
}

.tls-footer-services{
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
  min-height:48px;
}

.tls-service-chips,
.tls-footer-chips{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
}

.tls-service-chips a,
.tls-footer-chips a{
  display:inline-flex;
  padding:8px 14px;
  border-radius:999px;
  background:var(--tls-soft);
  color:var(--tls-muted);
  font-weight:750;
  font-size:14px;
  text-decoration:none;
}

.tls-footer-bottom{
  max-width:var(--tls-container);
  margin:0 auto;
  text-align:center;
  display:grid;
  gap:17px;
  justify-items:center;
  align-items:center;
}

.tls-footer-logo{
  display:flex;
  justify-content:center;
  width:100%;
  margin-bottom:0;
}

.tls-footer-logo img,
.tls-footer-logo .custom-logo{
  display:block;
  margin-inline:auto;
  max-height:70px;
  width:auto;
}

.tls-footer-nav{width:100%}

.tls-footer-menu{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:10px 16px;
  margin:0;
  padding:0;
  list-style:none;
}

.tls-footer-menu a{
  color:var(--tls-muted);
  font-weight:650;
  font-size:14px;
  text-decoration:none;
}

.tls-footer-menu a:hover{color:var(--tls-teal)}

.tls-footer-language{
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:40px;
}

.tls-socials,
.tls-social-links{
  display:flex;
  justify-content:center;
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
}

.tls-socials a,
.tls-social-links a{
  width:42px;
  height:42px;
  border-radius:50%;
  background:var(--tls-soft);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--tls-teal);
  font-weight:900;
  text-decoration:none;
}

.tls-copyright{
  color:#8a97a5;
  font-size:13px;
  margin:0;
  text-align:center;
}

/* ------------------------------
   Bottom offer banner - fixed and centered
------------------------------ */
.tls-floating-offer,
.tls-offer-bar{
  position:fixed!important;
  left:0!important;
  right:0!important;
  bottom:0!important;
  width:100%!important;
  max-width:100%!important;
  min-height:var(--tls-offer-h)!important;
  z-index:9998!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  padding:8px 48px!important;
  margin:0!important;
  background:linear-gradient(90deg,#ffe987,#f5a400)!important;
  color:#111!important;
  font-size:13px!important;
  line-height:1.45!important;
  text-align:center!important;
  font-weight:750!important;
  box-shadow:0 -8px 24px rgba(15,23,42,.12)!important;
  transform:none!important;
  direction:inherit!important;
}

.tls-floating-offer[hidden],
.tls-offer-bar[hidden]{display:none!important}

.tls-floating-offer span,
.tls-floating-offer p,
.tls-floating-offer a,
.tls-offer-bar span,
.tls-offer-bar p,
.tls-offer-bar a{
  max-width:100%;
  margin:0;
  color:inherit;
  white-space:normal;
}

.tls-floating-offer .tls-offer-close,
.tls-offer-close{
  position:absolute!important;
  inset-inline-start:10px!important;
  inset-inline-end:auto!important;
  top:50%!important;
  transform:translateY(-50%)!important;
  width:24px!important;
  height:24px!important;
  border-radius:999px!important;
  border:0!important;
  background:rgba(255,255,255,.75)!important;
  color:#111!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  cursor:pointer!important;
  font-weight:900!important;
  padding:0!important;
}

.tls-offer-icon{display:inline-flex}

/* ------------------------------
   Sticky CTA above offer banner
------------------------------ */
.tls-sticky-cta,
.tls-mobile-bottom-bar,
.tls-fixed-actions{
  position:fixed!important;
  left:50%!important;
  bottom:calc(var(--tls-offer-h) + 12px)!important;
  transform:translateX(-50%)!important;
  z-index:99990!important;
  display:flex!important;
  gap:8px!important;
  align-items:center!important;
  justify-content:center!important;
  padding:8px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.90)!important;
  backdrop-filter:blur(14px)!important;
  -webkit-backdrop-filter:blur(14px)!important;
  box-shadow:0 10px 35px rgba(15,23,42,.18)!important;
  border:1px solid rgba(11,47,58,.08)!important;
  width:auto!important;
  max-width:calc(100vw - 22px)!important;
}

.tls-sticky-cta a,
.tls-mobile-bottom-bar a,
.tls-fixed-actions a{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:44px!important;
  padding:0 20px!important;
  border-radius:999px!important;
  text-decoration:none!important;
  font-weight:950!important;
  white-space:nowrap!important;
  color:#fff!important;
}

.tls-cta-call{background:#0b2f3a!important}
.tls-cta-whatsapp{background:#25d366!important}
.tls-cta-book{background:#f5a400!important;color:#0b2f3a!important}

.tls-floating-call,
.tls-floating-whatsapp{
  bottom:calc(var(--tls-offer-h) + 82px + env(safe-area-inset-bottom,0px))!important;
}

/* ------------------------------
   WordPress defaults
------------------------------ */
.wp-caption{max-width:100%}
.wp-caption-text{font-size:13px;color:var(--tls-muted);text-align:center;margin-top:8px}
.aligncenter{margin-inline:auto}
.alignleft{float:left;margin:0 1.2em 1em 0}
.alignright{float:right;margin:0 0 1em 1.2em}
.sticky{}
.gallery-caption{}
.bypostauthor{}

/* ------------------------------
   Responsive
------------------------------ */
@media(max-width:1024px){
  .tls-related-page-grid,
  .tls-child-grid,
  .tls-related-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .tls-rating-box{grid-template-columns:1fr}
  .tls-rating-form{justify-content:flex-start}
}

@media(max-width:900px){
  :root{
    --tls-header-h:72px;
  }

  .tls-main,
  .tls-main-content{
    padding:24px 10px 80px;
  }

  .tls-site-footer{
    min-height:520px;
    padding-bottom:calc(var(--tls-offer-h) + 26px);
  }

  .tls-footer-top{
    grid-template-columns:1fr;
    text-align:center;
  }

  .tls-footer-services,
  .tls-service-chips,
  .tls-footer-chips{
    justify-content:center;
  }

  .tls-contact-grid{grid-template-columns:1fr}

  .tls-offer-icon{display:none}
}

@media(max-width:760px){
  .tls-header-inner{
    width:min(100% - 20px,1180px)!important;
    min-height:72px!important;
    height:auto!important;
    padding-block:10px!important;
    gap:7px!important;
  }

  .tls-brand-wrap{
    flex:0 1 auto!important;
    max-width:26vw!important;
    min-width:0!important;
  }

  .tls-brand-wrap img,
  .tls-brand-wrap .custom-logo{
    max-width:96px!important;
    max-height:40px!important;
  }

  .tls-text-logo{
    max-width:96px!important;
    font-size:16px!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }

  .tls-header-spacer{
    flex:1 1 auto!important;
    min-width:0!important;
  }

  .tls-header-actions{
    gap:6px!important;
    min-width:0!important;
  }

  .tls-book-btn,
  .tls-site-header .tls-book-btn{
    width:auto!important;
    min-width:88px!important;
    max-width:none!important;
    height:40px!important;
    min-height:40px!important;
    padding:0 10px!important;
    font-size:12px!important;
    flex:0 0 auto!important;
  }

  .tls-book-btn .tls-book-icon{
    width:14px!important;
    height:14px!important;
    flex:0 0 14px!important;
    font-size:9px!important;
  }

  .tls-language-switcher a,
  .tls-language-switcher.tls-lang-disabled,
  .tls-lang-switcher a{
    height:40px!important;
    min-height:40px!important;
    padding:0 7px!important;
    gap:4px!important;
    font-size:11px!important;
  }

  .tls-language-switcher .tls-lang-name,
  .tls-lang-name{
    max-width:54px!important;
    font-size:11px!important;
  }

  .tls-uae-flag,
  .tls-language-switcher .tls-uae-flag,
  .tls-lang-switcher .tls-uae-flag,
  .tls-uae-flag svg{
    width:20px!important;
    height:20px!important;
    flex-basis:20px!important;
  }

  .tls-menu-toggle,
  .tls-site-header .tls-menu-toggle{
    width:40px!important;
    min-width:40px!important;
    height:40px!important;
    min-height:40px!important;
    flex:0 0 40px!important;
  }

  .tls-menu-toggle>span{width:19px!important}

  .tls-content-shell{
    width:min(100% - 20px,1180px);
    margin:18px auto;
    border-radius:20px;
    padding:20px;
  }

  .tls-page-title,
  .tls-single-title,
  h1{font-size:30px}

  .tls-entry-content,
  .tls-article-content{
    font-size:17px;
    line-height:1.9;
  }

  .tls-toc{
    border-radius:18px;
  }

  .tls-rating-box{
    padding:18px;
    border-radius:20px;
  }

  .tls-rating-summary strong{font-size:42px}
  .tls-rate-stars label{font-size:30px}

  .tls-related-page-grid,
  .tls-child-grid,
  .tls-related-grid{
    grid-template-columns:1fr;
  }

  .tls-share-buttons a,
  .tls-share-buttons button{
    flex:1 1 calc(50% - 8px);
  }

  .tls-author-box{
    align-items:flex-start;
  }

  .tls-post-nav{
    grid-template-columns:1fr;
  }

  .tls-post-nav-next{
    text-align:start;
  }

  .tls-floating-offer,
  .tls-offer-bar{
    min-height:42px!important;
    padding:8px 38px!important;
    font-size:12px!important;
    line-height:1.35!important;
  }

  .tls-sticky-cta,
  .tls-mobile-bottom-bar,
  .tls-fixed-actions{
    bottom:calc(var(--tls-offer-h) + 10px)!important;
    width:calc(100% - 22px)!important;
    max-width:520px!important;
  }

  .tls-sticky-cta a,
  .tls-mobile-bottom-bar a,
  .tls-fixed-actions a{
    flex:1;
    min-height:42px!important;
    padding:0 8px!important;
    font-size:14px!important;
  }
}

@media(max-width:430px){
  .tls-header-inner{
    width:calc(100% - 10px)!important;
    gap:5px!important;
  }

  .tls-brand-wrap{max-width:20vw!important}

  .tls-brand-wrap img,
  .tls-brand-wrap .custom-logo{
    max-width:72px!important;
    max-height:34px!important;
  }

  .tls-text-logo{
    max-width:72px!important;
    font-size:14px!important;
  }

  .tls-header-actions{gap:5px!important}

  .tls-book-btn,
  .tls-site-header .tls-book-btn{
    min-width:80px!important;
    width:auto!important;
    height:38px!important;
    min-height:38px!important;
    padding:0 9px!important;
    font-size:11px!important;
  }

  .tls-book-btn .tls-book-icon{display:none!important}

  .tls-language-switcher a,
  .tls-language-switcher.tls-lang-disabled,
  .tls-lang-switcher a{
    height:38px!important;
    min-height:38px!important;
    padding:0 5px!important;
    font-size:10.5px!important;
  }

  .tls-language-switcher .tls-lang-name,
  .tls-lang-name{
    max-width:44px!important;
    font-size:10.5px!important;
  }

  .tls-uae-flag,
  .tls-language-switcher .tls-uae-flag,
  .tls-lang-switcher .tls-uae-flag,
  .tls-uae-flag svg{
    width:18px!important;
    height:18px!important;
    flex-basis:18px!important;
  }

  .tls-menu-toggle,
  .tls-site-header .tls-menu-toggle{
    width:38px!important;
    min-width:38px!important;
    height:38px!important;
    min-height:38px!important;
    flex-basis:38px!important;
  }

  .tls-toc summary{
    font-size:18px;
    padding:16px 18px;
  }

  .tls-toc-list{
    padding:0 18px 18px 36px;
  }

  .rtl .tls-toc-list,
  html[dir="rtl"] .tls-toc-list{
    padding:0 36px 18px 18px;
  }
}

@media(max-width:380px){
  .tls-sticky-cta a,
  .tls-mobile-bottom-bar a,
  .tls-fixed-actions a{
    font-size:13px!important;
  }

  .tls-share-buttons a,
  .tls-share-buttons button{
    flex-basis:100%;
  }
}

@media(max-width:360px){
  .tls-brand-wrap{max-width:16vw!important}

  .tls-brand-wrap img,
  .tls-brand-wrap .custom-logo{max-width:54px!important}

  .tls-book-btn,
  .tls-site-header .tls-book-btn{
    min-width:76px!important;
    padding:0 7px!important;
    font-size:10.5px!important;
  }

  .tls-book-btn .tls-book-text,
  .tls-book-btn span:not(.tls-book-icon){font-size:10.5px!important}

  .tls-language-switcher .tls-lang-name,
  .tls-lang-name{max-width:34px!important}
}

/* ProHClean final overflow + bottom banner fix
   Put this at the VERY END of style.css, after all previous rules. */

html,
body {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: clip !important;
}
@supports not (overflow: clip) {
  html,
  body { overflow-x: hidden !important; }
}

*, *::before, *::after { box-sizing: border-box !important; }

body {
  position: relative;
  min-width: 0 !important;
  padding-bottom: calc(var(--tls-offer-h, 44px) + 78px + env(safe-area-inset-bottom, 0px)) !important;
}

#page,
.site,
.tls-site,
.tls-main,
.tls-main-content,
.tls-page-main,
.tls-single-main,
.tls-content-shell,
.tls-entry-content,
.tls-article-content,
.wp-site-blocks,
.elementor,
.elementor-section,
.elementor-container,
.elementor-widget-wrap {
  max-width: 100% !important;
}

/* Common real cause: alignfull / 100vw blocks inside a constrained wrapper */
.tls-entry-content .alignfull,
.tls-article-content .alignfull,
.entry-content .alignfull,
.wp-block-cover.alignfull,
.wp-block-group.alignfull {
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-inline: 0 !important;
}

/* Media must never create horizontal overflow */
img, video, iframe, object, embed, canvas, svg {
  max-width: 100% !important;
  height: auto;
}

.tls-entry-content table,
.tls-article-content table,
.entry-content table {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: auto !important;
}

/* Bottom offer: never use 100vw because it includes scrollbar width */
.tls-floating-offer,
.tls-offer-bar {
  position: fixed !important;
  inset-inline-start: 0 !important;
  inset-inline-end: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  min-height: var(--tls-offer-h, 44px) !important;
  margin: 0 !important;
  padding: 8px 48px !important;
  transform: none !important;
  z-index: 9998 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  overflow: hidden !important;
  background: linear-gradient(90deg, #ffe987, #f5a400) !important;
  color: #111 !important;
  line-height: 1.35 !important;
}

.tls-floating-offer > *,
.tls-offer-bar > * {
  max-width: 100% !important;
  min-width: 0 !important;
  overflow-wrap: anywhere !important;
  white-space: normal !important;
}

.tls-floating-offer .tls-offer-close,
.tls-offer-bar .tls-offer-close,
.tls-offer-close {
  position: absolute !important;
  inset-inline-end: 10px !important;
  inset-inline-start: auto !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 26px !important;
  height: 26px !important;
  min-width: 26px !important;
  min-height: 26px !important;
  padding: 0 !important;
}

/* Keep CTA above the offer and centered */
.tls-sticky-cta,
.tls-fixed-actions {
  position: fixed !important;
  left: 50% !important;
  right: auto !important;
  bottom: calc(var(--tls-offer-h, 44px) + 12px + env(safe-area-inset-bottom, 0px)) !important;
  transform: translateX(-50%) !important;
  max-width: min(560px, calc(100% - 20px)) !important;
  width: auto !important;
  z-index: 9999 !important;
}

.tls-floating-call,
.tls-floating-whatsapp {
  right: 16px !important;
  left: auto !important;
  bottom: calc(var(--tls-offer-h, 44px) + 76px + env(safe-area-inset-bottom, 0px)) !important;
}

@media (max-width: 768px) {
  :root { --tls-offer-h: 44px; }
  body { padding-bottom: calc(var(--tls-offer-h, 44px) + 92px + env(safe-area-inset-bottom, 0px)) !important; }
  .tls-floating-offer,
  .tls-offer-bar {
    padding: 8px 38px !important;
    font-size: 12px !important;
  }
  .tls-sticky-cta,
  .tls-fixed-actions {
    width: calc(100% - 20px) !important;
    bottom: calc(var(--tls-offer-h, 44px) + 10px + env(safe-area-inset-bottom, 0px)) !important;
  }
}
