:root {
    --kv-primary: #355F8C;
    --kv-primary-dark: #294B71;
    --kv-primary-light: #537294;
    --kv-primary-rgb: 53 95 140;
    --kv-secondary: #9E6E57;
    --kv-secondary-dark: #845a45;
    --kv-secondary-rgb: 158 110 87;
    --kv-accent: #C81D25;
    --kv-accent-dark: #a8171e;
    --kv-accent-rgb: 53 95 140;
    --kv-warm: #E1AAA2;
    --kv-warm-rgb: 225 170 162;
    --kv-background: #ffffff;
    --kv-background-alt: #F2F1F2;
    --kv-surface: #ffffff;
    --kv-surface-soft: #F2F1F2;
    --kv-text: #3a3a3a;
    --kv-text-muted: #5D5D5E;
    --kv-text-light: #A8A9AB;
    --kv-text-on-primary: #ffffff;
    --kv-text-on-secondary: #ffffff;
    --kv-heading-font: "Space Grotesk";
    --kv-body-font: "Manrope";
}

[x-cloak] {
    display: none !important;
}

.kv-body {
    background: linear-gradient(180deg, var(--kv-background) 0%, var(--kv-background-alt) 100%);
    color: var(--kv-text);
    font-family: var(--kv-body-font), sans-serif;
}

.kv-body h1,
.kv-body h2,
.kv-body h3,
.kv-body h4,
.kv-body h5,
.kv-body h6 {
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-lock-scroll {
    overflow: hidden;
}

.kv-skip-link {
    position: absolute;
    left: 1rem;
    top: -100px;
    z-index: 999;
    border-radius: 999px;
    background: var(--kv-primary);
    color: var(--kv-text-on-primary);
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    padding: 0.65rem 1rem;
    transition: top 0.2s ease;
}

.kv-skip-link:focus {
    top: 1rem;
}

.kv-preloader {
    align-items: center;
    backdrop-filter: blur(6px);
    background: rgb(255 255 255 / 0.88);
    display: flex;
    inset: 0;
    justify-content: center;
    position: fixed;
    transition: opacity 0.24s ease, visibility 0.24s ease;
    visibility: visible;
    z-index: 120;
}

.kv-preloader.is-hidden {
    opacity: 0;
    pointer-events: none;
    visibility: hidden;
}

.kv-loader-dot {
    animation: kv-loader-pulse 1.2s infinite;
    background: var(--kv-primary);
    border-radius: 999px;
    height: 0.85rem;
    width: 0.85rem;
}

@keyframes kv-loader-pulse {
    0%,
    100% {
        box-shadow: -1.2rem 0 0 rgb(53 95 140 / 0.25), 1.2rem 0 0 rgb(158 110 87 / 0.25);
        transform: scale(1);
    }

    50% {
        box-shadow: -1.2rem 0 0 rgb(53 95 140 / 0.65), 1.2rem 0 0 rgb(158 110 87 / 0.65);
        transform: scale(1.2);
    }
}

.kv-main {
    min-height: 60vh;
}

.kv-header {
    background: rgb(255 255 255 / 0.86);
    backdrop-filter: blur(16px);
    border-bottom: 2px solid var(--kv-accent, #C81D25);
    box-shadow: 0 6px 26px rgb(15 23 42 / 0.06);
}

.kv-header-glow {
    background: linear-gradient(90deg, rgb(53 95 140 / 0.2), rgb(158 110 87 / 0.16), rgb(53 95 140 / 0.2));
    height: 2px;
    opacity: 0.85;
}

.kv-icon {
    display: inline-flex;
    height: 1.1rem;
    width: 1.1rem;
}

.kv-icon svg {
    height: 100%;
    width: 100%;
}

.kv-icon-sm {
    height: 0.95rem;
    width: 0.95rem;
}

.kv-action-pill {
    align-items: center;
    border: 1px solid rgb(17 24 39 / 0.1);
    border-radius: 999px;
    color: var(--kv-text);
    display: inline-flex;
    gap: 0.45rem;
    font-size: 0.75rem;
    font-weight: 700;
    justify-content: center;
    min-height: 2.2rem;
    min-width: 2.2rem;
    padding: 0 0.7rem;
    text-decoration: none;
    transition: all 0.2s ease;
}

.kv-action-pill:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.06);
    border-color: rgb(var(--kv-primary-rgb, 53 95 140) / 0.45);
    color: var(--kv-primary);
    transform: translateY(-1px);
}

.kv-action-pill--label {
    background: linear-gradient(120deg, rgb(var(--kv-primary-rgb, 53 95 140) / 0.08), rgb(var(--kv-secondary-rgb, 158 110 87) / 0.12));
}

.kv-action-pill--contact {
    background: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.12);
    border-color: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.25);
}

.kv-social-dot {
    align-items: center;
    border: 1px solid rgb(17 24 39 / 0.15);
    border-radius: 999px;
    color: var(--kv-text);
    display: inline-flex;
    font-size: 0.88rem;
    height: 1.95rem;
    justify-content: center;
    text-decoration: none;
    transition: all 0.2s ease;
    width: 1.95rem;
}

.kv-social-dot:hover {
    border-color: var(--kv-primary);
    color: var(--kv-primary);
}

.kv-lang-pill {
    align-items: center;
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.09);
    border: 1px solid rgb(var(--kv-primary-rgb, 53 95 140) / 0.2);
    border-radius: 999px;
    color: var(--kv-primary);
    display: inline-flex;
    font-size: 0.72rem;
    font-weight: 800;
    gap: 0.3rem;
    line-height: 1;
    min-height: 2.25rem;
    padding: 0 0.75rem;
}

.kv-lang-menu {
    background: #fff;
    border: 1px solid rgb(17 24 39 / 0.08);
    border-radius: 0.85rem;
    box-shadow: 0 18px 38px rgb(15 23 42 / 0.18);
    margin-top: 0.5rem;
    min-width: 4.4rem;
    position: absolute;
    right: 0;
    top: 100%;
    z-index: 45;
}

.kv-lang-item {
    color: var(--kv-text);
    display: block;
    font-size: 0.76rem;
    font-weight: 700;
    padding: 0.55rem 0.7rem;
    text-decoration: none;
}

.kv-lang-item:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.08);
    color: var(--kv-primary);
}

.kv-nav-shell {
    position: relative;
}

.kv-nav-link {
    align-items: center;
    border-radius: 0.75rem;
    color: var(--kv-text);
    display: inline-flex;
    font-size: 0.875rem;
    font-weight: 800;
    gap: 0.35rem;
    letter-spacing: 0.08em;
    line-height: 1;
    min-height: 2.5rem;
    padding: 0 0.85rem;
    text-decoration: none;
    text-transform: uppercase;
    transition: all 0.2s ease;
}

.kv-nav-link:hover,
.kv-nav-link:focus-visible {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.1);
    color: var(--kv-primary);
    outline: none;
}

/* ── Mega Menu — Bornova Inspired ── */
.kv-mega-panel {
    background: #f8f9fb url('../images/baskan-arka.png') center / cover no-repeat;
    border-top: 3px solid var(--kv-primary);
    box-shadow: 0 20px 60px rgb(15 23 42 / 0.12), 0 0 0 1px rgb(15 23 42 / 0.04);
    left: 0;
    position: absolute;
    right: 0;
    top: 100%;
    z-index: 50;
}

.kv-mega-inner {
    margin: 0 auto;
    max-width: 1320px;
    padding: 0 1rem;
}

.kv-mega-body {
    display: flex;
    gap: 0;
    padding: 1.75rem 0;
}

/* ── Mega — Mayor Sidebar ── */
.kv-mega-mayor {
    border-right: 1px solid rgb(0 0 0 / 0.08);
    flex-shrink: 0;
    padding-right: 1.9rem;
    width: 300px;
}

.kv-mega-mayor__heading {
    background: var(--kv-primary);
    border-radius: 0.3rem;
    color: #fff;
    display: inline-flex;
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 0.86rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    margin: 0 0 1rem;
    padding: 0.22rem 0.54rem;
    text-transform: uppercase;
}

.kv-mega-mayor__divider {
    background: rgb(15 23 42 / 0.16);
    height: 2px;
    margin-bottom: 1rem;
    width: 100%;
}

.kv-mega-mayor__name {
    color: var(--kv-text);
    display: block;
    font-size: 1.15rem;
    font-weight: 800;
    line-height: 1.25;
    margin-bottom: 0.2rem;
}

.kv-mega-mayor__role {
    color: var(--kv-text-muted);
    display: block;
    font-size: 0.96rem;
    font-weight: 600;
    margin-bottom: 0.9rem;
}

.kv-mega-mayor__profile {
    margin-bottom: 0.85rem;
}

.kv-mega-mayor__photo {
    aspect-ratio: 16 / 9;
    border-radius: 1rem;
    object-fit: cover;
    width: 100%;
}

.kv-mega-mayor__nav {
    border-top: 1px solid rgb(0 0 0 / 0.08);
    display: flex;
    flex-direction: column;
}

.kv-mega-mayor__nav a {
    align-items: center;
    border-bottom: 1px solid rgb(0 0 0 / 0.08);
    color: var(--kv-text);
    display: flex;
    font-size: 0.95rem;
    font-weight: 600;
    justify-content: space-between;
    min-height: 2.35rem;
    padding: 0.38rem 0;
    text-decoration: none;
    transition: color 0.15s ease;
}

.kv-mega-mayor__nav a i {
    font-size: 0.7rem;
    opacity: 0.5;
    transition: all 0.15s;
}

.kv-mega-mayor__nav a:last-child {
    border-bottom: none;
}

.kv-mega-mayor__nav a:hover {
    color: var(--kv-primary);
}

.kv-mega-mayor__nav a:hover i {
    opacity: 1;
    transform: translateX(2px);
}

/* ── Mega — Menu Columns ── */
.kv-mega-columns {
    display: grid;
    flex: 1;
    gap: 1.75rem;
    padding-left: 1.75rem;
}

.kv-mega-col__title {
    border-bottom: 2px solid var(--kv-primary);
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 0.82rem;
    font-weight: 900;
    letter-spacing: 0.1em;
    margin: 0 0 0.6rem;
    padding-bottom: 0.6rem;
    text-transform: uppercase;
}

.kv-mega-col__title a {
    color: inherit;
    text-decoration: none;
}

.kv-mega-col__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.kv-mega-subitem-label {
    align-items: center;
    display: inline-flex;
    gap: 0.55rem;
}

.kv-mega-subitem-bullet {
    align-items: center;
    color: rgb(var(--kv-primary-rgb, 53 95 140) / 0.9);
    display: inline-flex;
    flex: 0 0 0.75rem;
    height: 0.75rem;
    justify-content: center;
    transition: transform 0.15s ease;
    width: 0.75rem;
}

.kv-mega-subitem-bullet::before {
    border-right: 2px solid currentColor;
    border-top: 2px solid currentColor;
    border-top-right-radius: 1px;
    content: '';
    display: block;
    height: 0.36rem;
    opacity: 0.75;
    transform: rotate(45deg);
    transition: transform 0.15s ease, opacity 0.15s ease;
    width: 0.36rem;
}

.kv-mega-col__list li a {
    align-items: center;
    border-radius: 0.55rem;
    color: var(--kv-text);
    display: flex;
    font-size: 0.95rem;
    font-weight: 600;
    justify-content: space-between;
    padding: 0.5rem 0.25rem;
    text-decoration: none;
    transition: color 0.15s ease, background-color 0.15s ease;
}

.kv-mega-col__list li a i {
    font-size: 0.55rem;
    opacity: 0.3;
    transition: all 0.15s;
}

.kv-mega-col__list li a:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.06);
    color: var(--kv-primary);
}

.kv-mega-col__list li a:hover i {
    opacity: 0.7;
}

.kv-mega-col__list li a:hover .kv-mega-subitem-bullet {
    transform: translateX(1px);
}

.kv-mega-col__list li a:hover .kv-mega-subitem-bullet::before {
    opacity: 1;
    transform: translateX(2px) rotate(45deg);
}

/* ── Mega — Sub-sub items (Level 3) ── */
.kv-mega-col__sublist {
    list-style: none;
    margin: 0;
    padding: 0 0 0.25rem 1.25rem;
}

.kv-mega-col__sublist li a {
    align-items: center;
    border-radius: 0.375rem;
    color: var(--kv-text-muted, #64748b);
    display: flex;
    font-size: 0.8rem;
    gap: 0.5rem;
    padding: 0.25rem 0.5rem;
    transition: color 0.15s ease, background 0.15s ease;
}

.kv-mega-col__sublist li a:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.06);
    color: rgb(var(--kv-primary-rgb, 53 95 140));
}

.kv-mega-subitem-dot {
    background: currentColor;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
    height: 5px;
    min-height: 5px;
    min-width: 5px;
    opacity: 0.55;
    transition: opacity 0.15s ease;
    width: 5px;
}

.kv-mega-col__sublist li a:hover .kv-mega-subitem-dot {
    opacity: 1;
}

/* ── Mega — Quick Access Bar ── */
.kv-mega-quick {
    border-top: 1px solid rgb(0 0 0 / 0.08);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
}

.kv-mega-quick__item {
    align-items: center;
    border-right: 1px solid rgb(0 0 0 / 0.06);
    color: var(--kv-text);
    display: flex;
    font-size: 0.82rem;
    font-weight: 700;
    gap: 0.55rem;
    justify-content: center;
    padding: 0.9rem 1rem;
    text-decoration: none;
    transition: all 0.15s;
}

.kv-mega-quick__item:last-child {
    border-right: none;
}

.kv-mega-quick__item:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.04);
    color: var(--kv-primary);
}

.kv-mega-quick__item i {
    color: var(--kv-primary);
    font-size: 1rem;
}

/* ── Mega — Default Full-width Columns ── */
.kv-mega-columns--full {
    padding-left: 0;
}

/* ── Mega — Güncel Layout ── */
.kv-mega-guncel {
    display: flex;
    gap: 0;
    padding: 1.95rem 0;
}

.kv-mega-guncel__sidebar {
    border-right: 1px solid rgb(0 0 0 / 0.08);
    flex-shrink: 0;
    margin-right: 0.2rem;
    padding-right: 1.35rem;
    width: 250px;
}

.kv-mega-guncel__heading {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 0.9rem;
    font-weight: 900;
    letter-spacing: 0.1em;
    margin: 0 0 1.1rem;
    text-transform: uppercase;
}

.kv-mega-guncel__cats {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.kv-mega-guncel__cat {
    align-items: center;
    background: transparent;
    border: 0;
    border-bottom: 2px solid rgb(15 23 42 / 0.14);
    border-radius: 0;
    box-shadow: none;
    color: var(--kv-text);
    display: flex;
    font-size: 0.86rem;
    font-weight: 700;
    justify-content: space-between;
    min-height: 3.15rem;
    padding: 0.65rem 0.2rem 0.65rem 0;
    text-decoration: none;
    transition: none;
}

.kv-mega-guncel__cat:last-child {
    border-bottom: 2px solid rgb(15 23 42 / 0.14);
}

.kv-mega-guncel__cat-main {
    align-items: center;
    display: inline-flex;
    gap: 0.55rem;
}

.kv-mega-guncel__cat-icon {
    color: rgb(var(--kv-primary-rgb, 53 95 140) / 0.88);
    height: 0.95rem;
    width: 0.95rem;
}

.kv-mega-guncel__cat:hover,
.kv-mega-guncel__cat.is-active {
    background: transparent;
    border-bottom-color: rgb(var(--kv-primary-rgb, 53 95 140) / 0.7);
    color: var(--kv-primary);
}

.kv-mega-guncel__cat--link {
    border-bottom-style: solid;
}

.kv-mega-guncel__cat--link:hover {
    background: transparent;
    border-bottom-color: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.65);
    color: var(--kv-secondary);
}

.kv-mega-guncel__cat i {
    font-size: 0.62rem;
    opacity: 0.4;
    transition: none;
}

.kv-mega-guncel__cat:hover i,
.kv-mega-guncel__cat.is-active i {
    opacity: 1;
}

.kv-mega-guncel__content {
    flex: 1;
    min-height: 290px;
    min-width: 0;
    padding-left: 1.35rem;
}

.kv-mega-guncel__pane {
    min-height: 1px;
}

.kv-mega-guncel__empty {
    align-items: center;
    border: 1px dashed rgb(15 23 42 / 0.18);
    border-radius: 0.75rem;
    color: var(--kv-text-muted);
    display: flex;
    font-size: 0.92rem;
    font-weight: 600;
    justify-content: center;
    min-height: 220px;
}

.kv-mega-guncel__header {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 1.1rem;
}

.kv-mega-guncel__title {
    align-items: center;
    color: var(--kv-text);
    display: inline-flex;
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1rem;
    font-weight: 900;
    gap: 0.5rem;
    letter-spacing: 0.08em;
    margin: 0;
    text-transform: uppercase;
}

.kv-mega-guncel__title-icon {
    color: var(--kv-primary);
    height: 1.05rem;
    width: 1.05rem;
}

.kv-mega-guncel__viewall {
    align-items: center;
    color: var(--kv-primary);
    display: inline-flex;
    font-size: 0.76rem;
    font-weight: 800;
    gap: 0.3rem;
    letter-spacing: 0.04em;
    text-decoration: none;
    text-transform: uppercase;
    transition: gap 0.15s;
}

.kv-mega-guncel__viewall:hover {
    gap: 0.5rem;
}

/* ── Mega — News Carousel ── */
.kv-mega-news-swiper {
    overflow: hidden;
    position: relative;
}

.kv-mega-news-card {
    display: block;
    text-decoration: none;
}

.kv-mega-news-card__img {
    aspect-ratio: 16 / 11;
    background: rgb(248 250 252);
    border-radius: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.kv-mega-news-card__img img {
    height: 100%;
    object-fit: contain;
    object-position: center;
    transition: none;
    width: 100%;
}

.kv-mega-news-card:hover .kv-mega-news-card__img img {
    transform: none;
}

.kv-mega-news-card h4 {
    color: var(--kv-text);
    font-size: 0.86rem;
    font-weight: 700;
    line-height: 1.4;
    margin: 0.55rem 0 0.2rem;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.kv-mega-news-card:hover h4 {
    color: var(--kv-primary);
}

.kv-mega-news-card time {
    color: var(--kv-text-muted);
    font-size: 0.74rem;
    font-weight: 500;
}

.kv-mega-news-nav {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
    margin-top: 0.75rem;
}

.kv-mega-news-btn {
    align-items: center;
    background: none;
    border: 1.5px solid rgb(0 0 0 / 0.12);
    border-radius: 999px;
    color: var(--kv-text);
    cursor: pointer;
    display: flex;
    font-size: 0.85rem;
    height: 2.2rem;
    justify-content: center;
    transition: all 0.15s;
    width: 2.2rem;
}

.kv-mega-news-btn:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.06);
    border-color: var(--kv-primary);
    color: var(--kv-primary);
    transform: translateY(-1px);
}

/* ── Mega — Kiraz Layout (2 Kolon + Sağ Görsel) ── */
.kv-mega-kiraz {
    align-items: stretch;
    display: grid;
    gap: 1.35rem;
    grid-template-columns: minmax(0, 2fr) minmax(290px, 360px);
    padding: 1.75rem 0;
}

.kv-mega-kiraz__left {
    min-width: 0;
}

.kv-mega-kiraz__columns {
    gap: 1.4rem;
}

.kv-mega-kiraz__preview {
    border-left: 1px solid rgb(15 23 42 / 0.1);
    min-width: 0;
    padding-left: 1.35rem;
}

.kv-mega-kiraz__card {
    color: inherit;
    display: block;
    text-decoration: none;
}

.kv-mega-kiraz__image {
    aspect-ratio: 16 / 10;
    background: rgb(248 250 252);
    border: 1px solid rgb(15 23 42 / 0.08);
    border-radius: 0.7rem;
    overflow: hidden;
}

.kv-mega-kiraz__image img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.kv-mega-kiraz__meta {
    margin-top: 0.7rem;
}

.kv-mega-kiraz__meta h4 {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 0.98rem;
    font-weight: 800;
    line-height: 1.3;
    margin: 0 0 0.3rem;
}

.kv-mega-kiraz__meta p {
    color: var(--kv-text-muted);
    display: -webkit-box;
    font-size: 0.82rem;
    line-height: 1.5;
    margin: 0;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.kv-mega-kiraz__card:hover .kv-mega-kiraz__meta h4 {
    color: var(--kv-primary);
}

.kv-mega-overlay {
    backdrop-filter: blur(6px);
    background: rgb(15 23 42 / 0.45);
    inset: 0;
    position: fixed;
    z-index: 45;
}

.kv-mobile-toggle,
.kv-mobile-close {
    align-items: center;
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.08);
    border: 1px solid rgb(var(--kv-primary-rgb, 53 95 140) / 0.18);
    border-radius: 0.75rem;
    color: var(--kv-primary);
    display: inline-flex;
    justify-content: center;
    min-height: 2.4rem;
    min-width: 2.4rem;
}

.kv-mobile-overlay {
    background: rgb(15 23 42 / 0.58);
    inset: 0;
    position: fixed;
    z-index: 80;
}

.kv-mobile-drawer {
    background: #fff;
    border-left: 1px solid rgb(17 24 39 / 0.08);
    bottom: 0;
    display: flex;
    flex-direction: column;
    max-width: 23rem;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    position: fixed;
    right: 0;
    top: 0;
    width: 87%;
    z-index: 81;
}

.kv-mobile-item {
    border-bottom: 1px solid rgb(17 24 39 / 0.08);
}

.kv-mobile-link {
    align-items: center;
    color: var(--kv-text);
    display: flex;
    font-size: 0.86rem;
    font-weight: 700;
    justify-content: space-between;
    min-height: 2.9rem;
    padding: 0.1rem 0;
    text-decoration: none;
    width: 100%;
}

.kv-mobile-submenu {
    background: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.08);
    border-radius: 0.75rem;
    margin-bottom: 0.8rem;
    padding: 0.65rem;
}

.kv-mobile-submenu h3 {
    color: var(--kv-primary);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    margin-bottom: 0.35rem;
    margin-top: 0.2rem;
    text-transform: uppercase;
}

.kv-mobile-sublink {
    border-left: 2px solid transparent;
    color: var(--kv-text);
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    padding: 0.36rem 0 0.36rem 0.5rem;
    text-decoration: none;
    transition: border-color 0.15s, color 0.15s;
}

