/*
Theme Name: Kintamani
Theme URI: https://katrin.id
Author: Katrin
Author URI: https://katrin.id
Description: Lightweight WordPress theme with expanding tiles, smooth animations, and hybrid content approach. Tile shows preview excerpt, full article opens in single page. Optimized for mobile and PageSpeed.
Version: 1.4.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kintamani
Tags: one-column, custom-colors, custom-menu, featured-images, theme-options, translation-ready, blog
*/

/* ═══════════════════════════════════════════
   CSS CUSTOM PROPERTIES
   ═══════════════════════════════════════════ */
:root {
  --k-font-title: 'Noto Sans', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  --k-font-body: 'Open Sans', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  --k-bg: #faf9f7;
  --k-tile: #ffffff;
  --k-text: #1a1a1a;
  --k-muted: rgba(0,0,0,0.78);
  --k-subtle: rgba(0,0,0,0.64);
  --k-border: rgba(0,0,0,0.06);
  --k-surface: rgba(0,0,0,0.03);
  --k-header-bg: rgba(250,249,247,0.85);
  --k-divider: rgba(0,0,0,0.08);
  --k-accent: #0d9488;
  --k-radius: 16px;
  --k-max-width: 1120px;
  --k-article-width: 720px;
  --k-transition: 0.3s ease;
}

[data-theme="dark"] {
  --k-bg: #111111;
  --k-tile: #1a1a1a;
  --k-text: #e5e7eb;
  --k-muted: rgba(255,255,255,0.82);
  --k-subtle: rgba(255,255,255,0.68);
  --k-border: rgba(255,255,255,0.06);
  --k-surface: rgba(255,255,255,0.04);
  --k-header-bg: rgba(17,17,17,0.85);
  --k-divider: rgba(255,255,255,0.08);
}

/* ═══════════════════════════════════════════
   RESET & BASE
   ═══════════════════════════════════════════ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  background-color: var(--k-bg);
  color: var(--k-text);
  font-family: var(--k-font-body);
  font-size: 14px;
  line-height: 1.6;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  transition: background-color var(--k-transition), color var(--k-transition);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  border: none;
  background: none;
  cursor: pointer;
  font: inherit;
  color: inherit;
}

ul, ol { list-style: none; }

/* ═══════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════ */
.k-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background-color: var(--k-header-bg);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--k-border);
  transition: background-color var(--k-transition);
}

.k-header-inner {
  max-width: var(--k-max-width);
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 56px;
}

.k-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
}

.k-header-back {
  padding: 6px;
  margin-left: -4px;
  border-radius: 6px;
  color: var(--k-muted);
  transition: color 0.2s;
  display: none;
}
.k-header-back:hover { color: var(--k-text); }
.k-header-back.visible { display: flex; }

.k-logo {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--k-text);
  transition: color var(--k-transition);
}

/* Desktop Nav */
.k-nav {
  display: none;
  align-items: center;
  gap: 2px;
}

.k-nav-link {
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 13px;
  color: var(--k-muted);
  transition: color 0.2s;
}
.k-nav-link:hover { color: var(--k-text); }

.k-nav-divider {
  width: 1px;
  height: 14px;
  margin: 0 6px;
  background-color: var(--k-divider);
}

.k-nav-cat {
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--k-muted);
  transition: all 0.2s;
  position: relative;
}
.k-nav-cat:hover { color: var(--k-text); }
.k-nav-cat.active {
  color: #fff;
}

.k-header-actions {
  display: flex;
  align-items: center;
  gap: 2px;
}

.k-icon-btn {
  padding: 8px;
  border-radius: 6px;
  color: var(--k-muted);
  transition: color 0.2s;
  display: flex;
  align-items: center;
}
.k-icon-btn:hover { color: var(--k-text); }
.k-icon-btn svg { width: 17px; height: 17px; }

.k-mobile-toggle {
  display: none;
}

@media (min-width: 768px) {
  .k-nav { display: flex; }
  .k-mobile-toggle { display: none !important; }
}

/* Search Bar */
.k-search-bar {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-in-out, opacity 0.3s;
}
.k-search-bar.open {
  max-height: 60px;
  opacity: 1;
}
.k-search-bar-inner {
  max-width: var(--k-max-width);
  margin: 0 auto;
  padding: 0 20px 12px;
}
.k-search-input-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 8px;
  background-color: var(--k-surface);
  border: 1px solid var(--k-border);
}
.k-search-input-wrap svg {
  width: 14px; height: 14px;
  color: var(--k-subtle);
  flex-shrink: 0;
}
.k-search-input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-size: 14px;
  color: var(--k-text);
  caret-color: var(--k-accent);
}
.k-search-input::placeholder { color: var(--k-subtle); }

/* Mobile Menu */
.k-mobile-menu {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-in-out, opacity 0.3s;
}
.k-mobile-menu.open {
  max-height: 300px;
  opacity: 1;
}
.k-mobile-menu-inner {
  max-width: var(--k-max-width);
  margin: 0 auto;
  padding: 0 20px 16px;
}
.k-mobile-menu-link {
  display: block;
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 14px;
  color: var(--k-muted);
}
.k-mobile-menu-cats {
  padding-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.k-mobile-cat-pill {
  padding: 4px 12px;
  border-radius: 9999px;
  font-size: 12px;
  font-weight: 500;
  background-color: var(--k-surface);
  color: var(--k-muted);
  transition: all 0.2s;
}
.k-mobile-cat-pill.active {
  color: #fff;
}

@media (max-width: 767px) {
  .k-mobile-toggle { display: flex; }
}

/* ═══════════════════════════════════════════
   GRID VIEW (Homepage)
   ═══════════════════════════════════════════ */
.k-main {
  flex: 1;
  max-width: var(--k-max-width);
  width: 100%;
  margin: 0 auto;
  padding: 24px 20px;
}

.k-status {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  font-size: 12px;
  color: var(--k-subtle);
}
.k-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
}
.k-status-reset {
  margin-left: auto;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 12px;
  color: var(--k-subtle);
  cursor: pointer;
}

.k-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}

@media (min-width: 640px) {
  .k-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .k-grid { grid-template-columns: repeat(3, 1fr); }
}

/* Tile */
.k-tile {
  border-radius: var(--k-radius);
  overflow: hidden;
  background-color: var(--k-tile);
  border: 1px solid var(--k-border);
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  transition: box-shadow 0.3s, border-color 0.3s, transform 0.2s;
  cursor: pointer;
}
[data-theme="dark"] .k-tile {
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.k-tile:hover {
  box-shadow: 0 6px 24px rgba(0,0,0,0.08);
  transform: translateY(-2px);
}
[data-theme="dark"] .k-tile:hover {
  box-shadow: 0 6px 24px rgba(0,0,0,0.35);
}

.k-tile-thumb {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
}
.k-tile-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s;
}
.k-tile:hover .k-tile-thumb img {
  transform: scale(1.03);
}

.k-tile-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  display: inline-block;
  padding: 2px 8px;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 600;
  color: #fff;
}

.k-tile-thumb::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 40px;
  background: linear-gradient(to top, rgba(0,0,0,0.2), transparent);
}

.k-tile-info {
  padding: 16px 18px 18px;
}

.k-tile-title {
  font-size: 15px;
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: 8px;
  color: var(--k-text);
  transition: color 0.2s;
}
.k-tile:hover .k-tile-title {
  color: var(--k-accent);
}

.k-tile-excerpt {
  font-size: 13px;
  line-height: 1.6;
  color: var(--k-muted);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 10px;
}

.k-tile-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  color: var(--k-subtle);
}
.k-tile-meta svg { width: 12px; height: 12px; }

