:root{
  /* Minimal / light premium palette — one restrained accent */
  --ink:#0b1220;
  --ink-2:#1c2632;
  --body:#48515f;
  --muted:#8a93a1;
  --line:#e8ebf0;
  --line-2:#f0f2f6;
  --bg:#ffffff;
  --bg-soft:#f7f9fc;
  --accent:#1f6fd6;
  --accent-dark:#1559b0;
  --accent-soft:#eaf2fd;

  --radius:18px;
  --radius-sm:12px;
  --shadow-xs:0 1px 2px rgba(16,32,60,.05);
  --shadow:0 14px 40px -22px rgba(16,40,80,.30);
  --shadow-lg:0 40px 80px -36px rgba(16,40,80,.40);
  --container:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--body);background:var(--bg);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
body.rtl{font-family:'Cairo','Inter',system-ui,sans-serif}
a{text-decoration:none;color:var(--accent);transition:color .2s}
img{max-width:100%}
h1,h2,h3,h4,h5,h6{font-family:'Sora','Inter',sans-serif;font-weight:700;color:var(--ink);letter-spacing:-.025em;line-height:1.1}
.text-primary{color:var(--accent)!important}
.container{max-width:var(--container)}
.accent{color:var(--accent)}

/* ---------- Top bar ---------- */
/* position+z-index so the language dropdown is never hidden behind the sticky navbar */
.topbar{position:relative;z-index:1031;background:#fff;border-bottom:1px solid var(--line-2);color:var(--muted);font-size:.82rem;padding:.45rem 0}
.lang-switch .dropdown-menu{z-index:1050}
.topbar a{color:var(--muted)}
.topbar a:hover{color:var(--ink)}
.topbar .wa{color:var(--muted)}
.topbar .wa .bi{color:#1aa251}   /* keep just the icon green as a subtle brand cue */
.topbar .social{font-size:1rem;margin-inline-start:.3rem}
.lang-switch .btn{color:var(--ink-2);border:1px solid var(--line);border-radius:30px;padding:.12rem .7rem;font-size:.8rem;font-weight:600}
.lang-switch .btn:hover{border-color:var(--accent);color:var(--accent)}
.dropdown-menu{border:1px solid var(--line);box-shadow:var(--shadow);border-radius:14px;padding:.4rem}
.dropdown-item{border-radius:9px;padding:.5rem .85rem;font-weight:500;color:var(--ink-2)}
.dropdown-item:hover,.dropdown-item.active{background:var(--accent-soft);color:var(--accent)}

/* ---------- Navbar (clean) ---------- */
.sky-nav{background:rgba(255,255,255,.9);backdrop-filter:saturate(150%) blur(10px);-webkit-backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--line-2);padding:.7rem 0;transition:padding .25s,box-shadow .25s}
.sky-nav.scrolled{box-shadow:var(--shadow-xs);border-bottom-color:var(--line);padding:.45rem 0}
.navbar-brand img{transition:height .25s}
.sky-nav .nav-link{color:var(--ink-2);font-weight:600;font-size:.95rem;padding:.5rem .9rem;border-radius:8px;transition:color .2s}
.sky-nav .nav-link:hover,.sky-nav .nav-link.active{color:var(--accent)}
.sky-nav .dropdown-menu{margin-top:.5rem}

/* ---------- Buttons ---------- */
.btn{border-radius:11px;font-weight:600;letter-spacing:.1px;transition:.2s;padding:.7rem 1.4rem}
.btn-lg{padding:.85rem 1.8rem;font-size:1.02rem}
.btn-sky{background:var(--accent);border:0;color:#fff}
.btn-sky:hover{background:var(--accent-dark);color:#fff;transform:translateY(-1px)}
.btn-dark-min{background:var(--ink);border:0;color:#fff}
.btn-dark-min:hover{background:#000;color:#fff;transform:translateY(-1px)}
.btn-outline-sky{border:1.5px solid var(--line);color:var(--ink);background:#fff}
.btn-outline-sky:hover{border-color:var(--ink);color:var(--ink);background:#fff}
.btn .bi{transition:transform .2s}
.btn:hover .bi-arrow-right{transform:translateX(4px)}
body.rtl .btn:hover .bi-arrow-right{transform:translateX(-4px)}

/* ---------- Hero (bold static, light) ---------- */
.hero-min{position:relative;padding:6rem 0 5rem;overflow:hidden;background:#fff}
.hero-min::before{content:"";position:absolute;top:-20%;inset-inline-end:-10%;width:55%;height:120%;
  background:radial-gradient(closest-side,var(--accent-soft),transparent 70%);opacity:.9;z-index:0}
.hero-min .container{position:relative;z-index:1}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-family:'Sora',sans-serif;font-weight:600;font-size:.82rem;letter-spacing:.04em;color:var(--accent);background:var(--accent-soft);padding:.35rem .85rem;border-radius:30px;margin-bottom:1.4rem}
.hero-min h1{font-size:clamp(2.4rem,5.4vw,4.4rem);font-weight:800;color:var(--ink);margin:0 0 1.3rem;letter-spacing:-.035em}
.hero-min h1 .accent{color:var(--accent)}
.hero-min .lead{font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--body);max-width:52ch;margin-bottom:2rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem}
.hero-visual{position:relative}
.hero-visual .frame{border-radius:24px;overflow:hidden;background:var(--bg-soft);border:1px solid var(--line);box-shadow:var(--shadow-lg)}
.hero-visual .frame img{width:100%;height:420px;object-fit:cover;display:block}
@media(max-width:991px){.hero-min{padding:3.5rem 0}.hero-visual{margin-top:2.5rem}.hero-visual .frame img{height:300px}}

/* hero stats */
.hero-stats{display:flex;flex-wrap:wrap;gap:2.4rem;margin-top:2.6rem;padding-top:2rem;border-top:1px solid var(--line)}
.hero-stats .num{font-family:'Sora',sans-serif;font-weight:800;font-size:1.8rem;color:var(--ink);line-height:1}
.hero-stats .lbl{font-size:.85rem;color:var(--muted);margin-top:.25rem}

/* ---------- Slider hero (clean / minimal) ---------- */
/* Banner images are wide (~3.62:1). Show them at their natural ratio so the
   composition is never cropped; only crop-to-centre on small phones. */
/* ---------- Home hero: rotating slider photos behind a modern headline; finder floats over ---------- */
.home-hero{position:relative;overflow:hidden;padding:3.4rem 0 4.6rem;background:#0b1f3a;isolation:isolate}
.home-hero .hero-bg{position:absolute;inset:0;z-index:0}
.home-hero .hero-bg .carousel,.home-hero .hero-bg .carousel-inner,.home-hero .hero-bg .carousel-item{height:100%}
/* smooth, slow cross-fade between hero slides (no abrupt cut) */
.home-hero .hero-bg.carousel-fade .carousel-item,.home-hero .hero-bg .carousel-item{transition:opacity 1.1s ease-in-out}
.home-hero .hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center;filter:brightness(.86) saturate(.8)}
/* gentle Ken-Burns zoom on the active slide for a living, animated backdrop */
.home-hero .hero-bg .carousel-item.active img{animation:heroKen 9s ease-out both}
@keyframes heroKen{from{transform:scale(1.005)}to{transform:scale(1.07)}}
@media(prefers-reduced-motion:reduce){.home-hero .hero-bg .carousel-item.active img{animation:none}}
.home-hero .hero-overlay{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(100deg,rgba(7,16,32,.9) 0%,rgba(9,24,48,.82) 45%,rgba(11,32,64,.68) 100%)}
.home-hero .hero-content{position:relative;z-index:2}
.home-hero .hero-eyebrow{background:rgba(255,255,255,.14);color:#eaf2fd;border:1px solid rgba(255,255,255,.2);margin-bottom:.85rem}
.home-hero h1{color:#fff;font-size:clamp(1.9rem,3.7vw,3rem);letter-spacing:-.03em;margin:0 0 .8rem;max-width:19ch;text-shadow:0 2px 18px rgba(0,0,0,.3)}
.home-hero .hero-lead{color:rgba(255,255,255,.9);font-size:clamp(1.02rem,1.4vw,1.18rem);max-width:46ch;margin:0 0 1.45rem;text-shadow:0 1px 10px rgba(0,0,0,.35)}
.home-hero .hero-actions{display:flex;flex-wrap:wrap;gap:.7rem}
.home-hero .btn-light-hero{background:#fff;color:var(--accent);border:0;font-weight:700}
.home-hero .btn-light-hero:hover{background:#eaf2fd;color:var(--accent-dark);transform:translateY(-1px)}
.home-hero .btn-ghost-hero{background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.5);color:#fff}
.home-hero .btn-ghost-hero:hover{background:rgba(255,255,255,.18);color:#fff;border-color:#fff}
@media(max-width:767px){
  .home-hero{padding:3rem 0 4.4rem}
  /* the slide banners are busy; on a narrow crop mute them harder so the text reads clean */
  .home-hero .hero-bg img{filter:brightness(.66) saturate(.7)}
  .home-hero .hero-overlay{background:linear-gradient(175deg,rgba(6,13,27,.95) 0%,rgba(8,20,42,.92) 55%,rgba(10,28,56,.88) 100%)}
}

.sky-slider{position:relative;background:var(--bg-soft)}
.sky-slider .carousel-item{position:relative}
.sky-slider .carousel-item img{width:100%;height:auto;display:block;aspect-ratio:2839/784}
@media(max-width:767px){
  .sky-slider .carousel-item img{height:clamp(140px,40vw,200px);aspect-ratio:auto;object-fit:cover;object-position:center}
}
/* keep indicators clear of the floating finder card that overlaps the slider */
.sky-slider .carousel-indicators{margin-bottom:4.5rem}
@media(max-width:991px){.sky-slider .carousel-indicators{margin-bottom:3rem}}
@media(max-width:767px){.sky-slider .carousel-indicators{margin-bottom:.8rem}}
.sky-slider .carousel-indicators [data-bs-target]{width:9px;height:9px;border-radius:50%;border:0;background:rgba(11,18,32,.3);opacity:1;transition:.25s}
.sky-slider .carousel-indicators .active{width:28px;border-radius:9px;background:var(--accent)}
.sky-slider .carousel-control-prev,.sky-slider .carousel-control-next{width:5%;opacity:.55}
.sky-slider .carousel-control-prev:hover,.sky-slider .carousel-control-next:hover{opacity:1}
.sky-slider .carousel-control-prev-icon,.sky-slider .carousel-control-next-icon{filter:invert(1)}

/* ---------- Product finder (floating card) ---------- */
.finder-wrap{position:relative;z-index:5}
.finder-card{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-lg);padding:1.6rem 1.7rem}
.finder-card.overlap{margin-top:-46px}
.finder-title{font-family:'Sora',sans-serif;font-weight:700;font-size:1.02rem;color:var(--ink);display:flex;align-items:center;gap:.55rem;margin-bottom:1.1rem}
.finder-title .bi{color:var(--accent)}
.finder-card .form-select{height:54px;border-radius:13px;border:1.5px solid var(--line);background-color:var(--bg-soft);font-weight:500;color:var(--ink)}
.finder-card .form-select:focus{background-color:#fff;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.finder-card .btn{height:54px;font-size:1rem}
/* Category -> Model -> Find finder */
.finder-select .fs-grid{display:grid;grid-template-columns:1fr 1fr auto;gap:.7rem;align-items:end}
.finder-select .fs-label{display:block;font-size:.8rem;font-weight:600;color:var(--muted);margin-bottom:.35rem}
.finder-select .fs-go .btn{height:54px;white-space:nowrap;padding-inline:1.6rem}
.finder-select select:disabled{opacity:.6;cursor:not-allowed}
/* custom Category dropdown — icons + hierarchy a native <select> can't render */
.cat-dd{position:relative}
.cat-dd-toggle{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;height:54px;border:1.5px solid var(--line);border-radius:13px;background:var(--bg-soft);padding:0 1rem;font-weight:500;color:var(--ink);cursor:pointer;text-align:start}
.cat-dd.open .cat-dd-toggle,.cat-dd-toggle:focus-visible{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);background:#fff;outline:0}
.cat-dd-cur{display:flex;align-items:center;gap:.55rem;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.cat-dd-cur .bi{color:var(--accent);flex:0 0 auto}
.cat-dd-caret{transition:transform .2s;color:var(--muted);flex:0 0 auto}
.cat-dd.open .cat-dd-caret{transform:rotate(180deg)}
.cat-dd-menu{position:absolute;top:calc(100% + .4rem);inset-inline:0;background:#fff;border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow-lg);max-height:336px;overflow:auto;z-index:50;display:none;padding:.4rem}
.cat-dd.open .cat-dd-menu{display:block}
.cat-dd.drop-up .cat-dd-menu{top:auto;bottom:calc(100% + .4rem)}
.cat-dd-head{display:flex;align-items:center;gap:.5rem;padding:.55rem .6rem .3rem;font-family:'Sora','Inter',sans-serif;font-weight:700;font-size:.9rem;color:var(--ink);margin-top:.15rem}
.cat-dd-head .bi{color:var(--accent);font-size:1rem}
.cat-dd-opt{display:flex;align-items:center;gap:.5rem;width:100%;border:0;background:transparent;text-align:start;padding:.5rem .6rem;border-radius:9px;color:var(--ink-2);font-size:.92rem;cursor:pointer;white-space:nowrap;overflow:hidden}
.cat-dd-opt span{overflow:hidden;text-overflow:ellipsis}
.cat-dd-opt .bi{color:var(--muted);font-size:.92rem;flex:0 0 auto}
.cat-dd-opt:hover,.cat-dd-opt.active,.cat-dd-opt.kb{background:var(--accent-soft);color:var(--accent)}
.cat-dd-opt:hover .bi,.cat-dd-opt.active .bi,.cat-dd-opt.kb .bi{color:var(--accent)}
.cat-dd-opt.cat-dd-root{font-weight:600;color:var(--ink)}
@media(max-width:767px){.finder-select .fs-grid{grid-template-columns:1fr;gap:.55rem}.finder-select .fs-go .btn{width:100%}.finder-wrap{padding-bottom:4.5rem}}
@media(max-width:991px){.finder-card.overlap{margin-top:-34px}}
@media(max-width:767px){.finder-card.overlap{margin-top:1.5rem}.finder-card{padding:1.3rem}}

/* search bar (used in finder card + search page) */
.search-bar{display:flex;align-items:center;gap:.6rem;background:var(--bg-soft);border:1.5px solid var(--line);border-radius:14px;padding:.35rem;padding-inline-start:1rem;transition:.2s}
.search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);background:#fff}
.search-bar > .bi{font-size:1.15rem;color:var(--muted);flex:0 0 auto}
.search-bar input{flex:1 1 auto;min-width:0;border:0;background:transparent;outline:0;font-size:1.02rem;color:var(--ink);padding:.55rem 0}
.search-bar .btn{flex:0 0 auto;height:46px;border-radius:11px;padding:.5rem 1.5rem}
.finder-or{position:relative;text-align:center;margin:1rem 0}
.finder-or::before{content:"";position:absolute;top:50%;inset-inline:0;height:1px;background:var(--line)}
.finder-or span{position:relative;background:#fff;padding:0 .9rem;color:var(--muted);font-size:.82rem}
@media(max-width:575px){.search-bar .btn{padding:.5rem 1rem}}

/* live search dropdown */
.live-search{position:relative}
.live-results{position:absolute;top:calc(100% + .5rem);inset-inline:0;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);max-height:60vh;overflow:auto;z-index:40;display:none;padding:.4rem}
.live-results.show{display:block}
.suggest-item{display:flex;align-items:center;gap:.8rem;padding:.6rem .7rem;border-radius:10px;color:var(--ink)}
.suggest-item:hover,.suggest-item.active{background:var(--accent-soft)}
.suggest-item img{width:44px;height:44px;object-fit:contain;border:1px solid var(--line);border-radius:9px;background:#fff;flex:0 0 auto}
.suggest-item .ic{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:9px;background:var(--accent-soft);color:var(--accent);flex:0 0 auto;font-size:1.2rem}
.suggest-item .t{flex:1 1 auto;min-width:0}
.suggest-item .t b{display:block;font-weight:600;font-size:.94rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.suggest-item .t small{color:var(--muted);font-size:.78rem}
.suggest-item > .bi-arrow-right{color:var(--muted);flex:0 0 auto}
.suggest-empty{padding:1rem;text-align:center;color:var(--muted)}

/* ---------- Sections ---------- */
.section{padding:6rem 0}
.section-sm{padding:4rem 0}
.section-soft{background:var(--bg-soft)}
.eyebrow{display:inline-block;font-family:'Sora',sans-serif;font-weight:600;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:.7rem}
.section-title{margin-bottom:3rem}
.section-title h2{font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:700;letter-spacing:-.03em}
.section-title .lead{color:var(--muted);max-width:60ch;margin-top:.6rem;font-size:1.05rem}
.section-title.text-center .lead{margin-inline:auto}

/* ---------- Cards (flat minimal) ---------- */
.cat-card,.prod-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;height:100%;transition:transform .25s ease,box-shadow .25s,border-color .25s;color:var(--ink)}
.cat-card:hover,.prod-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line)}
.cat-card .thumb,.prod-card .thumb{height:200px;display:flex;align-items:center;justify-content:center;padding:1.6rem;background:#fff;overflow:hidden}
.cat-card .thumb img,.prod-card .thumb img{max-height:160px;max-width:100%;object-fit:contain;transition:transform .4s ease}
.cat-card:hover .thumb img,.prod-card:hover .thumb img{transform:scale(1.05)}
.cms-content img,.product-body img{max-width:100%!important;height:auto}
.cms-content table,.product-body table{max-width:100%;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
.cat-card .body,.prod-card .body{padding:1.1rem 1.3rem 1.3rem;border-top:1px solid var(--line-2)}
.cat-card .body h5,.prod-card .body h5{font-size:1rem;font-weight:600;margin:0 0 .35rem;color:var(--ink)}
.cat-card{position:relative}
.cat-badge{position:absolute;top:.6rem;inset-inline-start:.6rem;width:34px;height:34px;border-radius:9px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-xs);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1rem;z-index:2}
.cat-card .body .more,.prod-card .body .more{display:inline-flex;align-items:center;gap:.4rem;color:var(--muted);font-weight:600;font-size:.82rem;transition:color .2s}
.cat-card:hover .more,.prod-card:hover .more{color:var(--accent)}
.cat-card:hover .more .bi,.prod-card:hover .more .bi{transform:translateX(3px)}

/* ---------- Feature (minimal, line-separated) ---------- */
.feature{padding:1.8rem 0;height:100%}
.feature .ic{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--accent);background:var(--accent-soft);margin-bottom:1.1rem}
.feature h5{font-size:1.08rem;font-weight:600;margin-bottom:.5rem;color:var(--ink)}
.feature p{color:var(--muted);font-size:.94rem;margin:0;line-height:1.6}
.feature-grid > [class*=col]{border-inline-start:1px solid var(--line)}
.feature-grid > [class*=col]:first-child{border-inline-start:0}
@media(max-width:767px){.feature-grid > [class*=col]{border-inline-start:0;border-top:1px solid var(--line)}.feature-grid > [class*=col]:first-child{border-top:0}}

/* ---------- Page header (light, minimal) ---------- */
.page-strip{background:var(--bg-soft);border-bottom:1px solid var(--line);padding:3rem 0 2.6rem}
.page-strip h1{font-size:clamp(1.7rem,3vw,2.4rem);font-weight:700;margin:0;letter-spacing:-.03em}
.sky-crumb{font-size:.86rem;color:var(--muted);margin-bottom:.7rem}
.sky-crumb a{color:var(--muted)}
.sky-crumb a:hover{color:var(--accent)}
.sky-crumb span{color:var(--ink-2)}

/* ---------- Product detail ---------- */
.product-hero{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem}
.product-hero img{max-height:360px;object-fit:contain;margin:0 auto;display:block}
.product-body :is(p,li){color:var(--body);line-height:1.78}
/* legacy CMS HTML can contain fixed-width tables/images — keep them inside the page */
.cms-content{overflow-x:auto;-webkit-overflow-scrolling:touch}
.cms-content img{max-width:100%;height:auto}
.cms-content table{max-width:100%}
.cms-content iframe{max-width:100%}

/* horizontal scroller (related products etc.) */
.hscroll{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x proximity;padding-bottom:.85rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.hscroll::-webkit-scrollbar{height:8px}
.hscroll::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
.hscroll::-webkit-scrollbar-thumb:hover{background:var(--muted)}
.hscroll-item{flex:0 0 auto;width:215px;scroll-snap-align:start}
@media(max-width:575px){.hscroll-item{width:160px}}
.doc-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border:1px solid var(--line);border-radius:12px;margin-bottom:.6rem;background:#fff;transition:.2s;color:var(--ink)}
.doc-item:hover{border-color:var(--accent);box-shadow:var(--shadow-xs)}
.doc-item i{color:#e0392b;font-size:1.35rem}

/* ---------- News ---------- */
.news-item{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;height:100%;background:#fff;transition:.25s;color:var(--ink)}
.news-item:hover{box-shadow:var(--shadow);transform:translateY(-5px)}
.news-item .img{height:210px;background:var(--bg-soft) center/cover;display:flex;align-items:center;justify-content:center;overflow:hidden}
.news-item .img .img-ph i{font-size:2.4rem;color:var(--line)}
.news-item .body{padding:1.3rem}
.news-item .body h5{font-size:1.05rem;font-weight:600}

/* ---------- Tabs (corporate) ---------- */
.sky-tabs{gap:.2rem;border-bottom:1px solid var(--line)}
.sky-tabs .nav-link{color:var(--muted);font-weight:600;border:0;border-bottom:2px solid transparent;border-radius:0;padding:.7rem 1.05rem}
.sky-tabs .nav-link:hover{color:var(--ink)}
.sky-tabs .nav-link.active{color:var(--accent);border-bottom-color:var(--accent);background:none}
.cms-content{line-height:1.85;color:var(--body)}
.cms-content img{height:auto;border-radius:12px}

/* ---------- Forms ---------- */
.sky-form .form-control,.sky-form .form-select{border-radius:11px;border:1.5px solid var(--line);padding:.75rem .95rem;background:#fff;color:var(--ink)}
.sky-form .form-control:focus,.sky-form .form-select:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.sky-form .form-label{font-weight:600;color:var(--ink);font-size:.9rem}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:2.2rem}
/* Modern quote (lead) form */
.lead-head{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:1.1rem}
.lead-ic{flex:0 0 auto;width:40px;height:40px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.lead-title{font-family:'Sora',sans-serif;font-weight:700;font-size:1.08rem;margin:0;color:var(--ink);letter-spacing:-.01em}
.lead-sub{font-size:.82rem;color:var(--muted);margin:.2rem 0 0;line-height:1.45}
.lf-field{position:relative;margin-bottom:.6rem}
.lf-field > .bi{position:absolute;inset-inline-start:.9rem;top:.8rem;color:var(--muted-soft);font-size:1rem;pointer-events:none;transition:color .18s}
.lf-field input,.lf-field textarea{width:100%;border:1.5px solid var(--line);border-radius:13px;background:var(--bg-soft);padding:.72rem .9rem;padding-inline-start:2.6rem;font-size:1rem;color:var(--ink);font-family:inherit;transition:border-color .18s,box-shadow .18s,background .18s}
.lf-field input::placeholder,.lf-field textarea::placeholder{color:var(--muted-soft)}
.lf-field input:focus,.lf-field textarea:focus{outline:0;background:#fff;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.lf-field:focus-within > .bi{color:var(--accent)}
.lf-field.lf-area > .bi{top:.85rem}
.lf-field textarea{resize:vertical;min-height:86px;line-height:1.5}
.lf-send{border-radius:13px;padding:.75rem;font-weight:700;font-size:.98rem;margin-top:.2rem}
.lf-wa{display:flex;align-items:center;justify-content:center;gap:.5rem;border-radius:13px;padding:.72rem;font-weight:700;font-size:.96rem;margin-top:.55rem;border:1.5px solid rgba(37,211,102,.4);background:rgba(37,211,102,.1);color:#1aa64b;transition:.18s}
.lf-wa:hover{background:#25d366;border-color:#25d366;color:#fff}
.lf-wa .bi{color:#25d366;font-size:1.05rem;transition:color .18s}
.lf-wa:hover .bi{color:#fff}

/* ---------- Footer (light minimal) ---------- */
.sky-footer{background:#fff;border-top:1px solid var(--line);padding-top:4rem;margin-top:5rem;color:var(--body)}
.sky-footer h6{color:var(--ink);text-transform:uppercase;font-size:.76rem;letter-spacing:.1em;margin-bottom:1.1rem}
.text-muted-2{color:var(--muted)}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:.55rem}
.footer-links a{color:var(--body);font-size:.94rem}
.footer-links a:hover{color:var(--accent)}
.footer-social a{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:11px;color:var(--ink-2);margin-inline-end:.45rem;transition:.2s}
.footer-social a:hover{border-color:var(--accent);color:var(--accent)}
.footer-bottom{border-top:1px solid var(--line);margin-top:2.6rem;padding:1.3rem 0;font-size:.85rem;color:var(--muted)}

/* ---------- Floating buttons ---------- */
.wa-float{position:fixed;inset-block-end:calc(22px + env(safe-area-inset-bottom));inset-inline-end:20px;width:54px;height:54px;background:#25d366;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.65rem;box-shadow:var(--shadow);z-index:1030;transition:.2s}
.wa-float:hover{color:#fff;transform:scale(1.07)}
.go-top{position:fixed;inset-block-end:calc(86px + env(safe-area-inset-bottom));inset-inline-end:20px;width:44px;height:44px;background:#fff;border:1px solid var(--line);color:var(--ink);border-radius:12px;display:none;align-items:center;justify-content:center;z-index:1030;box-shadow:var(--shadow-xs)}
.go-top.show{display:flex}
.go-top:hover{color:var(--accent);border-color:var(--accent)}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s cubic-bezier(.2,.7,.3,1)}
.reveal.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- Mobile refinements ---------- */
/* clamp long titles so cards/news keep even heights */
.cat-card .body h5,.prod-card .body h5,.news-item .body h5{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
/* legacy fixed-width CMS tables: swipe horizontally (scroll container on the table itself, set above) and wrap long cell text */
.cms-content td,.cms-content th{word-break:break-word}
/* long emails / phone numbers / breadcrumbs / doc titles wrap instead of overflowing */
.sky-footer a,.footer-links a,.form-card a[href^="mailto"],.form-card a[href^="tel"]{overflow-wrap:anywhere}
.sky-crumb{display:flex;flex-wrap:wrap;align-items:center;gap:.15rem .45rem;overflow-wrap:anywhere}
.doc-item{align-items:flex-start}
.doc-item span{min-width:0;overflow-wrap:anywhere}
.suggest-item .t small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}

@media(max-width:767px){
  /* topbar = language + socials only (no cramped email row) */
  .topbar-left{display:none!important}
  .topbar .container{justify-content:flex-end!important}

  .section{padding:3.4rem 0}
  .section-title{margin-bottom:1.8rem}
  .sky-footer{padding-top:2.6rem;margin-top:3rem}
  .product-hero{margin-bottom:1.5rem}

  /* corporate tabs: one swipeable row instead of ragged wrapping */
  .sky-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .sky-tabs::-webkit-scrollbar{display:none}
  .sky-tabs .nav-item{flex:0 0 auto}
  .sky-tabs .nav-link{white-space:nowrap;padding:.6rem .85rem}

  /* breathing room for 2-up feature blocks */
  .feature-grid > [class*=col]{padding-inline:.9rem}
  .feature{padding:1.3rem 0}
}
@media(max-width:575px){
  .navbar-brand img{height:38px}
  .lang-switch .btn{padding:.35rem .75rem;font-size:.85rem}
  .form-card{padding:1.25rem}
  .form-card button[type=submit]{width:100%}
  /* smaller, denser product/category cards so the catalog isn't endless */
  .cat-card .thumb,.prod-card .thumb{height:140px;padding:1rem}
  .cat-card .thumb img,.prod-card .thumb img{max-height:105px}
  .cat-card .body,.prod-card .body{padding:.7rem .85rem .9rem}
  .cat-card .body h5,.prod-card .body h5{font-size:.92rem}
  .footer-bottom{padding-bottom:1.3rem}
  .live-results{max-height:55vh}
  /* shrink the WhatsApp float so it can't cover the full-width finder Find button */
  .wa-float{width:48px;height:48px;font-size:1.5rem}
}

/* ---------- Lightbox (GLightbox) theming ---------- */
.glightbox-container .goverlay{background:rgba(9,16,28,.94)!important}
.gslide-image img{background:#fff;border-radius:16px;box-shadow:0 30px 90px -20px rgba(0,0,0,.75);max-height:86vh!important;width:auto}
.gslide-description{background:#0f1827}
.gslide-title{color:#fff}
.gdesc-inner .gslide-desc{color:#b9c6d8}
.gbtn.gclose,.gnext,.gprev{background:rgba(255,255,255,.14)!important;border-radius:12px;opacity:1}
.gbtn.gclose:hover,.gnext:hover,.gprev:hover{background:rgba(255,255,255,.28)!important}
.gbtn svg,.gclose svg,.gnext svg,.gprev svg{fill:#fff}
@media(max-width:575px){
  .gslide-image img{border-radius:12px;max-height:78vh!important}
  .gprev,.gnext{display:none!important}
}

/* ============================================================
   PREMIUM POLISH PASS (overrides + additions)
   ============================================================ */
:root{ --muted:#5b6573; --muted-soft:#8a93a1; --pdf:#e0392b; }  /* AA-contrast body grey */

/* keyboard focus visibility (WCAG 2.4.7) */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
.btn:focus-visible{outline:0;box-shadow:0 0 0 4px var(--accent-soft)}
a.cat-card:focus-visible,a.prod-card:focus-visible,.news-item:focus-visible,.suggest-item:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.sky-nav .nav-link:focus-visible{outline:2px solid var(--accent);outline-offset:0}

/* section-heading accent underline (was an undefined .heading-line class) */
.heading-line{position:relative;display:inline-block;padding-bottom:.55rem}
.heading-line::after{content:"";position:absolute;inset-inline-start:0;bottom:0;width:44px;height:3px;border-radius:3px;background:var(--accent)}
.product-body h4,.cms-content + h4{font-size:1.2rem;font-weight:700;margin-top:2.2rem}

/* centred section titles get a subtle accent rule */
.section-title.text-center h2::after{content:"";display:block;width:48px;height:3px;border-radius:3px;background:var(--accent);opacity:.9;margin:.95rem auto 0}

/* RTL: mirror forward arrows so they point with the reading direction */
body.rtl .bi-arrow-right{display:inline-block;transform:scaleX(-1)}
body.rtl .btn:hover .bi-arrow-right{transform:scaleX(-1) translateX(4px)}
body.rtl .cat-card:hover .more .bi-arrow-right,body.rtl .prod-card:hover .more .bi-arrow-right{transform:scaleX(-1) translateX(3px)}

/* cards: real separation + purposeful hover + accent edge */
.prod-card{position:relative}
.cat-card .thumb,.prod-card .thumb{background:#fff}
.cat-card:hover,.prod-card:hover{transform:translateY(-6px);box-shadow:0 24px 50px -28px rgba(16,40,80,.45);border-color:var(--accent-soft)}
.cat-card::after,.prod-card::after{content:"";position:absolute;inset-inline:0;top:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s ease;z-index:3}
body.rtl .cat-card::after,body.rtl .prod-card::after{transform-origin:right}
.cat-card:hover::after,.prod-card:hover::after{transform:scaleX(1)}
.cat-card .body .more,.prod-card .body .more,.news-item .body .more{color:var(--accent-dark);transition:color .2s}
.cat-card:hover .more,.prod-card:hover .more,.news-item:hover .more{color:var(--accent)}

/* buttons: branded depth + a real outline hover */
.btn-sky{box-shadow:0 10px 24px -12px rgba(31,111,214,.55)}
.btn-sky:hover{box-shadow:0 14px 30px -12px rgba(31,111,214,.65)}
.btn-outline-sky:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}

/* interior page header: lift the flat grey band */
.page-strip{padding:3.4rem 0 3rem;background:linear-gradient(180deg,#fff,var(--bg-soft));position:relative;overflow:hidden}
.page-strip::before{content:"";position:absolute;top:-35%;inset-inline-end:-8%;width:42%;height:170%;background:radial-gradient(closest-side,var(--accent-soft),transparent 70%);opacity:.7;pointer-events:none}
.page-strip .container{position:relative}
.page-strip h1{font-size:clamp(1.9rem,3vw,2.6rem)}

/* slider: cap desktop height, tame indicator reserve, nicer controls */
.sky-slider .carousel-item img{max-height:460px;object-fit:cover}
.sky-slider .carousel-indicators{margin-bottom:3rem}
.sky-slider .carousel-control-prev-icon,.sky-slider .carousel-control-next-icon{width:44px;height:44px;background-color:rgba(255,255,255,.92);border-radius:50%;background-size:42%;box-shadow:var(--shadow-xs);filter:none}

/* section seams + softer rhythm */
.section-soft{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* feature row: clean divider cross on tablet (was a stray vertical line 768-991) */
@media(max-width:991px){
  .feature-grid > [class*=col]{border-inline-start:0}
  .feature-grid > [class*=col]:nth-child(n+3){border-top:1px solid var(--line)}
  .feature-grid > [class*=col]:nth-child(even){border-inline-start:1px solid var(--line)}
}

/* floating WhatsApp must not cover the footer on tablet/short pages */
@media(max-width:991px){ .footer-bottom{padding-bottom:1.3rem} }
.go-top{width:48px;height:48px;inset-block-end:calc(90px + env(safe-area-inset-bottom))}

/* certificate caption + gallery clamp so rows stay even */
.gallery-grid .small{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.4em}

/* product part-code line under H1 */
.prod-code{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--muted);background:var(--bg-soft);border:1px solid var(--line);border-radius:30px;padding:.3rem .9rem;margin-bottom:1.2rem}
.prod-code b{color:var(--ink);font-family:'Sora',sans-serif}
/* context chip on the contact form when a product subject is carried over */
.ctx-chip{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent-soft);color:var(--accent-dark);border-radius:30px;padding:.45rem 1rem;font-weight:600;font-size:.9rem;margin-bottom:1.2rem}
/* required-field legend + asterisk */
.req{color:var(--pdf);margin-inline-start:.15rem}
.form-legend{font-size:.84rem;color:var(--muted);margin-bottom:1rem}

@media(max-width:575px){ .search-bar .btn{min-width:48px;height:48px;padding:.5rem} }

/* skip-to-content link — clip pattern (does NOT extend the scroll canvas, unlike left:-9999px) */
.skip-link{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link:focus{position:fixed;width:auto;height:auto;margin:0;clip:auto;top:1rem;inset-inline-start:1rem;z-index:3000;background:#fff;color:var(--ink);padding:.6rem 1rem;border-radius:8px;box-shadow:var(--shadow)}
/* belt-and-suspenders: never allow horizontal page overflow */
html,body{overflow-x:clip}

/* topbar: lighter, refined type (was too bold/heavy) */
.topbar{font-weight:400;font-size:.8rem}
.topbar a{font-weight:400}
.lang-switch .btn{font-weight:500}
/* bigger, more confident logo */
.navbar-brand img{height:56px}
@media(max-width:575px){.navbar-brand img{height:48px}}

/* framed slider hero — contained, rounded, designed (not a raw banner strip) */
.sky-slider{background:transparent;padding-top:1.6rem}
.sky-slider #heroCarousel{border-radius:22px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.sky-slider .carousel-indicators{margin-bottom:1rem!important}
.finder-wrap{padding-top:1.4rem}
@media(max-width:575px){
  .sky-slider{padding-top:1rem}
  .sky-slider #heroCarousel{border-radius:16px}
  .sky-slider .carousel-indicators{margin-bottom:.6rem!important}
}

/* ===== bigger logo + modern offcanvas mobile menu ===== */
.navbar-brand img{height:60px}
@media(max-width:575px){.navbar-brand img{height:54px}}
.navbar-toggler{border:1px solid var(--line);border-radius:11px;padding:.5rem .65rem}
.navbar-toggler:focus{box-shadow:0 0 0 3px var(--accent-soft);outline:0}
.sky-offcanvas .offcanvas-header{border-bottom:1px solid var(--line);padding:1rem 1.3rem}
@media(max-width:991px){
  /* backdrop-filter on .sky-nav creates a containing block that traps the
     offcanvas's position:fixed inside the navbar box -> drawer collapses to
     navbar height. Drop it on mobile so the fixed drawer fills the viewport. */
  .sky-nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:#fff}
  .sky-offcanvas{width:87vw;max-width:340px;border:0}
  .sky-offcanvas .offcanvas-body{display:flex;flex-direction:column;padding:.4rem 1.3rem 1.6rem;overflow-y:auto}
  .sky-offcanvas .navbar-nav{width:100%}
  .sky-offcanvas .nav-item{border-top:0;border-bottom:1px solid var(--line-2)}
  .sky-offcanvas .nav-cta{border-bottom:0;margin-top:1.1rem}
  .sky-offcanvas .nav-link{display:block;padding:.95rem .2rem;font-size:1.06rem;font-weight:600;color:var(--ink-2)}
  .sky-offcanvas .nav-link:hover,.sky-offcanvas .nav-link.active{color:var(--accent)}
  .sky-offcanvas .nav-link.active::after{display:none}
  .sky-offcanvas .nav-cta .btn{display:block;width:100%;text-align:center;padding:.85rem 1rem;font-size:1rem}
  .offcanvas-extra{margin-top:1.4rem;padding-top:1.3rem;border-top:1px solid var(--line)}
  .oc-contact{display:flex;align-items:center;gap:.65rem;padding:.45rem 0;color:var(--ink-2);font-weight:500;font-size:.95rem;overflow-wrap:anywhere}
  .oc-contact .bi{font-size:1.15rem;color:var(--accent);flex:0 0 auto}
  .oc-social{display:flex;gap:.6rem;margin-top:.9rem}
  .oc-social a{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:12px;color:var(--ink-2);font-size:1.05rem}
  .oc-social a:hover{border-color:var(--accent);color:var(--accent)}
}

/* ============================================================
   REDESIGN PASS — cohesion, restored menus, gallery, mobile bar
   ============================================================ */

/* --- Catalog button in the topbar --- */
.topbar-cat{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--accent-dark)!important;background:var(--accent-soft);border-radius:30px;padding:.18rem .8rem}
.topbar-cat:hover{background:var(--accent);color:#fff!important}

/* --- Products / Careers nav dropdowns --- */
.sky-nav .dropdown-menu{min-width:230px;max-height:70vh;overflow:auto}
.sky-nav .nav-item.dropdown .dropdown-toggle::after{margin-inline-start:.35rem;vertical-align:.12em}

/* --- Product Finder label above the search bar --- */
.finder-card{position:relative}
.finder-head{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}
.finder-head .finder-label{font-family:'Sora',sans-serif;font-weight:700;font-size:1.05rem;color:var(--ink);letter-spacing:-.01em}
.finder-head .finder-ic{width:34px;height:34px;border-radius:10px;background:var(--accent-soft);color:var(--accent);display:inline-flex;align-items:center;justify-content:center;font-size:1.05rem;flex:0 0 auto}
.finder-head .finder-sub{color:var(--muted);font-size:.86rem}
@media(max-width:575px){.finder-head .finder-sub{display:none}}

/* --- Trust / stats strip (ties hero+finder to the catalog below) --- */
.trust-strip{padding:1.6rem 0}
.trust-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-xs);padding:1.3rem 1rem}
.trust-item{flex:1 1 0;min-width:130px;text-align:center;position:relative;padding:.2rem .6rem}
.trust-item + .trust-item::before{content:"";position:absolute;inset-inline-start:0;top:50%;transform:translateY(-50%);width:1px;height:60%;background:var(--line)}
.trust-item .num{font-family:'Sora',sans-serif;font-weight:800;font-size:1.7rem;color:var(--ink);line-height:1.05}
.trust-item .num .bi{color:var(--accent);font-size:1.4rem}
.trust-item .lbl{font-size:.8rem;color:var(--muted);margin-top:.3rem;letter-spacing:.01em}
@media(max-width:767px){
  .trust-grid{gap:.4rem;padding:1.1rem .6rem}
  .trust-item{flex:1 1 45%;min-width:0;padding:.5rem .3rem}
  .trust-item::before{display:none}
  .trust-item .num{font-size:1.35rem}
}

/* --- Universal closing CTA band --- */
.cta-band{padding:4.5rem 0}
.cta-band .inner{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;border-radius:26px;padding:3rem 2rem;text-align:center;box-shadow:0 30px 70px -30px rgba(31,111,214,.6);position:relative;overflow:hidden}
.cta-band .inner::before{content:"";position:absolute;top:-40%;inset-inline-end:-10%;width:55%;height:180%;background:radial-gradient(closest-side,rgba(255,255,255,.18),transparent 70%)}
.cta-band .eyebrow{color:#dce9fb}
.cta-band h2{color:#fff;font-size:clamp(1.5rem,3vw,2.3rem);margin:0 0 .7rem;position:relative}
.cta-band .lead{color:#eaf2fd;max-width:54ch;margin:0 auto 1.7rem;position:relative;font-size:1.05rem}
.cta-band .actions{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;position:relative}
.cta-band .btn-light-cta{background:#fff;color:var(--accent-dark);border:0}
.cta-band .btn-light-cta:hover{background:#f1f6ff;color:var(--accent-dark);transform:translateY(-2px)}
.cta-band .btn-ghost-cta{background:rgba(255,255,255,.06);color:#fff;border:1.5px solid #fff}
.cta-band .btn-ghost-cta:hover{background:rgba(255,255,255,.22);color:#fff}
@media(max-width:575px){.cta-band{padding:3rem 0}.cta-band .inner{padding:2.2rem 1.3rem;border-radius:20px}.cta-band .actions .btn{width:100%}}

/* --- Footer offices band (restored addresses) --- */
.sky-footer{margin-top:0;padding-top:0}     /* CTA band + offices band now own the top spacing */
.footer-cols{padding-top:3.6rem}
.footer-offices{border-top:1px solid var(--line);background:var(--bg-soft);padding:2.6rem 0}
.office-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.3rem 1.4rem;height:100%;transition:.2s}
.office-card:hover{box-shadow:var(--shadow);border-color:var(--accent-soft)}
.office-card .oc-head{display:flex;align-items:center;gap:.55rem;font-family:'Sora',sans-serif;font-weight:700;color:var(--ink);margin-bottom:.7rem}
.office-card .oc-head .bi{color:var(--accent)}
.office-card .oc-line{display:flex;align-items:flex-start;gap:.55rem;color:var(--body);font-size:.9rem;margin-bottom:.5rem;overflow-wrap:anywhere}
.office-card .oc-line .bi{color:var(--muted);margin-top:.15rem;flex:0 0 auto}
.office-card a.oc-line:hover{color:var(--accent)}

/* Lock background scroll while the mobile drawer is open. Locking the <html>
   scroll container (not just <body>) is what actually stops the page moving on
   mobile; no position change, so the page never jumps to the top. */
html.nav-open,html.nav-open body{overflow:hidden!important}

/* --- Photo gallery: natural-ratio photos on white tiles (masonry) --- */
.photo-gallery{column-count:4;column-gap:1rem}
@media(max-width:991px){.photo-gallery{column-count:3}}
@media(max-width:767px){.photo-gallery{column-count:2}}
@media(max-width:430px){.photo-gallery{column-count:1}}
.pg-item{display:block;break-inside:avoid;margin-bottom:1rem;background:#fff;border:1px solid var(--line);border-radius:14px;padding:.5rem;overflow:hidden;transition:transform .25s ease,box-shadow .25s,border-color .25s}
.pg-item:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--accent-soft)}
.pg-item img{display:block;width:100%;height:auto;border-radius:9px}

/* --- gallery-grid (certificates + product thumbs): white tile, no crop --- */
.gallery-grid > [class*=col] > a.glightbox{display:block;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:.2s}
.gallery-grid > [class*=col] > a.glightbox:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--accent-soft)}
.gallery-grid img{display:block;width:100%;aspect-ratio:1/1;object-fit:contain;background:#fff;padding:.55rem;border:0;border-radius:12px;cursor:pointer}
.gallery-grid img:hover{box-shadow:none;transform:none}

/* contact page office map */
.office-map{border-radius:12px;overflow:hidden;border:1px solid var(--line);line-height:0}
.office-map iframe{display:block}

/* ============================================================
   INTERACTIVE PRODUCT CATALOG (/catalog)
   ============================================================ */
.catalog-hero .catalog-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.5rem}
.catalog-hero .catalog-search{margin-top:1.15rem;max-width:520px}
.catalog-search{display:flex;align-items:center;gap:.6rem;background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:.2rem .2rem .2rem 1rem}
.catalog-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.catalog-search > .bi{color:var(--muted);font-size:1.1rem}
.catalog-search input{flex:1 1 auto;min-width:0;border:0;outline:0;background:transparent;padding:.6rem 0;font-size:1rem;color:var(--ink)}

.catalog-layout{display:grid;grid-template-columns:232px 1fr;gap:2.5rem;align-items:start}
@media(max-width:991px){.catalog-layout{grid-template-columns:1fr;gap:1.1rem}}

.catalog-index{position:sticky;top:92px}
.catalog-index .ci-title{font-family:'Sora',sans-serif;font-weight:700;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.8rem}
.catalog-index ul{list-style:none;margin:0;padding:0;max-height:calc(100vh - 140px);overflow:auto}
.ci-link{display:flex;align-items:center;gap:.55rem;padding:.5rem .7rem;border-radius:10px;color:var(--ink-2);font-weight:600;font-size:.9rem;margin-bottom:.15rem}
.ci-link .bi{color:var(--accent);font-size:1rem;flex:0 0 auto}
.ci-link span{flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ci-link em{font-style:normal;font-size:.72rem;color:var(--muted);background:var(--bg-soft);border-radius:20px;padding:.06rem .5rem;flex:0 0 auto}
.ci-link:hover{background:var(--bg-soft);color:var(--accent)}
.ci-link.active{background:var(--accent-soft);color:var(--accent)}
.ci-link.active em{background:#fff;color:var(--accent)}
@media(max-width:991px){
  .catalog-index{top:86px;z-index:20;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);margin:0 -1rem;padding:.55rem 1rem;border-bottom:1px solid var(--line)}
  .catalog-index .ci-title{display:none}
  .catalog-index ul{display:flex;gap:.5rem;overflow-x:auto;max-height:none;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .catalog-index ul::-webkit-scrollbar{display:none}
  .ci-link{flex:0 0 auto;border:1px solid var(--line);margin-bottom:0}
}

/* content-visibility lets the browser skip rendering + lazy-image work for
   off-screen category blocks -> the long catalog becomes fast on mobile. */
.cat-block{scroll-margin-top:104px;margin-bottom:3rem;content-visibility:auto;contain-intrinsic-size:auto 700px}
/* mobile: clear the sticky navbar (~85px) + the sticky category bar (~52px) when jumping */
@media(max-width:991px){.cat-block{scroll-margin-top:150px}}
.cat-block-title{display:flex;align-items:center;gap:.6rem;font-size:clamp(1.25rem,2.4vw,1.5rem);padding-bottom:.7rem;border-bottom:2px solid var(--line);margin-bottom:1.4rem}
.cat-block-title .bi{color:var(--accent)}
.cat-block-title .cb-count{margin-inline-start:auto;font-family:'Inter',sans-serif;font-size:.78rem;font-weight:600;color:var(--muted);letter-spacing:0}
.subcat-group{margin-bottom:1.6rem}
.subcat-title{font-size:1rem;font-weight:700;color:var(--ink-2);margin:1.1rem 0 1rem;display:flex;align-items:center;gap:.5rem}
.subcat-title::before{content:"";width:14px;height:2px;background:var(--accent);border-radius:2px;flex:0 0 auto}

.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:1rem}
@media(max-width:575px){.cat-grid{grid-template-columns:repeat(2,1fr);gap:.7rem}}
.cat-prod{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:transform .2s ease,box-shadow .2s,border-color .2s;color:var(--ink)}
.cat-prod:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--accent-soft)}
.cp-img{height:132px;display:flex;align-items:center;justify-content:center;background:#fff;padding:.7rem;border-bottom:1px solid var(--line-2)}
.cp-img img{max-height:118px;max-width:100%;object-fit:contain}
.cp-img .bi{font-size:2rem;color:var(--line)}
.cp-name{padding:.65rem .8rem;font-size:.85rem;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.catalog-empty{text-align:center;color:var(--muted);padding:3rem 1rem;font-size:1.05rem}
.catalog-empty .bi{display:block;font-size:2rem;margin-bottom:.6rem;opacity:.5}

/* print = clean printable catalog */
@media print{
  .topbar,.sky-nav,.sky-offcanvas,.offcanvas-backdrop,.sky-footer,.cta-band,.footer-offices,.mobile-bar,.wa-float,.go-top,.catalog-index,.catalog-actions,.catalog-search,.skip-link{display:none!important}
  .page-strip{background:#fff!important;padding:0 0 .6rem!important;border:0}
  .page-strip::before{display:none!important}
  .section{padding:0!important}
  .catalog-layout{display:block}
  .cat-block{margin-bottom:1rem;content-visibility:visible!important;contain-intrinsic-size:auto!important}
  .tab-content .tab-pane{display:block!important;opacity:1!important}
  .cat-block-title{break-after:avoid}
  .subcat-group,.cat-prod{break-inside:avoid}
  .cat-prod{border:1px solid #ccc}
  .cat-prod:hover{transform:none;box-shadow:none}
  .cat-grid{grid-template-columns:repeat(4,1fr);gap:.35rem}
  body{padding:0!important}
}

/* ============================================================
   FEEDBACK PASS — logo, slider arrows, spacing, finder, flags
   ============================================================ */

/* bigger, dominant logo (must out-size page headings) */
.navbar-brand img{height:56px}
.sky-nav.scrolled .navbar-brand img{height:48px}
@media(max-width:575px){.navbar-brand img{height:60px}}

/* page heading must not dwarf the logo on phones */
@media(max-width:575px){
  .page-strip h1{font-size:1.5rem}
  .page-strip{padding:2rem 0 1.6rem}
}

/* tighter section rhythm so bands read as one page, not islands */
.section{padding:4.5rem 0}
.section-title{margin-bottom:2rem}
@media(max-width:767px){.section{padding:2.8rem 0}.section-title{margin-bottom:1.5rem}}
.sky-slider{padding-top:.5rem}
.finder-wrap{padding-top:0}
/* Compress the above-the-fold so the category strip (with names) shows without scrolling */
@media(min-width:768px){
  .sky-slider .carousel-item img{max-height:290px;object-fit:cover;object-position:center}
  /* search card overlaps the hero (old design) — lift the dots so the card doesn't cover them */
  .sky-slider .carousel-indicators{margin-bottom:3rem!important}
  .finder-card{padding:.9rem 1.6rem}
  .finder-card .finder-label{margin-bottom:.45rem}
  .finder-cats{margin-top:.75rem;padding-top:.75rem}
  .finder-cats-head{margin-bottom:.55rem}
}
.cta-band{padding:3.4rem 0}

/* Product Finder label — clean, simple (icon box + subtitle removed) */
.finder-card .finder-label{display:block;font-family:'Sora',sans-serif;font-weight:700;font-size:1.02rem;color:var(--ink);margin-bottom:.85rem;letter-spacing:-.01em}

/* visible slider prev/next arrows (dark chevron on a white disc) */
.sky-slider .carousel-control-prev,.sky-slider .carousel-control-next{width:9%;opacity:1}
.sky-slider .carousel-control-prev-icon,.sky-slider .carousel-control-next-icon{
  width:46px;height:46px;background-color:#fff;border-radius:50%;background-size:40% 40%;
  box-shadow:0 6px 18px -6px rgba(16,40,80,.4);filter:none;border:1px solid var(--line)}
.sky-slider .carousel-control-prev-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230b1220'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3e%3c/svg%3e")}
.sky-slider .carousel-control-next-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230b1220'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e")}
.sky-slider .carousel-control-prev-icon:hover,.sky-slider .carousel-control-next-icon:hover{background-color:var(--accent-soft)}

/* site-wide search (header + mobile drawer) */
.nav-search{display:flex;align-items:center;gap:.45rem;background:var(--bg-soft,#f2f5f9);border:1px solid var(--line);border-radius:999px;padding:.34rem .85rem;width:180px;transition:width .2s,border-color .2s}
.nav-search:focus-within{border-color:var(--accent);width:220px}
.nav-search .bi{color:var(--muted);font-size:.92rem}
.nav-search input{border:0;background:transparent;outline:0;width:100%;font-size:.88rem;color:var(--ink)}
.oc-search{display:flex;align-items:center;gap:.55rem;background:var(--bg-soft,#f2f5f9);border:1px solid var(--line);border-radius:12px;padding:.65rem .95rem;margin-bottom:1.1rem}
.oc-search .bi{color:var(--muted)}
.oc-search input{border:0;background:transparent;outline:0;width:100%;font-size:1rem;color:var(--ink)}

/* Product Finder panel: search + browse-by-category strip = one connected unit */
.finder-cats{margin-top:1.05rem;padding-top:1.05rem;border-top:1px solid var(--line-2)}
.finder-cats-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.8rem}
.finder-cats-label{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.finder-cats-label .bi{color:var(--accent);font-size:.95rem}
.cs-navs{display:flex;gap:.45rem;flex:0 0 auto}
.cs-nav{width:34px;height:34px;border-radius:10px;background:#fff;border:1px solid var(--line);color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;transition:.18s}
.cs-nav:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.cs-nav:active{transform:scale(.94)}
.cat-slider{display:flex;gap:.85rem;overflow-x:auto;scroll-snap-type:x proximity;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:.15rem .1rem;cursor:grab}
.cat-slider::-webkit-scrollbar{display:none}
.cat-slider.dragging{cursor:grabbing;scroll-behavior:auto;scroll-snap-type:none}
.cat-slide{flex:0 0 168px;scroll-snap-align:start;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;color:var(--ink);text-decoration:none;transition:transform .22s,box-shadow .22s,border-color .22s}
.cat-slide:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--accent-soft)}
.cs-thumb{height:90px;display:flex;align-items:center;justify-content:center;padding:.6rem;background:#fff}
.cs-thumb img{max-height:74px;max-width:100%;object-fit:contain;pointer-events:none}
.cs-thumb .bi{font-size:2.3rem;color:var(--line)}
.cs-title{padding:.5rem .7rem;border-top:1px solid var(--line-2);font-size:.84rem;font-weight:600;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#fff}
@media(max-width:575px){.cat-slide{flex:0 0 140px}.cs-thumb{height:96px}.cs-thumb img{max-height:76px}.cs-title{font-size:.8rem}}
@media(max-width:575px){.sky-slider .carousel-control-prev-icon,.sky-slider .carousel-control-next-icon{width:36px;height:36px}}

/* language switcher with flags — modern, compact */
.lang-switch .btn{display:inline-flex;align-items:center;gap:.4rem}
.lang-switch .flag{border-radius:2px;box-shadow:0 0 0 1px rgba(0,0,0,.06);vertical-align:middle;object-fit:cover}
.lang-menu{min-width:180px}
.lang-menu .dropdown-item{display:flex;align-items:center;gap:.6rem;direction:ltr;text-align:left}

/* contact page — one-tap quick contact cards + help list */
.qc-card{display:flex;align-items:center;gap:.9rem;background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.05rem 1.2rem;height:100%;transition:transform .2s,box-shadow .2s,border-color .2s;color:var(--ink)}
.qc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--accent-soft);color:var(--ink)}
.qc-ic{width:48px;height:48px;border-radius:13px;display:inline-flex;align-items:center;justify-content:center;font-size:1.35rem;flex:0 0 auto;color:#fff}
.qc-call{background:var(--accent)}
.qc-wa{background:#1aa251}
.qc-mail{background:var(--ink)}
.qc-t{display:flex;flex-direction:column;min-width:0}
.qc-t b{font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;line-height:1.2}
.qc-t small{color:var(--muted);font-size:.82rem;overflow-wrap:anywhere}
.help-list{list-style:none;padding:0;margin:0}
.help-list li{display:flex;align-items:center;gap:.6rem;padding:.5rem 0;color:var(--body);font-weight:500;border-bottom:1px solid var(--line-2)}
.help-list li:last-child{border-bottom:0}
.help-list .bi{color:var(--accent);font-size:1.1rem;flex:0 0 auto}

/* ---------- Google auto-translate: hide chrome, keep layout clean ---------- */
.goog-te-banner-frame,.goog-te-balloon-frame,#goog-gt-tt,.goog-tooltip,.goog-tooltip:hover{display:none!important}
.goog-te-gadget{height:0;overflow:hidden;font-size:0}
.skiptranslate{display:none!important}
body{top:0!important}
font[style]{background:transparent!important;box-shadow:none!important;color:inherit!important}
/* "Auto-translate" group label in the language menu */
.lang-menu{max-height:min(72vh,430px);overflow-y:auto}
.lang-auto-label{display:flex;align-items:center;gap:.4rem;padding:.35rem .85rem;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.lang-auto-label .bi{font-size:.9rem;color:var(--accent)}
.lang-menu .dropdown-divider{margin:.35rem .4rem}

/* sidebar (drawer) menu icons */
.sky-offcanvas .nav-link .bi{color:inherit;width:1.5em;margin-inline-end:.55rem;font-size:1.05rem;text-align:center;display:inline-block;vertical-align:-.05em}
.footer-links a .bi,.topbar-left a .bi{margin-inline-end:.5rem}

/* catalog: fix CSS-grid blowout (grid items default to min-width:auto and won't
   shrink below content -> on mobile the product grid overflowed). */
.catalog-layout{min-width:0}
.catalog-layout > *{min-width:0}
.catalog-body{min-width:0}
.cat-grid{min-width:0}
.cat-prod,.cp-name{min-width:0}
.cat-block{contain-intrinsic-size:auto 600px}

/* Consistent icon↔text gap inside buttons via flex gap (survives Google-Translate
   stripping the HTML whitespace; gap doesn't apply to icon-only buttons). */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem}

/* ============================================================
   FINAL AUDIT FIXES — tap targets, contrast, tokens, heading markup
   ============================================================ */
:root{--wa:#25d366}                       /* single WhatsApp brand green */

/* touch targets >= ~40px (mostly-mobile audience) */
.sky-slider .carousel-indicators [data-bs-target]{border:7px solid transparent;box-sizing:content-box;background-clip:content-box}
.topbar .social{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;margin-inline-start:0}
.footer-social a{width:42px;height:42px}
.lang-switch .btn{min-height:44px;justify-content:center}

/* card "View →" affordance: legible at rest (no hover-only opacity) */
.cat-card .body .more,.prod-card .body .more,.news-item .body .more{opacity:1}

/* WhatsApp green from one token everywhere */
.wa-float{background:var(--wa)}
.qc-wa{background:var(--wa)}
.topbar .wa .bi{color:var(--wa)}
.wa-green{color:var(--wa)!important}

/* card titles are now <div class="card-title"> (not <h5>) for a clean heading
   outline; replicate the previous h5 visual styling */
.cat-card .body .card-title,.prod-card .body .card-title{font-size:1rem;font-weight:600;margin:0 0 .35rem;color:var(--ink);font-family:'Sora','Inter',sans-serif;line-height:1.2}
.news-item .body .card-title{font-size:1.05rem;font-weight:600;color:var(--ink);font-family:'Sora','Inter',sans-serif}
.cat-card .body .card-title,.prod-card .body .card-title,.news-item .body .card-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;overflow-wrap:anywhere}
/* feature titles demoted h5->h3 keep their size */
.feature h3{font-size:1.08rem;font-weight:600;margin-bottom:.5rem;color:var(--ink)}

/* friendly empty states (replaces the old "Page not found" reuse) */
.empty-state{text-align:center;padding:3.5rem 1rem;color:var(--muted)}
.empty-state .bi{font-size:2.6rem;color:var(--line);display:block;margin-bottom:.8rem}
.empty-state p{font-size:1.05rem;margin-bottom:1.2rem}
/* go-top is now a <button>: neutralise UA button styling */
.go-top{cursor:pointer;padding:0;font:inherit}

/* legacy CMS bodies use inline text-align:justify which creates ugly rivers on
   narrow mobile columns -> force natural left/right alignment for readability */
.cms-content [style*="justify"],.product-body [style*="justify"]{text-align:start!important}

/* slider mobile: keep a pleasant height (cover-crops the sides a little) rather
   than the very short full-fit which looked too thin */
@media(max-width:767px){
  .sky-slider .carousel-item img{height:clamp(150px,42vw,200px)!important;aspect-ratio:auto!important;object-fit:cover!important;object-position:center}
}