.kv-mobile-sublink:hover,
.kv-mobile-sublink:active {
    border-left-color: var(--kv-primary);
    color: var(--kv-primary);
}

.kv-mobile-sublink--nested {
    font-size: 0.75rem;
    font-weight: 500;
    opacity: 0.8;
    padding-left: 1.25rem;
    position: relative;
}

.kv-mobile-sublink--nested::before {
    background: currentColor;
    border-radius: 50%;
    content: '';
    height: 3px;
    left: 0.5rem;
    opacity: 0.4;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
}

.kv-mobile-pill,
.kv-mobile-contact {
    border: 1px solid rgb(17 24 39 / 0.12);
    border-radius: 0.7rem;
    color: var(--kv-text);
    display: inline-flex;
    font-size: 0.76rem;
    font-weight: 700;
    justify-content: center;
    padding: 0.55rem 0.65rem;
    text-decoration: none;
}

.kv-mobile-contact {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.08);
    border-color: rgb(var(--kv-primary-rgb, 53 95 140) / 0.24);
    width: 100%;
}

.kv-page-header {
    background-image: var(--kv-page-header-bg);
    background-position: center;
    background-size: cover;
    overflow: hidden;
    position: relative;
}

.kv-page-header__overlay {
    background: linear-gradient(120deg, rgb(var(--kv-primary-rgb, 53 95 140) / 0.87), rgb(var(--kv-secondary-rgb, 158 110 87) / 0.84));
    inset: 0;
    position: absolute;
}

.kv-page-header__pattern {
    background-image: radial-gradient(circle at 24% 28%, rgb(255 255 255 / 0.16) 0, transparent 36%),
                      radial-gradient(circle at 76% 64%, rgb(255 255 255 / 0.12) 0, transparent 32%);
    inset: 0;
    position: absolute;
}

.kv-page-title {
    color: #fff;
    font-size: clamp(1.35rem, 2.4vw, 2.15rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    margin: 0;
    max-width: 36ch;
    position: relative;
    z-index: 1;
}

.kv-page-badge {
    background: rgb(255 255 255 / 0.18);
    border: 1px solid rgb(255 255 255 / 0.32);
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin-bottom: 0.8rem;
    padding: 0.34rem 0.75rem;
    position: relative;
    text-transform: uppercase;
    z-index: 1;
}

.kv-page-meta {
    color: rgb(255 255 255 / 0.86);
    display: flex;
    flex-wrap: wrap;
    font-size: 0.82rem;
    gap: 0.8rem;
    margin-top: 0.6rem;
    position: relative;
    z-index: 1;
}

.kv-breadcrumb {
    align-items: center;
    color: rgb(255 255 255 / 0.88);
    display: flex;
    flex-wrap: wrap;
    font-size: 0.8rem;
    gap: 0.55rem;
    list-style: none;
    margin: 0;
    padding: 0;
    position: relative;
    z-index: 1;
}

.kv-breadcrumb li {
    align-items: center;
    display: inline-flex;
    gap: 0.55rem;
}

.kv-breadcrumb li + li::before {
    content: "/";
    opacity: 0.75;
}

.kv-breadcrumb a {
    color: #fff;
    text-decoration: none;
}

.kv-page-content-card {
    background: linear-gradient(180deg, rgb(255 255 255 / 0.98) 0%, rgb(248 250 252 / 0.96) 100%);
    border: 1px solid rgb(15 23 42 / 0.08);
    border-radius: 1rem;
    box-shadow: 0 18px 36px rgb(15 23 42 / 0.08);
}

.kv-page-prose {
    background: linear-gradient(180deg, rgb(255 255 255 / 0.96) 0%, rgb(250 251 252 / 0.95) 100%);
    border: 1px solid rgb(15 23 42 / 0.08);
    border-radius: 0.95rem;
    padding: 1.1rem 1.2rem;
}

.kv-page-prose h2 {
    border-bottom: 1px solid rgb(var(--kv-primary-rgb, 53 95 140) / 0.35);
    color: #1f2937;
    font-size: clamp(1.3rem, 2vw, 1.55rem);
    font-weight: 800;
    letter-spacing: -0.01em;
    margin: 1.15rem 0 0.75rem;
    padding-bottom: 0.45rem;
}

.kv-page-prose h3 {
    color: #243043;
    font-size: clamp(1.12rem, 1.7vw, 1.3rem);
    font-weight: 750;
    margin: 1.05rem 0 0.65rem;
    padding-left: 0.7rem;
    position: relative;
}

.kv-page-prose h3::before {
    background: var(--kv-primary);
    border-radius: 99px;
    content: "";
    height: 0.95em;
    left: 0;
    opacity: 0.8;
    position: absolute;
    top: 0.18em;
    width: 3px;
}

.kv-page-prose h4 {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.08);
    border: 1px solid rgb(var(--kv-primary-rgb, 53 95 140) / 0.2);
    border-radius: 0.55rem;
    color: #1f2937;
    display: inline-block;
    font-size: clamp(1rem, 1.45vw, 1.1rem);
    font-weight: 700;
    margin: 0.95rem 0 0.55rem;
    padding: 0.2rem 0.55rem;
}

.kv-page-prose p {
    color: #374151;
    line-height: 1.85;
}

.page-content-card {
    background: linear-gradient(180deg, rgb(255 255 255 / 0.98) 0%, rgb(248 250 252 / 0.96) 100%);
    border: 1px solid rgb(15 23 42 / 0.08);
    border-radius: 1rem;
    box-shadow: 0 18px 36px rgb(15 23 42 / 0.08);
    padding: 1.25rem;
}

.page-content-card .page-content {
    background: linear-gradient(180deg, rgb(255 255 255 / 0.96) 0%, rgb(250 251 252 / 0.95) 100%);
    border: 1px solid rgb(15 23 42 / 0.08);
    border-radius: 0.95rem;
    padding: 1.1rem 1.2rem;
}

/* --- CTA + Footer Wrapper: Tek arka plan --- */

.kv-bottom-wrap {
    position: relative;
    overflow: hidden;
    background: #1a3350;
}

.kv-bottom-wrap::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(
        90deg,
        #294B71 0%,
        #355F8C 12%,
        #537294 24%,
        #E1AAA2 36%,
        #C81D25 50%,
        #9E6E57 64%,
        #537294 76%,
        #355F8C 88%,
        #294B71 100%
    );
    background-size: 200% 100%;
    animation: kv-shimmer-border 4s linear infinite;
    z-index: 10;
}

@keyframes kv-shimmer-border {
    0%   { background-position: 0% 0; }
    100% { background-position: 200% 0; }
}

.kv-bottom-wrap__bg {
    position: absolute;
    inset: 0;
    background: url('../images/cta-bg-4.jpg') center / cover no-repeat;
    opacity: 0.18;
    pointer-events: none;
    z-index: 0;
}

.kv-bottom-wrap .kv-cta,
.kv-bottom-wrap .kv-footer {
    background: transparent;
}

.kv-footer {
    color: #fff;
    isolation: isolate;
    overflow: hidden;
    position: relative;
    padding-top: 3rem;
}

.kv-footer::before {
    display: none;
}

.kv-footer::after {
    display: none;
}

.kv-footer__bg {
    display: none;
}

.kv-footer > .mx-auto,
.kv-footer > .border-t {
    position: relative;
    z-index: 2;
}

@keyframes kv-footer-border-shift {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 260% 50%;
    }
}

@keyframes kv-neon-sweep {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 220% 50%;
    }
}

@keyframes kv-neon-pulse {
    0%,
    100% {
        opacity: 0.72;
    }

    35% {
        opacity: 1;
    }

    68% {
        opacity: 0.84;
    }
}

.kv-footer__title {
    color: #fff;
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    margin: 0 0 0.25rem;
    text-transform: uppercase;
}

.kv-footer__link {
    color: rgb(255 255 255 / 0.65);
    font-size: 0.84rem;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.15s;
}

.kv-footer__link:hover {
    color: #fff;
    padding-left: 0.3rem;
}

.kv-footer__social {
    align-items: center;
    border: 1px solid rgb(255 255 255 / 0.2);
    border-radius: 999px;
    color: rgb(255 255 255 / 0.75);
    display: inline-flex;
    font-size: 0.95rem;
    height: 2.4rem;
    justify-content: center;
    text-decoration: none;
    transition: all 0.2s;
    width: 2.4rem;
}

.kv-footer__social:hover {
    background: rgb(255 255 255 / 0.12);
    border-color: rgb(255 255 255 / 0.4);
    color: #fff;
    transform: translateY(-2px);
}

.kv-footer__contact-item {
    align-items: flex-start;
    color: rgb(255 255 255 / 0.65);
    display: flex;
    font-size: 0.84rem;
    gap: 0.6rem;
    line-height: 1.6;
}

.kv-footer__contact-icon {
    color: var(--kv-primary);
    flex-shrink: 0;
    font-size: 0.9rem;
    margin-top: 0.15rem;
}

.kv-footer__legal {
    background: none;
    border: none;
    color: rgb(255 255 255 / 0.45);
    cursor: pointer;
    font-size: 0.76rem;
    font-weight: 600;
    text-decoration: none;
    transition: color 0.15s;
}

.kv-footer__legal:hover {
    color: rgb(255 255 255 / 0.9);
}

.kv-scroll-top {
    align-items: center;
    background: #fff;
    border: none;
    border-radius: 999px;
    bottom: 1.5rem;
    box-shadow: 0 16px 34px rgb(15 23 42 / 0.22);
    color: var(--kv-primary);
    display: inline-flex;
    font-size: 1rem;
    font-weight: 900;
    height: 2.8rem;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    position: fixed;
    right: 1.2rem;
    transition: opacity 0.2s ease, transform 0.2s ease;
    width: 2.8rem;
    z-index: 70;
}

.kv-scroll-top.is-visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(-2px);
}

[data-theme-card] {
    border-radius: 1rem;
}

.kv-panel {
    background: rgb(255 255 255 / 0.9);
    border: 1px solid rgb(17 24 39 / 0.08);
    border-radius: 1rem;
    box-shadow: 0 10px 28px rgb(15 23 42 / 0.08);
    padding: 1.1rem;
}

.kv-panel__header h3 {
    color: var(--kv-text);
    font-size: 0.86rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    margin: 0;
    text-transform: uppercase;
}

.kv-year-filter {
    display: grid;
    gap: 0.45rem;
    margin-top: 0.9rem;
}

.kv-year-filter a {
    border: 1px solid rgb(17 24 39 / 0.08);
    border-radius: 0.75rem;
    color: var(--kv-text);
    display: block;
    font-size: 0.83rem;
    font-weight: 700;
    padding: 0.55rem 0.65rem;
    text-decoration: none;
}

.kv-year-filter a:hover,
.kv-year-filter a.is-active {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.1);
    border-color: rgb(var(--kv-primary-rgb, 53 95 140) / 0.3);
    color: var(--kv-primary);
}

/* Report Filter Form */
.kv-report-filter-form {
    display: grid;
    gap: 0.75rem;
    margin-top: 0.9rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgb(17 24 39 / 0.08);
    margin-bottom: 0.5rem;
}

.kv-report-filter-form__group {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.kv-report-filter-form__group label {
    color: var(--kv-text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.kv-report-filter-form__select {
    appearance: none;
    background: rgb(255 255 255 / 0.9) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%23666'/%3E%3C/svg%3E") no-repeat right 0.6rem center;
    border: 1px solid rgb(17 24 39 / 0.12);
    border-radius: 0.6rem;
    color: var(--kv-text);
    font-size: 0.83rem;
    font-weight: 600;
    padding: 0.5rem 2rem 0.5rem 0.65rem;
    transition: border-color 0.2s, box-shadow 0.2s;
    width: 100%;
}

.kv-report-filter-form__select:focus {
    border-color: rgb(var(--kv-primary-rgb, 53 95 140) / 0.5);
    box-shadow: 0 0 0 3px rgb(var(--kv-primary-rgb, 53 95 140) / 0.1);
    outline: none;
}

.kv-report-filter-form__btn {
    align-items: center;
    background: var(--kv-primary);
    border: none;
    border-radius: 0.6rem;
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    font-size: 0.82rem;
    font-weight: 700;
    gap: 0.35rem;
    justify-content: center;
    padding: 0.55rem 1rem;
    transition: background 0.2s, transform 0.15s;
}

.kv-report-filter-form__btn:hover {
    filter: brightness(1.1);
    transform: translateY(-1px);
}

.kv-report-filter-form__clear {
    align-items: center;
    color: var(--kv-text-muted);
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 600;
    gap: 0.3rem;
    justify-content: center;
    text-decoration: none;
    transition: color 0.2s;
}

.kv-report-filter-form__clear:hover {
    color: var(--kv-primary);
}

.kv-report-card {
    background: rgb(255 255 255 / 0.92);
    border: 1px solid rgb(17 24 39 / 0.09);
    border-radius: 1rem;
    box-shadow: 0 14px 34px rgb(15 23 42 / 0.08);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.kv-report-card__year {
    align-items: baseline;
    background: linear-gradient(120deg, rgb(var(--kv-primary-rgb, 53 95 140) / 0.95), rgb(var(--kv-secondary-rgb, 158 110 87) / 0.92));
    color: #fff;
    display: flex;
    gap: 0.55rem;
    justify-content: center;
    padding: 0.7rem 1rem;
}

.kv-report-card__year span {
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1.2rem;
    font-weight: 800;
    letter-spacing: 0.03em;
}

.kv-report-card__year small {
    font-size: 0.82rem;
    font-weight: 600;
    opacity: 0.92;
}

.kv-report-card__body {
    padding: 1rem 1rem 0.75rem;
}

.kv-report-card__badge {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.1);
    border-radius: 999px;
    color: var(--kv-primary);
    display: inline-flex;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin-bottom: 0.45rem;
    padding: 0.26rem 0.55rem;
    text-transform: uppercase;
}

.kv-report-card h3 {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1.03rem;
    font-weight: 700;
    line-height: 1.35;
    margin: 0;
}

.kv-report-card p {
    color: var(--kv-text-muted);
    font-size: 0.85rem;
    line-height: 1.6;
    margin: 0.45rem 0 0;
}

.kv-report-card__footer {
    align-items: center;
    border-top: 1px solid rgb(17 24 39 / 0.08);
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: space-between;
    padding: 0.85rem 1rem 1rem;
}

.kv-report-meta {
    align-items: center;
    color: var(--kv-text-muted);
    display: flex;
    flex-wrap: wrap;
    font-size: 0.76rem;
    gap: 0.55rem;
}

.kv-report-btn {
    background: var(--kv-primary);
    border: 1px solid var(--kv-primary);
    border-radius: 0.65rem;
    color: #fff;
    display: inline-flex;
    font-size: 0.77rem;
    font-weight: 700;
    line-height: 1;
    padding: 0.52rem 0.72rem;
    text-decoration: none;
}

.kv-report-btn:hover {
    background: linear-gradient(135deg, var(--kv-primary-dark), var(--kv-primary));
    border-color: var(--kv-primary-dark);
    color: #fff;
    transform: translateY(-1px);
}

.kv-report-btn--ghost {
    background: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.08);
    border-color: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.25);
    color: var(--kv-secondary-dark);
}

.kv-report-btn--ghost:hover {
    background: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.18);
    border-color: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.35);
    color: var(--kv-secondary-dark);
    transform: translateY(-1px);
}

.kv-report-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.kv-empty-state {
    align-items: center;
    background: rgb(255 255 255 / 0.88);
    border: 1px dashed rgb(17 24 39 / 0.18);
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-height: 11rem;
    justify-content: center;
    padding: 1.2rem;
    text-align: center;
}

.kv-empty-state h3 {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1.1rem;
    margin: 0;
}

.kv-empty-state p {
    color: var(--kv-text-muted);
    margin: 0;
}

.kv-org-board {
    background: rgb(255 255 255 / 0.92);
    border: 1px solid rgb(17 24 39 / 0.09);
    border-radius: 1.1rem;
    box-shadow: 0 18px 42px rgb(15 23 42 / 0.1);
    padding: 1.2rem;
}

.kv-org-mayor {
    align-items: center;
    background: linear-gradient(120deg, rgb(var(--kv-secondary-rgb, 158 110 87) / 0.96), rgb(var(--kv-primary-rgb, 53 95 140) / 0.96));
    border-radius: 0.95rem;
    color: #fff;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    justify-content: center;
    max-width: 62rem;
    min-height: 4.5rem;
    padding: 0.8rem 1rem;
    width: 100%;
}

.kv-org-mayor span {
    font-size: 0.92rem;
    font-weight: 600;
}

.kv-org-mayor strong {
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1.15rem;
    font-weight: 800;
}

.kv-org-main-connector {
    background: rgb(107 114 128 / 0.3);
    height: 1.1rem;
    margin: 0 auto;
    width: 2px;
}

.kv-org-grid {
    display: grid;
    gap: 0.85rem;
    grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
    position: relative;
}

.kv-org-grid::before {
    background: rgb(107 114 128 / 0.25);
    content: "";
    height: 1px;
    left: 3%;
    position: absolute;
    right: 3%;
    top: 0;
}

.kv-org-grid.is-single::before {
    display: none;
}

.kv-org-column__connector {
    background: rgb(107 114 128 / 0.25);
    height: 1rem;
    margin: 0 auto;
    width: 1px;
}

.kv-org-column__head {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.95);
    border-radius: 0.9rem;
    color: #fff;
    min-height: 4rem;
    padding: 0.7rem 0.65rem;
    text-align: center;
}

.kv-org-column__head h3 {
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.28;
    margin: 0;
}

.kv-org-column__head small {
    display: block;
    font-size: 0.78rem;
    font-weight: 500;
    margin-top: 0.2rem;
    opacity: 0.9;
}

.kv-org-units {
    display: grid;
    gap: 0.45rem;
    margin-top: 0.55rem;
}

.kv-org-unit {
    background: rgb(243 244 246 / 0.95);
    border: 1px solid rgb(17 24 39 / 0.08);
    border-radius: 0.7rem;
    color: var(--kv-text);
    display: block;
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1.34;
    padding: 0.55rem 0.5rem;
    text-align: center;
    text-decoration: none;
}

.kv-org-unit:hover {
    background: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.12);
    border-color: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.3);
    color: var(--kv-secondary-dark);
}

.kv-org-unit--empty {
    color: var(--kv-text-muted);
    font-weight: 600;
}

/* --- CTA Section --- */
.kv-cta {
    background: transparent;
    position: relative;
    overflow: hidden;
    z-index: 2;
    margin-bottom: -3rem;
}

.kv-cta__bg {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 20% 50%, rgb(var(--kv-primary-rgb) / 0.15) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgb(var(--kv-secondary-rgb, 158 110 87) / 0.1) 0%, transparent 40%),
        radial-gradient(circle at 60% 90%, rgb(var(--kv-primary-rgb) / 0.06) 0%, transparent 35%);
    pointer-events: none;
}

.kv-cta__bg-img {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0.12;
    pointer-events: none;
}

.kv-cta__skyline {
    display: none;
}

.kv-cta__eyebrow {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgb(255 255 255 / 0.45);
    margin-bottom: 0.75rem;
}