.k-btn-read {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  background-color: var(--k-accent);
  color: #fff;
  transition: all 0.2s;
}
.k-btn-read:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}
.k-btn-read svg { width: 14px; height: 14px; }

.k-empty {
  text-align: center;
  padding: 80px 20px;
  font-size: 14px;
  color: var(--k-subtle);
}

/* ═══════════════════════════════════════════
   SINGLE POST (Article Page)
   ═══════════════════════════════════════════ */
.k-article { flex: 1; }

/* Reading progress */
.k-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 60;
  height: 2px;
  background-color: var(--k-border);
  transition: background-color var(--k-transition);
}
.k-progress-bar {
  height: 100%;
  width: 0;
  transition: width 0.15s;
}

.k-hero {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/9;
}
.k-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.k-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, var(--k-bg) 0%, rgba(0,0,0,0.15) 40%, transparent 100%);
}
.k-hero-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  max-width: var(--k-article-width);
  margin: 0 auto;
  padding: 0 20px 32px;
}
.k-hero-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 10px;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 600;
  color: #fff;
  margin-bottom: 16px;
}
.k-hero-title {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.3;
  color: #fff;
  margin-bottom: 12px;
}
@media (min-width: 640px) {
  .k-hero-title { font-size: 40px; }
}
.k-hero-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 12px;
  color: rgba(255,255,255,0.6);
}
.k-hero-meta svg { width: 12px; height: 12px; }

.k-article-body {
  max-width: var(--k-article-width);
  margin: 0 auto;
  padding: 40px 20px;
}

.k-article-content {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.k-article-content p {
  font-size: 15px;
  line-height: 1.85;
  color: var(--k-muted);
}

.k-article-content ul {
  list-style: none;
  padding-left: 0;
}
.k-article-content ul li {
  font-size: 14px;
  line-height: 1.8;
  color: var(--k-muted);
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 2px 0;
}
.k-article-content ul li::before {
  content: '';
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background-color: var(--k-subtle);
  margin-top: 10px;
  flex-shrink: 0;
}

.k-article-content blockquote {
  border-left: 3px solid var(--k-accent);
  padding-left: 20px;
  margin: 8px 0;
  font-style: italic;
  color: var(--k-muted);
}

.k-article-content h2, .k-article-content h3, .k-article-content h4 {
  color: var(--k-text);
  margin-top: 8px;
}

.k-article-content figure,
.k-article-content .wp-block-image,
.k-article-content .gallery {
  margin: 8px 0;
}

.k-article-content figure img,
.k-article-content .wp-block-image img,
.k-article-content .gallery img {
  border-radius: 12px;
  width: 100%;
}

.k-article-content figcaption,
.k-article-content .wp-caption-text {
  text-align: center;
  font-size: 12px;
  color: var(--k-subtle);
  margin-top: 8px;
}

.k-article-content .gallery {
  display: grid;
  gap: 12px;
}
.k-article-content .gallery.columns-2 { grid-template-columns: repeat(2, 1fr); }
.k-article-content .gallery.columns-3 { grid-template-columns: repeat(3, 1fr); }
.k-article-content .gallery.columns-4 { grid-template-columns: repeat(4, 1fr); }
.k-article-content .gallery .gallery-item {
  overflow: hidden;
  border-radius: 12px;
}

/* Gallery fallback (for theme gallery) */
.k-gallery {
  padding-top: 16px;
  display: grid;
  gap: 12px;
}
.k-gallery.cols-1 { grid-template-columns: 1fr; }
.k-gallery.cols-2 { grid-template-columns: repeat(2, 1fr); }
.k-gallery.cols-3 { grid-template-columns: repeat(3, 1fr); }
.k-gallery-item {
  overflow: hidden;
  border-radius: 12px;
  aspect-ratio: 4/3;
}
.k-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Tags */
.k-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding-top: 16px;
}
.k-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 8px;
  font-size: 11px;
  background-color: var(--k-surface);
  color: var(--k-subtle);
}
.k-tag svg { width: 10px; height: 10px; }

/* Actions */
.k-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  padding-top: 20px;
  border-top: 1px solid var(--k-border);
}
.k-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 12px;
  background-color: var(--k-surface);
  color: var(--k-subtle);
  transition: all 0.2s;
}
.k-action-btn:hover {
  color: var(--k-text);
  background-color: var(--k-border);
}
.k-action-btn svg { width: 14px; height: 14px; }

/* Prev / Next */
.k-prenext {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  padding-top: 24px;
}
.k-prenext-link {
  padding: 16px;
  border-radius: 12px;
  background-color: var(--k-surface);
  transition: background-color 0.2s;
  text-align: left;
}
.k-prenext-link:hover {
  background-color: var(--k-border);
}
.k-prenext-link.next {
  text-align: right;
}
.k-prenext-label {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--k-subtle);
  margin-bottom: 4px;
}
.k-prenext-title {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: var(--k-text);
}

/* ═══════════════════════════════════════════
   SCROLL TO TOP
   ═══════════════════════════════════════════ */
.k-scroll-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 40;
  padding: 10px;
  border-radius: 50%;
  background-color: var(--k-surface);
  color: var(--k-muted);
  border: 1px solid var(--k-border);
  backdrop-filter: blur(12px);
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
  transition: all 0.3s;
  display: flex;
  align-items: center;
}
.k-scroll-top.visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.k-scroll-top svg { width: 16px; height: 16px; }

/* ═══════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════ */
.k-footer {
  padding: 24px 20px;
  text-align: center;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #000000 !important;
  transition: color var(--k-transition);
}
[data-theme="dark"] .k-footer {
  color: #FFFFFF !important;
}

/* ═══════════════════════════════════════════
   GOOGLE TRANSLATE WIDGET
   ═══════════════════════════════════════════ */
#google_translate_element {
  display: inline-block;
}

#google_translate_element .goog-te-gadget {
  font-family: var(--k-font-body) !important;
  color: var(--k-text) !important;
}

#google_translate_element .goog-te-gadget .goog-te-combo {
  font-family: var(--k-font-body) !important;
  font-size: 13px !important;
  color: var(--k-text) !important;
  background-color: var(--k-surface) !important;
  border: 1px solid var(--k-border) !important;
  border-radius: 8px !important;
  padding: 6px 10px !important;
  cursor: pointer;
  outline: none;
}

#google_translate_element .goog-te-gadget .goog-te-combo:focus {
  border-color: var(--k-accent) !important;
}

#google_translate_element .goog-te-gadget .goog-te-combo option {
  background-color: #ffffff !important;
  color: #1a1a1a !important;
}

/* Dark mode — force Google Translate dropdown to be readable */
[data-theme="dark"] #google_translate_element .goog-te-gadget .goog-te-combo {
  background-color: rgba(255,255,255,0.08) !important;
  color: #e5e7eb !important;
  border-color: rgba(255,255,255,0.12) !important;
}

[data-theme="dark"] #google_translate_element .goog-te-gadget .goog-te-combo option {
  background-color: #ffffff !important;
  color: #1a1a1a !important;
}

[data-theme="dark"] #google_translate_element .goog-te-gadget span,
[data-theme="dark"] #google_translate_element .goog-te-gadget a {
  color: var(--k-text) !important;
}

/* Google Translate skip/branding link */
.goog-te-banner-frame,
.goog-te-gadget span[id="goog-gt-tt"] {
  display: none !important;
}

/* Fix for Google Translate top banner that may appear */
body {
  top: 0 !important;
}

/* Light mode also ensure option readability */
#google_translate_element select.goog-te-combo option {
  background: #fff !important;
  color: #1a1a1a !important;
}

/* ═══════════════════════════════════════════
   SEARCH RESULTS
   ═══════════════════════════════════════════ */
.k-search-title {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 24px;
  color: var(--k-text);
}
.k-search-title span {
  color: var(--k-subtle);
  font-weight: 400;
}

