/* ======================================
   GALLERY PAGE (galeri.html)
   ====================================== */

body[data-page="gallery"] {
  --gallery-header-offset: 96px;
  --gallery-accent: #4A9AB5;
  --gallery-bg: #F4F8F9;
  --gallery-text: #1B2D3A;
}

body[data-page="gallery"] main.gallery-main {
  padding-top: var(--gallery-header-offset);
  background: transparent;
  color: var(--gallery-text);
}

/* HERO */
body[data-page="gallery"] .gallery-hero {
  position: relative;
  overflow: hidden;
  height: clamp(280px, 34vh, 420px);
  display: flex;
  align-items: flex-end;
}

body[data-page="gallery"] .gallery-hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

body[data-page="gallery"] .gallery-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15,17,19,0.3) 0%, rgba(15,17,19,0.7) 70%);
  z-index: 2;
}

body[data-page="gallery"] .gallery-hero__content {
  position: relative;
  z-index: 3;
  padding: clamp(18px, 4vw, 48px) 0;
  color: var(--gallery-text);
}

body[data-page="gallery"] .gallery-hero .breadcrumb {
  color: rgba(234,241,245,0.78);
  margin-bottom: 10px;
}

body[data-page="gallery"] #galleryTitle {
  margin: 0;
  font-size: clamp(28px, 4.6vw, 48px);
  line-height: 1.02;
  color: #fff;
  font-weight: 700;
}

/* FILTER BAR */
body[data-page="gallery"] .gallery-filters {
  padding: 14px 0 22px;
}

body[data-page="gallery"] .filter-row {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: space-between;
}

body[data-page="gallery"] .tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

body[data-page="gallery"] .tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.03);
  color: rgba(234,241,245,0.92);
  border: 1px solid rgba(255,255,255,0.03);
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

body[data-page="gallery"] .tab:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 18px rgba(15,17,19,0.45);
}

body[data-page="gallery"] .tab.is-active {
  background: var(--gallery-accent);
  color: var(--txt);
  border-color: rgba(74,154,181,0.18);
  box-shadow: 0 8px 30px rgba(74,154,181,0.12);
}

body[data-page="gallery"] .filter-search input[type="search"] {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.04);
  color: var(--gallery-text);
  padding: 10px 12px;
  border-radius: 10px;
  min-width: 180px;
}

/* GALLERY GRID */
body[data-page="gallery"] .gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  align-items: stretch;
}

body[data-page="gallery"] .gallery-card {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  background: rgba(255,255,255,0.02);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  border: 1px solid rgba(255,255,255,0.03);
  cursor: pointer;
}

body[data-page="gallery"] .gallery-card img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  display: block;
}

body[data-page="gallery"] .gallery-card .card-overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 12px 14px;
  background: linear-gradient(180deg, rgba(15,17,19,0) 0%, rgba(15,17,19,0.6) 70%);
  color: #fff;
}

body[data-page="gallery"] .gallery-card h3 {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
}

body[data-page="gallery"] .gallery-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 40px rgba(6,8,10,0.6);
  border-color: rgba(74,154,181,0.14);
}

/* LIGHTBOX */
body[data-page="gallery"] .lightbox {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

body[data-page="gallery"] .lightbox.is-open {
  display: flex;
}

body[data-page="gallery"] .lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(6,8,10,0.85);
}

body[data-page="gallery"] .lightbox__content {
  position: relative;
  z-index: 2;
  max-width: 92vw;
  max-height: 92vh;
  padding: 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

body[data-page="gallery"] .lightbox__content img {
  width: auto;
  max-width: 100%;
  max-height: calc(92vh - 140px);
  border-radius: 8px;
}

body[data-page="gallery"] .lightbox__close {
  position: absolute;
  right: 8px;
  top: 8px;
  background: rgba(27,45,58,0.08);
  color: var(--txt);
  border: none;
  width: 40px;
  height: 40px;
  border-radius: 8px;
  font-size: 20px;
  cursor: pointer;
}

/* RESPONSIVE */
@media (max-width: 1024px) {
  body[data-page="gallery"] .gallery-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  body[data-page="gallery"] {
    --gallery-header-offset: 80px;
  }
  body[data-page="gallery"] .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  body[data-page="gallery"] .gallery-card img { height: 220px; }
  body[data-page="gallery"] .filter-search input[type="search"] { min-width: 140px; }
}

@media (max-width: 480px) {
  body[data-page="gallery"] {
    --gallery-header-offset: 74px;
  }
  body[data-page="gallery"] .gallery-grid { grid-template-columns: 1fr; }
  body[data-page="gallery"] .gallery-card img { height: 180px; }
  body[data-page="gallery"] .filter-row { flex-direction: column; align-items: stretch; gap: 12px; }
}

/* ======================================
   ACTIVITY DETAIL PAGE (faaliyet-detay)
   ====================================== */

body[data-page="activity-detail"] {
  --activity-header-offset: 96px;
  color: var(--txt);
}

body[data-page="activity-detail"] main.activity-detail-main {
  padding-top: var(--activity-header-offset);
}

body[data-page="activity-detail"] .activity-detail-hero {
  position: relative;
  height: clamp(280px, 34vh, 420px);
  width: 100%;
  overflow: hidden;
  display: block;
}

body[data-page="activity-detail"] .activity-detail-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15,17,19,0.45) 0%, rgba(15,17,19,0.65) 60%);
  pointer-events: none;
  z-index: 2;
}

body[data-page="activity-detail"] .activity-detail-hero__img,
body[data-page="activity-detail"] #activityHeroImg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  will-change: transform;
}

body[data-page="activity-detail"] .activity-detail-header {
  padding: clamp(18px, 3vw, 32px) 0 12px;
  color: var(--txt);
}

body[data-page="activity-detail"] .breadcrumb {
  display: flex;
  gap: 10px;
  align-items: center;
  color: var(--muted);
  font-size: 0.95rem;
  margin-bottom: 8px;
}

body[data-page="activity-detail"] .breadcrumb a {
  color: var(--muted);
  text-decoration: none;
}

body[data-page="activity-detail"] .breadcrumb .breadcrumb__sep {
  color: rgba(27,45,58,0.35);
}

body[data-page="activity-detail"] .activity-detail-title {
  margin: 0;
  font-weight: 700;
  color: var(--txt);
  line-height: 1.05;
  font-size: clamp(28px, 4.4vw, 44px);
  letter-spacing: -0.02em;
}

body[data-page="activity-detail"] .activity-detail-content {
  padding: 18px 0 36px;
}

body[data-page="activity-detail"] .activity-detail-body {
  max-width: 1180px;
  margin: 0 auto;
  color: var(--txt);
  font-size: 1rem;
  line-height: 1.65;
  background: transparent;
  word-wrap: break-word;
}

body[data-page="activity-detail"] .activity-detail-body p {
  margin: 0 0 1rem 0;
}

body[data-page="activity-detail"] .activity-detail-cta-section {
  padding: 18px 0 48px;
}

body[data-page="activity-detail"] .activity-detail-cta-section .btn {
  display: inline-block;
  text-align: center;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  body[data-page="activity-detail"] {
    --activity-header-offset: 80px;
  }

  body[data-page="activity-detail"] .activity-detail-hero {
    height: clamp(220px, 30vh, 340px);
  }

  body[data-page="activity-detail"] .activity-detail-title {
    font-size: clamp(22px, 6.5vw, 32px);
  }

  body[data-page="activity-detail"] .activity-detail-body {
    padding: 0 18px;
  }
}

@media (max-width: 480px) {
  body[data-page="activity-detail"] {
    --activity-header-offset: 74px;
  }

  body[data-page="activity-detail"] .activity-detail-hero {
    height: clamp(200px, 28vh, 300px);
  }

  body[data-page="activity-detail"] .breadcrumb {
    font-size: 0.9rem;
  }

  body[data-page="activity-detail"] .activity-detail-title {
    font-size: 20px;
  }

  body[data-page="activity-detail"] .activity-detail-body {
    font-size: 0.98rem;
    padding: 0 14px;
  }
}

:root{
  --bg:#F4F8F9;
  --txt:#1B2D3A;
  --muted:rgba(27,45,58,.6);
  --brand:#4A9AB5;
  --shadow:0 18px 55px rgba(27,45,58,.08);
  --header-h:72px;
  --container:1180px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Arial;
  background:var(--bg);
  color:var(--txt);
}

/* HEADER */
.site-header{
  position:fixed;
  top:0; left:0; right:0;
  height:var(--header-h);
  background:rgba(255,255,255,.92);
  backdrop-filter: blur(14px);
  border-bottom:1px solid rgba(27,45,58,.08);
  z-index:999;
}

.header-inner{
  height:100%;
  width:min(var(--container), calc(100% - 40px));
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:24px;
}

/* MENU TOGGLE BUTTON */
.menu-toggle{
  display:none;
  flex-shrink:0;
  width:44px;
  height:44px;
  border:none;
  background:rgba(27,45,58,.06);
  border-radius:999px;
  color:rgba(27,45,58,.78);
  cursor:pointer;
  align-items:center;
  justify-content:center;
  padding:0;
  transition: all 0.3s ease;
}
.menu-toggle:hover{
  background:rgba(27,45,58,.12);
  color:#1B2D3A;
}
.menu-toggle:focus{
  outline:none;
  box-shadow: 0 0 0 3px rgba(74,154,181,.25);
}

/* BRAND/LOGO */
.brand{
  display:flex;
  align-items:center;
  flex-shrink:0;
  text-decoration:none;
}
.brand img{
  width:clamp(90px, 12vw, 120px);
  height:auto;
  display:block;
  image-rendering:crisp-edges;
}

@media (min-width: 1101px){
  .brand{
    margin-left:-10px;
  }
}

/* NAVIGATION */
.nav{
  display:flex;
  gap:32px;
  align-items:center;
  flex:1;
  margin:0 auto;
  justify-content:center;
}

.nav-link{
  color:rgba(27,45,58,.78);
  text-decoration:none;
  font-weight:600;
  font-size:14px;
  letter-spacing:.3px;
  white-space:nowrap;
  position:relative;
  transition: color 0.3s ease;
}
.nav-link:hover{
  color:#1B2D3A;
}
.nav-link.active::after{
  content:'';
  position:absolute;
  bottom:-8px;
  left:0;
  right:0;
  height:2px;
  background:var(--brand);
  border-radius:1px;
}

/* Mobile icons bar (visible only on mobile) */
.mobile-icons-bar{
  display:none;
  gap:8px;
  align-items:center;
  flex-shrink:0;
}

/* Mobile menu (visible only when toggled on mobile) */
.mobile-menu{
  display:none;
}
.mobile-menu.mobile-open{
  display:flex;
  position:absolute;
  top:var(--header-h);
  left:0;
  right:0;
  flex-direction:column;
  gap:8px;
  padding:16px 20px;
  background:rgba(255,255,255,.98);
  border-bottom:1px solid rgba(27,45,58,.08);
  z-index:998;
  max-height:calc(100vh - var(--header-h));
  overflow-y:auto;
}
.mobile-menu.mobile-open .nav-link{
  padding:10px 0;
  font-size:15px;
}

/* Show mobile menu section */
.mobile-menu.mobile-open .mobile-menu-section{
  display:block;
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid rgba(27,45,58,.08);
}
.mobile-menu.mobile-open .mobile-quick-actions{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-bottom:12px;
}
.mobile-menu.mobile-open .mobile-menu-section .nav-link{
  padding:10px 0;
}

.mobile-menu .mobile-submenu__trigger{
  width:100%;
  text-align:left;
  border:1px solid rgba(27,45,58,.12);
  border-radius:10px;
  background:rgba(244,248,249,.8);
  color:#1B2D3A;
  padding:10px 12px;
  font-weight:700;
}
.mobile-menu .mobile-submenu__trigger:hover,
.mobile-menu .mobile-submenu__trigger:focus-visible{
  border-color:rgba(74,154,181,.52);
  background:rgba(244,248,249,.95);
  outline:none;
}

.mobile-menu.mobile-open .mobile-menu-section{
  display:grid;
  gap:10px;
}
.mobile-menu.mobile-open .mobile-menu-section > .nav-link{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:40px;
  border:1px solid rgba(27,45,58,.12);
  border-radius:12px;
  background:rgba(244,248,249,.8);
  color:#1B2D3A;
  font-weight:700;
  text-decoration:none;
}
.mobile-menu.mobile-open .mobile-menu-section > .btn.btn-swiss{
  display:flex;
  width:100%;
  min-height:42px;
  justify-content:center;
  border-radius:12px;
  margin-top:0;
}

/* HEADER RIGHT SECTION */
.header-right{
  display:flex;
  align-items:center;
  margin-left:auto;
  gap:12px;
  flex-shrink:0;
  min-width:0;
}
.header-right > .btn-pill,
.header-right > .lang-dropdown{
  order:1;
}
.header-right > .icon-btn{
  order:2;
}

/* Desktop quick actions (cart + user) aligned to the far right */
.header-quick-actions{
  display:flex;
  align-items:center;
  gap:10px;
  order:3;
  margin-left:auto;
  padding-left:12px;
  border-left:1px solid rgba(255,255,255,.14);
}

/* ICON BUTTONS */
.icon-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border:1px solid rgba(27,45,58,.12);
  background:rgba(27,45,58,.05);
  border-radius:999px;
  color:rgba(27,45,58,.78);
  cursor:pointer;
  transition: all 0.3s ease;
  padding:0;
  position:relative;
  text-decoration:none;
}
.icon-btn:hover{
  background:rgba(27,45,58,.10);
  color:#1B2D3A;
}
.icon-btn:focus{
  outline:none;
  box-shadow: 0 0 0 3px rgba(74,154,181,.25);
}

/* CART BADGE */
.badge{
  position:absolute;
  top:-6px;
  right:-6px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:20px;
  height:20px;
  padding:0 5px;
  border-radius:999px;
  background:#ffd700;
  color:#000;
  font-weight:700;
  font-size:11px;
  line-height:1;
}

/* BANK BUTTON */
.btn-pill{
  padding:0 16px;
  height:38px;
  background:transparent;
  border:1px solid rgba(27,45,58,.18);
  border-radius:999px;
  color:rgba(27,45,58,.82);
  font-size:13px;
  font-weight:600;
  white-space:nowrap;
  transition: all 0.3s ease;
}
.btn-pill:hover{
  background:rgba(27,45,58,.06);
  border-color:rgba(27,45,58,.28);
  color:#1B2D3A;
}

.btn-swiss{
  background:linear-gradient(90deg, #d52b1e 0 33%, #ffffff 33% 67%, #d52b1e 67% 100%);
  border-color:#d52b1e;
  color:#111;
  font-size:14px;
  font-weight:600;
  letter-spacing:.3px;
}
.btn-swiss:hover{
  background:linear-gradient(90deg, #e13a2e 0 33%, #ffffff 33% 67%, #e13a2e 67% 100%);
  border-color:#e13a2e;
  color:#111;
}
.btn-swiss:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(213,43,30,.35);
}

/* LANGUAGE DROPDOWN */
.lang-dropdown{
  position:relative;
}
.lang-dropdown-toggle{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 12px;
  border:1px solid rgba(27,45,58,.12);
  border-radius:999px;
  background:#fff;
  color:#1B2D3A;
  cursor:pointer;
  font-weight:700;
  font-size:12px;
  transition:all .25s ease;
  white-space:nowrap;
}
.lang-dropdown-toggle:hover{
  border-color:rgba(27,45,58,.25);
  background:rgba(27,45,58,.03);
}
.lang-dropdown-toggle:focus{
  outline:none;
  box-shadow:0 0 0 3px rgba(74,154,181,.25);
}
.lang-globe{
  flex-shrink:0;
  opacity:.55;
}
.lang-chevron{
  flex-shrink:0;
  opacity:.45;
  transition:transform .25s ease;
}
.lang-dropdown.is-open .lang-chevron{
  transform:rotate(180deg);
}
.lang-dropdown-menu{
  display:none;
  position:absolute;
  top:calc(100% + 6px);
  right:0;
  min-width:155px;
  background:#fff;
  border:1px solid rgba(27,45,58,.1);
  border-radius:12px;
  box-shadow:0 8px 28px rgba(27,45,58,.12);
  padding:6px;
  list-style:none;
  margin:0;
  z-index:9999;
  animation:langDropIn .18s ease;
}
@keyframes langDropIn{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:translateY(0)}
}
.lang-dropdown.is-open .lang-dropdown-menu{
  display:block;
}
.lang-option{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 12px;
  border-radius:8px;
  cursor:pointer;
  font-size:13px;
  color:rgba(27,45,58,.7);
  font-weight:600;
  transition:all .15s ease;
}
.lang-option:hover{
  background:rgba(27,45,58,.05);
  color:#1B2D3A;
}
.lang-option.is-active{
  background:rgba(74,154,181,.1);
  color:#1B2D3A;
}
.lang-option .lang-code{
  display:inline-block;
  width:26px;
  font-weight:800;
  font-size:11px;
  letter-spacing:.5px;
  color:rgba(27,45,58,.45);
}
.lang-option.is-active .lang-code{
  color:#4A9AB5;
}
.lang-option .lang-label{
  flex:1;
}
.lang-option.is-active::after{
  content:'';
  width:6px;
  height:6px;
  border-radius:50%;
  background:#4A9AB5;
  flex-shrink:0;
}

/* RTL support */
html[dir="rtl"] .site-header{direction:rtl;}
html[dir="rtl"] .header-inner{direction:rtl;}
html[dir="rtl"] .nav{direction:rtl;}
html[dir="rtl"] .header-right{direction:rtl;}
html[dir="rtl"] .lang-dropdown-menu{right:auto;left:0;}
html[dir="rtl"] body{direction:rtl;text-align:right;}
html[dir="rtl"] .breadcrumb{direction:rtl;}
html[dir="rtl"] .footer{direction:rtl;text-align:right;}

/* Keep old class names as aliases for backward-compat (mobile code) */
.lang-group{display:none !important;}
.mobile-lang-group .lang-btn{display:none !important;}

@media (max-width: 1360px){
  .header-inner{
    gap:18px;
  }
  .nav{
    gap:22px;
  }
  .header-right{
    gap:10px;
  }
  .btn-pill{
    padding:0 13px;
    font-size:12px;
  }
  .lang-dropdown-toggle{
    padding:6px 10px;
    font-size:11px;
  }
}

/* Mobile language group (inside mobile menu) */
.mobile-lang-group{
  margin-top:12px;
}

.mobile-menu-section .btn-swiss{
  margin-top:8px;
  align-self:flex-start;
}

/* Injected with JS: language pills in mobile header */
.mobile-lang-inline{
  display:none;
}

/* BUTTONS */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  height:40px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid rgba(27,45,58,.12);
  background:rgba(27,45,58,.06);
  color:#1B2D3A;
  text-decoration:none;
  font-weight:700;
  font-size:13px;
}
.btn:hover{ background:rgba(27,45,58,.10); }
.btn-ghost{
  background:transparent;
  border-color:rgba(27,45,58,.14);
}