.kv-cta__title {
    font-size: clamp(1.5rem, 3vw, 2.2rem);
    font-weight: 800;
    color: #fff;
    line-height: 1.2;
    margin-bottom: 0.75rem;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-cta__desc {
    font-size: 0.9375rem;
    line-height: 1.7;
    color: rgb(255 255 255 / 0.6);
    max-width: 50ch;
}

.kv-cta-card {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 1rem 1.25rem;
    background: rgb(255 255 255 / 0.06);
    border: 1px solid rgb(255 255 255 / 0.08);
    border-radius: 0.85rem;
    text-decoration: none;
    transition: all 0.25s ease;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.kv-cta-card:hover {
    background: rgb(255 255 255 / 0.1);
    border-color: rgb(255 255 255 / 0.18);
    transform: translateX(4px);
}

.kv-cta-card__icon {
    width: 2.75rem;
    height: 2.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.75rem;
    background: rgb(var(--kv-warm-rgb, 225 170 162) / 0.2);
    color: var(--kv-warm);
    font-size: 1.15rem;
    flex-shrink: 0;
}

.kv-cta-card--action .kv-cta-card__icon {
    background: var(--kv-accent);
    color: #fff;
}

.kv-cta-card__label {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: rgb(255 255 255 / 0.45);
}

.kv-cta-card__value {
    display: block;
    font-size: 0.875rem;
    font-weight: 700;
    color: #fff;
}

.kv-cta-card__value i {
    font-size: 0.75rem;
    margin-left: 0.25rem;
    transition: margin-left 0.2s;
}

.kv-cta-card:hover .kv-cta-card__value i {
    margin-left: 0.5rem;
}

[data-reveal] {
    opacity: 0;
    transform: translateY(14px);
    transition: opacity 0.5s ease, transform 0.5s ease;
}

[data-reveal].is-in {
    opacity: 1;
    transform: translateY(0);
}

@media (max-width: 1279px) {
    .kv-header {
        backdrop-filter: blur(10px);
    }
}

@media (max-width: 767px) {
    .kv-panel,
    .kv-org-board {
        padding: 0.95rem;
    }

    .kv-report-card__footer {
        align-items: flex-start;
        flex-direction: column;
    }

    .kv-org-grid {
        grid-template-columns: 1fr;
    }

    .kv-org-grid::before {
        display: none;
    }
}

/* ========================================
   TRANSPARENT HEADER (Homepage)
   ======================================== */

.kv-header--transparent {
    background: transparent;
    backdrop-filter: none;
    border-bottom-color: transparent;
    box-shadow: none;
    transition: background 0.35s ease, backdrop-filter 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

.kv-header--transparent .kv-header-glow {
    opacity: 0;
    transition: opacity 0.35s ease;
}

.kv-header--transparent.is-scrolled {
    background: rgb(255 255 255 / 0.92);
    backdrop-filter: blur(14px);
    border-bottom-color: var(--kv-accent, #C81D25);
    box-shadow: 0 4px 30px rgb(15 23 42 / 0.08);
}

.kv-header--transparent.is-scrolled .kv-header-glow {
    opacity: 1;
}

.kv-header--transparent:not(.is-scrolled) .kv-action-pill,
.kv-header--transparent:not(.is-scrolled) .kv-social-dot {
    color: #fff;
    border-color: rgb(255 255 255 / 0.25);
}

.kv-header--transparent:not(.is-scrolled) .kv-action-pill--label {
    background: rgb(255 255 255 / 0.15);
}

.kv-header--transparent:not(.is-scrolled) .kv-action-pill--contact {
    background: rgb(255 255 255 / 0.18);
    border-color: rgb(255 255 255 / 0.3);
}

.kv-header--transparent:not(.is-scrolled) .kv-lang-pill {
    background: rgb(255 255 255 / 0.15);
    border-color: rgb(255 255 255 / 0.3);
    color: #fff;
}

.kv-header--transparent:not(.is-scrolled) .kv-nav-link {
    color: #fff;
}

.kv-header--transparent:not(.is-scrolled) .kv-nav-link:hover,
.kv-header--transparent:not(.is-scrolled) .kv-nav-link:focus-visible {
    background: rgb(255 255 255 / 0.15);
    color: #fff;
}

.kv-header--transparent:not(.is-scrolled) .kv-mobile-toggle {
    background: rgb(255 255 255 / 0.15);
    border-color: rgb(255 255 255 / 0.3);
    color: #fff;
}

/* ========================================
   HOMEPAGE - HERO
   ======================================== */

.kv-hero {
    height: 72svh;
    min-height: 420px;
    max-height: 680px;
    position: relative;
    overflow: hidden;
}

.kv-hero::before {
    background:
        radial-gradient(65% 155% at 50% 100%, rgb(var(--kv-primary-rgb, 53 95 140) / 0.5) 0%, transparent 74%),
        linear-gradient(180deg, rgb(255 74 86 / 0.12) 0%, rgb(255 74 86 / 0) 100%);
    bottom: -2px;
    content: "";
    height: 42px;
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    z-index: 3;
}

.kv-hero::after {
    animation: kv-neon-sweep 3.2s linear infinite, kv-neon-pulse 1.4s ease-in-out infinite;
    background:
        linear-gradient(90deg,
            rgb(0 0 0 / 0) 0%,
            rgb(255 104 116 / 0.2) 12%,
            rgb(255 66 80 / 0.98) 25%,
            rgb(255 180 186 / 0.95) 34%,
            rgb(53 95 140 / 1) 47%,
            rgb(255 72 86 / 0.92) 59%,
            rgb(0 0 0 / 0) 78%);
    background-size: 220% 100%;
    bottom: 0;
    box-shadow:
        0 0 8px rgb(53 95 140 / 0.8),
        0 0 16px rgb(255 70 84 / 0.55),
        0 0 30px rgb(255 95 108 / 0.35),
        0 -1px 0 rgb(255 255 255 / 0.3) inset;
    content: "";
    height: 4px;
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    z-index: 4;
}

.kv-hero-swiper,
.kv-hero-swiper .swiper-wrapper,
.kv-hero__slide {
    height: 100%;
}

.kv-hero__slide--static {
    height: 100%;
    position: relative;
}

.kv-hero__media {
    inset: 0;
    position: absolute;
}

.kv-hero__media img {
    height: 100%;
    object-fit: cover;
    width: 100%;
    filter: saturate(1.25) contrast(1.08);
}

.kv-hero__media--video {
    background: #000;
    filter: saturate(1.25) contrast(1.08);
}

.kv-hero__video-poster {
    inset: 0;
    position: absolute;
    z-index: 1;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity 0.6s ease;
}

.kv-hero__video-player {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.kv-hero__video-player iframe {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100%;
    width: 177.78vh;
    height: 56.25vw;
    transform: translate(-50%, -50%);
    border: 0;
}

.kv-hero__video-player video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.kv-hero__overlay {
    background:
        linear-gradient(180deg, rgb(0 0 0 / 0.5) 0%, rgb(0 0 0 / 0.25) 30%, transparent 60%);
    inset: 0;
    position: absolute;
    z-index: 1;
}

.kv-hero__content {
    align-items: flex-start;
    bottom: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    left: 0;
    padding-bottom: 3.8rem;
    padding-top: 8rem;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 2;
}

.kv-hero__badge {
    background: rgb(255 255 255 / 0.18);
    border: 1px solid rgb(255 255 255 / 0.28);
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    margin-bottom: 0.8rem;
    padding: 0.4rem 1rem;
}

.kv-hero__title {
    color: #fff;
    font-family: var(--kv-heading-font), sans-serif;
    font-size: clamp(2rem, 5vw, 3.8rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.1;
    margin: 0;
    max-width: 18ch;
    text-shadow: 0 2px 20px rgb(0 0 0 / 0.2);
}

.kv-hero__desc {
    color: rgb(255 255 255 / 0.9);
    font-size: clamp(0.9rem, 1.5vw, 1.1rem);
    line-height: 1.6;
    margin: 0.8rem 0 0;
    max-width: 48ch;
}

.kv-hero__cta {
    align-items: center;
    background: var(--kv-accent);
    border: none;
    border-radius: 0.75rem;
    color: #fff;
    display: inline-flex;
    font-size: 0.88rem;
    font-weight: 700;
    gap: 0.5rem;
    margin-top: 1.5rem;
    padding: 0.85rem 1.6rem;
    text-decoration: none;
    transition: all 0.25s ease;
}

.kv-hero__cta:hover {
    background: linear-gradient(135deg, var(--kv-accent-dark), var(--kv-accent));
    box-shadow: 0 10px 24px rgb(var(--kv-accent-rgb, 200 29 37) / 0.35);
    color: #fff;
    transform: translateY(-2px);
}

.kv-hero-pagination {
    bottom: 2rem !important;
    left: 50% !important;
    position: absolute;
    transform: translateX(-50%);
    z-index: 10;
}

.kv-hero-pagination .swiper-pagination-bullet {
    background: rgb(255 255 255 / 0.5);
    border-radius: 999px;
    height: 0.5rem;
    opacity: 1;
    transition: all 0.3s ease;
    width: 0.5rem;
}

.kv-hero-pagination .swiper-pagination-bullet-active {
    background: #fff;
    width: 1.8rem;
}

.kv-hero-nav {
    align-items: center;
    background: rgb(255 255 255 / 0.15);
    backdrop-filter: blur(8px);
    border: 1px solid rgb(255 255 255 / 0.2);
    border-radius: 999px;
    color: #fff;
    cursor: pointer;
    display: none;
    font-size: 1.2rem;
    height: 3rem;
    justify-content: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    transition: all 0.25s ease;
    width: 3rem;
    z-index: 10;
}

.kv-hero-nav:hover {
    background: rgb(255 255 255 / 0.25);
}

.kv-hero-prev {
    left: 1.5rem;
}

.kv-hero-next {
    right: 1.5rem;
}

.kv-hero__scroll-hint {
    bottom: 1.2rem;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    z-index: 10;
}

.kv-hero__scroll-hint span {
    animation: kv-scroll-hint 2s infinite;
    border: 2px solid rgb(255 255 255 / 0.5);
    border-radius: 999px;
    display: block;
    height: 2.2rem;
    position: relative;
    width: 1.4rem;
}

.kv-hero__scroll-hint span::before {
    animation: kv-scroll-dot 2s infinite;
    background: #fff;
    border-radius: 999px;
    content: "";
    height: 0.35rem;
    left: 50%;
    position: absolute;
    top: 0.4rem;
    transform: translateX(-50%);
    width: 0.35rem;
}

@keyframes kv-scroll-dot {
    0% { opacity: 1; top: 0.4rem; }
    100% { opacity: 0; top: 1.2rem; }
}

/* ========================================
   HOMEPAGE - QUICK SERVICES
   ======================================== */

.kv-quick-services {
    margin-top: -3.5rem;
    position: relative;
    z-index: 10;
}

.kv-quick-service {
    align-items: center;
    background: rgb(255 255 255 / 0.97);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgb(0 0 0 / 0.05);
    border-radius: 1rem;
    box-shadow: 0 8px 32px rgb(15 23 42 / 0.08);
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    padding: 1.35rem 0.85rem;
    text-align: center;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    position: relative;
    overflow: hidden;
}

.kv-quick-service::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 3px;
    border-radius: 0 0 3px 3px;
    background: linear-gradient(90deg, var(--kv-primary), var(--kv-secondary, #9E6E57));
    transition: width 0.3s ease;
}

.kv-quick-service:hover::before {
    width: 100%;
}

.kv-quick-service:hover {
    box-shadow: 0 16px 48px rgb(var(--kv-primary-rgb, 53 95 140) / 0.12);
    transform: translateY(-6px);
    border-color: rgb(var(--kv-primary-rgb, 53 95 140) / 0.12);
}

.kv-quick-service__icon {
    align-items: center;
    background: linear-gradient(135deg, rgb(var(--kv-primary-rgb, 53 95 140) / 0.08), rgb(var(--kv-secondary-rgb, 158 110 87) / 0.08));
    border-radius: 1rem;
    color: var(--kv-primary);
    display: flex;
    font-size: 1.5rem;
    height: 3.25rem;
    justify-content: center;
    transition: all 0.3s ease;
    width: 3.25rem;
}

.kv-quick-service:hover .kv-quick-service__icon {
    background: var(--kv-primary);
    color: #fff;
    transform: scale(1.1);
}

.kv-quick-service__title {
    color: var(--kv-text);
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1.3;
}

/* ========================================
   HOMEPAGE - SHARED SECTION STYLES
   ======================================== */

.kv-section {
    position: relative;
}

.kv-section--alt {
    background: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.03);
}

.kv-section__badge {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.1);
    border-radius: 999px;
    color: var(--kv-primary);
    display: inline-flex;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    margin-bottom: 0.6rem;
    padding: 0.32rem 0.8rem;
    text-transform: uppercase;
}

.kv-section__badge--sm {
    font-size: 0.68rem;
    padding: 0.24rem 0.6rem;
}

.kv-section__title {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: clamp(1.5rem, 3vw, 2.2rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin: 0;
}

/* NOTE: .kv-btn base and all variants consolidated in "Button Sizes & Variants" section */

/* ========================================
   UI TOUCHES - Global Hover Polish
   ======================================== */

:is(
    .kv-btn,
    .kv-hero__cta,
    .kv-report-btn,
    .kv-action-pill,
    .kv-pagination__btn,
    .kv-mobile-toggle,
    .kv-mobile-close
) {
    overflow: hidden;
    position: relative;
    transition: background 0.3s ease, color 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease, transform 0.25s ease;
}

:is(
    .kv-btn,
    .kv-hero__cta,
    .kv-report-btn,
    .kv-action-pill,
    .kv-pagination__btn,
    .kv-mobile-toggle,
    .kv-mobile-close
):hover {
    box-shadow: 0 6px 18px rgb(var(--kv-primary-rgb, 53 95 140) / 0.16);
}

:is(
    .kv-btn,
    .kv-hero__cta,
    .kv-report-btn
)::after {
    background: linear-gradient(120deg, rgb(255 255 255 / 0) 20%, rgb(255 255 255 / 0.22) 50%, rgb(255 255 255 / 0) 80%);
    border-radius: inherit;
    content: "";
    inset: 0;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    transform: translateX(-120%);
    transition: opacity 0.15s ease;
}

:is(
    .kv-btn,
    .kv-hero__cta,
    .kv-report-btn
):hover::after {
    animation: kv-btn-shine 0.7s ease forwards;
    opacity: 1;
}

@keyframes kv-btn-shine {
    0% { transform: translateX(-120%); }
    100% { transform: translateX(120%); }
}

/* --- Cards: Only bottom border accent --- */
.kv-body :is(
    .kv-card,
    .kv-news-card,
    .kv-feed-card,
    .kv-project-card,
    .kv-event-card,
    .kv-dept-card,
    .kv-album-card,
    .kv-report-card,
    .kv-contact-card,
    .kv-council-card,
    .kv-tender-card,
    .kv-mayor-info-card,
    .kv-vision-card,
    .kv-discover__card,
    .kv-profile-card
) {
    border: none;
    border-bottom: 3px solid rgb(var(--kv-primary-rgb, 53 95 140) / 0.28);
    transition: border-bottom-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
}

.kv-body :is(
    .kv-card,
    .kv-news-card,
    .kv-feed-card,
    .kv-project-card,
    .kv-event-card,
    .kv-dept-card,
    .kv-album-card,
    .kv-report-card,
    .kv-contact-card,
    .kv-council-card,
    .kv-tender-card,
    .kv-mayor-info-card,
    .kv-vision-card,
    .kv-discover__card,
    .kv-profile-card
):hover {
    border-bottom-color: var(--kv-primary);
}

/* ========================================
   HOMEPAGE - NEWS GRID
   ======================================== */

.kv-news-card {
    background: #fff;
    border: 1px solid rgb(17 24 39 / 0.06);
    border-radius: 1rem;
    box-shadow: 0 8px 24px rgb(15 23 42 / 0.06);
    overflow: hidden;
    transition: all 0.3s ease;
}

.kv-news-card:hover {
    box-shadow: 0 16px 40px rgb(15 23 42 / 0.1);
    transform: translateY(-3px);
}

.kv-news-card__media {
    aspect-ratio: 16 / 10;
    display: block;
    overflow: hidden;
    position: relative;
}

.kv-news-card--featured .kv-news-card__media {
    aspect-ratio: auto;
    height: 100%;
    min-height: 280px;
}

.kv-news-card__media img {
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
    width: 100%;
}

.kv-news-card:hover .kv-news-card__media img {
    transform: scale(1.05);
}

.kv-news-card__overlay {
    background: linear-gradient(180deg, transparent 40%, rgb(0 0 0 / 0.1) 100%);
    inset: 0;
    position: absolute;
}

.kv-news-card__date {
    background: var(--kv-primary);
    border-radius: 0.6rem;
    color: #fff;
    display: flex;
    flex-direction: column;
    left: 0.75rem;
    line-height: 1;
    padding: 0.45rem 0.6rem;
    position: absolute;
    text-align: center;
    top: 0.75rem;
    z-index: 2;
}

.kv-news-card__day {
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1.2rem;
    font-weight: 800;
}

.kv-news-card__month {
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.kv-news-card__category {
    border-radius: 999px;
    bottom: 0.75rem;
    color: #fff;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    padding: 0.28rem 0.65rem;
    position: absolute;
    right: 0.75rem;
    text-transform: uppercase;
    z-index: 2;
}

.kv-badge--news {
    background: var(--kv-secondary);
}

.kv-badge--announcement {
    background: var(--kv-primary);
}

.kv-news-card__body {
    padding: 1rem 1rem 1.1rem;
}

.kv-news-card__title {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.35;
    margin: 0;
}

.kv-news-card__title a {
    color: inherit;
    text-decoration: none;
}

.kv-news-card__title a:hover {
    color: var(--kv-primary);
}

.kv-news-card__excerpt {
    color: var(--kv-text-muted);
    font-size: 0.84rem;
    line-height: 1.6;
    margin: 0.4rem 0 0;
}

.kv-news-grid__head {
    text-align: center;
}

.kv-news-grid__title {
    font-size: clamp(1.3rem, 2.3vw, 1.75rem);
}

.kv-news-grid--minimal .kv-news-card {
    border-radius: 0.8rem;
    box-shadow: 0 4px 14px rgb(15 23 42 / 0.05);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.kv-news-grid--minimal .kv-news-card:hover {
    border-color: rgb(var(--kv-primary-rgb, 53 95 140) / 0.2);
    box-shadow: 0 8px 20px rgb(15 23 42 / 0.08);
    transform: none;
}

.kv-news-grid--minimal .kv-news-card__media {
    aspect-ratio: 16 / 9;
}

.kv-news-grid--minimal .kv-news-card__media img {
    transition: none;
}

.kv-news-grid--minimal .kv-news-card:hover .kv-news-card__media img {
    transform: none;
}

.kv-news-grid--minimal .kv-news-card__date {
    border-radius: 0.5rem;
    left: 0.6rem;
    padding: 0.32rem 0.45rem;
    top: 0.6rem;
}

.kv-news-grid--minimal .kv-news-card__day {
    font-size: 0.95rem;
}

.kv-news-grid--minimal .kv-news-card__month {
    font-size: 0.62rem;
}

.kv-news-grid--minimal .kv-news-card__category {
    border-radius: 0.45rem;
    bottom: 0.55rem;
    font-size: 0.62rem;
    letter-spacing: 0.03em;
    padding: 0.2rem 0.45rem;
    right: 0.55rem;
}

.kv-news-grid--minimal .kv-news-card__body {
    padding: 0.8rem 0.85rem 0.9rem;
}

.kv-news-grid--minimal .kv-news-card__title {
    font-size: 0.92rem;
    line-height: 1.35;
}

.kv-news-grid--minimal .kv-news-card__excerpt {
    display: -webkit-box;
    font-size: 0.78rem;
    line-height: 1.5;
    margin-top: 0.32rem;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

/* ========================================
   HOMEPAGE - NEWS SECTION (Haberler, Duyurular, Etkinlikler)
   ======================================== */

.kv-news-section {
    position: relative;
    overflow: hidden;
    background: linear-gradient(160deg, #f8fafc 0%, #f1f5f9 50%, #f8fafc 100%);
}

.kv-news-section__bg {
    display: none;
}

/* ========================================
   HOMEPAGE - FEED (Güncel) Tabs + Cards
   ======================================== */

.kv-feed-tabs {
    display: flex;
    gap: 0.2rem;
    background: var(--kv-surface-alt, #f1f5f9);
    border-radius: 0.75rem;
    padding: 0.25rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.kv-feed-tabs::-webkit-scrollbar { display: none; }

.kv-feed-tabs button {
    padding: 0.5rem 1rem;
    border-radius: 0.625rem;
    border: none;
    background: transparent;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--kv-text-muted);
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
    font-family: inherit;
}

.kv-feed-tabs button:hover {
    color: var(--kv-text);
    background: rgb(0 0 0 / 0.04);
}

.kv-feed-tabs button.is-active {
    background: var(--kv-primary);
    color: #fff;
    box-shadow: 0 2px 8px rgb(var(--kv-primary-rgb) / 0.25);
}

.kv-feed-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}

.kv-feed-card {
    background: var(--kv-surface);
    border-radius: 1rem;
    overflow: hidden;
    border: 1px solid var(--kv-border);
    border-bottom: 3px solid var(--kv-primary, #355F8C);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.kv-feed-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgb(0 0 0 / 0.08);
}

.kv-feed-card__media {
    display: block;
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 10;
}

.kv-feed-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.kv-feed-card:hover .kv-feed-card__media img {
    transform: scale(1.05);
}

.kv-feed-badge {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.25rem 0.6rem;
    border-radius: 0.5rem;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    z-index: 1;
}

.kv-feed-badge i { font-size: 0.7rem; }

.kv-feed-badge--news {
    background: rgb(59 130 246 / 0.88);
    color: #fff;
}

.kv-feed-badge--announcement {
    background: rgb(245 158 11 / 0.88);
    color: #fff;
}

.kv-feed-badge--event {
    background: rgb(16 185 129 / 0.88);
    color: #fff;
}

.kv-feed-card__body {
    padding: 1rem 1.15rem 1.15rem;
}

.kv-feed-card__date {
    font-size: 0.72rem;
    color: var(--kv-text-muted);
    display: flex;
    align-items: center;
    gap: 0.3rem;
    margin-bottom: 0.4rem;
}

.kv-feed-card__date i { font-size: 0.68rem; }

.kv-feed-card__title {
    font-size: 0.9375rem;
    font-weight: 700;
    line-height: 1.4;
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.kv-feed-card__title a {
    text-decoration: none;
    color: inherit;
    transition: color 0.15s;
}

.kv-feed-card__title a:hover {
    color: var(--kv-primary);
}

@media (max-width: 1023px) {
    .kv-feed-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 639px) {
    .kv-feed-grid { grid-template-columns: 1fr; gap: 1rem; }
    .kv-feed-tabs { gap: 0.15rem; }
    .kv-feed-tabs button { padding: 0.4rem 0.75rem; font-size: 0.75rem; }
}

/* ----------------------------------------
   MAGAZINE LAYOUT
   ---------------------------------------- */

.kv-magazine {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: 1.25rem;
    min-height: 440px;
}

.kv-magazine__featured {
    position: relative;
    border-radius: 1rem;
    overflow: hidden;
    color: #fff;
}

.kv-magazine__slide {
    display: block;
    position: absolute;
    inset: 0;
    text-decoration: none;
    color: #fff;
}

.kv-magazine__slide:first-child {
    position: relative;
}

.kv-magazine__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.kv-magazine__slide:hover img {
    transform: scale(1.04);
    transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.kv-magazine__dots {
    position: absolute;
    bottom: 0.85rem;
    right: 0.85rem;
    display: flex;
    gap: 0.35rem;
    z-index: 5;
}

.kv-magazine__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: none;
    background: rgb(255 255 255 / 0.4);
    cursor: pointer;
    padding: 0;
    transition: all 0.25s;
}

.kv-magazine__dot.is-active {
    background: #fff;
    width: 22px;
    border-radius: 4px;
}

.kv-magazine__featured-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgb(0 0 0 / 0.78) 0%, rgb(0 0 0 / 0.25) 45%, transparent 70%);
    z-index: 1;
}

.kv-magazine__featured-content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 1.75rem;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.kv-magazine__featured-content .kv-feed-badge {
    position: static;
    align-self: flex-start;
}

.kv-magazine__featured-content h3 {
    font-size: clamp(1.15rem, 2vw, 1.45rem);
    font-weight: 800;
    line-height: 1.3;
    margin: 0;
    font-family: var(--kv-heading-font), sans-serif;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}

.kv-magazine__featured-content p {
    font-size: 0.82rem;
    line-height: 1.5;
    margin: 0;
    opacity: 0.85;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.kv-magazine__featured-content time {
    font-size: 0.72rem;
    opacity: 0.7;
    display: flex;
    align-items: center;
    gap: 0.3rem;
}

.kv-magazine__list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    overflow-y: auto;
    scrollbar-width: thin;
}

.kv-magazine__item {
    display: flex;
    gap: 0.85rem;
    padding: 0.65rem;
    border-radius: 0.75rem;
    background: var(--kv-surface);
    border: 1px solid var(--kv-border);
    border-bottom: 3px solid var(--kv-primary, #355F8C);
    text-decoration: none;
    color: var(--kv-text);
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.kv-magazine__item:hover {
    border-color: rgb(var(--kv-primary-rgb) / 0.3);
    box-shadow: 0 4px 16px rgb(0 0 0 / 0.06);
    transform: translateX(3px);
}

.kv-magazine__item-thumb {
    flex-shrink: 0;
    width: 88px;
    height: 68px;
    border-radius: 0.5rem;
    overflow: hidden;
    position: relative;
}

.kv-magazine__item-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.kv-magazine__item-badge {
    position: absolute;
    top: 0.25rem;
    left: 0.25rem;
    width: 20px;
    height: 20px;
    border-radius: 0.35rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.55rem;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.kv-magazine__item-body {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.3rem;
    min-width: 0;
    flex: 1;
}

.kv-magazine__item-body h4 {
    font-size: 0.84rem;
    font-weight: 700;
    line-height: 1.35;
    margin: 0;
    font-family: var(--kv-heading-font), sans-serif;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    color: var(--kv-text);
}

.kv-magazine__item:hover h4 {
    color: var(--kv-primary);
}

.kv-magazine__item-body time {
    font-size: 0.68rem;
    color: var(--kv-text-muted);
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.kv-magazine__item-body time i { font-size: 0.62rem; }

@media (max-width: 767px) {
    .kv-magazine {
        grid-template-columns: 1fr;
        min-height: auto;
    }
    .kv-magazine__featured { min-height: 280px; }
    .kv-magazine__list { max-height: 360px; }
}

/* ========================================
   HOMEPAGE - INFO COLUMNS
   ======================================== */

.kv-info-column {
    background: rgb(255 255 255 / 0.9);
    border: 1px solid rgb(17 24 39 / 0.06);
    border-radius: 1.1rem;
    box-shadow: 0 8px 28px rgb(15 23 42 / 0.06);
    overflow: hidden;
}

.kv-info-column__header {
    align-items: flex-start;
    border-bottom: 1px solid rgb(17 24 39 / 0.06);
    display: flex;
    gap: 0.5rem;
    justify-content: space-between;
    padding: 1.2rem 1.2rem 1rem;
}

.kv-info-column__title {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1.05rem;
    font-weight: 800;
    line-height: 1.3;
    margin: 0;
}

.kv-info-column__more {
    align-items: center;
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.1);
    border-radius: 999px;
    color: var(--kv-primary);
    display: flex;
    flex-shrink: 0;
    font-size: 1rem;
    height: 2.2rem;
    justify-content: center;
    text-decoration: none;
    transition: all 0.2s ease;
    width: 2.2rem;
}

.kv-info-column__more:hover {
    background: var(--kv-primary);
    color: #fff;
}

.kv-info-column__list {
    padding: 0.5rem;
}

.kv-info-item {
    align-items: center;
    border-radius: 0.75rem;
    color: var(--kv-text);
    display: flex;
    gap: 0.75rem;
    padding: 0.65rem 0.7rem;
    text-decoration: none;
    transition: background 0.2s ease;
}

.kv-info-item:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.04);
}

.kv-info-item__thumb {
    border-radius: 0.6rem;
    flex-shrink: 0;
    height: 3.2rem;
    overflow: hidden;
    width: 3.2rem;
}

.kv-info-item__thumb img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.kv-info-item__icon {
    align-items: center;
    background: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.1);
    border-radius: 0.6rem;
    color: var(--kv-secondary);
    display: flex;
    flex-shrink: 0;
    font-size: 1.1rem;
    height: 3.2rem;
    justify-content: center;
    width: 3.2rem;
}

.kv-info-item__icon--tender {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.1);
    color: var(--kv-primary);
}

.kv-info-item__body h4 {
    color: var(--kv-text);
    font-size: 0.84rem;
    font-weight: 700;
    line-height: 1.35;
    margin: 0;
}

.kv-info-item__date {
    align-items: center;
    color: var(--kv-text-muted);
    display: flex;
    font-size: 0.74rem;
    gap: 0.3rem;
    margin-top: 0.2rem;
}

.kv-info-item--empty {
    color: var(--kv-text-muted);
    flex-direction: column;
    font-size: 0.82rem;
    gap: 0.3rem;
    justify-content: center;
    min-height: 8rem;
    text-align: center;
}

.kv-info-item--empty i {
    font-size: 1.5rem;
    opacity: 0.3;
}

/* ========================================
   HOMEPAGE - MAYOR
   ======================================== */

.kv-mayor {
    background: linear-gradient(145deg, rgb(var(--kv-secondary-rgb, 158 110 87) / 0.04), rgb(var(--kv-primary-rgb, 53 95 140) / 0.02));
    overflow: hidden;
    position: relative;
}

.kv-mayor__pattern {
    background: url('../images/baskan-arka.png') center / cover no-repeat;
    inset: 0;
    pointer-events: none;
    position: absolute;
    opacity: 0.35;
}

.kv-mayor__badge {
    background: linear-gradient(135deg, var(--kv-primary), var(--kv-primary-dark));
    border-radius: 999px;
    color: #fff;
    display: inline-block;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin-bottom: 1rem;
    padding: 0.4rem 1rem;
    text-transform: uppercase;
}

.kv-mayor__heading {
    color: var(--kv-primary);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: clamp(1.6rem, 3vw, 2.6rem);
    font-weight: 900;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin: 0 0 1.2rem;
}

.kv-mayor__message {
    color: var(--kv-text-muted);
    font-size: 0.95rem;
    hyphens: none;
    line-height: 1.8;
    margin: 0 0 1.5rem;
    max-width: 60ch;
    overflow-wrap: break-word;
    word-break: normal;
}

.kv-mayor__message.kv-prose > :first-child {
    margin-top: 0;
}

.kv-mayor__message.kv-prose > :last-child {
    margin-bottom: 0;
}

.kv-mayor__signature {
    align-items: center;
    border-top: 1px solid rgb(0 0 0 / 0.08);
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    margin-top: 1.5rem;
    padding-top: 1.5rem;
}

.kv-mayor__signature-info strong {
    color: var(--kv-text);
    display: block;
    font-size: 1rem;
    font-weight: 800;
}

.kv-mayor__signature-info span {
    color: var(--kv-primary);
    display: block;
    font-size: 0.82rem;
    font-weight: 600;
    margin-top: 0.15rem;
}

.kv-mayor__signature-divider {
    background: rgb(0 0 0 / 0.1);
    height: 2.5rem;
    width: 1px;
}

.kv-mayor__social {
    align-items: center;
    border: 1.5px solid rgb(17 24 39 / 0.12);
    border-radius: 999px;
    color: var(--kv-text);
    display: flex;
    font-size: 1rem;
    height: 2.5rem;
    justify-content: center;
    text-decoration: none;
    transition: all 0.2s ease;
    width: 2.5rem;
}

.kv-mayor__social:hover {
    background: var(--kv-primary);
    border-color: var(--kv-primary);
    color: #fff;
}

.kv-mayor__social--x:hover {
    background: #000;
    border-color: #000;
}

.kv-mayor__social--ig:hover {
    background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
    border-color: #dc2743;
}

.kv-mayor__social--yt:hover {
    background: #FF0000;
    border-color: #FF0000;
}

.kv-mayor__photo-wrapper {
    position: relative;
}

.kv-mayor__photo-img {
    aspect-ratio: 4 / 5;
    border-radius: 1.2rem;
    object-fit: cover;
    width: 100%;
}

.kv-mayor__cta-group {
    bottom: 0;
    display: flex;
    left: 0;
    position: absolute;
    right: 0;
}

.kv-mayor__cta {
    align-items: center;
    backdrop-filter: blur(12px);
    background: rgb(0 0 0 / 0.55);
    color: #fff;
    display: flex;
    flex: 1;
    font-size: 0.82rem;
    gap: 0.75rem;
    justify-content: space-between;
    padding: 0.85rem 1.1rem;
    text-decoration: none;
    transition: background 0.2s;
}

.kv-mayor__cta:first-child {
    border-bottom-left-radius: 1.2rem;
}

.kv-mayor__cta:last-child {
    border-bottom-right-radius: 1.2rem;
}

.kv-mayor__cta:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.8);
}

.kv-mayor__cta strong {
    display: block;
    font-weight: 700;
}

.kv-mayor__cta i {
    font-size: 1.1rem;
    transition: transform 0.2s;
}

.kv-mayor__cta:hover i {
    transform: translateX(3px);
}

/* ========================================
   HOMEPAGE - PROJECTS
   ======================================== */

.kv-project-featured {
    border-radius: 1.2rem;
    display: grid;
    min-height: 380px;
    overflow: hidden;
    position: relative;
}

.kv-project-featured__media {
    inset: 0;
    position: absolute;
}

.kv-project-featured__media img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.kv-project-featured__overlay {
    background: linear-gradient(90deg, rgb(0 0 0 / 0.7) 0%, rgb(0 0 0 / 0.2) 70%);
    inset: 0;
    position: absolute;
}

.kv-project-featured__content {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 2rem;
    position: relative;
    z-index: 1;
}

.kv-project-featured__content h3 {
    color: #fff;
    font-family: var(--kv-heading-font), sans-serif;
    font-size: clamp(1.3rem, 2.5vw, 1.8rem);
    font-weight: 800;
    line-height: 1.2;
    margin: 0.5rem 0;
    max-width: 30ch;
}

.kv-project-featured__content p {
    color: rgb(255 255 255 / 0.85);
    font-size: 0.88rem;
    line-height: 1.6;
    margin: 0;
    max-width: 50ch;
}

.kv-project-status {
    border-radius: 999px;
    display: inline-flex;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    padding: 0.3rem 0.7rem;
    text-transform: uppercase;
    width: fit-content;
}

.kv-project-status--active {
    background: rgb(53 95 140 / 0.15);
    color: #355F8C;
}

.kv-project-status--completed {
    background: rgb(34 197 94 / 0.15);
    color: #16a34a;
}

.kv-project-status--planned {
    background: rgb(158 110 87 / 0.15);
    color: #9E6E57;
}

.kv-project-featured .kv-project-status {
    color: #fff;
}

.kv-project-featured .kv-project-status--active { background: rgb(53 95 140 / 0.4); }
.kv-project-featured .kv-project-status--completed { background: rgb(34 197 94 / 0.4); }
.kv-project-featured .kv-project-status--planned { background: rgb(158 110 87 / 0.4); }

.kv-project-progress {
    align-items: center;
    display: flex;
    gap: 0.6rem;
    margin-top: 0.8rem;
}

.kv-project-progress__bar {
    background: rgb(255 255 255 / 0.2);
    border-radius: 999px;
    flex: 1;
    height: 0.4rem;
    overflow: hidden;
}

.kv-project-progress__fill {
    background: var(--kv-primary);
    border-radius: 999px;
    height: 100%;
    transition: width 0.6s ease;
}

.kv-project-featured .kv-project-progress__fill {
    background: #fff;
}

.kv-project-progress__label {
    color: rgb(255 255 255 / 0.85);
    font-size: 0.78rem;
    font-weight: 700;
}

.kv-project-progress--sm .kv-project-progress__bar {
    background: rgb(17 24 39 / 0.08);
}

.kv-project-progress--sm .kv-project-progress__label {
    color: var(--kv-text-muted);
}

.kv-project-card {
    background: #fff;
    border: 1px solid rgb(17 24 39 / 0.06);
    border-radius: 1rem;
    box-shadow: 0 8px 24px rgb(15 23 42 / 0.06);
    overflow: hidden;
    transition: all 0.3s ease;
}

.kv-project-card:hover {
    box-shadow: 0 14px 36px rgb(15 23 42 / 0.1);
    transform: translateY(-3px);
}

.kv-project-card__media {
    aspect-ratio: 16 / 10;
    display: block;
    overflow: hidden;
    position: relative;
}

.kv-project-card__media img {
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
    width: 100%;
}

.kv-project-card:hover .kv-project-card__media img {
    transform: scale(1.05);
}

.kv-project-card__media .kv-project-status {
    left: 0.75rem;
    position: absolute;
    top: 0.75rem;
    z-index: 2;
}

.kv-project-card__body {
    padding: 1rem;
}

.kv-project-card__body h4 {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.35;
    margin: 0;
}

.kv-project-card__body h4 a {
    color: inherit;
    text-decoration: none;
}

.kv-project-card__body h4 a:hover {
    color: var(--kv-primary);
}

/* ========================================
   HOMEPAGE - DISCOVER KIRAZ (Bento Grid)
   ======================================== */

.kv-discover {
    position: relative;
    overflow: hidden;
    background: linear-gradient(160deg, #edf2f7 0%, #e8eef6 50%, #f5f0ec 100%);
}

.kv-discover__bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.kv-discover__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(3, 1fr);
    gap: 0.75rem;
}

/* Hero carousel */
.kv-discover__carousel {
    grid-column: 1 / 3;
    grid-row: 1 / 4;
    position: relative;
    border-radius: 0.75rem;
    overflow: hidden;
}

.kv-discover__slide {
    position: absolute;
    inset: 0;
    display: block;
    text-decoration: none;
    color: #fff;
}

.kv-discover__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.kv-discover__slide:hover img {
    transform: scale(1.05);
}

.kv-discover__slide-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgb(0 0 0 / 0.65) 0%, rgb(0 0 0 / 0.1) 45%, transparent 70%);
    z-index: 1;
}

.kv-discover__slide-body {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 1rem 1.25rem;
    z-index: 2;
}

.kv-discover__dots {
    position: absolute;
    bottom: 0.75rem;
    right: 1rem;
    display: flex;
    gap: 0.4rem;
    z-index: 3;
}

.kv-discover__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: none;
    background: rgb(255 255 255 / 0.4);
    cursor: pointer;
    padding: 0;
    transition: all 0.25s;
}

.kv-discover__dot.is-active {
    background: #fff;
    transform: scale(1.25);
}

/* Image cards */
.kv-discover__card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: var(--kv-text);
    background: rgb(255 255 255 / 0.75);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgb(0 0 0 / 0.04);
    border-radius: 0.75rem;
    overflow: hidden;
    transition: all 0.25s ease;
}

.kv-discover__card:hover {
    background: #fff;
    border-color: rgb(var(--kv-primary-rgb) / 0.15);
    box-shadow: 0 6px 16px rgb(0 0 0 / 0.06);
    transform: translateY(-3px);
}

.kv-discover__card-thumb {
    width: 100%;
    height: 0;
    padding-bottom: 48%;
    position: relative;
    overflow: hidden;
}

.kv-discover__card-thumb img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.kv-discover__card:hover .kv-discover__card-thumb img {
    transform: scale(1.05);
}

.kv-discover__card-body {
    padding: 0.5rem 0.65rem;
}

.kv-discover__card-title {
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1.3;
    margin: 0;
}

.kv-discover__card-desc {
    font-size: 0.68rem;
    line-height: 1.4;
    color: var(--kv-text-muted);
    margin: 0.2rem 0 0;
}

@media (max-width: 1023px) {
    .kv-discover__grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: auto;
    }
    .kv-discover__carousel {
        grid-column: span 2;
        grid-row: span 1;
        min-height: 200px;
    }
    .kv-discover__slide {
        position: relative;
    }
}

@media (max-width: 639px) {
    .kv-discover__grid {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
    }
    .kv-discover__carousel {
        grid-column: span 1;
        min-height: 180px;
    }
}

/* ========================================
   HOMEPAGE - STATS
   ======================================== */

.kv-stats {
    background: linear-gradient(135deg, rgb(var(--kv-primary-rgb, 53 95 140) / 0.92), rgb(var(--kv-secondary-rgb, 158 110 87) / 0.95));
    color: #fff;
    overflow: hidden;
    position: relative;
}

.kv-stats__pattern {
    background: radial-gradient(circle at 20% 30%, rgb(255 255 255 / 0.15) 0, transparent 40%),
                radial-gradient(circle at 80% 70%, rgb(255 255 255 / 0.1) 0, transparent 35%);
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.kv-stats__badge {
    align-items: center;
    background: rgb(255 255 255 / 0.15);
    border: 1px solid rgb(255 255 255 / 0.25);
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 700;
    gap: 0.4rem;
    margin-bottom: 0.8rem;
    padding: 0.35rem 0.9rem;
}

.kv-stats__title {
    color: #fff;
    font-family: var(--kv-heading-font), sans-serif;
    font-size: clamp(1.5rem, 3.5vw, 2.5rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin: 0;
}

.kv-stats__highlight {
    color: rgb(255 255 255 / 0.6);
    font-style: italic;
}

.kv-stat-item {
    align-items: center;
    background: rgb(255 255 255 / 0.1);
    backdrop-filter: blur(4px);
    border: 1px solid rgb(255 255 255 / 0.15);
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    padding: 1.5rem 1rem;
    text-align: center;
}

.kv-stat-item__icon {
    font-size: 1.6rem;
    opacity: 0.7;
}

.kv-stat-item__value {
    font-family: var(--kv-heading-font), sans-serif;
    font-size: clamp(1.5rem, 3vw, 2.2rem);
    font-weight: 800;
    letter-spacing: -0.02em;
}

.kv-stat-item__label {
    font-size: 0.78rem;
    font-weight: 600;
    opacity: 0.8;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

/* ========================================
   HOMEPAGE - GALLERY
   ======================================== */

.kv-gallery-bento {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 170px;
    gap: 0.5rem;
}

.kv-gallery-cell {
    display: block;
    position: relative;
    border-radius: 0.75rem;
    overflow: hidden;
}

.kv-gallery-cell--hero {
    grid-column: span 2;
    grid-row: span 2;
}

.kv-gallery-cell img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.kv-gallery-cell:hover img {
    transform: scale(1.06);
}

.kv-gallery-cell__shine {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgb(255 255 255 / 0.12) 0%, transparent 50%);
    z-index: 1;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.35s;
}

.kv-gallery-cell:hover .kv-gallery-cell__shine {
    opacity: 1;
}

.kv-gallery-cell__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgb(0 0 0 / 0.6) 0%, transparent 55%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    padding: 1rem;
    gap: 0.3rem;
    color: #fff;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 2;
}

.kv-gallery-cell:hover .kv-gallery-cell__overlay {
    opacity: 1;
}

.kv-gallery-cell__overlay i {
    font-size: 0.85rem;
    background: rgb(255 255 255 / 0.2);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    width: 30px;
    height: 30px;
    border-radius: 0.4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
}

.kv-gallery-cell__overlay span {
    font-size: 0.78rem;
    font-weight: 600;
    text-shadow: 0 1px 3px rgb(0 0 0 / 0.3);
}

@media (max-width: 767px) {
    .kv-gallery-bento {
        grid-template-columns: repeat(2, 1fr);
        grid-auto-rows: 140px;
    }
}

@media (max-width: 479px) {
    .kv-gallery-bento { grid-auto-rows: 120px; }
    .kv-gallery-cell__overlay { padding: 0.65rem; }
    .kv-gallery-cell__overlay span { font-size: 0.7rem; }
}

/* ========================================
   HOMEPAGE - E-SERVICES
   ======================================== */

.kv-eservices {
    background: linear-gradient(145deg, rgb(var(--kv-secondary-rgb, 158 110 87) / 0.95), rgb(15 23 42 / 0.92));
    color: #fff;
    overflow: hidden;
    position: relative;
}

.kv-eservices__pattern {
    background: radial-gradient(circle at 10% 20%, rgb(var(--kv-primary-rgb, 53 95 140) / 0.2) 0, transparent 40%),
                radial-gradient(circle at 90% 80%, rgb(255 255 255 / 0.08) 0, transparent 30%);
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.kv-eservices__badge {
    background: rgb(255 255 255 / 0.15);
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    margin-bottom: 0.6rem;
    padding: 0.32rem 0.8rem;
    text-transform: uppercase;
}

.kv-eservices__title {
    color: #fff;
    font-family: var(--kv-heading-font), sans-serif;
    font-size: clamp(1.5rem, 3vw, 2.2rem);
    font-weight: 800;
    margin: 0;
}

.kv-eservices__subtitle {
    color: rgb(255 255 255 / 0.75);
    font-size: 0.9rem;
    margin: 0.4rem 0 0;
}

.kv-eservice-card {
    background: rgb(255 255 255 / 0.08);
    backdrop-filter: blur(4px);
    border: 1px solid rgb(255 255 255 / 0.12);
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    padding: 1.5rem 1.2rem;
    position: relative;
    text-decoration: none;
    transition: all 0.3s ease;
}

.kv-eservice-card:hover {
    background: rgb(255 255 255 / 0.14);
    border-color: rgb(255 255 255 / 0.25);
    transform: translateY(-3px);
}

.kv-eservice-card__icon {
    align-items: center;
    background: rgb(255 255 255 / 0.12);
    border-radius: 0.75rem;
    color: #fff;
    display: flex;
    font-size: 1.3rem;
    height: 2.8rem;
    justify-content: center;
    width: 2.8rem;
}

.kv-eservice-card__title {
    color: #fff;
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1rem;
    font-weight: 700;
    margin: 0;
}

.kv-eservice-card__desc {
    color: rgb(255 255 255 / 0.7);
    font-size: 0.82rem;
    line-height: 1.5;
    margin: 0;
}

.kv-eservice-card__arrow {
    color: rgb(255 255 255 / 0.4);
    font-size: 1rem;
    transition: all 0.2s ease;
}

.kv-eservice-card:hover .kv-eservice-card__arrow {
    color: #fff;
    transform: translateX(3px);
}

/* ========================================
   RESPONSIVE - HOMEPAGE
   ======================================== */

@media (min-width: 1024px) {
    .kv-hero-nav {
        display: flex;
    }

    .kv-news-card--featured {
        display: grid;
        grid-template-rows: 1fr auto;
    }

    .kv-news-card--featured .kv-news-card__body {
        padding: 1.2rem 1.4rem 1.4rem;
    }

    .kv-news-card--featured .kv-news-card__title {
        font-size: 1.2rem;
    }
}

@media (max-width: 767px) {
    /* Hero - mobilde daha kısa */
    .kv-hero {
        min-height: 320px;
        max-height: 480px;
    }

    .kv-hero__content {
        padding-bottom: 4.8rem;
        padding-top: 6.8rem;
    }

    .kv-quick-services {
        margin-top: -2.5rem;
    }

    /* Mayor - tek sütun, fotoğraf önce */
    .kv-mayor .grid {
        gap: 2rem;
    }

    .kv-mayor__photo-img {
        aspect-ratio: 3 / 4;
        max-height: 360px;
        width: auto;
        margin: 0 auto;
    }

    .kv-mayor__message {
        font-size: 0.88rem;
        line-height: 1.7;
    }

    .kv-mayor__heading {
        margin-bottom: 0.8rem;
    }

    .kv-mayor__cta {
        font-size: 0.75rem;
        padding: 0.7rem 0.8rem;
    }

    /* CTA - tek sütun stack */
    .kv-cta__title {
        text-align: center;
    }

    .kv-cta__desc {
        text-align: center;
        font-size: 0.85rem;
    }

    .kv-cta-card {
        padding: 0.85rem 1rem;
    }

    .kv-cta-card__icon {
        width: 2.4rem;
        height: 2.4rem;
        font-size: 1rem;
    }

    /* Stats - mobilde sıkıştır */
    .kv-stats .mb-10 {
        margin-bottom: 1.5rem;
    }

    .kv-stat-item__value {
        font-size: 1.3rem;
    }

    /* Gallery */
    .kv-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .kv-gallery-item--large {
        grid-column: span 2;
        grid-row: span 1;
    }

    /* Projects */
    .kv-project-featured {
        min-height: 300px;
    }

    .kv-project-featured__content {
        padding: 1.2rem;
    }

    /* Discover - padding azalt */
    .kv-discover .kv-section__title {
        font-size: 1.3rem;
    }
}

/* ── Extra Small (< 480px) ── */
@media (max-width: 479px) {
    .kv-hero {
        min-height: 280px;
        max-height: 400px;
    }

    .kv-mayor__photo-img {
        max-height: 300px;
    }

    .kv-mayor__cta {
        font-size: 0.7rem;
        padding: 0.6rem 0.7rem;
        gap: 0.4rem;
    }

    .kv-stat-item__value {
        font-size: 1.1rem;
    }

    .kv-cta-card__icon {
        width: 2rem;
        height: 2rem;
        font-size: 0.9rem;
    }

    .kv-cta-card {
        gap: 0.6rem;
        padding: 0.75rem;
    }

    .kv-gallery-grid {
        grid-template-columns: 1fr;
    }

    .kv-gallery-item--large {
        grid-column: span 1;
        grid-row: span 1;
    }
}

/* ========================================
   SHARED - PAGINATION
   ======================================== */

.kv-pagination {
    align-items: center;
    display: flex;
    gap: 0.35rem;
}

.kv-pagination__btn {
    align-items: center;
    background: #fff;
    border: 1px solid rgb(17 24 39 / 0.1);
    border-radius: 0.6rem;
    color: var(--kv-text);
    display: flex;
    font-size: 0.9rem;
    height: 2.4rem;
    justify-content: center;
    text-decoration: none;
    transition: all 0.2s ease;
    width: 2.4rem;
}

.kv-pagination__btn:hover {
    background: linear-gradient(135deg, var(--kv-primary-dark), var(--kv-primary));
    border-color: var(--kv-primary);
    color: #fff;
    transform: translateY(-1px);
}

.kv-pagination__num {
    align-items: center;
    border: 1px solid transparent;
    border-radius: 0.6rem;
    color: var(--kv-text);
    display: flex;
    font-size: 0.84rem;
    font-weight: 600;
    height: 2.4rem;
    justify-content: center;
    min-width: 2.4rem;
    padding: 0 0.5rem;
    text-decoration: none;
    transition: all 0.2s ease;
}

.kv-pagination__num:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.08);
    color: var(--kv-primary);
}

.kv-pagination__num.is-active {
    background: var(--kv-primary);
    color: #fff;
    font-weight: 700;
}

.kv-pagination__dots {
    color: var(--kv-text-muted);
    font-size: 0.84rem;
    padding: 0 0.2rem;
}

/* ========================================
   SHARED - EMPTY STATE
   ======================================== */

.kv-empty-state {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    padding: 4rem 1rem;
    text-align: center;
}

.kv-empty-state i {
    color: var(--kv-text-muted);
    font-size: 3rem;
    opacity: 0.3;
}

.kv-empty-state h4 {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    margin: 0;
}

.kv-empty-state p {
    color: var(--kv-text-muted);
    font-size: 0.88rem;
    margin: 0;
    max-width: 36ch;
}

/* ========================================
   SHARED - ARTICLE (Detail Pages)
   ======================================== */

.kv-article {
    min-width: 0;
}

.kv-article__hero {
    border-radius: 1rem;
    margin-bottom: 1.5rem;
    overflow: hidden;
}

.kv-article__hero img {
    width: 100%;
    height: auto;
    display: block;
}

.kv-article__content.kv-prose {
    color: var(--kv-text);
    font-size: 0.95rem;
    line-height: 1.8;
}

.kv-prose h2,
.kv-prose h3,
.kv-prose h4 {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-weight: 700;
    line-height: 1.3;
    margin: 1.5rem 0 0.6rem;
}

.kv-prose p {
    margin: 0 0 1rem;
}

.kv-prose img {
    border-radius: 0.75rem;
    height: auto;
    max-width: 100%;
}

.kv-prose a {
    color: var(--kv-primary);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.kv-prose ul,
.kv-prose ol {
    margin: 0 0 1rem;
    padding-left: 1.5rem;
}

.kv-prose blockquote {
    border-left: 3px solid var(--kv-primary);
    color: var(--kv-text-muted);
    font-style: italic;
    margin: 1rem 0;
    padding: 0.5rem 0 0.5rem 1rem;
}

.kv-prose table {
    border-collapse: collapse;
    margin: 1rem 0;
    width: 100%;
}

.kv-prose th,
.kv-prose td {
    border: 1px solid rgb(17 24 39 / 0.1);
    padding: 0.5rem 0.75rem;
    text-align: left;
}

.kv-prose th {
    background: rgb(17 24 39 / 0.03);
    font-weight: 700;
}

.kv-article__section-title {
    align-items: center;
    border-bottom: 1px solid rgb(17 24 39 / 0.08);
    color: var(--kv-text);
    display: flex;
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1.05rem;
    font-weight: 700;
    gap: 0.5rem;
    margin: 2rem 0 1rem;
    padding-bottom: 0.6rem;
}

.kv-article__section-title i {
    color: var(--kv-primary);
}

/* ── Gallery Grid ── */
.kv-gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
}

.kv-gallery-item {
    position: relative;
    overflow: hidden;
    border-radius: 0.5rem;
    cursor: pointer;
    display: block;
}

.kv-gallery-item--large {
    grid-column: span 2;
    grid-row: span 2;
}

.kv-gallery-item img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 0.5rem;
    transition: transform 0.4s ease;
}

.kv-gallery-item:hover img {
    transform: scale(1.03);
}

.kv-gallery-item:hover .kv-gallery-item__overlay {
    opacity: 1;
}

/* ========================================
   SHARED - TAGS
   ======================================== */

.kv-article__tags {
    align-items: center;
    border-top: 1px solid rgb(17 24 39 / 0.08);
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-top: 2rem;
    padding-top: 1rem;
}

.kv-article__tags > i {
    color: var(--kv-text-muted);
    margin-right: 0.2rem;
}

.kv-tag {
    background: rgb(var(--kv-secondary-rgb, 158 110 87) / 0.08);
    border-radius: 999px;
    color: var(--kv-secondary);
    font-size: 0.76rem;
    font-weight: 600;
    padding: 0.28rem 0.65rem;
    text-decoration: none;
    transition: all 0.2s ease;
}

.kv-tag:hover {
    background: var(--kv-secondary);
    color: #fff;
}

/* ========================================
   SHARED - LISTEN (Text-to-Speech)
   ======================================== */

.kv-article__listen {
    align-items: center;
    border-top: 1px solid rgb(17 24 39 / 0.08);
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.5rem;
    padding-top: 1rem;
}

.kv-listen-btn {
    align-items: center;
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.08);
    border: 1px solid rgb(var(--kv-primary-rgb, 53 95 140) / 0.2);
    border-radius: 0.7rem;
    color: var(--kv-primary);
    cursor: pointer;
    display: inline-flex;
    font-size: 0.84rem;
    font-weight: 700;
    gap: 0.4rem;
    padding: 0.55rem 1rem;
    transition: all 0.2s ease;
}