/* ═══════════════════════════════════════════
   LOAD MORE (AJAX Pagination)
   ═══════════════════════════════════════════ */
.k-load-more-wrap {
  padding: 0 0 20px;
}

.k-load-more-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 32px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 600;
  background-color: var(--k-surface);
  color: var(--k-subtle);
  border: 1px solid var(--k-border);
  cursor: pointer;
  transition: all 0.2s;
  min-width: 200px;
  justify-content: center;
}
.k-load-more-btn:hover {
  background-color: var(--k-border);
  color: var(--k-text);
  transform: translateY(-1px);
}
.k-load-more-btn.loading {
  opacity: 0.6;
  pointer-events: none;
}

/* Fade-in animation for new tiles */
.k-tile-new {
  opacity: 0;
  transform: translateY(16px);
  animation: kFadeIn 0.4s ease forwards;
}
@keyframes kFadeIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.k-tile-new:nth-child(2) { animation-delay: 0.05s; }
.k-tile-new:nth-child(3) { animation-delay: 0.1s; }
.k-tile-new:nth-child(4) { animation-delay: 0.15s; }
.k-tile-new:nth-child(5) { animation-delay: 0.2s; }
.k-tile-new:nth-child(6) { animation-delay: 0.25s; }
.k-tile-new:nth-child(7) { animation-delay: 0.3s; }
.k-tile-new:nth-child(8) { animation-delay: 0.35s; }
.k-tile-new:nth-child(9) { animation-delay: 0.4s; }

/* ═══════════════════════════════════════════
   404 PAGE
   ═══════════════════════════════════════════ */
.k-404 {
  text-align: center;
  padding: 80px 20px;
}
.k-404 h1 {
  font-size: 48px;
  font-weight: 700;
  color: var(--k-subtle);
  margin-bottom: 12px;
}
.k-404 p {
  font-size: 14px;
  color: var(--k-muted);
  margin-bottom: 24px;
}
.k-404 a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 20px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 500;
  background-color: var(--k-accent);
  color: #fff;
}

/* ═══════════════════════════════════════════
   WORDPRESS GALLERY
   ═══════════════════════════════════════════ */
.gallery { margin: 0 -6px; }
.gallery-item { margin: 0 6px 12px; float: left; }
.gallery-columns-2 .gallery-item { max-width: calc(50% - 12px); }
.gallery-columns-3 .gallery-item { max-width: calc(33.333% - 12px); }
.gallery-columns-4 .gallery-item { max-width: calc(25% - 12px); }
.gallery-icon img {
  border-radius: 12px;
  width: 100%;
  height: auto;
}
.gallery-caption {
  text-align: center;
  font-size: 12px;
  color: var(--k-subtle);
  margin-top: 6px;
}

/* ═══════════════════════════════════════════
   WORDPRESS ALIGNMENTS
   ═══════════════════════════════════════════ */
.alignleft { float: left; margin: 0 20px 12px 0; }
.alignright { float: right; margin: 0 0 12px 20px; }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.alignwide { max-width: calc(100% + 80px); margin-left: -40px; margin-right: -40px; }
@media (max-width: 767px) {
  .alignwide { max-width: 100%; margin-left: 0; margin-right: 0; }
}
.alignfull { max-width: 100vw; margin-left: calc(-50vw + 50%); margin-right: calc(-50vw + 50%); }
.alignfull img { width: 100%; }

/* ═══════════════════════════════════════════
   COMMENTS (Basic support)
   ═══════════════════════════════════════════ */
.k-comments {
  max-width: var(--k-article-width);
  margin: 0 auto;
  padding: 0 20px 40px;
}
.k-comments-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--k-text);
  padding-bottom: 16px;
  border-bottom: 1px solid var(--k-border);
  margin-bottom: 24px;
}
.k-comments ol { list-style: none; padding: 0; }
.k-comments .comment {
  padding: 16px 0;
  border-bottom: 1px solid var(--k-border);
}
.k-comments .comment-author {
  font-size: 13px;
  font-weight: 600;
  color: var(--k-text);
}
.k-comments .comment-meta {
  font-size: 11px;
  color: var(--k-subtle);
  margin-top: 2px;
}
.k-comments .comment-content p {
  font-size: 14px;
  line-height: 1.7;
  color: var(--k-muted);
  margin-top: 8px;
}
.k-comments .comment-respond {
  padding-top: 24px;
}
.k-comments .comment-form input,
.k-comments .comment-form textarea {
  width: 100%;
  padding: 10px 14px;
  border-radius: 8px;
  border: 1px solid var(--k-border);
  background-color: var(--k-surface);
  color: var(--k-text);
  font-family: inherit;
  font-size: 14px;
  margin-bottom: 12px;
  outline: none;
  transition: border-color 0.2s;
}
.k-comments .comment-form input:focus,
.k-comments .comment-form textarea:focus {
  border-color: var(--k-accent);
}
.k-comments .comment-form .submit {
  background-color: var(--k-accent);
  color: #fff;
  padding: 10px 24px;
  border-radius: 8px;
  font-weight: 600;
  font-size: 13px;
  cursor: pointer;
  border: none;
}

/* ═══════════════════════════════════════════
   ARTICLE MODAL POPUP
   ═══════════════════════════════════════════ */
.k-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0);
  backdrop-filter: blur(0px);
  -webkit-backdrop-filter: blur(0px);
  visibility: hidden;
  transition: background-color 0.3s ease, backdrop-filter 0.3s ease, visibility 0.3s;
  padding: 20px;
}

.k-modal-backdrop.open {
  background-color: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  visibility: visible;
}

[data-theme="dark"] .k-modal-backdrop.open {
  background-color: rgba(0, 0, 0, 0.65);
}

.k-modal-container {
  position: relative;
  width: 100%;
  max-width: 1120px;
  max-height: 90vh;
  border-radius: 20px;
  background-color: var(--k-tile);
  border: 1px solid var(--k-border);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.18);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  opacity: 0;
  transform: translateY(24px) scale(0.96);
  transition: opacity 0.35s ease, transform 0.35s ease;
}

[data-theme="dark"] .k-modal-container {
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.5);
}

.k-modal-backdrop.open .k-modal-container {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* Close Button */
.k-modal-close {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 10;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background-color: rgba(0, 0, 0, 0.35);
  color: #fff;
  border: none;
  cursor: pointer;
  transition: background-color 0.2s, transform 0.2s;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.k-modal-close:hover {
  background-color: rgba(0, 0, 0, 0.6);
  transform: scale(1.1);
}

.k-modal-close svg {
  width: 16px;
  height: 16px;
}

/* Modal Body (scrollable) */
.k-modal-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  position: relative;
}

/* Custom scrollbar for modal */
.k-modal-body::-webkit-scrollbar {
  width: 4px;
}
.k-modal-body::-webkit-scrollbar-track {
  background: transparent;
}
.k-modal-body::-webkit-scrollbar-thumb {
  background-color: var(--k-subtle);
  border-radius: 4px;
}

/* Loading State */
.k-modal-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 60px 20px;
  font-size: 13px;
  color: var(--k-subtle);
}

.k-modal-spinner {
  width: 18px;
  height: 18px;
  border: 2px solid var(--k-border);
  border-top-color: var(--k-accent);
  border-radius: 50%;
  animation: kSpin 0.7s linear infinite;
}

@keyframes kSpin {
  to { transform: rotate(360deg); }
}

/* Modal Featured Image */
.k-modal-thumb {
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  background: rgba(0, 0, 0, 0.08);
  aspect-ratio: 16 / 9;
}


.k-modal-thumb img {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  object-fit: cover;
  object-position: center center;
  display: block;
  transform: scale(1.01);
}

