/* KLSV Asset Ownership
 * @source-id theme:css:global-entry
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/global-entry
 * @runtime-handle klsv-global
 * @contracts imports tokens/base/components/a11y/shared presentation owners
 */
/* KLSV Asset Ownership
 * @source-id theme:css:tokens
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/foundation
 * @runtime-handle klsv-global
 * @contracts design tokens and compatibility aliases for existing selectors
 */

:root {
  /* Canonical KLSV UI tokens */
  --klsv-brand-indigo: #59695c;
  --klsv-brand-purple: #8d7555;
  --klsv-brand-purple-soft: #c3aa78;
  --klsv-brand-cyan: #768c9f;

  --klsv-ui-bg: #080814;
  --klsv-ui-bg-soft: #0F1022;
  --klsv-ui-bg-muted: #15162B;
  --klsv-ui-bg-hero: #0B1020;
  --klsv-ui-bg-deep: #050511;

  --klsv-ui-text: #F8FAFC;
  --klsv-ui-text-strong: #FFFFFF;
  --klsv-ui-text-soft: rgba(248, 250, 252, 0.82);
  --klsv-ui-text-faint: rgba(148, 163, 184, 0.72);
  --klsv-ui-text-muted: #94A3B8;
  --klsv-ui-text-primary: var(--klsv-ui-text);
  --klsv-ui-text-subtle: var(--klsv-ui-text-faint);


  --klsv-ui-accent: var(--klsv-brand-purple);
  --klsv-ui-accent-strong: var(--klsv-brand-purple-soft);
  --klsv-ui-accent-soft: rgba(141, 117, 85, 0.14);
  --klsv-ui-accent-glow: rgba(141, 117, 85, 0.30);
  --klsv-ui-accent-2: var(--klsv-brand-cyan);
  --klsv-ui-accent-2-soft: rgba(118, 140, 159, 0.12);
  --klsv-ui-accent-3: #EC4899;
  --klsv-ui-action-base: var(--klsv-brand-indigo);
  --klsv-ui-action-hover-base: #c3aa78;
  --klsv-ui-action-rgb: 89, 105, 92;
  --klsv-ui-action: var(--klsv-ui-action-base);
  --klsv-ui-action-hover: var(--klsv-ui-action-hover-base);
  --klsv-ui-action-gradient: linear-gradient(135deg, var(--klsv-brand-indigo), var(--klsv-brand-purple));
  --klsv-ui-action-soft: rgba(89, 105, 92, 0.14);
  --klsv-ui-action-wash: rgba(89, 105, 92, 0.10);
  --klsv-ui-action-border: rgba(141, 117, 85, 0.42);
  --klsv-nohero-mask-solid: #000;

  --klsv-ui-border: rgba(148, 163, 184, 0.16);
  --klsv-ui-border-strong: rgba(195, 170, 120, 0.30);
  --klsv-ui-border-soft: rgba(148, 163, 184, 0.10);
  --klsv-ui-border-accent: rgba(141, 117, 85, 0.34);
  --klsv-ui-border-muted: var(--klsv-ui-border-soft);


  --klsv-ui-surface-1: linear-gradient(180deg, rgba(21, 22, 43, 0.98), rgba(15, 16, 34, 0.96));
  --klsv-ui-surface-2: linear-gradient(180deg, rgba(29, 31, 58, 0.96), rgba(17, 24, 46, 0.94));
  --klsv-ui-surface-3: linear-gradient(180deg, rgba(17, 24, 46, 0.98), rgba(8, 8, 20, 0.98));
  --klsv-ui-surface-base: var(--klsv-ui-surface-3);
  --klsv-ui-surface-soft: rgba(141, 117, 85, 0.055);
  --klsv-ui-surface-subtle: rgba(89, 105, 92, 0.035);
  --klsv-ui-surface-wash-faint: rgba(89, 105, 92, 0.024);
  --klsv-ui-surface-wash-subtle: rgba(89, 105, 92, 0.036);
  --klsv-ui-surface-wash-muted: rgba(141, 117, 85, 0.050);
  --klsv-ui-surface-wash-soft: rgba(141, 117, 85, 0.070);
  --klsv-ui-surface-wash-hover: rgba(141, 117, 85, 0.105);
  --klsv-ui-surface-wash-hairline: rgba(89, 105, 92, 0.018);
  --klsv-ui-surface-wash-mid: rgba(141, 117, 85, 0.075);
  --klsv-ui-surface-shell-start: rgba(15, 16, 34, 0.96);
  --klsv-ui-surface-shell-end: rgba(8, 8, 20, 0.96);
  --klsv-ui-surface-card-start: rgba(21, 22, 43, 0.96);
  --klsv-ui-surface-card-end: rgba(15, 16, 34, 0.96);
  --klsv-ui-surface-card-deep-start: rgba(17, 24, 46, 0.98);
  --klsv-ui-surface-card-deep-end: rgba(8, 8, 20, 0.98);
  --klsv-ui-surface-line: rgba(141, 117, 85, 0.18);
  --klsv-ui-surface-sheen: rgba(195, 170, 120, 0.24);

  /* P2 shared panel language: Home, KL, Malaysia and detail pages use these tokens. */
  --klsv-ui-panel-bg: var(--klsv-ui-surface-1);
  --klsv-ui-panel-bg-soft: var(--klsv-ui-surface-2);
  --klsv-ui-panel-bg-subtle: var(--klsv-ui-surface-3);
  --klsv-ui-panel-border: var(--klsv-ui-border);
  --klsv-ui-panel-border-soft: var(--klsv-ui-border-soft);
  --klsv-ui-panel-border-accent: var(--klsv-ui-border-accent);
  --klsv-ui-panel-radius: var(--klsv-ui-radius-lg);
  --klsv-ui-panel-radius-compact: var(--klsv-ui-radius-md);
  --klsv-ui-panel-shadow: var(--klsv-ui-shadow-1);
  --klsv-ui-panel-shadow-soft: none;
  --klsv-ui-panel-grid: var(--klsv-nohero-grid, none);

  /* No-gray surface compatibility tokens */
  --klsv-no-gray-page-bg: var(--klsv-ui-bg);
  --klsv-no-gray-surface: var(--klsv-ui-surface-1);
  --klsv-no-gray-surface-soft: var(--klsv-ui-surface-2);
  --klsv-no-gray-card: var(--klsv-ui-surface-3);
  --klsv-no-gray-hover: rgba(141, 117, 85, 0.075);
  --klsv-no-gray-border: rgba(141, 117, 85, 0.22);

  --klsv-ui-region-n-bg: rgba(15, 110, 86, 0.22);
  --klsv-ui-region-n-text: #5DCAA5;
  --klsv-ui-region-n-border: rgba(15, 110, 86, 0.5);
  --klsv-ui-region-c-bg: rgba(83, 20, 135, 0.22);
  --klsv-ui-region-c-text: #AFA9EC;
  --klsv-ui-region-c-border: rgba(83, 74, 183, 0.55);
  --klsv-ui-region-s-bg: rgba(153, 33, 0, 0.22);
  --klsv-ui-region-s-text: #F0997B;
  --klsv-ui-region-s-border: rgba(153, 60, 29, 0.55);

  --klsv-ui-status-online: #1D9E75;
  --klsv-ui-status-online-glow: rgba(29, 158, 117, 0.6);
  --klsv-ui-whatsapp-bg: #25d366;
  --klsv-ui-whatsapp-bg-hover: #2ee875;
  --klsv-ui-text-on-dark: #fff;
  --klsv-ui-text-on-dark-soft: rgba(255, 255, 255, 0.88);

  --klsv-ui-gradient-gallery-card: var(--klsv-ui-surface-1);
  --klsv-ui-gradient-photo-overlay: linear-gradient(180deg, transparent, rgba(8, 8, 20, 0.78));
  --klsv-ui-gradient-photo-overlay-strong: linear-gradient(180deg, transparent, rgba(8, 8, 20, 0.86));
  --klsv-ui-gradient-profile-overlay: linear-gradient(to top, rgba(8, 8, 20, 0.88), rgba(8, 8, 20, 0.30) 70%, transparent);
  --klsv-ui-gradient-media-scrim: linear-gradient(180deg, rgba(8, 8, 20, 0.04), rgba(8, 8, 20, 0.56));
  --klsv-ui-gradient-thumb-scrim: linear-gradient(180deg, rgba(141, 117, 85, 0.020), rgba(8, 8, 20, 0.16));
  --klsv-ui-gradient-peer-overlay: linear-gradient(180deg, rgba(8, 8, 20, 0), rgba(8, 8, 20, 0.90));
  --klsv-ui-gradient-mobile-cta: linear-gradient(180deg, rgba(15, 16, 34, 0.96), rgba(8, 8, 20, 0.98));

  --klsv-ui-overlay-chip: rgba(11, 14, 19, 0.78);
  --klsv-ui-overlay-chip-strong: rgba(11, 14, 19, 0.8);
  --klsv-ui-overlay-count: rgba(11, 11, 13, 0.52);
  --klsv-ui-overlay-lightbox: rgba(5, 5, 7, 0.82);
  --klsv-ui-overlay-control: rgba(11, 11, 13, 0.86);
  --klsv-ui-overlay-control-hover: rgba(11, 11, 13, 0.96);
  --klsv-ui-overlay-deep: rgba(11, 11, 13, 0.92);
  --klsv-ui-overlay-soft-scrim-start: rgba(6, 8, 11, 0.02);
  --klsv-ui-overlay-soft-scrim-mid: rgba(6, 8, 11, 0.06);
  --klsv-ui-overlay-soft-scrim: rgba(6, 8, 11, 0.42);
  --klsv-ui-overlay-soft-scrim-strong: rgba(6, 8, 11, 0.5);
  --klsv-ui-overlay-thumb-scrim: rgba(7, 10, 14, 0.12);

  --klsv-ui-cream-surface-strong: rgba(255, 250, 243, 0.84);
  --klsv-ui-cream-surface: rgba(255, 250, 243, 0.78);
  --klsv-ui-cream-surface-soft: rgba(255, 250, 243, 0.72);
  --klsv-ui-cream-surface-faint: rgba(255, 250, 243, 0.54);
  --klsv-ui-cream-chip: rgba(255, 250, 243, 0.92);
  --klsv-ui-cream-surface-muted: rgba(255, 250, 243, 0.74);
  --klsv-ui-cream-surface-mid: rgba(255, 250, 243, 0.8);
  --klsv-ui-cream-surface-glow: rgba(255, 250, 243, 0.88);
  --klsv-ui-cream-surface-solid: rgba(255, 250, 243, 0.98);
  --klsv-ui-cream-surface-low: rgba(255, 250, 243, 0.66);
  --klsv-ui-cream-wash-start: rgba(246, 242, 234, 0.18);
  --klsv-ui-cream-wash-end: rgba(246, 242, 234, 0.72);
  --klsv-ui-cream-border: rgba(235, 227, 213, 0.88);
  --klsv-ui-table-head-bg: rgba(239, 232, 220, 0.86);
  --klsv-ui-media-placeholder: rgba(239, 232, 220, 0.72);
  --klsv-ui-peer-meta-text: rgba(245, 240, 232, 0.72);

  --klsv-ui-warm-glow: rgba(232, 184, 78, 0.4);
  --klsv-ui-olive-glow: rgba(124, 139, 122, 0.16);
  --klsv-ui-olive-glow-soft: rgba(124, 139, 122, 0.14);
  --klsv-ui-earth-glow: rgba(141, 117, 85, 0.14);
  --klsv-ui-earth-glow-soft: rgba(141, 117, 85, 0.12);
  --klsv-ui-earth-glow-strong: rgba(141, 117, 85, 0.16);
  --klsv-ui-olive-glow-faint: rgba(124, 139, 122, 0.1);
  --klsv-ui-olive-glow-muted: rgba(124, 139, 122, 0.12);
  --klsv-ui-accent-wash-faint: rgba(140, 163, 151, 0.1);
  --klsv-ui-accent-wash-soft: rgba(140, 163, 151, 0.12);
  --klsv-ui-accent-wash: rgba(140, 163, 151, 0.16);
  --klsv-ui-accent-2-wash-soft: rgba(118, 140, 159, 0.12);
  --klsv-ui-accent-2-wash: rgba(118, 140, 159, 0.16);
  --klsv-ui-muted-border-faint: rgba(71, 82, 74, 0.08);
  --klsv-ui-muted-border-soft: rgba(71, 82, 74, 0.12);
  --klsv-ui-map-glow: rgba(74, 163, 232, 0.08);
  --klsv-ui-map-glow-soft: rgba(74, 163, 232, 0.06);
  --klsv-ui-accent-2-glow: rgba(118, 140, 159, 0.14);
  --klsv-ui-accent-2-glow-soft: rgba(118, 140, 159, 0.1);

  --klsv-ui-font-display: "Fraunces", "Songti SC", "Noto Serif CJK SC", "Source Han Serif SC", Georgia, serif;
  --klsv-ui-font-body: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", sans-serif;
  --klsv-ui-font-mono: "JetBrains Mono", "SF Mono", ui-monospace, Menlo, Consolas, monospace;

  --klsv-font-display: var(--klsv-ui-font-display);
  --klsv-font-body: var(--klsv-ui-font-body);
  --klsv-font-mono: var(--klsv-ui-font-mono);

  --klsv-ui-heading-display: clamp(2.5rem, 2rem + 2.8vw, 4.75rem);
  --klsv-ui-hero-title-max: min(100%, 18ch);
  --klsv-ui-detail-title-max: min(100%, 20ch);
  --klsv-ui-title-max-mobile: min(100%, 18ch);
  --klsv-ui-micro-readable: 0.72rem;
  --klsv-ui-micro-compact-readable: 0.68rem;
  --klsv-ui-heading-xl: clamp(1.8rem, 1.45rem + 1.6vw, 2.7rem);
  --klsv-ui-heading-lg: clamp(1.3rem, 1.1rem + 0.8vw, 1.75rem);
  --klsv-ui-heading-md: 1.125rem;
  --klsv-ui-heading-sm: 1rem;
  --klsv-ui-body-lg: 1.05rem;
  --klsv-ui-body-md: 0.975rem;
  --klsv-ui-body-sm: 0.875rem;
  --klsv-ui-body: var(--klsv-ui-body-md);
  --klsv-ui-body-xs: 0.75rem;
  --klsv-ui-caption-size: var(--klsv-ui-body-xs);
  --klsv-ui-eyebrow-size: 12px;

  --klsv-ui-weight-regular: 400;
  --klsv-ui-weight-medium: 500;
  --klsv-ui-weight-semibold: 600;
  --klsv-ui-weight-bold: 700;

  --klsv-ui-leading-tight: 1.18;
  --klsv-ui-leading-snug: 1.35;
  --klsv-ui-leading-normal: 1.62;
  --klsv-ui-leading-relaxed: 1.74;

  --klsv-ui-tracking-tight: -0.02em;
  --klsv-ui-tracking-wide: 0.04em;
  --klsv-ui-tracking-eyebrow: 0.1em;

  --klsv-ui-space-3xs: 2px;
  --klsv-ui-space-2xs: 4px;
  --klsv-ui-space-xs: 8px;
  --klsv-ui-space-sm: 12px;
  --klsv-ui-space-md: 16px;
  --klsv-ui-space-lg: 24px;
  --klsv-ui-space-xl: 32px;
  --klsv-ui-space-2xl: 48px;
  --klsv-ui-space-3xl: 64px;
  --klsv-ui-space-4xl: 96px;
  --klsv-ui-section-gap: clamp(28px, 4vw, 56px);
  --klsv-ui-card-gap: var(--klsv-ui-space-md);
  --klsv-ui-compact-gap: var(--klsv-ui-space-sm);
  --klsv-ui-muted-copy: var(--klsv-ui-text-faint);
  --klsv-ui-compact-radius: var(--klsv-ui-radius-lg);

  --klsv-ui-radius-xs: 6px;
  --klsv-ui-radius-sm: 8px;
  --klsv-ui-radius-md: 14px;
  --klsv-ui-radius-lg: 20px;
  --klsv-ui-radius-xl: 28px;
  --klsv-ui-radius-2xl: 32px;
  --klsv-ui-radius-pill: 999px;

  --klsv-ui-shadow-1: 0 14px 30px rgba(0, 0, 0, 0.18);
  --klsv-ui-shadow-2: 0 22px 52px rgba(0, 0, 0, 0.28);
  --klsv-ui-shadow-3: 0 30px 70px rgba(0, 0, 0, 0.36);
  --klsv-ui-shadow-soft: 0 18px 42px rgba(0, 0, 0, 0.22);
  --klsv-ui-shadow-card: 0 0 0 1px rgba(255, 250, 243, 0.07), 0 10px 24px rgba(0, 0, 0, 0.18), 0 22px 58px rgba(0, 0, 0, 0.28);
  --klsv-ui-shadow-card-hover: 0 0 0 1px rgba(255, 250, 243, 0.11), 0 16px 34px rgba(0, 0, 0, 0.22), 0 30px 70px rgba(0, 0, 0, 0.34);
  --klsv-ui-shadow-action: 0 12px 26px rgba(195, 170, 120, 0.2);
  --klsv-ui-focus-ring: var(--klsv-ui-accent-strong);
  --klsv-ui-shadow-color-strong: rgba(0, 0, 0, 0.34);
  --klsv-ui-shadow-color-md: rgba(0, 0, 0, 0.26);
  --klsv-ui-shadow-color-soft: rgba(0, 0, 0, 0.22);

  --klsv-ui-duration-fast: 120ms;
  --klsv-ui-duration-instant: 1ms;
  --klsv-ui-duration-normal: 220ms;
  --klsv-ui-duration-slow: 360ms;

  --klsv-ui-ease-smooth: cubic-bezier(0.2, 0.6, 0.2, 1);
  --klsv-ui-ease-out-soft: cubic-bezier(0.16, 1, 0.3, 1);
  --klsv-ui-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  --klsv-ui-ease: var(--klsv-ui-ease-smooth);
  --klsv-ui-ease-standard: var(--klsv-ui-ease-in-out);
  --klsv-ui-transition: var(--klsv-ui-duration-fast) ease-out;

  /* Batch 13 motion/material primitives. */
  --klsv-motion-fast: 160ms;
  --klsv-motion-normal: 240ms;
  --klsv-motion-slow: 480ms;
  --klsv-motion-soft-loop: 5200ms;
  --klsv-motion-luxe: var(--klsv-ui-ease-out-soft);
  --klsv-glow-primary: 0 0 24px rgba(var(--klsv-ui-action-rgb), 0.22);
  --klsv-glow-soft: 0 0 48px rgba(var(--klsv-ui-action-rgb), 0.12);
  --klsv-glow-border: 0 0 0 1px rgba(var(--klsv-ui-action-rgb), 0.18);
  --klsv-surface-noise-opacity: 0.032;
  --klsv-surface-noise-size: 180px;

  --klsv-ui-z-base: 1;
  --klsv-ui-z-sticky: 50;
  --klsv-ui-z-navbar: 100;
  --klsv-ui-z-overlay: 200;
  --klsv-ui-z-modal: 300;
  --klsv-ui-z-toast: 400;

  --klsv-ui-shell-max: 1400px;
  --klsv-ui-shell-gutter: 24px;
  --klsv-ui-shell-narrow: 780px;
  --klsv-ui-header-height: 74px;
  --klsv-ui-mobile-cta-height: 82px;

  --klsv-ui-touch-target-min: 44px;
  --klsv-ui-touch-target-comfortable: 50px;
  --klsv-ui-touch-gap-min: 8px;
  --klsv-ui-focus-ring-width: 2px;
  --klsv-ui-control-height-sm: 36px;
  --klsv-ui-control-height-md: var(--klsv-ui-touch-target-min);
  --klsv-ui-control-height-lg: 48px;
  --klsv-ui-control-padding-x: 14px;
  --klsv-ui-control-padding-x-lg: 16px;
  --klsv-ui-link-pill-height: var(--klsv-ui-control-height-md);
  --klsv-ui-chip-height: 32px;
  --klsv-ui-badge-height: 28px;
  --klsv-ui-select-height: var(--klsv-ui-control-height-md);
  --klsv-ui-control-font-size: 0.78rem;
  --klsv-ui-control-font-size-sm: 0.72rem;
  --klsv-ui-chip-font-size: var(--klsv-ui-body-xs);
  --klsv-ui-control-tracking: 0.08em;
  --klsv-content-state-compact-gap: var(--klsv-ui-space-sm);
  --klsv-content-state-compact-padding: clamp(14px, 1.7vw, 20px);
  --klsv-content-state-compact-radius: var(--klsv-ui-panel-radius-compact);
  --klsv-content-state-compact-border: var(--klsv-ui-panel-border);
  --klsv-content-state-compact-bg: var(--klsv-ui-panel-bg);
  --klsv-content-state-compact-heading-size: clamp(1rem, 1.25vw, 1.18rem);
  --klsv-content-state-compact-copy-size: clamp(0.82rem, 1vw, 0.92rem);
  --klsv-ui-card-media-ratio: 3 / 4;
  --klsv-ui-critical-content-opacity: 1;
  --klsv-ui-motion-fail-safe-delay: 900ms;

  /* Batch 11: public UI color and typography roles. */
  --klsv-color-action-primary: var(--klsv-ui-action-base);
  --klsv-color-action-primary-hover: var(--klsv-ui-action-hover-base);
  --klsv-color-action-primary-rgb: var(--klsv-ui-action-rgb);
  --klsv-color-ambient-accent: var(--klsv-ui-accent);
  --klsv-color-ambient-accent-strong: var(--klsv-ui-accent-strong);
  --klsv-color-ambient-accent-soft: var(--klsv-ui-accent-soft);
  --klsv-color-whatsapp-action: var(--klsv-ui-whatsapp-bg);
  --klsv-color-whatsapp-action-hover: var(--klsv-ui-whatsapp-bg-hover);
  --klsv-color-text-primary: var(--klsv-ui-text);
  --klsv-color-text-strong: var(--klsv-ui-text-strong);
  --klsv-color-text-secondary: var(--klsv-ui-text-soft);
  --klsv-color-text-muted: var(--klsv-ui-text-faint);
  --klsv-color-border-subtle: var(--klsv-ui-border);
  --klsv-color-border-strong: var(--klsv-ui-border-strong);
  --klsv-type-hero-title: var(--klsv-ui-heading-display);
  --klsv-type-page-title: clamp(2rem, 1.35rem + 3vw, 3.75rem);
  --klsv-type-section-title: var(--klsv-ui-heading-xl);
  --klsv-type-panel-title: var(--klsv-ui-heading-lg);
  --klsv-type-card-title-system: clamp(1rem, .94rem + .35vw, 1.14rem);
  --klsv-type-body-system: var(--klsv-ui-body-md);
  --klsv-type-body-small-system: var(--klsv-ui-body-sm);
  --klsv-type-meta-system: var(--klsv-ui-body-xs);


  /* Compatibility aliases for existing CSS */
  --bg-primary: var(--klsv-ui-bg);
  --bg-base: var(--klsv-ui-bg);
  --bg-secondary: var(--klsv-ui-bg-soft);
  --bg-tertiary: var(--klsv-ui-bg-muted);
  --bg-surface: rgba(195, 170, 120, 0.035);
  --bg-elevated: rgba(27, 33, 43, 0.92);

  --border-color: var(--klsv-ui-border);
  --border-color-hover: rgba(243, 239, 231, 0.28);
  --border-color-strong: var(--klsv-ui-border-strong);
  --border-color-focus: rgba(140, 163, 151, 0.36);

  --text-primary: var(--klsv-ui-text);
  --text-secondary: var(--klsv-ui-text-soft);
  --text-muted: var(--klsv-ui-text-muted);
  --text-subtle: var(--klsv-ui-text-faint);
  --text-inverse: #020707;

  --accent-primary: var(--klsv-ui-accent);
  --accent-primary-hi: var(--klsv-ui-accent-strong);
  --accent-primary-lo: #697f74;
  --accent-primary-bg: var(--klsv-ui-accent-soft);
  --accent-primary-ink: #020707;
  --accent-secondary: var(--klsv-ui-accent-2);

  --accent-green: #79a289;
  --accent-green-soft: rgba(121, 162, 137, 0.16);
  --accent-green-dim: rgba(121, 162, 137, 0.08);
  --accent-purple-soft: rgba(118, 140, 159, 0.16);
  --accent-danger: #b87f89;

  --gradient-cta: linear-gradient(135deg, #bccdc4 0%, #93aa9e 46%, #768d82 100%);

  --font-display: var(--klsv-ui-font-display);
  --font-ui: var(--klsv-ui-font-body);
  --font-mono: var(--klsv-ui-font-mono);

  --text-micro: 0.72rem;
  --text-small: 0.8125rem;
  --text-body: var(--klsv-ui-body-md);
  --text-lead: var(--klsv-ui-body-lg);
  --text-h4: var(--klsv-ui-heading-md);
  --text-h3: clamp(1.125rem, 1.02rem + 0.4vw, 1.35rem);
  --text-h2: var(--klsv-ui-heading-xl);
  --text-h1: clamp(2rem, 1.5rem + 1.9vw, 3.2rem);
  --text-display: var(--klsv-ui-heading-display);

  --weight-regular: var(--klsv-ui-weight-regular);
  --weight-medium: var(--klsv-ui-weight-medium);
  --weight-semibold: var(--klsv-ui-weight-semibold);
  --weight-bold: var(--klsv-ui-weight-bold);

  --leading-tight: var(--klsv-ui-leading-tight);
  --leading-snug: var(--klsv-ui-leading-snug);
  --leading-normal: var(--klsv-ui-leading-normal);
  --leading-relaxed: var(--klsv-ui-leading-relaxed);

  --tracking-tight: var(--klsv-ui-tracking-tight);
  --tracking-wide: var(--klsv-ui-tracking-wide);
  --tracking-eyebrow: var(--klsv-ui-tracking-eyebrow);

  --space-3xs: var(--klsv-ui-space-3xs);
  --space-2xs: var(--klsv-ui-space-2xs);
  --space-xs: var(--klsv-ui-space-xs);
  --space-sm: var(--klsv-ui-space-sm);
  --space-md: var(--klsv-ui-space-md);
  --space-lg: var(--klsv-ui-space-lg);
  --space-xl: var(--klsv-ui-space-xl);
  --space-2xl: var(--klsv-ui-space-2xl);
  --space-3xl: var(--klsv-ui-space-3xl);
  --space-4xl: var(--klsv-ui-space-4xl);

  --radius-sm: var(--klsv-ui-radius-xs);
  --radius-md: var(--klsv-ui-radius-sm);
  --radius-lg: var(--klsv-ui-radius-md);
  --radius-xl: var(--klsv-ui-radius-lg);
  --radius-2xl: var(--klsv-ui-radius-xl);
  --radius-full: var(--klsv-ui-radius-pill);

  --shadow-sm: 0 10px 22px rgba(0, 0, 0, 0.18);
  --shadow-md: var(--klsv-ui-shadow-1);
  --shadow-lg: var(--klsv-ui-shadow-2);
  --shadow-focus: 0 0 0 3px rgba(140, 163, 151, 0.18);
  --shadow-glow: 0 24px 56px rgba(140, 163, 151, 0.2);
  --shadow-soft: var(--klsv-ui-shadow-soft);

  --duration-fast: var(--klsv-ui-duration-fast);
  --duration-normal: var(--klsv-ui-duration-normal);
  --duration-slow: var(--klsv-ui-duration-slow);

  --ease-smooth: var(--klsv-ui-ease-smooth);
  --ease-out-soft: var(--klsv-ui-ease-out-soft);
  --ease-in-out: var(--klsv-ui-ease-in-out);

  --z-base: var(--klsv-ui-z-base);
  --z-sticky: var(--klsv-ui-z-sticky);
  --z-navbar: var(--klsv-ui-z-navbar);
  --z-overlay: var(--klsv-ui-z-overlay);
  --z-modal: var(--klsv-ui-z-modal);
  --z-toast: var(--klsv-ui-z-toast);

  --shell-max: var(--klsv-ui-shell-max);
  --shell-gutter: var(--klsv-ui-shell-gutter);
  --shell-narrow: var(--klsv-ui-shell-narrow);
  --header-height: var(--klsv-ui-header-height);
  --mobile-cta-height: var(--klsv-ui-mobile-cta-height);
  --control-height-sm: var(--klsv-ui-control-height-sm);
  --control-height: var(--klsv-ui-control-height-md);
  --control-height-lg: var(--klsv-ui-control-height-lg);
  --link-pill-height: var(--klsv-ui-link-pill-height);
  --chip-height: var(--klsv-ui-chip-height);
  --select-height: var(--klsv-ui-select-height);
}

body.scope-malaysia-city {
  --klsv-ui-accent: var(--klsv-brand-purple);
  --klsv-ui-accent-strong: var(--klsv-brand-purple-soft);
  --klsv-ui-accent-soft: rgba(141, 117, 85, 0.14);
  --klsv-ui-border-accent: rgba(141, 117, 85, 0.34);

  --accent-primary: var(--klsv-ui-accent);
  --accent-primary-hi: var(--klsv-ui-accent-strong);
  --accent-primary-lo: var(--klsv-brand-indigo);
  --accent-primary-bg: var(--klsv-ui-accent-soft);
  --border-color-focus: var(--klsv-ui-border-accent);
  --shadow-focus: 0 0 0 3px rgba(141, 117, 85, 0.18);
  --shadow-glow: 0 18px 42px rgba(141, 117, 85, 0.2);
  --gradient-cta: linear-gradient(135deg, var(--klsv-brand-indigo) 0%, var(--klsv-brand-purple) 62%, var(--klsv-brand-purple-soft) 100%);

  --klsv-nohero-mask-solid: #000;
  --klsv-nohero-page-field: linear-gradient(rgba(195, 170, 120, 0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(195, 170, 120, 0.026) 1px, transparent 1px), radial-gradient(circle at 78% 18%, rgba(140, 163, 151, 0.18), transparent 28rem), radial-gradient(circle at 18% 84%, rgba(195, 170, 120, 0.08), transparent 24rem);
  --klsv-nohero-signal-map-bg: radial-gradient(circle, transparent 0 30%, rgba(243, 239, 231, 0.055) 31% 32%, transparent 33% 49%, rgba(243, 239, 231, 0.045) 50% 51%, transparent 52%), conic-gradient(from 210deg, rgba(140, 163, 151, 0.22), transparent 28%, rgba(195, 170, 120, 0.12), transparent 62%, rgba(118, 140, 159, 0.12), transparent);
  --klsv-nohero-hero-bg: linear-gradient(135deg, rgba(17, 22, 30, 0.98), rgba(8, 11, 16, 0.96));
  --klsv-nohero-hero-scan: linear-gradient(90deg, rgba(243, 239, 231, 0.05), transparent 18% 82%, rgba(243, 239, 231, 0.04)), repeating-linear-gradient(180deg, rgba(195, 170, 120, 0.03) 0 1px, transparent 1px 8px);
  --klsv-nohero-hero-panel-bg: linear-gradient(135deg, transparent 0 48%, rgba(140, 163, 151, 0.16) 49% 50%, transparent 51%), radial-gradient(circle at 72% 24%, rgba(140, 163, 151, 0.22), transparent 5px), radial-gradient(circle at 34% 48%, rgba(195, 170, 120, 0.18), transparent 5px), radial-gradient(circle at 62% 72%, rgba(118, 140, 159, 0.18), transparent 5px);
  --klsv-nohero-region-bg: linear-gradient(180deg, rgba(18, 23, 30, 0.72), rgba(8, 11, 16, 0.82));
  --klsv-nohero-region-scan: linear-gradient(90deg, rgba(243, 239, 231, 0.04), transparent 22%), repeating-linear-gradient(180deg, transparent 0 11px, rgba(195, 170, 120, 0.016) 12px);
  --klsv-nohero-card-bg: linear-gradient(180deg, rgba(195, 170, 120, 0.04), rgba(255, 255, 255, 0.018));
  --klsv-nohero-card-hover-bg: linear-gradient(180deg, rgba(140, 163, 151, 0.09), rgba(255, 255, 255, 0.024));
  --klsv-nohero-card-sheen: linear-gradient(115deg, transparent 0 42%, rgba(243, 239, 231, 0.08) 48%, transparent 54%);
  --klsv-nohero-border-weak: rgba(243, 239, 231, 0.08);
  --klsv-nohero-border-soft: rgba(243, 239, 231, 0.1);
  --klsv-nohero-border-mid: rgba(243, 239, 231, 0.14);
  --klsv-nohero-border-strong: rgba(243, 239, 231, 0.34);
  --klsv-nohero-border-accent: rgba(140, 163, 151, 0.42);
  --klsv-nohero-border-accent-soft: rgba(140, 163, 151, 0.28);
  --klsv-nohero-border-accent-mid: rgba(140, 163, 151, 0.38);
  --klsv-nohero-surface-deep: rgba(6, 9, 13, 0.62);
  --klsv-nohero-surface-tab: rgba(7, 10, 15, 0.72);
  --klsv-nohero-surface-quiet: rgba(195, 170, 120, 0.026);
  --klsv-nohero-surface-cell: rgba(195, 170, 120, 0.03);
  --klsv-nohero-surface-accent: rgba(140, 163, 151, 0.1);
  --klsv-nohero-surface-accent-soft: rgba(140, 163, 151, 0.08);
  --klsv-nohero-text-soft: rgba(243, 239, 231, 0.74);
  --klsv-nohero-text-muted: rgba(243, 239, 231, 0.68);
  --klsv-nohero-text-faint: rgba(243, 239, 231, 0.62);
  --klsv-nohero-text-dim: rgba(243, 239, 231, 0.58);
  --klsv-nohero-text-ghost: rgba(243, 239, 231, 0.54);
  --klsv-nohero-text-disabled: rgba(243, 239, 231, 0.5);
  --klsv-nohero-action-text: #10141a;
  --klsv-nohero-signal-glow: 0 0 0 5px rgba(140, 163, 151, 0.1), 0 0 22px rgba(140, 163, 151, 0.55);
  --klsv-nohero-signal-action-glow: 0 0 0 5px rgba(195, 170, 120, 0.1), 0 0 22px rgba(195, 170, 120, 0.42);
  --klsv-nohero-hero-shadow: 0 0 0 1px rgba(243, 239, 231, 0.07), 0 26px 70px rgba(0, 0, 0, 0.36);
}

@media (prefers-reduced-motion: reduce) {
  :root {
    --klsv-ui-duration-fast: 1ms;
    --klsv-ui-duration-normal: 1ms;
    --klsv-ui-duration-slow: 1ms;
    --duration-fast: var(--klsv-ui-duration-fast);
    --duration-normal: var(--klsv-ui-duration-normal);
    --duration-slow: var(--klsv-ui-duration-slow);
  }
}


/* No Hero target pass: terminal HUD tokens. */
:root {
  --klsv-nohero-black: #030506;
  --klsv-nohero-bg: #06090c;
  --klsv-nohero-bg-2: #090d11;
  --klsv-nohero-panel: rgba(6, 10, 13, 0.9);
  --klsv-nohero-panel-soft: rgba(12, 18, 23, 0.86);
  --klsv-nohero-panel-faint: rgba(195, 170, 120, 0.016);
  --klsv-nohero-line: rgba(195, 170, 120, 0.18);
  --klsv-nohero-line-strong: rgba(195, 170, 120, 0.42);
  --klsv-nohero-line-faint: rgba(195, 170, 120, 0.08);
  --klsv-nohero-white: #edf8f2;
  --klsv-nohero-muted: rgba(237, 248, 242, 0.64);
  --klsv-nohero-faint: rgba(237, 248, 242, 0.38);
  --klsv-nohero-green: #c3aa78;
  --klsv-nohero-green-soft: rgba(195, 170, 120, 0.14);
  --klsv-nohero-green-glow: rgba(195, 170, 120, 0.38);
  --klsv-nohero-cyan: #768c9f;
  --klsv-nohero-cyan-soft: rgba(118, 140, 159, 0.14);
  --klsv-nohero-amber: #ffe06d;
  --klsv-nohero-red: #ff315c;
  --klsv-nohero-red-soft: rgba(255, 49, 92, 0.16);
  --klsv-nohero-map-wash: rgba(195, 170, 120, 0.06);
  --klsv-nohero-card-wash: linear-gradient(180deg, rgba(5, 22, 16, 0.96), rgba(1, 8, 8, 0.98));
  --klsv-nohero-card-wash-hover: linear-gradient(180deg, rgba(20, 32, 38, 0.98), rgba(5, 9, 11, 0.98));
  --klsv-nohero-grid: linear-gradient(var(--klsv-nohero-line-faint) 1px, transparent 1px), linear-gradient(90deg, var(--klsv-nohero-line-faint) 1px, transparent 1px);
  --klsv-nohero-scan: linear-gradient(90deg, transparent, var(--klsv-nohero-green-soft), transparent);
  --klsv-nohero-map-rings: radial-gradient(circle, transparent 0 27%, var(--klsv-nohero-line-faint) 28% 29%, transparent 30% 46%, var(--klsv-nohero-line-faint) 47% 48%, transparent 49% 64%, var(--klsv-nohero-line-faint) 65% 66%, transparent 67%);
  --klsv-nohero-font-ui: "JetBrains Mono", "SF Mono", ui-monospace, Menlo, Consolas, monospace;

  /* KL latest video rail tokens.
     Keep KL on the default :root scope; do not introduce a KL body scope. */
  --klsv-ui-kl-video-copy-margin-top: var(--klsv-ui-space-xs);
  --klsv-ui-kl-video-copy-font-size: 0.78rem;
  --klsv-ui-kl-video-copy-line-height: 1.55;
  --klsv-ui-kl-video-rail-columns: clamp(220px, 24vw, 292px);
  --klsv-ui-kl-video-rail-gap: clamp(14px, 1.6vw, 18px);
  --klsv-ui-kl-video-rail-padding-end: var(--klsv-ui-space-xs);
  --klsv-ui-kl-video-card-surface: linear-gradient(180deg, rgba(6, 20, 17, 0.96), rgba(3, 10, 9, 0.98));
  --klsv-ui-kl-video-card-grid: var(--klsv-nohero-grid);
  --klsv-ui-kl-video-media-bg: #020504;
  --klsv-ui-kl-video-badge-inset: 9px;
  --klsv-ui-kl-video-badge-min-height: 22px;
  --klsv-ui-kl-video-badge-padding-x: var(--klsv-ui-space-xs);
  --klsv-ui-kl-video-badge-font-size: 0.54rem;
  --klsv-ui-kl-video-body-gap: var(--klsv-ui-space-xs);
  --klsv-ui-kl-video-body-padding: 12px 13px 14px;
  --klsv-ui-kl-video-name-font-size: 1rem;
  --klsv-ui-kl-video-meta-font-size: 0.72rem;
  --klsv-ui-kl-video-link-gap: 7px;
  --klsv-ui-kl-video-link-min-height: var(--klsv-ui-link-pill-height);
  --klsv-ui-kl-video-link-padding-x: 10px;
  --klsv-ui-kl-video-link-font-size: 0.6rem;
  --klsv-ui-kl-video-mobile-head-gap: var(--klsv-ui-space-sm);
  --klsv-ui-kl-video-mobile-copy-font-size: 0.72rem;
  --klsv-ui-kl-video-mobile-columns: minmax(214px, 72vw);
  --klsv-ui-kl-video-mobile-gap: var(--klsv-ui-space-sm);
  --klsv-ui-kl-video-mobile-body-gap: 7px;
  --klsv-ui-kl-video-mobile-body-padding: 11px 12px 13px;
  --klsv-ui-kl-video-mobile-name-font-size: 0.94rem;
  --klsv-ui-kl-video-mobile-meta-font-size: 0.68rem;
  --klsv-ui-kl-video-mobile-link-min-height: var(--klsv-ui-link-pill-height);
  --klsv-ui-kl-video-mobile-link-padding-x: 9px;
  --klsv-ui-kl-video-mobile-link-font-size: 0.56rem;
  --klsv-ui-kl-video-narrow-columns: minmax(204px, 74vw);


  --klsv-ui-bg: var(--klsv-nohero-bg);
  --klsv-ui-bg-soft: var(--klsv-nohero-bg-2);
  --klsv-ui-bg-muted: #0d1318;
  --klsv-ui-bg-hero: var(--klsv-nohero-bg);
  --klsv-ui-text: var(--klsv-nohero-white);
  --klsv-ui-text-strong: var(--klsv-nohero-white);
  --klsv-ui-text-soft: var(--klsv-nohero-muted);
  --klsv-ui-text-faint: var(--klsv-nohero-faint);
  --klsv-ui-text-muted: var(--klsv-nohero-faint);
  --klsv-ui-accent: var(--klsv-nohero-green);
  --klsv-ui-accent-strong: var(--klsv-nohero-green);
  --klsv-ui-accent-soft: var(--klsv-nohero-green-soft);
  --klsv-ui-accent-glow: var(--klsv-nohero-green-glow);
  --klsv-ui-accent-2: var(--klsv-nohero-cyan);
  --klsv-ui-accent-2-soft: var(--klsv-nohero-cyan-soft);
  --klsv-ui-action: var(--klsv-ui-action-base);
  --klsv-ui-action-hover: var(--klsv-ui-action-hover-base);
  --klsv-ui-action-soft: rgba(var(--klsv-ui-action-rgb), 0.14);
  --klsv-ui-action-wash: rgba(var(--klsv-ui-action-rgb), 0.11);
  --klsv-ui-action-border: rgba(var(--klsv-ui-action-rgb), 0.42);
  --klsv-ui-border: var(--klsv-nohero-line);
  --klsv-ui-border-strong: var(--klsv-nohero-line-strong);
  --klsv-ui-border-soft: var(--klsv-nohero-line-faint);
  --klsv-ui-border-accent: var(--klsv-nohero-line-strong);
  --klsv-ui-surface-1: var(--klsv-nohero-card-wash);
  --klsv-ui-surface-2: var(--klsv-nohero-card-wash);
  --klsv-ui-surface-3: linear-gradient(180deg, rgba(8, 13, 17, 0.96), rgba(3, 5, 7, 0.98));
  --klsv-ui-surface-soft: var(--klsv-nohero-panel-faint);
  --klsv-ui-surface-wash-faint: var(--klsv-nohero-panel-faint);
  --klsv-ui-surface-wash-subtle: var(--klsv-nohero-panel-faint);
  --klsv-ui-surface-wash-muted: rgba(195, 170, 120, 0.035);
  --klsv-ui-surface-wash-soft: rgba(195, 170, 120, 0.045);
  --klsv-ui-surface-wash-hover: rgba(195, 170, 120, 0.09);
  --klsv-ui-overlay-chip: rgba(2, 5, 6, 0.82);
  --klsv-ui-overlay-chip-strong: rgba(2, 5, 6, 0.9);
  --klsv-ui-overlay-deep: rgba(2, 5, 6, 0.94);
  --klsv-ui-cream-chip: var(--klsv-nohero-green);
  --klsv-ui-font-display: var(--klsv-nohero-font-ui);
  --klsv-ui-font-body: var(--klsv-nohero-font-ui);
  --klsv-ui-font-mono: var(--klsv-nohero-font-ui);
  --klsv-font-display: var(--klsv-nohero-font-ui);
  --klsv-font-body: var(--klsv-nohero-font-ui);
  --klsv-font-mono: var(--klsv-nohero-font-ui);
  --klsv-ui-heading-display: clamp(3rem, 2.2rem + 3.6vw, 5.6rem);
  --klsv-ui-heading-xl: clamp(1.9rem, 1.4rem + 2vw, 3.2rem);
  --klsv-ui-heading-lg: clamp(1.25rem, 1.05rem + 0.9vw, 1.8rem);
  --klsv-ui-body-lg: 1rem;
  --klsv-ui-body-md: 0.875rem;
  --klsv-ui-body-sm: 0.75rem;
  --klsv-ui-eyebrow-size: 0.68rem;
  --klsv-ui-leading-tight: 0.95;
  --klsv-ui-leading-normal: 1.45;
  --klsv-ui-leading-relaxed: 1.75;
  --klsv-ui-radius-xs: 2px;
  --klsv-ui-radius-sm: 3px;
  --klsv-ui-radius-md: 4px;
  --klsv-ui-radius-lg: 6px;
  --klsv-ui-radius-xl: 8px;
  --klsv-ui-radius-2xl: 10px;
  --klsv-ui-radius-pill: 2px;
  --klsv-ui-shell-max: 1504px;
  --klsv-ui-shell-gutter: 20px;
  --klsv-ui-header-height: 76px;
  --klsv-ui-shadow-1: 0 0 0 1px var(--klsv-nohero-line-faint), 0 18px 44px rgba(0, 0, 0, 0.34);
  --klsv-ui-shadow-2: 0 0 0 1px var(--klsv-nohero-line), 0 24px 72px rgba(0, 0, 0, 0.42);
  --klsv-ui-shadow-3: 0 0 0 1px var(--klsv-nohero-line-strong), 0 40px 120px rgba(0, 0, 0, 0.55);
  --shadow-glow: 0 0 26px var(--klsv-nohero-green-glow);
}

body.scope-malaysia-city {
  --klsv-ui-accent: var(--klsv-brand-purple);
  --klsv-ui-accent-strong: var(--klsv-brand-purple-soft);
  --klsv-ui-accent-soft: rgba(141, 117, 85, 0.14);
  --klsv-ui-border-accent: rgba(141, 117, 85, 0.34);
}


/* Design system foundation tokens.
   Stable aliases for future page/component migrations.
   These tokens intentionally map to the current KLSV UI system instead of
   introducing a separate visual language. */
:root {
  --klsv-ds-bg-page: var(--klsv-ui-bg);
  --klsv-ds-bg-page-soft: var(--klsv-ui-bg-soft);
  --klsv-ds-surface: var(--klsv-ui-surface-1);
  --klsv-ds-surface-strong: var(--klsv-ui-surface-2);
  --klsv-ds-surface-muted: var(--klsv-ui-surface-soft);
  --klsv-ds-surface-hover: var(--klsv-ui-surface-wash-hover);

  --klsv-ds-text: var(--klsv-ui-text);
  --klsv-ds-text-strong: var(--klsv-ui-text-strong);
  --klsv-ds-text-soft: var(--klsv-ui-text-soft);
  --klsv-ds-text-muted: var(--klsv-ui-text-muted);
  --klsv-ds-accent: var(--klsv-ui-accent);
  --klsv-ds-accent-strong: var(--klsv-ui-accent-strong);
  --klsv-ds-accent-soft: var(--klsv-ui-accent-soft);
  --klsv-ds-action: var(--klsv-ui-action);
  --klsv-ds-action-hover: var(--klsv-ui-action-hover);

  --klsv-ds-border: var(--klsv-ui-border);
  --klsv-ds-border-soft: var(--klsv-ui-border-soft);
  --klsv-ds-border-strong: var(--klsv-ui-border-strong);
  --klsv-ds-border-accent: var(--klsv-ui-border-accent);

  --klsv-ds-font-display: var(--klsv-ui-font-display);
  --klsv-ds-font-body: var(--klsv-ui-font-body);
  --klsv-ds-font-mono: var(--klsv-ui-font-mono);

  --klsv-ds-heading-hero: var(--klsv-ui-heading-display);
  --klsv-ds-heading-xl: var(--klsv-ui-heading-xl);
  --klsv-ds-heading-lg: var(--klsv-ui-heading-lg);
  --klsv-ds-heading-md: var(--klsv-ui-heading-md);
  --klsv-ds-body-lg: var(--klsv-ui-body-lg);
  --klsv-ds-body-md: var(--klsv-ui-body-md);
  --klsv-ds-body-sm: var(--klsv-ui-body-sm);
  --klsv-ds-body-xs: var(--klsv-ui-body-xs);
  --klsv-ds-eyebrow-size: var(--klsv-ui-eyebrow-size);

  --klsv-ds-leading-tight: var(--klsv-ui-leading-tight);
  --klsv-ds-leading-normal: var(--klsv-ui-leading-normal);
  --klsv-ds-leading-relaxed: var(--klsv-ui-leading-relaxed);
  --klsv-ds-tracking-tight: var(--klsv-ui-tracking-tight);
  --klsv-ds-tracking-eyebrow: var(--klsv-ui-tracking-eyebrow);

  --klsv-ds-space-2xs: var(--klsv-ui-space-2xs);
  --klsv-ds-space-xs: var(--klsv-ui-space-xs);
  --klsv-ds-space-sm: var(--klsv-ui-space-sm);
  --klsv-ds-space-md: var(--klsv-ui-space-md);
  --klsv-ds-space-lg: var(--klsv-ui-space-lg);
  --klsv-ds-space-xl: var(--klsv-ui-space-xl);
  --klsv-ds-space-2xl: var(--klsv-ui-space-2xl);
  --klsv-ds-section-gap: var(--klsv-ui-section-gap);

  --klsv-ds-radius-sm: var(--klsv-ui-radius-sm);
  --klsv-ds-radius-md: var(--klsv-ui-radius-md);
  --klsv-ds-radius-lg: var(--klsv-ui-radius-lg);
  --klsv-ds-radius-xl: var(--klsv-ui-radius-xl);
  --klsv-ds-radius-2xl: var(--klsv-ui-radius-2xl);
  --klsv-ds-radius-pill: var(--klsv-ui-radius-pill);

  --klsv-ds-shadow-card: var(--klsv-ui-shadow-card);
  --klsv-ds-shadow-card-hover: var(--klsv-ui-shadow-card-hover);
  --klsv-ds-shadow-panel: var(--klsv-ui-shadow-2);

  --klsv-ds-shell-max: var(--klsv-ui-shell-max);
  --klsv-ds-shell-gutter: var(--klsv-ui-shell-gutter);
  --klsv-ds-shell-width: min(var(--klsv-ds-shell-max), calc(100vw - var(--klsv-ds-shell-gutter) * 2));

  --klsv-ds-tap-target: var(--klsv-ui-touch-target-min);
  --klsv-ds-control-height: var(--klsv-ui-control-height-md);
  --klsv-ds-link-pill-height: var(--klsv-ui-link-pill-height);
  --klsv-ds-chip-height: var(--klsv-ui-chip-height);
  --klsv-ds-select-height: var(--klsv-ui-select-height);
  --klsv-ds-card-ratio: 3 / 4;
  --klsv-ds-photo-fit: cover;
  --klsv-ds-viewer-fit: contain;

  --klsv-ds-duration-fast: var(--klsv-ui-duration-fast);
  --klsv-ds-duration-normal: var(--klsv-ui-duration-normal);
  --klsv-ds-ease: var(--klsv-ui-ease-smooth);
}


/* ══════════════════════════════════════════════════════════════
   Modern Dark Directory staging polish overrides
   Keep the legacy token surface compatible while removing green/terminal drift.
   ══════════════════════════════════════════════════════════════ */
:root {
  --klsv-ui-bg: #08090c;
  --klsv-ui-bg-soft: #0d0f14;
  --klsv-ui-bg-muted: #12151d;
  --klsv-ui-bg-hero: #0d0f14;
  --klsv-ui-bg-deep: #040507;

  --klsv-ui-text: #f7f8fa;
  --klsv-ui-text-strong: #fff;
  --klsv-ui-text-soft: rgba(247, 248, 250, 0.72);
  --klsv-ui-text-faint: rgba(247, 248, 250, 0.50);
  --klsv-ui-text-muted: rgba(247, 248, 250, 0.64);
  --klsv-ui-text-primary: var(--klsv-ui-text);
  --klsv-ui-text-subtle: var(--klsv-ui-text-faint);

  --klsv-ui-accent: #c3aa78;
  --klsv-ui-accent-strong: #c4b5fd;
  --klsv-ui-accent-soft: rgba(195, 170, 120, 0.12);
  --klsv-ui-accent-glow: rgba(195, 170, 120, 0.28);
  --klsv-ui-accent-2: #768c9f;
  --klsv-ui-accent-2-soft: rgba(118, 140, 159, 0.10);
  --klsv-ui-accent-3: #f0abfc;
  --klsv-ui-action-base: var(--klsv-ui-accent);
  --klsv-ui-action-hover-base: var(--klsv-ui-accent-strong);
  --klsv-ui-action-rgb: 195, 170, 120;
  --klsv-ui-action: var(--klsv-ui-accent);
  --klsv-ui-action-hover: var(--klsv-ui-accent-strong);
  --klsv-ui-action-gradient: linear-gradient(135deg, #8d7555, #768c9f);
  --klsv-ui-action-soft: rgba(195, 170, 120, 0.12);
  --klsv-ui-action-wash: rgba(195, 170, 120, 0.085);
  --klsv-ui-action-border: rgba(195, 170, 120, 0.38);

  --klsv-brand-whatsapp: #25d366;
  --klsv-brand-whatsapp-hover: #2ee875;
  --klsv-brand-telegram: #229ed9;
  --klsv-brand-telegram-hover: #35b6f2;
  --klsv-ui-whatsapp-bg: var(--klsv-brand-whatsapp);
  --klsv-ui-whatsapp-bg-hover: var(--klsv-brand-whatsapp-hover);

  --klsv-ui-border: rgba(255, 255, 255, 0.075);
  --klsv-ui-border-strong: rgba(255, 255, 255, 0.13);
  --klsv-ui-border-soft: rgba(255, 255, 255, 0.055);
  --klsv-ui-border-accent: rgba(195, 170, 120, 0.26);
  --klsv-ui-border-muted: var(--klsv-ui-border-soft);

  --klsv-ui-surface-1: linear-gradient(180deg, rgba(18, 21, 29, 0.96), rgba(8, 9, 12, 0.96));
  --klsv-ui-surface-2: linear-gradient(180deg, rgba(23, 26, 35, 0.94), rgba(10, 11, 15, 0.94));
  --klsv-ui-surface-3: linear-gradient(180deg, rgba(13, 15, 20, 0.98), rgba(6, 7, 10, 0.98));
  --klsv-ui-surface-base: var(--klsv-ui-surface-3);
  --klsv-ui-surface-soft: rgba(255, 255, 255, 0.035);
  --klsv-ui-surface-subtle: rgba(255, 255, 255, 0.028);
  --klsv-ui-surface-wash-faint: rgba(195, 170, 120, 0.018);
  --klsv-ui-surface-wash-subtle: rgba(195, 170, 120, 0.026);
  --klsv-ui-surface-wash-muted: rgba(195, 170, 120, 0.035);
  --klsv-ui-surface-wash-soft: rgba(195, 170, 120, 0.045);
  --klsv-ui-surface-wash-hover: rgba(195, 170, 120, 0.07);
  --klsv-ui-surface-wash-hairline: rgba(195, 170, 120, 0.016);
  --klsv-ui-surface-wash-mid: rgba(195, 170, 120, 0.052);
  --klsv-ui-surface-shell-start: rgba(13, 15, 20, 0.96);
  --klsv-ui-surface-shell-end: rgba(4, 5, 7, 0.94);
  --klsv-ui-surface-card-start: rgba(18, 21, 29, 0.94);
  --klsv-ui-surface-card-end: rgba(8, 9, 12, 0.94);
  --klsv-ui-surface-card-deep-start: rgba(13, 15, 20, 0.98);
  --klsv-ui-surface-card-deep-end: rgba(6, 7, 10, 0.98);
  --klsv-ui-surface-line: rgba(255, 255, 255, 0.08);
  --klsv-ui-surface-sheen: rgba(195, 170, 120, 0.18);

  --klsv-ui-panel-bg: var(--klsv-ui-surface-1);
  --klsv-ui-panel-bg-soft: var(--klsv-ui-surface-2);
  --klsv-ui-panel-bg-subtle: var(--klsv-ui-surface-3);
  --klsv-ui-panel-border: var(--klsv-ui-border);
  --klsv-ui-panel-border-soft: var(--klsv-ui-border-soft);
  --klsv-ui-panel-border-accent: var(--klsv-ui-border-accent);

  --klsv-no-gray-page-bg: var(--klsv-ui-bg);
  --klsv-no-gray-surface: var(--klsv-ui-surface-1);
  --klsv-no-gray-surface-soft: var(--klsv-ui-surface-2);
  --klsv-no-gray-card: var(--klsv-ui-surface-3);
  --klsv-no-gray-hover: rgba(195, 170, 120, 0.055);
  --klsv-no-gray-border: rgba(195, 170, 120, 0.18);

  --klsv-ui-font-display: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --klsv-ui-font-body: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --klsv-ui-font-mono: var(--klsv-ui-font-body);
  --klsv-font-display: var(--klsv-ui-font-display);
  --klsv-font-body: var(--klsv-ui-font-body);
  --klsv-font-mono: var(--klsv-ui-font-body);

  --klsv-ui-heading-display: clamp(2.45rem, 2rem + 2.5vw, 4.5rem);
  --klsv-ui-heading-xl: clamp(1.75rem, 1.45rem + 1.3vw, 2.55rem);
  --klsv-ui-heading-lg: clamp(1.25rem, 1.1rem + 0.72vw, 1.65rem);
  --klsv-ui-hero-title-max: min(100%, 19ch);
  --klsv-ui-detail-title-max: min(100%, 21ch);
  --klsv-ui-title-max-mobile: min(100%, 18ch);
  --klsv-ui-eyebrow-size: 0.72rem;

  --klsv-ui-radius-md: 14px;
  --klsv-ui-radius-lg: 20px;
  --klsv-ui-radius-xl: 26px;
  --klsv-ui-radius-2xl: 30px;
  --klsv-ui-shadow-1: 0 16px 38px rgba(0, 0, 0, 0.24);
  --klsv-ui-shadow-2: 0 24px 64px rgba(0, 0, 0, 0.34);
  --klsv-ui-shadow-3: 0 30px 90px rgba(0, 0, 0, 0.46);
  --klsv-ui-shadow-card: 0 0 0 1px rgba(255, 255, 255, 0.055), 0 16px 38px rgba(0, 0, 0, 0.26);
  --klsv-ui-shadow-card-hover: 0 0 0 1px rgba(195, 170, 120, 0.22), 0 18px 42px rgba(0, 0, 0, 0.32);
}


/* Modern dark directory UX polish token reset. */
:root {
  --klsv-ui-bg: #080814;
  --klsv-ui-bg-soft: #0F1022;
  --klsv-ui-bg-muted: #15162B;
  --klsv-ui-bg-hero: #0B1020;
  --klsv-ui-bg-deep: #050511;
  --klsv-ui-text: #F8FAFC;
  --klsv-ui-text-strong: #FFFFFF;
  --klsv-ui-text-soft: rgba(248, 250, 252, .82);
  --klsv-ui-text-faint: rgba(148, 163, 184, .72);
  --klsv-ui-text-muted: #94A3B8;
  --klsv-ui-accent: var(--klsv-brand-purple);
  --klsv-ui-accent-strong: var(--klsv-brand-purple-soft);
  --klsv-ui-accent-soft: rgba(141, 117, 85, .14);
  --klsv-ui-accent-glow: rgba(141, 117, 85, .30);
  --klsv-ui-accent-2: var(--klsv-brand-cyan);
  --klsv-ui-accent-2-soft: rgba(118, 140, 159, .12);
  --klsv-ui-action-base: var(--klsv-brand-indigo);
  --klsv-ui-action-hover-base: #c3aa78;
  --klsv-ui-action: var(--klsv-ui-action-base);
  --klsv-ui-action-hover: var(--klsv-ui-action-hover-base);
  --klsv-ui-action-gradient: linear-gradient(135deg, var(--klsv-brand-indigo), var(--klsv-brand-purple));
  --klsv-ui-action-soft: rgba(89, 105, 92, .14);
  --klsv-ui-action-wash: rgba(89, 105, 92, .10);
  --klsv-ui-action-border: rgba(141, 117, 85, .42);
  --klsv-ui-border: rgba(148, 163, 184, .16);
  --klsv-ui-border-strong: rgba(195, 170, 120, .30);
  --klsv-ui-border-soft: rgba(148, 163, 184, .10);
  --klsv-ui-border-accent: rgba(141, 117, 85, .34);
  --klsv-ui-surface-wash-faint: rgba(89, 105, 92, .024);
  --klsv-ui-surface-wash-subtle: rgba(89, 105, 92, .036);
  --klsv-ui-surface-wash-muted: rgba(141, 117, 85, .050);
  --klsv-ui-surface-wash-soft: rgba(141, 117, 85, .070);
  --klsv-ui-surface-wash-hover: rgba(141, 117, 85, .105);
  --klsv-ui-surface-wash-hairline: rgba(89, 105, 92, .018);
  --klsv-ui-surface-wash-mid: rgba(141, 117, 85, .075);
  --klsv-ui-panel-bg: var(--klsv-ui-surface-1);
  --klsv-ui-panel-bg-soft: var(--klsv-ui-surface-2);
  --klsv-no-gray-hover: rgba(141, 117, 85, .075);
  --klsv-no-gray-border: rgba(141, 117, 85, .22);
  --klsv-ui-font-display: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --klsv-ui-font-body: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --klsv-ui-font-mono: var(--klsv-ui-font-body);
  --klsv-font-mono: var(--klsv-ui-font-body);
}


/* Front-end system consolidation canonical UI tokens */
:root {
  --klsv-ui-font-mono: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --klsv-ui-action-base: var(--klsv-brand-indigo);
  --klsv-ui-action: var(--klsv-brand-indigo);
  --klsv-ui-action-hover: #c3aa78;
  --klsv-ui-accent: var(--klsv-brand-purple);
  --klsv-ui-accent-2: var(--klsv-brand-cyan);
  --klsv-ui-surface: #0F1022;
  --klsv-ui-surface-soft: #15162B;
  --klsv-ui-border: rgba(148,163,184,.16);
  --klsv-ui-border-hover: rgba(141,117,85,.34);
}

/* Batch 1 foundation aliases.
   Keep these as stable primitives for page owners; do not place page-specific
   layout decisions here. */
:root {
  --klsv-ui-readable-measure: 68ch;
  --klsv-ui-readable-measure-narrow: 54ch;
  --klsv-ui-section-padding-y: clamp(28px, 5vw, 72px);
  --klsv-ui-section-padding-x: clamp(16px, 3vw, 28px);
  --klsv-ui-grid-gap: clamp(14px, 2vw, 24px);

  --klsv-ui-card-bg: var(--klsv-ui-panel-bg, var(--klsv-ui-surface-1));
  --klsv-ui-card-bg-soft: var(--klsv-ui-panel-bg-soft, var(--klsv-ui-surface-2));
  --klsv-ui-card-border: var(--klsv-ui-panel-border, var(--klsv-ui-border));
  --klsv-ui-card-border-hover: var(--klsv-ui-border-accent, var(--klsv-ui-border-strong));
  --klsv-ui-card-radius: var(--klsv-ui-panel-radius, var(--klsv-ui-radius-lg));
  --klsv-ui-card-radius-compact: var(--klsv-ui-panel-radius-compact, var(--klsv-ui-radius-md));
  --klsv-ui-card-shadow: var(--klsv-ui-shadow-card, var(--klsv-ui-shadow-1));
  --klsv-ui-card-shadow-hover: var(--klsv-ui-shadow-card-hover, var(--klsv-ui-shadow-2));

  --klsv-ui-control-bg: rgba(255, 255, 255, .045);
  --klsv-ui-control-bg-hover: var(--klsv-ui-surface-wash-hover, rgba(195, 170, 120, .07));
  --klsv-ui-control-border: var(--klsv-ui-border);
  --klsv-ui-control-border-hover: var(--klsv-ui-border-accent);
  --klsv-ui-control-radius: var(--klsv-ui-radius-pill);
  --klsv-ui-control-shadow: 0 0 0 1px rgba(255, 255, 255, .018), 0 10px 22px rgba(0, 0, 0, .20);

  --klsv-ui-focus-color: var(--klsv-ui-action-hover, var(--klsv-ui-accent-strong));
  --klsv-ui-focus-shadow: 0 0 0 4px rgba(var(--klsv-ui-action-rgb, 195, 170, 120), .16);
  --klsv-ui-focus-offset: 3px;

  --klsv-ds-readable-measure: var(--klsv-ui-readable-measure);
  --klsv-ds-section-padding-y: var(--klsv-ui-section-padding-y);
  --klsv-ds-section-padding-x: var(--klsv-ui-section-padding-x);
  --klsv-ds-grid-gap: var(--klsv-ui-grid-gap);
  --klsv-ds-card-bg: var(--klsv-ui-card-bg);
  --klsv-ds-card-border: var(--klsv-ui-card-border);
  --klsv-ds-card-radius: var(--klsv-ui-card-radius);
  --klsv-ds-card-shadow: var(--klsv-ui-card-shadow);
  --klsv-ds-focus-color: var(--klsv-ui-focus-color);
  --klsv-ds-focus-shadow: var(--klsv-ui-focus-shadow);
}

/* Batch 3 public surface and CTA aliases.
   These are component primitives only; page routing and SEO contracts stay in PHP. */
:root {
  --klsv-ui-bg: #050607;
  --klsv-ui-bg-soft: #0b0d10;
  --klsv-ui-bg-muted: #11151b;
  --klsv-ui-bg-deep: #020303;
  --klsv-ui-bg-hero: #07090c;
  --klsv-ui-surface: #0b0d10;
  --klsv-ui-surface-1: #101318;
  --klsv-ui-surface-2: #151923;
  --klsv-ui-surface-3: #1a1f2a;
  --klsv-ui-surface-hover: rgba(255, 255, 255, .075);
  --klsv-ui-panel-bg: var(--klsv-ui-surface-1);
  --klsv-ui-panel-bg-soft: var(--klsv-ui-surface-2);
  --klsv-ui-panel-border: rgba(255, 255, 255, .10);

  --klsv-ui-text: #f6f8f3;
  --klsv-ui-text-strong: #ffffff;
  --klsv-ui-text-soft: rgba(246, 248, 243, .82);
  --klsv-ui-text-muted: #a5adba;
  --klsv-ui-text-faint: rgba(165, 173, 186, .68);
  --klsv-ui-border: rgba(255, 255, 255, .10);
  --klsv-ui-border-soft: rgba(255, 255, 255, .07);
  --klsv-ui-border-strong: rgba(255, 255, 255, .18);
  --klsv-ui-border-accent: rgba(215, 255, 54, .36);

  --klsv-ui-action: #d7ff36;
  --klsv-ui-action-hover: #f0ff86;
  --klsv-ui-action-rgb: 215, 255, 54;
  --klsv-ui-action-border: rgba(215, 255, 54, .54);
  --klsv-ui-action-gradient: linear-gradient(135deg, #d7ff36 0%, #b7f22d 100%);
  --klsv-ui-action-soft: rgba(215, 255, 54, .13);
  --klsv-ui-action-wash: rgba(215, 255, 54, .08);
  --klsv-ui-accent: #2dd4bf;
  --klsv-ui-accent-strong: #67e8f9;
  --klsv-ui-accent-2: #8ab4ff;
  --klsv-ui-accent-warm: #e3b75d;

  --klsv-ui-control-bg: rgba(255, 255, 255, .055);
  --klsv-ui-control-bg-hover: rgba(255, 255, 255, .085);
  --klsv-ui-control-border: rgba(255, 255, 255, .14);
  --klsv-ui-control-border-hover: rgba(215, 255, 54, .42);
  --klsv-ui-control-radius: 8px;
  --klsv-ui-control-shadow: 0 1px 0 rgba(255, 255, 255, .06) inset, 0 14px 30px rgba(0, 0, 0, .28);
  --klsv-ui-focus-color: #d7ff36;
  --klsv-ui-focus-shadow: 0 0 0 4px rgba(215, 255, 54, .18);

  --klsv-ui-card-bg: var(--klsv-ui-surface-1);
  --klsv-ui-card-bg-soft: var(--klsv-ui-surface-2);
  --klsv-ui-card-border: rgba(255, 255, 255, .10);
  --klsv-ui-card-border-hover: rgba(215, 255, 54, .26);
  --klsv-ui-card-radius: 8px;
  --klsv-ui-card-radius-compact: 8px;
  --klsv-ui-card-shadow: 0 18px 44px rgba(0, 0, 0, .32);
  --klsv-ui-card-shadow-hover: 0 24px 58px rgba(0, 0, 0, .42), 0 0 0 1px rgba(215, 255, 54, .16);

  --klsv-cta-height: 46px;
  --klsv-cta-height-compact: 40px;
  --klsv-cta-radius: 8px;
  --klsv-cta-padding-inline: clamp(.95rem, 1.7vw, 1.25rem);
  --klsv-cta-browse-bg: var(--klsv-ui-action-gradient);
  --klsv-cta-browse-border: var(--klsv-ui-action-border);
  --klsv-cta-browse-text: #071006;
  --klsv-cta-browse-shadow: 0 16px 34px rgba(215, 255, 54, .18), 0 0 0 1px rgba(255, 255, 255, .08) inset;
  --klsv-cta-support-bg: rgba(255, 255, 255, .055);
  --klsv-cta-support-border: rgba(255, 255, 255, .16);
  --klsv-cta-support-text: var(--klsv-ui-text);
  --klsv-cta-support-shadow: 0 12px 26px rgba(0, 0, 0, .26);
  --klsv-cta-contact-bg: linear-gradient(135deg, #17c964 0%, #2dd4bf 100%);
  --klsv-cta-contact-border: rgba(45, 212, 191, .54);
  --klsv-cta-contact-text: #03120a;
  --klsv-cta-contact-shadow: 0 18px 38px rgba(23, 201, 100, .20), 0 0 0 1px rgba(255, 255, 255, .08) inset;
  --klsv-cta-telegram-bg: rgba(138, 180, 255, .14);
  --klsv-cta-telegram-border: rgba(138, 180, 255, .34);
  --klsv-cta-telegram-text: #dce8ff;
  --klsv-cta-telegram-shadow: 0 14px 30px rgba(0, 0, 0, .24);

  --klsv-ds-card-bg: var(--klsv-ui-card-bg);
  --klsv-ds-card-border: var(--klsv-ui-card-border);
  --klsv-ds-card-radius: var(--klsv-ui-card-radius);
  --klsv-ds-card-shadow: var(--klsv-ui-card-shadow);
  --klsv-ds-focus-color: var(--klsv-ui-focus-color);
  --klsv-ds-focus-shadow: var(--klsv-ui-focus-shadow);
}

/* KLSV Asset Ownership
 * @source-id theme:css:base
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/foundation
 * @runtime-handle klsv-global
 * @contracts minimal reset and typography baseline
 */

/* ── Reset ─────────────────────────────────────────────────── */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

body {
  margin: 0;
  min-height: 100vh;
  background: var(--klsv-ui-bg);
  color: var(--klsv-ui-text);
  font-family: var(--klsv-ui-font-body);
  font-size: var(--klsv-ui-body-md);
  font-weight: var(--klsv-ui-weight-regular);
  line-height: var(--klsv-ui-leading-normal);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "cv11", "ss01", "ss03";
}

/* ── Image / media sane defaults ───────────────────────────── */
img,
picture,
video,
svg {
  display: block;
  max-width: 100%;
  height: auto;
}

img {
  font-style: italic;           /* alt text styling when broken */
  background-repeat: no-repeat;
  background-size: cover;
  shape-margin: 0.75rem;
}

/* ── Form elements inherit ─────────────────────────────────── */
input,
button,
textarea,
select {
  font: inherit;
  color: inherit;
}

button {
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
}

/* ── Headings ──────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  margin: 0;
  font-family: var(--klsv-ui-font-display);
  font-weight: var(--klsv-ui-weight-medium);
  line-height: var(--klsv-ui-leading-tight);
  letter-spacing: var(--klsv-ui-tracking-tight);
  color: var(--klsv-ui-text);
  text-wrap: balance;
}

h1 { font-size: var(--text-h1); }
h2 { font-size: var(--klsv-ui-heading-xl); }
h3 { font-size: var(--text-h3); }

/* ── Body text ─────────────────────────────────────────────── */
p {
  margin: 0;
  text-wrap: pretty;
}

p + p {
  margin-top: var(--klsv-ui-space-sm);
}

small {
  font-size: var(--klsv-ui-body-sm);
  color: var(--klsv-ui-text-muted);
}

/* ── Links ─────────────────────────────────────────────────── */
a {
  color: var(--klsv-ui-accent);
  text-decoration: none;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.25em;
  transition: color var(--klsv-ui-duration-fast) var(--klsv-ui-ease-smooth);
}

a:hover {
  color: var(--klsv-ui-accent-strong);
}

a:focus-visible {
  outline: 2px solid var(--klsv-ui-accent);
  outline-offset: 2px;
  border-radius: var(--klsv-ui-radius-xs);
}

/* ── Lists ─────────────────────────────────────────────────── */
ul, ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* ── Selection ─────────────────────────────────────────────── */
::selection {
  background: var(--klsv-ui-accent);
  color: var(--accent-primary-ink);
}

/* ── Focus ring (keyboard only) ────────────────────────────── */
:focus { outline: none; }

:focus-visible {
  outline: 2px solid var(--klsv-ui-accent);
  outline-offset: 2px;
  border-radius: var(--klsv-ui-radius-xs);
}

/* ── Utility: visually hidden but accessible ───────────────── */
.klsv-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ── Container shell ───────────────────────────────────────── */
.klsv-shell {
  width: min(var(--klsv-ui-shell-max), calc(100vw - (var(--klsv-ui-shell-gutter) + var(--klsv-ui-shell-gutter))));
  margin-inline: auto;
}

.klsv-shell--narrow {
  max-width: var(--klsv-ui-shell-narrow);
}

/* ── Main region ───────────────────────────────────────────── */
/* Pass10: migrated final .klsv-main rule from design-refresh.css. */
.klsv-main {
  padding-block: clamp(24px, 4vw, 48px) clamp(72px, 7vw, 112px);
}

/* ── Page wrapper spacing ──────────────────────────────────── */
/* Pass10: migrated final .klsv-page rule from design-refresh.css. */
.klsv-page {
  gap: clamp(28px, 4vw, 56px);
}

/* ── Eyebrow / kicker ──────────────────────────────────────── */
.klsv-eyebrow,
.klsv-kicker {
  display: inline-block;
  font-family: var(--klsv-ui-font-body);
  font-size: var(--klsv-ui-eyebrow-size);
  font-weight: var(--klsv-ui-weight-medium);
  letter-spacing: var(--klsv-ui-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--klsv-ui-accent);
}

/* ── Prose block (wp content) ──────────────────────────────── */
.klsv-copy {
  color: var(--klsv-ui-text-soft);
  font-size: var(--klsv-ui-body-md);
  line-height: var(--klsv-ui-leading-relaxed);
}

.klsv-copy > * + * {
  margin-top: var(--klsv-ui-space-md);
}

.klsv-copy h2,
.klsv-copy h3 {
  color: var(--klsv-ui-text);
  margin-top: var(--klsv-ui-space-xl);
}

.klsv-copy a {
  text-decoration: underline;
  text-decoration-color: var(--klsv-ui-accent);
  text-decoration-thickness: 1px;
}

.klsv-copy strong {
  color: var(--klsv-ui-text);
  font-weight: var(--klsv-ui-weight-semibold);
}

/* ── HR ─────────────────────────────────────────────────────── */
hr {
  border: 0;
  height: 1px;
  background: var(--klsv-ui-border);
  margin-block: var(--klsv-ui-space-xl);
}

/* Pass34: migrated dark foundation after design-refresh removal. */
body {
  background:
    radial-gradient(circle at top left, var(--klsv-ui-accent-soft), transparent 28%),
    radial-gradient(circle at top right, var(--klsv-ui-accent-2-soft), transparent 24%),
    linear-gradient(180deg, var(--klsv-ui-bg-hero) 0%, var(--klsv-ui-surface-card-end) 42%, var(--klsv-ui-bg) 100%);
}

body::before {
  background:
    linear-gradient(90deg, var(--klsv-ui-surface-wash-subtle), transparent 18%, transparent 82%, var(--klsv-ui-surface-wash-faint)),
    linear-gradient(180deg, var(--klsv-ui-border-accent), transparent 22%);
}

body::after {
  opacity: 0.28;
  background-image:
    linear-gradient(var(--klsv-ui-surface-wash-muted) 1px, transparent 1px),
    linear-gradient(90deg, var(--klsv-ui-surface-wash-muted) 1px, transparent 1px);
  background-size: 96px 96px;
  mask-image: linear-gradient(180deg, var(--klsv-ui-shadow-color-soft), transparent 48%);
}

body.scope-malaysia-city {
  background:
    radial-gradient(circle at top left, var(--klsv-ui-accent-2-wash), transparent 28%),
    radial-gradient(circle at top right, var(--klsv-ui-accent-wash-soft), transparent 24%),
    linear-gradient(180deg, var(--klsv-ui-bg-hero) 0%, var(--klsv-ui-surface-card-end) 42%, var(--klsv-ui-bg) 100%);
}

/* KLSV Asset Ownership
 * @source-id theme:css:components-entry
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/components-entry
 * @runtime-handle klsv-global
 * @contracts structural component owners only; page visuals stay in page owners
 */
/* KLSV Asset Ownership
 * @source-id theme:css:component-header
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/components
 * @runtime-handle klsv-global
 * @contracts structural header owner only; visual rhythm lives in shared presentation owner
 */

.klsv-header { position: sticky; top: 0; z-index: 100; }
.klsv-header__inner { display: grid; grid-template-columns: auto 1fr auto; align-items: center; }
.klsv-brand { min-width: 0; }
.klsv-nav { min-width: 0; }
.klsv-nav__link { position: relative; }
.klsv-nav__link.is-active::after {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 7px;
  height: 1px;
  border-radius: 999px;
}
.klsv-header__cta { text-decoration: none; }
.klsv-platform-icon { display: inline-grid; place-items: center; width: 22px; height: 22px; border-radius: 999px; background: rgba(255,255,255,.96); }
.klsv-platform-icon svg { width: 14px; height: 14px; display: block; }
.klsv-platform-icon--whatsapp svg { fill: #25d366; }
.klsv-platform-icon--telegram svg { fill: #229ed9; }

/* KLSV Asset Ownership
 * @source-id theme:css:component-mobile-menu
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/components
 * @runtime-handle klsv-global
 * @contracts mobile drawer state, touch targets and active navigation feedback
 */

/* ══════════════════════════════════════════════════════════════
   MOBILE MENU
   ══════════════════════════════════════════════════════════════ */

.navbar__menu {
  display: none;
  position: relative;
}

.klsv-menu-toggle {
  display: grid;
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  align-content: center;
  justify-items: center;
  gap: 4px;
  border: 1px solid rgba(195,170,120,.20);
  border-radius: 12px;
  background: rgba(255,255,255,.035);
  color: var(--klsv-page-text, var(--text-primary));
  box-shadow: 0 0 0 1px rgba(255,255,255,.018), 0 10px 24px rgba(0,0,0,.20);
  cursor: pointer;
  touch-action: manipulation;
  transition:
    border-color var(--duration-fast) var(--ease-smooth),
    background var(--duration-fast) var(--ease-smooth),
    box-shadow var(--duration-fast) var(--ease-smooth),
    color var(--duration-fast) var(--ease-smooth),
    transform var(--duration-fast) var(--ease-smooth),
    filter var(--duration-fast) var(--ease-smooth);
}

.klsv-menu-toggle:hover,
.klsv-menu-toggle:focus-visible {
  border-color: rgba(195,170,120,.42);
  background: rgba(195,170,120,.12);
  color: var(--klsv-page-text, var(--text-primary));
  box-shadow: 0 0 24px rgba(195,170,120,.14), 0 12px 28px rgba(0,0,0,.24);
}

.klsv-menu-toggle:active {
  transform: scale(.96);
  filter: brightness(1.08);
}

.klsv-menu-toggle span {
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

.klsv-mobile-panel-wrap {
  position: relative;
}

.klsv-mobile-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: var(--z-overlay);
  display: flex;
  width: min(320px, calc(100vw - 24px));
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  border: 1px solid var(--klsv-nohero-line, var(--border-color-strong));
  border-radius: 0;
  background:
    linear-gradient(180deg, var(--klsv-nohero-panel-soft, var(--klsv-ui-surface-2)), var(--klsv-nohero-panel, var(--klsv-ui-surface-2))),
    var(--klsv-nohero-grid, transparent);
  background-size: auto, 36px 36px;
  box-shadow: 0 28px 90px var(--klsv-nohero-black, rgba(0, 0, 0, 0.48));
}

.klsv-mobile-panel[hidden] {
  display: none;
}

.klsv-mobile-panel::before {
  content: "MENU";
  display: block;
  margin: 3px 46px 7px 7px;
  color: var(--klsv-nohero-green, var(--accent-primary));
  font-family: var(--klsv-nohero-font-ui, var(--font-ui));
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.16em;
}

.klsv-mobile-panel__close {
  position: absolute;
  inset-block-start: 8px;
  inset-inline-end: 8px;
  display: inline-grid;
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  place-items: center;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--klsv-nohero-muted, var(--text-secondary));
  cursor: pointer;
  transition:
    color var(--duration-fast) var(--ease-smooth),
    transform var(--duration-fast) var(--ease-smooth);
}

.klsv-mobile-panel__close span {
  display: inline-grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border: 1px solid rgba(195,170,120,.22);
  border-radius: 2px;
  background: rgba(255,255,255,.035);
  color: rgba(247,248,250,.84);
  font-size: 1.2rem;
  line-height: 1;
  transition:
    border-color var(--duration-fast) var(--ease-smooth),
    background var(--duration-fast) var(--ease-smooth),
    box-shadow var(--duration-fast) var(--ease-smooth),
    color var(--duration-fast) var(--ease-smooth);
}

.klsv-mobile-panel__close:hover,
.klsv-mobile-panel__close:focus-visible {
  color: var(--klsv-page-text, var(--text-primary));
}

.klsv-mobile-panel__close:hover span,
.klsv-mobile-panel__close:focus-visible span {
  border-color: rgba(195,170,120,.48);
  background: rgba(195,170,120,.10);
  color: var(--klsv-page-text, var(--text-primary));
  box-shadow: 0 0 18px rgba(195,170,120,.12);
}

.klsv-mobile-panel a,
.klsv-mobile-panel__link {
  display: flex;
  min-height: 44px;
  align-items: center;
  border: 1px solid var(--klsv-nohero-line-faint, var(--border-color));
  border-radius: 0;
  padding: 10px 14px;
  color: var(--klsv-nohero-text-soft, var(--text-secondary));
  font-family: var(--klsv-nohero-font-ui, var(--font-ui));
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-decoration: none;
  text-transform: uppercase;
  transition:
    border-color var(--duration-fast) var(--ease-smooth),
    background var(--duration-fast) var(--ease-smooth),
    color var(--duration-fast) var(--ease-smooth);
}

.klsv-mobile-panel a:hover,
.klsv-mobile-panel a:focus-visible,
.klsv-mobile-panel__link:hover,
.klsv-mobile-panel__link:focus-visible {
  border-color: rgba(195,170,120,.34);
  background: rgba(195,170,120,.10);
  color: var(--klsv-page-text, var(--text-primary));
}

.klsv-mobile-panel a[aria-current="page"],
.klsv-mobile-panel__link.is-active {
  border-color: color-mix(in srgb, var(--accent-primary) 52%, transparent);
  background: color-mix(in srgb, var(--accent-primary) 14%, transparent);
  color: var(--accent-primary);
}

/* Keep the sticky header above the page while the mobile panel is open. */
body.has-nav-open .klsv-header {
  z-index: var(--z-modal);
}

/* Responsive nav collapse: tablet and phone share the same drawer contract. */
@media (max-width: 980px) {
  .navbar__menu {
    display: inline-flex;
  }

  .klsv-nav {
    display: none;
  }

  .navbar__menu.is-open .klsv-menu-toggle,
  .klsv-header.is-open .klsv-menu-toggle,
  .klsv-menu-toggle[aria-expanded="true"] {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }

  body.has-nav-open {
    overflow: hidden;
  }

  body.has-nav-open::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 980;
    background: var(--klsv-ui-overlay-deep, rgba(0, 0, 0, 0.72));
    pointer-events: auto;
  }

  body.has-nav-open .klsv-header {
    overflow: visible;
    z-index: 1000;
  }

  .klsv-mobile-panel {
    position: fixed;
    top: 76px;
    top: calc(var(--header-height) + var(--klsv-ui-space-sm));
    right: var(--shell-gutter);
    left: var(--shell-gutter);
    z-index: 1010;
    width: auto;
    max-height: calc(100dvh - var(--header-height) - var(--klsv-ui-space-xl) - env(safe-area-inset-bottom, 0px));
    overflow-y: auto;
    padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px));
    overscroll-behavior: contain;
  }

  .klsv-mobile-panel.is-open,
  body.has-nav-open .klsv-mobile-panel:not([hidden]) {
    display: flex;
  }
}

@media (max-width: 760px) {
  .klsv-mobile-panel {
    top: 72px;
    top: calc(var(--header-height) + 8px);
    max-height: calc(100dvh - 82px - env(safe-area-inset-bottom, 0px));
    max-height: calc(100dvh - var(--header-height) - 18px - env(safe-area-inset-bottom, 0px));
  }

  .klsv-mobile-panel a,
  .klsv-mobile-panel__link {
    min-height: 44px;
    padding-block: 10px;
    font-size: 0.7rem;
  }
}

@media (max-width: 420px) {
  .klsv-mobile-panel {
    right: 8px;
    left: 8px;
  }

  .klsv-mobile-panel::before {
    margin-inline-start: 4px;
  }
}

/* Mobile drawer contact CTA. */
.klsv-mobile-panel__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  margin-block-start: 6px;
  border: 1px solid var(--klsv-ui-accent);
  border-radius: var(--klsv-ui-radius-md);
  background: var(--klsv-ui-accent-wash-faint);
  color: var(--klsv-ui-accent);
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-eyebrow);
  text-decoration: none;
  text-transform: uppercase;
}

.klsv-mobile-panel__cta:hover,
.klsv-mobile-panel__cta:focus-visible {
  border-color: rgba(37, 211, 102, 0.72);
  background:
    linear-gradient(135deg, rgba(37, 211, 102, 0.16), rgba(118, 140, 159, 0.12)),
    var(--klsv-ui-action-soft);
  color: var(--klsv-ui-text-strong);
  box-shadow: 0 0 22px rgba(37, 211, 102, 0.14);
}

/* Mobile drawer CTA polish. */
.klsv-mobile-panel__cta {
  min-height: 44px;
  border-color: var(--klsv-ui-border-strong);
  background: rgba(255, 255, 255, 0.025);
}

.klsv-mobile-panel__cta .klsv-platform-icon {
  display: inline-grid;
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 999px;
  background:
    radial-gradient(circle at 35% 25%, rgba(255, 255, 255, 0.34), transparent 38%),
    linear-gradient(135deg, #25d366, #128c7e);
  color: #fff;
  box-shadow: 0 8px 18px rgba(18, 140, 126, 0.26);
}

.klsv-mobile-panel__cta .klsv-platform-icon svg {
  width: 17px;
  height: 17px;
  fill: currentColor;
}

.klsv-mobile-panel__cta span:last-child {
  line-height: 1;
}

body.has-nav-open .klsv-mobile-panel .klsv-mobile-panel__close {
  inset-block-start: 8px;
  inset-inline-end: 8px;
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

body.has-nav-open .klsv-mobile-panel .klsv-mobile-panel__close span {
  width: 34px;
  height: 34px;
  border-color: rgba(195,170,120,.22);
  background: rgba(255, 255, 255, 0.035);
  color: rgba(247, 248, 250, 0.84);
}

body.has-nav-open .klsv-mobile-panel .klsv-mobile-panel__close:hover span,
body.has-nav-open .klsv-mobile-panel .klsv-mobile-panel__close:focus-visible span {
  border-color: rgba(195,170,120,.48);
  background: rgba(195,170,120,.10);
  color: var(--klsv-page-text, var(--text-primary));
  box-shadow: 0 0 18px rgba(195,170,120,.12);
}

body.has-nav-open .klsv-mobile-panel .klsv-mobile-panel__link {
  padding-block: 10px;
  letter-spacing: 0.08em;
}

body.has-nav-open .klsv-mobile-panel .klsv-mobile-panel__cta {
  gap: 8px;
  min-height: 44px;
  margin-block-start: 6px;
  border-color: var(--klsv-ui-border-strong);
  background: rgba(255, 255, 255, 0.025);
  letter-spacing: 0.08em;
}

body.has-nav-open .klsv-mobile-panel .klsv-mobile-panel__cta:hover,
body.has-nav-open .klsv-mobile-panel .klsv-mobile-panel__cta:focus-visible {
  border-color: rgba(37, 211, 102, 0.72);
  background:
    linear-gradient(135deg, rgba(37, 211, 102, 0.16), rgba(118, 140, 159, 0.12)),
    var(--klsv-ui-action-soft);
  color: var(--klsv-ui-text-strong);
  box-shadow: 0 0 22px rgba(37, 211, 102, 0.14);
}

body.has-nav-open .klsv-mobile-panel .klsv-mobile-panel__cta .klsv-platform-icon {
  width: 28px;
  height: 28px;
  flex-basis: 28px;
  background:
    radial-gradient(circle at 35% 25%, rgba(255, 255, 255, 0.34), transparent 38%),
    linear-gradient(135deg, #25d366, #128c7e);
  color: #fff;
  box-shadow: 0 8px 18px rgba(18, 140, 126, 0.26);
}

body.has-nav-open .klsv-mobile-panel .klsv-mobile-panel__cta .klsv-platform-icon svg {
  width: 17px;
  height: 17px;
}

/* KLSV Asset Ownership
 * @source-id theme:css:component-design-system-foundation
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/components
 * @runtime-handle klsv-global
 * @contracts opt-in public Button/Card/Badge/Section/Empty State/FAQ/Price Guide/Gallery component system
 */

/* Public component system foundation.
   This file owns reusable visual primitives only. Page-specific layout remains in
   the page owner CSS files. */

:root {
  --klsv-button-height: var(--klsv-touch-target, 44px);
  --klsv-button-compact-height: var(--klsv-touch-target-compact, 40px);
  --klsv-button-radius: 18px;
  --klsv-button-padding-inline: clamp(.95rem, 1.8vw, 1.25rem);
  --klsv-button-border: rgba(255,255,255,.16);
  --klsv-button-bg: rgba(255,255,255,.045);
  --klsv-button-shadow: 0 0 0 1px rgba(255,255,255,.024), 0 14px 32px rgba(0,0,0,.24);
  --klsv-button-primary-border: rgba(167,124,255,.48);
  --klsv-button-primary-bg: linear-gradient(135deg, rgba(89,105,92,.86), rgba(118,140,159,.78));
  --klsv-button-primary-shadow: 0 18px 38px rgba(44,38,27,.34), 0 0 0 1px rgba(255,255,255,.026);
  --klsv-button-hover-border: rgba(195,170,120,.62);
}


.klsv-ds-section {
  position: relative;
  min-width: 0;
  max-width: 100%;
  border: 1px solid var(--klsv-ds-border, var(--klsv-page-border));
  border-radius: var(--klsv-ds-radius-lg, var(--klsv-page-radius));
  background: var(--klsv-ds-surface, var(--klsv-page-surface-card));
  box-shadow: var(--klsv-ds-shadow-card, var(--klsv-page-glow-soft));
  overflow: hidden;
}

.klsv-ds-section--hero {
  background:
    radial-gradient(circle at 86% 0%, rgba(var(--klsv-ui-action-rgb, 195, 170, 120), .16), transparent 22rem),
    var(--klsv-ds-surface, var(--klsv-page-surface-card));
}

.klsv-ds-section--flat {
  background: transparent;
  box-shadow: none;
}

.klsv-ds-section__head,
.klsv-ds-section-head,
.klsv-ds-section > .klsv-section-head,
.klsv-ds-section > .klsv-section-header {
  display: flex;
  flex-wrap: wrap;
  gap: var(--klsv-ds-space-md, 1rem);
  align-items: end;
  justify-content: space-between;
}

.klsv-ds-section__copy,
.klsv-ds-section-head__copy {
  display: grid;
  gap: var(--klsv-ds-space-xs, .5rem);
  max-width: var(--klsv-readable-measure, 68ch);
}

.klsv-ds-section__body,
.klsv-ds-section-body {
  min-width: 0;
}

.klsv-ds-eyebrow,
.klsv-ds-section__eyebrow {
  color: var(--klsv-ds-accent, var(--klsv-page-accent));
  font-size: var(--klsv-ds-eyebrow-size, var(--klsv-type-eyebrow));
  font-weight: 850;
  letter-spacing: var(--klsv-ds-tracking-eyebrow, .12em);
  line-height: 1.2;
  text-transform: uppercase;
}

.klsv-ds-actions,
.klsv-ds-section-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--klsv-ds-space-xs, .5rem);
  align-items: center;
}

.klsv-ds-button,
.klsv-button,
.klsv-btn,
.klsv-link-pill,
.klsv-section-link,
.klsv-section-actions a,
.klsv-ui-action {
  position: relative;
  display: inline-flex;
  min-width: 0;
  min-height: var(--klsv-ds-control-height, var(--klsv-button-height, var(--klsv-ui-touch-target-min, 44px)));
  align-items: center;
  justify-content: center;
  gap: 10px;
  max-width: 100%;
  padding: 0 var(--klsv-button-padding-inline, clamp(.95rem, 1.8vw, 1.25rem));
  border: 1px solid var(--klsv-ui-control-border, var(--klsv-button-border, var(--klsv-ds-border-strong, var(--klsv-page-border-strong))));
  border-radius: var(--klsv-ui-control-radius, var(--klsv-button-radius, var(--klsv-ds-radius-pill, 999px)));
  background: var(--klsv-ui-control-bg, var(--klsv-button-bg, rgba(255,255,255,.045)));
  color: var(--klsv-ds-text, var(--klsv-page-text));
  box-shadow: var(--klsv-ui-control-shadow, var(--klsv-button-shadow, 0 0 0 1px rgba(255,255,255,.018), 0 10px 22px rgba(0,0,0,.20)));
  font-size: clamp(.82rem, 1.4vw, .92rem);
  font-weight: 800;
  line-height: 1.1;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  touch-action: manipulation;
  transition:
    border-color var(--klsv-ds-duration-normal, var(--klsv-page-transition)),
    background var(--klsv-ds-duration-normal, var(--klsv-page-transition)),
    box-shadow var(--klsv-ds-duration-normal, var(--klsv-page-transition)),
    color var(--klsv-ds-duration-normal, var(--klsv-page-transition)),
    transform var(--klsv-ds-duration-normal, var(--klsv-page-transition)),
    filter var(--klsv-ds-duration-normal, var(--klsv-page-transition));
}

.klsv-ds-button--primary,
.klsv-button--primary,
.klsv-btn--primary,
.klsv-ui-action--primary {
  border-color: var(--klsv-ui-action-border, var(--klsv-button-primary-border, rgba(167,124,255,.48)));
  background: var(--klsv-ui-action-gradient, var(--klsv-button-primary-bg, var(--klsv-page-action-gradient, var(--gradient-cta))));
  color: #fff;
  box-shadow: var(--klsv-button-primary-shadow, var(--klsv-page-glow-primary, 0 0 24px rgba(195,170,120,.22)));
}

.klsv-ds-button--secondary,
.klsv-button--secondary,
.klsv-btn--secondary,
.klsv-link-pill,
.klsv-section-link,
.klsv-section-actions a,
.klsv-ui-action {
  border-color: var(--klsv-button-border, var(--klsv-ds-border, var(--klsv-page-border)));
  background: var(--klsv-button-bg, rgba(255,255,255,.045));
  color: var(--klsv-ds-text, var(--klsv-page-text));
}

.klsv-ds-button--outline,
.klsv-button--outline,
.klsv-btn--outline {
  border-color: var(--klsv-ds-border-strong, var(--klsv-page-border-strong));
  background: transparent;
}

.klsv-ds-button--ghost,
.klsv-button--ghost,
.klsv-btn--ghost {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
  color: var(--klsv-ds-text-soft, var(--klsv-page-text-soft));
}

.klsv-ds-button--compact,
.klsv-link-pill,
.klsv-home-area-card-v2__cta {
  min-height: var(--klsv-button-compact-height, var(--klsv-ds-link-pill-height, 36px));
  padding-inline: .78rem;
  font-size: .78rem;
}

.klsv-ds-button[disabled],
.klsv-ds-button.is-disabled,
.klsv-button[disabled],
.klsv-button.is-disabled,
.klsv-btn[disabled],
.klsv-btn.is-disabled {
  opacity: .52;
  cursor: not-allowed;
  transform: none;
  filter: none;
}

@media (hover: hover) and (pointer: fine) {
  .klsv-ds-button:hover,
  .klsv-button:hover,
  .klsv-btn:hover,
.klsv-link-pill:hover,
.klsv-section-link:hover,
.klsv-section-actions a:hover,
.klsv-ui-action:hover {
    border-color: var(--klsv-button-hover-border, var(--klsv-ds-border-accent, var(--klsv-page-border-strong)));
    background: var(--klsv-ds-surface-hover, rgba(195,170,120,.12));
    box-shadow: var(--klsv-page-glow-active, 0 0 24px rgba(195,170,120,.18));
    color: var(--klsv-ds-text-strong, var(--klsv-page-text));
    transform: translateY(-2px);
  }

.klsv-ds-button--primary:hover,
.klsv-button--primary:hover,
.klsv-btn--primary:hover,
.klsv-ui-action--primary:hover {
    filter: brightness(1.08);
  }
}

.klsv-ds-button:focus-visible,
.klsv-button:focus-visible,
.klsv-btn:focus-visible,
.klsv-link-pill:focus-visible,
.klsv-section-link:focus-visible,
.klsv-section-actions a:focus-visible,
.klsv-ui-action:focus-visible {
  outline: 2px solid var(--klsv-ds-action-hover, var(--klsv-page-accent));
  outline-offset: 3px;
  box-shadow: var(--klsv-focus-ring, 0 0 0 3px rgba(195,170,120,.20));
}

.klsv-ds-button:active,
.klsv-button:active,
.klsv-btn:active,
.klsv-link-pill:active,
.klsv-section-link:active,
.klsv-section-actions a:active,
.klsv-ui-action:active {
  transform: scale(.985);
  filter: brightness(1.08);
}

.klsv-ds-card,
.klsv-card-shell,
.klsv-ds-listing-card,
.klsv-ds-directory-card {
  position: relative;
  min-width: 0;
  max-width: 100%;
  border: 1px solid var(--klsv-ds-border, var(--klsv-page-border));
  border-radius: var(--klsv-ds-radius-md, var(--klsv-page-radius-sm));
  background: var(--klsv-ds-surface-muted, rgba(255,255,255,.028));
  box-shadow: 0 0 0 1px rgba(255,255,255,.018), 0 12px 30px rgba(0,0,0,.22);
  overflow: hidden;
  transition:
    border-color var(--klsv-ds-duration-normal, var(--klsv-page-transition)),
    background var(--klsv-ds-duration-normal, var(--klsv-page-transition)),
    box-shadow var(--klsv-ds-duration-normal, var(--klsv-page-transition)),
    transform var(--klsv-ds-duration-normal, var(--klsv-page-transition));
}

@media (hover: hover) and (pointer: fine) {
  .klsv-ds-card:hover,
  .klsv-card-shell:hover,
  .klsv-ds-listing-card:hover,
  .klsv-ds-directory-card:hover {
    border-color: var(--klsv-ds-border-accent, var(--klsv-page-border-strong));
    background: var(--klsv-ds-surface-hover, var(--klsv-page-surface));
    box-shadow: var(--klsv-ds-shadow-card-hover, var(--klsv-page-glow-soft));
    transform: translateY(-1px);
  }
}

.klsv-ds-card__media,
.klsv-ds-listing-card__media,
.klsv-ds-directory-card__media {
  position: relative;
  display: block;
  overflow: hidden;
  background: rgba(255,255,255,.04);
}

.klsv-ds-card__media img,
.klsv-ds-listing-card__media img,
.klsv-ds-directory-card__media img {
  width: 100%;
  height: 100%;
  object-fit: var(--klsv-ds-photo-fit, cover);
  object-position: center top;
}

/* Public Media Fit Contract
 * Use these variants to keep image behavior explicit per context.
 * Portrait/profile images crop safely. Poster/gallery images preserve full content.
 */
.klsv-ds-media,
.klsv-ds-media--portrait,
.klsv-ds-media--poster,
.klsv-ds-media--thumbnail,
.klsv-ds-media--gallery,
.klsv-ds-media--video {
  position: relative;
  display: block;
  overflow: hidden;
  background: rgba(255,255,255,.04);
}

.klsv-ds-media img,
.klsv-ds-media video,
.klsv-ds-media--portrait img,
.klsv-ds-media--poster img,
.klsv-ds-media--thumbnail img,
.klsv-ds-media--gallery img,
.klsv-ds-media--video img,
.klsv-ds-media--video video {
  width: 100%;
  height: 100%;
  display: block;
}

.klsv-ds-media--portrait img {
  object-fit: cover;
  object-position: center top;
}

.klsv-ds-media--poster img,
.klsv-ds-media--thumbnail img,
.klsv-ds-media--gallery img {
  object-fit: contain;
  object-position: center;
}

.klsv-ds-media--video video,
.klsv-ds-media--video img {
  object-fit: contain;
  object-position: center;
}

.klsv-ds-media--thumbnail {
  flex: 0 0 auto;
}


.klsv-ds-card__body,
.klsv-ds-listing-card__body,
.klsv-ds-directory-card__body {
  display: grid;
  gap: var(--klsv-ds-space-xs, .5rem);
  padding: clamp(.75rem, 2vw, 1rem);
}

.klsv-ds-card__footer {
  display: flex;
  flex-wrap: wrap;
  gap: var(--klsv-ds-space-xs, .5rem);
  align-items: center;
  justify-content: space-between;
}

.klsv-ds-badge,
.klsv-ui-pill,
.klsv-pill,
.klsv-chip {
  display: inline-flex;
  min-height: var(--klsv-ds-chip-height, 28px);
  align-items: center;
  justify-content: center;
  gap: .38rem;
  max-width: 100%;
  padding-inline: .7rem;
  border: 1px solid var(--klsv-ds-border, var(--klsv-page-border));
  border-radius: var(--klsv-ds-radius-pill, 999px);
  background: rgba(255,255,255,.04);
  color: var(--klsv-ds-text-soft, var(--klsv-page-text-soft));
  font-size: clamp(.68rem, 1.2vw, .76rem);
  font-weight: 760;
  line-height: 1;
  white-space: nowrap;
}

.klsv-ds-badge--accent,
.klsv-ds-badge.is-active,
.klsv-pill.is-active,
.klsv-chip.is-active,
.klsv-chip--status {
  border-color: var(--klsv-ds-border-accent, var(--klsv-page-border-strong));
  background: var(--klsv-ds-accent-soft, var(--klsv-page-accent-soft));
  color: var(--klsv-ds-text, var(--klsv-page-text));
}

.klsv-ds-badge--count,
.klsv-ds-badge--price {
  border-color: rgba(118,140,159,.22);
  background: rgba(118,140,159,.08);
  color: var(--klsv-ds-text, var(--klsv-page-text));
}

.klsv-ds-empty-state,
.klsv-empty-state-contract,
.klsv-content-state {
  display: grid;
  gap: var(--klsv-ds-space-sm, .75rem);
  padding: clamp(1rem, 3vw, 1.35rem);
  border: 1px dashed var(--klsv-ds-border-strong, var(--klsv-page-border-strong));
  border-radius: var(--klsv-ds-radius-md, var(--klsv-page-radius-sm));
  background:
    radial-gradient(circle at 8% 0%, rgba(var(--klsv-ui-action-rgb, 195,170,120), .12), transparent 16rem),
    rgba(255,255,255,.028);
  color: var(--klsv-ds-text-soft, var(--klsv-page-text-soft));
}

.klsv-ds-empty-state__title,
.klsv-content-state__title {
  color: var(--klsv-ds-text, var(--klsv-page-text));
  font-size: clamp(1rem, 2.4vw, 1.22rem);
  line-height: 1.18;
}

.klsv-ds-empty-state__actions,
.klsv-content-state__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--klsv-ds-space-xs, .5rem);
}