.kv-listen-btn:hover {
    background: var(--kv-primary);
    color: #fff;
}

.kv-listen-progress {
    align-items: center;
    display: flex;
    gap: 0.5rem;
}

.kv-listen-progress__bar {
    background: rgb(17 24 39 / 0.08);
    border-radius: 999px;
    height: 0.35rem;
    overflow: hidden;
    width: 8rem;
}

.kv-listen-progress__fill {
    background: var(--kv-primary);
    border-radius: 999px;
    height: 100%;
    transition: width 0.3s ease;
    width: 0%;
}

.kv-listen-progress__time {
    color: var(--kv-text-muted);
    font-size: 0.76rem;
    font-variant-numeric: tabular-nums;
}

.kv-listen-speed {
    align-items: center;
    display: flex;
    gap: 0.3rem;
}

.kv-listen-speed label {
    color: var(--kv-text-muted);
    font-size: 0.78rem;
}

.kv-listen-speed select {
    background: #fff;
    border: 1px solid rgb(17 24 39 / 0.12);
    border-radius: 0.4rem;
    color: var(--kv-text);
    font-size: 0.78rem;
    padding: 0.2rem 0.4rem;
}

/* ========================================
   SHARED - SHARE BUTTONS
   ======================================== */

.kv-article__share {
    align-items: center;
    border-top: 1px solid rgb(17 24 39 / 0.08);
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-top: 1.5rem;
    padding-top: 1rem;
}