.k-modal-thumb img.is-portrait {
  object-position: center top;
}

.k-modal-thumb img.is-squareish {
  object-position: center center;
}

.k-modal-thumb img.is-landscape {
  object-position: center center;
}


.k-modal-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 600;
  color: #fff;
}

/* Modal Header */
.k-modal-header {
  padding: 20px 24px 0;
}

/* Title Card — rounded container inside modal */
.k-modal-title-card {
  margin: 16px 24px 0;
  padding: 20px 24px;
  border-radius: 16px;
  background-color: var(--k-surface);
  border: 1px solid var(--k-border);
}

.k-modal-title-card .k-modal-title {
  font-size: 26px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--k-text);
  margin-bottom: 12px;
}

.k-modal-title-card .k-modal-meta {
  font-size: 14px;
  color: var(--k-subtle);
  padding-bottom: 0;
  border-bottom: none;
  gap: 16px;
}

.k-modal-title-card .k-modal-meta svg {
  width: 14px;
  height: 14px;
}

/* Hide original header when title card is used */
.k-modal-header.has-title-card {
  display: none;
}

/* Mobile responsive for title card */
@media (max-width: 640px) {
  .k-modal-title-card {
    margin: 12px 16px 0;
    padding: 16px 18px;
    border-radius: 12px;
  }

  .k-modal-title-card .k-modal-title {
    font-size: 22px;
    margin-bottom: 10px;
  }

  .k-modal-title-card .k-modal-meta {
    font-size: 13px;
    gap: 12px;
  }

  /* Modal content padding mobile */
  .k-modal-content {
    padding: 20px 18px;
  }
}

.k-modal-title {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--k-text);
  margin-bottom: 10px;
}

.k-modal-meta {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 13px;
  color: var(--k-subtle);
  padding-bottom: 16px;
  border-bottom: 1px solid var(--k-border);
}

.k-modal-meta span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.k-modal-meta svg {
  width: 12px;
  height: 12px;
}

/* Modal Content — bigger fonts */
.k-modal-content {
  padding: 24px 28px;
  overflow: hidden;
}

/* Constrain ALL media inside modal — override alignfull/alignwide/etc */
.k-modal-content img,
.k-modal-content video,
.k-modal-content iframe,
.k-modal-content embed,
.k-modal-content object {
  max-width: 100% !important;
  height: auto !important;
  display: block;
}

.k-modal-content img {
  border-radius: 10px;
}

/* Force alignfull to stay within modal bounds */
.k-modal-content .alignfull,
.k-modal-content .alignwide {
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  width: 100% !important;
}

.k-modal-content .alignfull img,
.k-modal-content .alignwide img {
  max-width: 100% !important;
  width: 100% !important;
}

/* WPBakery vc_row / vc_column containment */
.k-modal-content .vc_row,
.k-modal-content .vc_section,
.k-modal-content .vc_row[data-vc-full-width],
.k-modal-content .vc_row[data-vc-full-width-init] {
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  left: auto !important;
  right: auto !important;
}

.k-modal-content .vc_row > .vc_column_container,
.k-modal-content .vc_row > .wpb_column {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.k-modal-content .vc_video-container,
.k-modal-content .vc_video-aspect-ratio {
  max-width: 100% !important;
}

.k-modal-content .wpb_single_image img {
  max-width: 100% !important;
  height: auto !important;
}

.k-modal-content .wpb_video_wrapper {
  max-width: 100% !important;
}

.k-modal-content .wpb_video_wrapper iframe,
.k-modal-content .wpb_video_wrapper video {
  max-width: 100% !important;
  width: 100% !important;
}

/* Elementor compatibility (just in case) */
.k-modal-content .elementor-widget-wrap {
  max-width: 100% !important;
}

.k-modal-content .elementor-section[data-settings*="stretch_section"] {
  max-width: 100% !important;
  left: auto !important;
  right: auto !important;
}

.k-modal-content p {
  font-size: 16px;
  line-height: 1.85;
  color: var(--k-muted);
  margin-bottom: 16px;
}
.k-modal-content p:last-child {
  margin-bottom: 0;
}

.k-modal-content a,
.k-modal-content a span {
  color: var(--k-accent);
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 3px;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.k-modal-content a:hover,
.k-modal-content a:focus-visible,
.k-modal-content a:hover span,
.k-modal-content a:focus-visible span {
  color: var(--k-accent-2);
  opacity: 1;
}

.k-modal-content a:visited,
.k-modal-content a:visited span {
  color: color-mix(in srgb, var(--k-accent) 78%, var(--k-text) 22%);
}

.k-modal-content h2,
.k-modal-content h3,
.k-modal-content h4 {
  color: var(--k-text);
  font-size: 22px;
  margin-top: 12px;
  margin-bottom: 12px;
}

.k-modal-content h3 {
  font-size: 19px;
}

.k-modal-content h4 {
  font-size: 17px;
}

.k-modal-content ul,
.k-modal-content ol {
  padding-left: 0;
  margin-bottom: 14px;
}

.k-modal-content ul:not(.wpb_tabs_nav):not(.vc_tta-tabs-list):not(.ultimate-tabs-nav):not(.nav):not(.nav-tabs):not(.nav-pills):not(.resp-tabs-list) li {
  font-size: 15px;
  line-height: 1.75;
  color: var(--k-muted);
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 2px 0;
}

.k-modal-content ul:not(.wpb_tabs_nav):not(.vc_tta-tabs-list):not(.ultimate-tabs-nav):not(.nav):not(.nav-tabs):not(.nav-pills):not(.resp-tabs-list) li::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: var(--k-subtle);
  margin-top: 10px;
  flex-shrink: 0;
}

.k-modal-content blockquote {
  border-left: 3px solid var(--k-accent);
  padding-left: 16px;
  margin: 12px 0;
  font-style: italic;
  color: var(--k-muted);
  font-size: 15px;
}

.k-modal-content figure,
.k-modal-content .wp-block-image {
  margin: 12px 0;
}

.k-modal-content figure img,
.k-modal-content .wp-block-image img {
  border-radius: 10px;
  width: 100%;
  display: block;
}

.k-modal-content figcaption,
.k-modal-content .wp-caption-text {
  text-align: center;
  font-size: 13px;
  color: var(--k-subtle);
  margin-top: 6px;
}

.k-modal-content .gallery {
  display: grid;
  gap: 8px;
}
.k-modal-content .gallery.columns-2 { grid-template-columns: repeat(2, 1fr); }
.k-modal-content .gallery.columns-3 { grid-template-columns: repeat(3, 1fr); }
.k-modal-content .gallery.columns-4 { grid-template-columns: repeat(4, 1fr); }
.k-modal-content .gallery .gallery-item {
  overflow: hidden;
  border-radius: 10px;
}
.k-modal-content .gallery .gallery-item img {
  border-radius: 10px;
  width: 100%;
}



/* Kintamani: WPBakery / VC / Ultimate tabs support inside AJAX modal */
.k-modal-content .wpb_tabs .wpb_tabs_nav,
.k-modal-content .vc_tta-tabs .vc_tta-tabs-list,
.k-modal-content .ultimate-tabs-nav,
.k-modal-content .nav-tabs,
.k-modal-content .nav-pills,
.k-modal-content .nav {
  display: flex !important;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
}

.k-modal-content .wpb_tabs .wpb_tabs_nav li,
.k-modal-content .vc_tta-tabs .vc_tta-tab,
.k-modal-content .ultimate-tabs-nav li,
.k-modal-content .nav-tabs li,
.k-modal-content .nav-pills li,
.k-modal-content .nav li {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}

.k-modal-content .wpb_tabs .wpb_tabs_nav li::before,
.k-modal-content .vc_tta-tabs .vc_tta-tab::before,
.k-modal-content .ultimate-tabs-nav li::before,
.k-modal-content .nav-tabs li::before,
.k-modal-content .nav-pills li::before,
.k-modal-content .nav li::before {
  content: none !important;
}

.k-modal-content .wpb_tabs .wpb_tabs_nav li a,
.k-modal-content .vc_tta-tabs .vc_tta-tab > a,
.k-modal-content .ultimate-tabs-nav li a,
.k-modal-content .nav-tabs li a,
.k-modal-content .nav-pills li a,
.k-modal-content .nav li a {
  display: block;
  padding: 12px 20px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--k-text);
  text-decoration: none;
  border: 1px solid var(--k-border);
  border-radius: 8px;
  transition: all 0.25s ease;
  cursor: pointer;
}

