:root {
    --primary-color: #0B3D91;
    --primary-dark: #07265c;
    --accent-color: #E63946;
    --text-dark: #1D3557;
    --text-light: #F1FAEE;
    --text-muted: #6c757d;
    --bg-light: #f8f9fa;
    --border-color: #e2e8f0;
    --white: #ffffff;
    --open-gov-bg: #0B3D91;
    --open-gov-box-bg: rgba(255,255,255,0.05);
    --transition: all 0.3s ease-in-out;
    --swiper-theme-color: var(--accent-color);
}

* { margin: 0; padding: 0; box-sizing: border-box; font-family: 'Inter', sans-serif; }
html { scroll-behavior: smooth; }
body { background-color: var(--bg-light); color: var(--text-dark); line-height: 1.6; overflow-x: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: var(--transition); }
button, input, textarea, select { font: inherit; }

.container { max-width: 1300px; margin: 0 auto; padding: 0 20px; }
.text-center { text-align: center; }
.text-white { color: var(--white); }
.relative-container { position: relative; z-index: 10; }
.h-100 { height: 100%; }
.flex-align-center { display: flex; align-items: center; }
.mb-40 { margin-bottom: 40px; }
.mt-20 { margin-top: 20px; }
.mt-30 { margin-top: 30px; }
.mt-40 { margin-top: 40px; }
.section-padding { padding: 80px 0; }
.flex-space-between { display: flex; justify-content: space-between; align-items: center; }
.center-actions { justify-content: center; }

.news-ticker { display: flex; background: var(--text-dark); color: var(--white); font-size: .9rem; height: 40px; }
.ticker-label { background: var(--accent-color); padding: 0 20px; font-weight: 700; display: flex; align-items: center; z-index: 2; text-transform: uppercase; letter-spacing: 1px; }
.ticker-content { flex: 1; overflow: hidden; display: flex; align-items: center; }
.ticker-text { display: inline-flex; width: max-content; white-space: nowrap; animation: scroll-left 35s linear infinite; }
.ticker-text:hover { animation-play-state: paused; }
.ticker-text span { margin-right: 50px; }
.ticker-text span::before { content: "•"; color: var(--accent-color); margin-right: 10px; font-size: 1.2rem; vertical-align: middle; }
.ticker-text a:hover { color: var(--accent-color); }
@keyframes scroll-left { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

.main-header { position: fixed; top: 0; left: 0; width: 100%; z-index: 1000; background: rgba(255,255,255,.98); transition: var(--transition); border-bottom: 1px solid rgba(226,232,240,.9); backdrop-filter: blur(10px); box-shadow: 0 4px 20px rgba(0,0,0,.06); }
.slp-has-hero .main-header { background: transparent; border-bottom: 1px solid rgba(255,255,255,.1); box-shadow: none; backdrop-filter: none; }
.slp-has-ticker .main-header { top: 40px; }
.slp-has-ticker .main-header.scrolled,
.slp-has-ticker .main-header.search-active { top: 0; }
.main-header.scrolled, .main-header.search-active { top: 0; background: rgba(255,255,255,.98); backdrop-filter: blur(10px); box-shadow: 0 4px 20px rgba(0,0,0,.08); border-bottom: none; }
.header-spacer { height: 90px; }
.slp-has-ticker .header-spacer { height: 130px; }
.header-inner { display: flex; justify-content: space-between; align-items: center; gap: 16px; height: 90px; transition: height .3s ease; }
.main-header.scrolled .header-inner, .main-header.search-active .header-inner { height: 75px; }
.header-left { display: flex; align-items: center; gap: 50px; }
.logo, .custom-logo-link { display: flex; align-items: center; gap: 12px; }
.logo .custom-logo-link { display: inline-flex; align-items: center; }
.custom-logo { max-height: 64px; width: auto; }
.logo svg, .offcanvas-logo svg { width: 2rem; height: 2rem; color: var(--accent-color); }
.logo-text h1, .logo h1 { font-size: 1.8rem; font-weight: 800; line-height: 1.1; color: var(--text-dark); text-shadow: none; }
.logo-text span, .logo span { font-size: .85rem; color: var(--text-muted); text-shadow: none; }
.slp-has-hero .main-header:not(.scrolled):not(.search-active) .logo-text h1,
.slp-has-hero .main-header:not(.scrolled):not(.search-active) .logo h1 { color: var(--white); text-shadow: 0 2px 4px rgba(0,0,0,.5); }
.slp-has-hero .main-header:not(.scrolled):not(.search-active) .logo-text span,
.slp-has-hero .main-header:not(.scrolled):not(.search-active) .logo span { color: rgba(255,255,255,.8); text-shadow: 0 1px 2px rgba(0,0,0,.5); }
.main-header.scrolled .logo-text h1, .main-header.scrolled .logo h1, .main-header.search-active .logo-text h1, .main-header.search-active .logo h1 { color: var(--text-dark); text-shadow: none; }
.main-header.scrolled .logo-text span, .main-header.scrolled .logo span, .main-header.search-active .logo-text span, .main-header.search-active .logo span { color: var(--text-muted); text-shadow: none; }
.nav-list { display: flex; list-style: none; gap: 30px; }
.nav-list > li > a { font-weight: 600; font-size: 1.05rem; color: var(--text-dark); text-shadow: none; position: relative; padding: 25px 0; display: flex; align-items: center; gap: 6px; }
.slp-has-hero .main-header:not(.scrolled):not(.search-active) .nav-list > li > a { color: var(--white); text-shadow: 0 1px 3px rgba(0,0,0,.5); }
.nav-list > li > a svg { width: 16px; height: 16px; }
.main-header.scrolled .nav-list > li > a, .main-header.search-active .nav-list > li > a { color: var(--text-dark); text-shadow: none; }
.nav-list > li > a::after { content: ""; position: absolute; bottom: 20px; left: 0; width: 0; height: 2px; background-color: var(--accent-color); transition: width .3s ease; }
.nav-list > li > a:hover::after { width: 100%; }
.nav-list > li > a:hover { color: var(--accent-color); }
.has-mega { position: relative; }
.mega-menu { position: absolute; top: 100%; left: 0; width: min(860px, 92vw); background: var(--white); box-shadow: 0 10px 30px rgba(0,0,0,.1); border-radius: 0 0 12px 12px; opacity: 0; visibility: hidden; transform: translateY(15px); transition: opacity .3s ease, visibility .3s ease, transform .3s ease; z-index: 1001; padding: 30px; border-top: 3px solid var(--accent-color); }
.has-mega:hover > .mega-menu, .has-mega:focus-within > .mega-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.mega-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 30px; }
.mega-col h4 { font-size: 1.1rem; color: var(--primary-color); border-bottom: 2px solid var(--bg-light); padding-bottom: 10px; margin-bottom: 15px; }
.mega-col p { color: var(--text-muted); margin-bottom: 15px; }
.mega-col a { display: block; color: var(--text-muted); padding: 8px 0; font-size: .95rem; }
.mega-col a:hover { color: var(--accent-color); padding-left: 5px; }
.highlight-col { background: var(--bg-light); padding: 20px; border-radius: 8px; }
.header-right { display: flex; align-items: center; gap: 12px; }
.icon-btn, .menu-toggle, .lang-toggle { background: none; border: none; cursor: pointer; transition: var(--transition); }
.icon-btn, .menu-toggle { font-size: 1.8rem; color: var(--text-dark); }
.icon-btn svg, .menu-toggle svg { width: 1.7rem; height: 1.7rem; }
.lang-toggle { border: 1px solid var(--border-color); border-radius: 999px; padding: 10px 14px; color: var(--text-dark); font-size: .88rem; font-weight: 700; background: rgba(255,255,255,.65); }
.slp-has-hero .main-header:not(.scrolled):not(.search-active) .icon-btn,
.slp-has-hero .main-header:not(.scrolled):not(.search-active) .menu-toggle,
.slp-has-hero .main-header:not(.scrolled):not(.search-active) .lang-toggle { color: var(--white); border-color: rgba(255,255,255,.35); background: rgba(255,255,255,.08); }
.main-header.scrolled .icon-btn, .main-header.scrolled .menu-toggle, .main-header.scrolled .lang-toggle,
.main-header.search-active .icon-btn, .main-header.search-active .menu-toggle, .main-header.search-active .lang-toggle { color: var(--text-dark); border-color: var(--border-color); }
.menu-toggle { display: none; }