.kv-article__share-label {
    color: var(--kv-text);
    font-size: 0.88rem;
    font-weight: 700;
}

.kv-share-buttons {
    display: flex;
    gap: 0.4rem;
}

.kv-share-btn {
    align-items: center;
    border: none;
    border-radius: 0.5rem;
    color: #fff;
    cursor: pointer;
    display: flex;
    font-size: 0.95rem;
    height: 2.2rem;
    justify-content: center;
    text-decoration: none;
    transition: all 0.2s ease;
    width: 2.2rem;
}

.kv-share-btn:hover {
    opacity: 0.85;
    transform: translateY(-2px);
}

.kv-share-btn--facebook { background: #1877f2; }
.kv-share-btn--twitter { background: #0f1419; }
.kv-share-btn--whatsapp { background: #25d366; }
.kv-share-btn--copy { background: rgb(17 24 39 / 0.15); color: var(--kv-text); }
.kv-share-btn--copy:hover { background: var(--kv-secondary); color: #fff; }

/* ========================================
   SHARED - ARTICLE NAV (Prev/Next)
   ======================================== */

.kv-article__nav {
    border-top: 1px solid rgb(17 24 39 / 0.08);
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr 1fr;
    margin-top: 1.5rem;
    padding-top: 1.5rem;
}

.kv-article__nav-link {
    border: 1px solid rgb(17 24 39 / 0.08);
    border-radius: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    padding: 0.8rem 1rem;
    text-decoration: none;
    transition: all 0.2s ease;
}

.kv-article__nav-link:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.04);
    border-color: rgb(var(--kv-primary-rgb, 53 95 140) / 0.2);
}

.kv-article__nav-link--next {
    text-align: right;
}

.kv-article__nav-label {
    color: var(--kv-text-muted);
    font-size: 0.76rem;
    font-weight: 600;
}

.kv-article__nav-title {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 0.88rem;
    font-weight: 700;
    line-height: 1.35;
}

/* ========================================
   SHARED - SIDEBAR
   ======================================== */

.kv-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.kv-sidebar__widget {
    background: #fff;
    border: 1px solid rgb(17 24 39 / 0.06);
    border-radius: 1rem;
    box-shadow: 0 6px 20px rgb(15 23 42 / 0.05);
    overflow: hidden;
    padding: 1.2rem;
}

.kv-sidebar__title {
    border-bottom: 2px solid var(--kv-primary);
    color: var(--kv-text);
    display: inline-block;
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 0.95rem;
    font-weight: 800;
    margin: 0 0 0.8rem;
    padding-bottom: 0.4rem;
}

.kv-sidebar__list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.kv-sidebar-item {
    align-items: center;
    border-radius: 0.6rem;
    color: var(--kv-text);
    display: flex;
    gap: 0.7rem;
    padding: 0.5rem;
    text-decoration: none;
    transition: background 0.2s ease;
}

.kv-sidebar-item:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.04);
}

.kv-sidebar-item__thumb {
    border-radius: 0.5rem;
    flex-shrink: 0;
    height: 3.5rem;
    overflow: hidden;
    width: 3.5rem;
}

.kv-sidebar-item__thumb img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.kv-sidebar-item__body h5 {
    color: var(--kv-text);
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1.35;
    margin: 0;
}

.kv-sidebar-item:hover .kv-sidebar-item__body h5 {
    color: var(--kv-primary);
}

.kv-sidebar-item__date {
    align-items: center;
    color: var(--kv-text-muted);
    display: flex;
    font-size: 0.72rem;
    gap: 0.25rem;
    margin-top: 0.15rem;
}

/* ========================================
   SHARED - SEARCH FORM (Sidebar)
   ======================================== */

.kv-search-form {
    display: flex;
    gap: 0;
}

.kv-search-form__input {
    background: rgb(17 24 39 / 0.03);
    border: 1px solid rgb(17 24 39 / 0.1);
    border-radius: 0.6rem 0 0 0.6rem;
    color: var(--kv-text);
    flex: 1;
    font-size: 0.84rem;
    outline: none;
    padding: 0.55rem 0.75rem;
    transition: border-color 0.2s ease;
}

.kv-search-form__input:focus {
    border-color: var(--kv-primary);
}

.kv-search-form__btn {
    background: var(--kv-primary);
    border: none;
    border-radius: 0 0.6rem 0.6rem 0;
    color: #fff;
    cursor: pointer;
    font-size: 0.9rem;
    padding: 0 0.75rem;
    transition: background 0.2s ease;
}

.kv-search-form__btn:hover {
    background: var(--kv-primary-dark);
}

/* ========================================
   SHARED - SOCIAL GRID (Sidebar)
   ======================================== */

.kv-social-grid {
    display: grid;
    gap: 0.4rem;
    grid-template-columns: repeat(2, 1fr);
}

.kv-social-card {
    align-items: center;
    border-radius: 0.6rem;
    color: #fff;
    display: flex;
    font-size: 0.78rem;
    font-weight: 700;
    gap: 0.4rem;
    justify-content: center;
    padding: 0.55rem 0.5rem;
    text-decoration: none;
    transition: all 0.2s ease;
}

.kv-social-card:hover {
    opacity: 0.85;
    transform: translateY(-1px);
}

.kv-social-card i {
    font-size: 1rem;
}

.kv-social-card--facebook { background: #1877f2; }
.kv-social-card--twitter { background: #0f1419; }
.kv-social-card--instagram { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
.kv-social-card--youtube { background: #ff0000; }

/* ========================================
   SHARED - DETAIL BADGES
   ======================================== */

.kv-detail-badge {
    align-items: center;
    border-radius: 999px;
    display: inline-flex;
    font-size: 0.76rem;
    font-weight: 700;
    gap: 0.3rem;
    padding: 0.3rem 0.7rem;
}

.kv-detail-badge--danger {
    background: rgb(239 68 68 / 0.1);
    color: #dc2626;
}

.kv-detail-badge--warning {
    background: rgb(234 179 8 / 0.12);
    color: #a16207;
}

.kv-detail-badge--muted {
    background: rgb(17 24 39 / 0.06);
    color: var(--kv-text-muted);
}

/* ========================================
   SHARED - ATTACHMENTS
   ======================================== */

.kv-attachment-list {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.kv-attachment {
    align-items: center;
    background: rgb(17 24 39 / 0.02);
    border: 1px solid rgb(17 24 39 / 0.08);
    border-radius: 0.6rem;
    color: var(--kv-text);
    display: flex;
    gap: 0.5rem;
    padding: 0.6rem 0.8rem;
    text-decoration: none;
    transition: all 0.2s ease;
}

.kv-attachment:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.04);
    border-color: rgb(var(--kv-primary-rgb, 53 95 140) / 0.2);
}

.kv-attachment i {
    color: var(--kv-primary);
    font-size: 1.1rem;
}

.kv-attachment__name {
    flex: 1;
    font-size: 0.84rem;
    font-weight: 600;
}

.kv-attachment__size {
    color: var(--kv-text-muted);
    font-size: 0.74rem;
}

/* ========================================
   SHARED - SIDEBAR QUICK LINKS
   ======================================== */

.kv-sidebar-quick-link {
    align-items: center;
    border-radius: 0.5rem;
    color: var(--kv-text);
    display: flex;
    font-size: 0.84rem;
    font-weight: 600;
    gap: 0.5rem;
    padding: 0.55rem 0.6rem;
    text-decoration: none;
    transition: all 0.2s ease;
}

.kv-sidebar-quick-link:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.05);
    color: var(--kv-primary);
}

.kv-sidebar-quick-link i {
    color: var(--kv-primary);
    font-size: 1rem;
    opacity: 0.7;
}

/* ========================================
   ANNOUNCEMENT - CARD EXTRAS
   ======================================== */

.kv-news-card--expired {
    opacity: 0.7;
}

.kv-news-card__meta-row {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-bottom: 0.35rem;
}

.kv-news-card__year {
    color: var(--kv-text-muted);
    font-size: 0.72rem;
    font-weight: 600;
}

.kv-news-card__valid {
    align-items: center;
    color: #a16207;
    display: flex;
    font-size: 0.7rem;
    font-weight: 600;
    gap: 0.2rem;
}

.kv-news-card__valid--expired {
    color: var(--kv-text-muted);
    text-decoration: line-through;
}

/* ========================================
   NEWS LIST - CARD FOOTER
   ======================================== */

.kv-news-card__footer {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-top: 0.6rem;
}

.kv-news-card__views {
    align-items: center;
    color: var(--kv-text-muted);
    display: flex;
    font-size: 0.76rem;
    gap: 0.25rem;
}

.kv-news-card__more {
    align-items: center;
    color: var(--kv-primary);
    display: flex;
    font-size: 0.8rem;
    font-weight: 700;
    gap: 0.25rem;
    text-decoration: none;
    transition: gap 0.2s ease;
}

.kv-news-card__more:hover {
    gap: 0.5rem;
}

/* ========================================
   RESPONSIVE - SHARED COMPONENTS
   ======================================== */

@media (max-width: 767px) {
    .kv-article__nav {
        grid-template-columns: 1fr;
    }

    .kv-article__nav-link--next {
        text-align: left;
    }

    .kv-listen-progress__bar {
        width: 5rem;
    }
}

/* ========================
   Filter Tabs
   ======================== */
.kv-filter-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 0.375rem;
    background: var(--kv-surface);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px rgb(0 0 0 / 0.06);
}

.kv-filter-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.625rem 1.25rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--kv-text-muted);
    text-decoration: none;
    transition: all 0.2s ease;
}

.kv-filter-tab:hover {
    color: var(--kv-primary);
    background: rgb(53 95 140 / 0.06);
}

.kv-filter-tab--active {
    color: var(--kv-text-on-primary);
    background: var(--kv-primary);
    box-shadow: 0 2px 8px rgb(53 95 140 / 0.3);
}

.kv-filter-tab--active:hover {
    color: var(--kv-text-on-primary);
    background: var(--kv-primary-dark);
}

/* ========================
   Event Card
   ======================== */
.kv-event-card {
    display: flex;
    flex-direction: column;
    background: var(--kv-surface);
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 1px 3px rgb(0 0 0 / 0.06);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.kv-event-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgb(0 0 0 / 0.1);
}

.kv-event-card--past {
    opacity: 0.7;
}

.kv-event-card--past:hover {
    opacity: 1;
}

.kv-event-card__media {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
}

.kv-event-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.kv-event-card:hover .kv-event-card__media img {
    transform: scale(1.05);
}

.kv-event-card__date-badge {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0.375rem 0.75rem;
    background: var(--kv-primary);
    color: var(--kv-text-on-primary);
    border-radius: 0.5rem;
    line-height: 1;
    box-shadow: 0 2px 8px rgb(0 0 0 / 0.2);
}