.k-modal-content .wpb_tabs .wpb_tabs_nav li a:hover,
.k-modal-content .vc_tta-tabs .vc_tta-tab > a:hover,
.k-modal-content .ultimate-tabs-nav li a:hover,
.k-modal-content .nav-tabs li a:hover,
.k-modal-content .nav-pills li a:hover,
.k-modal-content .nav li a:hover {
  background: rgba(255, 255, 255, 0.1);
}

.k-modal-content .wpb_tabs .wpb_tabs_nav li.ui-tabs-active a,
.k-modal-content .wpb_tabs .wpb_tabs_nav li.active a,
.k-modal-content .vc_tta-tabs .vc_tta-tab.vc_active > a,
.k-modal-content .ultimate-tabs-nav li.active a,
.k-modal-content .nav-tabs li.active a,
.k-modal-content .nav-pills li.active a,
.k-modal-content .nav li.active a,
.k-modal-content .nav-tabs li a.active,
.k-modal-content .nav-pills li a.active,
.k-modal-content .nav li a.active {
  background: var(--k-accent) !important;
  color: #ffffff !important;
  border-color: var(--k-accent) !important;
}

.k-modal-content .wpb_tab,
.k-modal-content .vc_tta-panel,
.k-modal-content .ultimate-tab-content,
.k-modal-content .tab-content > .tab-pane {
  display: none;
  padding: 20px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--k-border);
  border-radius: 10px;
  margin-top: 10px;
}

.k-modal-content .wpb_tab.active,
.k-modal-content .wpb_tab.ui-tabs-panel-active,
.k-modal-content .vc_tta-panel.vc_active,
.k-modal-content .ultimate-tab-content.active,
.k-modal-content .tab-content > .tab-pane.active,
.k-modal-content .tab-content > .tab-pane.show,
.k-modal-content .tab-content > .active.show {
  display: block !important;
}

[data-theme="dark"] .k-modal-content .wpb_tabs .wpb_tabs_nav li a,
[data-theme="dark"] .k-modal-content .vc_tta-tabs .vc_tta-tab > a,
[data-theme="dark"] .k-modal-content .ultimate-tabs-nav li a,
[data-theme="dark"] .k-modal-content .nav-tabs li a,
[data-theme="dark"] .k-modal-content .nav-pills li a,
[data-theme="dark"] .k-modal-content .nav li a {
  background: rgba(255, 255, 255, 0.08) !important;
  color: rgba(255, 255, 255, 0.88) !important;
  border-color: rgba(255, 255, 255, 0.12) !important;
}

[data-theme="dark"] .k-modal-content .wpb_tabs .wpb_tabs_nav li.ui-tabs-active a,
[data-theme="dark"] .k-modal-content .wpb_tabs .wpb_tabs_nav li.active a,
[data-theme="dark"] .k-modal-content .vc_tta-tabs .vc_tta-tab.vc_active > a,
[data-theme="dark"] .k-modal-content .ultimate-tabs-nav li.active a,
[data-theme="dark"] .k-modal-content .nav-tabs li.active a,
[data-theme="dark"] .k-modal-content .nav-pills li.active a,
[data-theme="dark"] .k-modal-content .nav li.active a,
[data-theme="dark"] .k-modal-content .nav-tabs li a.active,
[data-theme="dark"] .k-modal-content .nav-pills li a.active,
[data-theme="dark"] .k-modal-content .nav li a.active {
  background: var(--k-accent) !important;
  color: #fff !important;
  border-color: var(--k-accent) !important;
}

[data-theme="dark"] .k-modal-content .wpb_tab,
[data-theme="dark"] .k-modal-content .vc_tta-panel,
[data-theme="dark"] .k-modal-content .vc_tta-panel-body,
[data-theme="dark"] .k-modal-content .ultimate-tab-content,
[data-theme="dark"] .k-modal-content .tab-content > .tab-pane {
  background: rgba(255, 255, 255, 0.03) !important;
  color: rgba(245, 247, 250, 0.93) !important;
}

.k-modal-content .vc_tta-panel-body,
.k-modal-content .wpb_tab .wpb_wrapper,
.k-modal-content .ultimate-tab-content {
  display: block;
}



/* Hard override for WordPress captions with inline width from content builder */
.k-modal-content figure.wp-caption,
.k-modal-content .wp-caption,
.k-modal-content figure[id^="attachment_"],
.k-modal-content [id^="attachment_"].wp-caption {
  width: auto !important;
  max-width: 100% !important;
  display: block !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.k-modal-content figure.wp-caption img,
.k-modal-content .wp-caption img,
.k-modal-content figure[id^="attachment_"] img,
.k-modal-content [id^="attachment_"].wp-caption img {
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
}

.k-modal-content figure.wp-caption figcaption,
.k-modal-content .wp-caption .wp-caption-text,
.k-modal-content figure[id^="attachment_"] figcaption,
.k-modal-content [id^="attachment_"].wp-caption .wp-caption-text {
  width: auto !important;
  max-width: 100% !important;
}

/* Modal Tags */
.k-modal-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 0 24px 24px;
}

.k-modal-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 6px;
  font-size: 10px;
  background-color: var(--k-surface);
  color: var(--k-subtle);
}

.k-modal-tag svg {
  width: 10px;
  height: 10px;
}

/* Modal responsive */
@media (max-width: 640px) {
  .k-modal-container {
    max-width: 100%;
    max-height: 90vh;
    border-radius: 16px;
  }

  .k-modal-backdrop {
    padding: 12px;
  }

  .k-modal-header {
    padding: 16px 18px 0;
  }

  .k-modal-title {
    font-size: 18px;
  }

  .k-modal-content {
    padding: 16px 18px;
  }

  .k-modal-tags {
    padding: 0 18px 18px;
  }

  .k-modal-close {
    top: 10px;
    right: 10px;
    width: 28px;
    height: 28px;
  }

  .k-modal-close svg {
    width: 14px;
    height: 14px;
  }
}



/* Image lightbox for modal content */
.k-lightbox {
  position: fixed;
  inset: 0;
  z-index: 130;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px;
  background: rgba(0, 0, 0, 0);
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.25s ease, background-color 0.25s ease, visibility 0.25s ease;
}

.k-lightbox.open {
  visibility: visible;
  opacity: 1;
  background: rgba(0, 0, 0, 0.88);
}

.k-lightbox-stage {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.k-lightbox-image {
  max-width: min(92vw, 1400px);
  max-height: 88vh;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
  border-radius: 12px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.45);
}

.k-lightbox-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 2;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #fff;
  background: rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.k-lightbox-close:hover {
  background: rgba(255, 255, 255, 0.28);
}

.k-lightbox-close svg {
  width: 18px;
  height: 18px;
}

body.k-lightbox-active {
  overflow: hidden;
}

/* Body scroll lock when modal is open */
body.k-modal-active {
  overflow: hidden;
}