.klsv-ds-faq,
.klsv-faq-section {
  border: 1px solid var(--klsv-ds-border, var(--klsv-page-border));
  border-radius: var(--klsv-ds-radius-lg, var(--klsv-page-radius));
  background: var(--klsv-ds-surface, var(--klsv-page-surface-card));
  box-shadow: var(--klsv-ds-shadow-card, var(--klsv-page-glow-soft));
}

.klsv-ds-faq__list,
.klsv-faq-section__list,
.klsv-faq-list {
  display: grid;
  gap: 0;
}

.klsv-ds-faq__item,
.klsv-faq-section__item,
.klsv-faq-item {
  border-top: 1px solid var(--klsv-ds-border, var(--klsv-page-border));
}

.klsv-ds-faq__item:first-child,
.klsv-faq-section__item:first-child,
.klsv-faq-item:first-child {
  border-top: 0;
}

.klsv-ds-faq__summary,
.klsv-faq-section__item > summary,
.klsv-faq-item > summary {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: .75rem;
  align-items: center;
  min-height: var(--klsv-ds-tap-target, 44px);
  padding-block: .85rem;
  color: var(--klsv-ds-text, var(--klsv-page-text));
  cursor: pointer;
  list-style: none;
}

.klsv-ds-faq__summary::-webkit-details-marker,
.klsv-faq-section__item > summary::-webkit-details-marker,
.klsv-faq-item > summary::-webkit-details-marker {
  display: none;
}