.btn.btn-swiss{
  background:linear-gradient(90deg, #d52b1e 0 33%, #ffffff 33% 67%, #d52b1e 67% 100%);
  border-color:#d52b1e;
  color:#111;
}
.btn.btn-swiss:hover{
  background:linear-gradient(90deg, #e13a2e 0 33%, #ffffff 33% 67%, #e13a2e 67% 100%);
  border-color:#e13a2e;
  color:#111;
}

/* HELP PAGE */
body[data-page="help"]{
  background:var(--bg);
  color:var(--txt);
}
body[data-page="help"] .help-main{
  padding-top:calc(var(--header-h) + 32px);
  padding-bottom:64px;
}
body[data-page="help"] .help-hero{
  padding:24px 0 20px;
}
body[data-page="help"] .help-title{
  margin:0;
  font-size:clamp(28px, 4vw, 44px);
  font-weight:700;
}
body[data-page="help"] .help-subtitle{
  margin:10px 0 0;
  max-width:720px;
  color:var(--muted);
  font-weight:600;
}
body[data-page="help"] .help-panel{
  margin-top:24px;
  padding:18px 20px;
  background:#fff;
  border:1px solid rgba(27,45,58,.08);
  border-radius:12px;
}
body[data-page="help"] .help-panel a{
  color:var(--brand);
  text-decoration:none;
}
body[data-page="help"] .help-panel a:hover{
  color:#1B2D3A;
}

body[data-page="help"] .help-kicker{
  margin:0 0 8px;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--brand);
  font-weight:700;
}

body[data-page="help"] .help-catalog{
  padding:10px 0 32px;
}

body[data-page="help"] .donation-block{
  margin-top:26px;
  padding:22px;
  border:1px solid rgba(74,154,181,.18);
  border-radius:20px;
  background:#fff;
  box-shadow:0 8px 32px rgba(27,45,58,.06);
}

body[data-page="help"] .donation-block__head h2{
  margin:0;
  font-size:clamp(22px, 3vw, 34px);
  letter-spacing:-.01em;
}

body[data-page="help"] .donation-block__lead{
  margin:8px 0 0;
  font-size:18px;
  font-weight:700;
  color:#1B2D3A;
}

body[data-page="help"] .donation-block__desc{
  margin:10px 0 0;
  color:var(--muted);
  line-height:1.65;
  max-width:940px;
}

body[data-page="help"] .donation-steps{
  margin:16px 0 0;
  padding:0;
  list-style:none;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

body[data-page="help"] .donation-steps li{
  min-width:132px;
  display:flex;
  align-items:center;
  gap:8px;
  border:1px solid rgba(74,154,181,.18);
  border-radius:999px;
  padding:8px 12px;
  background:rgba(74,154,181,.06);
}

body[data-page="help"] .donation-steps li strong{
  width:24px;
  height:24px;
  border-radius:50%;
  display:grid;
  place-items:center;
  font-size:13px;
  background:rgba(74,154,181,.28);
  border:1px solid rgba(74,154,181,.56);
}

body[data-page="help"] .donation-include{
  margin:14px 0 0;
  color:#1B2D3A;
}

body[data-page="help"] .donation-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}

body[data-page="help"] .donation-grid--single{
  grid-template-columns:minmax(0, 1fr);
  max-width:420px;
}

body[data-page="help"] .donation-card{
  border:1px solid rgba(74,154,181,.15);
  border-radius:16px;
  padding:16px;
  background:#fff;
  display:flex;
  flex-direction:column;
  gap:8px;
}

body[data-page="help"] .donation-card--featured{
  border-color:rgba(74,154,181,.4);
  box-shadow:0 10px 30px rgba(74,154,181,.08);
}

body[data-page="help"] .donation-badge{
  margin:0 0 2px;
  display:inline-block;
  width:max-content;
  border-radius:999px;
  border:1px solid rgba(74,154,181,.3);
  color:var(--brand);
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:5px 10px;
  background:rgba(74,154,181,.08);
}

body[data-page="help"] .donation-card h3{
  margin:0;
  font-size:20px;
}

body[data-page="help"] .donation-price{
  margin:0;
  font-size:18px;
  color:#1B2D3A;
  font-weight:700;
}

body[data-page="help"] .donation-note{
  margin:0;
  color:var(--muted);
}

body[data-page="help"] .donation-btn{
  margin-top:auto;
  width:max-content;
}

body[data-page="help"] .donation-actions{
  margin-top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

body[data-page="help"] .donation-list{
  margin:0;
  padding-left:18px;
  display:grid;
  gap:6px;
  color:var(--txt);
}

body[data-page="help"] .donation-custom-label{
  font-size:13px;
  color:var(--muted);
}

body[data-page="help"] .donation-custom-input{
  border:1px solid rgba(74,154,181,.22);
  border-radius:10px;
  background:#fff;
  color:var(--txt);
  padding:10px 12px;
}

body[data-page="help"] .donation-custom-input:focus{
  outline:0;
  border-color:rgba(74,154,181,.56);
  box-shadow:0 0 0 3px rgba(74,154,181,.12);
}

@media (max-width: 960px){
  body[data-page="help"] .donation-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px){
  body[data-page="help"] .donation-block{
    padding:16px;
    border-radius:16px;
  }

  body[data-page="help"] .donation-grid{
    grid-template-columns:minmax(0, 1fr);
  }

  body[data-page="help"] .donation-steps li{
    min-width:0;
    flex:1 1 120px;
  }
}

/* KURBAN INFO CARDS */
body[data-page="help"] .help-kurban-info{
  padding:56px 0 48px;
}

body[data-page="help"] .kurban-info-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:16px;
}

body[data-page="help"] .kurban-info-card{
  background:#fff;
  border:1px solid rgba(27,45,58,.06);
  border-radius:6px;
  padding:32px 28px;
  display:flex;
  gap:20px;
  align-items:flex-start;
  transition:all .3s ease;
}

body[data-page="help"] .kurban-info-card:hover{
  box-shadow:0 16px 48px rgba(27,45,58,.08);
  border-color:rgba(74,154,181,.2);
}

body[data-page="help"] .kurban-info-icon{
  width:56px;
  height:56px;
  min-width:56px;
  border-radius:6px;
  background:var(--brand);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
}

body[data-page="help"] .kurban-info-body{
  flex:1;
}

body[data-page="help"] .kurban-info-card h3{
  font-size:17px;
  font-weight:700;
  color:var(--txt);
  margin:0 0 6px;
  letter-spacing:-.2px;
}

body[data-page="help"] .kurban-info-card p{
  font-size:14px;
  line-height:1.65;
  color:var(--muted);
  margin:0;
}

/* KURBAN YEAR GALLERY */
body[data-page="help"] .help-kurban-gallery{
  padding:64px 0 56px;
}

body[data-page="help"] .kurban-gallery-header{
  text-align:center;
  margin-bottom:40px;
}

body[data-page="help"] .kurban-gallery-title{
  font-size:clamp(26px, 3.5vw, 38px);
  font-weight:800;
  color:var(--txt);
  margin:0 0 10px;
  letter-spacing:-.4px;
}

body[data-page="help"] .kurban-gallery-subtitle{
  font-size:16px;
  color:var(--muted);
  margin:0 0 28px;
  max-width:540px;
  margin-left:auto;
  margin-right:auto;
}

body[data-page="help"] .kurban-year-tabs{
  display:inline-flex;
  gap:4px;
  background:rgba(27,45,58,.04);
  padding:4px;
  border-radius:6px;
}

body[data-page="help"] .kurban-year-tab{
  padding:10px 28px;
  border-radius:4px;
  border:none;
  background:transparent;
  color:var(--muted);
  font-weight:600;
  font-size:15px;
  cursor:pointer;
  transition:all .2s ease;
}

body[data-page="help"] .kurban-year-tab:hover{
  color:var(--txt);
  background:rgba(255,255,255,.6);
}

body[data-page="help"] .kurban-year-tab.is-active{
  background:#fff;
  color:var(--txt);
  box-shadow:0 2px 8px rgba(27,45,58,.08);
}

body[data-page="help"] .kurban-year-panel{
  display:none;
}

body[data-page="help"] .kurban-year-panel.is-active{
  display:block;
  animation:helpFadeIn .45s ease;
}

@keyframes helpFadeIn{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}

body[data-page="help"] .kurban-panel-card{
  display:grid;
  grid-template-columns:1.15fr 1fr;
  background:#fff;
  border:1px solid rgba(27,45,58,.06);
  border-radius:8px;
  overflow:hidden;
  min-height:420px;
}

body[data-page="help"] .kurban-panel-visual{
  display:grid;
  grid-template-columns:1.6fr 1fr;
  gap:0;
  min-height:420px;
}

body[data-page="help"] .kurban-img-main{
  width:100%;
  height:100%;
  object-fit:cover;
}

body[data-page="help"] .kurban-img-side{
  width:100%;
  height:100%;
  object-fit:cover;
  border-left:1px solid rgba(27,45,58,.06);
}

body[data-page="help"] .kurban-panel-body{
  padding:40px 36px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

body[data-page="help"] .kurban-panel-year{
  display:inline-block;
  font-size:13px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--brand);
  margin-bottom:12px;
}

body[data-page="help"] .kurban-panel-body h3{
  font-size:clamp(20px, 2.2vw, 26px);
  font-weight:800;
  color:var(--txt);
  margin:0 0 16px;
  letter-spacing:-.3px;
  line-height:1.2;
}

body[data-page="help"] .kurban-panel-body p{
  font-size:15px;
  line-height:1.7;
  color:var(--muted);
  margin:0 0 28px;
}

body[data-page="help"] .kurban-panel-stats{
  display:flex;
  gap:24px;
}

body[data-page="help"] .kurban-stat{
  display:flex;
  flex-direction:column;
}

body[data-page="help"] .kurban-stat strong{
  font-size:28px;
  font-weight:800;
  color:var(--txt);
  line-height:1;
  letter-spacing:-.5px;
}

body[data-page="help"] .kurban-stat span{
  font-size:12px;
  font-weight:600;
  color:var(--muted);
  margin-top:4px;
  text-transform:uppercase;
  letter-spacing:.5px;
}

/* SOCIAL REELS */
body[data-page="help"] .help-social{
  padding:48px 0;
}

body[data-page="help"] .social-title{
  font-size:clamp(22px, 3vw, 30px);
  font-weight:800;
  color:var(--txt);
  margin:0 0 8px;
  text-align:center;
}

body[data-page="help"] .social-subtitle{
  font-size:15px;
  color:var(--muted);
  text-align:center;
  margin:0 0 32px;
}

body[data-page="help"] .social-reels-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:24px;
  max-width:900px;
  margin:0 auto;
}

body[data-page="help"] .social-reel-wrap{
  background:#fff;
  border:1px solid rgba(74,154,181,.14);
  border-radius:16px;
  padding:16px;
  display:flex;
  justify-content:center;
  overflow:hidden;
}

body[data-page="help"] .social-reel-wrap .instagram-media{
  margin:0 !important;
  max-width:100% !important;
  min-width:0 !important;
}

/* TRUST SECTION */
body[data-page="help"] .help-trust{
  padding:56px 0 64px;
}

body[data-page="help"] .trust-title{
  font-size:clamp(22px, 3vw, 30px);
  font-weight:800;
  color:var(--txt);
  margin:0 0 36px;
  text-align:center;
}

body[data-page="help"] .trust-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
}

body[data-page="help"] .trust-item{
  background:#fff;
  border:1px solid rgba(74,154,181,.14);
  border-radius:16px;
  padding:28px 22px;
  transition:all .3s ease;
}

body[data-page="help"] .trust-item:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 32px rgba(27,45,58,.07);
}

body[data-page="help"] .trust-number{
  display:inline-block;
  font-size:28px;
  font-weight:800;
  color:var(--brand);
  margin-bottom:12px;
  opacity:.5;
}

body[data-page="help"] .trust-item h4{
  font-size:15px;
  font-weight:700;
  color:var(--txt);
  margin:0 0 8px;
}

body[data-page="help"] .trust-item p{
  font-size:13px;
  line-height:1.6;
  color:var(--muted);
  margin:0;
}

@media (max-width:960px){
  body[data-page="help"] .kurban-info-grid{
    grid-template-columns:1fr;
  }
  body[data-page="help"] .trust-grid{
    grid-template-columns:repeat(2, 1fr);
  }
  body[data-page="help"] .kurban-panel-card{
    grid-template-columns:1fr;
  }
  body[data-page="help"] .kurban-panel-visual{
    min-height:280px;
  }
  body[data-page="help"] .kurban-panel-body{
    padding:28px 24px;
  }
  body[data-page="help"] .social-reels-grid{
    grid-template-columns:1fr;
    max-width:480px;
  }
}

@media (max-width:680px){
  body[data-page="help"] .trust-grid{
    grid-template-columns:1fr;
  }
  body[data-page="help"] .kurban-panel-visual{
    grid-template-columns:1fr;
    min-height:220px;
  }
  body[data-page="help"] .kurban-img-side{
    display:none;
  }
  body[data-page="help"] .kurban-panel-body{
    padding:24px 20px;
  }
  body[data-page="help"] .kurban-panel-stats{
    gap:16px;
  }
  body[data-page="help"] .kurban-stat strong{
    font-size:22px;
  }
  body[data-page="help"] .kurban-year-tab{
    padding:8px 18px;
    font-size:13px;
  }
}

/* BANK ACCOUNTS PAGE */
body[data-page="bank-accounts"]{
  background:var(--bg);
  color:var(--txt);
}
body[data-page="bank-accounts"] .bank-main{
  padding-top:calc(var(--header-h) + 22px);
  padding-bottom:64px;
}
body[data-page="bank-accounts"] .bank-hero{
  padding:24px 0 18px;
}
body[data-page="bank-accounts"] .bank-kicker{
  margin:0;
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--brand);
}
body[data-page="bank-accounts"] .bank-title{
  margin:6px 0 0;
  font-size:clamp(28px, 4vw, 44px);
  font-weight:700;
}
body[data-page="bank-accounts"] .bank-subtitle{
  margin:10px 0 0;
  max-width:780px;
  color:var(--muted);
  font-weight:600;
}

body[data-page="bank-accounts"] .bank-official{
  padding:8px 0 14px;
}
body[data-page="bank-accounts"] .bank-official-card{
  background:#fff;
  border:1px solid rgba(27,45,58,.08);
  border-radius:14px;
  padding:16px;
}
body[data-page="bank-accounts"] .bank-official-card__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
body[data-page="bank-accounts"] .bank-official-card__kicker{
  margin:0;
  font-size:13px;
  font-weight:700;
  color:var(--brand);
  text-transform:uppercase;
  letter-spacing:.06em;
}
body[data-page="bank-accounts"] .bank-official-list{
  margin:0;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px 20px;
}
body[data-page="bank-accounts"] .bank-official-row{
  margin:0;
}
body[data-page="bank-accounts"] .bank-official-row dt{
  margin:0;
  font-size:12px;
  color:var(--muted);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.05em;
}
body[data-page="bank-accounts"] .bank-official-row dd{
  margin:4px 0 0;
  font-size:16px;
  font-weight:700;
}

body[data-page="bank-accounts"] .bank-controls{
  padding:8px 0 16px;
}
body[data-page="bank-accounts"] .bank-controls__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
body[data-page="bank-accounts"] .bank-tabs{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
body[data-page="bank-accounts"] .bank-tab{
  border:1px solid rgba(27,45,58,.12);
  background:rgba(27,45,58,.04);
  color:var(--txt);
  border-radius:999px;
  height:36px;
  padding:0 14px;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
}
body[data-page="bank-accounts"] .bank-tab.is-active{
  background:var(--brand);
  border-color:var(--brand);
  color:#fff;
}

body[data-page="bank-accounts"] .bank-search{
  position:relative;
  min-width:min(100%, 310px);
}
body[data-page="bank-accounts"] .bank-search input{
  width:100%;
  height:40px;
  border-radius:10px;
  border:1px solid rgba(27,45,58,.12);
  background:#fff;
  color:var(--txt);
  padding:0 42px 0 12px;
  font-size:14px;
}
body[data-page="bank-accounts"] .bank-search__icon{
  position:absolute;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  color:var(--muted);
}

body[data-page="bank-accounts"] .bank-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}
body[data-page="bank-accounts"] .bank-card{
  background:#fff;
  border:1px solid rgba(27,45,58,.08);
  border-radius:14px;
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
body[data-page="bank-accounts"] .bank-card__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
}
body[data-page="bank-accounts"] .bank-currency{
  font-size:16px;
  font-weight:700;
}
body[data-page="bank-accounts"] .bank-label{
  margin:0;
  font-size:12px;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.05em;
}
body[data-page="bank-accounts"] .bank-account-no{
  margin:0;
  font-size:13px;
  font-weight:600;
  color:var(--muted);
}
body[data-page="bank-accounts"] .bank-iban{
  margin:0;
  font-size:18px;
  line-height:1.35;
  font-weight:700;
  letter-spacing:.02em;
  word-break:break-word;
}
body[data-page="bank-accounts"] .bank-copy{
  align-self:flex-start;
}
body[data-page="bank-accounts"] .bank-copy.is-copied{
  background:rgba(74,154,181,.18);
  border-color:rgba(74,154,181,.5);
}
body[data-page="bank-accounts"] .bank-empty{
  margin:16px 0 0;
  color:var(--muted);
}

body[data-page="bank-accounts"] .bank-assistant{
  padding:26px 0 6px;
}
body[data-page="bank-accounts"] .assistant-shell{
  position:relative;
  background:#fff;
  border:1px solid rgba(27,45,58,.08);
  border-radius:18px;
  padding:18px;
  overflow:hidden;
}
body[data-page="bank-accounts"] .assistant-shell::before{
  content:"";
  position:absolute;
  right:-40px;
  top:-40px;
  width:180px;
  height:180px;
  border-radius:50%;
  background:radial-gradient(circle at center, rgba(74,154,181,.22), rgba(74,154,181,0));
  pointer-events:none;
}
body[data-page="bank-accounts"] .assistant-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
}
body[data-page="bank-accounts"] .assistant-kicker{
  margin:0;
  color:var(--brand);
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
}
body[data-page="bank-accounts"] .assistant-title{
  margin:6px 0 0;
  font-size:clamp(20px, 2.6vw, 30px);
  line-height:1.2;
}
body[data-page="bank-accounts"] .assistant-badge{
  border:1px solid rgba(27,45,58,.12);
  background:rgba(27,45,58,.04);
  border-radius:999px;
  padding:6px 12px;
  font-size:12px;
  font-weight:700;
}

body[data-page="bank-accounts"] .assistant-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:16px;
}
body[data-page="bank-accounts"] .assistant-form,
body[data-page="bank-accounts"] .assistant-preview{
  background:rgba(244,248,249,.6);
  border:1px solid rgba(27,45,58,.06);
  border-radius:14px;
  padding:14px;
}
body[data-page="bank-accounts"] .assistant-form{
  display:grid;
  gap:12px;
}
body[data-page="bank-accounts"] .assistant-field{
  display:grid;
  gap:6px;
}
body[data-page="bank-accounts"] .assistant-field span{
  font-size:13px;
  color:var(--muted);
  font-weight:700;
}
body[data-page="bank-accounts"] .assistant-field input,
body[data-page="bank-accounts"] .assistant-field select{
  width:100%;
  height:42px;
  border-radius:10px;
  border:1px solid rgba(27,45,58,.12);
  background:#fff;
  color:var(--txt);
  padding:0 12px;
  font-size:14px;
}
body[data-page="bank-accounts"] .assistant-field select option{
  color:#111;
  background:#fff;
}
body[data-page="bank-accounts"] .assistant-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
body[data-page="bank-accounts"] .assistant-chip{
  border:1px dashed rgba(27,45,58,.18);
  background:rgba(27,45,58,.03);
  color:var(--txt);
  border-radius:999px;
  height:34px;
  padding:0 12px;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
}
body[data-page="bank-accounts"] .assistant-chip.is-active{
  border-style:solid;
  background:rgba(74,154,181,.2);
  border-color:rgba(74,154,181,.45);
}
body[data-page="bank-accounts"] .assistant-toggle{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:14px;
  font-weight:600;
}

body[data-page="bank-accounts"] .assistant-preview{
  display:grid;
  gap:12px;
}
body[data-page="bank-accounts"] .assistant-result{
  border:1px solid rgba(27,45,58,.08);
  background:rgba(244,248,249,.6);
  border-radius:12px;
  padding:12px;
  min-height:120px;
}
body[data-page="bank-accounts"] .assistant-result__label{
  margin:0;
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  color:var(--muted);
  letter-spacing:.05em;
}
body[data-page="bank-accounts"] .assistant-result__text{
  margin:8px 0 0;
  font-size:16px;
  line-height:1.45;
  font-weight:700;
  word-break:break-word;
}
body[data-page="bank-accounts"] .assistant-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
body[data-page="bank-accounts"] .assistant-actions .btn.is-copied{
  background:rgba(74,154,181,.18);
  border-color:rgba(74,154,181,.5);
}
body[data-page="bank-accounts"] .assistant-format{
  margin:0;
  font-size:12px;
  color:var(--muted);
}

/* Improve account select readability on dark UI */
body[data-page="bank-accounts"] #assistantIbanSelect{
  color:#1B2D3A !important;
  background:#fff !important;
}
body[data-page="bank-accounts"] #assistantIbanSelect option{
  color:#1B2D3A;
  background:#fff;
}

@media (max-width: 900px){
  body[data-page="bank-accounts"] .bank-official-card__head{
    flex-direction:column;
    align-items:flex-start;
  }
  body[data-page="bank-accounts"] .bank-official-list{
    grid-template-columns:1fr;
  }
  body[data-page="bank-accounts"] .bank-grid{
    grid-template-columns:1fr;
  }
  body[data-page="bank-accounts"] .assistant-head{
    flex-direction:column;
    align-items:flex-start;
  }
  body[data-page="bank-accounts"] .assistant-grid{
    grid-template-columns:1fr;
  }
}

/* ABOUT PAGE */
body[data-page="about"]{
  background:var(--bg);
  color:var(--txt);
}
body[data-page="about"] .about-main{
  padding-top:calc(var(--header-h) + 18px);
  padding-bottom:56px;
}
body[data-page="about"] .about-hero{
  padding:16px 0 8px;
}
body[data-page="about"] .about-hero__shell{
  margin-top:14px;
  position:relative;
  background:#fff;
  border:1px solid rgba(27,45,58,.08);
  border-radius:20px;
  padding:24px;
  overflow:hidden;
}
body[data-page="about"] .about-hero__shell::before{
  display:none;
}
body[data-page="about"] .about-hero__shell::after{
  display:none;
}
body[data-page="about"] .about-hero__kicker{
  margin:0;
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--brand);
}
body[data-page="about"] .about-hero__title{
  margin:8px 0 0;
  max-width:860px;
  font-size:clamp(30px, 4.8vw, 58px);
  line-height:1.04;
}
body[data-page="about"] .about-hero__lead{
  margin:14px 0 0;
  max-width:740px;
  color:var(--muted);
  font-size:clamp(16px, 2.2vw, 20px);
  font-weight:600;
}

body[data-page="about"] .about-story{
  padding-top:20px;
}
body[data-page="about"] .about-story__grid{
  display:grid;
  grid-template-columns:220px minmax(0, 1fr);
  gap:18px;
}
body[data-page="about"] .about-story__rail{
  position:sticky;
  top:calc(var(--header-h) + 18px);
  align-self:start;
  background:#fff;
  border:1px solid rgba(27,45,58,.08);
  border-radius:14px;
  padding:14px;
}
body[data-page="about"] .about-story__rail-label{
  margin:0;
  font-size:12px;
  color:var(--brand);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:700;
}
body[data-page="about"] .about-story__rail-text{
  margin:10px 0 0;
  color:var(--muted);
  font-weight:600;
  font-size:14px;
  line-height:1.45;
}

body[data-page="about"] .about-story__content{
  background:#fff;
  border:1px solid rgba(27,45,58,.08);
  border-radius:16px;
  padding:18px;
  display:grid;
  gap:12px;
}
body[data-page="about"] .about-story__content p{
  margin:0;
  line-height:1.75;
  color:var(--txt);
  font-size:15px;
}

body[data-page="about"] .about-manifesto{
  margin-top:6px;
  padding:14px;
  border-radius:12px;
  border:1px solid rgba(27,45,58,.08);
  background:rgba(74,154,181,.04);
}
body[data-page="about"] .about-manifesto__line{
  margin-top:10px;
  font-weight:700;
  color:#1B2D3A;
}
body[data-page="about"] .about-actions{
  margin-top:6px;
}

@media (max-width: 980px){
  body[data-page="about"] .about-story__grid{
    grid-template-columns:1fr;
  }
  body[data-page="about"] .about-story__rail{
    position:static;
  }
}

/* HERO */
/* HERO SECTION - REBUILT FOR MODERN LOOK */
.hero {
  position: relative;
  height: 100vh;
  min-height: 700px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  color: #fff;
  background: #000;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.hero-bg-visual {
  position: absolute;
  inset: 0;
}

.hero-bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  transform: scale(1.1);
  animation: kenBurns 20s infinite alternate linear;
}

.hero-bg-img.active {
  opacity: 1;
}

.hero-bg-img:nth-child(2) { animation-delay: 5s; }
.hero-bg-img:nth-child(3) { animation-delay: 10s; }

@keyframes kenBurns {
  from { transform: scale(1); }
  to { transform: scale(1.15); }
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.55) 50%, rgba(0,0,0,0.7) 100%);
  z-index: 2;
}

.hero-container {
  position: relative;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 100vh;
  padding-top: var(--header-h);
}

.hero-content {
  max-width: 860px;
  text-align: center;
  padding: 0 24px;
}

.hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: rgba(255,255,255,0.9);
  margin-bottom: 28px;
  animation: fadeInUp 0.7s ease backwards 0.15s;
}
.hero-kicker::before,
.hero-kicker::after {
  content: '';
  width: 32px;
  height: 1px;
  background: rgba(255,255,255,0.4);
}

.hero-title {
  font-size: clamp(42px, 8vw, 80px);
  font-weight: 900;
  line-height: 1.05;
  margin-bottom: 24px;
  color: #fff;
  text-shadow: 0 2px 40px rgba(0,0,0,0.25);
  animation: fadeInUp 0.8s ease backwards 0.35s;
}

.hero-description {
  font-size: clamp(17px, 2.5vw, 22px);
  color: rgba(255, 255, 255, 0.75);
  max-width: 560px;
  margin: 0 auto 44px;
  line-height: 1.7;
  font-weight: 400;
  animation: fadeInUp 0.8s ease backwards 0.55s;
}