/* Header branding and navigation: force white in dark mode, black in light mode, uppercase */
.k-logo,
.k-nav-link,
.k-nav-cat,
.k-mobile-menu-link,
.k-mobile-cat-pill,
.custom-logo-link,
.custom-logo-link img {
  text-transform: uppercase;
}

.k-logo,
.k-nav-link,
.k-nav-cat,
.k-mobile-menu-link,
.k-mobile-cat-pill {
  letter-spacing: 0.06em;
}

[data-theme="dark"] .k-logo,
[data-theme="dark"] .k-nav-link,
[data-theme="dark"] .k-nav-cat,
[data-theme="dark"] .k-mobile-menu-link,
[data-theme="dark"] .k-mobile-cat-pill {
  color: #ffffff !important;
}

[data-theme="light"] .k-logo,
[data-theme="light"] .k-nav-link,
[data-theme="light"] .k-nav-cat,
[data-theme="light"] .k-mobile-menu-link,
[data-theme="light"] .k-mobile-cat-pill,
html:not([data-theme]) .k-logo,
html:not([data-theme]) .k-nav-link,
html:not([data-theme]) .k-nav-cat,
html:not([data-theme]) .k-mobile-menu-link,
html:not([data-theme]) .k-mobile-cat-pill {
  color: #000000 !important;
}

[data-theme="dark"] .k-nav-link:hover,
[data-theme="dark"] .k-nav-cat:hover,
[data-theme="dark"] .k-mobile-menu-link:hover,
[data-theme="dark"] .k-mobile-cat-pill:hover {
  color: #ffffff !important;
}

[data-theme="light"] .k-nav-link:hover,
[data-theme="light"] .k-nav-cat:hover,
[data-theme="light"] .k-mobile-menu-link:hover,
[data-theme="light"] .k-mobile-cat-pill:hover,
html:not([data-theme]) .k-nav-link:hover,
html:not([data-theme]) .k-nav-cat:hover,
html:not([data-theme]) .k-mobile-menu-link:hover,
html:not([data-theme]) .k-mobile-cat-pill:hover {
  color: #000000 !important;
}


/* Force article/modal content text colors by theme mode */
[data-theme="dark"] .k-modal-header,
[data-theme="dark"] .k-modal-title,
[data-theme="dark"] .k-modal-meta,
[data-theme="dark"] .k-modal-content,
[data-theme="dark"] .k-modal-content p,
[data-theme="dark"] .k-modal-content li,
[data-theme="dark"] .k-modal-content span,
[data-theme="dark"] .k-modal-content div,
[data-theme="dark"] .k-modal-content strong,
[data-theme="dark"] .k-modal-content em,
[data-theme="dark"] .k-modal-content blockquote,
[data-theme="dark"] .k-modal-content figcaption,
[data-theme="dark"] .k-modal-content .wp-caption-text,
[data-theme="dark"] .k-modal-content h1,
[data-theme="dark"] .k-modal-content h2,
[data-theme="dark"] .k-modal-content h3,
[data-theme="dark"] .k-modal-content h4,
[data-theme="dark"] .k-modal-content h5,
[data-theme="dark"] .k-modal-content h6,
[data-theme="dark"] .k-modal-tags,
[data-theme="dark"] .k-modal-tag {
  color: #FFFFFF !important;
}

[data-theme="light"] .k-modal-header,
[data-theme="light"] .k-modal-title,
[data-theme="light"] .k-modal-meta,
[data-theme="light"] .k-modal-content,
[data-theme="light"] .k-modal-content p,
[data-theme="light"] .k-modal-content li,
[data-theme="light"] .k-modal-content span,
[data-theme="light"] .k-modal-content div,
[data-theme="light"] .k-modal-content strong,
[data-theme="light"] .k-modal-content em,
[data-theme="light"] .k-modal-content blockquote,
[data-theme="light"] .k-modal-content figcaption,
[data-theme="light"] .k-modal-content .wp-caption-text,
[data-theme="light"] .k-modal-content h1,
[data-theme="light"] .k-modal-content h2,
[data-theme="light"] .k-modal-content h3,
[data-theme="light"] .k-modal-content h4,
[data-theme="light"] .k-modal-content h5,
[data-theme="light"] .k-modal-content h6,
[data-theme="light"] .k-modal-tags,
[data-theme="light"] .k-modal-tag,
html:not([data-theme]) .k-modal-header,
html:not([data-theme]) .k-modal-title,
html:not([data-theme]) .k-modal-meta,
html:not([data-theme]) .k-modal-content,
html:not([data-theme]) .k-modal-content p,
html:not([data-theme]) .k-modal-content li,
html:not([data-theme]) .k-modal-content span,
html:not([data-theme]) .k-modal-content div,
html:not([data-theme]) .k-modal-content strong,
html:not([data-theme]) .k-modal-content em,
html:not([data-theme]) .k-modal-content blockquote,
html:not([data-theme]) .k-modal-content figcaption,
html:not([data-theme]) .k-modal-content .wp-caption-text,
html:not([data-theme]) .k-modal-content h1,
html:not([data-theme]) .k-modal-content h2,
html:not([data-theme]) .k-modal-content h3,
html:not([data-theme]) .k-modal-content h4,
html:not([data-theme]) .k-modal-content h5,
html:not([data-theme]) .k-modal-content h6,
html:not([data-theme]) .k-modal-tags,
html:not([data-theme]) .k-modal-tag {
  color: #000000 !important;
}


/* Accessibility: strengthen tile text contrast */
.k-tile-title {
  color: var(--k-text);
}

.k-tile-excerpt {
  color: var(--k-muted) !important;
}

.k-tile-meta,
.k-tile-meta span,
.k-tile-meta svg {
  color: var(--k-subtle) !important;
  fill: currentColor;
}


/* Wider homepage grid: target about 3/4 of screen on desktop, keep mobile friendly */
@media (min-width: 1024px) {
  .home .k-main,
  .blog .k-main,
  .archive .k-main,
  .search .k-main {
    max-width: min(75vw, 1600px);
  }

  .home .k-grid,
  .blog .k-grid,
  .archive .k-grid,
  .search .k-grid {
    gap: 24px;
  }

  .home .k-tile-thumb,
  .blog .k-tile-thumb,
  .archive .k-tile-thumb,
  .search .k-tile-thumb {
    aspect-ratio: 16 / 9;
  }
}

@media (min-width: 1440px) {
  .home .k-main,
  .blog .k-main,
  .archive .k-main,
  .search .k-main {
    max-width: min(78vw, 1720px);
  }
}


[data-theme="light"] .k-footer,
html:not([data-theme]) .k-footer {
  color: #000000 !important;
}


@media (min-width: 1280px) {
  .k-modal-container {
    max-width: min(88vw, 1240px);
  }

  .k-modal-header {
    padding: 24px 30px 0;
  }

  .k-modal-content {
    padding: 24px 30px;
  }

  .k-modal-tags {
    padding: 0 30px 30px;
  }
}


/* Translation widget readability in dark mode */
[data-theme="dark"] .k-modal-content select,
[data-theme="dark"] .k-modal-content option,
[data-theme="dark"] .translate-widget select,
[data-theme="dark"] .translate-widget option,
[data-theme="dark"] .gtranslate_wrapper select,
[data-theme="dark"] .gtranslate_wrapper option,
[data-theme="dark"] .trp-language-switcher select,
[data-theme="dark"] .trp-language-switcher option,
[data-theme="dark"] .weglot-switcher select,
[data-theme="dark"] .weglot-switcher option,
[data-theme="dark"] [class*="translate"] select,
[data-theme="dark"] [class*="translate"] option,
[data-theme="dark"] [class*="language"] select,
[data-theme="dark"] [class*="language"] option {
  color: #FFFFFF !important;
  background: #111111 !important;
  border-color: rgba(255,255,255,0.18) !important;
}

