/* =========================================================
   GEORGIAN FONTS
   ========================================================= */
@font-face {
    font-family: 'mrgvlovani B';
    src: url('/assets/fonts/bpg_mrgvlovani_caps_2010.ttf') format('truetype');
}
@font-face {
    font-family: 'BPG Ingiri Arial';
    src: url('/assets/fonts/bpg-ingiri-arial-webfont.woff2') format('woff2'),
         url('/assets/fonts/bpg-ingiri-arial-webfont.woff') format('woff'),
         url('/assets/fonts/bpg-ingiri-arial-webfont.ttf') format('truetype');
}
@font-face {
    font-family: 'ALK Life';
    src: url('/assets/fonts/alk-life-webfont.woff2') format('woff2'),
         url('/assets/fonts/alk-life-webfont.woff') format('woff'),
         url('/assets/fonts/alk-life-webfont.ttf') format('truetype');
}
@font-face {
    font-family: 'BPG Web 001 Caps';
    src: url('/assets/fonts/bpg-web-001-caps-webfont.woff2') format('woff2'),
         url('/assets/fonts/bpg-web-001-caps-webfont.woff') format('woff'),
         url('/assets/fonts/bpg-web-001-caps-webfont.ttf') format('truetype');
}

:root {
    --topbar-bg:  #2dbfe0;
    --header-bg:  #4396c9;
    --footer-bg:  #6f4792;
    --partners-bg:#8b41c7;
    --btn-grad1:  #7b56e6;
    --btn-grad2:  #371681;
    --text: #333;
    --light-bg: #f5f5f5;
}

* { box-sizing: border-box; }
body { font-family: 'mrgvlovani B', 'BPG Ingiri Arial', 'Segoe UI', sans-serif; color: var(--text); margin: 0; padding: 0; }
a { text-decoration: none; }

/* =========================================================
   TOP BAR
   ========================================================= */
#sp-top-bar {
    background-color: #2dbfe0 !important;
    color: #d4d4d4;
    padding: 6px 0;
}
.site-logo img { height: 60px; }
.logo-text-fallback { color: #fff; font-size: 1.1rem; font-weight: 700; }
.topbar-social { display: inline-block; margin-right: 6px; }
.topbar-social img { vertical-align: middle; }
.navbar-toggler-mobile {
    background: none; border: 1px solid rgba(255,255,255,0.5);
    color: #fff; padding: 4px 10px; border-radius: 4px; font-size: 1.1rem;
}

/* =========================================================
   DESKTOP NAV
   ========================================================= */
#sp-header {
    background-color: var(--header-bg);
    position: sticky; top: 0; z-index: 1000;
}
.sp-megamenu-parent {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-wrap: wrap;
}
.sp-megamenu-parent > .sp-menu-item > a {
    display: block;
    color: rgba(255,255,255,0.92);
    padding: 0 14px;
    height: 52px; line-height: 52px;
    font-size: 0.88rem;
    white-space: nowrap;
    transition: background 0.15s;
}
.sp-megamenu-parent > .sp-menu-item > a:hover,
.sp-megamenu-parent > .sp-menu-item.current-item > a {
    background: rgba(255,255,255,0.15);
    color: #fff;
}