.hero-actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  animation: fadeInUp 0.8s ease backwards 0.75s;
}

.hero-actions .btn {
  height: 54px;
  padding: 0 36px;
  font-size: 15px;
  font-weight: 700;
  border-radius: 999px;
  transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.btn-primary {
  background: var(--brand);
  color: #fff;
  border: 2px solid var(--brand);
}

.btn-primary:hover {
  background: #3A8AA5;
  border-color: #3A8AA5;
  color: #fff;
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(74, 154, 181, 0.35);
}

.btn-outline-hero {
  background: transparent;
  border: 2px solid rgba(255,255,255,0.5);
  color: #fff;
}
.btn-outline-hero:hover {
  background: rgba(255,255,255,0.12);
  border-color: #fff;
  color: #fff;
  transform: translateY(-3px);
}

.btn-outline {
  background: rgba(27, 45, 58, 0.04);
  border: 1px solid rgba(27, 45, 58, 0.15);
  color: #1B2D3A;
}

.btn-outline:hover {
  background: rgba(27, 45, 58, 0.08);
  border-color: rgba(27, 45, 58, 0.3);
  transform: translateY(-4px);
}

.hero-scroll {
  position: absolute;
  bottom: 36px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  animation: scrollPulse 2.5s ease-in-out infinite;
}

.scroll-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: rgba(255, 255, 255, 0.45);
  text-decoration: none;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 3px;
  transition: color 0.3s ease;
}

.scroll-link:hover {
  color: rgba(255,255,255,0.85);
}

@keyframes scrollPulse {
  0%, 100% { transform: translateX(-50%) translateY(0); opacity: 0.7; }
  50% { transform: translateX(-50%) translateY(8px); opacity: 1; }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 768px) {
  .hero-content {
    padding: 0 16px;
  }
  .hero-title {
    font-size: clamp(36px, 10vw, 52px);
  }
  .hero-actions {
    flex-direction: column;
    align-items: center;
  }
  .hero-actions .btn {
    width: 100%;
    max-width: 300px;
  }
}

/* SECTIONS */
.section{
  padding:86px 0;
  background:#F4F8F9;
  color:#1B2D3A;
}
.container{
  width:min(var(--container), calc(100% - 40px));
  margin:0 auto;
}
.section-head{
  text-align:center;
  margin-bottom:34px;
}
.section-head h2{
  margin:0;
  font-size:34px;
  letter-spacing:-.3px;
}
.section-head p{
  margin:10px auto 0;
  max-width:720px;
  color:var(--muted);
  font-weight:600;
}

/* SLIDER */
.slider{
  display:grid;
  grid-template-columns: 56px 1fr 56px;
  gap:18px;
  align-items:center;
}
.slider-btn{
  height:56px; width:56px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  box-shadow:0 12px 30px rgba(0,0,0,.10);
  cursor:pointer;
  font-size:28px;
  line-height:1;
}
.slider-track{
  display:flex;
  gap:22px;
  overflow:hidden;
  scroll-behavior:smooth;
}
.card{
  flex:0 0 calc((100% - 44px) / 3);
  border-radius:22px;
  background:#fff;
  box-shadow:0 20px 45px rgba(0,0,0,.08);
  overflow:hidden;
  border:1px solid rgba(0,0,0,.06);
}
.card img,
.card-icon-container{
  width:100%;
  height:190px;
  object-fit:cover;
  display:block;
}

.card-icon-container {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f8fafc;
  color: var(--brand);
  position: relative;
  overflow: hidden;
  transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.card:hover .card-icon-container {
  transform: scale(1.05);
}

.card-icon-container::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.4) 0%, rgba(255,255,255,0) 100%);
  z-index: 1;
}

.card-icon-container svg,
.card-icon-3d {
  position: relative;
  z-index: 2;
  filter: drop-shadow(0 10px 15px rgba(74, 154, 181, 0.2));
  transition: transform 0.4s ease;
  max-width: 80px;
  max-height: 80px;
  object-fit: contain;
}

.card:hover .card-icon-container svg,
.card:hover .card-icon-3d {
  transform: translateY(-5px) rotate(3deg) scale(1.1);
}

.card-icon-svg {
  width: 84px;
  height: 84px;
}

.card-icon-svg path,
.card-icon-svg circle {
  vector-effect: non-scaling-stroke;
}

.card:hover .card-icon-svg {
  transform: translateY(-4px) scale(1.05);
}


/* Icon Variants */
.card-icon-v1 { background: linear-gradient(145deg, #eef4f8 0%, #dbe8ef 100%); color: #2f647a; }
.card-icon-v2 { background: linear-gradient(145deg, #edf5f3 0%, #d8ebe4 100%); color: #2f6a55; }
.card-icon-v3 { background: linear-gradient(145deg, #f5f2ea 0%, #e9e1d1 100%); color: #6b5a2b; }

.card-body{
  padding:18px 18px 20px;
}
.card-body h3{
  margin:0 0 10px;
  font-size:18px;
  letter-spacing:-.2px;
}
.card-body p{
  margin:0;
  color:var(--muted);
  font-weight:600;
  min-height:48px;
}
.card-actions{
  display:flex;
  gap:10px;
  margin-top:16px;
  flex-wrap:wrap;
}
.card .btn{
  color:#1B2D3A;
  background:#f4f6f8;
  border-color:rgba(0,0,0,.08);
}
.card .btn:hover{ background:#eef2f5; }
.card .btn.btn-ghost{ background:#fff; }

/* dots */
.dots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:18px;
}
.dot{
  width:7px; height:7px;
  border-radius:999px;
  background:rgba(0,0,0,.22);
}
.dot.is-active{ background:#1B2D3A; }

/* RESPONSIVE */
@media (max-width: 1100px){
  .nav{ 
    display:none;
  }
  .header-right{
    display:none;
  }
  .header-quick-actions{
    display:none;
  }
  .menu-toggle{
    display:flex;
  }
  .mobile-icons-bar{
    display:none;
  }
  .mobile-menu.mobile-open{
    display:flex;
  }
  .mobile-menu .mobile-lang-group{
    display:none !important;
  }
  .mobile-lang-inline{
    display:flex;
    align-items:center;
    gap:4px;
    justify-self:end;
    position:relative;
    border:1px solid rgba(27,45,58,.12);
    border-radius:999px;
    padding:3px;
    background:rgba(244,248,249,.8);
  }
  .mobile-lang-inline .lang-dropdown-toggle{
    padding:4px 8px;
    font-size:10px;
    border-radius:999px;
  }
  .card{ flex-basis: calc((100% - 22px) / 2); }
}

/* TABLET & SMALL DEVICES */
@media (max-width: 768px){
  .header-inner{
    gap:12px;
    width:min(var(--container), calc(100% - 24px));
    display:grid;
    grid-template-columns: 40px 1fr auto;
    align-items:center;
    position:relative;
  }
  .brand img{
    width:clamp(75px, 10vw, 110px);
  }
  .header-right{
    gap:10px;
  }
  .icon-btn{
    width:36px;
    height:36px;
  }
  .icon-btn svg{
    width:18px;
    height:18px;
  }
  .btn-pill{
    padding:0 12px;
    height:36px;
    font-size:12px;
  }
  .lang-dropdown-toggle{
    padding:5px 10px;
    font-size:11px;
  }
  .menu-toggle{
    width:40px;
    height:40px;
  }
  .menu-toggle svg{
    width:20px;
    height:20px;
  }
  .brand{
    justify-self:center;
    position:absolute;
    left:50%;
    transform:translateX(-50%);
  }
  .mobile-icons-bar{
    justify-self:end;
  }
  .nav.mobile-open .nav-link{
    font-size:14px;
    padding:8px 0;
  }
  .card{ flex-basis: calc((100% - 22px) / 2); }
}

/* SMALL PHONES */
@media (max-width: 480px){
  :root{
    --header-h:64px;
  }
  .header-inner{
    gap:8px;
    width:calc(100% - 16px);
    grid-template-columns: 36px 1fr auto;
  }
  .brand img{
    width:clamp(60px, 9vw, 90px);
  }
  .menu-toggle{
    width:36px;
    height:36px;
  }
  .menu-toggle svg{
    width:18px;
    height:18px;
  }
  .header-right{
    gap:6px;
  }
  .icon-btn{
    width:32px;
    height:32px;
  }
  .icon-btn svg{
    width:16px;
    height:16px;
  }
  .badge{
    min-width:18px;
    height:18px;
    padding:0 3px;
    font-size:9px;
    top:-4px;
    right:-4px;
  }
  .btn-pill{
    display:none;
  }
  .lang-dropdown-toggle{
    padding:4px 8px;
    font-size:10px;
    gap:4px;
  }
  .mobile-lang-inline{
    gap:2px;
    padding:2px;
  }
  .mobile-lang-inline .lang-dropdown-toggle{
    font-size:9px;
    padding:3px 6px;
  }
  .nav.mobile-open{
    padding:12px 16px;
    gap:4px;
  }
  .nav.mobile-open .nav-link{
    color:rgba(27,45,58,.78);
    font-size:13px;
    padding:8px 0;
  }
  .hero{
    min-height:620px;
  }
  .hero-grid{
    grid-template-columns: 1fr;
  }
  .hero-divider{ display:none; }
  .hero-title{ font-size:clamp(32px, 7vw, 40px); }
  .card{ flex-basis: 100%; }
  .slider{
    grid-template-columns: 36px 1fr 36px;
    gap:8px;
  }
  .slider-btn{
    height:36px; width:36px;
    font-size:20px;
  }
}

/* EXTRA SMALL PHONES (<360px) */
@media (max-width: 360px){
  .header-inner{
    gap:6px;
  }
  .brand img{
    width:clamp(50px, 8vw, 75px);
  }
  .menu-toggle{
    width:32px;
    height:32px;
  }
  .menu-toggle svg{
    width:16px;
    height:16px;
  }
  .icon-btn{
    width:28px;
    height:28px;
  }
  .icon-btn svg{
    width:14px;
    height:14px;
  }
  .lang-dropdown-toggle{
    padding:3px 6px;
    font-size:9px;
    gap:3px;
  }
}

/* ===== SECTION 1: ONGOING PROJECTS GRID ===== */
.ch-projects{
  background:#F4F8F9;
  color:#1B2D3A;
  padding:86px 0;
}

.ch-projects-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(280px, 1fr));
  gap:28px;
  margin-top:56px;
}

.ch-project-card{
  position:relative;
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,253,0.96) 100%);
  border:1px solid rgba(27,45,58,.08);
  box-shadow:
    0 10px 28px rgba(18,38,52,.08),
    0 1px 0 rgba(255,255,255,.8) inset;
  overflow:hidden;
  transition:transform 0.26s ease, box-shadow 0.26s ease, border-color 0.26s ease;
  display:flex;
  flex-direction:column;
  min-height:320px;
  padding:22px;
}

.ch-project-card::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:4px;
  background:linear-gradient(90deg, rgba(74,154,181,0.95), rgba(122,194,214,0.95));
  opacity:.8;
}

.ch-project-card:hover{
  transform:translateY(-5px);
  border-color:rgba(74,154,181,.28);
  box-shadow:
    0 22px 44px rgba(18,38,52,.14),
    0 1px 0 rgba(255,255,255,.9) inset;
}

.ch-project-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:14px;
}

.ch-project-header h3{
  margin:0;
  font-size:23px;
  font-weight:800;
  letter-spacing:-.35px;
  color:#1B2D3A;
  line-height:1.18;
}

.ch-project-header p{
  margin:0;
  font-size:13px;
  color:var(--muted);
  font-weight:500;
  line-height:1.4;
}

.ch-project-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 12px;
  border-radius:999px;
  font-size:10.5px;
  font-weight:800;
  letter-spacing:.4px;
  text-transform:uppercase;
  white-space:nowrap;
  flex-shrink:0;
}

.ch-badge-kurban{
  background:rgba(74,154,181,.14);
  color:#245b70;
  border:1px solid rgba(74,154,181,.34);
}

.ch-badge-other{
  background:rgba(108,124,144,.14);
  color:#2b3d4f;
  border:1px solid rgba(108,124,144,.28);
}

.ch-project-meta-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:16px;
}

.ch-project-meta-pill{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.78);
  font-size:12.5px;
  font-weight:700;
  color:#556673;
  border:1px solid rgba(27,45,58,.1);
}

.ch-project-meta-pill svg{
  color:var(--brand);
  opacity:0.8;
}

.ch-project-target{
  font-size:13px;
  font-weight:600;
  color:var(--muted);
  margin-bottom:12px;
}

.ch-project-divider{
  height:1px;
  background:linear-gradient(90deg, rgba(27,45,58,.04), rgba(27,45,58,.12), rgba(27,45,58,.04));
  margin:16px 0 14px;
}

.ch-progress-section{
  margin-bottom:22px;
}

.ch-progress-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:10px;
  font-size:13px;
  font-weight:700;
  color:#60717f;
}

.ch-progress-bar{
  width:100%;
  height:10px;
  background:rgba(27,45,58,.1);
  border-radius:999px;
  overflow:hidden;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.08);
}