/* Native dropdown list should stay readable */
[data-theme="dark"] .k-modal-content option,
[data-theme="dark"] .translate-widget option,
[data-theme="dark"] .gtranslate_wrapper option,
[data-theme="dark"] .trp-language-switcher option,
[data-theme="dark"] .weglot-switcher option,
[data-theme="dark"] [class*="translate"] option,
[data-theme="dark"] [class*="language"] option {
  color: #000000 !important;
  background: #FFFFFF !important;
}


/* Match legacy theme typography */
h1, h2, h3, h4, h5, h6,
.k-logo,
.k-nav-link,
.k-nav-cat,
.k-mobile-menu-link,
.k-mobile-cat-pill,
.k-tile-title,
.k-modal-title,
.k-hero-title,
.k-search-title {
  font-family: var(--k-font-title);
}

body,
p,
li,
input,
textarea,
select,
button,
.k-tile-excerpt,
.k-tile-meta,
.k-modal-content,
.k-modal-meta,
.k-article-content,
.k-footer {
  font-family: var(--k-font-body);
}


@media (max-width: 640px) {
  .k-modal-thumb {
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  background: rgba(0, 0, 0, 0.08);
  aspect-ratio: 16 / 9;
}



@media (min-width: 641px) {
  .k-modal-thumb {
    max-height: min(62vh, 720px);
  }
}

@media (max-width: 640px) {
  .k-modal-thumb {
    max-height: 42vh;
  }
}


/* v1.4-inspired typography transplanted onto customized dark-mode/modal build */
body {
  font-size: 16px;
  line-height: 1.75;
}

.k-tile-title {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 0.85rem;
}

.k-tile-excerpt {
  font-size: 1.2rem;
  line-height: 1.7;
  margin-bottom: 0.9rem;
}

.k-tile-meta,
.k-tile-meta span {
  font-size: 0.95rem;
}

.k-tile-content {
  padding: 18px 18px 16px;
}

@media (max-width: 768px) {
  .k-tile-title {
    font-size: 1.35rem;
    margin-bottom: 0.7rem;
  }

  .k-tile-excerpt {
    font-size: 1.05rem;
    line-height: 1.7;
    margin-bottom: 0.8rem;
  }

  .k-tile-meta,
  .k-tile-meta span {
    font-size: 0.875rem;
  }
}


/* Strong featured image fit override inside modal */
.k-modal-thumb {
  aspect-ratio: 16 / 9 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  background: rgba(0, 0, 0, 0.08) !important;
}

.k-modal-thumb img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
  transform: scale(1.01) !important;
}

.k-modal-thumb img.is-portrait {
  object-position: center top !important;
}

.k-modal-thumb img.is-squareish {
  object-position: center center !important;
}

.k-modal-thumb img.is-landscape {
  object-position: center center !important;
}


/* Homepage card typography — enlarged for readability */
.k-tile-info {
  padding: 1.2rem 1.2rem 1.3rem !important;
}

.k-tile-title {
  font-family: var(--k-font-title) !important;
  font-size: 1.95rem !important;
  line-height: 1.25 !important;
  margin-bottom: 0.9rem !important;
  font-weight: 700 !important;
}

.k-tile-excerpt {
  font-size: 1.3rem !important;
  line-height: 1.6 !important;
  margin-bottom: 1rem !important;
}

.k-tile-meta,
.k-tile-meta span,
.k-tile-meta time,
.k-tile-meta svg {
  font-size: 0.95rem !important;
}

.k-tile-meta {
  display: flex !important;
  gap: 1rem !important;
  flex-wrap: wrap !important;
  margin-bottom: 0 !important;
}

@media (max-width: 768px) {
  .k-tile-info {
    padding: 1.1rem 1.1rem 1.2rem !important;
  }

  .k-tile-title {
    font-size: 1.6rem !important;
    margin-bottom: 0.8rem !important;
  }

  .k-tile-excerpt {
    font-size: 1.15rem !important;
    margin-bottom: 0.9rem !important;
  }

  .k-tile-meta,
  .k-tile-meta span,
  .k-tile-meta time,
  .k-tile-meta svg {
    font-size: 0.9rem !important;
  }
}


/* Force exact Expanding Tiles homepage card typography */
.k-tile-title,
.k-tile-title a {
  font-family: var(--k-font-title) !important;
  font-size: 1.4rem !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  margin-bottom: 0.75rem !important;
}

.k-tile-excerpt {
  font-family: var(--k-font-body) !important;
  font-size: 0.95rem !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
  margin-bottom: 1rem !important;
}

.k-tile-meta,
.k-tile-meta span,
.k-tile-meta time,
.k-tile-meta svg {
  font-family: var(--k-font-body) !important;
  font-size: 0.85rem !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
}

.k-tile-meta {
  display: flex !important;
  gap: 1rem !important;
  flex-wrap: wrap !important;
  margin-bottom: 1rem !important;
}

@media (max-width: 768px) {
  .k-tile-title,
  .k-tile-title a {
    font-size: 1.4rem !important;
  }

  .k-tile-excerpt {
    font-size: 0.95rem !important;
  }

  .k-tile-meta,
  .k-tile-meta span,
  .k-tile-meta time,
  .k-tile-meta svg {
    font-size: 0.85rem !important;
  }
}

/* Full homepage card-area transplant from Expanding Tiles */
@media (min-width: 1024px) {
  .home .k-grid,
  .blog .k-grid,
  .archive .k-grid,
  .search .k-grid {
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr)) !important;
    gap: 24px !important;
  }

  .home .k-main,
  .blog .k-main,
  .archive .k-main,
  .search .k-main {
    max-width: min(82vw, 1500px) !important;
  }
}

.home .k-tile,
.blog .k-tile,
.archive .k-tile,
.search .k-tile {
  border-radius: 18px !important;
  overflow: hidden !important;
}

.home .k-tile-thumb,
.blog .k-tile-thumb,
.archive .k-tile-thumb,
.search .k-tile-thumb {
  aspect-ratio: 16 / 9 !important;
}

.home .k-tile-info,
.blog .k-tile-info,
.archive .k-tile-info,
.search .k-tile-info {
  padding: 1.2rem 1.2rem 1.3rem !important;
}

.home .k-tile-title,
.home .k-tile-title a,
.blog .k-tile-title,
.blog .k-tile-title a,
.archive .k-tile-title,
.archive .k-tile-title a,
.search .k-tile-title,
.search .k-tile-title a {
  font-family: var(--k-font-title) !important;
  font-size: 2.15rem !important;
  font-weight: 700 !important;
  line-height: 1.22 !important;
  margin: 0 0 0.9rem !important;
}