.kv-event-card__day {
    font-size: 1.375rem;
    font-weight: 800;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-event-card__month {
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.kv-event-card__status {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    color: #fff;
}

.kv-event-card__status--ongoing {
    background: #16a34a;
}

.kv-event-card__status--past {
    background: #6b7280;
}

.kv-event-card__body {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 1.25rem;
}

.kv-event-card__title {
    font-size: 1.0625rem;
    font-weight: 700;
    line-height: 1.35;
    margin: 0 0 0.625rem;
}

.kv-event-card__title a {
    color: inherit;
    text-decoration: none;
}

.kv-event-card__title a:hover {
    color: var(--kv-primary);
}

.kv-event-card__meta {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    font-size: 0.8125rem;
    color: var(--kv-text-muted);
    margin-bottom: 0.75rem;
}

.kv-event-card__meta i {
    margin-right: 0.25rem;
    color: var(--kv-primary);
}

.kv-event-card__excerpt {
    font-size: 0.875rem;
    color: var(--kv-text-muted);
    line-height: 1.6;
    margin: 0 0 1rem;
    flex: 1;
}

.kv-event-card__more {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--kv-primary);
    text-decoration: none;
    transition: gap 0.2s ease;
}

.kv-event-card__more:hover {
    gap: 0.625rem;
}

/* ========================
   Event Info Widget (Detail Sidebar)
   ======================== */
.kv-event-info__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.kv-event-info__item {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.875rem 0;
    border-bottom: 1px solid var(--kv-surface-soft);
}

.kv-event-info__item:last-child {
    border-bottom: none;
}

.kv-event-info__item > i {
    flex-shrink: 0;
    width: 2rem;
    height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.5rem;
    background: rgb(53 95 140 / 0.08);
    color: var(--kv-primary);
    font-size: 0.9375rem;
}

.kv-event-info__item > div {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.kv-event-info__item strong {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--kv-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.kv-event-info__item span {
    font-size: 0.875rem;
    color: var(--kv-text);
    font-weight: 500;
}

.kv-event-info__action {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.2s ease;
    margin-top: 0.5rem;
}

.kv-event-info__action--primary {
    background: var(--kv-primary);
    color: var(--kv-text-on-primary);
}

.kv-event-info__action--primary:hover {
    background: var(--kv-primary-dark);
    color: var(--kv-text-on-primary);
    box-shadow: 0 4px 12px rgb(53 95 140 / 0.3);
}

.kv-event-info__action--success {
    background: #16a34a;
    color: #fff;
}

.kv-event-info__action--success:hover {
    background: #15803d;
    color: #fff;
    box-shadow: 0 4px 12px rgb(22 163 74 / 0.3);
}

/* ========================
   Event Mini (Sidebar Upcoming)
   ======================== */
.kv-event-mini {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem;
    border-radius: 0.5rem;
    text-decoration: none;
    color: inherit;
    transition: background 0.2s ease;
}

.kv-event-mini:hover {
    background: var(--kv-surface-soft);
}

.kv-event-mini__date {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 3rem;
    padding: 0.375rem;
    background: rgb(53 95 140 / 0.08);
    border-radius: 0.5rem;
    line-height: 1;
}

.kv-event-mini__day {
    font-size: 1.125rem;
    font-weight: 800;
    color: var(--kv-primary);
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-event-mini__month {
    font-size: 0.625rem;
    font-weight: 600;
    color: var(--kv-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-top: 0.125rem;
}

.kv-event-mini__info {
    flex: 1;
    min-width: 0;
}

.kv-event-mini__info h6 {
    font-size: 0.8125rem;
    font-weight: 600;
    margin: 0;
    line-height: 1.35;
    color: var(--kv-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.kv-event-mini__info small {
    font-size: 0.75rem;
    color: var(--kv-text-muted);
}

.kv-event-mini__info small i {
    font-size: 0.625rem;
    margin-right: 0.125rem;
}

/* ========================
   Detail Badge - Success variant
   ======================== */
.kv-detail-badge--success {
    background: rgb(22 163 74 / 0.1);
    color: #16a34a;
}

.kv-detail-badge--primary {
    background: rgb(53 95 140 / 0.1);
    color: var(--kv-primary);
}

/* ========================
   Responsive - Events
   ======================== */
@media (max-width: 639px) {
    .kv-filter-tabs {
        gap: 0.25rem;
    }

    .kv-filter-tab {
        padding: 0.5rem 0.875rem;
        font-size: 0.8125rem;
    }

    .kv-event-card__body {
        padding: 1rem;
    }

    .kv-event-card__title {
        font-size: 1rem;
    }
}

/* ========================
   Department Card (List)
   ======================== */
.kv-dept-card {
    display: flex;
    flex-direction: column;
    background: var(--kv-surface);
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 1px 3px rgb(0 0 0 / 0.06);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.kv-dept-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgb(0 0 0 / 0.1);
}

.kv-dept-card__header {
    position: relative;
    background: linear-gradient(135deg, var(--kv-primary), var(--kv-secondary));
    min-height: 5rem;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding-bottom: 1.75rem;
}

.kv-dept-card__image {
    position: absolute;
    inset: 0;
    overflow: hidden;
}

.kv-dept-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.3;
}

.kv-dept-card__icon {
    position: relative;
    z-index: 1;
    width: 3.5rem;
    height: 3.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--kv-surface);
    border-radius: 0.75rem;
    box-shadow: 0 4px 12px rgb(0 0 0 / 0.15);
    transform: translateY(50%);
}

.kv-dept-card__icon i {
    font-size: 1.5rem;
    color: var(--kv-primary);
}

.kv-dept-card__body {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 2rem 1.25rem 1.25rem;
}

.kv-dept-card__title {
    font-size: 1.0625rem;
    font-weight: 700;
    text-align: center;
    margin: 0 0 0.5rem;
    line-height: 1.35;
}

.kv-dept-card__desc {
    font-size: 0.875rem;
    color: var(--kv-text-muted);
    line-height: 1.6;
    text-align: center;
    margin: 0 0 0.75rem;
}

.kv-dept-card__contact {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    font-size: 0.8125rem;
    border-top: 1px solid var(--kv-surface-soft);
    padding-top: 0.75rem;
    margin-top: auto;
}

.kv-dept-card__contact li {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.kv-dept-card__contact li i {
    color: var(--kv-primary);
    font-size: 0.875rem;
    flex-shrink: 0;
}

.kv-dept-card__contact li a {
    color: var(--kv-text);
    text-decoration: none;
}

.kv-dept-card__contact li a:hover {
    color: var(--kv-primary);
}

.kv-dept-card__footer {
    padding: 0 1.25rem 1.25rem;
}

.kv-dept-card__link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.625rem 1rem;
    border-radius: 0.5rem;
    background: rgb(53 95 140 / 0.06);
    color: var(--kv-primary);
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.2s ease;
}

.kv-dept-card__link:hover {
    background: var(--kv-primary);
    color: var(--kv-text-on-primary);
}

/* ========================
   Department Manager (Detail)
   ======================== */
.kv-dept-manager {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 1rem 1.25rem;
    background: rgb(53 95 140 / 0.04);
    border-left: 3px solid var(--kv-primary);
    border-radius: 0 0.5rem 0.5rem 0;
    margin-bottom: 1.5rem;
}

.kv-dept-manager__title {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--kv-primary);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.kv-dept-manager__name {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
}

/* ========================
   Article Section (reusable)
   ======================== */
.kv-article__section {
    margin-top: 2.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--kv-surface-soft);
}

/* ========================
   Staff Item (Sidebar)
   ======================== */
.kv-staff-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.625rem 0;
}

.kv-staff-item__photo {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.kv-staff-item__placeholder {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: var(--kv-surface-soft);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--kv-text-muted);
}

.kv-staff-item__info h6 {
    font-size: 0.8125rem;
    font-weight: 600;
    margin: 0;
    line-height: 1.3;
}

.kv-staff-item__info span {
    font-size: 0.75rem;
    color: var(--kv-text-muted);
}

/* ========================
   Album Card (Gallery List)
   ======================== */
.kv-album-card {
    display: block;
    background: var(--kv-surface);
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 1px 3px rgb(0 0 0 / 0.06);
    text-decoration: none;
    color: inherit;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.kv-album-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgb(0 0 0 / 0.1);
}

.kv-album-card__media {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
}

.kv-album-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.kv-album-card:hover .kv-album-card__media img {
    transform: scale(1.08);
}

.kv-album-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgb(0 0 0 / 0.5) 0%, transparent 60%);
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    padding: 1rem;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.kv-album-card:hover .kv-album-card__overlay {
    opacity: 1;
}

.kv-album-card__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.25rem 0.75rem;
    background: rgb(255 255 255 / 0.2);
    backdrop-filter: blur(8px);
    border-radius: 999px;
    color: #fff;
    font-size: 0.8125rem;
    font-weight: 600;
}

.kv-album-card__view {
    width: 2.25rem;
    height: 2.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgb(255 255 255 / 0.2);
    backdrop-filter: blur(8px);
    border-radius: 50%;
    color: #fff;
    font-size: 1rem;
}

.kv-album-card__body {
    padding: 1rem 1.25rem;
}

.kv-album-card__title {
    font-size: 1rem;
    font-weight: 700;
    margin: 0;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.kv-album-card__date {
    font-size: 0.75rem;
    color: var(--kv-text-muted);
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    margin-top: 0.375rem;
}

/* ========================
   Media Grid (Album Detail)
   ======================== */
.kv-media-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
}

@media (min-width: 640px) {
    .kv-media-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1024px) {
    .kv-media-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.kv-media-item {
    position: relative;
    border-radius: 0.5rem;
    overflow: hidden;
    aspect-ratio: 1;
}

.kv-media-item a {
    display: block;
    width: 100%;
    height: 100%;
}

.kv-media-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.kv-media-item:hover img {
    transform: scale(1.05);
}

.kv-media-item__play {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgb(0 0 0 / 0.25);
    transition: background 0.3s ease;
}

.kv-media-item:hover .kv-media-item__play {
    background: rgb(0 0 0 / 0.4);
}

.kv-media-item__play i {
    font-size: 2.5rem;
    color: #fff;
    filter: drop-shadow(0 2px 4px rgb(0 0 0 / 0.3));
}

.kv-gallery-item__overlay,
.kv-media-item__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    background: rgb(0 0 0 / 0.45);
    color: #fff;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 1;
}

.kv-gallery-item:hover .kv-gallery-item__overlay,
.kv-media-item:hover .kv-gallery-item__overlay,
.kv-media-item:hover .kv-media-item__overlay {
    opacity: 1;
}

.kv-gallery-item__overlay i,
.kv-media-item__overlay i {
    font-size: 1.4rem;
}

.kv-gallery-item__overlay span,
.kv-media-item__overlay span {
    font-size: 0.72rem;
    font-weight: 600;
    max-width: 80%;
    text-align: center;
}

/* ========================
   Search Page
   ======================== */
.kv-search-page-form__inner {
    display: flex;
    align-items: center;
    background: var(--kv-surface);
    border-radius: 0.75rem;
    box-shadow: 0 2px 12px rgb(0 0 0 / 0.08);
    overflow: hidden;
    border: 2px solid transparent;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.kv-search-page-form__inner:focus-within {
    border-color: var(--kv-primary);
    box-shadow: 0 4px 20px rgb(53 95 140 / 0.12);
}

.kv-search-page-form__icon {
    padding: 0 0 0 1.25rem;
    font-size: 1.125rem;
    color: var(--kv-text-muted);
    flex-shrink: 0;
}

.kv-search-page-form__input {
    flex: 1;
    padding: 1rem;
    border: none;
    outline: none;
    font-size: 1rem;
    background: transparent;
    color: var(--kv-text);
    font-family: inherit;
}

.kv-search-page-form__input::placeholder {
    color: var(--kv-text-muted);
}

.kv-search-page-form__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.75rem 1.5rem;
    margin: 0.375rem;
    border: none;
    border-radius: 0.5rem;
    background: var(--kv-primary);
    color: var(--kv-text-on-primary);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s ease;
    flex-shrink: 0;
}

.kv-search-page-form__btn:hover {
    background: var(--kv-primary-dark);
}

.kv-search-info {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.875rem 1rem;
    background: var(--kv-surface);
    border: 1px solid var(--kv-surface-soft);
    border-radius: 0.5rem;
    font-size: 0.875rem;
    color: var(--kv-text-muted);
    margin-bottom: 1.5rem;
}

.kv-search-info i {
    color: var(--kv-secondary);
}

.kv-search-results {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.kv-search-result {
    display: flex;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--kv-surface);
    border-bottom: 1px solid var(--kv-surface-soft);
    transition: background 0.2s ease;
}

.kv-search-result:first-child {
    border-radius: 0.75rem 0.75rem 0 0;
}

.kv-search-result:last-child {
    border-bottom: none;
    border-radius: 0 0 0.75rem 0.75rem;
}

.kv-search-result:only-child {
    border-radius: 0.75rem;
}

.kv-search-result:hover {
    background: var(--kv-surface-soft);
}

.kv-search-result__image {
    flex-shrink: 0;
    width: 5rem;
    height: 5rem;
    border-radius: 0.5rem;
    overflow: hidden;
}

.kv-search-result__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.kv-search-result__image--empty {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--kv-surface-soft);
    color: var(--kv-text-muted);
    font-size: 1.5rem;
}

.kv-search-result__content {
    flex: 1;
    min-width: 0;
}

.kv-search-result__type {
    display: inline-block;
    padding: 0.125rem 0.5rem;
    border-radius: 999px;
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 0.375rem;
}