.ch-progress-fill{
  height:100%;
  background:linear-gradient(90deg, #4a9ab5, #7bc2d7);
  border-radius:999px;
  transition:width 0.5s ease;
}

.ch-progress-values{
  display:flex;
  justify-content:space-between;
  margin-top:6px;
  font-size:12px;
  color:var(--muted);
  font-weight:600;
}

.ch-project-actions{
  display:flex;
  gap:12px;
  margin-top:auto;
  flex-wrap:nowrap;
}

.ch-project-actions .btn{
  flex:1;
  min-width:0;
  color:#1c2f3e;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(27,45,58,.12);
  font-size:14px;
  font-weight:700;
  height:44px;
  padding:0 16px;
  border-radius:14px;
  transition:all .24s ease;
}

.ch-project-actions .btn:hover{
  background:#ffffff;
  border-color:rgba(27,45,58,.2);
  transform:translateY(-1px);
}

.ch-project-actions .btn-ghost{
  background:rgba(240,245,248,.72);
  color:#304a5a;
}

.ch-project-actions .btn:not(.btn-ghost){
  background:linear-gradient(135deg, #4a9ab5 0%, #62acc4 100%);
  color:#fff;
  border-color:transparent;
}

.ch-project-actions .btn:not(.btn-ghost):hover{
  background:linear-gradient(135deg, #3f8ea9 0%, #5ca7bf 100%);
  color:#fff;
  box-shadow:0 8px 18px rgba(74,154,181,.28);
}

/* ===== SECTION 2: FAQ ===== */
.ch-faq{
  padding:86px 0;
}

.ch-faq-wrapper{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:64px;
  align-items:start;
  margin-top:48px;
}

.ch-faq-wrapper--no-collage{
  grid-template-columns:1fr;
}

.ch-faq-wrapper--no-collage .ch-faq-collage{
  display:none;
}

.ch-faq-collage{
  position:relative;
  height:520px;
}

.ch-collage-item{
  position:absolute;
  border-radius:20px;
  overflow:hidden;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 20px 50px rgba(0,0,0,.3);
}

.ch-collage-lg{
  width:280px;
  height:400px;
  left:0;
  top:0;
}

.ch-collage-sm{
  width:200px;
  height:220px;
}

.ch-collage-top{
  right:0;
  top:0;
}

.ch-collage-bottom{
  right:0;
  bottom:40px;
}

.ch-collage-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.ch-faq-head{
  margin-bottom:32px;
}

.ch-faq-head h2{
  margin:0 0 12px;
  font-size:32px;
  font-weight:800;
  letter-spacing:-.4px;
  color:var(--txt);
}

.ch-faq-head p{
  margin:0;
  color:var(--muted);
  font-size:15px;
  font-weight:600;
}

.ch-accordion{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.ch-accordion-item{
  border:1px solid rgba(27,45,58,.08);
  border-radius:12px;
  background:#fff;
  overflow:hidden;
  transition:all 0.3s ease;
}

.ch-accordion-item:hover{
  background:rgba(244,248,249,.8);
  border-color:rgba(27,45,58,.14);
}

.ch-accordion-trigger{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 18px;
  border:none;
  background:transparent;
  color:var(--txt);
  cursor:pointer;
  font-size:15px;
  font-weight:700;
  letter-spacing:-.2px;
  transition:all 0.3s ease;
  text-align:left;
}

.ch-accordion-trigger:hover{
  color:#1B2D3A;
}

.ch-accordion-trigger svg{
  width:20px;
  height:20px;
  transition:transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  flex-shrink:0;
  margin-left:12px;
}

.ch-accordion-trigger[aria-expanded="true"] svg{
  transform:rotate(180deg);
}

.ch-accordion-content{
  display:none;
  padding:0 18px 16px;
  color:var(--muted);
  font-size:14px;
  line-height:1.6;
  font-weight:500;
  border-top:1px solid rgba(27,45,58,.06);
  animation:slideDown 0.3s ease;
}

.ch-accordion-content p{
  margin:0;
}

.ch-accordion-trigger[aria-expanded="true"]+.ch-accordion-content{
  display:block;
}

@keyframes slideDown{
  from{
    opacity:0;
    transform:translateY(-8px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

/* ===== SECTION 3: DONATION METHODS ===== */
/* ===== SECTION 3: Donation Methods (Curved Path Design) ===== */
.ch-donate-path{
  background:var(--bg);
  color:var(--txt);
  padding:86px 0;
  position:relative;
}

/* ===== PROJECTS: Premium Slider Styling ===== */
.projects .slider{
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
}

/* ===== HOMEPAGE PRELOADER (scoped) ===== */
/* Scoped styles only — adds bounce animation for .preloader-media, responsive sizing, and fade-out on .is-hidden */
.preloader{
  position:fixed;
  inset:0;
  background: radial-gradient(circle at 50% 12%, rgba(74,154,181,0.04), transparent 35%), var(--bg, #F4F8F9);
  display:grid;
  place-items:center;
  z-index:99999;
  transition:opacity 350ms ease, visibility 350ms ease;
  opacity:1;
  visibility:visible;
}

/* Fade-out when hidden */
.preloader.is-hidden{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition-duration:350ms;
}

.preloader-inner{
  position:relative;
  text-align:center;
  color:var(--txt);
  display:flex;
  flex-direction:column;
  gap:12px;
  align-items:center;
}

/* Responsive logo sizing and bounce animation */
.preloader-media{
  display:block;
  width:min(260px, 60vw);
  height:auto;
  animation:preloader-bounce 1000ms cubic-bezier(.2,.9,.2,1) infinite;
  will-change:transform;
}

@keyframes preloader-bounce{
  0%{ transform: translateY(0) scale(1); }
  20%{ transform: translateY(-14px) scale(1.02,0.98); }
  40%{ transform: translateY(0) scale(0.98,1.02); }
  60%{ transform: translateY(-8px) scale(1.01,0.99); }
  100%{ transform: translateY(0) scale(1); }
}

/* Keep a soft glow without interfering with layout */
.preloader-media{ filter: drop-shadow(0 18px 40px rgba(95,160,170,0.08)); }

.preloader-text{ margin:0; font-size:13px; color:var(--muted); }

/* Visually hidden helper for accessible text */
.visually-hidden{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0 0 0 0) !important;
  white-space:nowrap !important;
  border:0 !important;
}

/* Lock body scroll while preloader is active */
body.preloading{ overflow:hidden; height:100vh; }

/* Reduced motion: disable bounce */
@media (prefers-reduced-motion: reduce){
  .preloader{ transition:none; }
  .preloader-media{ animation:none; }
}

/* Small device tweak to avoid overflow */
@media (max-width:420px){
  .preloader-media{ width:min(220px, 70vw); }
}

/* End of HOMEPAGE PRELOADER block */ 


.projects .slider-track{
  display:flex;
  flex:1 1 auto;
  min-width:0;
  gap:28px;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-behavior:smooth;
  padding:6px 0;
  scrollbar-width:none;
  -ms-overflow-style:none;
}

.projects .slider-track::-webkit-scrollbar{
  display:none;
}

.projects .card{
  flex:0 0 calc((100% - 56px) / 3);
  border-radius:18px;
  background:linear-gradient(135deg, #ffffff, #fbfcfd);
  border:1px solid rgba(0,0,0,.06);
  box-shadow:none;
  overflow:hidden;
  transition:transform 300ms cubic-bezier(.2,.9,.2,1);
  display:flex;
  flex-direction:column;
}

.projects .card:hover{
  transform:translateY(-4px);
}

.projects .card-media{
  position:relative;
  width:100%;
  aspect-ratio:16/10;
  background:linear-gradient(180deg, #e9eef0, #f7f9fa);
  overflow:hidden;
  box-shadow:none;
}

/* Fill the whole media area for icon cards (no gray strip). */
.projects .card-media .card-icon-container{
  height:100%;
}

.projects .card-image{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  background:linear-gradient(180deg, #eef2f4, #f8fafb);
  transition:transform .5s ease, filter .5s ease;
  filter:saturate(1.03) contrast(1.02) brightness(.9);
}

.projects .card-media__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0.14) 0%, rgba(0,0,0,0.28) 100%);
  pointer-events:none;
  box-shadow:none;
}

.projects .card:hover .card-image{
  transform:scale(1.035);
  filter:saturate(1.08) contrast(1.04) brightness(.94);
}

.projects .card-badge{
  position:absolute;
  top:12px;left:12px;
  background:rgba(255,255,255,0.06);
  color:var(--txt);
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,0.03);
}

.projects .card-body{
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:12px;
  flex:1 1 auto;
}

.projects .card-body h3{
  margin:0;
  font-size:18px;
  font-weight:700;
  color:var(--txt);
}

.projects .card-body p{
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.5;
}

.projects .card-actions{
  display:flex;
  gap:10px;
  margin-top:auto;
}

.projects .card-actions .btn{
  height:40px;
  padding:0 14px;
  border-radius:999px;
}

.projects .card-actions .btn:only-child{
  width:100%;
  justify-content:center;
}

/* Controls: Prev/Next buttons (project-specific) */
.projects .slider-btn{
  width:52px;height:52px;
  border-radius:999px;
  border:1px solid rgba(27,45,58,.18);
  background:rgba(255,255,255,.92);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#1f3545;
  font-size:0;
  padding:0;
  cursor:pointer;
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease, background .24s ease;
}

.projects .slider-btn:hover{
  transform:translateY(-1px);
  border-color:rgba(74,154,181,.48);
  background:linear-gradient(135deg, #4a9ab5 0%, #62acc4 100%);
  color:#fff;
}

.projects .slider-btn:active{
  transform:translateY(0);
}

.projects .slider-btn:focus-visible{
  outline:3px solid rgba(74,154,181,.32);
  outline-offset:2px;
}

.projects .slider-btn svg{
  width:20px;
  height:20px;
  stroke:currentColor;
  transition:transform .24s ease;
}

.projects .slider-btn--prev:hover svg{
  transform:translateX(-2px);
}

.projects .slider-btn--next:hover svg{
  transform:translateX(2px);
}

/* Dots */
.projects .dots{ margin-top:18px; display:flex; justify-content:center; }
.projects .dots .dot{
  width:8px;height:8px;border-radius:999px;background:rgba(0,0,0,.12);display:inline-block;transition:all 220ms ease;margin:0 6px;
}
.projects .dots .dot.is-active{ width:20px;background:var(--brand);box-shadow:0 6px 18px rgba(74,154,181,.12);border-radius:99px;}

/* RESPONSIVE: TABLET */
@media (max-width:1100px){
  .projects .card{ flex:0 0 calc((100% - 28px) / 2); }
  .projects .slider-btn{ width:48px;height:48px; }
  .projects .slider-btn svg{ width:20px;height:20px; }
}

/* RESPONSIVE: MOBILE */
@media (max-width:768px){
  .projects .card{ flex:0 0 100%; }
  .projects .card{ border-radius:16px; }
  .projects .slider-track{ gap:18px; }
  .projects .slider-btn{ width:40px;height:40px; }
  .projects .slider-btn svg{ width:18px;height:18px; }
  .projects .dots{ display:flex; justify-content:center; gap:8px; }
}


.ch-donate-path__head{
  text-align:center;
  margin-bottom:68px;
}

.ch-donate-path__head h2{
  font-size:36px;
  font-weight:800;
  margin:0 0 14px;
  letter-spacing:-.4px;
  line-height:1.2;
}

.ch-donate-path__head p{
  font-size:15px;
  color:var(--muted);
  margin:0;
  font-weight:500;
}

/* Curved Dotted Path SVG */
.ch-donate-path__svg{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  width:90%;
  max-width:1000px;
  height:280px;
  pointer-events:none;
  opacity:0.7;
}

/* Items Grid */
.ch-donate-path__items{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:48px;
  position:relative;
  z-index:2;
  align-items:center;
}

/* Individual Item */
.ch-donate-path__item{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}

/* Donate Icon Box */
.ch-donate-path__icon-box{
  width:110px;
  height:110px;
  border-radius:24px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:28px;
  transition:transform 0.3s ease, box-shadow 0.3s ease;
}
.ch-donate-path__icon-box:hover{
  transform:translateY(-6px);
}
.ch-donate-path__icon-box--online{
  background:linear-gradient(135deg, #4A9AB5 0%, #367a8f 100%);
  color:#fff;
  box-shadow:0 12px 32px rgba(74,154,181,0.3);
}
.ch-donate-path__icon-box--bank{
  background:linear-gradient(135deg, #1B2D3A 0%, #2c4a5e 100%);
  color:#fff;
  box-shadow:0 12px 32px rgba(27,45,58,0.3);
}
.ch-donate-path__icon-box--support{
  background:linear-gradient(135deg, #4d6a7c 0%, #3b4f5d 100%);
  color:#fff;
  box-shadow:0 12px 32px rgba(44,66,80,0.28);
}
.ch-donate-path__icon-box svg{
  width:48px;
  height:48px;
  stroke:currentColor;
}

/* Text Content */
.ch-donate-path__item h3{
  font-size:18px;
  font-weight:700;
  margin:0 0 12px;
  letter-spacing:-.2px;
}

.ch-donate-path__item p{
  font-size:13px;
  line-height:1.65;
  color:var(--muted);
  margin:0 0 20px;
  font-weight:500;
}

/* CTA Link */
.ch-donate-path__link{
  color:var(--brand);
  text-decoration:none;
  font-weight:700;
  font-size:13px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  transition:gap 0.3s ease, color 0.3s ease;
  outline:none;
}

.ch-donate-path__link:hover{
  gap:10px;
  color:#3A8AA5;
}

.ch-donate-path__link:focus{
  text-decoration:underline;
}

.ch-donate-path__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid rgba(74,154,181,.35);
  background:linear-gradient(135deg, #4a9ab5 0%, #62acc4 100%);
  color:#fff;
  text-decoration:none;
  font-size:13px;
  font-weight:700;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.ch-donate-path__btn:hover{
  transform:translateY(-1px);
  background:linear-gradient(135deg, #3f8ea9 0%, #5ca7bf 100%);
  box-shadow:0 8px 18px rgba(74,154,181,.28);
}
.ch-donate-path__btn:focus-visible{
  outline:3px solid rgba(74,154,181,.28);
  outline-offset:2px;
}

/* ===== RESPONSIVE: TABLET (≤1100px) ===== */
@media (max-width:1100px){
  .ch-projects-grid{
    grid-template-columns:repeat(2, 1fr);
    gap:24px;
  }

  .ch-faq-wrapper{
    grid-template-columns:1fr;
    gap:48px;
  }

  .ch-faq-collage{
    height:400px;
  }

  .ch-collage-lg{
    width:240px;
    height:340px;
  }

  .ch-collage-sm{
    width:170px;
    height:190px;
  }

  .ch-donate-path__items{
    grid-template-columns:repeat(2, 1fr);
    gap:40px;
    row-gap:56px;
  }

  .ch-donate-path__icon-box{
    width:100px;
    height:100px;
  }
}

/* ===== RESPONSIVE: SMALL TABLET / PORTRAIT (≤768px) ===== */
@media (max-width:768px){
  .ch-projects{
    padding:64px 0;
  }

  .ch-projects-grid{
    grid-template-columns:1fr;
    gap:20px;
  }

  .ch-project-card{
    padding:16px;
  }

  .ch-project-header{
    margin-bottom:12px;
  }

  .ch-project-header h3{
    font-size:16px;
  }

  .ch-project-header p{
    font-size:12px;
  }

  .ch-project-badge{
    font-size:10px;
    padding:3px 8px;
  }

  .ch-project-meta-row{
    margin-bottom:10px;
  }

  .ch-project-meta-pill{
    font-size:11px;
    padding:5px 8px;
  }

  .ch-project-target{
    font-size:12px;
    margin-bottom:10px;
  }

  .ch-project-divider{
    margin:10px 0;
  }

  .ch-progress-section{
    margin-bottom:12px;
  }

  .ch-project-actions{
    gap:8px;
  }

  .ch-project-actions .btn{
    font-size:12px;
    height:34px;
    padding:0 10px;
  }

  .ch-faq{
    padding:64px 0;
  }

  .ch-faq-wrapper{
    gap:32px;
  }

  .ch-faq-collage{
    display:none;
  }

  .ch-collage-lg{
    width:200px;
    height:280px;
  }

  .ch-collage-sm{
    width:140px;
    height:160px;
  }

  .ch-faq-head h2{
    font-size:26px;
  }

  .ch-donate-path{
    padding:64px 0;
  }

  .ch-donate-path__head h2{
    font-size:28px;
  }

  .ch-donate-path__head p{
    font-size:14px;
  }

  .ch-donate-path__items{
    grid-template-columns:1fr;
    gap:32px;
    row-gap:48px;
  }

  .ch-donate-path__svg{
    display:none;
  }

  .ch-donate-path__icon-box{
    width:90px;
    height:90px;
    margin-bottom:20px;
  }

  .ch-donate-path__icon-box svg{
    width:40px;
    height:40px;
    border-width:3px;
  }

  .ch-donate-path__icon-box{
    border-radius:20px;
  }

  .ch-donate-path__item h3{
    font-size:16px;
  }

  .ch-donate-path__item p{
    font-size:12px;
  }
}

/* ===== RESPONSIVE: MOBILE (≤480px) ===== */
@media (max-width:480px){
  .ch-projects-grid{
    gap:16px;
  }

  .ch-project-image{
    height:140px;
  }

  .ch-project-body{
    padding:14px;
  }

  .ch-project-body h3{
    font-size:16px;
  }

  .ch-project-meta{
    font-size:12px;
    margin-bottom:12px;
  }

  .ch-progress-section{
    margin-bottom:14px;
  }

  .ch-progress-bar{
    height:6px;
  }

  .ch-project-actions{
    flex-direction:column;
  }

  .ch-project-actions .btn{
    width:100%;
    min-width:unset;
  }

  .ch-faq-collage{
    display:none;
  }

  .ch-faq-head h2{
    font-size:22px;
  }

  .ch-accordion-trigger{
    padding:14px 14px;
    font-size:14px;
  }

  .ch-accordion-content{
    padding:0 14px 12px;
    font-size:13px;
  }

  .ch-donate-path__head h2{
    font-size:24px;
  }

  .ch-donate-path__head p{
    font-size:13px;
  }

  .ch-donate-path__items{
    gap:28px;
    row-gap:40px;
  }

  .ch-donate-path__icon-box{
    width:80px;
    height:80px;
    margin-bottom:16px;
    border-radius:18px;
  }

  .ch-donate-path__icon-box svg{
    width:36px;
    height:36px;
  }

  .ch-donate-path__icon-box{
    border-radius:16px;
  }

  .ch-donate-path__item h3{
    font-size:15px;
    margin-bottom:10px;
  }

  .ch-donate-path__item p{
    font-size:12px;
    margin-bottom:16px;
  }

  .ch-donate-path__link{
    font-size:12px;
  }
}

/* ===== CH Footer ===== */
/* ===== FOOTER ===== */
.ch-footer{
  position:relative;
  background:#fff;
  color:var(--txt);
  border-top:1px solid rgba(27,45,58,.1);
  margin-top:86px;
  padding:0;
  overflow:hidden;
}

.ch-footer::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Crect width='32' height='32' fill='%23FF0000'/%3E%3Crect x='13' y='6' width='6' height='20' fill='%23fff'/%3E%3Crect x='6' y='13' width='20' height='6' fill='%23fff'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:center;
  background-size:280px 280px;
  opacity:0.07;
  pointer-events:none;
  z-index:0;
}

.ch-footer__overlay{ display:none; }

.ch-footer__main{
  position:relative;
  z-index:1;
  padding:56px 0 48px;
}

.ch-footer__content{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1.5fr;
  gap:48px;
}

.ch-footer__column{
  display:flex;
  flex-direction:column;
}

.ch-footer__logo{
  height:auto;
  width:130px;
  max-width:130px;
  object-fit:contain;
  margin-bottom:16px;
}

.ch-footer__subtitle{
  font-size:14px;
  line-height:1.65;
  color:var(--muted);
  margin:0 0 24px;
  max-width:260px;
}

.ch-footer__socials{
  display:flex;
  gap:12px;
}

.ch-footer__social{
  width:36px;
  height:36px;
  border-radius:6px;
  border:1px solid rgba(27,45,58,.1);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--txt);
  text-decoration:none;
  transition:all .2s ease;
}

.ch-footer__social:hover{
  border-color:var(--brand);
  color:var(--brand);
  background:rgba(74,154,181,.04);
}

.ch-footer__heading{
  font-size:14px;
  font-weight:700;
  color:var(--txt);
  margin:0 0 20px;
  letter-spacing:.3px;
}

.ch-footer__nav{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.ch-footer__link{
  color:var(--muted);
  text-decoration:none;
  font-size:14px;
  font-weight:400;
  transition:color .2s ease;
}

.ch-footer__link:hover{
  color:var(--txt);
}

.ch-footer__link:focus{
  outline:2px solid rgba(74,154,181,.4);
  outline-offset:2px;
}

.ch-footer__cta-desc{
  font-size:14px;
  color:var(--muted);
  margin:0 0 20px;
  line-height:1.6;
}

.ch-footer__cta-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 28px;
  border-radius:6px;
  border:1px solid var(--brand);
  background:var(--brand);
  color:#fff;
  font-size:14px;
  font-weight:600;
  text-decoration:none;
  transition:all .2s ease;
}

.ch-footer__cta-btn:hover{
  background:#3A8AA5;
  border-color:#3A8AA5;
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(74,154,181,.2);
}

/* FOOTER BOTTOM BAR */
.ch-footer__bottom{
  position:relative;
  z-index:1;
  border-top:1px solid rgba(27,45,58,.08);
  padding:20px 0;
}

.ch-footer__bottom-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
}

.ch-footer__copyright{
  font-size:13px;
  color:var(--muted);
  margin:0;
  font-weight:400;
}

.ch-footer__bottom-links{
  display:flex;
  gap:24px;
}

.ch-footer__bottom-link{
  font-size:13px;
  color:var(--muted);
  text-decoration:none;
  transition:color .2s ease;
}

.ch-footer__bottom-link:hover{
  color:var(--txt);
}

/* FOOTER RTL */
html[dir="rtl"] .ch-footer{direction:rtl;text-align:right;}
html[dir="rtl"] .ch-footer__socials{justify-content:flex-start;}
html[dir="rtl"] .ch-footer__cta-btn{flex-direction:row-reverse;}
html[dir="rtl"] .ch-footer__bottom-inner{direction:rtl;}
html[dir="rtl"] .ch-footer__bottom-links{direction:rtl;}

/* FOOTER RESPONSIVE */
@media (max-width:1100px){
  .ch-footer__content{
    grid-template-columns:1.2fr 1fr 1fr;
    gap:36px;
  }
  .ch-footer__column--cta{
    grid-column:1 / -1;
  }
  .ch-footer__cta-btn{
    align-self:flex-start;
  }
}

@media (max-width:768px){
  .ch-footer{
    margin-top:64px;
  }
  .ch-footer__main{
    padding:40px 0 36px;
  }
  .ch-footer__content{
    grid-template-columns:1fr 1fr;
    gap:32px 24px;
  }
  .ch-footer__column--brand{
    grid-column:1 / -1;
    text-align:center;
    align-items:center;
  }
  .ch-footer__subtitle{
    max-width:100%;
  }
  .ch-footer__socials{
    justify-content:center;
  }
  .ch-footer__column--cta{
    grid-column:1 / -1;
    text-align:center;
    align-items:center;
  }
  .ch-footer__cta-desc{
    max-width:400px;
  }
  .ch-footer__cta-btn{
    align-self:center;
  }
  .ch-footer__bottom{
    padding:16px 0;
  }
  .ch-footer__bottom-inner{
    flex-direction:column;
    gap:12px;
    text-align:center;
  }
  .ch-footer__bottom-links{
    justify-content:center;
    flex-wrap:wrap;
    gap:12px 20px;
  }
  .ch-footer__bottom-link{
    font-size:12px;
  }
  .ch-footer__copyright{
    font-size:12px;
  }

  /* RTL mobile centering */
  html[dir="rtl"] .ch-footer__column--brand{text-align:center;}
  html[dir="rtl"] .ch-footer__column--cta{text-align:center;}
}

@media (max-width:480px){
  .ch-footer{
    margin-top:48px;
  }
  .ch-footer__main{
    padding:28px 0 24px;
  }
  .ch-footer__content{
    grid-template-columns:1fr;
    gap:24px;
  }
  .ch-footer__column--brand{
    grid-column:auto;
  }
  .ch-footer__column--cta{
    grid-column:auto;
  }
  .ch-footer__column{
    text-align:center;
    align-items:center;
  }
  .ch-footer__heading{
    font-size:13px;
    margin-bottom:14px;
  }
  .ch-footer__nav{
    align-items:center;
  }
  .ch-footer__link{
    font-size:13px;
  }
  .ch-footer__logo{
    width:110px;
    max-width:110px;
    margin-bottom:12px;
  }
  .ch-footer__subtitle{
    font-size:13px;
    margin-bottom:18px;
  }
  .ch-footer__cta-desc{
    font-size:13px;
    max-width:100%;
  }
  .ch-footer__cta-btn{
    width:100%;
    justify-content:center;
    padding:12px 20px;
    font-size:13px;
  }
  .ch-footer__bottom{
    padding:14px 0;
  }
  .ch-footer__bottom-links{
    gap:10px 16px;
  }
  .ch-footer__bottom-link{
    font-size:11px;
  }
  .ch-footer__copyright{
    font-size:11px;
  }
}

@media (max-width:360px){
  .ch-footer__main{
    padding:24px 0 20px;
  }
  .ch-footer__content{
    gap:20px;
  }
  .ch-footer__cta-btn{
    padding:10px 16px;
    font-size:12px;
  }
  .ch-footer__bottom-links{
    flex-direction:column;
    gap:8px;
    align-items:center;
  }
}

/* ===== NAV DROPDOWN (Corporate) ===== */
.site-header .nav-item--dropdown{position:relative;}

/* Corporate trigger: clean text-only look with animated underline */
.site-header .nav-link--trigger{
  cursor:pointer;
  background:transparent;
  border:0;
  box-shadow:none;
  padding:0;
  color:inherit;
  font-weight:600;
  font-size:14px;
  position:relative;
  display:inline-flex;
  align-items:center;
  transition: color 200ms ease, transform 220ms ease;
}

.site-header .nav-link--trigger::after{
  content:'';
  position:absolute;
  left:0;
  right:0;
  bottom:-8px;
  height:2px;
  background:var(--brand);
  border-radius:2px;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 220ms cubic-bezier(.2,.8,.2,1), opacity 220ms ease;
  opacity:0.95;
}

/* Hover / focus / expanded states */
.site-header .nav-link--trigger:hover,
.site-header .nav-link--trigger:focus{
  transform:translateY(-1px);
}

.site-header .nav-link--trigger:hover::after,
.site-header .nav-link--trigger:focus::after,
.site-header .nav-link--trigger[aria-expanded="true"]::after,
.site-header .nav-item--dropdown.is-open .nav-link--trigger::after{
  transform:scaleX(1);
}

.site-header .nav-link--trigger:focus-visible{
  outline:3px solid rgba(127,200,217,0.18);
  outline-offset:4px;
}

.site-header .nav-dropdown{
  list-style:none;
  margin:0;
  padding:12px;
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  width:clamp(220px, 26vw, 320px);
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-radius:16px;
  border:1px solid rgba(27,45,58,0.08);
  box-shadow:0 18px 50px rgba(27,45,58,0.12);
  display:none;
  flex-direction:column;
  gap:6px;
  z-index:9999;
  overflow:hidden;
}

.site-header .nav-dropdown li{list-style:none; margin:0; padding:0;}

.site-header .nav-dropdown a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  font-size:15px;
  line-height:1.25;
  color:var(--txt);
  text-decoration:none;
  font-weight:600;
  hyphens:auto;
  overflow-wrap:anywhere;
}

.site-header .nav-dropdown a:hover,
.site-header .nav-dropdown a:focus{
  background:rgba(74,154,181,0.06);
  color:var(--brand);
  outline:none;
}

.site-header .nav-dropdown a:focus-visible{
  outline:3px solid rgba(127,200,217,0.22);
  outline-offset:3px;
  border-radius:10px;
}

/* open on hover or focus-within or when toggled via JS */
.site-header .nav-item--dropdown:hover .nav-dropdown,
.site-header .nav-item--dropdown:focus-within .nav-dropdown,
.site-header .nav-item--dropdown.is-open .nav-dropdown{
  display:flex;
}

/* show visual state for trigger when expanded */
.site-header .nav-link--trigger[aria-expanded="true"]{
  color:var(--brand);
}

/* Mobile collapsible submenu */
.mobile-submenu__panel{
  max-height:0;
  overflow:hidden;
  transition:max-height 280ms ease, opacity 200ms ease;
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:0 8px;
}

.mobile-submenu__panel a{
  padding:12px 10px;
  display:flex;
  align-items:center;
  min-height:44px;
  border-radius:8px;
  font-size:14px;
  color:var(--txt);
  text-decoration:none;
}

.mobile-submenu__panel a:hover,
.mobile-submenu__panel a:focus{
  background:rgba(74,154,181,0.06);
  color:var(--brand);
}

.mobile-submenu.is-open .mobile-submenu__panel{
  max-height:1000px; /* generous max for expand */
}

@media (max-width:768px){
  /* ensure no horizontal scroll on mobile */
  .nav-dropdown{left:auto; right:0; min-width:200px; width:200px;}
  .mobile-submenu__panel{padding-left:14px;}
}

/* ===== NAV HOVER / UNDERLINE ANIMATION (Desktop only) ===== */
@media (min-width:1101px){
  /* apply to top-level nav links and corporate trigger */
  .site-header .nav .nav-link,
  .site-header .nav-link--trigger{
    position:relative;
    transition: color 200ms ease, transform 260ms cubic-bezier(.2,.9,.2,1);
    -webkit-transition: color 200ms ease, transform 260ms cubic-bezier(.2,.9,.2,1);
  }

  .site-header .nav .nav-link::after,
  .site-header .nav-link--trigger::after{
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -10px;
    height: 1.5px;
    background: linear-gradient(90deg, var(--brand), rgba(74,154,181,0.6));
    border-radius: 2px;
    box-shadow: 0 0 10px rgba(74,154,181,0.12);
    transform: scaleX(0);
    transform-origin: left;
    opacity: 0;
    transition: transform 260ms cubic-bezier(.2,.9,.2,1), opacity 240ms ease;
  }

  .site-header .nav .nav-link:hover,
  .site-header .nav .nav-link:focus-visible,
  .site-header .nav-link--trigger:hover,
  .site-header .nav-link--trigger:focus-visible{
    transform: translateY(-1px);
  }

  .site-header .nav .nav-link:hover::after,
  .site-header .nav .nav-link:focus-visible::after,
  .site-header .nav-link--trigger:hover::after,
  .site-header .nav-link--trigger:focus-visible::after,
  .site-header .nav-link--trigger[aria-expanded="true"]::after,
  .site-header .nav-item--dropdown.is-open .nav-link--trigger::after,
  .site-header .nav .nav-link.active::after{
    transform: scaleX(1);
    opacity: 1;
  }

  /* keep accessible focus-visible without adding a box background */
  .site-header .nav .nav-link:focus-visible,
  .site-header .nav-link--trigger:focus-visible{
    outline:3px solid rgba(127,200,217,0.18);
    outline-offset:4px;
  }
}

/* ===== PROJECTS PAGE: Scoped styles under .projects-page ===== */
/* Appended block — only selectors starting with .projects-page to avoid global impact */
.projects-page .projects-hero{
  background-size:cover;
  background-position:center center;
  min-height:300px;
  display:grid;
  align-items:center;
  color:var(--txt, #f6f7f8);
  position:relative;
}
.projects-page .projects-hero .page-hero__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(11,15,20,0.6) 10%, rgba(11,15,20,0.85) 80%);
  pointer-events:none;
}
.projects-page .page-hero__inner{ position:relative; z-index:2; padding:36px 0; }
.projects-page .breadcrumb{ color:var(--muted, rgba(255,255,255,0.62)); font-size:14px; margin-bottom:8px; }
.projects-page .page-title{ font-size:34px; margin:0; color:var(--txt, #fff); }

.projects-page .projects-category{ padding:48px 0; border-top:1px solid rgba(255,255,255,0.03); }
.projects-page .category-head h2{ margin:0 0 18px 0; font-size:20px; color:var(--txt, #fff); }

.projects-page .projects-grid{
  display:grid;
  gap:18px;
  grid-template-columns: repeat(4, 1fr);
}

.projects-page .project-card{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border:1px solid rgba(255,255,255,0.04);
  box-shadow: 0 8px 30px rgba(2,6,10,0.5);
  padding:18px;
  border-radius:12px;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:140px;
  transition:transform 220ms cubic-bezier(.2,.9,.2,1), box-shadow 220ms ease;
}
.projects-page .project-card:hover{ transform:translateY(-8px); box-shadow:0 18px 50px rgba(2,6,10,0.6); }
.projects-page .project-region{ display:inline-block; background:rgba(127,200,217,0.08); color:var(--txt, #fff); padding:6px 10px; border-radius:999px; font-size:12px; }
.projects-page .project-card h3{ margin:4px 0 0 0; font-size:16px; color:var(--txt, #fff); flex:1 0 auto; }
.projects-page .project-card .project-detail-btn{ margin-top:auto; align-self:flex-start; }

/* Detail panel styling */
.projects-page .project-detail{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border:1px solid rgba(255,255,255,0.06);
  border-radius:12px;
  padding:24px;
  margin:32px 0;
  backdrop-filter: blur(6px);
  box-shadow:0 12px 40px rgba(2,6,10,0.6);
}
.projects-page .project-detail[hidden]{ display:none; }

/* Global donate CTA */
.projects-page .projects-cta .btn{
  padding:14px 28px;
  font-size:16px;
  box-shadow:0 10px 30px rgba(127,200,217,0.08);
}
.projects-page .projects-cta .btn.btn-pill{ box-shadow:0 12px 40px rgba(127,200,217,0.12); }

/* Responsive breakpoints */
@media (max-width:1024px){
  .projects-page .projects-grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width:768px){
  .projects-page .projects-grid{ grid-template-columns: repeat(2, 1fr); }
  .projects-page .page-title{ font-size:28px; }
  .projects-page .projects-main{ padding-top: var(--header-offset, 78px); }
}
@media (max-width:480px){
  .projects-page .projects-grid{ grid-template-columns: 1fr; }
  .projects-page .projects-hero{ min-height:260px; }
  .projects-page .page-title{ font-size:22px; }
}

/* End of .projects-page scoped styles */

/* ===== PROJECTS PAGE: PREMIUM ENHANCEMENTS (Appended) ===== */
/* Header overlap fix, premium images in cards, refined spacing and gloss effects */

.projects-page .projects-main{
  padding-top: var(--header-offset, 92px);
}

/* Premium hero: dark overlay, rounded bottom fade, soft gradient */
.projects-page .projects-hero{
  background-size: cover;
  background-position: center 30%;
  background-attachment: fixed;
  position: relative;
  min-height: 340px;
  display: grid;
  align-items: center;
  justify-content: center;
  color: var(--txt, #fff);
}

.projects-page .projects-hero::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(11, 15, 20, 0.5) 0%,
    rgba(11, 15, 20, 0.8) 50%,
    rgba(11, 15, 20, 0.95) 100%
  );
  pointer-events: none;
  z-index: 1;
}

.projects-page .page-hero__inner{
  position: relative;
  z-index: 2;
  text-align: center;
}

/* Category headers with subtle divider */
.projects-page .projects-category{
  padding: 54px 0;
  border-top: 1px solid rgba(127, 200, 217, 0.06);
  position: relative;
}

.projects-page .projects-category:first-of-type{
  border-top: none;
  padding-top: 32px;
}

.projects-page .category-head h2{
  font-size: 24px;
  font-weight: 600;
  color: var(--txt, #fff);
  margin: 0 0 28px 0;
  position: relative;
  padding-bottom: 12px;
}

.projects-page .category-head h2::after{
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 40px;
  height: 2px;
  background: linear-gradient(90deg, var(--brand, #7fc8d9), transparent);
  border-radius: 999px;
}

/* Premium cards with image support */
.projects-page .project-card{
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01));
  border: 1px solid rgba(127, 200, 217, 0.08);
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 280px;
  transition: transform 240ms cubic-bezier(0.2, 0.9, 0.2, 1), box-shadow 240ms ease, border-color 240ms ease;
  box-shadow: 0 12px 40px rgba(2, 6, 10, 0.5);
}

.projects-page .project-card:hover{
  transform: translateY(-12px);
  box-shadow: 0 24px 60px rgba(127, 200, 217, 0.1);
  border-color: rgba(127, 200, 217, 0.12);
}

/* Image media block with aspect ratio */
.projects-page .project-card__media{
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.4));
}

.projects-page .project-card__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 280ms ease;
}

.projects-page .project-card:hover .project-card__media img{
  transform: scale(1.04);
}

/* Image overlay gradient (subtle enhancement) */
.projects-page .project-card__media::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(11, 15, 20, 0.3));
  pointer-events: none;
  z-index: 2;
}

/* Tag pill positioned in image top-left */
.projects-page .project-card__tag{
  position: absolute;
  top: 10px;
  left: 10px;
  background: rgba(127, 200, 217, 0.15);
  color: rgba(255, 255, 255, 0.95);
  padding: 5px 12px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid rgba(127, 200, 217, 0.2);
  z-index: 3;
  backdrop-filter: blur(4px);
}

/* Card body (title + button) */
.projects-page .project-card h3{
  font-size: 17px;
  font-weight: 600;
  color: var(--txt, #fff);
  margin: 14px 16px 0 16px;
  line-height: 1.3;
  flex: 1 0 auto;
}

.projects-page .project-card .project-detail-btn{
  margin: auto 16px 14px 16px;
  margin-top: auto;
  align-self: flex-start;
  padding: 8px 14px;
  font-size: 13px;
  border: 1px solid rgba(127, 200, 217, 0.2);
  background: transparent;
  color: var(--txt, #fff);
  border-radius: 6px;
  cursor: pointer;
  transition: all 200ms ease;
}

.projects-page .project-card .project-detail-btn:hover{
  background: rgba(127, 200, 217, 0.1);
  border-color: rgba(127, 200, 217, 0.4);
  box-shadow: 0 4px 12px rgba(127, 200, 217, 0.08);
}

/* Detail panel premium styling */
.projects-page .project-detail{
  background: #fff;
  border: 1px solid rgba(127, 200, 217, 0.1);
  border-radius: 14px;
  padding: 32px;
  margin: 48px 0;
  backdrop-filter: blur(8px);
  box-shadow: 0 16px 50px rgba(27, 45, 58, 0.06);
}

.projects-page .project-detail h2{
  font-size: 26px;
  color: var(--txt, #fff);
  margin: 0 0 16px 0;
}

.projects-page .project-detail__body{
  color: var(--txt);
  line-height: 1.6;
}

/* Global donate CTA with glow */
.projects-page .projects-cta{
  text-align: center;
  padding: 56px 0;
  border-top: 1px solid rgba(127, 200, 217, 0.06);
  margin-top: 32px;
}

.projects-page .projects-cta .btn{
  padding: 16px 32px;
  font-size: 16px;
  font-weight: 600;
  background: linear-gradient(135deg, var(--brand, #7fc8d9), rgba(127, 200, 217, 0.8));
  color: var(--bg, #0b0f14);
  border: none;
  border-radius: 8px;
  box-shadow: 0 14px 40px rgba(127, 200, 217, 0.15);
  transition: all 240ms ease;
  cursor: pointer;
}

.projects-page .projects-cta .btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 20px 60px rgba(127, 200, 217, 0.25);
}

/* Small screen adjustments for cards */
@media (max-width: 768px){
  .projects-page .project-card{
    min-height: 240px;
  }
  .projects-page .project-card__media{
    aspect-ratio: 16 / 10;
  }
  .projects-page .category-head h2{
    font-size: 20px;
  }
}

@media (max-width: 480px){
  .projects-page .projects-main{
    padding-top: var(--header-offset, 74px);
  }
  .projects-page .project-card{
    min-height: 220px;
  }
  .projects-page .projects-cta{
    padding: 40px 0;
  }
  .projects-page .project-detail{
    padding: 24px;
    margin: 32px 0;
  }
}

/* End of PROJECTS PAGE PREMIUM ENHANCEMENTS */

/* ===== PROJECTS PAGE: LAYOUT FIX & HERO/INTRO (Final Update) ===== */
/* Header offset variables, full-width hero image, and title section styling */

:root{
  --header-offset: 96px;
}

@media (max-width: 768px){
  :root{
    --header-offset: 80px;
  }
}

.projects-page{
  scroll-padding-top: var(--header-offset);
}

/* Override main padding to use header offset variable */
.projects-page .projects-main{
  padding-top: var(--header-offset);
}

/* Full-width hero image section (extends under fixed header) */
.projects-hero{
  height: clamp(220px, 32vh, 360px);
  background: url("../assets/img/projects/projelerimiz-kapak.jpg") center/cover no-repeat;
  position: relative;
  margin-top: calc(var(--header-offset) * -1);
  padding-top: var(--header-offset);
}

/* Force projects hero image source (prevents scoped overrides). */
.projects-page .projects-hero{
  background-image: url("../assets/img/projects/projelerimiz-kapak.jpg") !important;
  background-size: cover !important;
  background-position: center center !important;
  background-color: transparent !important;
}

/* Keep only uploaded hero image, remove darkening layers. */
.projects-page .projects-hero::after{
  display: none !important;
}

.projects-hero__overlay{
  display: none !important;
}

.projects-hero__overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.55), rgba(0, 0, 0, 0.85));
  pointer-events: none;
}

.projects-hero__inner{
  position: relative;
  height: 100%;
  display: flex;
  align-items: flex-end;
  padding-bottom: 22px;
  padding-left: max(24px, (100% - var(--container, 1200px)) / 2);
}

.projects-hero__crumb{
  color: rgba(255, 255, 255, 0.8);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 0;
  font-weight: 500;
}

/* Intro section with title (after hero) */
.projects-intro{
  padding: 34px 0 18px;
}

.projects-title{
  margin: 0;
  font-size: clamp(28px, 3.2vw, 44px);
  font-weight: 700;
  color: var(--txt, #fff);
}

.projects-subtitle{
  margin: 10px 0 0;
  max-width: 70ch;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.5;
}

/* Responsive adjustments for header offset on smaller screens */
@media (max-width: 768px){
  .projects-page .projects-main{
    padding-top: var(--header-offset, 80px);
  }
  .projects-intro{
    padding: 28px 0 14px;
  }
  .projects-title{
    font-size: clamp(24px, 2.8vw, 36px);
  }
}

@media (max-width: 480px){
  .projects-page .projects-main{
    padding-top: var(--header-offset, 74px);
  }
  .projects-hero{
    height: clamp(180px, 28vh, 280px);
  }
  .projects-hero__inner{
    padding-bottom: 16px;
    padding-left: 16px;
  }
  .projects-intro{
    padding: 22px 0 12px;
  }
  .projects-title{
    font-size: clamp(20px, 2.4vw, 28px);
  }
  .projects-subtitle{
    font-size: 13px;
  }
}

/* End of PROJECTS PAGE LAYOUT FIX & HERO/INTRO */

/* ============================================================================
   PROJECT DETAIL PAGE LAYOUT
   ============================================================================ */

.project-detail-page {
  background-color: var(--bg);
}

.project-detail-main {
  padding-top: var(--header-offset, 96px);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* Hero Image Section */
.project-detail-hero {
  width: 100%;
  height: clamp(280px, 40vw, 420px);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.1);
}

.project-detail-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* Title Section */
.project-detail-header {
  padding: clamp(32px, 6vw, 64px) 0;
  border-bottom: 1px solid rgba(27, 45, 58, 0.08);
}

.project-detail-title {
  font-size: clamp(24px, 5vw, 42px);
  font-weight: 700;
  color: var(--txt);
  margin: 0;
  line-height: 1.2;
}

/* Content Section */
.project-detail-content {
  padding: clamp(32px, 6vw, 64px) 0;
  flex: 1;
}

.project-detail-body {
  font-size: clamp(16px, 2vw, 18px);
  color: var(--txt);
  line-height: 1.6;
  max-width: 800px;
}

/* CTA Section */
.project-detail-cta-section {
  padding: clamp(32px, 6vw, 64px) 0;
  border-top: 1px solid rgba(27, 45, 58, 0.06);
  background-color: rgba(244, 248, 249, 0.6);
}

/* Responsive - Tablet (768px) */
@media (max-width: 768px) {
  .project-detail-main {
    padding-top: 80px;
  }

  .project-detail-hero {
    height: clamp(240px, 50vw, 360px);
  }

  .project-detail-header {
    padding: 24px 0;
  }

  .project-detail-title {
    font-size: clamp(20px, 4vw, 32px);
  }

  .project-detail-content {
    padding: 24px 0;
  }

  .project-detail-body {
    font-size: 16px;
  }

  .project-detail-cta-section {
    padding: 24px 0;
  }
}

/* Responsive - Mobile (480px) */
@media (max-width: 480px) {
  .project-detail-main {
    padding-top: 74px;
  }

  .project-detail-hero {
    height: clamp(200px, 60vw, 300px);
  }

  .project-detail-header {
    padding: 16px 0;
  }

  .project-detail-title {
    font-size: clamp(18px, 5vw, 26px);
  }

  .project-detail-content {
    padding: 16px 0;
  }

  .project-detail-body {
    font-size: 15px;
  }

  .project-detail-cta-section {
    padding: 16px 0;
  }
}

/* End of PROJECT DETAIL PAGE LAYOUT */
.projects-page .projects-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  padding: 0;
}

.projects-page .project-card {
  background: #fff;
  border: 1px solid rgba(74, 154, 181, 0.2);
  border-radius: 8px;
  overflow: hidden;
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

.projects-page .project-card:hover {
  transform: translateY(-4px);
  border-color: rgba(74, 154, 181, 0.6);
  box-shadow: 0 8px 24px rgba(74, 154, 181, 0.15);
  background: rgba(74, 154, 181, 0.04);
}

/* Image container with aspect ratio and overlay */
.projects-page .project-card__media {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: linear-gradient(135deg, #E0EBF0 0%, #D4E2E8 100%);
}

.projects-page .project-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.3s ease;
  display: block;
}

/* Overlay gradient for readability */
.projects-page .project-card__media::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.1) 0%, rgba(0, 0, 0, 0.3) 100%);
  pointer-events: none;
}

.projects-page .project-card:hover .project-card__media img {
  transform: scale(1.05);
}

/* Region tag pill - top left */
.projects-page .project-card__tag {
  position: absolute;
  top: 12px;
  left: 12px;
  background: rgba(74, 154, 181, 0.9);
  color: #fff;
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  z-index: 1;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(245, 247, 250, 0.2);
}

/* Card content */
.projects-page .project-card h3 {
  padding: 18px 18px 10px 18px;
  margin: 0;
  font-size: 17px;
  font-weight: 600;
  color: var(--txt);
  line-height: 1.4;
  flex-grow: 1;
}

.projects-page .project-card .btn-ghost {
  margin: 10px 18px 18px 18px;
}

/* Responsive - Tablet (1024px) */
@media (max-width: 1024px) {
  .projects-page .projects-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}

/* Responsive - Mobile tablet (768px) */
@media (max-width: 768px) {
  .projects-page .projects-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }

  .projects-page .project-card h3 {
    padding: 16px 16px 8px 16px;
    font-size: 16px;
  }

  .projects-page .project-card .btn-ghost {
    margin: 8px 16px 16px 16px;
  }

  .projects-page .project-card__tag {
    top: 10px;
    left: 10px;
    padding: 5px 10px;
    font-size: 11px;
  }
}

/* Responsive - Mobile (480px) */
@media (max-width: 480px) {
  .projects-page .projects-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .projects-page .project-card {
    border-radius: 6px;
  }

  .projects-page .project-card__media {
    border-radius: 6px 6px 0 0;
  }

  .projects-page .project-card h3 {
    padding: 12px 12px 4px 12px;
    font-size: 14px;
  }

  .projects-page .project-card .btn-ghost {
    margin: 4px 12px 12px 12px;
    font-size: 13px;
    padding: 8px 12px;
  }

  .projects-page .project-card__tag {
    top: 8px;
    left: 8px;
    padding: 4px 8px;
    font-size: 10px;
  }

  .projects-page .project-card:hover {
    transform: translateY(-2px);
  }
}

/* End of PROJECTS PAGE - ENHANCED CARD STYLING */

/* ============================================================================
   ACTIVITIES PAGE (faaliyetlerimiz)
   ============================================================================ */

body[data-page="activities"] {
  background-color: var(--bg);
}

body[data-page="activities"] .activities-main {
  padding-top: var(--header-offset, 96px);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* Hero Section */
body[data-page="activities"] .activities-hero {
  position: relative;
  width: 100%;
  height: clamp(280px, 40vw, 420px);
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.3);
}

body[data-page="activities"] .activities-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

body[data-page="activities"] .activities-hero__overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.5) 100%);
  pointer-events: none;
}

body[data-page="activities"] .activities-hero__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2;
  padding: clamp(24px, 6vw, 48px) 0;
}

body[data-page="activities"] .activities-hero__content .breadcrumb {
  margin-bottom: 16px;
  font-size: clamp(12px, 1.5vw, 14px);
  color: rgba(245, 247, 250, 0.8);
}

body[data-page="activities"] .activities-hero__title {
  margin: 0 0 8px 0;
  font-size: clamp(28px, 6vw, 48px);
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
}

body[data-page="activities"] .activities-hero__subtitle {
  margin: 0;
  font-size: clamp(14px, 2vw, 18px);
  color: rgba(245, 247, 250, 0.9);
  line-height: 1.5;
  max-width: 600px;
}

/* Main Content Section */
body[data-page="activities"] .activities-content {
  padding: clamp(32px, 6vw, 64px) 0;
  flex: 1;
}

body[data-page="activities"] .activities-wrapper {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 32px;
  align-items: start;
}

/* SIDEBAR */
body[data-page="activities"] .activities-sidebar {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

body[data-page="activities"] .activities-sidebar__block {
  background: #fff;
  border: 1px solid rgba(74, 154, 181, 0.2);
  border-radius: 12px;
  padding: 24px;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  transition: all 0.3s ease;
}

body[data-page="activities"] .activities-sidebar__block:hover {
  border-color: rgba(74, 154, 181, 0.4);
  background: rgba(74, 154, 181, 0.04);
}

body[data-page="activities"] .activities-sidebar__title {
  margin: 0 0 20px 0;
  font-size: 16px;
  font-weight: 700;
  color: var(--txt);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Recent Items List */
body[data-page="activities"] .activities-recent-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

body[data-page="activities"] .activities-recent-item {
  display: flex;
  gap: 12px;
  padding: 12px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.8);
  transition: all 0.3s ease;
  text-decoration: none;
  border: 1px solid transparent;
}

body[data-page="activities"] .activities-recent-item:hover,
body[data-page="activities"] .activities-recent-item:focus {
  background: rgba(74, 154, 181, 0.1);
  border-color: rgba(74, 154, 181, 0.3);
  transform: translateX(4px);
  outline: none;
}

body[data-page="activities"] .activities-recent-item:focus {
  box-shadow: 0 0 0 2px rgba(74, 154, 181, 0.5);
}

body[data-page="activities"] .activities-recent-item__thumb {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: 6px;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.2);
}

body[data-page="activities"] .activities-recent-item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

body[data-page="activities"] .activities-recent-item__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex: 1;
  min-width: 0;
}

body[data-page="activities"] .activities-recent-item__title {
  margin: 0 0 4px 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--txt);
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

body[data-page="activities"] .activities-recent-item__meta {
  margin: 0;
  font-size: 12px;
  color: var(--muted);
}

/* Popular Tags/Pills */
body[data-page="activities"] .activities-popular-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

body[data-page="activities"] .activities-popular-tag {
  display: inline-block;
  padding: 6px 12px;
  background: rgba(74, 154, 181, 0.15);
  border: 1px solid rgba(74, 154, 181, 0.3);
  border-radius: 20px;
  font-size: 12px;
  color: var(--txt);
  transition: all 0.3s ease;
  cursor: pointer;
  font-weight: 500;
}

body[data-page="activities"] .activities-popular-tag:hover {
  background: rgba(74, 154, 181, 0.25);
  border-color: rgba(74, 154, 181, 0.5);
  color: var(--txt);
}

/* FEED */
body[data-page="activities"] .activities-feed {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

/* Featured Activity Card */
body[data-page="activities"] .activities-featured {
  background: #fff;
  border: 1px solid rgba(74, 154, 181, 0.2);
  border-radius: 12px;
  overflow: hidden;
  transition: all 0.3s ease;
}

body[data-page="activities"] .activities-featured:hover {
  border-color: rgba(74, 154, 181, 0.5);
  box-shadow: 0 8px 24px rgba(74, 154, 181, 0.1);
  transform: translateY(-2px);
}

body[data-page="activities"] .activities-featured__media {
  width: 100%;
  height: clamp(240px, 50vw, 360px);
  overflow: hidden;
  background: rgba(0, 0, 0, 0.2);
}

body[data-page="activities"] .activities-featured__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.3s ease;
}

body[data-page="activities"] .activities-featured:hover .activities-featured__img {
  transform: scale(1.03);
}

body[data-page="activities"] .activities-featured__content {
  padding: clamp(24px, 4vw, 32px);
}

body[data-page="activities"] .activities-featured__title {
  margin: 0 0 12px 0;
  font-size: clamp(20px, 3vw, 28px);
  font-weight: 700;
  color: var(--txt);
  line-height: 1.3;
}

body[data-page="activities"] .activities-featured__meta {
  margin: 0 0 12px 0;
  font-size: 13px;
  color: var(--muted);
}

body[data-page="activities"] .activities-featured__excerpt {
  margin: 0 0 16px 0;
  font-size: 15px;
  color: var(--txt);
  line-height: 1.6;
}

/* Activity List Items */
body[data-page="activities"] .activities-list {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

body[data-page="activities"] .activities-list-item {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 20px;
  padding: 20px;
  background: #fff;
  border: 1px solid rgba(74, 154, 181, 0.2);
  border-radius: 12px;
  transition: all 0.3s ease;
}

body[data-page="activities"] .activities-list-item:hover {
  border-color: rgba(74, 154, 181, 0.5);
  box-shadow: 0 6px 20px rgba(74, 154, 181, 0.1);
  transform: translateY(-2px);
  background: rgba(74, 154, 181, 0.04);
}

body[data-page="activities"] .activities-list-item__media {
  width: 100%;
  height: 160px;
  border-radius: 8px;
  overflow: hidden;
  background: rgba(244, 248, 249, 0.4);
}

body[data-page="activities"] .activities-list-item__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.3s ease;
}

body[data-page="activities"] .activities-list-item:hover .activities-list-item__media img {
  transform: scale(1.05);
}

body[data-page="activities"] .activities-list-item__content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

body[data-page="activities"] .activities-list-item__title {
  margin: 0 0 8px 0;
  font-size: 18px;
  font-weight: 700;
  color: var(--txt);
  line-height: 1.4;
}

body[data-page="activities"] .activities-list-item__meta {
  margin: 0 0 12px 0;
  font-size: 13px;
  color: var(--muted);
}

body[data-page="activities"] .activities-list-item__excerpt {
  margin: 0 0 16px 0;
  font-size: 15px;
  color: var(--txt);
  line-height: 1.6;
}

body[data-page="activities"] .activities-list-item .btn-ghost {
  align-self: flex-start;
}

/* CTA Section */
body[data-page="activities"] .activities-cta-section {
  padding: clamp(32px, 6vw, 64px) 0;
  border-top: 1px solid rgba(27, 45, 58, 0.06);
  background-color: rgba(244, 248, 249, 0.6);
}

/* Responsive - Tablet (1024px) */
@media (max-width: 1024px) {
  body[data-page="activities"] .activities-wrapper {
    grid-template-columns: 280px 1fr;
    gap: 24px;
  }

  body[data-page="activities"] .activities-sidebar__block {
    padding: 20px;
  }

  body[data-page="activities"] .activities-list-item {
    grid-template-columns: 200px 1fr;
    gap: 16px;
    padding: 16px;
  }

  body[data-page="activities"] .activities-list-item__media {
    height: 140px;
  }

  body[data-page="activities"] .activities-list-item__title {
    font-size: 16px;
  }

  body[data-page="activities"] .activities-featured__content {
    padding: 20px;
  }

  body[data-page="activities"] .activities-featured__title {
    font-size: clamp(18px, 2.5vw, 24px);
  }
}

/* Responsive - Mobile (768px) */
@media (max-width: 768px) {
  body[data-page="activities"] .activities-main {
    padding-top: 80px;
  }

  body[data-page="activities"] .activities-hero {
    height: clamp(240px, 50vw, 300px);
  }

  body[data-page="activities"] .activities-content {
    padding: 24px 0;
  }

  body[data-page="activities"] .activities-wrapper {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  body[data-page="activities"] .activities-sidebar {
    order: 2;
    gap: 24px;
  }

  body[data-page="activities"] .activities-feed {
    order: 1;
    gap: 24px;
  }

  body[data-page="activities"] .activities-list-item {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 12px;
  }

  body[data-page="activities"] .activities-list-item__media {
    height: 180px;
  }

  body[data-page="activities"] .activities-recent-item {
    padding: 10px;
    gap: 10px;
  }

  body[data-page="activities"] .activities-recent-item__thumb {
    width: 70px;
    height: 70px;
  }

  body[data-page="activities"] .activities-recent-item__title {
    font-size: 13px;
  }

  body[data-page="activities"] .activities-featured__content {
    padding: 16px;
  }

  body[data-page="activities"] .activities-featured__title {
    font-size: clamp(18px, 4vw, 22px);
    margin-bottom: 8px;
  }

  body[data-page="activities"] .activities-featured__excerpt {
    margin-bottom: 12px;
    font-size: 14px;
  }

  body[data-page="activities"] .activities-sidebar__title {
    font-size: 15px;
    margin-bottom: 16px;
  }

  body[data-page="activities"] .activities-list-item__title {
    font-size: 15px;
  }

  body[data-page="activities"] .activities-list-item__excerpt {
    font-size: 14px;
  }
}

/* Responsive - Small Mobile (480px) */
@media (max-width: 480px) {
  body[data-page="activities"] .activities-main {
    padding-top: 74px;
  }

  body[data-page="activities"] .activities-hero {
    height: clamp(200px, 60vw, 260px);
  }

  body[data-page="activities"] .activities-hero__content {
    padding: 16px 0;
  }

  body[data-page="activities"] .activities-hero__title {
    font-size: clamp(22px, 5vw, 28px);
  }

  body[data-page="activities"] .activities-hero__subtitle {
    font-size: clamp(13px, 3vw, 15px);
  }

  body[data-page="activities"] .activities-content {
    padding: 16px 0;
  }

  body[data-page="activities"] .activities-sidebar {
    gap: 16px;
  }

  body[data-page="activities"] .activities-feed {
    gap: 16px;
  }

  body[data-page="activities"] .activities-sidebar__block {
    padding: 16px;
    border-radius: 8px;
  }

  body[data-page="activities"] .activities-sidebar__title {
    font-size: 14px;
    margin-bottom: 12px;
  }

  body[data-page="activities"] .activities-recent-list {
    gap: 12px;
  }

  body[data-page="activities"] .activities-recent-item {
    padding: 8px;
    gap: 8px;
  }

  body[data-page="activities"] .activities-recent-item__thumb {
    width: 60px;
    height: 60px;
  }

  body[data-page="activities"] .activities-recent-item__title {
    font-size: 12px;
  }

  body[data-page="activities"] .activities-recent-item__meta {
    font-size: 11px;
  }

  body[data-page="activities"] .activities-popular-tag {
    padding: 5px 10px;
    font-size: 11px;
  }

  body[data-page="activities"] .activities-featured {
    border-radius: 8px;
  }

  body[data-page="activities"] .activities-featured__media {
    height: clamp(180px, 50vw, 220px);
  }

  body[data-page="activities"] .activities-featured__content {
    padding: 12px;
  }

  body[data-page="activities"] .activities-featured__title {
    font-size: clamp(16px, 4vw, 20px);
    margin-bottom: 6px;
  }

  body[data-page="activities"] .activities-featured__meta {
    margin-bottom: 8px;
    font-size: 12px;
  }

  body[data-page="activities"] .activities-featured__excerpt {
    margin-bottom: 10px;
    font-size: 13px;
    line-height: 1.5;
  }

  body[data-page="activities"] .activities-list-item {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 10px;
    border-radius: 8px;
  }

  body[data-page="activities"] .activities-list-item__media {
    height: 150px;
    border-radius: 6px;
  }

  body[data-page="activities"] .activities-list-item__title {
    font-size: 14px;
    margin-bottom: 4px;
  }

  body[data-page="activities"] .activities-list-item__meta {
    font-size: 12px;
    margin-bottom: 6px;
  }

  body[data-page="activities"] .activities-list-item__excerpt {
    font-size: 13px;
    margin-bottom: 8px;
    line-height: 1.5;
  }

  body[data-page="activities"] .activities-list-item .btn-ghost {
    font-size: 13px;
    padding: 8px 12px;
  }

  body[data-page="activities"] .activities-cta-section {
    padding: 24px 0;
  }
}

/* End of ACTIVITIES PAGE */

/* ================================
   GALLERY — PREMIUM REDESIGN OVERRIDES
   Scoped: body[data-page="gallery"]
   Appended to override previous gallery rules with premium look
   ================================ */

body[data-page="gallery"] {
  --gallery-hero-min: 320px;
  --gallery-hero-max: 440px;
  --gallery-chip-bg: rgba(27,45,58,0.03);
  --gallery-chip-border: rgba(27,45,58,0.08);
  --gallery-card-bg: #fff;
  --gallery-card-border: rgba(74,154,181,0.15);
}

/* 1) Cinematic HERO */
body[data-page="gallery"] .gallery-hero {
  min-height: var(--gallery-hero-min);
  max-height: var(--gallery-hero-max);
  display: flex;
  align-items: flex-end;
  position: relative;
  overflow: hidden;
}

body[data-page="gallery"] .gallery-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background-image:
    linear-gradient(180deg, rgba(15,17,19,0.6) 0%, rgba(15,17,19,0.8) 70%),
    radial-gradient(ellipse at center, rgba(0,0,0,0.08) 0%, rgba(0,0,0,0.45) 80%);
  pointer-events: none;
}

/* subtle noise via pseudo-element (css-only approximation) */
body[data-page="gallery"] .gallery-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  background-image: linear-gradient(180deg, rgba(255,255,255,0.002) 0%, rgba(0,0,0,0.002) 100%);
  mix-blend-mode: overlay;
  pointer-events: none;
}

body[data-page="gallery"] .gallery-hero__img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center;
  transition: transform 12s ease;
}

body[data-page="gallery"] .gallery-hero:hover .gallery-hero__img { transform: scale(1.02); }

body[data-page="gallery"] .gallery-hero__content #galleryTitle {
  font-size: clamp(32px, 6vw, 56px);
  text-shadow: 0 6px 30px rgba(6,8,10,0.6);
  z-index: 4;
}

/* 2) Floating filter bar (glass) */
body[data-page="gallery"] .gallery-filters {
  position: sticky;
  top: calc(var(--gallery-header-offset, 96px) + 12px);
  z-index: 50;
  margin: 0 auto 20px;
  backdrop-filter: blur(10px) saturate(120%);
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border: 1px solid rgba(255,255,255,0.04);
  padding: 10px 16px;
  border-radius: 14px;
  box-shadow: 0 8px 40px rgba(6,8,10,0.5);
}

body[data-page="gallery"] .filter-row { align-items: center; }

body[data-page="gallery"] .tabs { gap: 10px; }

body[data-page="gallery"] .tab {
  background: var(--gallery-chip-bg);
  border: 1px solid var(--gallery-chip-border);
  padding: 10px 16px;
  border-radius: 999px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

body[data-page="gallery"] .tab:hover { transform: translateY(-4px); box-shadow: 0 14px 36px rgba(6,8,10,0.45); }

body[data-page="gallery"] .tab.is-active {
  color: var(--txt);
  background: linear-gradient(90deg,#dff6f8 0%, #cfeff3 100%);
  box-shadow: 0 10px 30px rgba(74,154,181,0.12), inset 0 0 0 2px rgba(74,154,181,0.12);
}

body[data-page="gallery"] .filter-search input[type="search"] {
  min-width: 200px; padding: 10px 14px; border-radius: 12px;
  background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.04); color: inherit;
}

/* 3) Masonry-ish Grid (CSS-only) */
body[data-page="gallery"] .gallery-grid {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 16px; grid-auto-rows: 10px;
}

/* default desktop spans */
body[data-page="gallery"] .gallery-card { grid-column: span 3; grid-row: span 9; }
body[data-page="gallery"] .gallery-card.is-tall { grid-row: span 14; }
body[data-page="gallery"] .gallery-card.is-mid  { grid-row: span 10; }
body[data-page="gallery"] .gallery-card.is-short{ grid-row: span 8; }

/* ensure card fills cell */
body[data-page="gallery"] .gallery-card { display:block; position:relative; overflow:hidden; }

/* 4) Card style — editorial */
body[data-page="gallery"] .gallery-card {
  border-radius: 20px; background: var(--gallery-card-bg); border:1px solid var(--gallery-card-border);
  backdrop-filter: blur(6px); transition: transform .28s cubic-bezier(.2,.9,.3,1), box-shadow .28s ease;
}

body[data-page="gallery"] .gallery-card img { width:100%; height:100%; object-fit:cover; display:block; transition: transform .6s ease; }
body[data-page="gallery"] .gallery-card:hover img { transform: scale(1.04); }

/* bottom info overlay */
body[data-page="gallery"] .card-info { position:absolute; left:12px; right:12px; bottom:12px; padding:12px 14px; border-radius:12px;
  background: linear-gradient(180deg, rgba(15,17,19,0.0) 0%, rgba(15,17,19,0.68) 70%); display:flex; align-items:center; justify-content:space-between; gap:10px; }
body[data-page="gallery"] .card-info h3 { margin:0; font-size:1rem; font-weight:700; color:#fff; }
body[data-page="gallery"] .card-tag { padding:6px 10px; border-radius:999px; font-size:0.78rem; background: rgba(255,255,255,0.04); color: rgba(234,241,245,0.94); border:1px solid rgba(255,255,255,0.04); }

body[data-page="gallery"] .gallery-card:hover { transform: translateY(-8px); box-shadow: 0 30px 90px rgba(6,8,10,0.68); }

/* 5) Lightbox enhancements */
body[data-page="gallery"] .lightbox__close { width:56px; height:42px; border-radius:999px; font-size:22px; padding:6px 12px; right:14px; top:14px; background: rgba(255,255,255,0.06); backdrop-filter: blur(6px); }
body[data-page="gallery"] .lightbox__content img { box-shadow: 0 22px 80px rgba(6,8,10,0.75); border-radius:10px; }

/* 6) Responsive spans */
@media (max-width: 1024px) { body[data-page="gallery"] .gallery-card { grid-column: span 4; } }
@media (max-width: 768px)  { body[data-page="gallery"] { --gallery-header-offset:80px; } body[data-page="gallery"] .gallery-card { grid-column: span 6; } }
@media (max-width: 480px)  { body[data-page="gallery"] { --gallery-header-offset:74px; } body[data-page="gallery"] .gallery-card { grid-column: span 12; } body[data-page="gallery"] .card-info { left:10px; right:10px; bottom:10px; } }

/* LEGAL / CORPORATE PAGES */
body[data-page="legal"] {
  background: var(--bg);
  color: var(--txt);
}

body[data-page="legal"] .corporate-main {
  padding-top: var(--header-offset, 96px);
  min-height: 100vh;
}

body[data-page="legal"] .corporate-hero {
  position: relative;
  width: 100%;
  height: clamp(220px, 34vw, 360px);
  overflow: hidden;
  background: rgba(0, 0, 0, 0.24);
}

body[data-page="legal"] .corporate-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.2), rgba(15, 17, 19, 0.65));
}