/* Dropdown */
.sp-menu-item { position: relative; }
.sp-dropdown {
    display: none;
    position: absolute; top: 100%; left: 0;
    background: #fff;
    min-width: 240px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.15);
    border-radius: 0 0 6px 6px;
    z-index: 2000;
}
.sp-dropdown ul { list-style: none; margin: 0; padding: 6px 0; }
.sp-dropdown ul li { position: relative; }
.sp-dropdown ul li a {
    display: block; padding: 9px 18px;
    color: #333; font-size: 0.87rem;
}
.sp-dropdown ul li a:hover { background: #f0f4ff; color: var(--header-bg); }

/* Sub-dropdown */
.sp-dropdown-sub {
    top: 0; left: 100%;
}

/* Show on hover */
.sp-menu-item:hover > .sp-dropdown,
.sp-dropdown li:hover > .sp-dropdown { display: block; }

/* =========================================================
   MOBILE NAV
   ========================================================= */
.mobile-nav {
    background: var(--header-bg);
    padding: 10px 0;
}
.mobile-nav ul { list-style: none; margin: 0; padding: 0; }
.mobile-nav ul li a {
    display: block; padding: 10px 20px;
    color: rgba(255,255,255,0.9); font-size: 0.9rem;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}
.mobile-nav ul li ul { padding-left: 16px; background: rgba(0,0,0,0.1); }
.mobile-nav ul li ul li a { padding: 8px 20px; font-size: 0.85rem; }

/* =========================================================
   MAIN CONTENT WRAPPER
   ========================================================= */
.main-content { min-height: 60vh; }

/* =========================================================
   WELCOME / HERO SECTION
   ========================================================= */
/* Welcome two-column layout */
.welcome-columns {
    display: flex;
    gap: 24px;
    align-items: stretch;
}
.welcome-slider {
    flex: 1 1 66.666%;
}
.welcome-panels {
    flex: 0 0 calc(33.333% - 24px);
    min-width: 220px;
}
@media (max-width: 767px) {
    .welcome-columns { flex-direction: column; gap: 4px; }
    .welcome-slider, .welcome-panels { flex: none; width: 100%; }
}

.welcome-section {
    background: #d8d0d0 url('/assets/img/bg-vector.png') center center repeat-y;
    background-size: 100%;
    position: relative;
    z-index: 10;
}

/* GK Image Show (gk_hotel_tabs) overrides */
.gkIsWrapper-gk_hotel_tabs figcaption { top: 35%; padding-left: 40px; }
.gkIsWrapper-gk_hotel_tabs {
    height: 450px;
    overflow: hidden;
    width: 100%;
}
.gkIsWrapper-gk_hotel_tabs figure {
    height: 450px;
}
.gkIsWrapper-gk_hotel_tabs .gkIsSlide {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 450px;
}
.gkIsWrapper-gk_hotel_tabs .gkIsPreloader {
    width: 100%;
}

/* Quick Panels */
.quick-panels {
    display: flex; flex-direction: column; height: 450px; overflow: hidden;
    gap: 4px;
}
.col-md-4 .quick-panels { height: 100%; min-height: 450px; }
.quick-panel {
    flex: 1;
    position: relative;
    background-size: cover; background-position: center;
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
    border-radius: 10px;
}
.quick-panel-overlay {
    position: absolute; inset: 0;
    background: rgba(0,0,0,0.2);
}
.quick-panel-btn {
    position: relative; z-index: 1;
    background: linear-gradient(45deg, var(--btn-grad1), var(--btn-grad2));
    color: #fff; border: none;
    padding: 12px 28px; font-size: 1rem; font-weight: 600;
    border-radius: 50px;
    transition: opacity 0.2s;
}
.quick-panel-btn:hover { opacity: 0.88; color: #fff; }

/* =========================================================
   NEWS CAROUSEL SECTION
   ========================================================= */
.news-carousel-section { background: var(--topbar-bg); }
.news-carousel-header {
    padding: 14px 0 8px;
}
.news-carousel-header h2 {
    margin: 0; font-size: 1.1rem; font-weight: 700; color: var(--footer-bg);
}
.news-carousel-header h2 a { color: var(--footer-bg); }
.news-carousel-header h2 a:hover { color: var(--partners-bg); }

.news-slide-item { padding: 4px; }
.news-slide-img { height: 160px; overflow: hidden; border-radius: 4px; }
.news-slide-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.news-slide-title { padding: 6px 2px; }
.news-slide-title h3 { font-size: 0.8rem; margin: 0; line-height: 1.3; }
.news-slide-title h3 a { color: #fff; }
.news-slide-title h3 a:hover { color: var(--footer-bg); }

/* Splide override */
.news-carousel-section .splide__pagination__page { background: rgba(0,0,0,0.3); }
.news-carousel-section .splide__pagination__page.is-active { background: var(--footer-bg); }

/* =========================================================
   PARTNERS SECTION
   ========================================================= */
#sp-partners {
    background-color: var(--partners-bg);
    padding: 24px 0;
}
.partner-logo {
    max-height: 65px; max-width: 150px;
    object-fit: contain;
    background-color: #fff;
    border-radius: 6px;
    padding: 4px 8px;
    opacity: 0.9;
    transition: opacity 0.2s;
}
.partner-logo:hover { opacity: 1; }
.partner-logo-main {
    max-height: 82px; max-width: 180px;
}
.partners-title {
    color: #fff; font-size: 20px; font-weight: 600; margin: 0;
    white-space: nowrap;
}

/* =========================================================
   FOOTER
   ========================================================= */
#sp-footer {
    background-color: var(--footer-bg);
    color: #fff; padding: 16px 0;
    font-size: 0.85rem;
}
.sp-copyright { color: rgba(255,255,255,0.9); }

/* =========================================================
   INTERIOR PAGES
   ========================================================= */
.page-title {
    font-size: 1.7rem; font-weight: 700; margin: 28px 0 20px;
    color: var(--header-bg);
}
.page-title i { margin-right: 8px; }

.breadcrumb-bar {
    background: #eef2f7; padding: 10px 0; font-size: 0.85rem;
    margin-bottom: 0;
}
.breadcrumb-bar .breadcrumb { margin: 0; }
.breadcrumb-item a { color: var(--header-bg); }
.breadcrumb-item.active { color: #666; }

.article-meta { color: #888; font-size: 0.85rem; }
.article-image { border-radius: 8px; width: 100%; height: auto; margin-bottom: 24px; display: block; }
.article-body {
    font-size: 1rem; line-height: 1.85;
    background: rgba(0,0,0,0.035);
    border-radius: 10px;
    padding: 28px 32px;
}
.article-body.small { padding: 14px 16px; border-radius: 8px; }
.article-body img { max-width: 100%; border-radius: 6px; }
.article-body p { margin-bottom: 1rem; }
.article-body table { width: 100%; border-collapse: collapse; margin: 1rem 0; font-size: 0.9rem; }
.article-body table td, .article-body table th { border: 1px solid #ddd; padding: 7px 10px; }
.article-body table th { background: var(--header-bg); color: #fff; }
.article-body table tr:nth-child(even) { background: #f5f8fb; }
@media (max-width: 576px) {
    .article-body { padding: 18px 20px; }
}

/* News Cards (news.php, etc.) */
.news-card { border: none; border-radius: 10px; overflow: hidden; box-shadow: 0 2px 10px rgba(0,0,0,0.07); height: 100%; transition: transform 0.2s; }
.news-card:hover { transform: translateY(-3px); }
.news-card img { width: 100%; height: 200px; object-fit: cover; }
.news-card .card-body { padding: 16px; }
.news-date { font-size: 0.77rem; color: #999; }
.news-card .card-title { font-size: 0.92rem; font-weight: 600; margin: 6px 0; }
.news-card .card-title a { color: var(--text); }
.news-card .card-title a:hover { color: var(--header-bg); }
.read-more { color: var(--header-bg); font-size: 0.82rem; font-weight: 600; }
.no-img-placeholder { width: 100%; height: 200px; background: #edf2f7; display: flex; align-items: center; justify-content: center; color: #bbb; font-size: 2rem; }

/* Project cards (projects.php) — logos/banners can be wide, so show them at full size, uncropped */
.project-card-row { border: none; border-radius: 10px; overflow: hidden; box-shadow: 0 2px 10px rgba(0,0,0,0.07); transition: transform 0.2s; }
.project-card-row:hover { transform: translateY(-3px); }
.project-img-wrap { width: 100%; background: #f4f6f9; }
.project-img-wrap img.project-img { display: block; width: 100%; height: auto; }

/* Mini news list (e.g. projects.php sidebar) */
.news-mini-item {
    display: flex; align-items: center; gap: 12px;
    margin-bottom: 14px; color: var(--text, #333);
}
.news-mini-item:last-child { margin-bottom: 0; }
.news-mini-item img,
.news-mini-noimg {
    width: 64px; height: 64px; flex: 0 0 64px;
    border-radius: 6px; object-fit: cover;
}
.news-mini-noimg {
    background: #edf2f7; display: flex; align-items: center; justify-content: center;
    color: #bbb; font-size: 1.2rem;
}
.news-mini-title { font-size: 0.87rem; font-weight: 600; line-height: 1.35; }
.news-mini-item:hover .news-mini-title { color: var(--header-bg); }

/* Section title */
.section-title { font-size: 1.4rem; font-weight: 700; color: var(--header-bg); padding-bottom: 10px; margin-bottom: 24px; position: relative; }
.section-title::after { content: ''; position: absolute; bottom: 0; left: 0; width: 48px; height: 3px; background: var(--footer-bg); border-radius: 2px; }

/* Pagination */
.pagination .page-link { color: var(--header-bg); border-color: #c8dcf0; }
.pagination .page-item.active .page-link { background: var(--header-bg); border-color: var(--header-bg); }

/* List group */
.list-group-item-action:hover { background: #eef4fb; color: var(--header-bg); }

/* Admin sidebar */
.admin-sidebar { background: #2d2b4e; min-height: 100vh; padding: 20px 0; width: 220px; min-width: 220px; }
.admin-sidebar .nav-link { color: rgba(255,255,255,0.75); border-radius: 6px; margin: 2px 12px; }
.admin-sidebar .nav-link:hover { color: #fff; background: rgba(255,255,255,0.12); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 767px) {
    .gkIsWrapper-gk_hotel_tabs,
    .gkIsWrapper-gk_hotel_tabs figure,
    .gkIsWrapper-gk_hotel_tabs .gkIsSlide { height: 260px; }
    .quick-panels { height: auto; flex-direction: row; }
    .quick-panel { height: 120px; }
    .quick-panel-btn { font-size: 0.8rem; padding: 7px 14px; }
    .page-title { font-size: 1.3rem; }
}
@media (max-width: 480px) {
    .gkIsWrapper-gk_hotel_tabs,
    .gkIsWrapper-gk_hotel_tabs figure,
    .gkIsWrapper-gk_hotel_tabs .gkIsSlide { height: 200px; }
    .quick-panels { flex-direction: column; }
    .quick-panel { height: 100px; }
}