.home .k-tile-excerpt,
.blog .k-tile-excerpt,
.archive .k-tile-excerpt,
.search .k-tile-excerpt {
  font-family: var(--k-font-body) !important;
  font-size: 1.35rem !important;
  line-height: 1.62 !important;
  color: var(--k-muted) !important;
  margin: 0 0 1rem !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 5 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

.home .k-tile-meta,
.home .k-tile-meta span,
.home .k-tile-meta time,
.home .k-tile-meta svg,
.blog .k-tile-meta,
.blog .k-tile-meta span,
.blog .k-tile-meta time,
.blog .k-tile-meta svg,
.archive .k-tile-meta,
.archive .k-tile-meta span,
.archive .k-tile-meta time,
.archive .k-tile-meta svg,
.search .k-tile-meta,
.search .k-tile-meta span,
.search .k-tile-meta time,
.search .k-tile-meta svg {
  font-family: var(--k-font-body) !important;
  font-size: 1rem !important;
  line-height: 1.6 !important;
}

.home .k-tile-meta,
.blog .k-tile-meta,
.archive .k-tile-meta,
.search .k-tile-meta {
  display: flex !important;
  gap: 1rem !important;
  flex-wrap: wrap !important;
  margin: 0 !important;
}

@media (max-width: 768px) {
  .home .k-tile-info,
  .blog .k-tile-info,
  .archive .k-tile-info,
  .search .k-tile-info {
    padding: 1.1rem 1.1rem 1.2rem !important;
  }

  .home .k-tile-title,
  .home .k-tile-title a,
  .blog .k-tile-title,
  .blog .k-tile-title a,
  .archive .k-tile-title,
  .archive .k-tile-title a,
  .search .k-tile-title,
  .search .k-tile-title a {
    font-size: 1.7rem !important;
  }

  .home .k-tile-excerpt,
  .blog .k-tile-excerpt,
  .archive .k-tile-excerpt,
  .search .k-tile-excerpt {
    font-size: 1.2rem !important;
    -webkit-line-clamp: 5 !important;
  }

  .home .k-tile-meta,
  .home .k-tile-meta span,
  .home .k-tile-meta time,
  .home .k-tile-meta svg,
  .blog .k-tile-meta,
  .blog .k-tile-meta span,
  .blog .k-tile-meta time,
  .blog .k-tile-meta svg,
  .archive .k-tile-meta,
  .archive .k-tile-meta span,
  .archive .k-tile-meta time,
  .archive .k-tile-meta svg,
  .search .k-tile-meta,
  .search .k-tile-meta span,
  .search .k-tile-meta time,
  .search .k-tile-meta svg {
    font-size: 0.82rem !important;
  }
}

/* Exact homepage tile selectors from live markup */
.home .k-grid > article.k-tile > .k-tile-info,
.blog .k-grid > article.k-tile > .k-tile-info,
.archive .k-grid > article.k-tile > .k-tile-info,
.search .k-grid > article.k-tile > .k-tile-info {
  padding: 1.2rem 1.2rem 1.3rem !important;
}

.home .k-grid > article.k-tile > .k-tile-info > .k-tile-title,
.blog .k-grid > article.k-tile > .k-tile-info > .k-tile-title,
.archive .k-grid > article.k-tile > .k-tile-info > .k-tile-title,
.search .k-grid > article.k-tile > .k-tile-info > .k-tile-title {
  font-family: var(--k-font-title) !important;
  font-size: 2.15rem !important;
  font-weight: 700 !important;
  line-height: 1.22 !important;
  margin: 0 0 0.9rem !important;
}

.home .k-grid > article.k-tile > .k-tile-info > .k-tile-excerpt,
.blog .k-grid > article.k-tile > .k-tile-info > .k-tile-excerpt,
.archive .k-grid > article.k-tile > .k-tile-info > .k-tile-excerpt,
.search .k-grid > article.k-tile > .k-tile-info > .k-tile-excerpt {
  font-family: var(--k-font-body) !important;
  font-size: 1.35rem !important;
  line-height: 1.62 !important;
  margin: 0 0 1rem !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 5 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

.home .k-grid > article.k-tile > .k-tile-info > .k-tile-meta,
.home .k-grid > article.k-tile > .k-tile-info > .k-tile-meta span,
.home .k-grid > article.k-tile > .k-tile-info > .k-tile-meta time,
.home .k-grid > article.k-tile > .k-tile-info > .k-tile-meta svg,
.blog .k-grid > article.k-tile > .k-tile-info > .k-tile-meta,
.blog .k-grid > article.k-tile > .k-tile-info > .k-tile-meta span,
.blog .k-grid > article.k-tile > .k-tile-info > .k-tile-meta time,
.blog .k-grid > article.k-tile > .k-tile-info > .k-tile-meta svg,
.archive .k-grid > article.k-tile > .k-tile-info > .k-tile-meta,
.archive .k-grid > article.k-tile > .k-tile-info > .k-tile-meta span,
.archive .k-grid > article.k-tile > .k-tile-info > .k-tile-meta time,
.archive .k-grid > article.k-tile > .k-tile-info > .k-tile-meta svg,
.search .k-grid > article.k-tile > .k-tile-info > .k-tile-meta,
.search .k-grid > article.k-tile > .k-tile-info > .k-tile-meta span,
.search .k-grid > article.k-tile > .k-tile-info > .k-tile-meta time,
.search .k-grid > article.k-tile > .k-tile-info > .k-tile-meta svg {
  font-size: 1rem !important;
  line-height: 1.5 !important;
}

.home .k-grid > article.k-tile > .k-tile-info > .k-tile-meta,
.blog .k-grid > article.k-tile > .k-tile-info > .k-tile-meta,
.archive .k-grid > article.k-tile > .k-tile-info > .k-tile-meta,
.search .k-grid > article.k-tile > .k-tile-info > .k-tile-meta {
  gap: 0.95rem !important;
}

@media (max-width: 768px) {
  .home .k-grid > article.k-tile > .k-tile-info > .k-tile-title,
  .blog .k-grid > article.k-tile > .k-tile-info > .k-tile-title,
  .archive .k-grid > article.k-tile > .k-tile-info > .k-tile-title,
  .search .k-grid > article.k-tile > .k-tile-info > .k-tile-title {
    font-size: 1.7rem !important;
  }

  .home .k-grid > article.k-tile > .k-tile-info > .k-tile-excerpt,
  .blog .k-grid > article.k-tile > .k-tile-info > .k-tile-excerpt,
  .archive .k-grid > article.k-tile > .k-tile-info > .k-tile-excerpt,
  .search .k-grid > article.k-tile > .k-tile-info > .k-tile-excerpt {
    font-size: 1.2rem !important;
  }
}

/* Strong translate widget readability fix */
[data-theme="dark"] #google_translate_element,
[data-theme="dark"] #google_translate_element .goog-te-gadget,
[data-theme="dark"] #google_translate_element .goog-te-gadget-simple,
[data-theme="dark"] #google_translate_element .goog-te-gadget-simple span,
[data-theme="dark"] #google_translate_element .goog-te-gadget a,
[data-theme="dark"] #google_translate_element .goog-te-gadget span {
  color: #FFFFFF !important;
}

[data-theme="dark"] #google_translate_element .goog-te-gadget .goog-te-combo,
[data-theme="dark"] .k-translate select,
[data-theme="dark"] .translate-widget select,
[data-theme="dark"] [class*="translate"] select,
[data-theme="dark"] [class*="language"] select {
  color: #FFFFFF !important;
  -webkit-text-fill-color: #FFFFFF !important;
  background: #111111 !important;
  border-color: rgba(255,255,255,0.18) !important;
}

#google_translate_element .goog-te-gadget .goog-te-combo option,
#google_translate_element .goog-te-gadget .goog-te-combo optgroup,
#google_translate_element .goog-te-gadget .goog-te-combo option:disabled,
[data-theme="dark"] #google_translate_element .goog-te-gadget .goog-te-combo option,
[data-theme="dark"] #google_translate_element .goog-te-gadget .goog-te-combo optgroup,
[data-theme="dark"] #google_translate_element .goog-te-gadget .goog-te-combo option:disabled,
[data-theme="dark"] .k-translate select option,
[data-theme="dark"] .k-translate select option:disabled,
[data-theme="dark"] .translate-widget select option,
[data-theme="dark"] .translate-widget select option:disabled,
[data-theme="dark"] [class*="translate"] select option,
[data-theme="dark"] [class*="translate"] select option:disabled,
[data-theme="dark"] [class*="language"] select option,
[data-theme="dark"] [class*="language"] select option:disabled {
  color: #111111 !important;
  -webkit-text-fill-color: #111111 !important;
  background: #FFFFFF !important;
  opacity: 1 !important;
}