.klsv-faq-section__item > summary::after,
.klsv-faq-item > summary::after {
  content: '+';
  display: grid;
  width: 1.45rem;
  height: 1.45rem;
  place-items: center;
  border: 1px solid var(--klsv-ds-border, var(--klsv-page-border));
  border-radius: var(--klsv-ds-radius-pill, 999px);
  color: var(--klsv-ds-accent, var(--klsv-page-accent));
  font-weight: 850;
}

.klsv-faq-section__item[open] > summary::after,
.klsv-faq-item[open] > summary::after {
  content: '–';
}

.klsv-ds-faq__answer,
.klsv-faq-section__answer,
.klsv-faq-item__answer {
  padding-block-end: .95rem;
  color: var(--klsv-ds-text-soft, var(--klsv-page-text-soft));
}

.klsv-ds-price-board {
  display: grid;
  gap: var(--klsv-ds-space-md, 1rem);
}

.klsv-ds-price-board__groups {
  display: grid;
  gap: var(--klsv-ds-space-sm, .75rem);
}

.klsv-ds-price-board__group {
  display: grid;
  gap: var(--klsv-ds-space-sm, .75rem);
  padding: clamp(.85rem, 2.4vw, 1.15rem);
  border: 1px solid var(--klsv-ds-border, var(--klsv-page-border));
  border-radius: var(--klsv-ds-radius-md, var(--klsv-page-radius-sm));
  background: rgba(255,255,255,.026);
}