.btn { padding: 14px 30px; border-radius: 30px; font-weight: 600; font-size: 1.05rem; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; border: 2px solid transparent; transition: var(--transition); }
.btn-primary { background: var(--accent-color); color: var(--white); }
.btn-primary:hover { background: #c32d3a; transform: translateY(-2px); box-shadow: 0 5px 15px rgba(230,57,70,.3); }
.btn-outline { background: rgba(255,255,255,.1); backdrop-filter: blur(5px); border-color: var(--white); color: var(--white); }
.btn-outline:hover { background: var(--white); color: var(--primary-color); transform: translateY(-2px); }
.btn-text { color: var(--primary-color); font-weight: 600; display: inline-flex; align-items: center; }
.btn-icon-hover { gap: 0; }
.btn-icon-hover svg { width: 18px; height: 18px; max-width: 0; opacity: 0; overflow: hidden; transition: all .3s cubic-bezier(.175,.885,.32,1.275); transform: translateX(-10px); }
.btn-icon-hover:hover svg { max-width: 25px; opacity: 1; transform: translateX(0); margin-left: 8px; }

.search-modal { position: fixed; inset: 0; background: rgba(255,255,255,.98); z-index: 9999; display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transition: var(--transition); backdrop-filter: blur(10px); }
.search-modal.active { opacity: 1; visibility: visible; }
.search-modal-content { text-align: center; width: 100%; max-width: 700px; padding: 20px; position: relative; transform: translateY(-20px); transition: transform .4s ease; }
.search-modal.active .search-modal-content { transform: translateY(0); }
.close-search-modal { position: absolute; top: -50px; right: 0; background: none; border: none; font-size: 2.5rem; cursor: pointer; color: var(--text-dark); transition: var(--transition); }
.close-search-modal svg { width: 2rem; height: 2rem; }
.close-search-modal:hover { color: var(--accent-color); transform: rotate(90deg); }
.search-modal-content h2 { font-size: 2rem; color: var(--primary-color); margin-bottom: 30px; font-weight: 800; }
.modal-search-form { display: flex; border: 2px solid var(--border-color); border-radius: 50px; overflow: hidden; background: var(--white); box-shadow: 0 10px 30px rgba(0,0,0,.05); }
.modal-search-form input { flex: 1; padding: 20px 30px; border: none; font-size: 1.2rem; outline: none; }
.modal-search-form button { border-radius: 0; margin: 0; padding: 0 35px; font-size: 1.2rem; }

.offcanvas-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 1999; opacity: 0; visibility: hidden; transition: var(--transition); backdrop-filter: blur(3px); }
.offcanvas-overlay.active { opacity: 1; visibility: visible; }
.offcanvas { position: fixed; top: 0; right: -400px; width: min(350px, 92vw); height: 100vh; background: var(--white); color: var(--text-dark); z-index: 2000; transition: right .4s ease; display: flex; flex-direction: column; overflow-y: auto; box-shadow: -12px 0 30px rgba(15,23,42,.12); }
.offcanvas.active { right: 0; }
.offcanvas-header { display: flex; justify-content: space-between; align-items: center; padding: 22px 25px; border-bottom: 1px solid var(--border-color); }
.offcanvas-logo .custom-logo { max-height: 54px; }
.offcanvas-logo h1 { color: var(--text-dark); font-size: 1.35rem; }
.offcanvas-logo span { color: var(--text-muted); }
.close-offcanvas { background: none; border: none; color: var(--text-dark); cursor: pointer; }
.close-offcanvas svg { width: 1.8rem; height: 1.8rem; }
.offcanvas-body { padding: 30px 25px; flex-grow: 1; }
.mobile-nav { list-style: none; }
.mobile-nav > li { border-bottom: 1px solid var(--border-color); }
.mobile-nav > li > a { display: block; padding: 15px 0; font-size: 1.2rem; color: var(--text-dark); font-weight: 600; }
.mobile-dropdown-header { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.mobile-dropdown-header a { padding: 15px 0; font-size: 1.2rem; color: var(--text-dark); font-weight: 600; flex: 1; }
.submenu-btn { background: none; border: none; color: var(--text-dark); padding: 10px; cursor: pointer; }
.submenu-btn svg { width: 1.2rem; height: 1.2rem; transition: transform .3s ease; }
.submenu-btn.active svg { transform: rotate(180deg); }
.mobile-submenu { list-style: none; padding-left: 15px; display: none; background: #f8fafc; border-radius: 8px; margin-bottom: 15px; }
.mobile-submenu li a { display: block; padding: 10px 15px; color: #475569; font-size: 1rem; }

.hero-slider { height: 100vh; width: 100%; position: relative; }
.slp-has-ticker.slp-has-hero .hero-slider { margin-top: 40px; height: calc(100vh - 40px); }
.hero-slide { background-size: cover; background-position: center; position: relative; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(11,61,145,.95) 0%, rgba(11,61,145,.5) 60%, transparent 100%); }
.hero-70 { width: 70%; padding-right: 50px; color: var(--white); position: relative; z-index: 2; }
.badge { display: inline-block; background: var(--accent-color); color: var(--white); padding: 6px 18px; border-radius: 30px; font-size: .85rem; font-weight: 700; margin-bottom: 25px; text-transform: uppercase; }
.hero-70 h2 { font-size: 4rem; font-weight: 800; line-height: 1.1; margin-bottom: 25px; text-shadow: 0 4px 10px rgba(0,0,0,.3); }
.hero-70 p { font-size: 1.25rem; margin-bottom: 40px; opacity: .95; max-width: 80%; }
.hero-actions { display: flex; gap: 20px; flex-wrap: wrap; }
.hero-pagination { position: absolute; right: 25px !important; left: auto !important; top: 50% !important; bottom: auto !important; transform: translateY(-50%); display: flex; flex-direction: column; gap: 12px; z-index: 10; }
.hero-pagination .swiper-pagination-bullet { width: 10px; height: 10px; background: var(--white); opacity: .5; margin: 0 !important; }
.hero-pagination .swiper-pagination-bullet-active { opacity: 1; background: var(--accent-color); transform: scale(1.3); }
.hero-prev, .hero-next { color: var(--white) !important; width: 60px; height: 60px; background: rgba(0,0,0,.3); border-radius: 50%; backdrop-filter: blur(5px); opacity: 0; transition: var(--transition); border: 1px solid rgba(255,255,255,.2); }
.hero-prev::after, .hero-next::after { display: none; }
.hero-prev svg, .hero-next svg { width: 2rem; height: 2rem; }
.hero-slider:hover .hero-prev, .hero-slider:hover .hero-next { opacity: 1; }
.hero-prev:hover, .hero-next:hover { background: var(--accent-color); border-color: var(--accent-color); }

.services-wrapper { margin-top: -80px; position: relative; z-index: 20; }
.services-carousel { padding: 10px !important; }
.service-card-outline { background: var(--white); padding: 35px 20px; text-align: center; border-radius: 12px; color: var(--text-dark); border: 2px solid var(--border-color); display: block; transition: var(--transition); min-height: 180px; }
.service-card-outline svg { width: 3.5rem; height: 3.5rem; color: var(--primary-color); margin-bottom: 15px; transition: var(--transition); }
.service-card-outline h3 { font-size: 1.2rem; font-weight: 600; }
.service-card-outline:hover { border-color: var(--accent-color); transform: translateY(-5px); }
.service-card-outline:hover svg { color: var(--accent-color); transform: scale(1.1); }
.services-prev, .services-next { background: var(--white); width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--border-color); color: var(--primary-color) !important; top: 50%; margin-top: -19px; z-index: 20; box-shadow: 0 4px 10px rgba(0,0,0,.05); transition: var(--transition); }
.services-prev { left: -20px; }
.services-next { right: -20px; }
.services-prev::after, .services-next::after { font-size: 13px !important; font-weight: 700; }
.services-prev:hover, .services-next:hover { background: var(--primary-color); color: var(--white) !important; border-color: var(--primary-color); }

.news-section-padding { padding: 80px 20px; }
.news-calls-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 40px; }
.news-side, .calls-side, .content-column, .single-sidebar-side { min-width: 0; }
.section-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 30px; border-bottom: 2px solid var(--border-color); padding-bottom: 15px; gap: 15px; }
.section-header h1, .section-header h2 { font-size: 2.2rem; color: var(--primary-color); font-weight: 800; }
.news-grid-2x2 { display: grid; grid-template-columns: 1fr 1fr; gap: 25px; }
.news-card-minimal { background: var(--white); border-radius: 12px; overflow: hidden; border: 1px solid var(--border-color); transition: var(--transition); }
.news-card-minimal:hover { border-color: var(--primary-color); transform: translateY(-3px); box-shadow: 0 10px 20px rgba(0,0,0,.05); }
.news-img { height: 200px; background-size: cover; background-position: center; transition: transform .5s ease; }
.news-card-minimal:hover .news-img { transform: scale(1.05); }
.news-info { padding: 20px; background: var(--white); position: relative; z-index: 2; }
.news-info .date { color: var(--accent-color); font-weight: 600; font-size: .85rem; display: flex; align-items: center; gap: 5px; }
.news-info .date svg { width: 16px; height: 16px; }
.news-info h3 { margin-top: 10px; font-size: 1.15rem; line-height: 1.4; color: var(--text-dark); }
.news-info h3 a:hover { color: var(--accent-color); }
.news-info p { margin-top: 10px; color: #475569; }
.calls-side { display: flex; flex-direction: column; }
.calls-box, .box-card { background: #f1f5f9; border-radius: 12px; padding: 25px; border: 1px solid var(--border-color); display: flex; flex-direction: column; }
.box-card { background: var(--white); }
.calls-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; border-bottom: 2px solid #e2e8f0; padding-bottom: 10px; gap: 10px; }
.calls-header-title { display: flex; align-items: center; gap: 10px; color: var(--primary-color); }
.calls-header-title svg { width: 1.8rem; height: 1.8rem; }
.calls-header-title h3, .widget-title { font-size: 1.2rem; font-weight: 700; color: var(--primary-color); }
.calls-nav-top { display: flex; gap: 8px; }
.vert-nav { background: var(--white); border: 1px solid var(--border-color); border-radius: 5px; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text-muted); transition: var(--transition); }
.vert-nav:hover { background: var(--primary-color); color: var(--white); border-color: var(--primary-color); }
.vert-nav svg { width: 1rem; height: 1rem; }
.vertical-calls { height: 340px; width: 100%; overflow: hidden; }
.call-item { padding: 15px; background: var(--white); border-radius: 8px; border: 1px solid var(--border-color); transition: var(--transition); height: auto !important; margin-bottom: 10px; display: flex; flex-direction: column; }
.call-item:hover { border-color: var(--accent-color); box-shadow: 0 4px 10px rgba(0,0,0,.05); transform: translateX(5px); }
.call-date { font-size: .8rem; color: var(--text-muted); font-weight: 600; margin-bottom: 5px; }
.call-item a { color: var(--primary-dark); font-weight: 600; font-size: .95rem; line-height: 1.4; }
.call-item a:hover { color: var(--accent-color); }
.view-all-calls { display: flex; align-items: center; justify-content: flex-end; font-weight: 600; margin-top: 15px; color: var(--primary-color); font-size: .95rem; }
.sidebar-banners { border-radius: 12px; overflow: hidden; box-shadow: 0 5px 15px rgba(0,0,0,.08); min-width: 0; }
.sidebar-banners-plain { box-shadow: none; background: transparent; }
.sidebar-banners-plain .calls-header { margin-bottom: 0; }
.sidebar-banners-plain .sidebar-banner-carousel { margin-top: 20px; }
.sidebar-banner-card { display: block; height: 260px; background-size: cover; background-position: center; position: relative; border-radius: 12px; overflow: hidden; transition: transform .3s ease; }
.sidebar-banner-card:hover { transform: scale(1.02); }
.banner-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.85) 0%, transparent 100%); }
.banner-info { position: absolute; bottom: 0; left: 0; width: 100%; padding: 20px 20px 35px; color: var(--white); z-index: 2; }
.banner-info h4 { font-size: 1.3rem; margin-bottom: 5px; font-weight: 700; }
.banner-info p { font-size: .95rem; color: #d1d5db; }
.sidebar-banner-pagination { bottom: 10px !important; text-align: left !important; padding-left: 20px; }
.sidebar-banner-pagination .swiper-pagination-bullet { background: rgba(255,255,255,.5); width: 8px; height: 8px; }
.sidebar-banner-pagination .swiper-pagination-bullet-active { background: var(--white); }

.open-gov-section { background-color: var(--open-gov-bg); margin: 20px 0; }
.open-gov-padding { padding: 60px 0; }
.border-bottom-light { border-bottom: 1px solid rgba(255,255,255,.2); padding-bottom: 15px; display: flex; justify-content: space-between; align-items: flex-end; }
.border-bottom-light h2 { color: var(--white); }
.gov-nav-arrows { display: flex; gap: 10px; }
.gov-prev, .gov-next { position: static !important; margin: 0 !important; width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,.1); color: var(--white) !important; border: 1px solid rgba(255,255,255,.3); transition: var(--transition); display: flex; align-items: center; justify-content: center; }
.gov-prev::after, .gov-next::after { display: none; }
.gov-prev svg, .gov-next svg { width: 1rem; height: 1rem; }
.gov-prev:hover, .gov-next:hover { background: var(--accent-color); border-color: var(--accent-color); }
.gov-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.gov-click-box { background: var(--open-gov-box-bg); border: 1px solid rgba(255,255,255,.1); border-radius: 12px; padding: 25px 20px; display: flex; flex-direction: column; align-items: center; text-align: center; color: var(--white); transition: var(--transition); min-height: 150px; }
.gov-click-box svg { width: 2.5rem; height: 2.5rem; margin-bottom: 10px; color: rgba(255,255,255,.8); transition: var(--transition); }
.gov-click-box h3 { font-size: 1rem; font-weight: 600; }
.gov-click-box:hover { background: rgba(255,255,255,.15); border-color: rgba(255,255,255,.4); transform: translateY(-5px); }
.gov-click-box:hover svg { color: var(--white); transform: scale(1.1); }

.tourism-padding { padding: 60px 0; }
.turizam-title { font-size: 2.2rem; color: var(--primary-color); font-weight: 800; }
.tourism-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 25px; }
.tour-card { position: relative; border-radius: 12px; overflow: hidden; cursor: pointer; height: 280px; }
.tour-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s ease; }
.tour-card:hover img { transform: scale(1.1); }
.tour-info { position: absolute; bottom: 0; left: 0; width: 100%; padding: 60px 20px 20px; background: linear-gradient(to top, rgba(0,0,0,.92) 0%, transparent 100%); color: var(--white); transition: var(--transition); }
.tour-card:hover .tour-info { padding-bottom: 30px; }
.tour-info h3 { font-size: 1.3rem; font-weight: 700; margin: 0; }
.tour-info p { max-height: 0; overflow: hidden; opacity: 0; transition: var(--transition); color: rgba(255,255,255,.85); }
.tour-card:hover .tour-info p { max-height: 80px; opacity: 1; margin-top: 10px; }