body[data-page="legal"] .corporate-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

body[data-page="legal"] .corporate-header {
  padding: 24px 0 14px;
}

body[data-page="legal"] .corporate-title {
  margin: 8px 0 0;
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1.2;
}

body[data-page="legal"] .corporate-content {
  padding: 10px 0 36px;
}

body[data-page="legal"] .corporate-body {
  background: #fff;
  border: 1px solid rgba(27, 45, 58, 0.08);
  border-radius: 16px;
  padding: clamp(16px, 2.2vw, 26px);
}

body[data-page="legal"] .charter-heading {
  margin: 0 0 10px;
  font-size: clamp(20px, 2.6vw, 30px);
  line-height: 1.3;
}

body[data-page="legal"] .charter-intro {
  margin: 0 0 14px;
  color: var(--muted);
}

body[data-page="legal"] .charter-pre {
  margin: 0;
  white-space: pre-wrap;
  word-break: break-word;
  font-family: inherit;
  line-height: 1.75;
  color: rgba(27, 45, 58, 0.9);
}

@media (max-width: 768px) {
  body[data-page="legal"] .corporate-main {
    padding-top: 80px;
  }
}

@media (max-width: 480px) {
  body[data-page="legal"] .corporate-main {
    padding-top: 74px;
  }

  body[data-page="legal"] .corporate-body {
    border-radius: 12px;
    padding: 14px;
  }
}