.klsv-ds-price-board__buckets {
  display: grid;
  gap: var(--klsv-ds-space-sm, .75rem);
}

.klsv-ds-price-board__bucket {
  display: grid;
  gap: .55rem;
  min-width: 0;
}

.klsv-ds-price-board__bucket h4 {
  color: var(--klsv-ds-accent, var(--klsv-page-accent));
  font-size: var(--klsv-ds-eyebrow-size, var(--klsv-type-eyebrow));
  font-weight: 850;
  letter-spacing: var(--klsv-ds-tracking-eyebrow, .1em);
  line-height: 1.2;
  text-transform: uppercase;
}

.klsv-ds-price-board__rows {
  display: grid;
  gap: 0;
  margin: 0;
}

.klsv-ds-price-board__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .75rem;
  align-items: baseline;
  padding-block: .55rem;
  border-top: 1px solid var(--klsv-ds-border-soft, var(--klsv-page-border));
}

.klsv-ds-price-board__row:first-child {
  border-top: 0;
}

.klsv-ds-price-board__price {
  margin: 0;
  color: var(--klsv-ds-text-strong, var(--klsv-page-text));
  font-weight: 850;
  white-space: nowrap;
}

.klsv-ds-gallery,
.klsv-single-gallery {
  display: grid;
  gap: var(--klsv-ds-space-sm, .75rem);
}

.klsv-ds-gallery__stage,
.klsv-single-gallery__hero,
.klsv-single-gallery__video-media {
  border: 1px solid var(--klsv-ds-border, var(--klsv-page-border));
  border-radius: var(--klsv-ds-radius-md, var(--klsv-page-radius-sm));
  background: rgba(255,255,255,.04);
  box-shadow: 0 12px 28px rgba(0,0,0,.22);
  overflow: hidden;
}

.klsv-ds-gallery__thumbs,
.klsv-single-gallery__thumbs,
.klsv-single-gallery__photos {
  display: grid;
  gap: var(--klsv-ds-space-xs, .5rem);
}

.klsv-ds-gallery__thumb,
.klsv-single-gallery__thumb {
  border: 1px solid var(--klsv-ds-border, var(--klsv-page-border));
  border-radius: var(--klsv-ds-radius-sm, 8px);
  background: rgba(255,255,255,.04);
  overflow: hidden;
}