.kv-search-result__type--news { background: rgb(59 130 246 / 0.1); color: #3b82f6; }
.kv-search-result__type--announcement { background: rgb(245 158 11 / 0.1); color: #f59e0b; }
.kv-search-result__type--event { background: rgb(139 92 246 / 0.1); color: #8b5cf6; }
.kv-search-result__type--page { background: rgb(34 197 94 / 0.1); color: #22c55e; }
.kv-search-result__type--project { background: rgb(236 72 153 / 0.1); color: #ec4899; }

.kv-search-result__title {
    font-size: 1rem;
    font-weight: 600;
    margin: 0 0 0.25rem;
    line-height: 1.35;
}

.kv-search-result__title a {
    color: inherit;
    text-decoration: none;
}

.kv-search-result__title a:hover {
    color: var(--kv-primary);
}

.kv-search-result__excerpt {
    font-size: 0.8125rem;
    color: var(--kv-text-muted);
    line-height: 1.6;
    margin: 0 0 0.375rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.kv-search-result__meta {
    font-size: 0.75rem;
    color: var(--kv-text-muted);
}

.kv-search-result__meta i {
    font-size: 0.6875rem;
    margin-right: 0.125rem;
}

/* Search Loading */
.kv-search-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem 1rem;
    color: var(--kv-text-muted);
    font-size: 0.875rem;
}

.kv-search-loading__spinner {
    width: 2rem;
    height: 2rem;
    border: 3px solid var(--kv-surface-soft);
    border-top-color: var(--kv-primary);
    border-radius: 50%;
    animation: kv-spin 0.7s linear infinite;
    margin-bottom: 0.75rem;
}

@keyframes kv-spin {
    to { transform: rotate(360deg); }
}

/* NOTE: .kv-btn--outline consolidated in "Button Sizes & Variants" section */

/* Responsive - Search */
@media (max-width: 639px) {
    .kv-search-page-form__btn span { display: none; }
    .kv-search-result__image { width: 3.5rem; height: 3.5rem; }
    .kv-search-result { padding: 0.875rem; gap: 0.75rem; }
    .kv-search-result__title { font-size: 0.9375rem; }
}

/* ===================================================================
   SHARED COMPONENTS - Alert, Form, Accordion, Badge, Spinner
   =================================================================== */

/* --- Alert --- */
.kv-alert {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    border-radius: 0.75rem;
    font-size: 0.875rem;
    line-height: 1.5;
    border: 1px solid transparent;
    margin-bottom: 1rem;
    animation: kv-alert-in 0.3s ease;
}

@keyframes kv-alert-in {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}

.kv-alert i:first-child { font-size: 1.125rem; flex-shrink: 0; margin-top: 1px; }

.kv-alert--success { background: #ecfdf5; border-color: #a7f3d0; color: #065f46; }
.kv-alert--danger  { background: #fef2f2; border-color: #fecaca; color: #991b1b; }
.kv-alert--warning { background: #fffbeb; border-color: #fde68a; color: #92400e; }
.kv-alert--info    { background: #eff6ff; border-color: #bfdbfe; color: #1e40af; }

.kv-alert__close {
    margin-left: auto;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.25rem;
    opacity: 0.5;
    font-size: 1.25rem;
    line-height: 1;
    color: currentColor;
    transition: opacity 0.2s;
    flex-shrink: 0;
}

.kv-alert__close:hover { opacity: 1; }

/* --- Form --- */
.kv-form__group { margin-bottom: 1rem; }

.kv-form__label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--kv-text);
    margin-bottom: 0.375rem;
}

.kv-form__label .kv-required { color: #ef4444; }

.kv-form__input,
.kv-form__select,
.kv-form__textarea {
    display: block;
    width: 100%;
    padding: 0.625rem 0.875rem;
    font-size: 0.9375rem;
    line-height: 1.5;
    color: var(--kv-text);
    background: var(--kv-surface);
    border: 1.5px solid var(--kv-border, #e2e8f0);
    border-radius: 0.5rem;
    transition: border-color 0.2s, box-shadow 0.2s;
    outline: none;
    font-family: inherit;
}

.kv-form__input:focus,
.kv-form__select:focus,
.kv-form__textarea:focus {
    border-color: var(--kv-primary);
    box-shadow: 0 0 0 3px rgb(var(--kv-primary-rgb) / 0.12);
}

.kv-form__input::placeholder,
.kv-form__textarea::placeholder {
    color: var(--kv-text-muted);
    opacity: 0.7;
}

.kv-form__textarea { resize: vertical; min-height: 120px; }

.kv-form__select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 14px;
    padding-right: 2.5rem;
}

.kv-form__check {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.kv-form__check-input {
    width: 1.125rem;
    height: 1.125rem;
    margin-top: 0.15rem;
    accent-color: var(--kv-primary);
    cursor: pointer;
    flex-shrink: 0;
}

.kv-form__check-label {
    font-size: 0.875rem;
    color: var(--kv-text-muted);
    line-height: 1.4;
}

.kv-form__check-label a {
    color: var(--kv-primary);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.kv-form__feedback {
    display: none;
    font-size: 0.8125rem;
    color: #ef4444;
    margin-top: 0.25rem;
}

.kv-form--validated .kv-form__input:invalid ~ .kv-form__feedback,
.kv-form--validated .kv-form__select:invalid ~ .kv-form__feedback,
.kv-form--validated .kv-form__textarea:invalid ~ .kv-form__feedback,
.kv-form--validated .kv-form__check-input:invalid ~ .kv-form__feedback {
    display: block;
}

.kv-form--validated .kv-form__input:invalid,
.kv-form--validated .kv-form__select:invalid,
.kv-form--validated .kv-form__textarea:invalid {
    border-color: #ef4444;
}

.kv-form--validated .kv-form__input:valid,
.kv-form--validated .kv-form__select:valid,
.kv-form--validated .kv-form__textarea:valid {
    border-color: #22c55e;
}

.kv-form__help {
    font-size: 0.8125rem;
    color: var(--kv-text-muted);
    margin-top: 0.25rem;
}

/* --- Accordion (Alpine.js) --- */
.kv-accordion { display: flex; flex-direction: column; gap: 0.5rem; }

.kv-accordion__item {
    background: var(--kv-surface);
    border: 1px solid var(--kv-border, #e2e8f0);
    border-radius: 0.75rem;
    overflow: hidden;
    transition: box-shadow 0.2s;
}

.kv-accordion__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 1rem 1.25rem;
    background: none;
    border: none;
    text-align: left;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--kv-text);
    cursor: pointer;
    gap: 1rem;
    font-family: inherit;
    transition: color 0.2s;
}

.kv-accordion__trigger:hover { color: var(--kv-primary); }

.kv-accordion__trigger-icon {
    width: 1.5rem;
    height: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--kv-surface-soft);
    font-size: 0.75rem;
    flex-shrink: 0;
    transition: transform 0.3s, background 0.2s;
}

.kv-accordion__trigger[aria-expanded="true"] .kv-accordion__trigger-icon {
    transform: rotate(180deg);
    background: var(--kv-primary);
    color: var(--kv-text-on-primary);
}

.kv-accordion__content {
    padding: 0 1.25rem 1rem;
    font-size: 0.875rem;
    line-height: 1.7;
    color: var(--kv-text-muted);
}

/* --- Badge --- */
.kv-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.25rem 0.625rem;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 999px;
    white-space: nowrap;
    line-height: 1.4;
}

.kv-badge--primary  { background: rgb(var(--kv-primary-rgb) / 0.12); color: var(--kv-primary); }
.kv-badge--success  { background: #ecfdf5; color: #065f46; }
.kv-badge--danger   { background: #fef2f2; color: #991b1b; }
.kv-badge--warning  { background: #fffbeb; color: #92400e; }
.kv-badge--info     { background: #eff6ff; color: #1e40af; }
.kv-badge--secondary { background: var(--kv-surface-soft); color: var(--kv-text-muted); }

.kv-badge--outline {
    background: transparent;
    border: 1px solid currentColor;
    padding: 0.1875rem 0.5625rem;
}

.kv-badge--lg {
    padding: 0.375rem 0.875rem;
    font-size: 0.8125rem;
}

/* --- Spinner --- */
.kv-spinner {
    display: inline-block;
    width: 1.25rem;
    height: 1.25rem;
    border: 2px solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: kv-spin 0.7s linear infinite;
    vertical-align: middle;
}

.kv-spinner--sm { width: 1rem; height: 1rem; border-width: 1.5px; }
.kv-spinner--lg { width: 2rem; height: 2rem; border-width: 3px; }

/* --- Button Sizes & Variants (Consolidated) --- */
.kv-btn {
    align-items: center;
    border: none;
    border-radius: 0.75rem;
    cursor: pointer;
    display: inline-flex;
    font-family: inherit;
    font-size: 0.85rem;
    font-weight: 700;
    gap: 0.5rem;
    justify-content: center;
    line-height: 1.4;
    padding: 0.7rem 1.5rem;
    text-decoration: none;
    white-space: nowrap;
}

.kv-btn--primary {
    background: var(--kv-primary);
    color: var(--kv-text-on-primary);
}

.kv-btn--primary:hover {
    background: linear-gradient(135deg, var(--kv-primary-dark), var(--kv-primary));
    box-shadow: 0 8px 22px rgb(var(--kv-primary-rgb, 53 95 140) / 0.25);
    color: var(--kv-text-on-primary);
    transform: translateY(-2px);
}

.kv-btn--outline {
    background: transparent;
    border: 1.5px solid rgb(var(--kv-primary-rgb, 53 95 140) / 0.3);
    color: var(--kv-primary);
}

.kv-btn--outline:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.06);
    border-color: var(--kv-primary);
    color: var(--kv-primary-dark);
    transform: translateY(-1px);
}

.kv-btn--white {
    background: rgb(255 255 255 / 0.2);
    border: 1px solid rgb(255 255 255 / 0.35);
    color: #fff;
}

.kv-btn--white:hover {
    background: rgb(255 255 255 / 0.35);
    color: #fff;
    transform: translateY(-1px);
}

.kv-btn--accent {
    background: var(--kv-accent);
    color: #fff;
}

.kv-btn--accent:hover {
    background: linear-gradient(135deg, var(--kv-accent-dark), var(--kv-accent));
    box-shadow: 0 8px 22px rgb(var(--kv-accent-rgb, 200 29 37) / 0.3);
    color: #fff;
    transform: translateY(-2px);
}

.kv-btn--warm {
    background: var(--kv-secondary);
    color: #fff;
}

.kv-btn--warm:hover {
    background: var(--kv-secondary-dark);
    box-shadow: 0 6px 18px rgb(var(--kv-secondary-rgb, 158 110 87) / 0.25);
    color: #fff;
    transform: translateY(-2px);
}

.kv-btn--secondary {
    background: var(--kv-surface-soft);
    color: var(--kv-text);
}

.kv-btn--secondary:hover {
    background: var(--kv-border, #e2e8f0);
    color: var(--kv-text);
    transform: translateY(-1px);
}

.kv-btn--ghost {
    background: transparent;
    color: var(--kv-primary);
    padding: 0.5rem 1rem;
}

.kv-btn--ghost:hover {
    background: rgb(var(--kv-primary-rgb, 53 95 140) / 0.06);
    color: var(--kv-primary-dark);
}

.kv-btn--lg { padding: 0.75rem 2rem; font-size: 1rem; }
.kv-btn--sm { padding: 0.375rem 1rem; font-size: 0.8125rem; }
.kv-btn--block { width: 100%; }

.kv-btn:disabled, .kv-btn[disabled] {
    opacity: 0.6;
    pointer-events: none;
}

/* ===================================================================
   MODULE COMPONENTS - Mayor, Profile, Council, Tender, Contact, etc.
   =================================================================== */

/* --- Mayor --- */
.kv-mayor-sidebar {
    position: sticky;
    top: 100px;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.kv-mayor-photo {
    border-radius: 1rem;
    overflow: hidden;
    background: var(--kv-surface);
    box-shadow: 0 4px 20px rgb(0 0 0 / 0.08);
}

.kv-mayor-photo img {
    width: 100%;
    height: auto;
    display: block;
    aspect-ratio: 3/4;
    object-fit: cover;
}

.kv-mayor-photo__info {
    padding: 1rem 1.25rem;
    text-align: center;
}

.kv-mayor-photo__info h4 {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--kv-text);
    margin-bottom: 0.25rem;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-mayor-photo__info span {
    font-size: 0.8125rem;
    color: var(--kv-primary);
    font-weight: 500;
}

.kv-mayor-info-card {
    background: var(--kv-surface);
    border-radius: 0.75rem;
    padding: 1.25rem;
    border: 1px solid var(--kv-border, #e2e8f0);
}

.kv-mayor-info-card h5 {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--kv-text);
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-mayor-info-card h5 i { color: var(--kv-primary); }

.kv-mayor-info-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.kv-mayor-info-list li {
    display: flex;
    justify-content: space-between;
    font-size: 0.8125rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px dashed var(--kv-border, #e2e8f0);
}

.kv-mayor-info-list li:last-child { border-bottom: none; padding-bottom: 0; }

.kv-mayor-info-list .kv-label { color: var(--kv-text-muted); }
.kv-mayor-info-list .kv-value { font-weight: 600; color: var(--kv-text); }

.kv-mayor-social {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.kv-mayor-social a {
    width: 2.5rem;
    height: 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.5rem;
    font-size: 1.125rem;
    color: #fff;
    transition: transform 0.2s, box-shadow 0.2s;
}

.kv-mayor-social a:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgb(0 0 0 / 0.15); }
.kv-mayor-social .kv-social--facebook  { background: #1877F2; }
.kv-mayor-social .kv-social--twitter   { background: #000; }
.kv-mayor-social .kv-social--instagram { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
.kv-mayor-social .kv-social--youtube   { background: #FF0000; }

.kv-mayor-section {
    background: var(--kv-surface);
    border-radius: 0.75rem;
    border: 1px solid var(--kv-border, #e2e8f0);
    overflow: hidden;
    margin-bottom: 1.5rem;
}

.kv-mayor-section__header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--kv-border, #e2e8f0);
    background: var(--kv-surface-soft);
}

.kv-mayor-section__header i {
    font-size: 1.25rem;
    color: var(--kv-primary);
}

.kv-mayor-section__header h3 {
    font-size: 1.0625rem;
    font-weight: 700;
    color: var(--kv-text);
    margin: 0;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-mayor-section__body {
    padding: 1.25rem;
    font-size: 0.9375rem;
    line-height: 1.8;
    color: var(--kv-text);
}

.kv-mayor-section__body img { max-width: 100%; height: auto; border-radius: 0.5rem; }

/* Mayor Vision */
.kv-mayor-vision {
    background: linear-gradient(135deg, rgb(var(--kv-primary-rgb) / 0.03), rgb(var(--kv-secondary-rgb, 158 110 87) / 0.05));
    border-radius: 1.25rem;
    padding: 2.5rem;
}

.kv-mayor-vision__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.375rem 1rem;
    background: rgb(var(--kv-primary-rgb) / 0.1);
    color: var(--kv-primary);
    border-radius: 999px;
    font-size: 0.8125rem;
    font-weight: 600;
    margin-bottom: 1rem;
}

.kv-mayor-vision__title {
    font-size: 2rem;
    font-weight: 800;
    color: var(--kv-text);
    line-height: 1.2;
    margin-bottom: 0.75rem;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-mayor-vision__title span { color: var(--kv-primary); }

.kv-mayor-vision__desc {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--kv-text-muted);
    max-width: 55ch;
}

/* Vision Cards */
.kv-vision-card {
    background: var(--kv-surface);
    border: 1px solid var(--kv-border);
    border-radius: 1rem;
    padding: 1.5rem;
    text-align: center;
    transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
}

.kv-vision-card:hover {
    border-color: rgb(var(--kv-primary-rgb) / 0.3);
    box-shadow: 0 8px 28px rgb(var(--kv-primary-rgb) / 0.07);
    transform: translateY(-3px);
}

.kv-vision-card__icon {
    width: 3rem;
    height: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.75rem;
    font-size: 1.25rem;
    margin: 0 auto 0.75rem;
}

.kv-vision-card__icon--green { background: #ecfdf5; color: #059669; }
.kv-vision-card__icon--blue { background: #eff6ff; color: #2563eb; }
.kv-vision-card__icon--amber { background: #fffbeb; color: #d97706; }
.kv-vision-card__icon--rose { background: #fff1f2; color: #e11d48; }

.kv-vision-card__title {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--kv-text);
    margin-bottom: 0.5rem;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-vision-card__text {
    font-size: 0.8125rem;
    line-height: 1.6;
    color: var(--kv-text-muted);
}

/* --- Profile Card --- */
.kv-profile-card {
    background: var(--kv-surface);
    border-radius: 0.75rem;
    border: 1px solid var(--kv-border, #e2e8f0);
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.2s;
    text-decoration: none;
    display: block;
}

.kv-profile-card:hover {
    box-shadow: 0 8px 24px rgb(0 0 0 / 0.08);
    transform: translateY(-2px);
}

.kv-profile-card__image {
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--kv-surface-soft);
}

.kv-profile-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s;
}

.kv-profile-card:hover .kv-profile-card__image img { transform: scale(1.05); }

.kv-profile-card__image--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    color: var(--kv-text-muted);
    opacity: 0.3;
}

.kv-profile-card__body {
    padding: 1rem 1.25rem;
    text-align: center;
}

.kv-profile-card__name {
    font-size: 1rem;
    font-weight: 700;
    color: var(--kv-text);
    margin-bottom: 0.25rem;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-profile-card__title {
    font-size: 0.8125rem;
    color: var(--kv-primary);
    font-weight: 500;
}

.kv-profile-card__contact {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--kv-border, #e2e8f0);
    font-size: 0.8125rem;
}

.kv-profile-card__contact a {
    color: var(--kv-text-muted);
    transition: color 0.2s;
}

.kv-profile-card__contact a:hover { color: var(--kv-primary); }

/* --- Council Card --- */
.kv-council-card {
    background: var(--kv-surface);
    border-radius: 0.75rem;
    border: 1px solid var(--kv-border, #e2e8f0);
    padding: 1.25rem;
    transition: box-shadow 0.2s;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.kv-council-card:hover {
    box-shadow: 0 4px 16px rgb(0 0 0 / 0.06);
}

.kv-council-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.kv-council-card__number {
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--kv-primary);
}

.kv-council-card__date {
    font-size: 0.75rem;
    color: var(--kv-text-muted);
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.kv-council-card__title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--kv-text);
    line-height: 1.4;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-council-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--kv-border, #e2e8f0);
}

.kv-council-card__pdf {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: #dc2626;
    text-decoration: none;
    transition: opacity 0.2s;
}

.kv-council-card__pdf:hover { opacity: 0.7; }

/* Council Year Navigation */
.kv-council-years {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
}

.kv-council-year {
    padding: 0.375rem 0.875rem;
    border-radius: 999px;
    font-size: 0.8125rem;
    font-weight: 600;
    text-decoration: none;
    color: var(--kv-text-muted);
    background: var(--kv-surface-soft);
    transition: all 0.2s;
}

.kv-council-year:hover { color: var(--kv-primary); background: rgb(var(--kv-primary-rgb) / 0.08); }
.kv-council-year--active { background: var(--kv-primary); color: var(--kv-text-on-primary); }

/* --- Council Filter --- */
.kv-council-select {
    width: 100%;
    padding: 0.625rem 0.875rem;
    border: 1px solid var(--kv-border, #e2e8f0);
    border-radius: 0.5rem;
    font-size: 0.875rem;
    color: var(--kv-text);
    background: #fff;
    outline: none;
    transition: border-color 0.2s;
    appearance: auto;
}
.kv-council-select:focus {
    border-color: var(--kv-primary);
    box-shadow: 0 0 0 2px rgb(var(--kv-primary-rgb) / 0.12);
}

.kv-council-filter-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.625rem 1.5rem;
    background: var(--kv-primary-light, #537294);
    color: #fff;
    font-size: 0.875rem;
    font-weight: 600;
    border: none;
    border-radius: 0.5rem;
    cursor: pointer;
    transition: background 0.2s;
    white-space: nowrap;
}
.kv-council-filter-btn:hover { background: var(--kv-primary); }

/* --- Council Accordion --- */
.kv-council-accordion {
    border: 1px solid var(--kv-border, #e2e8f0);
    border-radius: 0.75rem;
    overflow: hidden;
    background: var(--kv-surface);
}

.kv-council-accordion__item {
    border-bottom: 1px solid var(--kv-border, #e2e8f0);
}
.kv-council-accordion__item:last-child { border-bottom: none; }

.kv-council-accordion__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 1rem 1.25rem;
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
    font-size: 0.875rem;
    color: var(--kv-text);
    gap: 0.75rem;
    transition: background 0.15s;
}
.kv-council-accordion__trigger:hover {
    background: var(--kv-surface-soft, #f8fafc);
}
.kv-council-accordion__trigger--active {
    background: var(--kv-surface-soft, #f8fafc);
    border-bottom: 1px solid var(--kv-border, #e2e8f0);
}

.kv-council-accordion__title {
    font-weight: 500;
    line-height: 1.4;
    flex: 1;
    min-width: 0;
}

.kv-council-accordion__icon {
    flex-shrink: 0;
    font-size: 1rem;
    color: var(--kv-text-muted);
    transition: transform 0.25s ease;
}

.kv-council-accordion__body {
    padding: 1.25rem;
    background: #fff;
}

/* Council Type Badges */
.kv-council-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.625rem;
    border-radius: 999px;
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    white-space: nowrap;
    flex-shrink: 0;
}
.kv-council-badge--agenda {
    background: #fef3c7;
    color: #92400e;
}
.kv-council-badge--decision {
    background: #e0f2fe;
    color: #0369a1;
}

/* --- Tender Card --- */
.kv-tender-card {
    background: var(--kv-surface);
    border-radius: 0.75rem;
    border: 1px solid var(--kv-border, #e2e8f0);
    padding: 1.25rem;
    transition: box-shadow 0.2s, border-color 0.2s;
    display: block;
    text-decoration: none;
    color: inherit;
}

.kv-tender-card:hover {
    box-shadow: 0 6px 20px rgb(0 0 0 / 0.07);
    border-color: var(--kv-primary);
}

.kv-tender-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.kv-tender-card__title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--kv-text);
    line-height: 1.4;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-tender-card__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
    margin-bottom: 0.75rem;
}

.kv-tender-card__dates {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    font-size: 0.8125rem;
    color: var(--kv-text-muted);
    padding-top: 0.75rem;
    border-top: 1px solid var(--kv-border, #e2e8f0);
}

.kv-tender-card__dates span {
    display: flex;
    align-items: center;
    gap: 0.375rem;
}

.kv-tender-card__dates i { color: var(--kv-primary); }

/* Tender Info (Detail Page) */
.kv-tender-info {
    background: var(--kv-surface);
    border-radius: 0.75rem;
    border: 1px solid var(--kv-border, #e2e8f0);
    overflow: hidden;
}

.kv-tender-info__title {
    padding: 1rem 1.25rem;
    font-size: 0.9375rem;
    font-weight: 700;
    background: var(--kv-surface-soft);
    border-bottom: 1px solid var(--kv-border, #e2e8f0);
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-tender-info__title i { color: var(--kv-primary); }

.kv-tender-info__list {
    padding: 0;
    margin: 0;
    list-style: none;
}

.kv-tender-info__item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding: 0.75rem 1.25rem;
    font-size: 0.875rem;
    border-bottom: 1px solid var(--kv-border, #e2e8f0);
}

.kv-tender-info__item:last-child { border-bottom: none; }
.kv-tender-info__item .kv-label { color: var(--kv-text-muted); white-space: nowrap; }
.kv-tender-info__item .kv-value { font-weight: 600; color: var(--kv-text); text-align: right; }

/* --- Contact Card --- */
.kv-contact-card {
    background: var(--kv-surface);
    border-radius: 0.75rem;
    border: 1px solid var(--kv-border, #e2e8f0);
    padding: 1.5rem;
    text-align: center;
    transition: box-shadow 0.2s, transform 0.2s;
    height: 100%;
}

.kv-contact-card:hover {
    box-shadow: 0 8px 24px rgb(0 0 0 / 0.08);
    transform: translateY(-2px);
}

.kv-contact-card__icon {
    width: 3.5rem;
    height: 3.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 1rem;
    font-size: 1.5rem;
    color: var(--kv-primary);
    background: rgb(var(--kv-primary-rgb) / 0.1);
    margin: 0 auto 1rem;
}

.kv-contact-card h4 {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-contact-card p {
    font-size: 0.875rem;
    color: var(--kv-text-muted);
    margin-bottom: 0.25rem;
    line-height: 1.6;
}

.kv-contact-card a { color: var(--kv-primary); text-decoration: none; }
.kv-contact-card a:hover { text-decoration: underline; }

/* Contact Map */
.kv-contact-map {
    border-radius: 0.75rem;
    overflow: hidden;
    box-shadow: 0 4px 16px rgb(0 0 0 / 0.08);
    background: var(--kv-surface-soft);
}

.kv-contact-map iframe { display: block; width: 100%; height: 400px; border: 0; }

.kv-contact-map__placeholder {
    height: 400px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 0.5rem;
    color: var(--kv-text-muted);
}

.kv-contact-map__placeholder i { font-size: 2.5rem; opacity: 0.4; }

/* Contact Hours */
.kv-contact-hours {
    background: var(--kv-surface);
    border-radius: 0.75rem;
    padding: 1.25rem;
    border: 1px solid var(--kv-border, #e2e8f0);
}

.kv-contact-hours h5 {
    font-size: 0.9375rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-contact-hours h5 i { color: var(--kv-primary); }

.kv-contact-hours table { width: 100%; border-collapse: collapse; }

.kv-contact-hours td {
    padding: 0.5rem 0;
    font-size: 0.875rem;
    border-bottom: 1px dashed var(--kv-border, #e2e8f0);
}

.kv-contact-hours tr:last-child td { border-bottom: none; }
.kv-contact-hours td:last-child { text-align: right; font-weight: 600; }

/* Contact Department Card */
.kv-dept-contact-card {
    background: var(--kv-surface);
    border-radius: 0.75rem;
    border: 1px solid var(--kv-border, #e2e8f0);
    padding: 1.25rem;
    transition: box-shadow 0.2s;
}

.kv-dept-contact-card:hover { box-shadow: 0 4px 12px rgb(0 0 0 / 0.06); }

.kv-dept-contact-card h5 {
    font-size: 0.9375rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-dept-contact-card p {
    font-size: 0.8125rem;
    color: var(--kv-text-muted);
    margin-bottom: 0.375rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.kv-dept-contact-card p i { color: var(--kv-primary); width: 1rem; text-align: center; }
.kv-dept-contact-card a { color: var(--kv-text-muted); text-decoration: none; }
.kv-dept-contact-card a:hover { color: var(--kv-primary); }

/* Contact Social */
.kv-contact-social {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.kv-contact-social a {
    width: 2.75rem;
    height: 2.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.625rem;
    font-size: 1.25rem;
    color: #fff;
    transition: transform 0.2s, box-shadow 0.2s;
}

.kv-contact-social a:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgb(0 0 0 / 0.2); }
.kv-contact-social .kv-social--facebook  { background: #1877F2; }
.kv-contact-social .kv-social--twitter   { background: #000; }
.kv-contact-social .kv-social--instagram { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
.kv-contact-social .kv-social--youtube   { background: #FF0000; }

/* --- Sitemap --- */
.kv-sitemap-card {
    background: var(--kv-surface);
    border-radius: 0.75rem;
    border: 1px solid var(--kv-border, #e2e8f0);
    overflow: hidden;
    height: 100%;
}

.kv-sitemap-card__header {
    padding: 1rem 1.25rem;
    background: var(--kv-surface-soft);
    border-bottom: 1px solid var(--kv-border, #e2e8f0);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.kv-sitemap-card__header i {
    font-size: 1.125rem;
    color: var(--kv-primary);
}

.kv-sitemap-card__header h4 {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--kv-text);
    margin: 0;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-sitemap-list {
    list-style: none;
    padding: 0.75rem 0;
    margin: 0;
}

.kv-sitemap-list li { padding: 0; }

.kv-sitemap-list a {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1.25rem;
    font-size: 0.875rem;
    color: var(--kv-text-muted);
    text-decoration: none;
    transition: all 0.2s;
}

.kv-sitemap-list a:hover {
    color: var(--kv-primary);
    background: rgb(var(--kv-primary-rgb) / 0.04);
}

.kv-sitemap-list a i { font-size: 0.625rem; opacity: 0.5; }

/* --- Info Widget (reusable sidebar widget) --- */
.kv-info-widget {
    background: var(--kv-surface);
    border-radius: 0.75rem;
    border: 1px solid var(--kv-border, #e2e8f0);
    padding: 1.25rem;
}

.kv-info-widget__title {
    font-size: 0.9375rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--kv-heading-font), sans-serif;
}

.kv-info-widget__title i { color: var(--kv-primary); }

.kv-info-widget__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.kv-info-widget__list li {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.8125rem;
    color: var(--kv-text-muted);
    line-height: 1.4;
}

.kv-info-widget__list li i { color: #22c55e; margin-top: 2px; flex-shrink: 0; }

.kv-info-widget__list a {
    color: var(--kv-text-muted);
    text-decoration: none;
}

.kv-info-widget__list a:hover { color: var(--kv-primary); }

/* --- Prose (rich content from WYSIWYG) --- */
.kv-prose { font-size: 0.9375rem; line-height: 1.8; color: var(--kv-text); }
.kv-prose h1, .kv-prose h2, .kv-prose h3, .kv-prose h4, .kv-prose h5, .kv-prose h6 {
    font-family: var(--kv-heading-font), sans-serif;
    font-weight: 700;
    color: var(--kv-text);
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
}
.kv-prose h2 { font-size: 1.375rem; }
.kv-prose h3 { font-size: 1.25rem; }
.kv-prose h4 { font-size: 1.125rem; }
.kv-prose p { margin-bottom: 1rem; }
.kv-prose ul, .kv-prose ol { padding-left: 1.5rem; margin-bottom: 1rem; }
.kv-prose li { margin-bottom: 0.375rem; }
.kv-prose img { max-width: 100%; height: auto; border-radius: 0.5rem; margin: 1rem 0; }
.kv-prose a { color: var(--kv-primary); text-decoration: underline; text-underline-offset: 2px; }
.kv-prose blockquote {
    border-left: 4px solid var(--kv-primary);
    padding: 0.75rem 1.25rem;
    margin: 1rem 0;
    background: var(--kv-surface-soft);
    border-radius: 0 0.5rem 0.5rem 0;
    font-style: italic;
    color: var(--kv-text-muted);
}
.kv-prose table { width: 100%; border-collapse: collapse; margin: 1rem 0; }
.kv-prose th, .kv-prose td {
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--kv-border, #e2e8f0);
    font-size: 0.875rem;
}
.kv-prose th { background: var(--kv-surface-soft); font-weight: 600; }

/* ===================================================================
   RESPONSIVE - Module Components
   =================================================================== */

@media (max-width: 1023px) {
    .kv-mayor-sidebar { position: static; }
    .kv-mayor-vision { padding: 1.5rem; }
    .kv-mayor-vision__title { font-size: 1.5rem; }
    .kv-vision-card { padding: 1.25rem; }
}

@media (max-width: 639px) {
    .kv-contact-card { padding: 1.25rem; }
    .kv-council-card__header { flex-direction: column; align-items: flex-start; }
    .kv-council-accordion__trigger { padding: 0.75rem 1rem; font-size: 0.8125rem; }
    .kv-council-accordion__title { font-size: 0.8125rem; }
    .kv-council-badge { font-size: 0.6rem; padding: 0.15rem 0.5rem; }
    .kv-council-accordion__body { padding: 1rem; }
    .kv-tender-card__dates { flex-direction: column; gap: 0.5rem; }
    .kv-tender-info__item { flex-direction: column; gap: 0.25rem; }
    .kv-tender-info__item .kv-value { text-align: left; }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* ========================================
   ATATÜRK KÖŞESİ
   Editorial Magazine Estetiği
   ======================================== */
:root {
    --ata-white: #ffffff;
    --ata-off-white: #fafafa;
    --ata-light-gray: #f5f5f5;
    --ata-border: #e8e8e8;
    --ata-text: #1a1a1a;
    --ata-text-light: #666666;
    --ata-text-muted: #999999;
    --ata-accent: #c41e3a;
    --ata-font-display: Georgia, "Times New Roman", serif;
    --ata-font-body: var(--kv-body-font), -apple-system, BlinkMacSystemFont, sans-serif;
}

.kv-ataturk-hero {
    min-height: 100vh;
    background: var(--ata-white);
    display: flex;
    align-items: center;
    position: relative;
    padding: 120px 0 80px;
}
.kv-ataturk-hero__layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
}
.kv-ataturk-hero__image {
    display: flex;
    justify-content: center;
    align-items: center;
}
.kv-ataturk-hero__portrait {
    max-width: 100%;
    max-height: 70vh;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: grayscale(30%) contrast(1.05);
    box-shadow: 0 30px 80px rgba(0,0,0,0.15);
}
.kv-ataturk-hero__placeholder {
    width: 100%;
    max-width: 400px;
    aspect-ratio: 3/4;
    background: var(--ata-light-gray);
    border: 2px dashed var(--ata-border);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 15px;
    color: var(--ata-text-muted);
}
.kv-ataturk-hero__placeholder i { font-size: 4rem; opacity: 0.3; }
.kv-ataturk-hero__placeholder span { font-size: 0.875rem; }
.kv-ataturk-hero__text { padding: 40px 0; }
.kv-ataturk-hero__line {
    width: 1px;
    height: 60px;
    background: var(--ata-accent);
    margin-bottom: 30px;
}
.kv-ataturk-hero__date {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.3em;
    color: var(--ata-text-muted);
    margin-bottom: 20px;
    text-transform: uppercase;
}
.kv-ataturk-hero__name {
    font-family: var(--ata-font-display);
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    font-weight: 400;
    line-height: 1.1;
    color: var(--ata-text);
    margin: 0 0 20px;
    letter-spacing: -0.02em;
}
.kv-ataturk-hero__name span { font-weight: 700; font-style: italic; }
.kv-ataturk-hero__desc {
    font-size: 1rem;
    font-weight: 300;
    color: var(--ata-text-light);
    letter-spacing: 0.1em;
    margin-bottom: 30px;
}
.kv-ataturk-hero__quote {
    font-family: var(--ata-font-display);
    font-size: 1.25rem;
    font-style: italic;
    color: var(--ata-text);
    margin: 0;
    padding-left: 20px;
    border-left: 2px solid var(--ata-accent);
}
.kv-ataturk-scroll {
    position: absolute;
    bottom: 40px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    color: var(--ata-text-muted);
    text-decoration: none;
    font-size: 0.75rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    transition: color 0.3s;
}
.kv-ataturk-scroll:hover { color: var(--ata-accent); }
.kv-ataturk-scroll i { font-size: 1.25rem; animation: kv-scroll-bounce 2s infinite; }
@keyframes kv-scroll-bounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(8px); }
}

/* Section Base */
.kv-ataturk-section {
    background: var(--ata-white);
    padding: 100px 0;
    border-bottom: 1px solid var(--ata-border);
}
.kv-ataturk-section--alt { background: var(--ata-off-white); border-bottom: none; }
.kv-ataturk-intro { text-align: center; margin-bottom: 80px; }
.kv-ataturk-intro__num {
    display: block;
    font-family: var(--ata-font-display);
    font-size: 0.875rem;
    color: var(--ata-accent);
    letter-spacing: 0.2em;
    margin-bottom: 20px;
}
.kv-ataturk-intro h2 {
    font-family: var(--ata-font-display);
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    font-weight: 400;
    color: var(--ata-text);
    margin: 0 0 15px;
}
.kv-ataturk-intro p {
    font-size: 1rem;
    font-weight: 300;
    color: var(--ata-text-light);
    max-width: 500px;
    margin: 0 auto;
}

/* Timeline */
.kv-ataturk-timeline { max-width: 800px; margin: 0 auto; position: relative; }
.kv-ataturk-timeline::before {
    content: '';
    position: absolute;
    left: 80px;
    top: 0;
    bottom: 0;
    width: 1px;
    background: var(--ata-border);
}
.kv-ataturk-timeline__entry { display: flex; gap: 40px; padding: 30px 0; position: relative; }
.kv-ataturk-timeline__entry::after {
    content: '';
    position: absolute;
    left: 76px;
    top: 38px;
    width: 9px;
    height: 9px;
    background: var(--ata-white);
    border: 2px solid var(--ata-accent);
    border-radius: 50%;
}
.kv-ataturk-timeline__year {
    flex-shrink: 0;
    width: 60px;
    text-align: right;
    font-family: var(--ata-font-display);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--ata-text);
}
.kv-ataturk-timeline__body { flex: 1; padding-left: 20px; }
.kv-ataturk-timeline__body h3 {
    font-family: var(--ata-font-display);
    font-size: 1.5rem;
    font-weight: 500;
    color: var(--ata-text);
    margin: 0 0 10px;
}
.kv-ataturk-timeline__body p {
    font-size: 1rem;
    font-weight: 300;
    line-height: 1.8;
    color: var(--ata-text-light);
    margin: 0;
}

/* Principles */
.kv-ataturk-principles {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 50px 40px;
    max-width: 1000px;
    margin: 0 auto;
}
.kv-ataturk-principle {
    text-align: center;
    padding: 40px 20px;
    border: 1px solid transparent;
    transition: border-color 0.3s;
}
.kv-ataturk-principle:hover { border-color: var(--ata-border); }
.kv-ataturk-principle__num {
    font-family: var(--ata-font-display);
    font-size: 2.5rem;
    font-weight: 300;
    color: var(--ata-accent);
    margin-bottom: 20px;
    opacity: 0.6;
}
.kv-ataturk-principle h3 {
    font-family: var(--ata-font-display);
    font-size: 1.5rem;
    font-weight: 500;
    color: var(--ata-text);
    margin: 0 0 15px;
}
.kv-ataturk-principle p {
    font-size: 0.9375rem;
    font-weight: 300;
    line-height: 1.7;
    color: var(--ata-text-light);
    margin: 0;
}

/* Quotes */
.kv-ataturk-quotes {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
    max-width: 1000px;
    margin: 0 auto;
}
.kv-ataturk-quote {
    padding: 40px;
    border-left: 2px solid var(--ata-accent);
    background: var(--ata-off-white);
    margin: 0;
    transition: background 0.3s;
}
.kv-ataturk-quote:hover { background: var(--ata-light-gray); }
.kv-ataturk-quote p {
    font-family: var(--ata-font-display);
    font-size: 1.375rem;
    font-style: italic;
    line-height: 1.6;
    color: var(--ata-text);
    margin: 0 0 20px;
}
.kv-ataturk-quote cite {
    font-size: 0.8125rem;
    font-weight: 500;
    font-style: normal;
    color: var(--ata-accent);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

/* World Leaders */
.kv-ataturk-world-quotes {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    max-width: 1000px;
    margin: 0 auto;
}
.kv-ataturk-world-quote {
    padding: 40px;
    border: 1px solid var(--ata-border);
    background: var(--ata-white);
    transition: box-shadow 0.3s;
}
.kv-ataturk-world-quote:hover { box-shadow: 0 10px 40px rgba(0,0,0,0.06); }
.kv-ataturk-world-quote blockquote { margin: 0 0 25px; }
.kv-ataturk-world-quote blockquote p {
    font-family: var(--ata-font-display);
    font-size: 1.125rem;
    font-style: italic;
    line-height: 1.7;
    color: var(--ata-text);
    margin: 0;
}
.kv-ataturk-world-quote footer {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding-top: 20px;
    border-top: 1px solid var(--ata-border);
}
.kv-ataturk-world-quote footer strong { font-size: 0.9375rem; font-weight: 600; color: var(--ata-text); }
.kv-ataturk-world-quote footer span { font-size: 0.8125rem; color: var(--ata-text-muted); }

/* Speech */
.kv-ataturk-speech {
    max-width: 800px;
    margin: 0 auto;
    background: var(--ata-white);
    padding: 60px;
    border: 1px solid var(--ata-border);
}
.kv-ataturk-speech__opening {
    text-align: center;
    margin-bottom: 40px;
    padding-bottom: 40px;
    border-bottom: 1px solid var(--ata-border);
    font-family: var(--ata-font-display);
    font-size: 2rem;
    font-weight: 500;
    color: var(--ata-text);
}
.kv-ataturk-speech__body p {
    font-size: 1.0625rem;
    font-weight: 300;
    line-height: 2;
    color: var(--ata-text);
    margin: 0 0 25px;
    text-align: justify;
}
.kv-ataturk-speech__highlight {
    background: var(--ata-off-white);
    padding: 40px;
    margin: 40px 0;
    border-left: 3px solid var(--ata-accent);
}
.kv-ataturk-speech__highlight p {
    font-family: var(--ata-font-display);
    font-size: 1.25rem;
    line-height: 1.8;
    color: var(--ata-text);
    margin: 0 0 15px;
    text-align: left;
}
.kv-ataturk-speech__highlight p:last-child { margin: 0; }
.kv-ataturk-speech__highlight .kv-power-quote {
    font-size: 1.5rem;
    font-weight: 600;
    font-style: italic;
    color: var(--ata-accent);
}
.kv-ataturk-speech__footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 40px;
    border-top: 1px solid var(--ata-border);
    margin-top: 40px;
}
.kv-ataturk-speech__author { font-family: var(--ata-font-display); font-size: 1.125rem; font-weight: 500; font-style: italic; color: var(--ata-text); }
.kv-ataturk-speech__date { font-size: 0.875rem; color: var(--ata-text-muted); }

/* Gallery */
.kv-ataturk-gallery {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    max-width: 1100px;
    margin: 0 auto;
}
.kv-ataturk-gallery__item { margin: 0; overflow: hidden; background: var(--ata-light-gray); }
.kv-ataturk-gallery__img {
    width: 100%;
    height: 320px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--ata-off-white);
    overflow: hidden;
}
.kv-ataturk-gallery__img img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: grayscale(100%);
    transition: all 0.5s;
}
.kv-ataturk-gallery__item:hover img { filter: grayscale(0%); transform: scale(1.03); }
.kv-ataturk-gallery__placeholder {
    width: 100%;
    height: 320px;
    background: var(--ata-light-gray);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: var(--ata-text-muted);
}
.kv-ataturk-gallery__placeholder i { font-size: 3rem; opacity: 0.4; }
.kv-ataturk-gallery__placeholder span { font-size: 0.75rem; }
.kv-ataturk-gallery__item figcaption {
    font-size: 0.875rem;
    color: var(--ata-text-light);
    padding: 15px;
    text-align: center;
    background: var(--ata-white);
    border-top: 1px solid var(--ata-border);
}

/* Memorial */
.kv-ataturk-memorial {
    background: var(--ata-text);
    padding: 100px 0;
}
.kv-ataturk-memorial__inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 80px;
    max-width: 1000px;
    margin: 0 auto;
}
.kv-ataturk-memorial__date { text-align: center; padding: 40px; border: 1px solid rgba(255,255,255,0.2); }
.kv-ataturk-memorial__day { display: block; font-family: var(--ata-font-display); font-size: 5rem; font-weight: 300; color: var(--ata-white); line-height: 1; }
.kv-ataturk-memorial__month { display: block; font-size: 1rem; font-weight: 500; letter-spacing: 0.3em; text-transform: uppercase; color: rgba(255,255,255,0.7); margin: 10px 0; }
.kv-ataturk-memorial__year { display: block; font-family: var(--ata-font-display); font-size: 1.5rem; font-weight: 300; color: rgba(255,255,255,0.5); }
.kv-ataturk-memorial__time { display: block; font-size: 0.875rem; color: var(--ata-accent); margin-top: 15px; letter-spacing: 0.2em; }
.kv-ataturk-memorial__text { max-width: 500px; }
.kv-ataturk-memorial__text blockquote {
    font-family: var(--ata-font-display);
    font-size: 1.5rem;
    font-style: italic;
    line-height: 1.7;
    color: var(--ata-white);
    margin: 0 0 25px;
    padding-left: 25px;
    border-left: 2px solid var(--ata-accent);
}
.kv-ataturk-memorial__note { font-size: 1rem; font-weight: 300; line-height: 1.8; color: rgba(255,255,255,0.6); margin: 0; }

/* Atatürk Responsive */
@media (max-width: 991px) {
    .kv-ataturk-hero__layout { grid-template-columns: 1fr; gap: 40px; text-align: center; }
    .kv-ataturk-hero__image { order: -1; }
    .kv-ataturk-hero__portrait { max-height: 50vh; }
    .kv-ataturk-hero__text { padding: 0; }
    .kv-ataturk-hero__line { margin: 0 auto 30px; }
    .kv-ataturk-hero__quote { border-left: none; border-top: 2px solid var(--ata-accent); padding-left: 0; padding-top: 20px; max-width: 400px; margin: 0 auto; }
    .kv-ataturk-principles { grid-template-columns: repeat(2, 1fr); gap: 30px; }
    .kv-ataturk-memorial__inner { flex-direction: column; text-align: center; gap: 50px; }
    .kv-ataturk-memorial__text blockquote { border-left: none; padding-left: 0; border-top: 2px solid var(--ata-accent); padding-top: 25px; }
}
@media (max-width: 767px) {
    .kv-ataturk-section { padding: 70px 0; }
    .kv-ataturk-intro { margin-bottom: 50px; }
    .kv-ataturk-timeline::before { left: 15px; }
    .kv-ataturk-timeline__entry { flex-direction: column; gap: 15px; padding-left: 40px; }
    .kv-ataturk-timeline__entry::after { left: 11px; top: 8px; }
    .kv-ataturk-timeline__year { width: auto; text-align: left; }
    .kv-ataturk-timeline__body { padding-left: 0; }
    .kv-ataturk-principles { grid-template-columns: 1fr; }
    .kv-ataturk-quotes, .kv-ataturk-world-quotes { grid-template-columns: 1fr; }
    .kv-ataturk-gallery { grid-template-columns: repeat(2, 1fr); gap: 20px; }
    .kv-ataturk-speech { padding: 30px 20px; }
    .kv-ataturk-speech__highlight { padding: 25px; margin: 25px 0; }
    .kv-ataturk-hero__name { font-size: 2.5rem; }
    .kv-ataturk-memorial__day { font-size: 4rem; }
    .kv-ataturk-hero__placeholder { max-width: 280px; }
}
@media (max-width: 480px) {
    .kv-ataturk-gallery { grid-template-columns: 1fr; }
    .kv-ataturk-gallery__img, .kv-ataturk-gallery__placeholder { height: 260px; }
}

/* ========================================================================
   INSTAGRAM STORIES BİLEŞENİ
   ======================================================================== */

/* Dairesel grup butonları satırı */
.kv-stories {
    padding: 1.25rem 0 0.5rem;
    background: linear-gradient(180deg, rgba(0,0,0,0.03) 0%, transparent 100%);
}
.kv-stories__row {
    display: flex;
    gap: 1.25rem;
    justify-content: center;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding: 0.5rem 0;
}
.kv-stories__row::-webkit-scrollbar { display: none; }

.kv-stories__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    flex-shrink: 0;
    transition: transform 0.2s ease;
}
.kv-stories__item:hover { transform: scale(1.08); }
.kv-stories__item:active { transform: scale(0.96); }

/* Gradient halka */
.kv-stories__ring {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 76px;
    height: 76px;
    border-radius: 50%;
    background: conic-gradient(
        var(--ring-color, #2563eb) 0deg,
        color-mix(in srgb, var(--ring-color, #2563eb) 60%, #fff) 120deg,
        var(--ring-color, #2563eb) 240deg,
        color-mix(in srgb, var(--ring-color, #2563eb) 60%, #fff) 360deg
    );
    padding: 3px;
    transition: box-shadow 0.3s ease;
}
.kv-stories__item:hover .kv-stories__ring {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--ring-color, #2563eb) 25%, transparent);
}

/* Dairesel thumbnail */
.kv-stories__thumb {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 68px;
    height: 68px;
    border-radius: 50%;
    overflow: hidden;
    background: #fff;
    border: 2px solid #fff;
}
.kv-stories__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}
.kv-stories__icon {
    font-size: 1.5rem;
    color: var(--ring-color, #2563eb);
}

/* Grup etiketi */
.kv-stories__label {
    font-size: 0.75rem;
    font-weight: 600;
    color: #374151;
    white-space: nowrap;
    max-width: 80px;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ========================================================================
   STORY VIEWER (Tam Ekran)
   ======================================================================== */

.kv-story-viewer {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Geçiş animasyonları */
.kv-story-viewer--enter { transition: opacity 0.25s ease; }
.kv-story-viewer--enter-start { opacity: 0; }
.kv-story-viewer--enter-end { opacity: 1; }
.kv-story-viewer--leave { transition: opacity 0.2s ease; }
.kv-story-viewer--leave-start { opacity: 1; }
.kv-story-viewer--leave-end { opacity: 0; }

/* Backdrop */
.kv-story-viewer__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.92);
}

/* Container */
.kv-story-viewer__container {
    position: relative;
    width: 100%;
    max-width: 420px;
    height: 90dvh;
    max-height: 780px;
    border-radius: 16px;
    overflow: hidden;
    background: #000;
    display: flex;
    flex-direction: column;
    user-select: none;
    -webkit-user-select: none;
}

/* Progress bar'lar */
.kv-story-viewer__progress {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: flex;
    gap: 3px;
    padding: 10px 12px 0;
    z-index: 10;
}
.kv-story-viewer__bar {
    flex: 1;
    height: 3px;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 3px;
    overflow: hidden;
}
.kv-story-viewer__bar-fill {
    height: 100%;
    background: #fff;
    width: 0%;
    border-radius: 3px;
}
.kv-story-viewer__bar-fill--paused {
    animation-play-state: paused !important;
}

@keyframes kvStoryProgress {
    from { width: 0%; }
    to { width: 100%; }
}

/* Header */
.kv-story-viewer__header {
    position: absolute;
    top: 20px;
    left: 12px;
    right: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 10;
}
.kv-story-viewer__group-info {
    display: flex;
    align-items: center;
    gap: 8px;
}
.kv-story-viewer__group-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}
.kv-story-viewer__group-label {
    font-size: 0.85rem;
    font-weight: 600;
    color: #fff;
    text-shadow: 0 1px 3px rgba(0,0,0,0.5);
}
.kv-story-viewer__close {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.4);
    border: none;
    border-radius: 50%;
    color: #fff;
    font-size: 1.1rem;
    cursor: pointer;
    transition: background 0.2s;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.kv-story-viewer__close:hover {
    background: rgba(0, 0, 0, 0.7);
}

/* Görsel alanı */
.kv-story-viewer__media {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: #111;
}
.kv-story-viewer__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Yükleniyor */
.kv-story-viewer__loader {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.3);
}
.kv-story-viewer__spinner {
    width: 36px;
    height: 36px;
    border: 3px solid rgba(255, 255, 255, 0.2);
    border-top-color: #fff;
    border-radius: 50%;
    animation: kvStorySpin 0.7s linear infinite;
}
@keyframes kvStorySpin {
    to { transform: rotate(360deg); }
}

/* Sol/sağ navigasyon alanları */
.kv-story-viewer__nav {
    position: absolute;
    top: 50px;
    bottom: 120px;
    width: 35%;
    z-index: 5;
    cursor: pointer;
}
.kv-story-viewer__nav--prev { left: 0; }
.kv-story-viewer__nav--next { right: 0; width: 65%; }

/* Alt bilgi */
.kv-story-viewer__footer {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 60px 16px 16px;
    background: linear-gradient(transparent, rgba(0,0,0,0.85));
    z-index: 10;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.kv-story-viewer__title {
    font-size: 1rem;
    font-weight: 600;
    color: #fff;
    margin: 0;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.kv-story-viewer__date {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.7);
    margin: 0;
}
.kv-story-viewer__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    padding: 8px 18px;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: 24px;
    color: #fff;
    font-size: 0.85rem;
    font-weight: 500;
    text-decoration: none;
    transition: background 0.2s, transform 0.2s;
    align-self: flex-start;
}
.kv-story-viewer__link:hover {
    background: rgba(255, 255, 255, 0.25);
    color: #fff;
    transform: translateY(-1px);
}

/* Grup noktaları (footer içinde) */
.kv-story-viewer__dots {
    display: flex;
    gap: 6px;
    justify-content: center;
    margin-bottom: 4px;
}
.kv-story-viewer__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.4);
    border: none;
    cursor: pointer;
    padding: 0;
    transition: all 0.2s;
}
.kv-story-viewer__dot--active {
    width: 20px;
    border-radius: 4px;
}

/* ========================================================================
   STORIES RESPONSIVE
   ======================================================================== */

@media (max-width: 768px) {
    .kv-stories__row {
        justify-content: flex-start;
        gap: 1rem;
        padding: 0.5rem 0.25rem;
    }
    .kv-stories__ring {
        width: 64px;
        height: 64px;
    }
    .kv-stories__thumb {
        width: 56px;
        height: 56px;
    }
    .kv-stories__label {
        font-size: 0.7rem;
    }

    /* Mobilde tam ekran viewer */
    .kv-story-viewer__container {
        max-width: 100%;
        height: 100dvh;
        max-height: none;
        border-radius: 0;
    }
}

@media (max-width: 480px) {
    .kv-stories__ring {
        width: 58px;
        height: 58px;
    }
    .kv-stories__thumb {
        width: 50px;
        height: 50px;
    }
    .kv-stories__icon { font-size: 1.25rem; }
}

/* ===== ÜYESİ OLDUĞUMUZ BİRLİKLER ===== */
.kv-union-card {
    background: var(--kv-surface, #fff);
    border: 1px solid var(--kv-border, #e2e8f0);
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: box-shadow 0.25s ease, border-color 0.25s ease, transform 0.25s ease;
}
.kv-union-card:hover {
    border-color: var(--kv-primary);
    box-shadow: 0 8px 30px rgb(var(--kv-primary-rgb) / 0.12);
    transform: translateY(-2px);
}
.kv-union-card__logo {
    align-items: center;
    background: #f8fafc;
    display: flex;
    height: 180px;
    justify-content: center;
    padding: 1.5rem;
}
.kv-union-card__img {
    height: 100%;
    max-height: 140px;
    max-width: 100%;
    object-fit: contain;
    transition: transform 0.3s ease;
    width: auto;
}
.kv-union-card:hover .kv-union-card__img {
    transform: scale(1.05);
}
.kv-union-card__placeholder {
    align-items: center;
    display: flex;
    height: 100%;
    justify-content: center;
    opacity: 0.3;
    width: 100%;
}
.kv-union-card__body {
    flex: 1;
    padding: 1.25rem 1.5rem 0.75rem;
}
.kv-union-card__title {
    color: var(--kv-text);
    font-family: var(--kv-heading-font), sans-serif;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.4;
    margin: 0 0 0.5rem;
}
.kv-union-card__excerpt {
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    color: var(--kv-text-muted);
    display: -webkit-box;
    font-size: 0.85rem;
    line-height: 1.5;
    margin: 0;
    overflow: hidden;
}
.kv-union-card__footer {
    border-top: 1px solid var(--kv-border, #e2e8f0);
    display: flex;
    gap: 0;
    margin-top: auto;
}
.kv-union-card__btn {
    align-items: center;
    display: inline-flex;
    flex: 1;
    font-size: 0.8rem;
    font-weight: 600;
    gap: 0.4rem;
    justify-content: center;
    padding: 0.75rem 0.5rem;
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease;
}
.kv-union-card__btn--detail {
    color: var(--kv-primary);
}
.kv-union-card__btn--detail:hover {
    background: rgb(var(--kv-primary-rgb) / 0.06);
    color: var(--kv-primary-dark);
}
.kv-union-card__btn--website {
    border-left: 1px solid var(--kv-border, #e2e8f0);
    color: var(--kv-text-muted);
}
.kv-union-card__btn--website:hover {
    background: rgb(var(--kv-primary-rgb) / 0.06);
    color: var(--kv-primary);
}