/* CONTACT PAGE */
body[data-page="contact"] {
  background: var(--bg);
  color: var(--txt);
}

body[data-page="contact"] .contact-main {
  padding-top: calc(var(--header-h) + 20px);
  padding-bottom: 56px;
}

body[data-page="contact"] .contact-hero {
  padding: 12px 0 20px;
}

body[data-page="contact"] .contact-title {
  margin: 10px 0 0;
  font-size: clamp(30px, 4.4vw, 48px);
  line-height: 1.1;
}

body[data-page="contact"] .contact-subtitle {
  margin: 12px 0 0;
  max-width: 760px;
  color: var(--muted);
  font-weight: 600;
}

body[data-page="contact"] .contact-content {
  padding: 10px 0 24px;
}

body[data-page="contact"] .contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

body[data-page="contact"] .contact-cards {
  display: grid;
  gap: 12px;
}

body[data-page="contact"] .contact-card,
body[data-page="contact"] .contact-map-wrap {
  background: #fff;
  border: 1px solid rgba(27, 45, 58, 0.08);
  border-radius: 14px;
  padding: 16px;
}

body[data-page="contact"] .contact-card h2,
body[data-page="contact"] .contact-map-wrap h2 {
  margin: 0 0 8px;
  font-size: 18px;
}

body[data-page="contact"] .contact-card p {
  margin: 0;
  line-height: 1.65;
  color: rgba(27, 45, 58, 0.85);
}

body[data-page="contact"] .contact-card a {
  color: var(--brand);
  text-decoration: none;
}

body[data-page="contact"] .contact-card a:hover {
  text-decoration: underline;
}

body[data-page="contact"] .contact-card .btn {
  margin-top: 12px;
  text-decoration: none;
}

body[data-page="contact"] .contact-map {
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(27, 45, 58, 0.08);
  background: #fff;
}

body[data-page="contact"] .contact-map iframe {
  width: 100%;
  min-height: 420px;
  display: block;
}

@media (max-width: 980px) {
  body[data-page="contact"] .contact-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  body[data-page="contact"] .contact-main {
    padding-top: calc(var(--header-h) + 14px);
  }

  body[data-page="contact"] .contact-card,
  body[data-page="contact"] .contact-map-wrap {
    padding: 14px;
  }

  body[data-page="contact"] .contact-map iframe {
    min-height: 300px;
  }
}

/* ============================================================================
   IMPACT MAP PAGE + IMPACT DETAIL PAGE
   ============================================================================ */

body[data-page="impact-map"] .impact-map-main,
body[data-page="impact-detail"] .impact-detail-main {
  padding-top: calc(var(--header-h) + 20px);
  padding-bottom: 56px;
}

body[data-page="impact-map"] .impact-map-head h1,
body[data-page="impact-detail"] .impact-detail-head h1 {
  margin: 8px 0 0;
  font-size: clamp(30px, 4.8vw, 52px);
  line-height: 1.08;
}

body[data-page="impact-map"] .impact-map-head p,
body[data-page="impact-detail"] .impact-detail-head p {
  margin: 12px 0 0;
  max-width: 780px;
  color: var(--muted);
  font-weight: 600;
}

body[data-page="impact-map"] .impact-map-content {
  margin-top: 18px;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
}

body[data-page="impact-map"] .impact-globe-card {
  border: 1px solid rgba(74, 154, 181, 0.18);
  background: #fff;
  border-radius: 18px;
  padding: 14px;
  box-shadow: 0 22px 60px rgba(27, 45, 58, 0.06);
}

body[data-page="impact-map"] .impact-globe-stage {
  width: 100%;
  min-height: 560px;
  border-radius: 14px;
  border: 1px solid rgba(74, 154, 181, 0.28);
  background:
    radial-gradient(circle at 50% 40%, rgba(74, 154, 181, 0.16), transparent 45%),
    rgba(244, 248, 249, 0.72);
  display: grid;
  place-items: center;
  cursor: grab;
  touch-action: none;
}

body[data-page="impact-map"] .impact-globe-stage.is-dragging { cursor: grabbing; }

body[data-page="impact-map"] .impact-globe {
  position: relative;
  width: min(420px, 86vw);
  aspect-ratio: 1/1;
  transform-style: preserve-3d;
  transition: transform 80ms linear;
}

body[data-page="impact-map"] .impact-globe__sphere {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  overflow: hidden;
  background:
    radial-gradient(circle at 35% 30%, rgba(255, 255, 255, 0.18), transparent 38%),
    radial-gradient(circle at 30% 25%, rgba(64, 119, 189, 0.42), rgba(9, 22, 48, 0.94) 62%),
    linear-gradient(180deg, rgba(30, 50, 90, 0.9), rgba(8, 18, 36, 0.94));
  border: 1px solid rgba(74, 154, 181, 0.35);
  box-shadow:
    inset -28px -22px 60px rgba(0, 0, 0, 0.45),
    inset 0 0 36px rgba(74, 154, 181, 0.25),
    0 20px 60px rgba(2, 8, 20, 0.65);
}

body[data-page="impact-map"] .impact-land {
  position: absolute;
  background: linear-gradient(180deg, rgba(130, 188, 117, 0.82), rgba(61, 128, 57, 0.82));
  border: 1px solid rgba(190, 234, 170, 0.2);
  filter: saturate(1.1);
}
body[data-page="impact-map"] .impact-land--africa { width: 35%; height: 40%; left: 45%; top: 36%; border-radius: 42% 38% 52% 48%; transform: rotate(8deg); }
body[data-page="impact-map"] .impact-land--europe { width: 22%; height: 16%; left: 44%; top: 23%; border-radius: 42% 40% 45% 55%; }
body[data-page="impact-map"] .impact-land--asia { width: 34%; height: 22%; left: 60%; top: 25%; border-radius: 58% 42% 40% 60%; }
body[data-page="impact-map"] .impact-land--arabia { width: 15%; height: 14%; left: 61%; top: 39%; border-radius: 42% 54% 58% 40%; }

body[data-page="impact-map"] .impact-hotspot {
  position: absolute;
  left: 49%;
  top: 46%;
  width: 30%;
  height: 33%;
  border-radius: 48%;
  border: 1px dashed rgba(255, 255, 255, 0.22);
  background: rgba(74, 154, 181, 0.08);
  cursor: pointer;
}

body[data-page="impact-map"] .impact-country {
  position: absolute;
  z-index: 3;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(156, 231, 255, 0.8);
  background: rgba(92, 187, 214, 0.24);
  color: #eaf8ff;
  font-size: 11px;
  font-weight: 800;
  cursor: pointer;
}

body[data-page="impact-map"] .impact-country--uganda { left: 58%; top: 50%; }
body[data-page="impact-map"] .impact-country--somalia { left: 66%; top: 48%; }
body[data-page="impact-map"] .impact-country--sudan { left: 61%; top: 43%; }
body[data-page="impact-map"] .impact-country--gaza { left: 59%; top: 36%; }

body[data-page="impact-map"] .impact-map-hint {
  margin: 12px 4px 0;
  color: var(--muted);
  font-size: 13px;
}