@media (min-width: 760px) {
  .klsv-ds-price-board__buckets {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .klsv-ds-section,
  .klsv-ds-faq {
    border-radius: var(--klsv-ds-radius-md, var(--klsv-page-radius-sm));
  }

  .klsv-ds-button,
  .klsv-button,
  .klsv-btn,
  .klsv-link-pill,
  .klsv-section-link,
  .klsv-section-actions a,
  .klsv-ui-action {
    min-height: var(--klsv-ds-tap-target, 44px);
  }

  .klsv-ds-section__head,
  .klsv-ds-section-head,
  .klsv-ds-section > .klsv-section-head,
  .klsv-ds-section > .klsv-section-header {
    align-items: start;
  }
}

/* Batch 1 foundation hardening.
   These rules normalize primitives without taking ownership from page CSS. */
.klsv-ds-section,
.klsv-ds-card,
.klsv-card-shell,
.klsv-ds-listing-card,
.klsv-ds-directory-card,
.klsv-ds-faq,
.klsv-ds-empty-state,
.klsv-empty-state-contract,
.klsv-content-state {
  min-width: 0;
  max-width: 100%;
}

.klsv-ds-section {
  background: var(--klsv-ds-card-bg, var(--klsv-ds-surface));
  border-color: var(--klsv-ds-card-border, var(--klsv-ds-border));
  border-radius: var(--klsv-ds-card-radius, var(--klsv-ds-radius-lg));
  box-shadow: var(--klsv-ds-card-shadow, var(--klsv-ds-shadow-card));
}

.klsv-ds-section__copy,
.klsv-ds-section-head__copy,
.klsv-ds-card__body,
.klsv-ds-listing-card__body,
.klsv-ds-directory-card__body,
.klsv-ds-empty-state,
.klsv-content-state {
  overflow-wrap: anywhere;
}

.klsv-ds-button[aria-disabled="true"],
.klsv-button[aria-disabled="true"],
.klsv-btn[aria-disabled="true"],
.klsv-link-pill[aria-disabled="true"],
.klsv-ui-action[aria-disabled="true"] {
  opacity: .54;
  pointer-events: none;
}

.klsv-ds-button:focus-visible,
.klsv-button:focus-visible,
.klsv-btn:focus-visible,
.klsv-link-pill:focus-visible,
.klsv-section-link:focus-visible,
.klsv-section-actions a:focus-visible,
.klsv-ui-action:focus-visible,
.klsv-ds-card:focus-within,
.klsv-card-shell:focus-within,
.klsv-ds-listing-card:focus-within,
.klsv-ds-directory-card:focus-within {
  outline: var(--klsv-ui-focus-ring-width, 2px) solid var(--klsv-ds-focus-color, var(--klsv-ui-focus-color));
  outline-offset: var(--klsv-ui-focus-offset, 3px);
  box-shadow: var(--klsv-ds-focus-shadow, var(--klsv-ui-focus-shadow)), var(--klsv-ds-shadow-card, 0 12px 30px rgba(0, 0, 0, .22));
}

@media (hover: hover) and (pointer: fine) {
  .klsv-ds-card:hover,
  .klsv-card-shell:hover,
  .klsv-ds-listing-card:hover,
  .klsv-ds-directory-card:hover {
    border-color: var(--klsv-ui-card-border-hover, var(--klsv-ds-border-accent));
    box-shadow: var(--klsv-ui-card-shadow-hover, var(--klsv-ds-shadow-card-hover));
  }
}

@media (hover: none), (pointer: coarse) {
  .klsv-ds-button:hover,
  .klsv-button:hover,
  .klsv-btn:hover,
  .klsv-link-pill:hover,
  .klsv-section-link:hover,
  .klsv-section-actions a:hover,
  .klsv-ui-action:hover,
  .klsv-ds-card:hover,
  .klsv-card-shell:hover,
  .klsv-ds-listing-card:hover,
  .klsv-ds-directory-card:hover {
    transform: none;
  }
}

/* Batch 3 CTA primitives.
   These variants express funnel intent without changing links, routes, or PHP data. */
.klsv-ds-action-group,
.klsv-cta-group {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(8px, 1.4vw, 12px);
  align-items: center;
  min-width: 0;
}

.klsv-ds-cta-stack {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.klsv-ds-button,
.klsv-button,
.klsv-btn,
.klsv-link-pill,
.klsv-section-link,
.klsv-section-actions a,
.klsv-ui-action {
  min-height: var(--klsv-cta-height, var(--klsv-ds-control-height, var(--klsv-button-height, 44px)));
  padding-inline: var(--klsv-cta-padding-inline, var(--klsv-button-padding-inline, clamp(.95rem, 1.8vw, 1.25rem)));
  border-radius: var(--klsv-cta-radius, var(--klsv-ui-control-radius, var(--klsv-button-radius, 999px)));
  white-space: normal;
  overflow-wrap: anywhere;
}

.klsv-ds-button > *,
.klsv-button > *,
.klsv-btn > *,
.klsv-link-pill > *,
.klsv-section-link > *,
.klsv-section-actions a > *,
.klsv-ui-action > * {
  min-width: 0;
}

.klsv-ds-button--browse,
.klsv-button--browse,
.klsv-ui-action--browse {
  border-color: var(--klsv-cta-browse-border, var(--klsv-ui-action-border));
  background: var(--klsv-cta-browse-bg, var(--klsv-ui-action-gradient));
  color: var(--klsv-cta-browse-text, #071006);
  box-shadow: var(--klsv-cta-browse-shadow, var(--klsv-button-primary-shadow));
}

.klsv-ds-button--support,
.klsv-button--support,
.klsv-ui-action--support {
  border-color: var(--klsv-cta-support-border, var(--klsv-ui-control-border));
  background: var(--klsv-cta-support-bg, var(--klsv-ui-control-bg));
  color: var(--klsv-cta-support-text, var(--klsv-ds-text));
  box-shadow: var(--klsv-cta-support-shadow, var(--klsv-ui-control-shadow));
}

.klsv-ds-button--contact,
.klsv-button--contact,
.klsv-btn--contact,
.klsv-btn--platform-whatsapp {
  border-color: var(--klsv-cta-contact-border, var(--klsv-ui-accent));
  background: var(--klsv-cta-contact-bg, var(--klsv-ui-action-gradient));
  color: var(--klsv-cta-contact-text, #03120a);
  box-shadow: var(--klsv-cta-contact-shadow, var(--klsv-button-primary-shadow));
}

.klsv-ds-button--telegram,
.klsv-button--telegram,
.klsv-btn--platform-telegram {
  border-color: var(--klsv-cta-telegram-border, var(--klsv-ui-accent-2));
  background: var(--klsv-cta-telegram-bg, var(--klsv-ui-control-bg));
  color: var(--klsv-cta-telegram-text, var(--klsv-ds-text));
  box-shadow: var(--klsv-cta-telegram-shadow, var(--klsv-ui-control-shadow));
}

.klsv-ds-button[aria-busy="true"],
.klsv-button[aria-busy="true"],
.klsv-btn[aria-busy="true"],
.klsv-link-pill[aria-busy="true"],
.klsv-ui-action[aria-busy="true"],
.klsv-ds-button.is-loading,
.klsv-button.is-loading,
.klsv-btn.is-loading,
.klsv-link-pill.is-loading,
.klsv-ui-action.is-loading {
  cursor: progress;
  opacity: .72;
  pointer-events: none;
  transform: none;
}

@media (hover: hover) and (pointer: fine) {
  .klsv-ds-button--browse:hover,
  .klsv-button--browse:hover,
  .klsv-ui-action--browse:hover,
  .klsv-ds-button--contact:hover,
  .klsv-button--contact:hover,
  .klsv-btn--contact:hover,
  .klsv-btn--platform-whatsapp:hover {
    filter: brightness(1.04) saturate(1.04);
  }

  .klsv-ds-button--support:hover,
  .klsv-button--support:hover,
  .klsv-ui-action--support:hover,
  .klsv-ds-button--telegram:hover,
  .klsv-button--telegram:hover,
  .klsv-btn--platform-telegram:hover {
    background: var(--klsv-ui-control-bg-hover, rgba(255, 255, 255, .085));
  }
}

@media (max-width: 640px) {
  .klsv-ds-action-group,
  .klsv-cta-group {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .klsv-ds-action-group > *,
  .klsv-cta-group > *,
  .klsv-ds-cta-stack > * {
    width: 100%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .klsv-ds-button,
  .klsv-button,
  .klsv-btn,
  .klsv-link-pill,
  .klsv-section-link,
  .klsv-section-actions a,
  .klsv-ui-action {
    transition-duration: 1ms;
  }
}

/* KLSV Asset Ownership
 * @source-id theme:css:component-footer
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/components
 * @runtime-handle klsv-global
 * @contracts structural footer owner only; visual rhythm lives in shared presentation owner
 */

.klsv-footer-v2 { position: relative; }
.klsv-footer-v2__grid { display: grid; }
.klsv-footer-v2__links { list-style: none; }
.klsv-footer-v2__utility-links { display: flex; flex-wrap: wrap; gap: .75rem; }

/* KLSV Asset Ownership
 * @source-id theme:css:component-states
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/components
 * @runtime-handle klsv-global
 * @contracts structural empty/state primitives
 */

.klsv-content-state,
.klsv-empty-state,
.klsv-state {
  display: grid;
  gap: var(--klsv-content-state-compact-gap, var(--klsv-ui-space-sm, .75rem));
  min-width: 0;
  max-width: 100%;
}

.klsv-state {
  padding: var(--klsv-content-state-compact-padding, clamp(14px, 1.7vw, 20px));
  border: 1px solid var(--klsv-content-state-compact-border, var(--klsv-ui-panel-border));
  border-radius: var(--klsv-content-state-compact-radius, var(--klsv-ui-panel-radius-compact));
  background: var(--klsv-content-state-compact-bg, var(--klsv-ui-panel-bg));
  color: var(--klsv-ui-text-soft);
}

.klsv-state__title,
.klsv-content-state__title,
.klsv-empty-state__title {
  margin: 0;
  color: var(--klsv-ui-text-strong);
  font-size: var(--klsv-content-state-compact-heading-size, clamp(1rem, 1.25vw, 1.18rem));
  line-height: var(--klsv-ui-leading-snug, 1.35);
}

.klsv-state__copy,
.klsv-content-state__copy,
.klsv-empty-state__copy {
  margin: 0;
  color: var(--klsv-ui-text-soft);
  font-size: var(--klsv-content-state-compact-copy-size, clamp(.82rem, 1vw, .92rem));
  line-height: var(--klsv-ui-leading-normal, 1.62);
}

.klsv-state__actions,
.klsv-content-state__actions,
.klsv-empty-state__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--klsv-ui-touch-gap-min, 8px);
  align-items: center;
}

.klsv-state.is-empty,
.klsv-empty-state,
.klsv-content-state.is-empty {
  border-style: dashed;
}

.klsv-state.is-loading,
.klsv-content-state.is-loading {
  color: var(--klsv-ui-text-faint);
}

.klsv-state.is-error,
.klsv-content-state.is-error {
  border-color: rgba(255, 49, 92, .32);
  background: linear-gradient(180deg, rgba(255, 49, 92, .08), rgba(255, 49, 92, .025));
}

.klsv-state.is-success,
.klsv-content-state.is-success {
  border-color: rgba(37, 211, 102, .3);
  background: linear-gradient(180deg, rgba(37, 211, 102, .07), rgba(37, 211, 102, .022));
}

.klsv-state.is-disabled,
.klsv-content-state.is-disabled {
  opacity: .62;
  pointer-events: none;
}

/* Batch 9: canonical empty/loading/error state language. */
:root {
  --klsv-state-gap: clamp(10px, 2vw, 14px);
  --klsv-state-padding: clamp(16px, 3vw, 24px);
  --klsv-state-min-height: 128px;
  --klsv-state-radius: var(--klsv-ui-panel-radius, 14px);
  --klsv-state-border: rgba(243, 239, 231, .12);
  --klsv-state-border-strong: rgba(243, 239, 231, .18);
  --klsv-state-bg: radial-gradient(circle at 8% 0%, rgba(var(--klsv-ui-action-rgb, 195, 170, 120), .10), transparent 16rem), rgba(255, 255, 255, .022);
  --klsv-state-bg-empty: radial-gradient(circle at 50% 0%, rgba(var(--klsv-ui-action-rgb, 195, 170, 120), .09), transparent 58%), rgba(255, 255, 255, .018);
  --klsv-state-text: var(--klsv-ui-text-strong);
  --klsv-state-copy: var(--klsv-ui-text-soft);
}

.klsv-content-state,
.klsv-empty-state,
.klsv-ds-empty-state,
.klsv-empty-state-contract,
.klsv-state {
  gap: var(--klsv-state-gap);
  min-height: var(--klsv-state-min-height);
  padding: var(--klsv-state-padding);
  border: 1px solid var(--klsv-state-border);
  border-radius: var(--klsv-state-radius);
  background: var(--klsv-state-bg);
  color: var(--klsv-state-copy);
  overflow-wrap: anywhere;
}

.klsv-empty-state,
.klsv-empty-state-contract,
.klsv-ds-empty-state,
.klsv-content-state--empty,
.klsv-state.is-empty,
.klsv-content-state.is-empty {
  border-style: dashed;
  border-color: var(--klsv-state-border-strong);
  background: var(--klsv-state-bg-empty);
}

.klsv-content-state--error,
.klsv-state.is-error,
.klsv-content-state.is-error {
  border-color: rgba(255, 49, 92, .32);
  background: linear-gradient(180deg, rgba(255, 49, 92, .08), rgba(255, 49, 92, .025));
}

.klsv-content-state--notice,
.klsv-content-state--fallback,
.klsv-content-state--start {
  border-color: var(--klsv-state-border);
}

.klsv-content-state__title,
.klsv-empty-state__title,
.klsv-ds-empty-state__title,
.klsv-state__title,
.klsv-content-state h2,
.klsv-content-state h3,
.klsv-content-state h4,
.klsv-empty-state h2,
.klsv-empty-state h3,
.klsv-empty-state h4 {
  color: var(--klsv-state-text);
  font-size: var(--klsv-state-title-size, clamp(1.05rem, 2.4vw, 1.32rem));
  line-height: 1.18;
}

.klsv-content-state p,
.klsv-empty-state p,
.klsv-state__copy,
.klsv-content-state__copy,
.klsv-empty-state__copy {
  max-width: 62ch;
  color: var(--klsv-state-copy);
  font-size: var(--klsv-state-copy-size, .92rem);
}

@media (max-width: 560px) {
  .klsv-content-state,
  .klsv-empty-state,
  .klsv-ds-empty-state,
  .klsv-empty-state-contract,
  .klsv-state {
    min-height: 112px;
    padding: clamp(14px, 4vw, 18px);
  }

  .klsv-content-state__actions,
  .klsv-empty-state__actions {
    width: 100%;
  }

  .klsv-content-state__action {
    width: 100%;
  }
}

/* Batch 5: canonical empty/loading/error actions and motion-safe loading. */
.klsv-content-state--loading,
.klsv-state.is-loading,
.klsv-content-state.is-loading,
.klsv-content-state[aria-busy="true"],
.klsv-state[aria-busy="true"] {
  position: relative;
  overflow: hidden;
  border-style: solid;
  border-color: rgba(118, 140, 159, .22);
  background:
    linear-gradient(110deg, rgba(255,255,255,.028), rgba(255,255,255,.07), rgba(255,255,255,.028)),
    var(--klsv-state-bg);
}

.klsv-content-state--loading::after,
.klsv-state.is-loading::after,
.klsv-content-state.is-loading::after,
.klsv-content-state[aria-busy="true"]::after,
.klsv-state[aria-busy="true"]::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.09), transparent);
  transform: translateX(-100%);
  animation: klsv-state-loading-sheen 1.7s ease-in-out infinite;
  pointer-events: none;
}

.klsv-content-state--error,
.klsv-state.is-error,
.klsv-content-state.is-error {
  color: rgba(255,231,237,.88);
}

.klsv-content-state--error .klsv-content-state__title,
.klsv-state.is-error .klsv-state__title,
.klsv-content-state.is-error .klsv-content-state__title {
  color: #ffe7ed;
}

.klsv-content-state--notice,
.klsv-content-state--fallback,
.klsv-content-state--start {
  background:
    radial-gradient(circle at 12% 0%, rgba(42,211,191,.10), transparent 18rem),
    rgba(255,255,255,.022);
}

.klsv-content-state__actions,
.klsv-empty-state__actions,
.klsv-content-state__links {
  min-width: 0;
}

.klsv-content-state__action,
.klsv-content-state__chip {
  display: inline-flex;
  min-height: var(--klsv-touch-target, 44px);
  align-items: center;
  justify-content: center;
  max-width: 100%;
  text-align: center;
}

.klsv-content-state__chip {
  padding-inline: .78rem;
}

.klsv-content-state__action:focus-visible,
.klsv-content-state__chip:focus-visible {
  outline: 2px solid rgba(42,211,191,.72);
  outline-offset: 3px;
}

@keyframes klsv-state-loading-sheen {
  0% {
    transform: translateX(-100%);
  }
  58%,
  100% {
    transform: translateX(100%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .klsv-content-state--loading::after,
  .klsv-state.is-loading::after,
  .klsv-content-state.is-loading::after,
  .klsv-content-state[aria-busy="true"]::after,
  .klsv-state[aria-busy="true"]::after {
    animation: none;
    transform: none;
  }
}

/* KLSV Asset Ownership
 * @source-id theme:css:component-utilities
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/components
 * @runtime-handle klsv-global
 * @contracts non-visual utilities and screen-reader helpers
 */

.klsv-hidden { display: none !important; }
.klsv-visually-hidden,
.klsv-sr-only,
.screen-reader-text {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.klsv-min-0 { min-width: 0; }
.klsv-no-scroll { overflow: hidden; }

.klsv-stack {
  display: grid;
  gap: var(--klsv-ui-stack-gap, var(--klsv-ui-space-md, 1rem));
}

.klsv-cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--klsv-ui-cluster-gap, var(--klsv-ui-space-xs, .5rem));
  align-items: center;
}

.klsv-cluster--between {
  justify-content: space-between;
}

/* KLSV Asset Ownership
 * @source-id theme:css:a11y-performance
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/baseline-guardrails
 * @runtime-handle klsv-global
 * @contracts focus visibility, skip navigation, reduced motion and content containment
 */

:root {
  --klsv-a11y-focus-color: var(--klsv-ui-accent, #d7b46a);
  --klsv-a11y-focus-ring: 0 0 0 3px color-mix(in srgb, var(--klsv-a11y-focus-color) 38%, transparent);
  --klsv-a11y-anchor-offset: calc(var(--klsv-ui-header-height, 72px) + 18px);
}

.klsv-skip-link {
  position: fixed;
  inset-block-start: 12px;
  inset-inline-start: 12px;
  z-index: calc(var(--klsv-ui-z-navbar, 50) + 40);
  transform: translateY(-150%);
  opacity: 0;
  pointer-events: none;
  padding: 12px 16px;
  border: 1px solid var(--klsv-ui-border-strong, rgba(255,255,255,.22));
  border-radius: var(--klsv-ui-radius-pill, 999px);
  background: var(--klsv-ui-bg, #101010);
  color: var(--klsv-ui-text, #fff);
  box-shadow: var(--klsv-ui-shadow-lg, 0 18px 50px rgba(0,0,0,.28));
  font-weight: 800;
  text-decoration: none;
  transition: transform .18s ease, opacity .18s ease;
}

.klsv-skip-link:focus,
.klsv-skip-link:focus-visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.klsv-main {
  scroll-margin-top: var(--klsv-a11y-anchor-offset);
}

.klsv-main:focus {
  outline: none;
}

:where(
  a[href],
  button,
  input,
  select,
  textarea,
  summary,
  [tabindex]:not([tabindex="-1"])
):focus-visible {
  outline: var(--klsv-ui-focus-ring-width, 2px) solid var(--klsv-a11y-focus-color);
  outline-offset: 4px;
  box-shadow: var(--klsv-a11y-focus-ring);
}

.klsv-directory-map__viewport {
  isolation: isolate;
}

button.klsv-directory-map__node,
.klsv-directory-map__node[role="button"] {
  appearance: none;
  -webkit-appearance: none;
  border: 0;
  margin: 0;
  padding: 0;
  font: inherit;
  color: inherit;
  text-align: start;
  background: transparent;
}

button.klsv-directory-map__node {
  cursor: pointer;
}

button.klsv-directory-map__node:focus-visible,
.klsv-directory-map__node[role="button"]:focus-visible {
  outline-offset: 7px;
}

.klsv-filter-bar,
.klsv-directory-filter-rail,
.klsv-section-contract,
.klsv-directory-section {
  scroll-margin-top: var(--klsv-a11y-anchor-offset);
}

html.klsv-motion-ready :where([data-klsv-motion-static="1"], [data-klsv-critical-content="1"]),
html.klsv-motion-ready :where([data-klsv-motion-static="1"], [data-klsv-critical-content="1"]) :where([data-animate], [data-klsv-motion-child]) {
  opacity: var(--klsv-ui-critical-content-opacity, 1) !important;
  transform: none !important;
  translate: none !important;
  clip-path: none !important;
  visibility: visible !important;
}

@supports (content-visibility: auto) {
  .klsv-section-contract:not(:first-child),
  .klsv-directory-section:not(:first-child),
  .klsv-search-results-section,
  .klsv-virtual-section,
  .klsv-content-article > * + * {
    content-visibility: auto;
    contain-intrinsic-size: 1px 680px;
  }

  .klsv-card-grid > .klsv-directory-card:nth-child(n+7),
  .klsv-directory-grid > .profile-card:nth-child(n+7) {
    content-visibility: auto;
    contain-intrinsic-size: 1px 420px;
  }
}


@supports (content-visibility: auto) {
  :where([data-klsv-motion-static="1"], [data-klsv-critical-content="1"]),
  .klsv-section-contract[data-klsv-motion-static="1"],
  .klsv-section-contract[data-klsv-critical-content="1"],
  .klsv-directory-section[data-klsv-motion-static="1"],
  .klsv-directory-section[data-klsv-critical-content="1"],
  .klsv-ds-section[data-klsv-motion-static="1"],
  .klsv-ds-section[data-klsv-critical-content="1"] {
    content-visibility: visible;
    contain-intrinsic-size: auto;
  }

  .klsv-ds-page > .klsv-ds-section:not(:first-child):not([data-klsv-motion-static="1"]):not([data-klsv-critical-content="1"]),
  .klsv-ds-results,
  .klsv-ds-grid--cards > *:nth-child(n+9),
  .klsv-ds-results__grid > *:nth-child(n+9) {
    content-visibility: auto;
    contain-intrinsic-size: 1px 640px;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }

  .klsv-directory-map__scan,
  .klsv-directory-map__ring,
  .klsv-directory-map__trace,
  [data-klsv-hero-reveal],
  .reveal,
  .reveal-group > * {
    animation: none !important;
    transform: none !important;
  }
}

@media (forced-colors: active) {
  .klsv-skip-link,
  :where(a[href], button, input, select, textarea, summary, [tabindex]:not([tabindex="-1"])):focus-visible {
    outline: var(--klsv-ui-focus-ring-width, 2px) solid CanvasText;
    box-shadow: none;
  }

  .klsv-directory-map__node i,
  .klsv-live-dot {
    forced-color-adjust: none;
    background: CanvasText;
  }
}

/* KLSV Asset Ownership
 * @source-id theme:css:image-performance-pipeline
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/shared-performance
 * @runtime-handle klsv-global
 * @contracts stable media dimensions while native loading/fetchpriority decide network cost
 */

img[data-klsv-image-pipeline="1"] {
  display: block;
  max-width: 100%;
  height: auto;
}

.klsv-profile-card__media,
.klsv-home-area-card-v2__media,
.klsv-malaysia-city-photo-tile__media,
.klsv-malaysia-city-photo-card__media,
.klsv-single-gallery__hero-link,
.klsv-single-gallery__thumb {
  contain: paint;
}

.klsv-profile-card__media img[data-klsv-image-pipeline="1"],
.klsv-home-area-card-v2__media img[data-klsv-image-pipeline="1"],
.klsv-malaysia-city-photo-tile__media img[data-klsv-image-pipeline="1"],
.klsv-malaysia-city-photo-card__media img[data-klsv-image-pipeline="1"] {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.klsv-single-gallery__hero-image[data-klsv-image-pipeline="1"],
.klsv-single-gallery__thumb-image[data-klsv-image-pipeline="1"] {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.klsv-profile-card__media-fallback,
.klsv-home-area-card-v2--placeholder,
.klsv-directory-card--no-image {
  contain: paint;
}


.klsv-single-gallery__hero-link {
  aspect-ratio: 4 / 5;
}

.klsv-single-gallery__thumb {
  aspect-ratio: 3 / 4;
}

/* KLSV Asset Ownership
 * @source-id theme:css:shared-frontend-presentation
 * @owner klsv-theme/inc/frontend/assets.php
 * @layer theme-css/shared-presentation
 * @runtime-handle klsv-global
 * @contracts common public shell, shared typography, sections, cards, buttons and content primitives
 */

:root {
  --klsv-page-bg: #05060a;
  --klsv-page-bg-soft: #090b12;
  --klsv-page-surface: linear-gradient(180deg, rgba(255,255,255,.052), rgba(255,255,255,.018));
  --klsv-page-surface-strong: linear-gradient(180deg, rgba(255,255,255,.074), rgba(255,255,255,.028));
  --klsv-page-border: rgba(255,255,255,.09);
  --klsv-page-border-strong: rgba(195,170,120,.28);
  --klsv-page-text: var(--klsv-color-text-primary, #f7f8fa);
  --klsv-page-text-soft: var(--klsv-color-text-secondary, rgba(247,248,250,.68));
  --klsv-page-text-muted: var(--klsv-color-text-muted, rgba(247,248,250,.48));
  --klsv-page-accent: var(--klsv-color-action-primary, #c3aa78);
  --klsv-page-accent-soft: rgba(var(--klsv-color-action-primary-rgb, 195,170,120), .14);
  --klsv-page-cyan: #768c9f;
  --klsv-page-radius: 12px;
  --klsv-page-radius-sm: 10px;
  --klsv-page-gutter: clamp(16px, 3.8vw, 24px);
  --klsv-page-shell: 1120px;
  --klsv-page-shell-wide: 1240px;
  --klsv-page-gap: clamp(16px, 2.6vw, 26px);
  --klsv-page-section-gap: clamp(16px, 2.3vw, 24px);
  --klsv-page-pad: clamp(15px, 3vw, 24px);
  --klsv-page-pad-sm: clamp(12px, 2.4vw, 16px);
  --klsv-page-header-height: 64px;
  --klsv-ui-bg: var(--klsv-page-bg);
  --klsv-ui-text: var(--klsv-page-text);
  --klsv-ui-text-muted: var(--klsv-page-text-soft);
  --klsv-ui-accent: var(--klsv-page-accent);
  --klsv-ui-action: var(--klsv-page-accent);
  --klsv-ui-border: var(--klsv-page-border);
  --klsv-ui-border-strong: var(--klsv-page-border-strong);
  --shell-max: var(--klsv-page-shell-wide);
  --shell-gutter: var(--klsv-page-gutter);
  --header-height: var(--klsv-page-header-height);
  --klsv-page-bg-layer: radial-gradient(circle at 82% -14%, rgba(var(--klsv-color-action-primary-rgb, 195,170,120), .16), transparent 28rem), radial-gradient(circle at 10% 12%, rgba(118,140,159,.08), transparent 24rem), linear-gradient(180deg, #07080d 0%, #05060a 58%, #07080d 100%);
  --klsv-page-surface-card: linear-gradient(180deg, rgba(16,18,26,.82), rgba(8,9,13,.74));
  --klsv-page-accent-strong: var(--klsv-color-action-primary-hover, #d2bd8a);
  --klsv-page-cyan-soft: rgba(118,140,159,.12);
  --klsv-page-action-gradient: linear-gradient(135deg, rgba(var(--klsv-color-action-primary-rgb, 195,170,120), .96), rgba(118,140,159,.9));
  --klsv-button-primary-border: rgba(118, 160, 150, .58);
  --klsv-button-primary-bg: linear-gradient(135deg, rgba(55, 118, 111, .96), rgba(92, 132, 126, .9));
  --klsv-button-primary-shadow: 0 18px 42px rgba(31, 105, 98, .28);
  --klsv-page-glow-soft: 0 0 0 1px rgba(255,255,255,.035), 0 14px 40px rgba(0,0,0,.30), var(--klsv-glow-soft, 0 0 34px rgba(var(--klsv-color-action-primary-rgb, 195,170,120), .08));
  --klsv-page-glow-primary: var(--klsv-glow-border, 0 0 0 1px rgba(195,170,120,.22)), var(--klsv-glow-primary, 0 0 28px rgba(195,170,120,.22)), 0 0 56px rgba(118,140,159,.10);
  --klsv-page-glow-active: 0 0 0 1px rgba(195,170,120,.34), var(--klsv-glow-primary, 0 0 30px rgba(195,170,120,.30)), 0 0 64px rgba(118,140,159,.14);
  --klsv-page-shadow-soft: 0 18px 44px rgba(0,0,0,.34);
  --klsv-page-transition: var(--klsv-motion-fast, 160ms) var(--klsv-motion-luxe, cubic-bezier(.2,.7,.2,1));
  --klsv-readable-measure-tight: 56ch;
  --klsv-readable-measure: 68ch;
  --klsv-readable-measure-wide: 76ch;
  --klsv-type-body: var(--klsv-type-body-system, clamp(.93rem, 1.6vw, .98rem));
  --klsv-type-body-sm: var(--klsv-type-body-small-system, .875rem);
  --klsv-type-meta: var(--klsv-type-meta-system, clamp(.76rem, 1.35vw, .82rem));
  --klsv-type-eyebrow: clamp(.67rem, 1.2vw, .72rem);
  --klsv-type-card-title: var(--klsv-type-card-title-system, clamp(.96rem, 1.8vw, 1.04rem));
  --klsv-line-body: 1.62;
  --klsv-line-compact: 1.38;
  --klsv-pill-height: 28px;
  --klsv-pill-height-interactive: 34px;
  --klsv-pill-pad-inline: 10px;
  --klsv-focus-ring: 0 0 0 3px rgba(195,170,120,.20);
  --klsv-premium-border: rgba(195,170,120,.22);
  --klsv-premium-border-active: rgba(195,170,120,.38);
  --klsv-premium-spotlight: radial-gradient(circle at var(--klsv-spotlight-x, 50%) var(--klsv-spotlight-y, 0%), rgba(195,170,120,.13), transparent 34%);
  --klsv-premium-hero-glow: radial-gradient(circle at 78% 0%, rgba(var(--klsv-color-action-primary-rgb, 195,170,120), .13), transparent 30rem), radial-gradient(circle at 8% 10%, rgba(118,140,159,.07), transparent 24rem);
  --klsv-premium-cta-shine: linear-gradient(110deg, transparent 0%, rgba(255,255,255,.16) 42%, transparent 72%);
  --klsv-media-directory-card-height: clamp(190px, 22vw, 300px);
  --klsv-media-profile-card-height: clamp(205px, 24vw, 330px);
  --klsv-media-related-card-height: clamp(185px, 21vw, 290px);
  --klsv-media-strip-thumb-inline: 58px;
  --klsv-media-strip-thumb-block: 78px;
  --klsv-media-detail-max-height: 620px;
  --klsv-media-radius: var(--klsv-page-radius-sm);
  --klsv-hero-padding-block: clamp(32px, 5.4vw, 64px);
  --klsv-hero-padding-inline: clamp(20px, 4vw, 48px);
  --klsv-hero-grid-gap: clamp(28px, 5vw, 56px);
  --klsv-hero-copy-gap: clamp(14px, 2.4vw, 24px);
  --klsv-hero-meta-gap: clamp(14px, 2vw, 18px);
  --klsv-hero-action-gap: clamp(10px, 1.6vw, 14px);
  --klsv-hero-copy-max: 720px;
  --klsv-hero-copy-measure: min(68ch, 100%);
  --klsv-hero-intro-max: 62ch;
  --klsv-hero-action-max: 540px;
  --klsv-hero-control-padding: clamp(16px, 2vw, 24px);
  --klsv-hero-control-bg: radial-gradient(circle at 18% 0%, rgba(195,170,120,.12), transparent 70%), rgba(255,255,255,.028);
  --klsv-hero-control-border: rgba(255,255,255,.08);
  --klsv-hero-control-radius: var(--klsv-page-radius-sm, 14px);
  --klsv-hero-stat-height: 36px;
  --klsv-hero-button-min: 168px;
  --klsv-hero-primary-button-min: 188px;
  --klsv-hero-secondary-button-min: 156px;
  --klsv-hero-title-measure: min(17ch, 100%);
  --klsv-hero-title-size: clamp(2.55rem, 4.65vw, 5.35rem);
  --klsv-hero-title-line: 1.04;
  --klsv-hero-title-tracking: -.032em;
  --klsv-hero-title-weight: 560;
}

@media (max-width: 560px) {
  :root {
    --klsv-media-directory-card-height: clamp(178px, 56vw, 250px);
    --klsv-media-profile-card-height: clamp(188px, 58vw, 270px);
    --klsv-media-related-card-height: clamp(170px, 54vw, 240px);
    --klsv-media-strip-thumb-inline: 46px;
    --klsv-media-strip-thumb-block: 62px;
    --klsv-media-detail-max-height: 520px;
    --klsv-hero-padding-block: 26px;
    --klsv-hero-padding-inline: 18px;
    --klsv-hero-grid-gap: 22px;
    --klsv-hero-copy-gap: 14px;
    --klsv-hero-meta-gap: 12px;
    --klsv-hero-title-measure: min(16ch, 100%);
    --klsv-hero-title-size: clamp(2.18rem, 9.4vw, 3rem);
    --klsv-hero-action-max: 100%;
  }
}

@media (min-width: 1180px) {
  :root {
    --klsv-media-directory-card-height: clamp(230px, 19vw, 300px);
    --klsv-media-profile-card-height: clamp(240px, 21vw, 330px);
    --klsv-media-related-card-height: clamp(210px, 18vw, 290px);
    --klsv-media-strip-thumb-inline: 62px;
    --klsv-media-strip-thumb-block: 82px;
  }
}

html {
  background: var(--klsv-page-bg);
  color-scheme: dark;
}

body.klsv-runtime,
body {
  min-width: 0;
  background: var(--klsv-page-bg-layer);
  color: var(--klsv-page-text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: var(--klsv-line-body);
}

body.klsv-runtime *,
body.klsv-runtime *::before,
body.klsv-runtime *::after {
  box-sizing: border-box;
}

body.klsv-runtime a {
  color: inherit;
  text-decoration: none;
}

body.klsv-runtime img,
body.klsv-runtime video {
  max-width: 100%;
  height: auto;
}

/* Global media density system */
.klsv-card-media,
.klsv-profile-card__media,
.klsv-ds-listing-card__media,
.klsv-directory-card__media,
.klsv-kl-area-card__media,
.klsv-malaysia-city-profile-card__media {
  contain: paint;
}

.klsv-card-media img,
.klsv-profile-card__media img,
.klsv-ds-listing-card__media img,
.klsv-directory-card__media img,
.klsv-kl-area-card__media img,
.klsv-malaysia-city-profile-card__image {
  object-position: center top;
}

.klsv-profile-card__media {
  height: var(--klsv-media-profile-card-height);
  max-height: var(--klsv-media-profile-card-height);
}

.klsv-kl-area-card__media,
.klsv-malaysia-city-profile-card__media {
  inline-size: var(--klsv-media-strip-thumb-inline);
  block-size: var(--klsv-media-strip-thumb-block);
  max-inline-size: 100%;
  aspect-ratio: auto;
}

body.klsv-runtime :focus-visible {
  outline: 2px solid var(--klsv-page-accent);
  outline-offset: 3px;
}

/* Linear readability utilities */
.klsv-ui-meta-row,
.klsv-ui-pill-group,
.klsv-inline-points,
.klsv-hub-flat-head__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
  min-width: 0;
}

.klsv-ui-stat-strip,
.klsv-hub-flat-head__meta {
  align-items: center;
}

.klsv-ui-pill,
.klsv-ui-stat-strip > span,
.klsv-hub-flat-head__meta > span,
.klsv-pill,
.klsv-chip {
  display: inline-flex;
  min-height: var(--klsv-pill-height);
  align-items: center;
  justify-content: center;
  gap: 6px;
  max-width: 100%;
  padding-inline: var(--klsv-pill-pad-inline);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: var(--klsv-page-text-soft);
  font-size: .75rem;
  font-weight: 680;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
}

.klsv-ui-pill strong {
  color: var(--klsv-page-text);
  font-weight: 780;
}

.klsv-ui-pill--muted,
.klsv-pill--muted,
.klsv-chip--muted {
  color: var(--klsv-page-text-muted);
}

.klsv-ui-pill--accent,
.klsv-ui-pill--success,
.klsv-chip--status,
.klsv-pill.is-active,
.klsv-chip.is-active {
  border-color: rgba(195,170,120,.24);
  background: rgba(195,170,120,.10);
  color: var(--klsv-page-text);
}

.klsv-ui-pill--price {
  border-color: rgba(118,140,159,.20);
  background: rgba(118,140,159,.08);
  color: var(--klsv-page-text);
}

a.klsv-ui-pill,
button.klsv-ui-pill,
.klsv-ui-pill--interactive,
a.klsv-pill,
button.klsv-pill,
a.klsv-chip,
button.klsv-chip {
  min-height: var(--klsv-pill-height-interactive);
  cursor: pointer;
  touch-action: manipulation;
  transition:
    border-color var(--klsv-page-transition),
    background var(--klsv-page-transition),
    box-shadow var(--klsv-page-transition),
    color var(--klsv-page-transition),
    transform var(--klsv-page-transition),
    filter var(--klsv-page-transition);
}

@media (hover: hover) and (pointer: fine) {
  a.klsv-ui-pill:hover,
  button.klsv-ui-pill:hover,
  .klsv-ui-pill--interactive:hover,
  a.klsv-pill:hover,
  button.klsv-pill:hover,
  a.klsv-chip:hover,
  button.klsv-chip:hover {
    border-color: rgba(195,170,120,.34);
    background: rgba(195,170,120,.12);
    box-shadow: 0 0 18px rgba(195,170,120,.10);
    color: var(--klsv-page-text);
    transform: translateY(-1px);
  }
}

a.klsv-ui-pill:active,
button.klsv-ui-pill:active,
.klsv-ui-pill--interactive:active,
a.klsv-pill:active,
button.klsv-pill:active,
a.klsv-chip:active,
button.klsv-chip:active {
  transform: scale(.985);
  filter: brightness(1.08);
}

.klsv-ui-readable,
.klsv-section-intro,
.klsv-section-copy,
.klsv-panel__summary {
  max-width: var(--klsv-hero-copy-measure, var(--klsv-readable-measure));
  line-height: var(--klsv-line-body);
}

.klsv-ui-readable--tight {
  max-width: var(--klsv-readable-measure-tight);
}

.klsv-ui-readable--wide {
  max-width: var(--klsv-readable-measure-wide);
}

html,
body {
  width: 100%;
  max-width: 100%;
  overflow-x: clip;
}

@supports not (overflow-x: clip) {
  html,
  body {
    overflow-x: hidden;
  }
}

body.klsv-runtime {
  position: relative;
}

body.klsv-runtime .klsv-main,
body.klsv-runtime .klsv-page-shell,
body.klsv-runtime .klsv-shell,
body.klsv-runtime .klsv-site-shell,
body.klsv-runtime .klsv-page,
body.klsv-runtime .klsv-home-flat,
body.klsv-runtime .klsv-kl-command-deck,
body.klsv-runtime .klsv-kl-command-deck--flat,
body.klsv-runtime .klsv-malaysia-command-deck,
body.klsv-runtime .klsv-malaysia-command-deck--flat,
body.klsv-runtime .klsv-directory-surface,
body.klsv-runtime .klsv-virtual-surface,
body.klsv-runtime .klsv-shell--profile,
body.klsv-runtime .klsv-section-contract,
body.klsv-runtime .klsv-subpage-section,
body.klsv-runtime .klsv-ui-section,
body.klsv-runtime .klsv-ui-hero,
body.klsv-runtime .klsv-directory-hero,
body.klsv-runtime .klsv-hub-flat-head,
body.klsv-runtime .klsv-flat-page-head,
body.klsv-runtime .klsv-city-flat-head,
body.klsv-runtime .klsv-search-hero {
  min-width: 0;
  max-width: 100%;
}

body.klsv-runtime .klsv-page-shell {
  overflow-x: clip;
}

@supports not (overflow-x: clip) {
  body.klsv-runtime .klsv-page-shell {
    overflow-x: hidden;
  }
}

.klsv-main {
  min-height: 60vh;
  padding-block: 10px clamp(44px, 6vw, 72px);
}

.klsv-shell,
.klsv-site-shell,
.klsv-page-shell > .klsv-shell {
  width: calc(100% - (var(--klsv-page-gutter) * 2));
  max-width: var(--klsv-page-shell-wide);
  margin-inline: auto;
}

/* Interface shell media regression fix: runtime reset must not override shell alignment. */
body.klsv-runtime .klsv-header__inner,
body.klsv-runtime .klsv-shell,
body.klsv-runtime .klsv-site-shell,
body.klsv-runtime .klsv-page-shell > .klsv-shell,
body.klsv-runtime .klsv-footer-v2 .klsv-shell {
  width: calc(100% - (var(--klsv-page-gutter) * 2));
  max-width: var(--klsv-page-shell-wide);
  margin-inline: auto;
}

.klsv-page,
.klsv-home-flat,
.klsv-kl-command-deck--flat,
.klsv-malaysia-command-deck--flat,
.klsv-directory-surface,
.klsv-virtual-surface,
.klsv-shell--profile {
  display: grid;
  gap: var(--klsv-page-section-gap);
}

.klsv-page {
  padding-block: 0;
}

/* Header */
.klsv-header {
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid var(--klsv-page-border);
  background: rgba(8,9,12,.88);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.klsv-header__inner {
  width: calc(100% - (var(--klsv-page-gutter) * 2));
  max-width: var(--klsv-page-shell-wide);
  min-height: var(--klsv-page-header-height);
  margin-inline: auto;
  display: grid;
  grid-template-columns: auto minmax(0,1fr) auto auto;
  gap: clamp(10px, 2vw, 18px);
  align-items: center;
}

.klsv-brand {
  display: grid;
  gap: 2px;
  color: var(--klsv-page-text);
}

.klsv-brand strong {
  font-size: 1rem;
  line-height: 1;
  letter-spacing: .02em;
}

.klsv-brand__accent,
.klsv-brand__tagline {
  color: var(--klsv-page-accent);
}

.klsv-brand__tagline {
  font-size: .66rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.klsv-nav {
  display: flex;
  justify-content: center;
  gap: 2px;
  min-width: 0;
}

.klsv-nav a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding-inline: 12px;
  border: 1px solid transparent;
  border-radius: 8px;
  color: var(--klsv-page-text-soft);
  font-size: .82rem;
}

.klsv-nav a:hover,
.klsv-nav a.is-active {
  color: var(--klsv-page-text);
  border-color: var(--klsv-page-border);
  background: var(--klsv-page-surface);
}

.klsv-header__support,
.klsv-header__meta {
  display: flex;
  min-width: 0;
  align-items: center;
  gap: var(--klsv-hero-action-gap, 10px);
}

.klsv-header__meta {
  min-inline-size: 0;
}

.navbar__menu {
  justify-self: end;
  margin-inline-start: auto;
}

.klsv-menu-toggle {
  display: grid;
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  place-items: center;
  gap: 4px;
  border: 1px solid rgba(195,170,120,.20);
  border-radius: 12px;
  background: rgba(255,255,255,.035);
  color: var(--klsv-page-text);
  box-shadow: 0 0 0 1px rgba(255,255,255,.018), 0 10px 24px rgba(0,0,0,.20);
  cursor: pointer;
  touch-action: manipulation;
  transition:
    border-color var(--klsv-page-transition),
    background var(--klsv-page-transition),
    box-shadow var(--klsv-page-transition),
    color var(--klsv-page-transition),
    transform var(--klsv-page-transition),
    filter var(--klsv-page-transition);
}

.klsv-menu-toggle span {
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

@media (hover: hover) and (pointer: fine) {
  .klsv-menu-toggle:hover {
    border-color: rgba(195,170,120,.42);
    background: rgba(195,170,120,.12);
    box-shadow: 0 0 24px rgba(195,170,120,.14), 0 12px 28px rgba(0,0,0,.24);
    color: var(--klsv-page-text);
    transform: translateY(-1px);
  }
}

.klsv-menu-toggle:active {
  transform: scale(.96);
  filter: brightness(1.08);
}

.klsv-menu-toggle:focus-visible {
  outline: 2px solid rgba(195,170,120,.80);
  outline-offset: 3px;
}

.klsv-header__cta,
.klsv-btn,
.klsv-button,
.klsv-ds-button,
.klsv-link-pill,
.klsv-section-link,
.klsv-contact-channel-action,
.klsv-global-sticky-cta__button {
  display: inline-flex;
  min-height: var(--klsv-touch-target, 44px);
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 14px;
  border: 1px solid var(--klsv-page-border);
  border-radius: 8px;
  background: transparent;
  color: var(--klsv-page-text);
  font-size: .85rem;
  font-weight: 650;
  line-height: 1.1;
  text-align: center;
  text-decoration: none;
  touch-action: manipulation;
}

/* Batch 8: interactive target normalization and sticky CTA safety. */
body.klsv-runtime,
.klsv-page {
  --klsv-bottom-action-safe: calc(var(--klsv-touch-target, 44px) + max(20px, env(safe-area-inset-bottom, 0px)));
}

.klsv-link-pill,
.klsv-section-link,
.klsv-hub-flat-head__action,
.klsv-flat-page-head__action,
.klsv-malaysia-city-strip__link,
.klsv-kl-area-strip__link,
.klsv-kl-area-stream__more,
.klsv-kl-directory-guide__link,
.klsv-kl-video-card__link,
.klsv-content-state__action,
.klsv-contact-channel-action {
  min-height: var(--klsv-touch-target-compact, 40px);
  line-height: 1.15;
  touch-action: manipulation;
}

.klsv-btn,
.klsv-button,
.klsv-ds-button,
.klsv-header__cta,
.klsv-global-sticky-cta__button {
  min-height: var(--klsv-touch-target, 44px);
}

@media (pointer: coarse) {
  .klsv-link-pill,
  .klsv-section-link,
  .klsv-hub-flat-head__action,
  .klsv-flat-page-head__action,
  .klsv-malaysia-city-strip__link,
  .klsv-kl-area-strip__link,
  .klsv-kl-area-stream__more,
  .klsv-kl-directory-guide__link,
  .klsv-kl-video-card__link,
  .klsv-content-state__action,
  .klsv-contact-channel-action {
    min-height: var(--klsv-touch-target, 44px);
  }
}

.klsv-page:has(.klsv-global-sticky-cta),
.klsv-page:has(.klsv-contact-sticky-cta),
.klsv-page:has(.klsv-single-profile-mobile-cta) {
  padding-bottom: var(--klsv-bottom-action-safe);
}

@media (max-width: 760px) {
  body.klsv-runtime:not(.klsv-context--home):not(.klsv-context--single-profile) .klsv-main {
    padding-bottom: calc(var(--klsv-bottom-action-safe) + 16px);
    scroll-padding-bottom: calc(var(--klsv-bottom-action-safe) + 16px);
  }
}

.klsv-btn:hover,
.klsv-button:hover,
.klsv-ds-button:hover,
.klsv-link-pill:hover,
.klsv-section-link:hover,
.klsv-contact-channel-action:hover,
.klsv-global-sticky-cta__button:hover {
  border-color: var(--klsv-button-hover-border, var(--klsv-page-border-strong));
  background: rgba(195,170,120,.12);
}

.klsv-btn:focus-visible,
.klsv-button:focus-visible,
.klsv-ds-button:focus-visible,
.klsv-link-pill:focus-visible,
.klsv-section-link:focus-visible,
.klsv-contact-channel-action:focus-visible,
.klsv-global-sticky-cta__button:focus-visible,
.klsv-pill:focus-visible,
.klsv-chip:focus-visible {
  outline: 2px solid rgba(195,170,120,.80);
  outline-offset: 3px;
}

.klsv-btn:active,
.klsv-button:active,
.klsv-ds-button:active,
.klsv-link-pill:active,
.klsv-section-link:active,
.klsv-contact-channel-action:active,
.klsv-global-sticky-cta__button:active,
.klsv-pill:active,
.klsv-chip:active {
  transform: scale(.985);
  filter: brightness(1.08);
}

.klsv-btn--primary,
.klsv-button--primary,
.klsv-ds-button--primary,
.klsv-contact-channel-action--primary,
.klsv-header__cta--whatsapp {
  border-color: rgba(195,170,120,.42);
  background: var(--klsv-page-accent-soft);
  color: var(--klsv-page-text);
}

.klsv-header__cta--telegram {
  border-color: rgba(118,140,159,.34);
  background: rgba(118,140,159,.08);
}

/* Legacy pill aliases are normalized by the Linear readability utilities above. */
.klsv-pill,
.klsv-chip {
  touch-action: manipulation;
}

.klsv-filter-tags,
.klsv-tag-list,
.klsv-chip-list,
.klsv-city-area-nav,
.klsv-tabs,
.klsv-tab-list {
  position: relative;
  scrollbar-width: thin;
}

.klsv-filter-tags::before,
.klsv-tag-list::before,
.klsv-chip-list::before,
.klsv-city-area-nav::before,
.klsv-tabs::before,
.klsv-tab-list::before,
.klsv-filter-tags::after,
.klsv-tag-list::after,
.klsv-chip-list::after,
.klsv-city-area-nav::after,
.klsv-tabs::after,
.klsv-tab-list::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 2;
  display: block;
  width: 16px;
  pointer-events: none;
}

.klsv-filter-tags::before,
.klsv-tag-list::before,
.klsv-chip-list::before,
.klsv-city-area-nav::before,
.klsv-tabs::before,
.klsv-tab-list::before {
  left: 0;
  background: linear-gradient(90deg, var(--klsv-page-bg, #05060a), transparent);
}

.klsv-filter-tags::after,
.klsv-tag-list::after,
.klsv-chip-list::after,
.klsv-city-area-nav::after,
.klsv-tabs::after,
.klsv-tab-list::after {
  right: 0;
  background: linear-gradient(270deg, var(--klsv-page-bg, #05060a), transparent);
}

.klsv-pill,
.klsv-chip,
.klsv-filter-chip,
[role="button"].klsv-filter-chip,
[role="tab"],
.klsv-tab {
  position: relative;
  min-height: var(--klsv-touch-target-chip, 36px);
  transition:
    border-color var(--klsv-page-transition),
    background var(--klsv-page-transition),
    box-shadow var(--klsv-page-transition),
    color var(--klsv-page-transition),
    transform var(--klsv-page-transition);
}

.klsv-pill.is-active::after,
.klsv-chip.is-active::after,
.klsv-filter-chip.is-active::after,
.klsv-filter-chip[aria-pressed="true"]::after,
[role="button"].klsv-filter-chip[aria-pressed="true"]::after,
[role="tab"][aria-selected="true"]::after,
.klsv-tab.is-active::after {
  content: "";
  position: absolute;
  inset: auto 10px 5px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(var(--klsv-color-action-primary-rgb, 195,170,120), .92), rgba(118,140,159,.62));
  transform-origin: center;
  animation: klsv-tab-indicator-settle var(--klsv-motion-normal, 240ms) var(--klsv-motion-luxe, cubic-bezier(.16,1,.3,1)) both;
}

@media (hover: hover) and (pointer: fine) {
  .klsv-pill:hover,
  .klsv-chip:hover,
  .klsv-filter-chip:hover,
  [role="button"].klsv-filter-chip:hover,
  [role="tab"]:hover,
  .klsv-tab:hover {
    border-color: rgba(195,170,120,.38);
    box-shadow: 0 0 18px rgba(195,170,120,.12);
  }
}

@keyframes klsv-tab-indicator-settle {
  from {
    transform: scaleX(.42);
  }
  to {
    transform: scaleX(1);
  }
}

.klsv-single-gallery__hero,
.klsv-single-gallery__thumb,
.klsv-single-gallery__video-media,
.profile-lightbox__dialog {
  position: relative;
  isolation: isolate;
}

.klsv-single-gallery__hero img,
.klsv-single-gallery__thumb img,
.profile-lightbox__image {
  transition:
    opacity var(--klsv-motion-normal, 240ms) var(--klsv-motion-luxe, cubic-bezier(.16,1,.3,1)),
    transform var(--klsv-motion-slow, 480ms) var(--klsv-motion-luxe, cubic-bezier(.16,1,.3,1)),
    filter var(--klsv-motion-normal, 240ms) var(--klsv-motion-luxe, cubic-bezier(.16,1,.3,1));
}

.klsv-single-gallery__thumb[aria-current="true"],
.klsv-single-gallery__thumb.is-active {
  border-color: rgba(195,170,120,.48);
  box-shadow: 0 0 0 1px rgba(195,170,120,.18), 0 0 22px rgba(195,170,120,.18);
}

@media (hover: hover) and (pointer: fine) {
  .klsv-single-gallery__thumb:hover img {
    transform: scale(1.035);
    filter: saturate(1.04) contrast(1.02);
  }
}

.klsv-content-state,
.klsv-empty-state,
.klsv-no-results,
.klsv-loading-state,
[aria-busy="true"] {
  position: relative;
  isolation: isolate;
}

.klsv-loading-state::before,
[aria-busy="true"]::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,.07) 42%, transparent 74%);
  transform: translateX(-120%);
  pointer-events: none;
}

.klsv-loading-state > *,
[aria-busy="true"] > * {
  position: relative;
  z-index: 1;
}

@media (prefers-reduced-motion: no-preference) {
  .klsv-loading-state::before,
  [aria-busy="true"]::before {
    animation: klsv-skeleton-shimmer 1400ms var(--klsv-motion-luxe, cubic-bezier(.16,1,.3,1)) infinite;
  }

  [data-parallax] {
    transform: translate3d(0, var(--klsv-parallax-y, 0), 0);
    transition: transform var(--klsv-motion-slow, 480ms) var(--klsv-motion-luxe, cubic-bezier(.16,1,.3,1));
    will-change: transform;
  }
}

@media (max-width: 767px), (pointer: coarse) {
  [data-parallax] {
    transform: none;
    will-change: auto;
  }
}

@keyframes klsv-skeleton-shimmer {
  to {
    transform: translateX(120%);
  }
}

.klsv-pill.is-active,
.klsv-chip--status {
  border-color: rgba(195,170,120,.24);
  background: rgba(195,170,120,.10);
  color: var(--klsv-page-text);
}

/* Breadcrumbs */
.klsv-breadcrumbs {
  color: var(--klsv-page-text-muted);
  font-size: .76rem;
}

.klsv-breadcrumbs__list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
}

.klsv-breadcrumbs a:hover {
  color: var(--klsv-page-text);
}

/* Page heads and sections */
.klsv-directory-hero,
.klsv-hub-flat-head,
.klsv-flat-page-head,
.klsv-city-flat-head,
.klsv-search-hero {
  padding: var(--klsv-hero-padding-block) var(--klsv-hero-padding-inline);
  border-bottom: 1px solid var(--klsv-page-border);
  background: transparent;
}

.klsv-ui-hero__main,
.klsv-hub-flat-head__main,
.klsv-flat-page-head__main {
  display: grid;
  min-width: 0;
  max-width: 100%;
  gap: var(--klsv-hero-grid-gap, var(--klsv-page-pad-sm));
}

.klsv-ui-hero__copy,
.klsv-hub-flat-head__copy,
.klsv-flat-page-head__copy {
  display: grid;
  min-width: 0;
  max-width: min(var(--klsv-hero-copy-max, 720px), 100%);
  gap: var(--klsv-hero-copy-gap, 14px);
}

.klsv-eyebrow,
.klsv-section-eyebrow,
.klsv-panel__label,
.klsv-flat-page-head__eyebrow,
.klsv-hub-flat-head__eyebrow {
  color: var(--klsv-page-accent);
  font-size: var(--klsv-type-eyebrow);
  font-weight: 800;
  letter-spacing: .12em;
  line-height: 1.2;
  text-transform: uppercase;
}

.klsv-page-title,
.klsv-directory-hero h1,
.klsv-flat-page-head__title,
.klsv-hub-flat-head h1 {
  max-width: var(--klsv-hero-title-measure, min(17ch, 100%));
  color: var(--klsv-page-text);
  overflow-wrap: break-word;
  font-size: var(--klsv-hero-title-size, clamp(2.55rem, 4.65vw, 5.35rem));
  font-weight: var(--klsv-hero-title-weight, 560);
  line-height: var(--klsv-hero-title-line, 1.04);
  letter-spacing: var(--klsv-hero-title-tracking, -.032em);
  text-wrap: balance;
}

.klsv-directory-hero p,
.klsv-flat-page-head__intro,
.klsv-hub-flat-head__copy > p,
.klsv-section-copy,
.klsv-panel__summary {
  max-width: var(--klsv-readable-measure);
  color: var(--klsv-page-text-soft);
  font-size: var(--klsv-type-body);
  line-height: var(--klsv-line-body);
}

.klsv-hub-flat-head__actions,
.klsv-flat-page-head__actions,
.klsv-kl-hero__cta-row,
.klsv-kl-hero__route-buttons,
.klsv-malaysia-hero__cta-row,
.klsv-malaysia-hero__route-buttons {
  display: flex;
  min-width: 0;
  max-width: 100%;
  flex-wrap: wrap;
  gap: var(--klsv-hero-action-gap, 12px);
  align-items: center;
}

.klsv-hub-flat-head__action,
.klsv-flat-page-head__action,
.klsv-kl-hero__button,
.klsv-malaysia-hero__button {
  display: inline-flex;
  min-height: var(--klsv-button-height, 48px);
  align-items: center;
  justify-content: center;
  padding-inline: clamp(.95rem, 1.8vw, 1.25rem);
  border: 1px solid var(--klsv-button-border, var(--klsv-page-border));
  border-radius: var(--klsv-button-radius, 18px);
  background: var(--klsv-button-bg, rgba(255,255,255,.045));
  color: var(--klsv-page-text);
  box-shadow: var(--klsv-button-shadow, 0 10px 24px rgba(0,0,0,.20));
  font-size: .84rem;
  font-weight: 780;
}

.klsv-kl-hero__controls,
.klsv-malaysia-hero__controls {
  display: grid;
  gap: clamp(18px, 2.4vw, 28px);
}

.klsv-kl-hero__button,
.klsv-malaysia-hero__button {
  min-width: min(100%, var(--klsv-hero-button-min));
}

.klsv-kl-hero__button--primary,
.klsv-malaysia-hero__button--primary {
  min-width: min(100%, var(--klsv-hero-primary-button-min));
}

.klsv-kl-hero__button--telegram,
.klsv-kl-hero__button--whatsapp,
.klsv-malaysia-hero__button--whatsapp {
  min-width: min(100%, var(--klsv-hero-secondary-button-min));
}

.klsv-hub-flat-head__action:hover,
.klsv-flat-page-head__action:hover,
.klsv-kl-hero__button:hover,
.klsv-malaysia-hero__button:hover {
  border-color: var(--klsv-page-border-strong);
  background: var(--klsv-page-surface);
}

.klsv-hub-flat-head__meta,
.klsv-kl-hero__stats,
.klsv-malaysia-hero__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0;
  padding: 0;
  color: var(--klsv-page-text-muted);
  font-size: var(--klsv-type-meta);
  line-height: var(--klsv-line-compact);
}

.klsv-kl-hero__stat,
.klsv-malaysia-hero__stat {
  display: inline-grid;
  grid-template-columns: auto auto;
  align-items: baseline;
  gap: 6px;
  min-height: var(--klsv-hero-stat-height);
  padding: 8px 12px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 999px;
  background: rgba(255,255,255,.032);
}

.klsv-kl-hero__stat dt,
.klsv-kl-hero__stat dd,
.klsv-malaysia-hero__stat dt,
.klsv-malaysia-hero__stat dd {
  margin: 0;
  line-height: 1.1;
}

.klsv-section-contract,
.klsv-subpage-section,
.klsv-copy-card,
.klsv-panel,
.klsv-surface,
.klsv-faq-list,
.klsv-content-state,
.klsv-empty-state {
  border: 1px solid var(--klsv-page-border);
  border-radius: var(--klsv-page-radius);
  background: transparent;
}

.klsv-section-contract,
.klsv-subpage-section,
.klsv-copy-card,
.klsv-panel,
.klsv-faq-list,
.klsv-content-state,
.klsv-empty-state {
  padding: var(--klsv-page-pad);
}

.klsv-section-header,
.klsv-section-head,
.klsv-ui-section-head,
.klsv-panel__head,
.klsv-related-profiles__head,
.klsv-single-gallery__head {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: end;
  justify-content: space-between;
  margin-bottom: clamp(12px, 2vw, 18px);
}

.klsv-section-header > div,
.klsv-section-head > div,
.klsv-ui-section-head > div,
.klsv-panel__head > div,
.klsv-related-profiles__head > div,
.klsv-single-gallery__head > div {
  display: grid;
  min-width: 0;
  max-width: var(--klsv-readable-measure);
  gap: 6px;
}

.klsv-section-header h2,
.klsv-section-head h2,
.klsv-ui-section-head h2,
.klsv-panel__head h2,
.klsv-related-profiles__title {
  position: relative;
  max-width: min(18ch, 100%);
  font-size: clamp(1.22rem, 3.6vw, 1.82rem);
  line-height: 1.08;
  letter-spacing: -.025em;
}

.klsv-section-header h2::after,
.klsv-section-head h2::after,
.klsv-ui-section-head h2::after,
.klsv-panel__head h2::after,
.klsv-related-profiles__title::after {
  content: "";
  display: block;
  width: min(56px, 42%);
  height: 2px;
  margin-block-start: 9px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(var(--klsv-color-action-primary-rgb, 195,170,120), .86), rgba(118,140,159,.56));
  transform-origin: left center;
}

.klsv-card-grid,
.klsv-ui-grid,
.klsv-related-profiles__grid,
.klsv-peer-grid {
  display: grid;
  gap: 12px;
}

/* Interface density alignment: desktop content follows the compact header rhythm without using zoom/transform scaling. */
@media (min-width: 960px) {
  .klsv-section-contract,
  .klsv-subpage-section,
  .klsv-copy-card,
  .klsv-panel,
  .klsv-faq-list,
  .klsv-content-state,
  .klsv-empty-state {
    border-radius: var(--klsv-page-radius-sm);
  }
}

.klsv-directory-card,
.klsv-profile-card,
.klsv-ds-directory-card,
.klsv-ds-listing-card,
.klsv-kl-area-strip,
.klsv-malaysia-city-strip,
.klsv-kl-video-card,
.klsv-single-package-card,
.klsv-hotel-peers {
  border: 1px solid var(--klsv-page-border);
  border-radius: var(--klsv-page-radius-sm);
  background: transparent;
  overflow: hidden;
}

.klsv-directory-card:hover,
.klsv-profile-card:hover,
.klsv-ds-directory-card:hover,
.klsv-ds-listing-card:hover,
.klsv-kl-area-strip:hover,
.klsv-malaysia-city-strip:hover {
  border-color: var(--klsv-page-border-strong);
  background: var(--klsv-page-surface);
}

.klsv-directory-card:focus-within,
.klsv-profile-card:focus-within,
.klsv-ds-directory-card:focus-within,
.klsv-ds-listing-card:focus-within,
.klsv-kl-area-strip:focus-within,
.klsv-malaysia-city-strip:focus-within {
  border-color: var(--klsv-page-border-strong);
  box-shadow: 0 0 0 3px rgba(195,170,120,.16), var(--klsv-page-glow-soft);
}

.klsv-card-body,
.klsv-directory-card__body,
.klsv-profile-card__body {
  display: grid;
  gap: 8px;
  padding: 12px;
}

.klsv-directory-card__title,
.klsv-profile-card__title,
.klsv-kl-area-card__name,
.klsv-kl-video-card__name {
  color: var(--klsv-page-text);
  font-size: var(--klsv-type-card-title);
  font-weight: 750;
  line-height: 1.2;
  letter-spacing: -.015em;
}

.klsv-directory-card__meta,
.klsv-profile-card__readout,
.klsv-profile-card__fact-line,
.klsv-profile-card__excerpt,
.klsv-profile-card__signal-meta {
  color: var(--klsv-page-text-muted);
  font-size: var(--klsv-type-meta);
  line-height: var(--klsv-line-compact);
}

.klsv-card-media,
.klsv-profile-card__media,
.klsv-ds-listing-card__media,
.klsv-directory-card__media,
.klsv-kl-area-card__media,
.klsv-malaysia-city-profile-card__media {
  position: relative;
  display: block;
  overflow: hidden;
  background: rgba(255,255,255,.035);
  cursor: pointer;
}

.klsv-card-media img,
.klsv-profile-card__media img,
.klsv-ds-listing-card__media img,
.klsv-directory-card__media img,
.klsv-kl-area-card__media img,
.klsv-malaysia-city-profile-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.klsv-profile-card__media-badges {
  position: absolute;
  inset: auto 8px 8px 8px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.klsv-profile-card__media-badge {
  padding: 4px 7px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: rgba(8,9,12,.76);
  color: var(--klsv-page-text);
  font-size: .65rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.klsv-profile-card__footer,
.klsv-card-footer {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

/* FAQ and copy */
.klsv-faq-section__list,
.klsv-faq-list {
  display: grid;
  gap: 0;
}

.klsv-faq-section__item,
.klsv-faq-item {
  border-top: 1px solid var(--klsv-page-border);
  padding-block: 14px;
}

.klsv-faq-section__item:first-child,
.klsv-faq-item:first-child {
  border-top: 0;
}

.klsv-faq-section__question,
.klsv-faq-item__question {
  color: var(--klsv-page-text);
  font-weight: 750;
}

.klsv-faq-section__answer,
.klsv-faq-item__answer,
.klsv-copy {
  max-width: var(--klsv-readable-measure-wide);
  color: var(--klsv-page-text-soft);
  line-height: var(--klsv-line-body);
}

.klsv-copy :where(p, ul, ol) {
  margin-block: 0 1em;
}

/* Contact and utility lists */
.klsv-shortcut-cloud,
.klsv-contact-channel-list,
.klsv-task-checklist,
.klsv-contact-include-list {
  display: grid;
  gap: 10px;
}

.klsv-shortcut-card,
.klsv-contact-channel-row,
.klsv-task-checklist li,
.klsv-contact-include-list li {
  display: grid;
  gap: 6px;
  padding-block: 12px;
  border-top: 1px solid var(--klsv-page-border);
}

.klsv-contact-channel-row {
  grid-template-columns: minmax(0,1fr) auto;
  align-items: center;
}

/* Global sticky CTA */
.klsv-global-sticky-cta {
  display: none;
}

@media (max-width: 760px) {
  body:not(.is-contact):not(.single-profile) .klsv-global-sticky-cta {
    position: fixed;
    left: 50%;
    right: auto;
    bottom: max(16px, env(safe-area-inset-bottom, 0px));
    z-index: 90;
    display: block;
    width: min(312px, calc(100% - 32px));
    transform: translateX(-50%);
    pointer-events: none;
  }

  body:not(.is-contact):not(.single-profile) .klsv-global-sticky-cta__button {
    width: 100%;
    min-height: 46px;
    pointer-events: auto;
    background: rgba(13,15,20,.94);
    backdrop-filter: blur(16px);
  }

  body.klsv-runtime.klsv-context--search .klsv-global-sticky-cta {
    display: none;
  }
}





/* Luminous dark surface rhythm */
.klsv-header {
  background: rgba(7,8,13,.82);
  box-shadow: 0 10px 34px rgba(0,0,0,.26), 0 0 36px rgba(195,170,120,.055);
}

.klsv-brand strong,
.klsv-page-title,
.klsv-directory-hero h1,
.klsv-flat-page-head__title,
.klsv-hub-flat-head h1 {
  text-shadow: 0 0 28px rgba(195,170,120,.16);
}

.klsv-brand__accent,
.klsv-brand__tagline,
.klsv-eyebrow,
.klsv-section-eyebrow,
.klsv-panel__label,
.klsv-flat-page-head__eyebrow,
.klsv-hub-flat-head__eyebrow {
  color: var(--klsv-page-accent-strong);
  text-shadow: 0 0 18px rgba(195,170,120,.34);
}

.klsv-nav a,
.klsv-btn,
.klsv-button,
.klsv-ds-button,
.klsv-link-pill,
.klsv-hub-flat-head__action,
.klsv-flat-page-head__action,
.klsv-contact-channel-action {
  transition:
    border-color var(--klsv-page-transition),
    background var(--klsv-page-transition),
    box-shadow var(--klsv-page-transition),
    color var(--klsv-page-transition),
    transform var(--klsv-page-transition),
    filter var(--klsv-page-transition);
}

.klsv-nav a.is-active,
.klsv-nav a:hover {
  border-color: rgba(195,170,120,.26);
  background: rgba(195,170,120,.07);
  box-shadow: 0 0 22px rgba(195,170,120,.10);
}

.klsv-btn--primary,
.klsv-button--primary,
.klsv-ds-button--primary,
.klsv-contact-channel-action--primary,
.klsv-header__cta--whatsapp {
  border-color: rgba(195,170,120,.44);
  background: var(--klsv-page-action-gradient);
  color: #ffffff;
  box-shadow: var(--klsv-page-glow-primary);
}

.klsv-header__cta--telegram {
  border-color: rgba(118,140,159,.36);
  background: rgba(118,140,159,.10);
  box-shadow: 0 0 22px rgba(118,140,159,.12);
}

.klsv-btn:hover,
.klsv-button:hover,
.klsv-ds-button:hover,
.klsv-link-pill:hover,
.klsv-section-link:hover,
.klsv-hub-flat-head__action:hover,
.klsv-flat-page-head__action:hover,
.klsv-contact-channel-action:hover,
.klsv-global-sticky-cta__button:hover {
  border-color: var(--klsv-page-border-strong);
  background: rgba(195,170,120,.08);
  box-shadow: var(--klsv-page-glow-active);
  transform: translateY(-1px);
  filter: brightness(1.06);
}

.klsv-btn:active,
.klsv-button:active,
.klsv-ds-button:active,
.klsv-link-pill:active,
.klsv-section-link:active,
.klsv-hub-flat-head__action:active,
.klsv-flat-page-head__action:active,
.klsv-contact-channel-action:active,
.klsv-global-sticky-cta__button:active {
  transform: scale(.985);
  box-shadow: var(--klsv-page-glow-soft);
  filter: brightness(1.08);
}

.klsv-section-contract,
.klsv-subpage-section,
.klsv-copy-card,
.klsv-panel,
.klsv-surface,
.klsv-faq-list,
.klsv-content-state,
.klsv-empty-state,
.klsv-directory-card,
.klsv-profile-card,
.klsv-ds-directory-card,
.klsv-ds-listing-card,
.klsv-kl-area-strip,
.klsv-malaysia-city-strip,
.klsv-kl-video-card,
.klsv-single-package-card,
.klsv-hotel-peers {
  background: var(--klsv-page-surface-card);
  box-shadow: var(--klsv-page-glow-soft);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition:
    border-color var(--klsv-page-transition),
    background var(--klsv-page-transition),
    box-shadow var(--klsv-page-transition),
    transform var(--klsv-page-transition);
}

.klsv-section-contract:hover,
.klsv-subpage-section:hover,
.klsv-copy-card:hover,
.klsv-panel:hover,
.klsv-directory-card:hover,
.klsv-profile-card:hover,
.klsv-ds-directory-card:hover,
.klsv-ds-listing-card:hover,
.klsv-kl-area-strip:hover,
.klsv-malaysia-city-strip:hover,
.klsv-kl-video-card:hover {
  border-color: var(--klsv-page-border-strong);
  background: var(--klsv-page-surface-strong);
  box-shadow: var(--klsv-page-glow-active);
}

.klsv-card-media,
.klsv-profile-card__media,
.klsv-ds-listing-card__media,
.klsv-directory-card__media,
.klsv-kl-video-card__media,
.klsv-kl-area-card__media {
  background:
    radial-gradient(circle at 50% 0%, rgba(195,170,120,.10), transparent 55%),
    rgba(255,255,255,.035);
}

.klsv-card-media::after,
.klsv-profile-card__media::after,
.klsv-ds-listing-card__media::after,
.klsv-directory-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.045), inset 0 -32px 46px rgba(0,0,0,.20);
  pointer-events: none;
}

.klsv-profile-card:hover,
.klsv-directory-card:hover,
.klsv-ds-listing-card:hover {
  transform: translateY(-2px);
}

.klsv-profile-card__media-badge {
  border-color: rgba(195,170,120,.30);
  background: rgba(7,8,13,.76);
  box-shadow: 0 0 16px rgba(195,170,120,.16);
}

.profile-lightbox__backdrop {
  background:
    radial-gradient(circle at 78% 18%, rgba(195,170,120,.18), transparent 34rem),
    radial-gradient(circle at 18% 78%, rgba(118,140,159,.12), transparent 30rem),
    rgba(0,0,0,.88);
}

.profile-lightbox__dialog {
  filter: drop-shadow(0 0 34px rgba(195,170,120,.18));
}

.profile-lightbox__image,
.profile-lightbox__video {
  box-shadow: 0 0 0 1px rgba(255,255,255,.07), 0 24px 80px rgba(0,0,0,.58), 0 0 42px rgba(195,170,120,.16);
}

.profile-lightbox__close,
.profile-lightbox__nav,
.profile-lightbox__action {
  border-color: rgba(195,170,120,.26);
  background: rgba(8,9,12,.88);
  box-shadow: 0 0 22px rgba(195,170,120,.14);
}

@keyframes klsv-accent-pulse {
  0%, 100% {
    box-shadow: var(--klsv-page-glow-primary);
  }

  50% {
    box-shadow: var(--klsv-page-glow-active);
  }
}

@media (prefers-reduced-motion: no-preference) {
  .klsv-header__cta--whatsapp,
  .klsv-contact-channel-action--primary {
    animation: klsv-accent-pulse 4.8s ease-in-out infinite;
  }
}

@supports not ((backdrop-filter: blur(10px)) or (-webkit-backdrop-filter: blur(10px))) {
  .klsv-section-contract,
  .klsv-subpage-section,
  .klsv-copy-card,
  .klsv-panel,
  .klsv-surface,
  .klsv-faq-list,
  .klsv-content-state,
  .klsv-empty-state,
  .klsv-directory-card,
  .klsv-profile-card,
  .klsv-ds-directory-card,
  .klsv-ds-listing-card,
  .klsv-kl-area-strip,
  .klsv-malaysia-city-strip,
  .klsv-kl-video-card,
  .klsv-single-package-card,
  .klsv-hotel-peers {
    background: rgba(13,15,22,.92);
  }
}

/* Shared media viewer */
body.has-lightbox-open {
  overflow: hidden;
  overscroll-behavior: contain;
}

.profile-lightbox {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: grid;
  place-items: center;
  padding: max(14px, env(safe-area-inset-top, 0px)) max(14px, env(safe-area-inset-right, 0px)) max(14px, env(safe-area-inset-bottom, 0px)) max(14px, env(safe-area-inset-left, 0px));
  opacity: 0;
  pointer-events: none;
  transition: opacity 160ms ease;
}

.profile-lightbox.is-open {
  opacity: 1;
  pointer-events: auto;
}

.profile-lightbox[hidden] {
  display: none;
}

.profile-lightbox__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(0,0,0,.84);
  cursor: zoom-out;
}

.profile-lightbox__dialog {
  position: relative;
  z-index: 1;
  width: min(100%, 1120px);
  max-height: calc(100dvh - 28px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
  display: grid;
  outline: 0;
}

.profile-lightbox__stage {
  display: grid;
  grid-template-columns: auto minmax(0,1fr) auto;
  gap: 10px;
  align-items: center;
}

.profile-lightbox__figure {
  display: grid;
  gap: 10px;
  margin: 0;
  min-width: 0;
}

.profile-lightbox__image,
.profile-lightbox__video {
  width: auto;
  max-width: 100%;
  max-height: calc(100dvh - 128px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
  margin-inline: auto;
  border-radius: 8px;
  object-fit: contain;
  background: #050609;
}

.profile-lightbox__video {
  width: min(100%, 860px);
}

.profile-lightbox__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  align-items: center;
  justify-content: center;
  color: var(--klsv-page-text-soft);
  font-size: .8rem;
}

.profile-lightbox__counter {
  color: var(--klsv-page-text);
  font-weight: 750;
}

.profile-lightbox__label,
.profile-lightbox__hint {
  max-width: min(80vw, 640px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-lightbox__close,
.profile-lightbox__nav,
.profile-lightbox__action {
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  background: rgba(8,9,12,.86);
  color: var(--klsv-page-text);
}

.profile-lightbox__close {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 3;
  width: 42px;
  height: 42px;
  font-size: 1.4rem;
  line-height: 1;
}

.profile-lightbox__nav {
  width: 42px;
  height: 54px;
  font-size: 2rem;
  line-height: 1;
}

.profile-lightbox__action {
  display: inline-flex;
  min-height: 38px;
  align-items: center;
  padding-inline: 12px;
  font-weight: 750;
}

.klsv-card-media[data-klsv-card-media-view],
.klsv-single-gallery__hero-link,
.klsv-single-gallery__thumb,
[data-klsv-photo-lightbox] {
  cursor: zoom-in;
}

.klsv-profile-card__media-badges,
.klsv-profile-card__deck,
.klsv-profile-card__scan {
  display: none;
}

@supports not ((backdrop-filter: blur(10px)) or (-webkit-backdrop-filter: blur(10px))) {
  .klsv-header,
  .klsv-global-sticky-cta__button,
  .profile-lightbox__close,
  .profile-lightbox__nav {
    background: rgba(8,9,12,.96);
  }
}

@media (max-width: 760px) {
  .profile-lightbox {
    align-items: stretch;
    padding: max(10px, env(safe-area-inset-top, 0px)) max(10px, env(safe-area-inset-right, 0px)) max(10px, env(safe-area-inset-bottom, 0px)) max(10px, env(safe-area-inset-left, 0px));
  }

  .profile-lightbox__dialog,
  .profile-lightbox__stage {
    width: 100%;
    max-height: calc(100dvh - 20px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
  }

  .profile-lightbox__stage {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr auto;
  }

  .profile-lightbox__figure {
    align-self: center;
  }

  .profile-lightbox__image,
  .profile-lightbox__video {
    max-height: calc(100dvh - 116px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
  }

  .profile-lightbox__nav {
    position: absolute;
    top: 50%;
    z-index: 2;
    transform: translateY(-50%);
    width: 40px;
    height: 52px;
  }

  .profile-lightbox__nav--prev {
    left: 0;
  }

  .profile-lightbox__nav--next {
    right: 0;
  }

  .profile-lightbox__meta {
    justify-content: flex-start;
    padding-inline: 2px 46px;
  }

  .profile-lightbox__label,
  .profile-lightbox__hint {
    max-width: 100%;
    white-space: normal;
  }
}

/* Linear premium visual accents */
.klsv-directory-hero,
.klsv-hub-flat-head,
.klsv-flat-page-head,
.klsv-city-flat-head,
.klsv-search-hero,
.klsv-profile-stage {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.klsv-directory-hero::before,
.klsv-hub-flat-head::before,
.klsv-flat-page-head::before,
.klsv-city-flat-head::before,
.klsv-search-hero::before,
.klsv-profile-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background:
    radial-gradient(circle at 82% 4%, rgba(var(--klsv-color-action-primary-rgb, 195,170,120), .18), transparent 27rem),
    radial-gradient(circle at 2% 96%, rgba(118,140,159,.10), transparent 24rem),
    radial-gradient(circle at 58% 22%, rgba(255,255,255,.045), transparent 18rem);
  opacity: .78;
  pointer-events: none;
}

.klsv-directory-hero::after,
.klsv-hub-flat-head::after,
.klsv-flat-page-head::after,
.klsv-city-flat-head::after,
.klsv-search-hero::after,
.klsv-profile-stage::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background:
    radial-gradient(circle at 78% 12%, rgba(255,255,255,.05), transparent 18rem),
    radial-gradient(circle at 1px 1px, rgba(255,255,255,.22) 1px, transparent 0);
  background-size: auto, var(--klsv-surface-noise-size, 180px) var(--klsv-surface-noise-size, 180px);
  opacity: var(--klsv-surface-noise-opacity, .032);
  pointer-events: none;
}

.klsv-directory-hero > *,
.klsv-hub-flat-head > *,
.klsv-flat-page-head > *,
.klsv-city-flat-head > *,
.klsv-search-hero > *,
.klsv-profile-stage > * {
  position: relative;
  z-index: 1;
}

.klsv-profile-stage {
  box-shadow:
    var(--klsv-glow-border, 0 0 0 1px rgba(195,170,120,.18)),
    0 16px 42px rgba(0,0,0,.24);
}

@media (max-width: 560px) {
  .klsv-directory-hero::before,
  .klsv-hub-flat-head::before,
  .klsv-flat-page-head::before,
  .klsv-city-flat-head::before,
  .klsv-search-hero::before,
  .klsv-profile-stage::before {
    opacity: .46;
  }

  .klsv-directory-hero::after,
  .klsv-hub-flat-head::after,
  .klsv-flat-page-head::after,
  .klsv-city-flat-head::after,
  .klsv-search-hero::after,
  .klsv-profile-stage::after {
    opacity: calc(var(--klsv-surface-noise-opacity, .032) * .55);
  }
}

.klsv-directory-card--interactive,
.klsv-profile-card,
.klsv-ds-listing-card,
.klsv-kl-video-card,
.klsv-malaysia-popular-cities__item,
.klsv-malaysia-city-photo-card {
  transition:
    border-color var(--klsv-page-transition),
    background var(--klsv-page-transition),
    box-shadow var(--klsv-page-transition),
    transform var(--klsv-page-transition),
    filter var(--klsv-page-transition);
}

@media (hover: hover) and (pointer: fine) {
  .klsv-directory-card--interactive:hover,
  .klsv-profile-card:hover,
  .klsv-ds-listing-card:hover,
  .klsv-kl-video-card:hover,
  .klsv-malaysia-popular-cities__item:hover,
  .klsv-malaysia-city-photo-card:hover {
    border-color: var(--klsv-premium-border-active);
    background:
      var(--klsv-premium-spotlight),
      var(--klsv-page-surface-strong);
    box-shadow: 0 0 0 1px rgba(195,170,120,.14), 0 18px 44px rgba(0,0,0,.34), 0 0 30px rgba(195,170,120,.14);
  }
}

.klsv-btn--primary,
.klsv-button--primary,
.klsv-ds-button--primary,
.klsv-contact-channel-action--primary,
.klsv-header__cta--whatsapp,
.klsv-global-sticky-cta__button {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.klsv-btn--primary::after,
.klsv-button--primary::after,
.klsv-ds-button--primary::after,
.klsv-contact-channel-action--primary::after,
.klsv-header__cta--whatsapp::after,
.klsv-global-sticky-cta__button::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: var(--klsv-premium-cta-shine);
  opacity: 0;
  transform: translateX(-42%);
  transition:
    opacity var(--klsv-page-transition),
    transform 420ms var(--klsv-motion-ease-luxe, ease);
  pointer-events: none;
}

@media (hover: hover) and (pointer: fine) {
  .klsv-btn--primary:hover::after,
  .klsv-button--primary:hover::after,
  .klsv-ds-button--primary:hover::after,
  .klsv-contact-channel-action--primary:hover::after,
  .klsv-header__cta--whatsapp:hover::after,
  .klsv-global-sticky-cta__button:hover::after {
    opacity: .9;
    transform: translateX(42%);
  }
}

.klsv-card-media::after,
.klsv-profile-card__media::after,
.klsv-ds-listing-card__media::after,
.klsv-directory-card__media::after,
.klsv-kl-area-card__media::after,
.klsv-malaysia-city-profile-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.28)),
    radial-gradient(circle at 20% 6%, rgba(255,255,255,.11), transparent 28%);
  opacity: .48;
  pointer-events: none;
  transition: opacity var(--klsv-page-transition);
}

.klsv-card-media img,
.klsv-profile-card__media img,
.klsv-ds-listing-card__media img,
.klsv-directory-card__media img,
.klsv-kl-area-card__media img,
.klsv-malaysia-city-profile-card__image {
  transform-origin: center top;
  transition:
    transform var(--klsv-motion-slow, 480ms) var(--klsv-motion-luxe, cubic-bezier(.16,1,.3,1)),
    filter var(--klsv-motion-normal, 240ms) var(--klsv-motion-luxe, cubic-bezier(.16,1,.3,1));
}

.klsv-profile-card__media-badge {
  transition:
    border-color var(--klsv-page-transition),
    box-shadow var(--klsv-page-transition),
    filter var(--klsv-page-transition);
}

@media (hover: hover) and (pointer: fine) {
  .klsv-card-media:hover,
  .klsv-profile-card__media:hover,
  .klsv-ds-listing-card__media:hover,
  .klsv-directory-card__media:hover,
  .klsv-kl-area-card__media:hover,
  .klsv-malaysia-city-profile-card__media:hover {
    box-shadow: inset 0 0 0 1px rgba(195,170,120,.18), 0 0 26px rgba(195,170,120,.12);
  }

  .klsv-card-media:hover::after,
  .klsv-profile-card__media:hover::after,
  .klsv-ds-listing-card__media:hover::after,
  .klsv-directory-card__media:hover::after,
  .klsv-kl-area-card__media:hover::after,
  .klsv-malaysia-city-profile-card__media:hover::after,
  .klsv-directory-card--interactive:hover .klsv-directory-card__media::after,
  .klsv-profile-card:hover .klsv-profile-card__media::after,
  .klsv-ds-listing-card:hover .klsv-ds-listing-card__media::after,
  .klsv-kl-area-card:hover .klsv-kl-area-card__media::after,
  .klsv-malaysia-city-profile-card:hover .klsv-malaysia-city-profile-card__media::after {
    opacity: .68;
  }

  .klsv-card-media:hover img,
  .klsv-profile-card__media:hover img,
  .klsv-ds-listing-card__media:hover img,
  .klsv-directory-card__media:hover img,
  .klsv-kl-area-card__media:hover img,
  .klsv-malaysia-city-profile-card__media:hover .klsv-malaysia-city-profile-card__image,
  .klsv-directory-card--interactive:hover .klsv-directory-card__media img,
  .klsv-profile-card:hover .klsv-profile-card__media img,
  .klsv-ds-listing-card:hover .klsv-ds-listing-card__media img,
  .klsv-kl-area-card:hover .klsv-kl-area-card__media img,
  .klsv-malaysia-city-profile-card:hover .klsv-malaysia-city-profile-card__image {
    transform: scale(1.03);
    filter: saturate(1.04) contrast(1.02);
  }

  .klsv-profile-card:hover .klsv-profile-card__media-badge {
    border-color: rgba(195,170,120,.44);
    box-shadow: 0 0 18px rgba(195,170,120,.24), 0 0 30px rgba(118,140,159,.08);
    filter: brightness(1.05);
  }
}

@media (prefers-reduced-motion: reduce) {
  .klsv-btn--primary::after,
  .klsv-button--primary::after,
  .klsv-ds-button--primary::after,
  .klsv-contact-channel-action--primary::after,
  .klsv-header__cta--whatsapp::after,
  .klsv-global-sticky-cta__button::after,
  .klsv-card-media::after,
  .klsv-profile-card__media::after,
  .klsv-ds-listing-card__media::after,
  .klsv-directory-card__media::after,
  .klsv-kl-area-card__media::after,
  .klsv-malaysia-city-profile-card__media::after,
  .klsv-card-media img,
  .klsv-profile-card__media img,
  .klsv-ds-listing-card__media img,
  .klsv-directory-card__media img,
  .klsv-kl-area-card__media img,
  .klsv-malaysia-city-profile-card__image,
  .klsv-profile-card__media-badge {
    transition: none;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .klsv-section-header,
  .klsv-section-head,
  .klsv-ui-section-head,
  .klsv-panel__head,
  .klsv-related-profiles__head,
  .klsv-single-gallery__head {
    animation: klsv-section-head-settle var(--klsv-motion-slow, 480ms) var(--klsv-motion-luxe, cubic-bezier(.16,1,.3,1)) both;
  }

  .klsv-section-header h2::after,
  .klsv-section-head h2::after,
  .klsv-ui-section-head h2::after,
  .klsv-panel__head h2::after,
  .klsv-related-profiles__title::after {
    animation: klsv-section-line-reveal var(--klsv-motion-slow, 480ms) var(--klsv-motion-luxe, cubic-bezier(.16,1,.3,1)) both;
  }

  .klsv-directory-grid > *,
  .klsv-card-grid--profiles > *,
  .klsv-related-profiles__grid > *,
  .klsv-peer-grid > *,
  .klsv-malaysia-popular-cities__list > *,
  .klsv-home-v2__area-grid > * {
    animation: klsv-card-stagger-settle var(--klsv-motion-slow, 480ms) var(--klsv-motion-luxe, cubic-bezier(.16,1,.3,1)) both;
  }

  .klsv-directory-grid > *:nth-child(2),
  .klsv-card-grid--profiles > *:nth-child(2),
  .klsv-related-profiles__grid > *:nth-child(2),
  .klsv-peer-grid > *:nth-child(2),
  .klsv-malaysia-popular-cities__list > *:nth-child(2),
  .klsv-home-v2__area-grid > *:nth-child(2) {
    animation-delay: 50ms;
  }

  .klsv-directory-grid > *:nth-child(3),
  .klsv-card-grid--profiles > *:nth-child(3),
  .klsv-related-profiles__grid > *:nth-child(3),
  .klsv-peer-grid > *:nth-child(3),
  .klsv-malaysia-popular-cities__list > *:nth-child(3),
  .klsv-home-v2__area-grid > *:nth-child(3) {
    animation-delay: 90ms;
  }

  .klsv-directory-grid > *:nth-child(n+4),
  .klsv-card-grid--profiles > *:nth-child(n+4),
  .klsv-related-profiles__grid > *:nth-child(n+4),
  .klsv-peer-grid > *:nth-child(n+4),
  .klsv-malaysia-popular-cities__list > *:nth-child(n+4),
  .klsv-home-v2__area-grid > *:nth-child(n+4) {
    animation-delay: 120ms;
  }
}

@keyframes klsv-section-head-settle {
  from {
    opacity: .92;
    transform: translateY(5px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes klsv-section-line-reveal {
  from {
    transform: scaleX(.58);
  }
  to {
    transform: scaleX(1);
  }
}

@keyframes klsv-card-stagger-settle {
  from {
    opacity: .94;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: no-preference) {
  @media (hover: hover) and (pointer: fine) {
    .klsv-btn--primary,
    .klsv-button--primary,
    .klsv-ds-button--primary,
    .klsv-contact-channel-action--primary,
    .klsv-header__cta--whatsapp {
      animation: klsv-cta-soft-breathe var(--klsv-motion-soft-loop, 5200ms) ease-in-out infinite;
    }
  }

  .klsv-global-sticky-cta__button,
  .klsv-single-profile-mobile-cta__button,
  .klsv-contact-sticky-cta__button {
    animation: klsv-cta-border-breathe var(--klsv-motion-soft-loop, 5200ms) ease-in-out infinite;
  }
}

@keyframes klsv-cta-soft-breathe {
  0%,
  100% {
    box-shadow: var(--klsv-glow-border, 0 0 0 1px rgba(195,170,120,.18)), 0 10px 26px rgba(0,0,0,.22);
  }
  48% {
    box-shadow: var(--klsv-glow-border, 0 0 0 1px rgba(195,170,120,.18)), 0 12px 30px rgba(0,0,0,.28), var(--klsv-glow-primary, 0 0 24px rgba(195,170,120,.22));
  }
}

@keyframes klsv-cta-border-breathe {
  0%,
  100% {
    box-shadow: 0 0 0 1px rgba(195,170,120,.18), 0 10px 26px rgba(0,0,0,.24);
  }
  48% {
    box-shadow: 0 0 0 1px rgba(195,170,120,.34), 0 12px 30px rgba(0,0,0,.28), 0 0 20px rgba(195,170,120,.18);
  }
}

/* Footer */
.klsv-footer-v2 {
  position: relative;
  margin-top: clamp(28px, 6vw, 72px);
  padding-block: clamp(28px, 5vw, 52px) clamp(16px, 3vw, 24px);
  border-top: 1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(circle at 20% 0%, rgba(195,170,120,.07), transparent 30rem),
    var(--klsv-page-bg);
}

.klsv-footer-v2 .klsv-shell {
  display: grid;
  gap: clamp(18px, 3vw, 28px);
}

.klsv-footer-v2__top,
.klsv-footer-v2__meta {
  width: 100%;
  max-width: none;
  margin-inline: 0;
}

.klsv-footer-v2__top {
  display: grid;
  gap: 8px;
  padding-block: 0;
}

.klsv-footer-v2__brand {
  display: grid;
  gap: 4px;
  max-width: 680px;
}

.klsv-footer-v2__eyebrow,
.klsv-footer-v2__column-title {
  color: var(--klsv-page-text);
  font-size: .78rem;
  font-weight: 760;
  letter-spacing: .02em;
}

.klsv-footer-v2__wordmark {
  width: fit-content;
  color: var(--klsv-page-text);
  font-weight: 760;
  line-height: 1.2;
  text-decoration: none;
}

.klsv-footer-v2__brand p {
  margin: 0;
  max-width: 58ch;
  color: var(--klsv-page-text-soft);
  font-size: .92rem;
  line-height: 1.45;
}

.klsv-footer-v2__grid {
  display: grid;
  width: 100%;
  max-width: 1080px;
  gap: clamp(18px, 4vw, 56px);
  padding-block: clamp(18px, 3vw, 28px);
  border-block: 1px solid rgba(255,255,255,.07);
}

.klsv-footer-v2__column {
  display: grid;
  gap: 8px;
  align-content: start;
  min-width: 0;
}

.klsv-footer-v2__column-title {
  margin: 0;
}

.klsv-footer-v2__links,
.klsv-footer-v2__utility-links {
  display: grid;
  gap: 4px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.klsv-footer-v2__links a,
.klsv-footer-v2__utility-links a {
  display: inline-flex;
  width: fit-content;
  min-height: 32px;
  align-items: center;
  border-radius: 8px;
  color: var(--klsv-page-text-soft);
  font-size: .9rem;
  line-height: 1.25;
  text-decoration: none;
  transition:
    color var(--klsv-page-transition),
    background var(--klsv-page-transition),
    box-shadow var(--klsv-page-transition),
    transform var(--klsv-page-transition),
    filter var(--klsv-page-transition);
}

@media (hover: hover) and (pointer: fine) {
  .klsv-footer-v2__wordmark:hover,
  .klsv-footer-v2__links a:hover,
  .klsv-footer-v2__utility-links a:hover {
    color: var(--klsv-page-text);
    background: rgba(195,170,120,.055);
    box-shadow: 0 0 18px rgba(195,170,120,.10);
    transform: translateX(2px);
  }
}

.klsv-footer-v2__wordmark:focus-visible,
.klsv-footer-v2__links a:focus-visible,
.klsv-footer-v2__utility-links a:focus-visible {
  outline: 2px solid rgba(195,170,120,.80);
  outline-offset: 3px;
}

.klsv-footer-v2__wordmark:active,
.klsv-footer-v2__links a:active,
.klsv-footer-v2__utility-links a:active {
  transform: scale(.985);
  filter: brightness(1.08);
}

.klsv-footer-v2__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  justify-content: space-between;
  padding-block: 0;
  border-top: 0;
  color: var(--klsv-page-text-muted);
  font-size: .78rem;
}

.klsv-footer-v2__meta-copy {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 10px;
}

@media (min-width: 720px) {
  :root {
    --klsv-page-header-height: 72px;
  }

  .klsv-ui-hero__main,
  .klsv-hub-flat-head__main,
  .klsv-flat-page-head__main {
    grid-template-columns: minmax(0,1fr) minmax(260px, 380px);
    align-items: center;
    gap: clamp(24px, 5vw, 52px);
  }

  .klsv-card-grid,
  .klsv-related-profiles__grid,
  .klsv-peer-grid {
    grid-template-columns: repeat(3, minmax(0,1fr));
  }

  .klsv-footer-v2__grid {
    grid-template-columns: repeat(3, minmax(180px,1fr));
  }
}

@media (min-width: 1024px) {
  .klsv-card-grid,
  .klsv-related-profiles__grid,
  .klsv-peer-grid {
    grid-template-columns: repeat(4, minmax(0,1fr));
  }
}

/* Batch 6: keep tablet heroes single-column so action panels do not crush titles. */
@media (min-width: 720px) and (max-width: 959px) {
  .klsv-ui-hero__main,
  .klsv-hub-flat-head__main,
  .klsv-flat-page-head__main,
  body.klsv-runtime .klsv-ui-hero__main,
  body.klsv-runtime .klsv-hub-flat-head__main,
  body.klsv-runtime .klsv-flat-page-head__main {
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
  }

  .klsv-ui-hero__actions,
  .klsv-hub-flat-head__actions,
  .klsv-flat-page-head__actions,
  body.klsv-runtime .klsv-ui-hero__actions,
  body.klsv-runtime .klsv-hub-flat-head__actions,
  body.klsv-runtime .klsv-flat-page-head__actions {
    width: 100%;
    justify-self: stretch;
  }
}

@media (max-width: 980px) {
  .klsv-nav {
    display: none;
  }

  .navbar__menu {
    display: inline-flex;
    justify-self: end;
    margin-inline-start: auto;
  }

  .klsv-header__inner {
    display: flex;
    justify-content: space-between;
    gap: 12px;
  }

  .klsv-header__meta {
    min-width: 0;
  }

  .klsv-brand {
    min-width: 0;
  }

  .klsv-header__cta {
    display: none;
  }

  .klsv-header__support {
    display: none;
  }
}


@media (max-width: 760px) {
  .klsv-ui-hero__main,
  .klsv-hub-flat-head__main,
  .klsv-flat-page-head__main {
    grid-template-columns: minmax(0,1fr);
    align-items: stretch;
  }

  .klsv-ui-hero__copy,
  .klsv-hub-flat-head__copy,
  .klsv-flat-page-head__copy,
  .klsv-hub-flat-head__actions,
  .klsv-flat-page-head__actions {
    min-width: 0;
    max-width: 100%;
  }

  .klsv-hub-flat-head__action,
  .klsv-flat-page-head__action {
    max-width: 100%;
    white-space: normal;
  }
}

@media (max-width: 760px) {
  .klsv-footer-v2 {
    margin-top: clamp(22px, 8vw, 44px);
    padding-block: 28px 18px;
  }

  .klsv-footer-v2__grid {
    max-width: none;
    grid-template-columns: 1fr;
    gap: 18px;
    padding-block: 18px;
  }

  .klsv-footer-v2__links a,
  .klsv-footer-v2__utility-links a {
    min-height: 36px;
  }

  .klsv-footer-v2__meta {
    display: grid;
    gap: 10px;
  }

  .klsv-footer-v2__meta-copy {
    display: grid;
    gap: 4px;
  }
}

@media (max-width: 560px) {
  .klsv-main {
    padding-block-start: 6px;
  }

  .klsv-shell,
  .klsv-site-shell,
  .klsv-page-shell > .klsv-shell {
    width: calc(100% - 24px);
    max-width: var(--klsv-page-shell-wide);
  }

  .klsv-section-contract,
  .klsv-subpage-section,
  .klsv-copy-card,
  .klsv-panel,
  .klsv-faq-list,
  .klsv-content-state,
  .klsv-empty-state {
    padding: 14px;
  }

  .klsv-hub-flat-head__actions,
  .klsv-flat-page-head__actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .klsv-hub-flat-head__action,
  .klsv-flat-page-head__action {
    width: 100%;
  }
}


/* Global visual rhythm and shared cards */
:root {
  --klsv-space-1: 4px;
  --klsv-space-2: 8px;
  --klsv-space-3: 12px;
  --klsv-space-4: 16px;
  --klsv-space-5: 20px;
  --klsv-space-6: 24px;
  --klsv-space-8: 32px;
  --klsv-space-10: 40px;
  --klsv-page-border: rgba(255,255,255,.072);
  --klsv-page-border-strong: rgba(195,170,120,.24);
  --klsv-page-section-gap: clamp(16px, 2.3vw, 28px);
  --klsv-page-pad: clamp(14px, 3vw, 24px);
  --klsv-font-page-title: clamp(2rem, 8vw, 3.75rem);
  --klsv-font-section-title: clamp(1.55rem, 5vw, 2.55rem);
  --klsv-font-card-title: clamp(.98rem, 2.4vw, 1.18rem);
  --klsv-font-meta: .82rem;
}

.klsv-page-title,
.klsv-directory-hero h1,
.klsv-hub-flat-head h1,
.klsv-flat-page-head__title {
  font-size: var(--klsv-font-page-title);
  letter-spacing: -.046em;
}

.klsv-section-head h2,
.klsv-ui-section-head h2,
.klsv-copy-card h2,
.klsv-profile-system-panel h2,
.klsv-virtual-section h2 {
  font-size: var(--klsv-font-section-title);
  letter-spacing: -.04em;
}

.klsv-directory-card__title,
.klsv-profile-card__title,
.klsv-kl-area-card__name,
.klsv-malaysia-city-strip h3 {
  font-size: var(--klsv-font-card-title);
}

.klsv-directory-card__meta,
.klsv-profile-card__readout,
.klsv-profile-card__fact-line,
.klsv-profile-card__signal-meta,
.klsv-kl-area-strip__meta,
.klsv-malaysia-city-strip__meta {
  font-size: var(--klsv-font-meta);
}

.klsv-filter-chip,
.klsv-ds-filter-chip,
.klsv-malaysia-city-strip__link {
  transition: border-color .18s ease, background-color .18s ease, box-shadow .18s ease, transform .18s ease, color .18s ease;
}

.klsv-filter-chip,
.klsv-ds-filter-chip {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 999px;
  background: rgba(255,255,255,.024);
  color: var(--klsv-page-text-soft);
  line-height: 1;
  text-decoration: none;
}

.klsv-filter-chip:hover,
.klsv-ds-filter-chip:hover {
  color: var(--klsv-page-text);
  border-color: rgba(195,170,120,.30);
  background: rgba(195,170,120,.08);
  box-shadow: 0 0 22px rgba(195,170,120,.12);
}

.klsv-profile-card {
  align-self: start;
}

.klsv-profile-card__media {
  aspect-ratio: 3 / 4;
}

.klsv-profile-card__body {
  align-content: start;
}

.klsv-profile-card__title {
  margin: 0;
}

.klsv-profile-card__readout {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 8px;
}

.klsv-profile-card__footer {
  margin-top: 2px;
}

@media (max-width: 760px) {
  :root {
    --klsv-page-gutter: clamp(14px, 4vw, 20px);
    --klsv-page-section-gap: 18px;
    --klsv-page-pad: 14px;
    --klsv-font-page-title: clamp(2rem, 9.6vw, 2.7rem);
    --klsv-font-section-title: clamp(1.45rem, 6.3vw, 2rem);
  }

  .klsv-section-head,
  .klsv-ui-section-head {
    gap: 10px;
  }
}


/* Tokens, tap targets and empty states */
:root {
  --klsv-touch-target: 44px;
  --klsv-touch-target-compact: 40px;
  --klsv-touch-target-chip: 36px;
  --klsv-card-gap: clamp(10px, 2.4vw, 16px);
  --klsv-section-head-gap: clamp(10px, 2.2vw, 16px);
  --klsv-image-radius: var(--klsv-page-radius-sm);
  --klsv-page-text-soft: rgba(247,248,250,.72);
  --klsv-page-text-muted: rgba(247,248,250,.54);
}

.klsv-card-grid,
.klsv-ui-grid,
.klsv-related-profiles__grid,
.klsv-peer-grid,
.klsv-directory-grid,
.klsv-card-grid--profiles {
  gap: var(--klsv-card-gap);
}

.klsv-section-header,
.klsv-section-head,
.klsv-ui-section-head,
.klsv-panel__head,
.klsv-related-profiles__head,
.klsv-single-gallery__head {
  gap: var(--klsv-section-head-gap);
}

.klsv-section-copy,
.klsv-copy,
.klsv-content-state p,
.klsv-empty-state p {
  color: var(--klsv-page-text-soft);
}

.klsv-btn,
.klsv-button,
.klsv-ds-button,
.klsv-contact-channel-action,
.klsv-content-state__action {
  min-height: var(--klsv-touch-target);
  border-radius: 10px;
  transition:
    border-color var(--klsv-page-transition),
    background var(--klsv-page-transition),
    box-shadow var(--klsv-page-transition),
    color var(--klsv-page-transition),
    transform var(--klsv-page-transition);
}

.klsv-content-state__action {
  border-color: rgba(195,170,120,.22);
  background: rgba(195,170,120,.085);
  font-weight: 720;
}

.klsv-link-pill,
.klsv-hub-flat-head__action,
.klsv-flat-page-head__action,
.klsv-malaysia-city-strip__link,
.klsv-kl-area-strip__link,
.klsv-kl-area-stream__more,
.klsv-kl-directory-guide__link,
.klsv-malaysia-city-photo-toggle,
.klsv-malaysia-city-photo-card__profile-link,
.klsv-malaysia-city-photo-card__photo-link {
  display: inline-flex;
  min-height: var(--klsv-touch-target-compact);
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding-inline: 14px;
  border: 1px solid rgba(195,170,120,.18);
  border-radius: 999px;
  background: rgba(195,170,120,.075);
  color: var(--klsv-page-text);
  font-weight: 720;
  line-height: 1.1;
  text-decoration: none;
  box-shadow: 0 0 0 1px rgba(255,255,255,.025), 0 10px 24px rgba(0,0,0,.20);
}

.klsv-filter-chip,
.klsv-ds-filter-chip,
.klsv-pill,
.klsv-chip,
.klsv-content-state__chip {
  min-height: var(--klsv-touch-target-chip);
  align-items: center;
}

@media (hover: hover) and (pointer: fine) {
  .klsv-link-pill:hover,
  .klsv-filter-chip:hover,
  .klsv-ds-filter-chip:hover,
  .klsv-pill:hover,
  .klsv-chip:hover,
  .klsv-content-state__chip:hover,
  .klsv-content-state__action:hover,
  .klsv-malaysia-city-strip__link:hover,
  .klsv-kl-area-strip__link:hover {
    transform: translateY(-1px);
  }
}

@media (hover: none), (pointer: coarse) {
  .klsv-directory-card:hover,
  .klsv-profile-card:hover,
  .klsv-ds-directory-card:hover,
  .klsv-ds-listing-card:hover,
  .klsv-kl-area-strip:hover,
  .klsv-malaysia-city-strip:hover {
    transform: none;
    box-shadow: var(--klsv-page-glow-soft);
  }
}

.klsv-content-state,
.klsv-empty-state {
  display: grid;
  min-height: var(--klsv-state-min-height, 128px);
  align-content: center;
  gap: var(--klsv-state-gap, 12px);
  border-style: dashed;
  border-color: var(--klsv-state-border-strong, rgba(255,255,255,.10));
  background: var(--klsv-state-bg-empty, radial-gradient(circle at 50% 0%, rgba(195,170,120,.09), transparent 58%), rgba(255,255,255,.018));
}

.klsv-content-state:focus-within,
.klsv-empty-state:focus-within {
  border-color: rgba(195,170,120,.24);
  box-shadow: 0 0 0 3px rgba(195,170,120,.12);
}

.klsv-content-state__copy {
  display: grid;
  gap: 6px;
}

.klsv-content-state__eyebrow {
  color: var(--klsv-page-accent-strong, var(--klsv-page-accent));
  font-size: .72rem;
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.klsv-content-state h2,
.klsv-content-state h3,
.klsv-content-state h4,
.klsv-empty-state h2,
.klsv-empty-state h3,
.klsv-empty-state h4 {
  margin: 0;
  color: var(--klsv-page-text);
  font-size: clamp(1.05rem, 4vw, 1.35rem);
  line-height: 1.15;
  letter-spacing: -.02em;
}

.klsv-content-state p,
.klsv-empty-state p {
  max-width: 62ch;
  margin: 0;
  font-size: var(--klsv-state-copy-size, .92rem);
}

.klsv-content-state__links,
.klsv-content-state__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.klsv-card-media,
.klsv-profile-card__media,
.klsv-ds-listing-card__media,
.klsv-directory-card__media {
  border-radius: var(--klsv-image-radius) var(--klsv-image-radius) 0 0;
}


@media (max-width: 760px) {
  .klsv-ui-hero__main,
  .klsv-hub-flat-head__main,
  .klsv-flat-page-head__main {
    grid-template-columns: minmax(0,1fr);
    align-items: stretch;
  }

  .klsv-ui-hero__copy,
  .klsv-hub-flat-head__copy,
  .klsv-flat-page-head__copy,
  .klsv-hub-flat-head__actions,
  .klsv-flat-page-head__actions {
    min-width: 0;
    max-width: 100%;
  }

  .klsv-hub-flat-head__action,
  .klsv-flat-page-head__action {
    max-width: 100%;
    white-space: normal;
  }
}

@media (max-width: 560px) {
  :root {
    --klsv-card-gap: 10px;
    --klsv-section-head-gap: 10px;
  }

  .klsv-content-state__action {
    width: 100%;
  }

  .klsv-content-state,
  .klsv-empty-state {
    min-height: var(--klsv-state-mobile-min-height, 112px);
  }
}

/* Public UX pass: shared states, FAQ, CTA and footer rhythm */
.klsv-page {
  --klsv-p1-section-gap: clamp(18px, 3vw, 32px);
  --klsv-p1-card-gap: clamp(12px, 2vw, 18px);
}

.klsv-page .klsv-section-contract,
.klsv-page .klsv-subpage-section,
.klsv-page .klsv-copy-card,
.klsv-page .klsv-panel,
.klsv-page .klsv-faq-section,
.klsv-page .klsv-content-state,
.klsv-page .klsv-empty-state {
  border-color: rgba(255,255,255,.095);
}

.klsv-page .klsv-section-contract + .klsv-section-contract,
.klsv-page .klsv-section-contract + .klsv-faq-section,
.klsv-page .klsv-faq-section + .klsv-section-contract {
  margin-top: 0;
}

.klsv-header__cta,
.klsv-link-pill,
.klsv-section-link,
.klsv-hub-flat-head__action,
.klsv-flat-page-head__action,
.klsv-content-state__action,
.klsv-content-state__chip {
  min-height: var(--klsv-touch-target-compact, 40px);
  border-radius: 999px;
  font-weight: 780;
}

.klsv-link-pill,
.klsv-content-state__action,
.klsv-content-state__chip {
  border-color: rgba(195,170,120,.18);
  background: rgba(195,170,120,.065);
}

.klsv-content-state {
  position: relative;
  overflow: hidden;
  gap: clamp(12px, 2vw, 18px);
  background:
    radial-gradient(circle at 0% 0%, rgba(195,170,120,.10), transparent 22rem),
    var(--klsv-page-surface-card);
}

.klsv-content-state::before {
  content: "";
  width: 36px;
  height: 36px;
  border: 1px solid rgba(195,170,120,.30);
  border-radius: 12px;
  background:
    radial-gradient(circle at 50% 35%, rgba(195,170,120,.36), transparent 45%),
    rgba(255,255,255,.035);
  box-shadow: 0 0 24px rgba(195,170,120,.14);
}

.klsv-content-state__copy {
  display: grid;
  gap: 6px;
  max-width: var(--klsv-readable-measure, 68ch);
}

.klsv-content-state__eyebrow {
  color: var(--klsv-page-accent-strong);
  font-size: var(--klsv-type-eyebrow, .72rem);
  font-weight: 850;
  letter-spacing: .11em;
  text-transform: uppercase;
}

.klsv-content-state h2,
.klsv-content-state h3,
.klsv-content-state h4 {
  margin: 0;
  max-width: 18ch;
  font-size: clamp(1.24rem, 3.2vw, 1.72rem);
  line-height: 1.08;
  letter-spacing: -.025em;
}

.klsv-content-state p {
  margin: 0;
  color: var(--klsv-page-text-soft);
  line-height: var(--klsv-line-body, 1.62);
}

.klsv-content-state__actions,
.klsv-content-state__links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.klsv-faq-section {
  background:
    radial-gradient(circle at 92% 0%, rgba(195,170,120,.08), transparent 28rem),
    var(--klsv-page-surface-card);
}

.klsv-faq-section__intro,
.klsv-faq-section .klsv-section-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
  justify-content: start;
  text-align: left;
}

.klsv-faq-section__title {
  max-width: 18ch;
  font-size: clamp(1.45rem, 3.4vw, 2.05rem);
  line-height: 1.06;
  letter-spacing: -.035em;
}

.klsv-faq-section__copy {
  max-width: var(--klsv-readable-measure, 68ch);
}

.klsv-faq-section__item summary {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  min-height: 42px;
  cursor: pointer;
}

.klsv-faq-section__item summary::after {
  content: "+";
  color: var(--klsv-page-accent);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1;
}

.klsv-faq-section__item[open] summary::after {
  content: "–";
}

.klsv-faq-section__number {
  color: var(--klsv-page-accent-strong);
  font-size: .78rem;
  font-weight: 850;
}

.klsv-faq-section__answer {
  padding-inline-start: 34px;
}

.klsv-footer-v2 {
  margin-top: clamp(44px, 7vw, 88px);
}

.klsv-footer-v2 .klsv-shell {
  padding-block: clamp(28px, 5vw, 54px);
}

@media (hover: hover) and (pointer: fine) {
  .klsv-link-pill:hover,
  .klsv-content-state__action:hover,
  .klsv-content-state__chip:hover {
    border-color: rgba(195,170,120,.38);
    background: rgba(195,170,120,.13);
    box-shadow: 0 0 20px rgba(195,170,120,.14);
    transform: translateY(-1px);
  }
}

.klsv-content-state__action,
.klsv-content-state__chip {
  border-radius: var(--klsv-button-radius, 999px);
  transition:
    transform var(--klsv-page-transition),
    border-color var(--klsv-page-transition),
    background var(--klsv-page-transition),
    box-shadow var(--klsv-page-transition);
}

.klsv-content-state__action:focus-visible,
.klsv-content-state__chip:focus-visible {
  outline: 2px solid var(--klsv-page-focus-ring, rgba(118,140,159,.82));
  outline-offset: 3px;
  border-color: rgba(118,140,159,.48);
  box-shadow: 0 0 0 4px rgba(118,140,159,.12), 0 0 22px rgba(195,170,120,.16);
}

@media (max-width: 560px) {
  .klsv-faq-section__item summary {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .klsv-faq-section__number {
    display: none;
  }

  .klsv-faq-section__answer {
    padding-inline-start: 0;
  }

  .klsv-content-state::before {
    width: 30px;
    height: 30px;
    border-radius: 10px;
  }
}

/* Public QA regression: footer handoff and compact component states */
.klsv-main {
  padding-bottom: clamp(44px, 6vw, 72px);
}

.klsv-footer-v2 {
  margin-top: clamp(32px, 5vw, 64px);
}

.klsv-footer-v2 .klsv-shell {
  padding-block: clamp(26px, 4.5vw, 48px);
}

.klsv-ds-badge,
.klsv-ui-pill,
.klsv-pill,
.klsv-chip {
  box-shadow: none;
}

.klsv-link-pill.klsv-ds-badge,
.klsv-chip.klsv-ds-badge {
  min-height: var(--klsv-pill-height, 28px);
}

/* responsive visual QA: remove oversized section hover bands */
@media (hover: hover) and (pointer: fine) {
  .klsv-section-contract:hover,
  .klsv-subpage-section:hover,
  .klsv-copy-card:hover,
  .klsv-panel:hover {
    background: var(--klsv-page-surface-card);
    box-shadow: var(--klsv-page-glow-soft);
    transform: none;
  }

  .klsv-kl-area-strip:hover,
  .klsv-malaysia-city-strip:hover {
    background: transparent;
    box-shadow: none;
    transform: none;
  }
}

.klsv-profile-stage::before {
  inset: 0;
  opacity: .34;
}

.klsv-ds-section::before,
.klsv-section-contract::before,
.klsv-subpage-section::before {
  max-width: 100%;
  pointer-events: none;
}


/* public visual hierarchy polish. */
.klsv-home-flat__eyebrow,
.klsv-home-v2__eyebrow,
.klsv-content-state__eyebrow,
.klsv-footer-v2__eyebrow,
.klsv-footer-v2__column-title,
.klsv-telegram-updates-cta__eyebrow {
  color: var(--klsv-page-accent-strong);
  text-shadow: 0 0 18px rgba(195,170,120,.24);
}

.klsv-footer-v2 {
  margin-top: clamp(22px, 4vw, 48px);
  border-top-color: rgba(195,170,120,.14);
  background:
    radial-gradient(circle at 18% 0%, rgba(195,170,120,.11), transparent 30rem),
    radial-gradient(circle at 82% 10%, rgba(118,140,159,.055), transparent 28rem),
    linear-gradient(180deg, rgba(14,16,24,.92), rgba(5,6,10,1));
}

.klsv-footer-v2__brand {
  gap: 7px;
}

.klsv-footer-v2__eyebrow {
  font-size: .72rem;
  font-weight: 820;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.klsv-footer-v2__wordmark {
  color: var(--klsv-page-text);
  font-weight: 820;
}

.klsv-footer-v2__column-title {
  font-size: .82rem;
  font-weight: 820;
}

.klsv-footer-v2__grid {
  border-block-color: rgba(195,170,120,.10);
}

.klsv-footer-v2__links a,
.klsv-footer-v2__utility-links a {
  padding-inline: 2px 8px;
  color: rgba(247,248,250,.66);
}

@media (hover: hover) and (pointer: fine) {
  .klsv-footer-v2__wordmark:hover,
  .klsv-footer-v2__links a:hover,
  .klsv-footer-v2__utility-links a:hover {
    color: var(--klsv-page-accent-strong);
    background: rgba(195,170,120,.075);
    box-shadow: 0 0 20px rgba(195,170,120,.16);
    text-decoration: underline;
    text-decoration-color: rgba(195,170,120,.46);
    text-underline-offset: 4px;
  }
}


/* public hero rhythm unification: shared spacing contract. */
body.klsv-runtime .klsv-directory-hero,
body.klsv-runtime .klsv-hub-flat-head,
body.klsv-runtime .klsv-flat-page-head,
body.klsv-runtime .klsv-city-flat-head,
body.klsv-runtime .klsv-search-hero {
  display: grid;
  gap: var(--klsv-hero-meta-gap);
  padding: var(--klsv-hero-padding-block) var(--klsv-hero-padding-inline);
  border: 1px solid var(--klsv-page-border);
  border-radius: var(--klsv-page-radius);
  background:
    radial-gradient(circle at 86% 0%, rgba(195,170,120,.12), transparent 24rem),
    radial-gradient(circle at 0% 12%, rgba(118,140,159,.055), transparent 22rem),
    var(--klsv-page-surface-card);
  box-shadow:
    var(--klsv-glow-border, 0 0 0 1px rgba(195,170,120,.18)),
    0 18px 48px rgba(0,0,0,.28),
    var(--klsv-glow-soft, 0 0 48px rgba(195,170,120,.12));
}

body.klsv-runtime .klsv-ui-hero__main,
body.klsv-runtime .klsv-hub-flat-head__main,
body.klsv-runtime .klsv-flat-page-head__main {
  display: grid;
  min-width: 0;
  max-width: 100%;
  gap: var(--klsv-hero-grid-gap);
  align-items: center;
}

body.klsv-runtime .klsv-ui-hero__copy,
body.klsv-runtime .klsv-hub-flat-head__copy,
body.klsv-runtime .klsv-flat-page-head__copy {
  display: grid;
  min-width: 0;
  max-width: min(var(--klsv-hero-copy-max), 100%);
  gap: var(--klsv-hero-copy-gap);
  align-content: center;
}

body.klsv-runtime .klsv-ui-hero__copy > *,
body.klsv-runtime .klsv-hub-flat-head__copy > *,
body.klsv-runtime .klsv-flat-page-head__copy > *,
body.klsv-runtime .klsv-flat-page-head > .klsv-flat-page-head__eyebrow {
  margin-block: 0;
}

body.klsv-runtime .klsv-directory-hero h1,
body.klsv-runtime .klsv-hub-flat-head h1,
body.klsv-runtime .klsv-flat-page-head__title,
body.klsv-runtime .klsv-page-title {
  margin: 0;
  max-width: min(14ch, 100%);
  line-height: .98;
}

body.klsv-runtime .klsv-directory-hero p,
body.klsv-runtime .klsv-hub-flat-head__copy > p,
body.klsv-runtime .klsv-flat-page-head__intro {
  max-width: min(var(--klsv-hero-intro-max), 100%);
  margin: 0;
  line-height: 1.58;
}

body.klsv-runtime .klsv-ui-hero__actions,
body.klsv-runtime .klsv-hub-flat-head__actions,
body.klsv-runtime .klsv-flat-page-head__actions,
body.klsv-runtime .klsv-search-hero__tools {
  display: flex;
  min-width: 0;
  max-width: 100%;
  flex-wrap: wrap;
  gap: var(--klsv-hero-action-gap);
  align-items: center;
}

body.klsv-runtime .klsv-search-hero__tools {
  display: grid;
}

body.klsv-runtime .klsv-ui-hero__meta,
body.klsv-runtime .klsv-hub-flat-head__meta {
  margin: 0;
}

@media (min-width: 960px) {
  body.klsv-runtime .klsv-ui-hero__main,
  body.klsv-runtime .klsv-hub-flat-head__main,
  body.klsv-runtime .klsv-flat-page-head__main {
    grid-template-columns: minmax(0, 1fr) minmax(260px, var(--klsv-hero-action-max));
  }

  body.klsv-runtime .klsv-ui-hero__actions,
  body.klsv-runtime .klsv-hub-flat-head__actions,
  body.klsv-runtime .klsv-flat-page-head__actions,
  body.klsv-runtime .klsv-search-hero__tools {
    width: min(var(--klsv-hero-action-max), 100%);
    justify-self: end;
    align-self: center;
    justify-content: flex-end;
  }
}

@media (max-width: 760px) {
  body.klsv-runtime .klsv-directory-hero,
  body.klsv-runtime .klsv-hub-flat-head,
  body.klsv-runtime .klsv-flat-page-head,
  body.klsv-runtime .klsv-city-flat-head,
  body.klsv-runtime .klsv-search-hero {
    padding: var(--klsv-hero-padding-block) var(--klsv-hero-padding-inline);
  }

  body.klsv-runtime .klsv-ui-hero__main,
  body.klsv-runtime .klsv-hub-flat-head__main,
  body.klsv-runtime .klsv-flat-page-head__main {
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
  }

  body.klsv-runtime .klsv-ui-hero__actions,
  body.klsv-runtime .klsv-hub-flat-head__actions,
  body.klsv-runtime .klsv-flat-page-head__actions,
  body.klsv-runtime .klsv-search-hero__tools {
    width: 100%;
    justify-self: stretch;
    justify-content: flex-start;
  }
}




/* Global Button + Hero Rhythm Consolidation.
 * Home can skin its hero image, but reusable button feel, hero scale,
 * title measure and action rhythm live in the shared layer.
 */
.klsv-ds-button,
.klsv-button,
.klsv-btn,
.klsv-link-pill,
.klsv-section-link,
.klsv-section-actions a,
.klsv-ui-action,
.klsv-kl-hero__button,
.klsv-malaysia-hero__button,
.klsv-hub-flat-head__action,
.klsv-flat-page-head__action {
  min-height: var(--klsv-button-height, var(--klsv-touch-target, 44px));
  padding-inline: var(--klsv-button-padding-inline, clamp(.95rem, 1.8vw, 1.25rem));
  border-color: var(--klsv-button-border, rgba(255,255,255,.16));
  border-radius: var(--klsv-button-radius, 18px);
  background: var(--klsv-button-bg, rgba(255,255,255,.045));
  box-shadow: var(--klsv-button-shadow, 0 0 0 1px rgba(255,255,255,.024), 0 14px 32px rgba(0,0,0,.24));
  font-weight: 800;
}

.klsv-ds-button--primary,
.klsv-button--primary,
.klsv-btn--primary,
.klsv-ui-action--primary,
.klsv-kl-hero__button--primary,
.klsv-malaysia-hero__button--primary,
.klsv-header__cta--whatsapp {
  border-color: var(--klsv-button-primary-border, rgba(167,124,255,.48));
  background: var(--klsv-button-primary-bg, linear-gradient(135deg, rgba(89,105,92,.86), rgba(118,140,159,.78)));
  box-shadow: var(--klsv-button-primary-shadow, 0 18px 38px rgba(44,38,27,.34));
  color: #fff;
}

.klsv-ds-button--secondary,
.klsv-button--secondary,
.klsv-btn--secondary,
.klsv-ui-action--secondary,
.klsv-kl-hero__button--secondary,
.klsv-kl-hero__button--whatsapp,
.klsv-malaysia-hero__button--secondary,
.klsv-malaysia-hero__button--whatsapp {
  border-color: var(--klsv-button-border, rgba(255,255,255,.16));
  background: var(--klsv-button-bg, rgba(255,255,255,.045));
}

.klsv-directory-hero__button {
  --klsv-button-height: clamp(48px, 4.5vw, 56px);
  --klsv-button-padding-inline: clamp(1.15rem, 2vw, 1.55rem);
  --klsv-button-radius: 999px;
  display: inline-flex;
  min-width: min(100%, 170px);
  align-items: center;
  justify-content: center;
  border-width: 1px;
  border-style: solid;
  font-size: clamp(.9rem, 1vw, 1rem);
  line-height: 1;
  text-align: center;
  white-space: nowrap;
}

.klsv-directory-hero__button.klsv-button--primary,
.klsv-directory-hero__button.klsv-hub-flat-head__action--primary {
  min-width: min(100%, 190px);
}

.klsv-link-pill,
.klsv-section-link,
.klsv-hub-flat-head__action,
.klsv-flat-page-head__action,
.klsv-home-v2__panel-link,
.klsv-home-area-card-v2__cta {
  min-height: var(--klsv-button-compact-height, var(--klsv-touch-target-compact, 40px));
}

.klsv-directory-hero__button.klsv-hub-flat-head__action {
  min-height: var(--klsv-button-height, var(--klsv-touch-target, 44px));
}

@media (hover: hover) and (pointer: fine) {
  .klsv-ds-button:hover,
  .klsv-button:hover,
  .klsv-btn:hover,
  .klsv-link-pill:hover,
  .klsv-section-link:hover,
  .klsv-section-actions a:hover,
  .klsv-ui-action:hover,
  .klsv-kl-hero__button:hover,
  .klsv-malaysia-hero__button:hover,
  .klsv-hub-flat-head__action:hover,
  .klsv-flat-page-head__action:hover {
    border-color: var(--klsv-button-hover-border, rgba(195,170,120,.62));
    background: rgba(195,170,120,.12);
    transform: translateY(-2px);
  }

  .klsv-kl-hero__button--telegram:hover,
  .klsv-kl-hero__button--whatsapp:hover,
  .klsv-malaysia-hero__button--whatsapp:hover {
    border-color: rgba(118, 140, 159, .45);
    background: linear-gradient(135deg, rgba(89,105,92,.22), rgba(118,140,159,.16));
    box-shadow: 0 0 0 1px rgba(118,140,159,.18), 0 18px 38px rgba(44,38,27,.24);
    color: #fff;
  }
}

.klsv-kl-hero__button--telegram:focus-visible,
.klsv-kl-hero__button--whatsapp:focus-visible,
.klsv-malaysia-hero__button--whatsapp:focus-visible {
  border-color: rgba(118, 140, 159, .45);
  background: linear-gradient(135deg, rgba(89,105,92,.22), rgba(118,140,159,.16));
  box-shadow: 0 0 0 1px rgba(118,140,159,.18), 0 18px 38px rgba(44,38,27,.24);
  color: #fff;
}

/* KL and Malaysia hub heroes use a final shared skin to avoid page-token drift. */
.klsv-kl-command-deck .klsv-kl-hero__cta-row,
.klsv-page--malaysia-cities-hub .klsv-malaysia-hero__cta-row {
  display: grid;
  align-items: stretch;
}

.klsv-kl-command-deck .klsv-kl-hero__route-buttons,
.klsv-page--malaysia-cities-hub .klsv-malaysia-hero__route-buttons {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.klsv-kl-command-deck .klsv-kl-hero__button--telegram,
.klsv-page--malaysia-cities-hub .klsv-malaysia-hero__button--telegram {
  min-height: clamp(52px, 5vw, 60px);
  border-color: rgba(31, 166, 218, .46);
  background: linear-gradient(135deg, rgba(16, 92, 126, .96), rgba(10, 62, 92, .92));
  color: #fff;
  box-shadow: 0 18px 42px rgba(9, 92, 135, .28), 0 0 0 1px rgba(255,255,255,.055) inset;
}

.klsv-kl-command-deck .klsv-kl-hero__button--secondary,
.klsv-page--malaysia-cities-hub .klsv-malaysia-hero__button--secondary {
  min-height: 44px;
  border-color: rgba(195,170,120,.22);
  background: transparent;
  color: rgba(247,248,250,.84);
  box-shadow: none;
  font-size: .78rem;
}

@media (hover: hover) and (pointer: fine) {
  .klsv-kl-command-deck .klsv-kl-hero__button--telegram:hover,
  .klsv-page--malaysia-cities-hub .klsv-malaysia-hero__button--telegram:hover {
    border-color: rgba(55, 188, 238, .68);
    background: linear-gradient(135deg, rgba(19, 112, 151, .98), rgba(12, 75, 109, .96));
    box-shadow: 0 20px 46px rgba(9, 92, 135, .36), 0 0 0 1px rgba(255,255,255,.075) inset;
    color: #fff;
  }

  .klsv-kl-command-deck .klsv-kl-hero__button--secondary:hover,
  .klsv-page--malaysia-cities-hub .klsv-malaysia-hero__button--secondary:hover {
    border-color: rgba(243, 210, 123, .48);
    background: rgba(243, 210, 123, .07);
    color: #fff;
  }
}

.klsv-kl-command-deck .klsv-kl-hero__button--telegram:focus-visible,
.klsv-page--malaysia-cities-hub .klsv-malaysia-hero__button--telegram:focus-visible {
  border-color: rgba(55, 188, 238, .68);
  background: linear-gradient(135deg, rgba(19, 112, 151, .98), rgba(12, 75, 109, .96));
  box-shadow: 0 20px 46px rgba(9, 92, 135, .36), 0 0 0 1px rgba(255,255,255,.075) inset;
  color: #fff;
}

.klsv-kl-command-deck .klsv-kl-hero__button--secondary:focus-visible,
.klsv-page--malaysia-cities-hub .klsv-malaysia-hero__button--secondary:focus-visible {
  border-color: rgba(243, 210, 123, .48);
  background: rgba(243, 210, 123, .07);
  color: #fff;
}

.klsv-kl-command-deck .klsv-kl-hero__stats,
.klsv-page--malaysia-cities-hub .klsv-malaysia-hero__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(12px, 2vw, 18px);
  margin: 0;
  padding: clamp(16px, 2.4vw, 22px) 0 0;
  width: 100%;
  max-width: 100%;
  border-top: 1px solid rgba(255,255,255,.08);
}

.klsv-kl-command-deck .klsv-kl-hero__stat,
.klsv-page--malaysia-cities-hub .klsv-malaysia-hero__stat {
  display: grid;
  grid-template-columns: 1fr;
  align-items: start;
  gap: 5px;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.klsv-kl-command-deck .klsv-kl-hero__stat dt,
.klsv-page--malaysia-cities-hub .klsv-malaysia-hero__stat dt {
  margin: 0;
  color: var(--klsv-hero-stat-muted-accent, rgba(116, 138, 120, .72));
  font-size: clamp(1.35rem, 2.8vw, 2rem);
  font-weight: 820;
  line-height: 1.1;
  letter-spacing: 0;
}

.klsv-kl-command-deck .klsv-kl-hero__stat dd,
.klsv-page--malaysia-cities-hub .klsv-malaysia-hero__stat dd {
  margin: 0;
  color: rgba(247,248,250,.7);
  font-size: .76rem;
  font-weight: 720;
  line-height: 1.1;
  text-transform: uppercase;
}

.klsv-ui-hero,
.klsv-directory-hero,
.klsv-hub-flat-head,
.klsv-flat-page-head,
.klsv-city-flat-head,
.klsv-search-hero {
  padding: var(--klsv-hero-padding-block) var(--klsv-hero-padding-inline);
}

.klsv-ui-hero__main,
.klsv-hub-flat-head__main,
.klsv-flat-page-head__main {
  gap: var(--klsv-hero-grid-gap);
}

.klsv-ui-hero__copy,
.klsv-hub-flat-head__copy,
.klsv-flat-page-head__copy {
  max-width: min(var(--klsv-hero-copy-max, 720px), 100%);
  gap: var(--klsv-hero-copy-gap, 14px);
}

.klsv-page-title,
.klsv-directory-hero h1,
.klsv-flat-page-head__title,
.klsv-hub-flat-head h1 {
  max-width: var(--klsv-hero-title-measure, min(17ch, 100%));
  font-size: var(--klsv-hero-title-size, clamp(2.55rem, 4.65vw, 5.35rem));
  font-weight: var(--klsv-hero-title-weight, 560);
  line-height: var(--klsv-hero-title-line, 1.04);
  letter-spacing: var(--klsv-hero-title-tracking, -.032em);
  text-wrap: balance;
}

.klsv-directory-hero p,
.klsv-flat-page-head__intro,
.klsv-hub-flat-head__copy > p {
  max-width: var(--klsv-hero-intro-max, 62ch);
}

.klsv-hub-flat-head__actions,
.klsv-flat-page-head__actions,
.klsv-ui-hero__actions {
  gap: var(--klsv-hero-action-gap, 10px);
}

/* Shared public card information hierarchy. Page cards should consume these
   tokens instead of hard-coding separate name, meta and price colors. */
:root {
  --klsv-card-info-title: #d8bf7a;
  --klsv-card-info-meta: rgba(255,255,255,.86);
  --klsv-card-info-price: #93e6a4;
}

/* Batch 5: shared listing/card/filter/CTA component contract. */
:root {
  --klsv-component-card-radius: var(--klsv-ui-card-radius-compact, 12px);
  --klsv-component-card-border: rgba(255,255,255,.09);
  --klsv-component-card-border-hover: rgba(216,191,122,.34);
  --klsv-component-card-bg: linear-gradient(180deg, rgba(255,255,255,.046), rgba(255,255,255,.018));
  --klsv-component-card-bg-hover: linear-gradient(180deg, rgba(255,255,255,.064), rgba(255,255,255,.024));
  --klsv-component-card-shadow: 0 16px 34px rgba(0,0,0,.24);
  --klsv-component-card-shadow-hover: 0 22px 44px rgba(0,0,0,.32);
  --klsv-component-chip-border: rgba(255,255,255,.12);
  --klsv-component-chip-bg: rgba(255,255,255,.045);
  --klsv-component-chip-bg-active: rgba(42,211,191,.12);
  --klsv-component-chip-border-active: rgba(42,211,191,.38);
  --klsv-component-motion: 160ms ease;
}

.klsv-card-grid--profiles,
.klsv-ds-grid--profiles,
.klsv-search-results-grid,
.klsv-search-recent-grid,
.klsv-keyword-profile-grid {
  align-items: stretch;
  gap: clamp(12px, 2vw, 18px);
}

.klsv-profile-card-contract,
.klsv-directory-card--profile,
.klsv-ds-listing-card--profile,
.klsv-search-profile-card,
.klsv-keyword-profile-card {
  position: relative;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  min-width: 0;
  height: 100%;
  overflow: hidden;
  border: 1px solid var(--klsv-component-card-border);
  border-radius: var(--klsv-component-card-radius);
  background: var(--klsv-component-card-bg);
  box-shadow: var(--klsv-component-card-shadow);
  isolation: isolate;
  transition:
    border-color var(--klsv-component-motion),
    background var(--klsv-component-motion),
    box-shadow var(--klsv-component-motion),
    transform var(--klsv-component-motion);
}

.klsv-profile-card-contract:focus-within,
.klsv-directory-card--profile:focus-within,
.klsv-ds-listing-card--profile:focus-within,
.klsv-search-profile-card:focus-within,
.klsv-keyword-profile-card:focus-within {
  border-color: var(--klsv-component-card-border-hover);
  box-shadow: var(--klsv-component-card-shadow-hover), 0 0 0 3px rgba(216,191,122,.12);
}

.klsv-profile-card-contract .klsv-profile-card__media,
.klsv-directory-card--profile .klsv-profile-card__media,
.klsv-ds-listing-card--profile .klsv-profile-card__media,
.klsv-search-profile-card .klsv-profile-card__media,
.klsv-keyword-profile-card .klsv-profile-card__media {
  position: relative;
  min-width: 0;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 0%, rgba(216,191,122,.12), transparent 46%),
    rgba(255,255,255,.03);
}

.klsv-profile-card-contract .klsv-profile-card__img,
.klsv-directory-card--profile .klsv-profile-card__img,
.klsv-ds-listing-card--profile .klsv-profile-card__img,
.klsv-search-profile-card .klsv-profile-card__img,
.klsv-keyword-profile-card .klsv-profile-card__img {
  transition: transform 220ms ease, filter 220ms ease;
}

.klsv-profile-card__media-fallback {
  display: grid;
  min-height: clamp(180px, 32vw, 320px);
  place-items: center;
  color: rgba(247,248,250,.82);
  font-size: clamp(2rem, 6vw, 3.5rem);
  font-weight: 820;
}

.klsv-profile-card-contract .klsv-profile-card__body,
.klsv-directory-card--profile .klsv-profile-card__body,
.klsv-ds-listing-card--profile .klsv-profile-card__body,
.klsv-search-profile-card .klsv-profile-card__body,
.klsv-keyword-profile-card .klsv-profile-card__body {
  display: grid;
  grid-template-rows: auto;
  align-content: start;
  min-width: 0;
}

.klsv-profile-card__readout,
.klsv-profile-card__facts,
.klsv-profile-card__signal-row,
.klsv-profile-card__footer {
  min-width: 0;
}

.klsv-profile-card__footer {
  margin-top: auto;
}

.klsv-profile-card__footer .klsv-link-pill,
.klsv-ds-filter-chip,
.klsv-link-pill {
  min-height: var(--klsv-touch-target, 44px);
}

.klsv-ds-filter-chip,
.klsv-link-pill,
.klsv-content-state__chip {
  border-color: var(--klsv-component-chip-border);
  background: var(--klsv-component-chip-bg);
  transition:
    border-color var(--klsv-component-motion),
    background var(--klsv-component-motion),
    color var(--klsv-component-motion),
    transform var(--klsv-component-motion);
}

.klsv-ds-filter-chip.is-active,
.klsv-ds-filter-chip[aria-current="page"],
.klsv-link-pill.is-active,
.klsv-content-state__chip.is-active {
  border-color: var(--klsv-component-chip-border-active);
  background: var(--klsv-component-chip-bg-active);
  color: var(--klsv-public-action, #2ad3bf);
}

.klsv-ds-button[aria-disabled="true"],
.klsv-ds-button.is-disabled,
.klsv-btn[aria-disabled="true"],
.klsv-btn.is-disabled,
.klsv-link-pill[aria-disabled="true"],
.klsv-link-pill.is-disabled {
  opacity: .58;
  pointer-events: none;
}

@media (hover: hover) and (pointer: fine) {
  .klsv-profile-card-contract:hover,
  .klsv-directory-card--profile:hover,
  .klsv-ds-listing-card--profile:hover,
  .klsv-search-profile-card:hover,
  .klsv-keyword-profile-card:hover {
    border-color: var(--klsv-component-card-border-hover);
    background: var(--klsv-component-card-bg-hover);
    box-shadow: var(--klsv-component-card-shadow-hover);
    transform: translateY(-2px);
  }

  .klsv-profile-card-contract:hover .klsv-profile-card__img,
  .klsv-directory-card--profile:hover .klsv-profile-card__img,
  .klsv-ds-listing-card--profile:hover .klsv-profile-card__img,
  .klsv-search-profile-card:hover .klsv-profile-card__img,
  .klsv-keyword-profile-card:hover .klsv-profile-card__img {
    transform: scale(1.025);
    filter: saturate(1.04) contrast(1.02);
  }

  .klsv-ds-filter-chip:hover,
  .klsv-link-pill:hover,
  .klsv-content-state__chip:hover {
    border-color: var(--klsv-component-chip-border-active);
    background: rgba(42,211,191,.10);
  }
}

@media (prefers-reduced-motion: reduce) {
  .klsv-profile-card-contract,
  .klsv-directory-card--profile,
  .klsv-ds-listing-card--profile,
  .klsv-search-profile-card,
  .klsv-keyword-profile-card,
  .klsv-profile-card__img,
  .klsv-ds-filter-chip,
  .klsv-link-pill,
  .klsv-content-state__chip {
    transition: none;
  }

  .klsv-profile-card-contract:hover,
  .klsv-directory-card--profile:hover,
  .klsv-ds-listing-card--profile:hover,
  .klsv-search-profile-card:hover,
  .klsv-keyword-profile-card:hover,
  .klsv-profile-card-contract:hover .klsv-profile-card__img,
  .klsv-directory-card--profile:hover .klsv-profile-card__img,
  .klsv-ds-listing-card--profile:hover .klsv-profile-card__img,
  .klsv-search-profile-card:hover .klsv-profile-card__img,
  .klsv-keyword-profile-card:hover .klsv-profile-card__img {
    transform: none;
  }
}