.partner-marquee { background: var(--white); border-top: 1px solid var(--border-color); padding: 15px 0; overflow: hidden; display: flex; align-items: center; }
.partner-track { display: inline-flex; width: max-content; white-space: nowrap; align-items: center; animation: scroll-left 30s linear infinite; }
.partner-track:hover { animation-play-state: paused; }
.partner-track a { color: var(--text-muted); font-weight: 600; font-size: 1rem; text-transform: uppercase; transition: color .3s; display: inline-flex; align-items: center; }
.partner-track a:hover { color: var(--primary-color); }
.partner-track .separator { margin: 0 30px; color: var(--border-color); font-weight: 300; }
.partner-logo { max-height: 46px; width: auto; filter: grayscale(100%); transition: var(--transition); }
.partner-logo-link:hover .partner-logo { filter: grayscale(0%); transform: scale(1.03); }

.premium-footer { background: #0a192f; color: #a8b2d1; padding-top: 60px; }
.footer-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: 40px; margin-bottom: 40px; }
.footer-brand h2 { color: var(--white); margin-bottom: 15px; font-size: 1.6rem; display: flex; align-items: center; gap: 10px; }
.footer-brand h2 svg { width: 1.4rem; height: 1.4rem; }
.social-icons a { background: rgba(255,255,255,.1); width: 35px; height: 35px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; font-size: 1.1rem; margin-right: 10px; margin-top: 15px; color: var(--white); transition: var(--transition); }
.social-icons a svg { width: 1rem; height: 1rem; }
.social-icons a:hover { background: var(--accent-color); transform: translateY(-3px); color: var(--white); }
.footer-links h4, .footer-newsletter h4 { color: var(--white); margin-bottom: 20px; font-size: 1.1rem; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; }
.footer-links ul { list-style: none; }
.footer-links li { margin-bottom: 10px; }
.footer-links a { color: #a8b2d1; display: flex; align-items: center; }
.footer-links a::before { content: "›"; margin-right: 8px; font-size: 1.2rem; color: var(--accent-color); }
.footer-links a:hover { color: var(--white); padding-left: 5px; }
.newsletter-form { display: flex; margin-top: 15px; }
.newsletter-form input { flex: 1; padding: 12px; border: none; border-radius: 8px 0 0 8px; outline: none; background: rgba(255,255,255,.05); color: var(--white); border: 1px solid rgba(255,255,255,.1); }
.newsletter-form button { background: var(--accent-color); color: var(--white); border: none; padding: 0 20px; border-radius: 0 8px 8px 0; cursor: pointer; font-size: 1.2rem; transition: background .3s; }
.newsletter-form button svg { width: 1rem; height: 1rem; }
.newsletter-form button:hover { background: #c32d3a; }
.footer-bottom { background: #020c1b; padding: 20px 0; }
.footer-legal a { color: #a8b2d1; margin-left: 20px; font-size: .9rem; }
.footer-legal a:hover { color: var(--white); }
.back-to-top-btn { position: fixed; bottom: 30px; right: 30px; width: 45px; height: 45px; background-color: var(--accent-color); color: var(--white); border: none; border-radius: 50%; cursor: pointer; box-shadow: 0 4px 15px rgba(0,0,0,.2); display: flex; align-items: center; justify-content: center; z-index: 1000; opacity: 0; visibility: hidden; transform: translateY(20px); transition: all .4s ease; }
.back-to-top-btn svg { width: 1.2rem; height: 1.2rem; }
.back-to-top-btn.visible { opacity: 1; visibility: visible; transform: translateY(0); }
.back-to-top-btn:hover { background-color: #c32d3a; transform: translateY(-5px) scale(1.1); }

.breadcrumbs-bar { background-color: #f1f5f9; padding: 12px 0; border-bottom: 1px solid var(--border-color); margin-top: 0; }
.breadcrumbs-list { list-style: none; display: flex; align-items: center; gap: 10px; font-size: .9rem; color: var(--text-muted); flex-wrap: wrap; }
.breadcrumbs-list li { display: flex; align-items: center; gap: 10px; }
.breadcrumbs-list li a { color: var(--primary-color); display: flex; align-items: center; gap: 5px; font-weight: 500; }
.breadcrumbs-list li a:hover { color: var(--accent-color); }
.breadcrumbs-list li:not(:last-child)::after { content: "/"; color: #cbd5e1; }
.breadcrumbs-list li.active { color: var(--text-dark); font-weight: 600; }
.article-calls-grid, .archive-layout, .page-layout { display: grid; grid-template-columns: 2.5fr 1fr; gap: 40px; }
.archive-layout.no-sidebar, .single-full, .fullwidth-page { grid-template-columns: 1fr; }
.article-header { margin-bottom: 30px; }
.article-main-title { font-size: 2.5rem; color: var(--primary-color); font-weight: 800; line-height: 1.2; margin-bottom: 15px; }
.article-meta { display: flex; align-items: center; gap: 20px; color: var(--text-muted); font-size: .95rem; font-weight: 500; border-top: 1px solid var(--border-color); padding-top: 15px; flex-wrap: wrap; }
.meta-item { display: flex; align-items: center; gap: 6px; }
.meta-item svg { width: 16px; height: 16px; }
.article-featured-image { margin-bottom: 40px; border-radius: 12px; overflow: hidden; box-shadow: 0 5px 20px rgba(0,0,0,.05); }
.article-body { background: var(--white); padding: 40px; border-radius: 12px; border: 1px solid var(--border-color); box-shadow: 0 5px 15px rgba(0,0,0,.02); }
.rich-text p { font-size: 1.1rem; color: #334155; line-height: 1.8; margin-bottom: 20px; }
.rich-text .wp-block-image figcaption, .rich-text figcaption { margin-top: 10px; color: var(--text-muted); font-size: .95rem; text-align: center; }
.rich-text .lead, .rich-text .lead-paragraph, .rich-text p:first-child { font-size: 1.18rem; }
.rich-text h2 { font-size: 1.8rem; color: var(--primary-color); margin: 40px 0 20px; font-weight: 700; }
.rich-text h3 { font-size: 1.4rem; color: var(--primary-dark); margin: 30px 0 15px; }
.rich-text ul, .rich-text ol { margin: 0 0 25px 20px; color: #334155; font-size: 1.1rem; line-height: 1.8; }
.rich-text li { margin-bottom: 10px; }
.rich-text li::marker { color: var(--accent-color); font-weight: bold; }
.rich-text blockquote, .wp-block-quote { background: #f8fafc; border-left: 5px solid var(--accent-color); padding: 25px; margin: 30px 0; font-size: 1.2rem; font-style: italic; color: var(--primary-color); font-weight: 500; border-radius: 0 8px 8px 0; }
.rich-text iframe, .rich-text video, .rich-text .wp-block-embed { max-width: 100%; }
.single-article-main.section-padding, .page-entry-wrap.section-padding, .section-padding.page-layout-wrap { padding-top: 36px; }
.article-share-box { display: flex; align-items: center; gap: 15px; margin-top: 40px; padding-top: 20px; border-top: 1px solid var(--border-color); font-weight: 600; color: var(--text-dark); flex-wrap: wrap; }
.article-share-box .social-icons a { background: var(--bg-light); color: var(--primary-color); margin: 0; }
.article-share-box .social-icons button { background: var(--bg-light); color: var(--primary-color); margin: 0; width: 35px; height: 35px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; border: none; cursor: pointer; transition: var(--transition); }
.article-share-box .social-icons a:hover,
.article-share-box .social-icons button:hover { background: var(--accent-color); color: var(--white); }
.article-share-box .social-icons button svg { width: 1rem; height: 1rem; }
.article-share-box .social-icons button.is-copied { background: #16a34a; color: var(--white); }
.sidebar-news-list { display: flex; flex-direction: column; gap: 20px; }
.sidebar-news-item { display: flex; align-items: center; gap: 15px; transition: var(--transition); }
.sidebar-news-item img { width: 80px; height: 80px; object-fit: cover; border-radius: 8px; transition: var(--transition); }
.sidebar-news-item:hover img { transform: scale(1.05); }
.sidebar-news-item .news-info { flex: 1; padding: 0; background: transparent; }
.sidebar-news-item h3 { font-size: .95rem; margin-top: 5px; transition: var(--transition); }
.sidebar-news-item:hover h3 { color: var(--accent-color); }
.archive-card { display: grid; grid-template-columns: 280px 1fr; background: var(--white); border-radius: 12px; overflow: hidden; border: 1px solid var(--border-color); margin-bottom: 24px; }
.archive-thumb img { width: 100%; height: 100%; object-fit: cover; }
.archive-card-content { padding: 24px; }
.archive-card-content h2 { margin: 10px 0; color: var(--primary-color); }
.archive-card-content p { color: #475569; }
.pagination-wrap { margin-top: 30px; }
.pagination-wrap .nav-links { display: flex; gap: 10px; flex-wrap: wrap; }
.pagination-wrap .page-numbers { display: inline-flex; padding: 10px 14px; background: var(--white); border: 1px solid var(--border-color); border-radius: 8px; }
.pagination-wrap .current, .pagination-wrap .page-numbers:hover { background: var(--accent-color); color: var(--white); border-color: var(--accent-color); }
.not-found-wrap { max-width: 760px; margin: 0 auto; }
.slp-official-box { overflow: hidden; padding: 0; }
.slp-official-image img { width: 100%; height: 240px; object-fit: cover; }
.slp-official-content { padding: 22px; }
.slp-official-role { display: inline-block; margin-bottom: 8px; color: var(--accent-color); font-weight: 700; font-size: .85rem; text-transform: uppercase; letter-spacing: .04em; }
.slp-official-content h3 { font-size: 1.35rem; color: var(--primary-color); margin-bottom: 8px; }
.slp-official-content p { color: #475569; margin-bottom: 16px; }
.slp-documents-section { margin-top: 32px; }
.slp-documents-table { display: flex; flex-direction: column; gap: 12px; padding: 22px; background: var(--white); border: 1px solid var(--border-color); border-radius: 14px; box-shadow: 0 5px 15px rgba(0,0,0,.02); }
.slp-doc-group-title, .slp-doc-subgroup-title { font-weight: 800; color: var(--primary-color); font-size: 1rem; padding: 12px 14px; background: linear-gradient(90deg, rgba(11,61,145,.08), rgba(230,57,70,.05)); border-radius: 10px; }
.slp-doc-subgroup-title { font-size: .95rem; background: #f8fafc; }
.slp-doc-item { display: grid; grid-template-columns: auto 1fr auto; gap: 14px; align-items: center; padding: 16px; border: 1px solid var(--border-color); border-radius: 12px; background: #fbfdff; transition: var(--transition); }
.slp-doc-item:hover { border-color: var(--accent-color); box-shadow: 0 10px 20px rgba(0,0,0,.04); transform: translateY(-2px); }
.slp-doc-icon { width: 46px; height: 46px; border-radius: 12px; background: rgba(11,61,145,.08); display: flex; align-items: center; justify-content: center; color: var(--primary-color); }
.slp-doc-icon svg { width: 1.35rem; height: 1.35rem; }
.slp-doc-main h4 { font-size: 1rem; color: var(--text-dark); margin-bottom: 4px; }
.slp-doc-meta { display: flex; gap: 10px; flex-wrap: wrap; color: var(--text-muted); font-size: .85rem; }
.slp-doc-meta span { padding: 4px 8px; border-radius: 999px; background: #eef2ff; }
.slp-doc-btn { display: inline-flex; align-items: center; justify-content: center; min-width: 110px; padding: 12px 16px; background: var(--accent-color); color: var(--white); border-radius: 999px; font-weight: 700; }
.slp-doc-btn:hover { background: #c32d3a; }

@media (max-width: 1200px) {
    .mega-menu { width: min(700px, 92vw); }
    .gov-grid-4 { grid-template-columns: repeat(3, 1fr); }
    .hero-70 { width: 80%; }
}

@media (max-width: 992px) {
    .header-left { gap: 20px; }
    .nav-list { gap: 15px; }
    .hero-70 { width: 90%; }
    .news-calls-grid, .article-calls-grid, .archive-layout, .page-layout { grid-template-columns: 1fr; }
    .vertical-calls { height: 280px; }
    .sidebar-banners { max-width: 500px; margin: 30px auto 0; }
    .tourism-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-top { grid-template-columns: 1fr 1fr; gap: 40px; }
    .gov-grid-4 { grid-template-columns: repeat(2, 1fr); }
    .article-main-title { font-size: 2.1rem; }
    .article-body { padding: 30px; }
    .archive-card { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .desktop-nav { display: none; }
    .menu-toggle { display: block; }
    .main-header { top: 0; background: var(--white); box-shadow: 0 4px 10px rgba(0,0,0,.1); }
    .news-ticker { display: none; }
    .slp-has-ticker .main-header { top: 0; }
    .header-spacer, .slp-has-ticker .header-spacer { height: 76px; }
    .slp-has-ticker.slp-has-hero .hero-slider { margin-top: 0; height: 85vh; }
    .logo-text h1, .logo h1 { color: var(--text-dark); font-size: 1.5rem; text-shadow: none; }
    .logo-text span, .logo span { color: var(--text-muted); text-shadow: none; }
    .menu-toggle, .icon-btn, .lang-toggle { color: var(--text-dark); border-color: var(--border-color); }
    .search-modal-content { padding-top: 50px; }
    .close-search-modal { top: 10px; right: 20px; }
    .modal-search-form { flex-direction: column; border-radius: 12px; }
    .modal-search-form button { padding: 15px; border-radius: 0 0 12px 12px; }
    .hero-slider { height: 85vh; }
    .hero-overlay { background: linear-gradient(to top, rgba(11,61,145,.95) 0%, rgba(0,0,0,.4) 100%); }
    .hero-70 { width: 100%; padding-right: 0; text-align: center; padding-top: 80px; }
    .hero-70 h2 { font-size: 2.5rem; margin-bottom: 15px; }
    .hero-70 p { font-size: 1.1rem; margin-bottom: 30px; max-width: 100%; }
    .hero-actions { flex-direction: column; gap: 15px; width: 100%; }
    .hero-actions .btn { width: 100%; }
    .hero-pagination, .hero-prev, .hero-next { display: none !important; }
    .services-wrapper { margin-top: 26px; }
    .services-wrapper .swiper { padding-bottom: 60px !important; overflow: hidden !important; }
    .service-card-outline { min-height: 150px; padding: 26px 16px; }
    .service-card-outline svg { width: 2.7rem; height: 2.7rem; }
    .service-card-outline h3 { font-size: 1.05rem; }
    .services-prev, .services-next { top: auto; bottom: 2px; margin-top: 0; width: 40px; height: 40px; }
    .services-prev { left: calc(50% - 54px); }
    .services-next { right: calc(50% - 54px); }
    .news-section-padding { padding: 50px 15px; }
    .news-grid-2x2, .archive-grid { grid-template-columns: 1fr; gap: 20px; }
    .section-header { flex-direction: column; align-items: flex-start; gap: 15px; margin-bottom: 25px; }
    .news-side .section-header { flex-direction: row; align-items: flex-end; justify-content: space-between; }
    .news-side .section-header h2 { font-size: 1.75rem; line-height: 1.1; flex: 1; }
    .news-side .section-header .btn-text { font-size: .95rem; white-space: nowrap; }
    .article-main-title { font-size: 1.8rem; }
    .article-meta { flex-direction: column; align-items: flex-start; gap: 10px; }
    .article-body { padding: 20px; border: none; border-radius: 0; }
    .rich-text blockquote, .wp-block-quote { padding: 15px; font-size: 1.1rem; }
    .slp-documents-table { padding: 16px; }
    .slp-doc-item { grid-template-columns: 1fr; align-items: flex-start; }
    .slp-doc-btn { width: 100%; }
    .open-gov-padding { padding: 34px 0; }
    .gov-grid-4 { grid-template-columns: 1fr 1fr; gap: 15px; }
    .gov-click-box { min-height: 124px; padding: 20px 14px; }
    .gov-click-box svg { width: 2rem; height: 2rem; }
    .gov-click-box h3 { font-size: .95rem; }
    .border-bottom-light { flex-direction: row; align-items: center; justify-content: space-between; gap: 12px; }
    .border-bottom-light h2 { font-size: 1.55rem; }
    .gov-nav-arrows { align-self: auto; }
    .gov-prev, .gov-next { width: 38px; height: 38px; }
    .tourism-padding { padding: 40px 0; }
    .tourism-grid { grid-template-columns: 1fr; }
    .tour-card { height: 240px; }
    .footer-top { grid-template-columns: 1fr; gap: 30px; }
    .footer-bottom .container { flex-direction: column; gap: 15px; text-align: center; }
    .footer-legal a { margin: 0 10px; }
    .back-to-top-btn { bottom: 20px; right: 20px; width: 40px; height: 40px; }
}

@media (max-width: 480px) {
    .hero-70 h2 { font-size: 2.1rem; }
    .gov-grid-4 { grid-template-columns: 1fr; }
    .services-prev { left: calc(50% - 50px); }
    .services-next { right: calc(50% - 50px); }
    .news-side .section-header h2 { font-size: 1.55rem; }
    .news-side .section-header .btn-text { font-size: .88rem; }
}

/* Final polish: header, single content, media credits, footer, sidebar services. */
.slp-no-hero .main-header,
body:not(.home) .main-header { background: rgba(255,255,255,.98); border-bottom: 1px solid rgba(226,232,240,.9); box-shadow: 0 4px 20px rgba(0,0,0,.06); backdrop-filter: blur(10px); }
.slp-has-hero .main-header.scrolled,
.slp-has-hero .main-header.search-active { background: rgba(255,255,255,.98); border-bottom: 0; box-shadow: 0 4px 20px rgba(0,0,0,.08); backdrop-filter: blur(10px); }
.mobile-submenu-title { padding: 12px 15px 6px; color: var(--primary-color); font-weight: 800; font-size: .85rem; text-transform: uppercase; letter-spacing: .04em; }
.single-article-main.section-padding { padding-top: 20px; }
.breadcrumbs-bar + .single-article-main.section-padding { padding-top: 24px; }
.article-header { margin-bottom: 20px; }
.article-header .badge { margin-bottom: 14px; }
.article-meta { padding-top: 12px; }
.article-featured-image { margin-bottom: 24px; }
.rich-text h1, .rich-text h2, .rich-text h3, .rich-text h4, .rich-text h5, .rich-text h6 { clear: both; }
.rich-text h2:first-child, .rich-text h3:first-child, .rich-text p:first-child { margin-top: 0; }
.rich-text p:empty { display: none; }
.rich-text .wp-caption, .rich-text figure, .rich-text .wp-block-image { position: relative; overflow: hidden; border-radius: 12px; margin: 30px 0; }
.rich-text .wp-caption img, .rich-text figure img, .rich-text .wp-block-image img { width: 100%; }
.slp-image-with-overlay { position: relative; overflow: hidden; }
.slp-image-overlay-caption,
.rich-text .wp-caption-text,
.rich-text .wp-block-image figcaption,
.rich-text figcaption { position: absolute; left: 12px; right: 12px; bottom: 12px; width: auto; margin: 0; padding: 9px 12px; border-radius: 10px; background: rgba(2, 12, 27, .78); color: #fff; font-size: .88rem; line-height: 1.4; text-align: left; backdrop-filter: blur(6px); }
.slp-service-list { display: flex; flex-direction: column; gap: 10px; }
.slp-service-list-item { display: flex; align-items: center; gap: 12px; min-height: 58px; padding: 12px 14px; border-radius: 12px; border: 1px solid var(--border-color); background: #f8fafc; color: var(--text-dark); font-weight: 700; }
.slp-service-list-item:hover { border-color: var(--accent-color); background: #fff; transform: translateY(-2px); box-shadow: 0 8px 18px rgba(0,0,0,.05); }
.slp-service-list-icon { flex: 0 0 38px; width: 38px; height: 38px; border-radius: 10px; background: rgba(11,61,145,.08); color: var(--primary-color); display: inline-flex; align-items: center; justify-content: center; }
.slp-service-list-icon svg { width: 1.25rem; height: 1.25rem; }
.slp-service-list-text { flex: 1; line-height: 1.35; }
.single-open-gov-section { margin-top: 34px; }
.single-open-gov-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.single-open-gov-grid .gov-click-box { background: var(--primary-color); min-height: 128px; }
.footer-newsletter { display: none; }
.footer-top { grid-template-columns: 2fr 1fr 1fr 1fr; }
@media (max-width: 992px) { .single-open-gov-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 576px) { .single-open-gov-grid { grid-template-columns: 1fr; } .slp-image-overlay-caption, .rich-text .wp-caption-text, .rich-text .wp-block-image figcaption, .rich-text figcaption { position: static; border-radius: 0 0 12px 12px; background: #0f172a; } }

/* Final refinement pass: hero header, dropdowns, single layout compactness. */
body.home.slp-has-hero .main-header:not(.scrolled):not(.search-active) {
    background: transparent !important;
    border-bottom: 1px solid rgba(255,255,255,.14);
    box-shadow: none;
    backdrop-filter: none;
}
body.home.slp-has-hero .header-spacer { display: none; }
body.home.slp-has-hero .hero-slider { position: relative; z-index: 1; }

.has-dropdown { position: relative; }
.has-dropdown > a svg,
.has-mega > a svg { width: 16px; height: 16px; }
.dropdown-menu {
    position: absolute;
    top: calc(100% - 10px);
    left: 0;
    min-width: 250px;
    list-style: none;
    padding: 12px;
    border-radius: 0 0 14px 14px;
    background: var(--white);
    border-top: 3px solid var(--accent-color);
    box-shadow: 0 12px 28px rgba(15,23,42,.14);
    opacity: 0;
    visibility: hidden;
    transform: translateY(14px);
    transition: var(--transition);
    z-index: 1001;
}
.has-dropdown:hover .dropdown-menu,
.has-dropdown:focus-within .dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.dropdown-menu li { list-style: none; }
.dropdown-menu a {
    display: flex;
    align-items: center;
    padding: 11px 12px;
    color: #475569;
    font-weight: 600;
    border-radius: 10px;
}
.dropdown-menu a:hover {
    color: var(--accent-color);
    background: #f8fafc;
}
.mobile-submenu li a { border-radius: 8px; }

.single-post .breadcrumbs-bar,
.page .breadcrumbs-bar {
    padding: 10px 0;
}
.single-post .single-article-main.section-padding,
.single-post .breadcrumbs-bar + .single-article-main.section-padding {
    padding-top: 0;
}
.single-post .article-header { margin-bottom: 16px; }
.single-post .article-featured-image { margin-bottom: 20px; }

.slp-image-overlay-caption,
.rich-text .wp-caption-text,
.rich-text .wp-block-image figcaption,
.rich-text figcaption {
    left: 16px;
    right: auto;
    bottom: 16px;
    max-width: min(72%, 560px);
    padding: 10px 14px;
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(2, 12, 27, .72), rgba(2, 12, 27, .88));
    box-shadow: 0 10px 25px rgba(2,12,27,.16);
    font-size: .86rem;
}
.article-featured-image img { width: 100%; }

.single-compact-header {
    margin-bottom: 20px;
    padding-bottom: 12px;
    align-items: center;
}
.single-compact-header h2,
.related-posts-section .section-header h2 {
    font-size: 1.35rem;
    line-height: 1.2;
}
.single-open-gov-section { margin-top: 28px; margin-bottom: 20px; }
.single-open-gov-carousel { overflow: hidden; }
.single-open-gov-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.single-open-gov-grid .gov-click-box {
    min-height: 122px;
    padding: 18px 14px;
}
.single-open-gov-grid .gov-click-box h3 { font-size: .98rem; }
.single-gov-nav .gov-prev,
.single-gov-nav .gov-next {
    position: static;
    margin: 0;
    width: 38px;
    height: 38px;
}
.single-gov-nav { display: flex; gap: 8px; }
.single-gov-nav .gov-prev::after,
.single-gov-nav .gov-next::after { display: none; }
.related-posts-section { margin-top: 12px; }
.related-posts-section .section-header { margin-bottom: 20px; }

@media (max-width: 768px) {
    .dropdown-menu { display: none !important; }
    .single-open-gov-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .slp-image-overlay-caption,
    .rich-text .wp-caption-text,
    .rich-text .wp-block-image figcaption,
    .rich-text figcaption {
        max-width: calc(100% - 32px);
    }
}

@media (max-width: 576px) {
    .single-open-gov-grid { grid-template-columns: 1fr; }
    .slp-image-overlay-caption,
    .rich-text .wp-caption-text,
    .rich-text .wp-block-image figcaption,
    .rich-text figcaption {
        position: static;
        max-width: 100%;
        border-radius: 0 0 12px 12px;
        background: #0f172a;
    }
}

/* HOTFIX 1.0.9: keep site container bounded and stop single post width runaway. */
html,
body {
    overflow-x: hidden;
}

.single-post .container {
    width: 100%;
    max-width: 1300px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 20px;
    padding-right: 20px;
    box-sizing: border-box;
}

.single-post .relative-container {
    min-width: 0 !important;
}

.single-post .article-calls-grid,
.single-post .article-content-wrapper,
.single-post .single-sidebar-side,
.single-post .article-body,
.single-post .related-posts-section,
.single-post .single-open-gov-section,
.single-post .single-open-gov-carousel,
.single-post .single-open-gov-carousel .swiper-wrapper,
.single-post .single-open-gov-carousel .swiper-slide,
.single-post .news-grid-2x2,
.single-post .news-card-minimal,
.single-post .news-img-link,
.single-post .news-img {
    min-width: 0 !important;
    max-width: 100% !important;
}

.single-post .article-calls-grid,
.single-post .article-content-wrapper,
.single-post .single-open-gov-section,
.single-post .single-open-gov-carousel,
.single-post .related-posts-section {
    width: 100% !important;
    overflow: hidden !important;
}

.single-post .single-open-gov-carousel .swiper-wrapper {
    box-sizing: border-box;
}

.single-post .single-open-gov-carousel .swiper-slide {
    overflow: hidden !important;
    box-sizing: border-box;
}

.single-post .single-open-gov-grid {
    width: 100% !important;
    min-width: 0 !important;
}

.single-post img,
.single-post iframe,
.single-post video,
.single-post embed,
.single-post object,
.single-post table,
.single-post pre {
    max-width: 100% !important;
}

.single-post pre,
.single-post table {
    overflow-x: auto;
}

@media (max-width: 992px) {
    .single-post .article-calls-grid {
        grid-template-columns: minmax(0, 1fr) !important;
    }
}

/* 1.0.10 focus fix: footer responsive + mobile open-gov 2x2. */
.premium-footer .footer-top {
    align-items: start;
}
.footer-brand,
.footer-links,
.footer-newsletter {
    min-width: 0;
}
.footer-links ul,
.footer-links li {
    min-width: 0;
}
.footer-links a {
    overflow-wrap: anywhere;
}
.footer-bottom .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}
.footer-legal {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px 18px;
}
.footer-legal a {
    margin-left: 0 !important;
}

@media (max-width: 992px) {
    .premium-footer .footer-top {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 34px 28px !important;
    }
    .footer-brand {
        grid-column: 1 / -1;
    }
}

@media (max-width: 640px) {
    .premium-footer {
        padding-top: 42px;
    }
    .premium-footer .footer-top {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 26px 18px !important;
    }
    .footer-brand {
        grid-column: 1 / -1;
    }
    .footer-brand h2 {
        font-size: 1.35rem;
    }
    .footer-links h4,
    .footer-newsletter h4 {
        font-size: .92rem;
        margin-bottom: 12px;
    }
    .footer-links li {
        margin-bottom: 8px;
    }
    .footer-links a {
        font-size: .9rem;
        line-height: 1.35;
    }
    .footer-bottom .container {
        flex-direction: column;
        text-align: center;
    }
    .footer-legal {
        justify-content: center;
    }

    .single-post .single-open-gov-grid,
    .single-open-gov-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 12px !important;
    }
    .single-open-gov-grid .gov-click-box {
        min-height: 112px !important;
        padding: 14px 8px !important;
    }
    .single-open-gov-grid .gov-click-box h3 {
        font-size: .86rem !important;
        line-height: 1.25 !important;
    }
}

@media (max-width: 380px) {
    .premium-footer .footer-top {
        grid-template-columns: 1fr !important;
    }
    .single-post .single-open-gov-grid,
    .single-open-gov-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* 1.0.11 precise hotfix: home hero header, single spacing, footer glyphs, share labels. */
body.home.slp-has-hero .header-spacer {
    display: none !important;
    height: 0 !important;
}
body.home.slp-has-hero .main-header:not(.scrolled):not(.search-active) {
    position: absolute !important;
    top: 0 !important;
    left: 0;
    right: 0;
    background: transparent !important;
    border-bottom: 1px solid rgba(255,255,255,.14) !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
}
body.home.slp-has-ticker.slp-has-hero .main-header:not(.scrolled):not(.search-active) {
    top: 40px !important;
}
body.home.slp-has-hero .main-header.scrolled,
body.home.slp-has-hero .main-header.search-active {
    position: fixed !important;
    top: 0 !important;
    background: rgba(255,255,255,.98) !important;
    border-bottom: 0 !important;
    box-shadow: 0 4px 20px rgba(0,0,0,.08) !important;
    backdrop-filter: blur(10px) !important;
}
body.home.slp-has-ticker.slp-has-hero .hero-slider {
    margin-top: 40px !important;
    height: calc(100vh - 40px);
}

.slp-has-ticker .header-spacer {
    height: 60px !important;
}
.single-post .breadcrumbs-bar {
    padding-top: 0 !important;
    padding-bottom: 10px !important;
}
.single-post .single-article-main.section-padding,
.single-post .breadcrumbs-bar + .single-article-main.section-padding {
    padding-top: 40px !important;
}

.footer-links a::before {
    content: "\203A" !important;
    margin-right: 8px;
    font-size: 1.2rem;
    line-height: 1;
    color: var(--accent-color);
}

.article-share-box .social-share-icons {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.article-share-box .social-share-icons a,
.article-share-box .social-share-icons button {
    width: auto !important;
    min-height: 36px;
    border-radius: 999px !important;
    padding: 0 12px !important;
    gap: 7px;
    font-size: .88rem;
    font-weight: 700;
    text-decoration: none;
}
.article-share-box .social-share-icons a svg,
.article-share-box .social-share-icons button svg {
    width: 1rem;
    height: 1rem;
    flex: 0 0 auto;
}


/* 1.0.12 header/logo/hero precision fix */
body.home.slp-has-ticker.slp-has-hero .main-header:not(.scrolled):not(.search-active) {
    top: 70px !important;
}
body.home.slp-has-ticker.slp-has-hero .hero-slider {
    margin-top: 0 !important;
    height: calc(100vh - 40px) !important;
}

.main-header .container.header-inner,
.header-inner.container {
    max-width: none !important;
    width: 100% !important;
    padding-left: 18px !important;
    padding-right: 28px !important;
}
.header-inner {
    display: grid !important;
    grid-template-columns: minmax(260px, auto) 1fr auto !important;
    align-items: center !important;
    gap: 18px !important;
}
.header-left {
    display: contents !important;
}
.header-left .logo,
.header-left .custom-logo-link + .logo-text,
.logo {
    justify-self: start !important;
}
.header-left .logo,
.header-left > .logo,
.logo {
    gap: 8px !important;
}
.logo .custom-logo-link,
.header-left .custom-logo-link {
    margin-right: 0 !important;
}
.custom-logo {
    max-height: 58px !important;
}
.logo-text h1,
.logo h1 {
    font-size: 1.55rem !important;
    line-height: 1.05 !important;
    margin-bottom: 2px !important;
}
.logo-text span,
.logo span {
    font-size: .84rem !important;
    line-height: 1.15 !important;
}
.desktop-nav {
    justify-self: center !important;
}
.nav-list {
    justify-content: center !important;
    gap: 24px !important;
}
.nav-list > li > a {
    font-size: .98rem !important;
}
.header-right {
    justify-self: end !important;
}

body.home.slp-has-hero .hero-70 {
    padding-top: 130px !important;
}
body.home.slp-has-ticker.slp-has-hero .hero-70 {
    padding-top: 155px !important;
}
body.home .hero-70 .badge {
    margin-bottom: 28px !important;
}
body.home .hero-70 h2 {
    margin-bottom: 28px !important;
}
body.home .hero-70 p {
    margin-bottom: 46px !important;
}

@media (max-width: 992px) {
    .header-inner {
        display: flex !important;
        justify-content: space-between !important;
        gap: 12px !important;
    }
    .header-left {
        display: flex !important;
        gap: 10px !important;
    }
    .desktop-nav {
        display: none !important;
    }
    .main-header .container.header-inner,
    .header-inner.container {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }
    .custom-logo {
        max-height: 48px !important;
    }
    .logo-text h1,
    .logo h1 {
        font-size: 1.28rem !important;
    }
    .logo-text span,
    .logo span {
        font-size: .78rem !important;
    }
    body.home.slp-has-hero .hero-70,
    body.home.slp-has-ticker.slp-has-hero .hero-70 {
        padding-top: 95px !important;
    }
}

@media (max-width: 576px) {
    .main-header .container.header-inner,
    .header-inner.container {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }
    .header-left,
    .logo {
        gap: 7px !important;
    }
    .custom-logo {
        max-height: 42px !important;
    }
    .logo-text h1,
    .logo h1 {
        font-size: 1.08rem !important;
    }
    .logo-text span,
    .logo span {
        font-size: .72rem !important;
    }
    .header-right {
        gap: 8px !important;
    }
    .lang-toggle {
        padding: 8px 10px !important;
        font-size: .78rem !important;
    }
}

/* 1.0.13 emergency rollback: keep header contained and logo intact */
.main-header .container.header-inner,
.header-inner.container {
    max-width: 1300px !important;
    width: auto !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
}
.header-inner {
    display: grid !important;
    grid-template-columns: minmax(280px, 1fr) auto minmax(170px, 1fr) !important;
    align-items: center !important;
    gap: 18px !important;
    height: 90px !important;
}
.main-header.scrolled .header-inner,
.main-header.search-active .header-inner {
    height: 75px !important;
}
.header-left {
    display: flex !important;
    align-items: center !important;
    gap: 0 !important;
    min-width: 0 !important;
}
.header-left .logo,
.logo {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-width: 0 !important;
    justify-self: auto !important;
}
.logo .custom-logo,
.custom-logo {
    max-height: 58px !important;
    width: auto !important;
    flex: 0 0 auto !important;
}
.logo-text h1,
.logo h1 {
    font-size: 1.48rem !important;
    line-height: 1.05 !important;
    margin-bottom: 2px !important;
    white-space: nowrap !important;
}
.logo-text span,
.logo span {
    font-size: .82rem !important;
    line-height: 1.15 !important;
    white-space: nowrap !important;
}
.desktop-nav {
    display: block !important;
    justify-self: center !important;
    grid-column: 2 !important;
}
.nav-list {
    justify-content: center !important;
    gap: 24px !important;
}
.nav-list > li > a {
    font-size: .98rem !important;
}
.header-right {
    justify-self: end !important;
    display: flex !important;
    align-items: center !important;
}
body.home.slp-has-ticker.slp-has-hero .main-header:not(.scrolled):not(.search-active) {
    position: absolute !important;
    top: 70px !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    background: transparent !important;
}
body.home.slp-has-ticker.slp-has-hero .hero-slider {
    margin-top: 0 !important;
    height: calc(100vh - 40px) !important;
}

@media (max-width: 992px) {
    .header-inner {
        display: flex !important;
        justify-content: space-between !important;
        gap: 12px !important;
        height: 76px !important;
    }
    .main-header.scrolled .header-inner,
    .main-header.search-active .header-inner {
        height: 70px !important;
    }
    .main-header .container.header-inner,
    .header-inner.container {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }
    .desktop-nav {
        display: none !important;
    }
    .logo .custom-logo,
    .custom-logo {
        max-height: 46px !important;
    }
    .logo-text h1,
    .logo h1 {
        font-size: 1.2rem !important;
    }
    .logo-text span,
    .logo span {
        font-size: .74rem !important;
    }
}

@media (max-width: 576px) {
    .main-header .container.header-inner,
    .header-inner.container {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }
    .logo .custom-logo,
    .custom-logo {
        max-height: 40px !important;
    }
    .logo-text h1,
    .logo h1 {
        font-size: 1.02rem !important;
    }
    .logo-text span,
    .logo span {
        font-size: .68rem !important;
    }
}


/* 1.0.14 precise header layout: logo left, menu center, actions right */
.main-header .container.header-inner,
.header-inner.container {
    max-width: 1300px !important;
    width: calc(100% - 40px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.header-inner {
    display: grid !important;
    grid-template-columns: minmax(320px, 1fr) auto minmax(220px, 1fr) !important;
    align-items: center !important;
    column-gap: 28px !important;
}
.header-left {
    grid-column: 1 !important;
    justify-self: start !important;
    display: flex !important;
    align-items: center !important;
    min-width: 0 !important;
}
.header-left .logo,
.logo:not(.offcanvas-logo) {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 0 !important;
}
.desktop-nav {
    grid-column: 2 !important;
    justify-self: center !important;
    display: block !important;
    min-width: 0 !important;
}
.nav-list {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 28px !important;
    white-space: nowrap !important;
}
.nav-list > li > a {
    font-size: .96rem !important;
    line-height: 1.2 !important;
}
.header-right {
    grid-column: 3 !important;
    justify-self: end !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    min-width: 0 !important;
}
.logo .custom-logo,
.custom-logo {
    max-height: 56px !important;
    width: auto !important;
}
.logo-text h1,
.logo h1 {
    font-size: 1.46rem !important;
    line-height: 1.05 !important;
    margin: 0 0 2px !important;
    white-space: nowrap !important;
}
.logo-text span,
.logo span {
    font-size: .82rem !important;
    line-height: 1.15 !important;
    white-space: nowrap !important;
}
body.home.slp-has-ticker.slp-has-hero .main-header:not(.scrolled):not(.search-active) {
    position: absolute !important;
    top: 70px !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    background: transparent !important;
}
body.home.slp-has-ticker.slp-has-hero .hero-slider {
    margin-top: 0 !important;
    height: calc(100vh - 40px) !important;
}

@media (max-width: 1100px) {
    .header-inner {
        grid-template-columns: minmax(260px, 1fr) auto minmax(180px, 1fr) !important;
        column-gap: 18px !important;
    }
    .nav-list { gap: 18px !important; }
    .nav-list > li > a { font-size: .9rem !important; }
    .logo-text h1, .logo h1 { font-size: 1.28rem !important; }
    .logo-text span, .logo span { font-size: .76rem !important; }
}

@media (max-width: 992px) {
    .main-header .container.header-inner,
    .header-inner.container {
        width: calc(100% - 24px) !important;
    }
    .header-inner {
        display: flex !important;
        justify-content: space-between !important;
        gap: 12px !important;
    }
    .desktop-nav { display: none !important; }
    .header-right { margin-left: auto !important; }
    .logo .custom-logo, .custom-logo { max-height: 44px !important; }
    .logo-text h1, .logo h1 { font-size: 1.16rem !important; }
    .logo-text span, .logo span { font-size: .72rem !important; }
}

@media (max-width: 576px) {
    .main-header .container.header-inner,
    .header-inner.container {
        width: calc(100% - 20px) !important;
    }
    .header-left .logo,
    .logo:not(.offcanvas-logo) { gap: 7px !important; }
    .logo .custom-logo, .custom-logo { max-height: 38px !important; }
    .logo-text h1, .logo h1 { font-size: 1rem !important; }
    .logo-text span, .logo span { font-size: .66rem !important; }
    .lang-toggle { padding: 8px 10px !important; font-size: .78rem !important; }
    .header-right { gap: 8px !important; }
}

/* 1.0.15 mega menu placement: anchor dropdown to the header container, not the menu item */
.main-header,
.main-header .container.header-inner,
.header-inner.container {
    overflow: visible !important;
}
.main-header .container.header-inner,
.header-inner.container {
    position: relative !important;
}
.desktop-nav .has-mega {
    position: static !important;
}
.desktop-nav .mega-menu {
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
    transform: translateY(14px) !important;
    box-sizing: border-box !important;
}
.desktop-nav .has-mega:hover .mega-menu,
.desktop-nav .has-mega:focus-within .mega-menu {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}
.desktop-nav .mega-grid {
    width: 100% !important;
    box-sizing: border-box !important;
}
@media (max-width: 992px) {
    .desktop-nav .mega-menu {
        display: none !important;
    }
}

/* 1.0.16 final polish: footer columns/social, home president card, mobile sidebar padding, embeds. */
.president-card {
    padding: 0;
    overflow: hidden;
    margin-bottom: 30px;
}
.president-photo {
    height: 210px;
    background: #eef2f7;
}
.president-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.president-content {
    padding: 24px;
}
.president-label {
    display: inline-flex;
    color: var(--accent-color);
    font-size: .82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 8px;
}
.president-content h3 {
    color: var(--primary-color);
    font-size: 1.35rem;
    margin-bottom: 10px;
}
.president-content p {
    color: #475569;
    line-height: 1.6;
    margin-bottom: 16px;
}
.president-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--primary-color);
    font-weight: 800;
}
.president-cta:hover { color: var(--accent-color); }
.president-cta svg { width: 16px; height: 16px; }
.footer-brand .social-icons:empty { display: none; }
.footer-brand .social-icons a[aria-label*="facebook" i],
.footer-brand .social-icons a[aria-label*="instagram" i],
.footer-brand .social-icons a[aria-label*="linkedin" i] { display: inline-flex; }
.rich-text iframe,
.rich-text video,
.rich-text .wp-block-embed,
.rich-text .wp-block-embed__wrapper,
.rich-text .wp-block-video,
.rich-text .wp-block-embed iframe {
    border-radius: 14px;
    overflow: hidden;
}
.rich-text .wp-block-embed iframe,
.rich-text iframe[src*="youtube"],
.rich-text iframe[src*="youtu.be"] {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
}

@media (max-width: 768px) {
    .calls-side,
    .sidebar-banners,
    .sidebar-banner-carousel,
    .sidebar-banner-card,
    .president-card {
        width: 100%;
        max-width: none;
        margin-left: 0;
        margin-right: 0;
        box-sizing: border-box;
    }
    .sidebar-banner-card {
        border-radius: 14px;
    }
    .banner-info {
        left: 20px;
        right: 20px;
        bottom: 20px;
    }
    .news-calls-grid {
        padding-left: 15px;
        padding-right: 15px;
        margin-left: -15px;
        margin-right: -15px;
    }
    .president-content { padding: 20px; }
    .premium-footer .footer-top {
        grid-template-columns: 1fr 1fr !important;
    }
    .premium-footer .footer-brand {
        grid-column: 1 / -1;
    }
}

@media (max-width: 480px) {
    .news-calls-grid {
        padding-left: 18px;
        padding-right: 18px;
        margin-left: -18px;
        margin-right: -18px;
    }
    .sidebar-banner-card { height: 250px; }
    .premium-footer .footer-top {
        grid-template-columns: 1fr 1fr !important;
        gap: 24px 18px !important;
    }
    .footer-links h4 { font-size: .95rem !important; }
    .footer-links a { font-size: .92rem !important; }
}

/* 1.0.18 requested fixes: mobile spacing, lightbox, banner grid, document icons. */
:root { --slp-card-radius: 14px; }
.box-card,
.news-card-minimal,
.calls-box,
.service-card-outline,
.gov-click-box,
.sidebar-widget,
.president-card,
.slp-documents-table { border-radius: var(--slp-card-radius); }
.news-info,
.widget,
.sidebar-widget,
.calls-box,
.article-content-wrapper,
.slp-documents-table { word-break: normal; overflow-wrap: anywhere; }

@media (max-width: 768px) {
    .container { padding-left: 14px !important; padding-right: 14px !important; }
    .section-padding { padding: 44px 0 !important; }
    .news-section-padding, .tourism-padding, .open-gov-padding { padding-top: 36px !important; padding-bottom: 36px !important; }
    .section-header { gap: 12px; margin-bottom: 18px; }
    .section-header h1, .section-header h2 { font-size: clamp(1.35rem, 6vw, 1.85rem) !important; line-height: 1.15 !important; }
    .article-main-title { font-size: clamp(1.55rem, 7vw, 2.15rem) !important; line-height: 1.12 !important; }
    .article-body, .rich-text, .news-info p { font-size: .98rem; line-height: 1.65; }
    .news-card-minimal .news-info { padding: 16px !important; }
    .box-card, .calls-box, .president-content, .sidebar-widget { padding: 18px !important; }
    .news-calls-grid { padding-left: 0 !important; padding-right: 0 !important; margin-left: 0 !important; margin-right: 0 !important; }
    .btn { padding: 12px 20px; font-size: .95rem; }
    .desktop-nav { display: none !important; }
    .header-right .lang-toggle { display: none !important; }
    .header-inner { height: 70px !important; }
    .logo:not(.offcanvas-logo) { gap: 4px !important; }
    .logo:not(.offcanvas-logo) .custom-logo { margin-right: -2px !important; }
    .logo-text h1, .logo h1 { letter-spacing: -.02em; }
}
@media (max-width: 480px) {
    .container { padding-left: 12px !important; padding-right: 12px !important; }
    .section-padding { padding: 34px 0 !important; }
    .news-img { height: 176px !important; }
    .service-card-outline, .gov-click-box { padding: 16px 10px !important; min-height: 112px !important; }
    .service-card-outline h3, .gov-click-box h3 { font-size: .9rem !important; line-height: 1.25 !important; }
    .custom-logo { max-height: 36px !important; }
    .logo-text h1, .logo h1 { font-size: .94rem !important; }
    .logo-text span, .logo span { font-size: .62rem !important; }
}

.offcanvas { max-width: 390px; }
.offcanvas-body { padding-bottom: 18px; }
.offcanvas-footer { margin-top: auto; padding: 18px 22px 24px; border-top: 1px solid var(--border-color); background: linear-gradient(180deg, rgba(248,250,252,.5), #fff); }
.offcanvas-lang-toggle { width: 100%; border: 1px solid var(--border-color); border-radius: 16px; background: var(--primary-color); color: var(--white); padding: 13px 16px; font-weight: 800; cursor: pointer; box-shadow: 0 10px 24px rgba(11,61,145,.18); }
.offcanvas-lang-toggle:hover { background: var(--primary-dark); }

.sidebar-banner-carousel { position: relative; }
.sidebar-banner-prev, .sidebar-banner-next { width: 34px !important; height: 34px !important; border-radius: 999px; background: rgba(255,255,255,.92); color: var(--primary-color); box-shadow: 0 8px 18px rgba(0,0,0,.16); }
.sidebar-banner-prev::after, .sidebar-banner-next::after { display: none; }
.sidebar-banner-prev svg, .sidebar-banner-next svg { width: 18px; height: 18px; }
.sidebar-banner-prev { left: 12px !important; }
.sidebar-banner-next { right: 12px !important; }

.open-gov-banner-section { padding: 24px 0 10px; background: var(--bg-light); }
.open-gov-banner-carousel { overflow: hidden; }
.open-gov-banner-card { display: flex; align-items: center; justify-content: center; position: relative; height: 118px; border-radius: 14px; overflow: hidden; background: var(--white); border: 1px solid var(--border-color); box-shadow: 0 8px 22px rgba(15,23,42,.06); }
.open-gov-banner-card img { width: 100%; height: 100%; object-fit: cover; }
.open-gov-banner-card span { position: absolute; left: 10px; right: 10px; bottom: 10px; border-radius: 10px; padding: 7px 9px; background: rgba(15,23,42,.76); color: #fff; font-weight: 800; font-size: .86rem; text-align: center; }
@media (min-width: 993px) {
    .open-gov-banner-grid { display: grid !important; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 20px; transform: none !important; }
    .open-gov-banner-slide { width: auto !important; margin-right: 0 !important; }
}
@media (max-width: 768px) {
    .open-gov-banner-section { padding: 18px 0 4px; }
    .open-gov-banner-card { height: 104px; }
}

.single-open-gov-section .single-gov-pagination { position: static; margin-top: 16px; }
.single-open-gov-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; grid-auto-rows: 1fr; }
.single-open-gov-grid .gov-click-box { min-height: 118px !important; }
@media (max-width: 768px) { .single-open-gov-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; } }

.slp-doc-item { gap: 14px; }
.slp-doc-icon { width: 54px; height: 54px; border-radius: 14px; background: #eef4ff; color: var(--primary-color); flex: 0 0 54px; display: inline-flex; flex-direction: column; align-items: center; justify-content: center; gap: 1px; }
.slp-doc-icon svg { width: 22px; height: 22px; }
.slp-doc-icon span { font-size: .58rem; font-weight: 900; line-height: 1; letter-spacing: .03em; }
.slp-doc-meta:empty { display: none; }
.slp-doc-meta span { font-weight: 700; color: var(--text-muted); }
@media (max-width: 560px) {
    .slp-documents-table { padding: 12px !important; gap: 10px !important; }
    .slp-doc-item { padding: 12px !important; gap: 10px !important; align-items: center; }
    .slp-doc-icon { width: 46px; height: 46px; flex-basis: 46px; border-radius: 12px; }
    .slp-doc-icon svg { width: 19px; height: 19px; }
    .slp-doc-main h4 { font-size: .94rem !important; line-height: 1.25 !important; }
    .slp-doc-btn { padding: 9px 12px !important; font-size: .84rem !important; }
}

.slp-clickable-image { cursor: zoom-in; }
.slp-lightbox { position: fixed; inset: 0; z-index: 10000; display: flex; align-items: center; justify-content: center; padding: 24px; background: rgba(2,6,23,.88); opacity: 0; visibility: hidden; transition: opacity .22s ease, visibility .22s ease; }
.slp-lightbox.active { opacity: 1; visibility: visible; }
.slp-lightbox img { max-width: min(1120px, 92vw); max-height: 86vh; border-radius: 14px; box-shadow: 0 25px 80px rgba(0,0,0,.35); object-fit: contain; }
.slp-lightbox-close, .slp-lightbox-nav { position: absolute; border: 0; border-radius: 999px; background: rgba(255,255,255,.94); color: #0f172a; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 12px 30px rgba(0,0,0,.22); }
.slp-lightbox-close { top: 20px; right: 20px; width: 42px; height: 42px; font-size: 30px; line-height: 1; }
.slp-lightbox-nav { top: 50%; transform: translateY(-50%); width: 48px; height: 48px; font-size: 42px; line-height: 1; }
.slp-lightbox-prev { left: 20px; }
.slp-lightbox-next { right: 20px; }
.slp-lightbox-count { position: absolute; left: 50%; bottom: 18px; transform: translateX(-50%); padding: 6px 12px; border-radius: 999px; background: rgba(255,255,255,.92); color: #0f172a; font-size: .85rem; font-weight: 800; }
@media (max-width: 640px) {
    .slp-lightbox { padding: 12px; }
    .slp-lightbox img { max-width: 94vw; max-height: 78vh; }
    .slp-lightbox-nav { width: 40px; height: 40px; font-size: 34px; }
    .slp-lightbox-prev { left: 10px; }
    .slp-lightbox-next { right: 10px; }
    .slp-lightbox-close { top: 12px; right: 12px; }
}


/* 1.0.19 polish update: mobile/nav/sidebar/home requested refinements. */
.hero-content.hero-70 {
    max-width: min(100%, 1080px) !important;
}
.hero-content h2 {
    text-wrap: balance;
    max-width: 100%;
}
.calls-box {
    background: linear-gradient(180deg, #0b3d91 0%, #082e6e 100%);
    color: #fff;
    border-color: rgba(255,255,255,.12);
}
.calls-box .calls-header-title,
.calls-box .calls-header-title h3,
.calls-box .calls-header-title svg,
.calls-box .call-date,
.calls-box .call-item a,
.calls-box .view-all-calls,
.calls-box .view-all-calls svg {
    color: #fff !important;
}
.calls-box .call-item {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.14);
}
.calls-box .call-item:hover {
    background: rgba(255,255,255,.14);
}
.calls-box .vert-nav {
    background: rgba(255,255,255,.14);
    color: #fff;
    border-color: rgba(255,255,255,.18);
}
.calls-box .vert-nav:hover { background: rgba(255,255,255,.22); }
.president-card {
    background: linear-gradient(180deg, #143d80 0%, #0a2f67 100%);
    border-color: rgba(255,255,255,.08);
    box-shadow: 0 18px 40px rgba(11,61,145,.18);
}
.president-photo {
    position: relative;
    height: 260px;
}
.president-photo::after {
    content: "";
    position: absolute;
    inset: auto 0 0 0;
    height: 48%;
    background: linear-gradient(180deg, rgba(2,6,23,0) 0%, rgba(2,6,23,.82) 100%);
}
.president-photo-overlay {
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 16px;
    z-index: 2;
}
.president-label {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.16);
    border: 1px solid rgba(255,255,255,.2);
    color: #fff;
    backdrop-filter: blur(6px);
    margin-bottom: 0;
}
.president-label-static { margin-bottom: 12px; }
.president-content { color: rgba(255,255,255,.9); }
.president-content h3,
.president-content p,
.president-cta,
.president-cta svg { color: #fff; }
.president-content p { opacity: .9; }
.president-cta:hover { color: #dbeafe; }

.nav-list { gap: 10px !important; }
.nav-list > li > a {
    padding: 11px 14px !important;
    border-radius: 999px !important;
    transition: var(--transition);
}
.nav-list > li > a::after { display: none !important; }
.nav-list > li > a:hover,
.nav-list > li.is-active > a,
.nav-list > li > a[aria-current="page"] {
    color: var(--accent-color) !important;
    background: rgba(230,57,70,.1);
}
.slp-has-hero .main-header:not(.scrolled):not(.search-active) .nav-list > li > a:hover,
.slp-has-hero .main-header:not(.scrolled):not(.search-active) .nav-list > li.is-active > a {
    background: rgba(255,255,255,.15);
    color: #fff !important;
}
.dropdown-menu {
    padding: 14px !important;
    border-radius: 18px !important;
    min-width: 280px;
}
.dropdown-menu li + li { margin-top: 6px; }
.dropdown-menu a,
.mobile-submenu li a,
.mega-col a {
    border-radius: 999px;
    font-weight: 700 !important;
}
.dropdown-menu a:hover,
.dropdown-menu li.is-active a,
.mobile-submenu li.is-active a,
.mobile-submenu-parent.is-active a,
.mega-col a:hover,
.mega-col a.is-active {
    background: rgba(11,61,145,.09) !important;
    color: var(--primary-color) !important;
}
.mega-menu {
    border-radius: 18px !important;
    padding: 26px !important;
    box-shadow: 0 22px 45px rgba(15,23,42,.14) !important;
}
.mega-grid {
    gap: 20px !important;
    align-items: start !important;
}
.mega-col {
    min-width: 0;
}
.mega-col h4 {
    font-size: 1.16rem !important;
    font-weight: 800 !important;
    margin-bottom: 14px !important;
}
.mega-col p {
    color: #334155 !important;
    font-weight: 600;
    line-height: 1.55;
}
.mega-col a {
    margin-bottom: 6px;
    padding: 11px 13px !important;
    color: #334155 !important;
}
.highlight-col {
    border-radius: 16px !important;
    background: linear-gradient(180deg, #f8fbff 0%, #f1f5f9 100%) !important;
}
.offcanvas-logo .logo-text h1,
.offcanvas-logo h1 {
    font-size: 1.48rem !important;
}
.offcanvas-logo .logo-text span,
.offcanvas-logo span {
    font-size: .8rem !important;
}
.mobile-nav > li {
    border-bottom: 0;
    margin-bottom: 8px;
}
.mobile-dropdown-header,
.mobile-nav > li > a {
    width: 100%;
}
.mobile-nav > li > a,
.mobile-dropdown-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    width: 100%;
    padding: 14px 16px;
    border: 0;
    background: #f8fafc;
    color: var(--text-dark);
    font-size: 1.06rem;
    font-weight: 800;
    border-radius: 16px;
    text-align: left;
}
.mobile-dropdown.is-active > .mobile-dropdown-header .mobile-dropdown-toggle,
.mobile-nav > li.is-active > a {
    background: rgba(11,61,145,.08);
    color: var(--primary-color);
}
.mobile-dropdown-toggle .submenu-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    background: rgba(11,61,145,.08);
    color: var(--primary-color);
    flex: 0 0 34px;
    transition: transform .2s ease;
}
.mobile-dropdown.is-open .mobile-dropdown-toggle .submenu-btn { transform: rotate(180deg); }
.mobile-submenu {
    padding: 10px !important;
    margin-top: 8px;
    border-radius: 16px !important;
    overflow: hidden;
}
.mobile-submenu li a {
    padding: 11px 13px !important;
    font-size: .98rem !important;
}
.mobile-submenu-title {
    padding: 8px 12px 6px !important;
}
.mobile-submenu-parent a {
    background: rgba(11,61,145,.06);
    color: var(--primary-color) !important;
}
.offcanvas-body,
.offcanvas,
.mobile-nav,
.mobile-submenu,
.mobile-dropdown,
.mobile-dropdown-header {
    overflow-x: hidden;
}

.single-sidebar-side .sidebar-banner-carousel,
.single-sidebar-side .sidebar-banners {
    position: relative;
}

@media (max-width: 768px) {
    .hero-pagination {
        right: 50% !important;
        left: 50% !important;
        top: auto !important;
        bottom: 18px !important;
        transform: translateX(-50%) !important;
        flex-direction: row !important;
        gap: 10px !important;
        width: auto !important;
        padding: 8px 12px;
        border-radius: 999px;
        background: rgba(2,6,23,.28);
        backdrop-filter: blur(6px);
    }
    .hero-pagination .swiper-pagination-bullet {
        width: 9px;
        height: 9px;
    }
    .header-left .logo,
    .logo:not(.offcanvas-logo) {
        gap: 4px !important;
    }
    .logo .custom-logo,
    .custom-logo {
        max-height: 46px !important;
    }
    .logo-text h1,
    .logo h1 {
        font-size: 1.12rem !important;
    }
    .logo-text span,
    .logo span {
        font-size: .7rem !important;
    }
    .offcanvas-logo .custom-logo { max-height: 58px !important; }
    .services-carousel .swiper-slide {
        height: auto;
    }
    .gov-grid-4,
    .single-open-gov-grid {
        grid-template-columns: repeat(2, minmax(0,1fr)) !important;
    }
    .turizam-title {
        font-size: 1.5rem !important;
        white-space: nowrap;
    }
    .tourism-grid {
        display: grid !important;
        grid-auto-flow: column;
        grid-auto-columns: 86%;
        grid-template-columns: none !important;
        gap: 14px !important;
        overflow-x: auto;
        padding-bottom: 8px;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
    }
    .tourism-grid > * {
        min-width: 0;
        scroll-snap-align: start;
    }
    .tourism-grid::-webkit-scrollbar { display: none; }
}
@media (max-width: 640px) {
    .container {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }
    .header-inner { height: 74px !important; }
    .hero-content h2 {
        font-size: clamp(1.9rem, 8vw, 2.6rem) !important;
        line-height: 1.05 !important;
    }
    .hero-content p {
        font-size: .96rem;
    }
    .logo .custom-logo,
    .custom-logo {
        max-height: 48px !important;
    }
    .logo-text h1,
    .logo h1 {
        font-size: 1.18rem !important;
    }
    .logo-text span,
    .logo span {
        font-size: .73rem !important;
    }
    .service-card-outline {
        min-height: 122px !important;
    }
    .services-wrapper .services-prev,
    .services-wrapper .services-next,
    .gov-nav-arrows,
    .hero-prev,
    .hero-next {
        display: none !important;
    }
    .single-sidebar-side .sidebar-banner-prev,
    .single-sidebar-side .sidebar-banner-next,
    .sidebar-banners .sidebar-banner-prev,
    .sidebar-banners .sidebar-banner-next {
        display: flex !important;
    }
}


/* 1.0.20 follow-up mobile/header/menu refinements. */
.hero-content.hero-70 {
    max-width: 100% !important;
}
.hero-content h2 {
    width: 100%;
    max-width: 100% !important;
}
@media (min-width: 993px) {
    .hero-content h2 {
        white-space: nowrap;
    }
}
.hero-pagination {
    display: flex !important;
}
.dropdown-menu a {
    padding: 11px 14px !important;
    color: #334155 !important;
}
.dropdown-menu a:hover,
.dropdown-menu li.is-active a,
.nav-list > li.is-active > a,
.nav-list > li > a:hover,
.mega-col a:hover,
.mega-col a.is-active {
    box-shadow: inset 0 0 0 1px rgba(11, 61, 145, .08);
}
.mega-grid {
    align-items: stretch !important;
}
.mega-col {
    display: flex;
    flex-direction: column;
    min-width: 0;
}
.mega-col h4 {
    padding-bottom: 10px;
    border-bottom: 1px solid #e2e8f0;
}
.mega-col a {
    color: #334155 !important;
    line-height: 1.35;
}
.highlight-col {
    padding: 18px !important;
}
.highlight-col h4 {
    color: var(--primary-color) !important;
}
.highlight-col p,
.highlight-col a {
    color: #334155 !important;
    font-weight: 700;
}
.highlight-col .btn-text {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 11px 14px;
    border-radius: 999px;
    background: rgba(11, 61, 145, .08);
}
.vertical-slider-wrap {
    touch-action: pan-y;
}
.mobile-submenu li a,
.mobile-submenu-parent a {
    white-space: normal;
    word-break: break-word;
}
.single-sidebar-side .sidebar-banner-carousel {
    overflow: hidden;
}
@media (max-width: 768px) {
    .hero-pagination {
        display: flex !important;
        right: 50% !important;
        left: 50% !important;
        top: auto !important;
        bottom: 14px !important;
        transform: translateX(-50%) !important;
        flex-direction: row !important;
        gap: 10px !important;
        width: auto !important;
    }
    .header-inner {
        height: 76px !important;
    }
    .header-left .logo,
    .logo:not(.offcanvas-logo) {
        gap: 2px !important;
        align-items: center;
    }
    .logo .custom-logo,
    .custom-logo {
        max-height: 54px !important;
    }
    .logo-text h1,
    .logo h1 {
        font-size: 1.28rem !important;
        line-height: 1.02 !important;
    }
    .logo-text span,
    .logo span {
        font-size: .79rem !important;
        line-height: 1.08 !important;
    }
    .offcanvas-logo .logo-text h1,
    .offcanvas-logo h1 {
        font-size: 1.68rem !important;
    }
    .offcanvas-logo .logo-text span,
    .offcanvas-logo span {
        font-size: .9rem !important;
    }
    .services-carousel {
        padding: 6px 0 12px !important;
    }
    .services-carousel .swiper-slide {
        height: auto !important;
    }
    .service-card-outline {
        min-height: 118px !important;
        padding: 18px 10px !important;
    }
    .service-card-outline h3 {
        font-size: .92rem !important;
        line-height: 1.25 !important;
    }
    .gov-grid-4,
    .single-open-gov-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
    .calls-box .vertical-slider-wrap {
        overflow: hidden;
    }
    .turizam-title {
        font-size: 1.26rem !important;
        white-space: nowrap;
    }
}
@media (max-width: 640px) {
    .hero-content h2 {
        font-size: clamp(1.6rem, 6vw, 2.15rem) !important;
        line-height: 1.08 !important;
        white-space: normal !important;
        text-wrap: balance;
    }
    .logo .custom-logo,
    .custom-logo {
        max-height: 58px !important;
    }
    .logo-text h1,
    .logo h1 {
        font-size: 1.36rem !important;
    }
    .logo-text span,
    .logo span {
        font-size: .84rem !important;
    }
    .offcanvas-logo .custom-logo {
        max-height: 66px !important;
    }
    .offcanvas-logo .logo-text h1,
    .offcanvas-logo h1 {
        font-size: 1.78rem !important;
    }
    .offcanvas-logo .logo-text span,
    .offcanvas-logo span {
        font-size: .94rem !important;
    }
}


/* 1.0.21 final follow-up: mega wrap, centered nav, mobile scroll UX. */
@media (min-width: 993px) {
    .header-inner {
        display: grid !important;
        grid-template-columns: auto 1fr auto;
        align-items: center;
    }
    .desktop-nav {
        justify-self: center;
        width: 100%;
        display: flex;
        justify-content: center;
    }
    .desktop-nav .nav-list {
        justify-content: center;
        flex-wrap: nowrap;
    }
}
.mega-menu,
.mega-grid,
.highlight-col,
.highlight-col p {
    min-width: 0;
}
.highlight-col p,
.mega-col p,
.dropdown-menu a,
.mega-col a {
    white-space: normal !important;
    overflow-wrap: anywhere;
    word-break: normal;
}
.highlight-col p {
    max-width: 100%;
    line-height: 1.55 !important;
}
.services-wrapper .swiper {
    overflow: visible;
}
.open-gov-pagination {
    position: static !important;
    margin-top: 18px;
    text-align: center;
}
.open-gov-pagination .swiper-pagination-bullet,
.single-gov-pagination .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    background: rgba(255,255,255,.5);
    opacity: 1;
}
.open-gov-pagination .swiper-pagination-bullet-active,
.single-gov-pagination .swiper-pagination-bullet-active {
    background: #fff;
    transform: scale(1.15);
}
.single-gov-pagination {
    display: none !important;
}
.page .article-featured-image,
.page .slp-image-with-overlay {
    margin-bottom: 24px;
}
@media (max-width: 768px) {
    .breadcrumbs-bar .container {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    .breadcrumbs-list {
        flex-wrap: nowrap !important;
        white-space: nowrap;
        width: max-content;
        min-width: 100%;
        padding-bottom: 2px;
    }
    .breadcrumbs-list::-webkit-scrollbar,
    .breadcrumbs-bar .container::-webkit-scrollbar {
        display: none;
    }
    .article-share-box {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }
    .article-share-box > span {
        display: block;
        text-align: left;
    }
    .article-share-box .social-share-icons {
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 10px;
    }
    .article-share-box .social-share-icons a,
    .article-share-box .social-share-icons button {
        width: 100% !important;
        min-height: 70px;
        border-radius: 18px !important;
        padding: 10px 6px !important;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 8px;
        text-align: center;
        line-height: 1.15;
    }
    .article-share-box .social-share-icons a svg,
    .article-share-box .social-share-icons button svg {
        width: 1.15rem;
        height: 1.15rem;
    }
    .services-wrapper {
        overflow: hidden;
    }
    .services-carousel {
        overflow: visible !important;
        padding-right: 22px !important;
    }
    .services-carousel .swiper-slide {
        width: auto;
    }
    .open-gov-section .gov-nav-arrows {
        display: flex !important;
    }
    .open-gov-section .gov-prev,
    .open-gov-section .gov-next {
        display: flex !important;
    }
    .single-open-gov-section .single-gov-nav,
    .single-open-gov-section .single-gov-prev,
    .single-open-gov-section .single-gov-next {
        display: flex !important;
    }
}
@media (max-width: 640px) {
    .services-wrapper .services-prev,
    .services-wrapper .services-next,
    .hero-prev,
    .hero-next {
        display: none !important;
    }
    .open-gov-section .gov-nav-arrows,
    .single-open-gov-section .single-gov-nav {
        display: flex !important;
    }
}


/* 1.0.33 calls ordering, overlay icon decorations, hero center fix */
.hero-slide .relative-container,
.hero-slide .flex-align-center {
    justify-content: center;
}
.hero-slide .hero-content {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}
.hero-slide .hero-actions,
.hero-slide .badge {
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
}

.calls-box,
.gov-click-box,
.service-card-outline {
    position: relative;
    overflow: hidden;
    isolation: isolate;
}
.calls-box::before,
.gov-click-box::before,
.service-card-outline::before {
    content: "";
    position: absolute;
    inset: auto -16px -26px auto;
    width: 120px;
    height: 120px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    opacity: .075;
    transform: rotate(-18deg);
    pointer-events: none;
    z-index: 0;
}
.calls-box::before {
    inset: 28px -6px auto auto;
    width: 150px;
    height: 150px;
    opacity: .07;
    transform: rotate(-20deg);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m3 11 18-5v12L3 14v-3z'/%3E%3Cpath d='M11.6 16.8a3 3 0 1 1-5.8 1.6l.6-4.4'/%3E%3Cpath d='M6 12V8'/%3E%3C/svg%3E");
}
.gov-click-box::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 21h18'/%3E%3Cpath d='M5 21V7l7-4 7 4v14'/%3E%3Cpath d='M9 9h.01'/%3E%3Cpath d='M15 9h.01'/%3E%3Cpath d='M9 13h.01'/%3E%3Cpath d='M15 13h.01'/%3E%3Cpath d='M10 21v-4h4v4'/%3E%3C/svg%3E");
    opacity: .065;
}
.service-card-outline::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230b3d91' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 2v20'/%3E%3Cpath d='M2 12h20'/%3E%3Cpath d='m4.93 4.93 14.14 14.14'/%3E%3Cpath d='m19.07 4.93-14.14 14.14'/%3E%3C/svg%3E");
    opacity: .045;
}
.calls-box > *,
.gov-click-box > *,
.service-card-outline > * {
    position: relative;
    z-index: 1;
}
.vertical-calls {
    height: 344px;
    overflow: hidden;
}
.vertical-calls .swiper-wrapper {
    align-items: flex-start;
}
.call-item {
    margin-bottom: 0;
    min-height: 0;
}
.vertical-calls .swiper-slide {
    height: auto !important;
}
.calls-box .call-item:first-child {
    scroll-margin-top: 0;
}
.calls-box .call-item:hover {
    transform: translateX(3px);
}
@media (max-width: 768px) {
    .vertical-calls {
        height: 344px;
    }
    .calls-box::before {
        width: 120px;
        height: 120px;
        top: 18px;
        right: -8px;
    }
    .gov-click-box::before,
    .service-card-outline::before {
        width: 96px;
        height: 96px;
    }
}