body[data-page="impact-map"] .impact-map-side {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
body[data-page="impact-map"] .impact-country-card {
  border: 1px solid rgba(74, 154, 181, 0.26);
  background: #fff;
  border-radius: 14px;
  padding: 14px;
  box-shadow: 0 22px 60px rgba(27, 45, 58, 0.06);
}
body[data-page="impact-map"] .impact-country-card h2 { margin: 0; }
body[data-page="impact-map"] .impact-country-card p { margin: 10px 0 0; color: var(--muted); }
body[data-page="impact-map"] .impact-country-card a {
  margin-top: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(74, 154, 181, 0.26);
  background: rgba(74, 154, 181, 0.12);
  color: var(--txt);
  text-decoration: none;
  font-weight: 700;
}

body[data-page="impact-detail"] .impact-detail-filters {
  margin-top: 18px;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
}

body[data-page="impact-detail"] .impact-filter-card,
body[data-page="impact-detail"] .impact-assets-card {
  border: 1px solid rgba(74, 154, 181, 0.26);
  background: #fff;
  border-radius: 14px;
  padding: 14px;
  box-shadow: 0 22px 60px rgba(27, 45, 58, 0.06);
}

body[data-page="impact-detail"] .impact-filter-card label {
  display: block;
  margin-bottom: 8px;
  font-size: 13px;
  color: var(--muted);
  font-weight: 700;
}

body[data-page="impact-detail"] .impact-filter-card select {
  width: 100%;
  min-height: 42px;
  border-radius: 10px;
  padding: 0 10px;
}

body[data-page="impact-detail"] .impact-filter-card--country {
  border-radius: 16px;
  background: linear-gradient(145deg, #ffffff, #f7fbfc);
}

body[data-page="impact-detail"] .impact-filter-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

body[data-page="impact-detail"] .impact-filter-head label {
  margin: 0;
  font-size: 14px;
  color: #1B2D3A;
}

body[data-page="impact-detail"] .impact-filter-head p {
  margin: 0;
  font-size: 12px;
  color: #7A99A8;
  font-weight: 600;
}

body[data-page="impact-detail"] .impact-select-shell {
  margin-top: 10px;
  position: relative;
}

body[data-page="impact-detail"] .impact-select-shell__icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
}

body[data-page="impact-detail"] .impact-filter-card--country select {
  min-height: 50px;
  border-radius: 12px;
  border: 1px solid rgba(74, 154, 181, 0.3);
  background: #fff;
  color: #1B2D3A;
  font-weight: 600;
  padding: 0 38px 0 40px;
  box-shadow: 0 0 0 3px rgba(74, 154, 181, 0.08);
}

body[data-page="impact-detail"] .impact-detail-metrics { margin-top: 12px; }
body[data-page="impact-detail"] .impact-metrics-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

body[data-page="impact-detail"] .impact-metric-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(74, 154, 181, 0.22);
  background: linear-gradient(145deg, #ffffff, #f8fbfc);
  border-radius: 14px;
  padding: 14px;
  box-shadow: 0 10px 26px rgba(27, 45, 58, 0.08);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

body[data-page="impact-detail"] .impact-metric-card::after {
  content: "";
  position: absolute;
  right: -22px;
  top: -24px;
  width: 72px;
  height: 72px;
  border-radius: 999px;
  background: radial-gradient(circle at center, rgba(74, 154, 181, 0.18), rgba(74, 154, 181, 0));
  pointer-events: none;
}

body[data-page="impact-detail"] .impact-metric-card:hover {
  transform: translateY(-2px);
  border-color: rgba(74, 154, 181, 0.36);
  box-shadow: 0 16px 34px rgba(27, 45, 58, 0.12);
}
body[data-page="impact-detail"] .impact-metric-card__label {
  margin: 0;
  color: #6f8a98;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.01em;
}
body[data-page="impact-detail"] .impact-metric-card__value {
  margin: 8px 0 0;
  font-size: clamp(22px, 2.3vw, 28px);
  font-weight: 800;
  line-height: 1.25;
  color: #1B2D3A;
}

body[data-page="impact-detail"] .impact-detail-assets { margin-top: 12px; }
body[data-page="impact-detail"] .impact-assets-card {
  border-radius: 16px;
  border-color: rgba(74, 154, 181, 0.2);
  background: linear-gradient(145deg, #ffffff, #f8fbfc);
  box-shadow: 0 14px 42px rgba(27, 45, 58, 0.09);
}
body[data-page="impact-detail"] .impact-assets-card h2 {
  margin: 0 0 10px;
  font-size: 22px;
  color: #1B2D3A;
}
body[data-page="impact-detail"] .impact-assets-list { display: grid; gap: 10px; }
body[data-page="impact-detail"] .impact-asset-item {
  border: 1px solid rgba(74, 154, 181, 0.2);
  border-radius: 12px;
  padding: 14px;
  background: #fff;
  box-shadow: 0 8px 18px rgba(27, 45, 58, 0.06);
}
body[data-page="impact-detail"] .impact-asset-item h3 {
  margin: 0 0 10px;
  color: #1B2D3A;
  font-size: 16px;
}
body[data-page="impact-detail"] .impact-asset-item p {
  margin: 6px 0 0;
  color: #3d5a69;
  font-size: 14px;
  line-height: 1.45;
}
body[data-page="impact-detail"] .impact-asset-item p strong {
  color: #1B2D3A;
  font-weight: 700;
}
body[data-page="impact-detail"] .impact-asset-item--plain {
  border-style: solid;
}
body[data-page="impact-detail"] .impact-asset-item--plain h3 {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.5;
}
body[data-page="impact-detail"] .impact-assets-empty { margin: 0; color: var(--muted); }

@media (max-width: 1024px) {
  body[data-page="impact-map"] .impact-map-content { grid-template-columns: 1fr; }
  body[data-page="impact-map"] .impact-map-side { grid-template-columns: 1fr; }
  body[data-page="impact-detail"] .impact-metrics-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 768px) {
  body[data-page="impact-map"] .impact-map-main,
  body[data-page="impact-detail"] .impact-detail-main {
    padding-top: calc(var(--header-h) + 14px);
  }
  body[data-page="impact-map"] .impact-globe-stage { min-height: 400px; }
  body[data-page="impact-detail"] .impact-detail-filters { grid-template-columns: 1fr; }
}

/* Real globe overrides */
body[data-page="impact-map"] .impact-globe-stage {
  overflow: hidden;
  position: relative;
}

body[data-page="impact-map"] .impact-globe-canvas {
  width: 100%;
  height: 100%;
  min-height: inherit;
}

body[data-page="impact-map"] .impact-globe-canvas canvas {
  width: 100% !important;
  height: 100% !important;
  display: block;
}

@media (max-width: 600px) {
  body[data-page="impact-map"] .impact-map-head h1,
  body[data-page="impact-detail"] .impact-detail-head h1 {
    font-size: clamp(30px, 8.6vw, 40px);
  }

  body[data-page="impact-map"] .impact-map-head p,
  body[data-page="impact-detail"] .impact-detail-head p {
    font-size: 15px;
    line-height: 1.55;
  }

  body[data-page="impact-map"] .impact-map-content {
    gap: 12px;
    margin-top: 14px;
  }

  body[data-page="impact-map"] .impact-globe-card {
    padding: 10px;
    border-radius: 14px;
  }

  body[data-page="impact-map"] .impact-globe-stage {
    min-height: 360px;
    border-radius: 12px;
  }

  body[data-page="impact-map"] .impact-map-hint {
    font-size: 12px;
    line-height: 1.4;
    margin: 10px 2px 0;
  }

  body[data-page="impact-map"] .impact-country-card {
    padding: 12px;
    border-radius: 12px;
  }

  body[data-page="impact-map"] .impact-country-card p {
    overflow-wrap: anywhere;
    word-break: break-word;
    line-height: 1.55;
    font-size: 14px;
  }

  body[data-page="impact-map"] .impact-country-card a {
    min-height: 36px;
    padding: 0 12px;
    font-size: 13px;
  }

  body[data-page="impact-detail"] .impact-metrics-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================================================
   MOBILE HEADER + FOOTER FIXES
   ============================================================================ */

@media (max-width: 768px) {
  .site-header {
    height: 68px;
  }

  .header-inner {
    width: calc(100% - 20px);
    display: grid;
    grid-template-columns: 42px 1fr auto auto;
    gap: 10px;
    align-items: center;
  }

  .menu-toggle {
    width: 38px;
    height: 38px;
    margin: 0;
    justify-self: start;
  }

  .brand {
    justify-self: center;
  }

  .brand img {
    width: 92px;
    max-width: 92px;
  }

  .mobile-icons-bar {
    justify-self: end;
    gap: 6px;
  }

  .mobile-lang-inline {
    display: flex;
    justify-self: end;
    gap: 3px;
    position: relative;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 999px;
    padding: 2px 3px;
    background: rgba(244, 248, 249, 0.8);
  }

  .mobile-lang-inline .lang-dropdown-toggle {
    font-size: 10px;
    padding: 3px 6px;
  }

  .mobile-icons-bar .icon-btn {
    width: 34px;
    height: 34px;
  }

  .mobile-menu.mobile-open {
    top: 68px;
    padding: 14px 16px;
  }
}

@media (max-width: 480px) {
  .site-header {
    height: 64px;
  }

  .header-inner {
    width: calc(100% - 14px);
    grid-template-columns: 36px 1fr auto auto;
    gap: 8px;
  }

  .menu-toggle {
    width: 34px;
    height: 34px;
  }

  .brand img {
    width: 84px;
    max-width: 84px;
  }

  .mobile-icons-bar .icon-btn {
    width: 32px;
    height: 32px;
  }

  .mobile-lang-inline .lang-dropdown-toggle {
    font-size: 9px;
    padding: 2px 5px;
  }

  .mobile-menu.mobile-open {
    top: 64px;
    padding: 12px 14px;
  }
}

/* ===== Modern mobile nav (responsive only) ===== */
@media (max-width: 1100px) {
  .menu-toggle {
    border: 1px solid rgba(27, 45, 58, 0.16);
    background: rgba(255, 255, 255, 0.82);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.16);
    transition: all 0.28s ease;
  }

  .menu-toggle:hover {
    background: rgba(255, 255, 255, 0.92);
    border-color: rgba(27, 45, 58, 0.28);
    transform: translateY(-1px);
  }

  .menu-toggle[aria-expanded="true"] {
    border-color: rgba(74, 154, 181, 0.55);
    background: rgba(74, 154, 181, 0.18);
    color: #eaf7fb;
    box-shadow: 0 10px 28px rgba(15, 26, 34, 0.22);
  }

  .mobile-menu.mobile-open {
    left: 8px;
    right: 8px;
    top: calc(var(--header-h) + 8px);
    border: 1px solid rgba(27, 45, 58, 0.12);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.94);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    box-shadow: 0 24px 50px rgba(10, 18, 26, 0.22);
    padding: 14px;
    gap: 10px;
    max-height: min(76vh, calc(100vh - var(--header-h) - 24px));
  }

  .mobile-menu.mobile-open .nav-link {
    display: flex;
    align-items: center;
    min-height: 46px;
    padding: 10px 12px;
    border-radius: 12px;
    color: #1f2f3a;
    font-weight: 700;
    letter-spacing: 0.01em;
    text-decoration: none;
    transition: background 0.22s ease, color 0.22s ease, transform 0.22s ease;
  }

  body[data-page="home"] .site-header .mobile-menu.mobile-open .nav-link,
  body[data-page="home"] .site-header .mobile-menu.mobile-open .mobile-submenu__trigger {
    color: #1f2f3a;
  }

  .mobile-menu.mobile-open .nav-link:hover,
  .mobile-menu.mobile-open .nav-link:focus-visible {
    background: rgba(74, 154, 181, 0.1);
    color: #173341;
    transform: translateX(2px);
    outline: none;
  }

  .mobile-menu .mobile-submenu__trigger {
    min-height: 48px;
    border-radius: 12px;
    border: 1px solid rgba(27, 45, 58, 0.16);
    background: rgba(255, 255, 255, 0.9);
    color: #1f2f3a;
    font-weight: 800;
  }

  .mobile-menu .mobile-submenu__trigger:hover,
  .mobile-menu .mobile-submenu__trigger:focus-visible {
    border-color: rgba(74, 154, 181, 0.5);
    background: rgba(74, 154, 181, 0.1);
  }

  .mobile-menu.mobile-open .mobile-menu-section {
    margin-top: 12px;
    padding-top: 14px;
    border-top: 1px solid rgba(27, 45, 58, 0.1);
    gap: 10px;
  }

  /* Keep donation catalog visible inside mobile menu */
  .mobile-menu.mobile-open .mobile-menu-section > .btn.btn-pill {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 46px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid rgba(27, 45, 58, 0.12);
    background: rgba(244, 248, 249, 0.8);
    color: #1f2f3a;
    font-weight: 700;
    text-decoration: none;
  }

  .mobile-menu.mobile-open .mobile-menu-section > .btn.btn-pill:hover,
  .mobile-menu.mobile-open .mobile-menu-section > .btn.btn-pill:focus-visible {
    background: rgba(74, 154, 181, 0.1);
    color: #173341;
    border-color: rgba(74, 154, 181, 0.45);
    outline: none;
  }

  .mobile-menu.mobile-open .mobile-quick-actions {
    margin-bottom: 4px;
  }
}

@media (max-width: 480px) {
  .mobile-menu.mobile-open {
    left: 6px;
    right: 6px;
    top: calc(var(--header-h) + 6px);
    border-radius: 16px;
    padding: 12px;
    max-height: min(74vh, calc(100vh - var(--header-h) - 18px));
  }

  .mobile-menu.mobile-open .nav-link,
  .mobile-menu .mobile-submenu__trigger {
    min-height: 42px;
    padding: 8px 10px;
    font-size: 15px;
  }

  .mobile-menu.mobile-open .mobile-menu-section > .btn.btn-pill {
    min-height: 42px;
    padding: 8px 10px;
    font-size: 15px;
  }
}

/* Keep footer pinned bottom on impact pages */
body[data-page="impact-map"],
body[data-page="impact-detail"] {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

body[data-page="impact-map"] .impact-map-main,
body[data-page="impact-detail"] .impact-detail-main {
  flex: 1;
}

body[data-page="impact-map"] .ch-footer,
body[data-page="impact-detail"] .ch-footer {
  margin-top: auto !important;
}

/* ================================
   GALLERY — MODERN REFRESH
   ================================ */
body[data-page="gallery"] {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

body[data-page="gallery"] .gallery-main {
  position: relative;
  flex: 1;
  padding-top: calc(var(--header-h) + 24px);
  padding-bottom: 44px;
}

body[data-page="gallery"] .gallery-bg-fx {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

body[data-page="gallery"] .gallery-bg-fx__mesh {
  position: absolute;
  inset: 0;
  opacity: 0.35;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(74, 154, 181, 0.15) 1px, transparent 0);
  background-size: 26px 26px;
}

body[data-page="gallery"] .gallery-bg-fx__orb {
  position: absolute;
  border-radius: 999px;
  filter: blur(70px);
}

body[data-page="gallery"] .gallery-bg-fx__orb--a {
  width: 320px;
  height: 320px;
  left: -100px;
  top: 140px;
  background: rgba(74, 154, 181, 0.22);
}

body[data-page="gallery"] .gallery-bg-fx__orb--b {
  width: 280px;
  height: 280px;
  right: -90px;
  top: 80px;
  background: rgba(27, 45, 58, 0.14);
}

body[data-page="gallery"] .gallery-head,
body[data-page="gallery"] .gallery-controls,
body[data-page="gallery"] .gallery-section {
  position: relative;
  z-index: 1;
}

body[data-page="gallery"] .gallery-head__card {
  border-radius: 28px;
  border: 1px solid rgba(74, 154, 181, 0.2);
  background: linear-gradient(145deg, #ffffff, #f8fbfc);
  box-shadow: 0 20px 55px rgba(27, 45, 58, 0.08);
  padding: 30px;
}

body[data-page="gallery"] .gallery-kicker {
  margin: 0;
  color: #4A9AB5;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body[data-page="gallery"] .gallery-title {
  margin: 8px 0 10px;
  font-size: clamp(34px, 5.6vw, 56px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: #1B2D3A;
}

body[data-page="gallery"] .gallery-subtitle {
  margin: 0;
  max-width: 760px;
  color: #4A6B7C;
  font-size: clamp(15px, 1.7vw, 18px);
  line-height: 1.65;
}

body[data-page="gallery"] .gallery-stats {
  margin-top: 22px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

body[data-page="gallery"] .gallery-stat {
  min-width: 140px;
  border-radius: 14px;
  border: 1px solid rgba(74, 154, 181, 0.2);
  background: rgba(255, 255, 255, 0.72);
  padding: 12px 14px;
}

body[data-page="gallery"] .gallery-stat strong {
  display: block;
  font-size: 22px;
  color: #1B2D3A;
  line-height: 1.1;
}

body[data-page="gallery"] .gallery-stat span {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  color: #6f8a98;
}

body[data-page="gallery"] .gallery-controls {
  margin-top: 16px;
}

body[data-page="gallery"] .gallery-controls__inner {
  display: flex;
  gap: 16px;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  border-radius: 18px;
  border: 1px solid rgba(74, 154, 181, 0.2);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 14px 40px rgba(27, 45, 58, 0.06);
  padding: 14px;
}

body[data-page="gallery"] .gallery-filters {
  margin: 0;
  border: 0;
  padding: 0;
  box-shadow: none;
  background: transparent;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

body[data-page="gallery"] .tab {
  border: 1px solid rgba(74, 154, 181, 0.26);
  border-radius: 999px;
  background: #fff;
  color: #2a4554;
  font-weight: 600;
  padding: 10px 15px;
  transition: all 0.2s ease;
}

body[data-page="gallery"] .tab:hover {
  border-color: #4A9AB5;
  transform: translateY(-1px);
}

body[data-page="gallery"] .tab.is-active {
  border-color: #1B2D3A;
  color: #fff;
  background: #1B2D3A;
}

body[data-page="gallery"] .gallery-tools {
  display: flex;
  align-items: center;
  gap: 10px;
}

body[data-page="gallery"] .gallery-search {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 12px;
  border: 1px solid rgba(27, 45, 58, 0.15);
  background: #fff;
  padding: 0 10px;
  min-width: min(100%, 260px);
  height: 42px;
  color: #7a99a8;
}

body[data-page="gallery"] .gallery-search input {
  width: 100%;
  height: 100%;
  border: 0;
  outline: 0;
  color: #1B2D3A;
  background: transparent;
  font-size: 14px;
}

body[data-page="gallery"] .gallery-result {
  margin: 0;
  color: #4A6B7C;
  font-size: 14px;
  font-weight: 600;
}

body[data-page="gallery"] #galleryResultCount {
  color: #1B2D3A;
  font-size: 16px;
}

body[data-page="gallery"] .gallery-section {
  margin-top: 16px;
}

body[data-page="gallery"] .gallery-grid-wrap {
  border-radius: 24px;
  border: 1px solid rgba(74, 154, 181, 0.2);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 20px 60px rgba(27, 45, 58, 0.08);
  padding: 16px;
}

body[data-page="gallery"] .gallery-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 14px;
}

body[data-page="gallery"] .gallery-card {
  position: relative;
  grid-column: span 3;
  border-radius: 18px;
  overflow: hidden;
  cursor: pointer;
  border: 1px solid rgba(74, 154, 181, 0.15);
  background: #fff;
  box-shadow: 0 12px 30px rgba(27, 45, 58, 0.08);
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

body[data-page="gallery"] .gallery-card:nth-child(5n + 1),
body[data-page="gallery"] .gallery-card:nth-child(7n + 3) {
  grid-column: span 6;
}

body[data-page="gallery"] .gallery-card img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  display: block;
}

body[data-page="gallery"] .gallery-card:hover {
  transform: translateY(-4px);
  border-color: rgba(74, 154, 181, 0.45);
  box-shadow: 0 18px 36px rgba(27, 45, 58, 0.15);
}

body[data-page="gallery"] .gallery-card:focus-visible {
  outline: 3px solid rgba(74, 154, 181, 0.5);
  outline-offset: 2px;
}

body[data-page="gallery"] .gallery-empty {
  margin-top: 12px;
  border-radius: 14px;
  border: 1px dashed rgba(74, 154, 181, 0.3);
  background: rgba(74, 154, 181, 0.05);
  color: #2e4b5b;
  text-align: center;
  padding: 24px;
  font-weight: 600;
}

body[data-page="gallery"] .lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
}

body[data-page="gallery"] .lightbox.is-open {
  display: flex;
}

body[data-page="gallery"] .lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(8, 12, 16, 0.74);
}

body[data-page="gallery"] .lightbox__content {
  position: relative;
  z-index: 2;
  width: min(94vw, 980px);
  max-height: 92vh;
  border-radius: 20px;
  border: 1px solid rgba(74, 154, 181, 0.3);
  background: #fff;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.35);
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

body[data-page="gallery"] .lightbox__close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(27, 45, 58, 0.14);
  background: rgba(255, 255, 255, 0.95);
  color: #1B2D3A;
  font-size: 22px;
  cursor: pointer;
}

body[data-page="gallery"] #lightboxImg {
  width: 100%;
  max-height: calc(92vh - 88px);
  object-fit: contain;
  border-radius: 14px;
  background: #f3f8fa;
}

body[data-page="gallery"] #lightboxTitle {
  margin: 0;
  padding: 0 6px 4px;
  color: #1B2D3A;
  font-weight: 600;
}

body[data-page="gallery"] .ch-footer {
  margin-top: auto;
}

@media (max-width: 1140px) {
  body[data-page="gallery"] .gallery-card {
    grid-column: span 4;
  }

  body[data-page="gallery"] .gallery-card:nth-child(5n + 1),
  body[data-page="gallery"] .gallery-card:nth-child(7n + 3) {
    grid-column: span 8;
  }
}

@media (max-width: 860px) {
  body[data-page="gallery"] .gallery-main {
    padding-top: calc(var(--header-h) + 14px);
  }

  body[data-page="gallery"] .gallery-head__card {
    padding: 20px;
    border-radius: 22px;
  }

  body[data-page="gallery"] .gallery-controls__inner {
    align-items: stretch;
  }

  body[data-page="gallery"] .gallery-tools {
    width: 100%;
    justify-content: space-between;
  }

  body[data-page="gallery"] .gallery-search {
    flex: 1;
  }

  body[data-page="gallery"] .gallery-card,
  body[data-page="gallery"] .gallery-card:nth-child(5n + 1),
  body[data-page="gallery"] .gallery-card:nth-child(7n + 3) {
    grid-column: span 6;
  }

  body[data-page="gallery"] .gallery-card img {
    height: 220px;
  }
}

@media (max-width: 560px) {
  body[data-page="gallery"] .gallery-stats {
    gap: 8px;
  }

  body[data-page="gallery"] .gallery-stat {
    min-width: 120px;
    padding: 10px 12px;
  }

  body[data-page="gallery"] .gallery-tools {
    flex-direction: column;
    align-items: stretch;
  }

  body[data-page="gallery"] .gallery-result {
    text-align: right;
  }

  body[data-page="gallery"] .gallery-card,
  body[data-page="gallery"] .gallery-card:nth-child(5n + 1),
  body[data-page="gallery"] .gallery-card:nth-child(7n + 3) {
    grid-column: span 12;
  }

  body[data-page="gallery"] .gallery-card img {
    height: 230px;
  }
}

/* Home contact assistant */
.home-assistant {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 120;
}

.home-assistant__fab {
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 999px;
  padding: 12px 18px;
  background: rgba(255, 255, 255, 0.94);
  color: #1B2D3A;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.36);
  backdrop-filter: blur(8px);
}

.home-assistant__panel {
  width: min(92vw, 360px);
  margin-top: 10px;
  border-radius: 18px;
  border: 1px solid rgba(74, 154, 181, 0.38);
  background: linear-gradient(140deg, rgba(255, 255, 255, 0.96), rgba(244, 248, 249, 0.98));
  box-shadow: 0 24px 72px rgba(27, 45, 58, 0.12);
  backdrop-filter: blur(10px);
  padding: 14px;
}

.home-assistant__panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.home-assistant__panel-head h2 {
  margin: 0;
  font-size: 17px;
}

.home-assistant__panel-head button {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  border: 1px solid rgba(74, 154, 181, 0.36);
  background: rgba(27, 45, 58, 0.06);
  color: var(--txt);
  cursor: pointer;
}

.home-assistant__panel p {
  margin: 8px 0 10px;
  color: var(--txt);
  font-size: 13px;
}

.home-assistant__form {
  display: grid;
  gap: 9px;
}

.home-assistant__form label {
  display: grid;
  gap: 5px;
  font-size: 13px;
  color: rgba(236, 244, 250, 0.92);
}

.home-assistant__form input,
.home-assistant__form textarea {
  width: 100%;
  border-radius: 10px;
  border: 1px solid rgba(74, 154, 181, 0.28);
  background: #fff;
  color: var(--txt);
  padding: 9px 10px;
}

.home-assistant__submit {
  border: 1px solid rgba(74, 154, 181, 0.48);
  border-radius: 10px;
  padding: 10px 12px;
  font-weight: 700;
  background: var(--brand);
  color: #fff;
  cursor: pointer;
}

.home-assistant__submit:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.home-assistant__state {
  min-height: 18px;
  margin: 2px 0 0;
  font-size: 12px;
  color: rgba(231, 241, 249, 0.82);
}

.home-assistant__state.is-success {
  color: #8bf6c4;
}

.home-assistant__state.is-error {
  color: #ffb2b2;
}

@media (max-width: 600px) {
  .home-assistant {
    right: 12px;
    bottom: 12px;
  }
}

/* Cookie consent */
.cookie-consent {
  position: fixed;
  left: 14px;
  right: 14px;
  bottom: 14px;
  z-index: 130;
  pointer-events: none;
}

.cookie-consent__banner,
.cookie-consent__panel {
  pointer-events: auto;
  width: min(960px, 100%);
  margin: 0 auto;
  border-radius: 18px;
  border: 1px solid rgba(74, 154, 181, 0.4);
  background: linear-gradient(140deg, rgba(255, 255, 255, 0.96), rgba(244, 248, 249, 0.98));
  box-shadow: 0 20px 60px rgba(27, 45, 58, 0.12);
  backdrop-filter: blur(10px);
  padding: 14px;
}

.cookie-consent__panel {
  margin-top: 10px;
  max-width: 620px;
}

.cookie-consent__banner h2,
.cookie-consent__panel h3 {
  margin: 0 0 8px;
  font-size: 18px;
  color: #1B2D3A;
}

.cookie-consent__banner p {
  margin: 0;
  color: #3a4f5e;
  font-size: 14px;
  line-height: 1.55;
}

.cookie-consent__actions {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cookie-consent__actions button {
  border: 1px solid rgba(74, 154, 181, 0.44);
  border-radius: 999px;
  padding: 8px 14px;
  background: rgba(74, 154, 181, 0.12);
  color: #1B2D3A;
  font-weight: 600;
  cursor: pointer;
}

.cookie-consent__actions button.is-ghost {
  background: transparent;
}

.cookie-consent__row {
  margin-top: 8px;
  border: 1px solid rgba(74, 154, 181, 0.26);
  border-radius: 12px;
  background: rgba(244, 248, 250, 0.6);
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: #1B2D3A;
  font-size: 14px;
}

.cookie-consent__row input[type="checkbox"] {
  width: 18px;
  height: 18px;
}

.cookie-consent .is-ghost-link {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(74, 154, 181, 0.34);
  border-radius: 999px;
  padding: 8px 14px;
  color: #4A9AB5;
  text-decoration: none;
  font-size: 14px;
}

.cookie-consent__settings {
  margin-top: 8px;
  pointer-events: auto;
  border: none;
  border-radius: 50%;
  width: 44px;
  height: 44px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.95);
  color: #1B2D3A;
  cursor: pointer;
  box-shadow: 0 2px 12px rgba(0,0,0,0.12);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.cookie-consent__settings:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 18px rgba(0,0,0,0.18);
}

@media (max-width: 640px) {
  .cookie-consent {
    left: 10px;
    right: 10px;
    bottom: 10px;
  }

  .cookie-consent__banner p {
    font-size: 13px;
  }
}

/* Auth page */
body[data-page="auth"] {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

body[data-page="auth"] .auth-main {
  flex: 1;
  position: relative;
  padding-top: calc(var(--header-h) + 22px);
  padding-bottom: 48px;
  overflow: hidden;
}

body[data-page="auth"] .auth-main::before,
body[data-page="auth"] .auth-main::after {
  content: "";
  position: absolute;
  pointer-events: none;
  border-radius: 999px;
  filter: blur(68px);
  opacity: 0.58;
}

body[data-page="auth"] .auth-main::before {
  width: 320px;
  height: 320px;
  left: -80px;
  top: 68px;
  background: rgba(74, 154, 181, 0.34);
}

body[data-page="auth"] .auth-main::after {
  width: 260px;
  height: 260px;
  right: -70px;
  top: 180px;
  background: rgba(125, 245, 213, 0.26);
}

body[data-page="auth"] .auth-wrap {
  position: relative;
  z-index: 1;
}

body[data-page="auth"] .auth-shell {
  width: min(1080px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 20px;
  border-radius: 30px;
  border: 1px solid rgba(74, 154, 181, 0.28);
  background: #fff;
  box-shadow: 0 28px 90px rgba(27, 45, 58, 0.08);
  overflow: hidden;
  backdrop-filter: blur(12px);
}

body[data-page="auth"] .auth-showcase {
  position: relative;
  padding: 28px;
  border-right: 1px solid rgba(74, 154, 181, 0.24);
  background:
    radial-gradient(circle at 12% 18%, rgba(74, 154, 181, 0.22), transparent 40%),
    radial-gradient(circle at 88% 84%, rgba(125, 245, 213, 0.14), transparent 42%);
}

body[data-page="auth"] .auth-showcase h1 {
  margin: 8px 0 10px;
  font-size: clamp(34px, 4.1vw, 50px);
  line-height: 1.06;
  letter-spacing: -0.02em;
  color: transparent;
  background: linear-gradient(90deg, #1B2D3A 0%, #2E6E85 55%, #4A9AB5 100%);
  -webkit-background-clip: text;
  background-clip: text;
  text-shadow: none;
}

body[data-page="auth"] .auth-showcase p {
  margin: 0;
  color: rgba(232, 241, 248, 0.82);
  line-height: 1.65;
}

body[data-page="auth"] .auth-benefits {
  margin: 16px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

body[data-page="auth"] .auth-benefits li {
  border: 1px solid rgba(74, 154, 181, 0.24);
  border-radius: 12px;
  background: rgba(74, 154, 181, 0.06);
  padding: 10px 12px;
  color: var(--txt);
  font-size: 14px;
}

body[data-page="auth"] .auth-kicker {
  margin: 0;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(201, 241, 255, 0.82);
}

body[data-page="auth"] .auth-card {
  padding: 24px;
}

body[data-page="auth"] .auth-head h2 {
  margin: 0;
  font-size: clamp(26px, 3vw, 34px);
  letter-spacing: -0.01em;
}

body[data-page="auth"] .auth-head p {
  margin: 6px 0 0;
  color: rgba(234, 241, 248, 0.8);
}

body[data-page="auth"] .auth-tabs {
  margin-top: 16px;
  display: flex;
  gap: 8px;
}

body[data-page="auth"] .auth-tab {
  border: 1px solid rgba(74, 154, 181, 0.36);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.03);
  color: #eef8fd;
  padding: 10px 16px;
  cursor: pointer;
  font-weight: 700;
  transition: all 0.22s ease;
}

body[data-page="auth"] .auth-tab.is-active {
  background: rgba(74, 154, 181, 0.14);
  border-color: var(--brand);
  color: var(--txt);
}

body[data-page="auth"] .auth-tab:hover {
  transform: translateY(-1px);
  border-color: rgba(125, 245, 213, 0.46);
}

body[data-page="auth"] .auth-panel {
  margin-top: 14px;
}

body[data-page="auth"] .auth-form {
  display: grid;
  gap: 11px;
}

body[data-page="auth"] .auth-form label {
  display: grid;
  gap: 6px;
  font-size: 14px;
  color: rgba(237, 245, 250, 0.92);
}

body[data-page="auth"] .auth-form input,
body[data-page="auth"] .auth-form textarea {
  border: 1px solid rgba(74, 154, 181, 0.3);
  border-radius: 12px;
  background: #fff;
  color: var(--txt);
  padding: 10px 12px;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

body[data-page="auth"] .auth-form input:focus,
body[data-page="auth"] .auth-form textarea:focus {
  outline: 0;
  border-color: rgba(125, 245, 213, 0.6);
  box-shadow: 0 0 0 3px rgba(125, 245, 213, 0.14);
}

body[data-page="auth"] .auth-submit {
  border: 1px solid var(--brand);
  border-radius: 12px;
  background: var(--brand);
  color: #fff;
  font-weight: 700;
  padding: 10px 13px;
  cursor: pointer;
  transition: all 0.2s ease;
}

body[data-page="auth"] .auth-submit:hover {
  border-color: rgba(125, 245, 213, 0.62);
  transform: translateY(-1px);
}

body[data-page="auth"] .auth-submit--ghost {
  background: rgba(255, 255, 255, 0.03);
}

body[data-page="auth"] .auth-session {
  margin-top: 14px;
  border-top: 1px solid rgba(74, 154, 181, 0.26);
  padding-top: 14px;
}

body[data-page="auth"] .auth-session h3 {
  margin: 0 0 8px;
  font-size: 17px;
}

body[data-page="auth"] .auth-session p {
  margin: 0 0 10px;
}

body[data-page="auth"] .auth-status {
  min-height: 20px;
  margin: 12px 0 0;
  font-size: 14px;
}

body[data-page="auth"] .auth-status.is-success { color: #8bf6c4; }
body[data-page="auth"] .auth-status.is-error { color: #ffb8b8; }

@media (max-width: 980px) {
  body[data-page="auth"] .auth-shell {
    grid-template-columns: 1fr;
  }

  body[data-page="auth"] .auth-showcase {
    border-right: 0;
    border-bottom: 1px solid rgba(74, 154, 181, 0.24);
    padding-bottom: 20px;
  }
}

@media (max-width: 640px) {
  body[data-page="auth"] .auth-card {
    border-radius: 16px;
    padding: 14px;
  }

  body[data-page="auth"] .auth-showcase {
    padding: 16px 14px 18px;
  }

  body[data-page="auth"] .auth-showcase h1 {
    font-size: clamp(30px, 9.2vw, 40px);
  }
}

/* Home page visual tune-up */

/* Transparent header on home page (before scroll) */
body[data-page="home"] .site-header {
  background: transparent;
  border-bottom: 1px solid transparent;
  backdrop-filter: none;
  transition: background 0.35s ease, border-color 0.35s ease, backdrop-filter 0.35s ease, box-shadow 0.35s ease;
}

body[data-page="home"] .site-header .nav-link,
body[data-page="home"] .site-header .nav-link--trigger,
body[data-page="home"] .site-header .icon-btn,
body[data-page="home"] .site-header .menu-toggle {
  color: rgba(255,255,255,0.9);
  transition: color 0.35s ease;
}
body[data-page="home"] .site-header .nav-link:hover,
body[data-page="home"] .site-header .nav-link--trigger:hover {
  color: #fff;
}

body[data-page="home"] .site-header .btn-pill {
  border-color: rgba(255,255,255,0.35);
  color: #fff;
  transition: all 0.35s ease;
}
body[data-page="home"] .site-header .btn-pill:hover {
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.6);
}

body[data-page="home"] .site-header .lang-dropdown-toggle {
  color: rgba(255,255,255,0.9);
  border-color: rgba(255,255,255,0.3);
  background: rgba(255,255,255,0.08);
  transition: all 0.35s ease;
}
body[data-page="home"] .site-header .mobile-lang-inline {
  border-color: rgba(255,255,255,0.28);
  background: transparent;
}
body[data-page="home"] .site-header .lang-dropdown-toggle:hover {
  background: rgba(255,255,255,0.15);
  border-color: rgba(255,255,255,0.5);
}
body[data-page="home"] .site-header .lang-globe,
body[data-page="home"] .site-header .lang-chevron {
  opacity: 0.8;
}

/* Dropdown menu in transparent header - glass effect */
body[data-page="home"] .site-header .nav-dropdown {
  background: rgba(255,255,255,0.12);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-color: rgba(255,255,255,0.18);
  box-shadow: 0 20px 60px rgba(0,0,0,0.25);
}
body[data-page="home"] .site-header .nav-dropdown a {
  color: rgba(255,255,255,0.9);
}
body[data-page="home"] .site-header .nav-dropdown a:hover,
body[data-page="home"] .site-header .nav-dropdown a:focus {
  color: #fff;
  background: rgba(255,255,255,0.12);
}
body[data-page="home"] .site-header .nav-link--trigger[aria-expanded="true"] {
  color: #fff;
}

/* Scrolled: dropdown white with dark text */
body[data-page="home"] .site-header.is-scrolled .nav-dropdown {
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-color: rgba(27,45,58,0.08);
  box-shadow: 0 18px 50px rgba(27,45,58,0.12);
}
body[data-page="home"] .site-header.is-scrolled .nav-dropdown a {
  color: rgba(27,45,58,0.85);
}
body[data-page="home"] .site-header.is-scrolled .nav-dropdown a:hover,
body[data-page="home"] .site-header.is-scrolled .nav-dropdown a:focus {
  color: #1B2D3A;
  background: rgba(74,154,181,0.06);
}
body[data-page="home"] .site-header.is-scrolled .nav-link--trigger[aria-expanded="true"] {
  color: var(--brand);
}

body[data-page="home"] .site-header .badge {
  background: var(--brand);
  color: #fff;
}

body[data-page="home"] .site-header .menu-toggle {
  background: rgba(255,255,255,0.1);
  color: #fff;
}

/* Scrolled state - back to solid white */
body[data-page="home"] .site-header.is-scrolled {
  background: rgba(255,255,255,0.95);
  border-bottom-color: rgba(27,45,58,0.08);
  backdrop-filter: blur(14px);
  box-shadow: 0 1px 12px rgba(0,0,0,0.06);
}

body[data-page="home"] .site-header.is-scrolled .nav-link,
body[data-page="home"] .site-header.is-scrolled .nav-link--trigger,
body[data-page="home"] .site-header.is-scrolled .icon-btn,
body[data-page="home"] .site-header.is-scrolled .menu-toggle {
  color: rgba(27,45,58,0.78);
}
body[data-page="home"] .site-header.is-scrolled .nav-link:hover,
body[data-page="home"] .site-header.is-scrolled .nav-link--trigger:hover {
  color: #1B2D3A;
}

body[data-page="home"] .site-header.is-scrolled .btn-pill {
  border-color: rgba(27,45,58,0.15);
  color: var(--txt);
}

body[data-page="home"] .site-header.is-scrolled .lang-dropdown-toggle {
  color: #1B2D3A;
  border-color: rgba(27,45,58,0.12);
  background: #fff;
}
body[data-page="home"] .site-header.is-scrolled .mobile-lang-inline {
  border-color: rgba(27,45,58,0.12);
  background: rgba(244,248,249,0.9);
}
body[data-page="home"] .site-header.is-scrolled .lang-dropdown-toggle:hover {
  background: rgba(27,45,58,0.03);
  border-color: rgba(27,45,58,0.25);
}
body[data-page="home"] .site-header.is-scrolled .lang-globe,
body[data-page="home"] .site-header.is-scrolled .lang-chevron {
  opacity: 0.55;
}

body[data-page="home"] .site-header.is-scrolled .menu-toggle {
  background: rgba(27,45,58,0.06);
  color: rgba(27,45,58,0.78);
}

body[data-page="home"] .site-header .brand img {
  filter: brightness(0) invert(1);
  transition: filter 0.35s ease;
}
body[data-page="home"] .site-header.is-scrolled .brand img {
  filter: none;
}

/* When mobile menu is open, always show solid header */
body[data-page="home"] .site-header:has(.mobile-menu.mobile-open) {
  background: rgba(255,255,255,0.95);
  border-bottom-color: rgba(27,45,58,0.08);
  backdrop-filter: blur(14px);
}
body[data-page="home"] .site-header:has(.mobile-menu.mobile-open) .nav-link,
body[data-page="home"] .site-header:has(.mobile-menu.mobile-open) .icon-btn,
body[data-page="home"] .site-header:has(.mobile-menu.mobile-open) .menu-toggle {
  color: rgba(27,45,58,0.78);
}
body[data-page="home"] .site-header:has(.mobile-menu.mobile-open) .menu-toggle {
  background: rgba(27,45,58,0.06);
}
body[data-page="home"] .site-header:has(.mobile-menu.mobile-open) .brand img {
  filter: none;
}
body[data-page="home"] .site-header:has(.mobile-menu.mobile-open) .mobile-lang-inline {
  border-color: rgba(27,45,58,0.12);
  background: rgba(244,248,249,0.9);
}

body[data-page="home"] .nav .nav-link,
body[data-page="home"] .nav-link--trigger {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.01em;
}

body[data-page="home"] .hero {
  min-height: 100vh;
}

body[data-page="home"] .hero-overlay {
  background:
    linear-gradient(180deg, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.3) 40%, rgba(0,0,0,0.65) 100%);
}

body[data-page="home"] .hero-title {
  font-size: clamp(46px, 7vw, 80px);
  line-height: 1.02;
}

body[data-page="home"] .hero-scroll {
  bottom: 28px;
}

@media (max-width: 768px) {
  body[data-page="home"] .hero {
    min-height: calc(100svh - 6px);
  }

  body[data-page="home"] .hero-title {
    font-size: clamp(38px, 11vw, 54px);
    line-height: 1.05;
  }
}

@media (max-width: 520px) {
  body[data-page="home"] .hero-title {
    font-size: clamp(32px, 11.6vw, 44px);
  }

  body[data-page="home"] .hero-actions {
    gap: 10px;
  }

  body[data-page="home"] .hero-actions .btn {
    min-width: 100%;
    min-height: 48px;
    padding: 0 20px;
  }

  .cookie-consent__settings {
    width: 38px;
    height: 38px;
  }

  .home-assistant__fab {
    padding: 9px 13px;
    font-size: 13px;
  }
}

/* =============================================
   PAGE DECORATIVE ELEMENTS — Animated Blobs, Rings, Dots
   ============================================= */

@keyframes decoBounce {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-80px); }
}
@keyframes decoBounce2 {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-60px); }
}
@keyframes decoSway {
  0%   { transform: translateX(0) translateY(0); }
  25%  { transform: translateX(50px) translateY(-30px); }
  50%  { transform: translateX(0) translateY(-60px); }
  75%  { transform: translateX(-50px) translateY(-30px); }
  100% { transform: translateX(0) translateY(0); }
}
@keyframes decoOrbit {
  from { transform: rotate(0deg) translateX(40px) rotate(0deg); }
  to   { transform: rotate(360deg) translateX(40px) rotate(-360deg); }
}
@keyframes decoSpin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes decoPulse {
  0%, 100% { transform: scale(1); opacity: 0.6; }
  50%      { transform: scale(1.4); opacity: 1; }
}
@keyframes decoDrift {
  0%   { transform: translate(0, 0); }
  20%  { transform: translate(60px, -40px); }
  40%  { transform: translate(-30px, -80px); }
  60%  { transform: translate(40px, -20px); }
  80%  { transform: translate(-50px, -50px); }
  100% { transform: translate(0, 0); }
}

.page-deco {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  overflow: hidden;
  isolation: isolate;
}

/* Ensure all content sections sit above decorative layer */
main > *:not(.page-deco),
header,
footer,
.modal,
.cookie-bar {
  position: relative;
  z-index: 1;
}

/* Blobs -- large soft colored shapes */
.deco-blob {
  position: absolute;
  border-radius: 50%;
  will-change: transform;
}
.deco-blob--1 {
  width: 260px; height: 260px;
  top: 5%; left: -40px;
  background: rgba(200, 40, 40, 0.10);
  filter: blur(50px);
  animation: decoDrift 22s ease-in-out infinite;
}
.deco-blob--2 {
  width: 200px; height: 200px;
  top: 50%; right: -30px;
  background: rgba(30, 30, 30, 0.07);
  filter: blur(45px);
  animation: decoDrift 18s ease-in-out infinite reverse;
  animation-delay: -6s;
}
.deco-blob--3 {
  width: 180px; height: 180px;
  bottom: 8%; left: 20%;
  background: rgba(74, 154, 181, 0.12);
  filter: blur(40px);
  animation: decoDrift 25s ease-in-out infinite;
  animation-delay: -12s;
}

/* Rings -- spinning bordered circles */
.deco-ring {
  position: absolute;
  border-radius: 50%;
  will-change: transform;
}
.deco-ring--1 {
  width: 120px; height: 120px;
  top: 15%; right: 10%;
  border: 3px solid rgba(210, 43, 30, 0.45);
  animation: decoSpin 20s linear infinite;
}
.deco-ring--2 {
  width: 80px; height: 80px;
  bottom: 25%; left: 8%;
  border: 3px dashed rgba(210, 43, 30, 0.30);
  animation: decoSpin 28s linear infinite reverse;
}

/* Dots -- small bouncing balls */
.deco-dot {
  position: absolute;
  border-radius: 50%;
  will-change: transform;
}
.deco-dot--1 {
  width: 14px; height: 14px;
  top: 22%; left: 25%;
  background: rgba(200, 40, 40, 0.35);
  animation: decoBounce 3s ease-in-out infinite;
}
.deco-dot--2 {
  width: 10px; height: 10px;
  top: 60%; right: 18%;
  background: rgba(30, 30, 30, 0.25);
  animation: decoBounce2 2.5s ease-in-out infinite;
  animation-delay: -0.8s;
}
.deco-dot--3 {
  width: 18px; height: 18px;
  bottom: 18%; right: 30%;
  background: rgba(74, 154, 181, 0.30);
  animation: decoSway 6s ease-in-out infinite;
}

@media (max-width: 768px) {
  .deco-blob--1 { width: 160px; height: 160px; }
  .deco-blob--2 { width: 120px; height: 120px; }
  .deco-blob--3 { width: 100px; height: 100px; }
  .deco-ring--1 { width: 80px; height: 80px; }
  .deco-ring--2 { width: 50px; height: 50px; }
  .deco-dot--1 { width: 10px; height: 10px; }
  .deco-dot--3 { width: 12px; height: 12px; }
}

@media (prefers-reduced-motion: reduce) {
  .deco-blob, .deco-ring, .deco-dot {
    animation: none !important;
  }
}

