/*
Theme Name: Kavana Interio
Theme URI: https://kavanainterio.com
Author: Kavana Interio Team
Description: Premium Luxury Interior Design WordPress Theme — Light Cream & Gold. Fully Elementor compatible.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: kavana-interio
Tags: interior-design, luxury, elementor, responsive, light-mode
*/

/* ============================================================
   KAVANA INTERIO — DESIGN TOKENS (ALL LIGHT PALETTE)
   ============================================================ */
:root {
  /* Brand Gold */
  --ki-gold:          #C9A96E;
  --ki-gold-dark:     #A67C4A;
  --ki-gold-light:    #E8D5B0;
  --ki-gold-pale:     #F5ECD8;

  /* Cream Backgrounds — NEVER dark */
  --ki-cream:         #FDF8F0;
  --ki-cream-mid:     #F9F1E4;
  --ki-cream-dark:    #F2E6D2;
  --ki-warm-white:    #FEFCF8;
  --ki-sand:          #EDE0C8;
  --ki-linen:         #FAF5EC;

  /* Text — Warm Browns (no black) */
  --ki-text-primary:  #4A3425;
  --ki-text-secondary:#6B4C35;
  --ki-text-muted:    #9A7B65;
  --ki-text-light:    #C4A882;

  /* Accent */
  --ki-terracotta:    #C8856A;
  --ki-sage:          #8EA888;
  --ki-blush:         #EAC8BC;
  --ki-lavender:      #C8BAD8;

  /* UI */
  --ki-border:        #E6D4BC;
  --ki-border-light:  #EFE4D0;
  --ki-shadow:        rgba(180, 140, 90, 0.10);
  --ki-shadow-gold:   rgba(201, 169, 110, 0.22);
  --ki-shadow-soft:   rgba(180, 140, 90, 0.07);

  /* SUCCESS / Footer now light */
  --ki-footer-bg:     #FDF6EC;
  --ki-footer-border: #E8D5B0;

  /* Typography */
  --font-heading: 'Cinzel', 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Josefin Sans', 'Lato', sans-serif;
  --font-accent:  'Cormorant Garamond', Georgia, serif;

  /* Spacing */
  --space-xs:  0.5rem;
  --space-sm:  1rem;
  --space-md:  1.5rem;
  --space-lg:  2.5rem;
  --space-xl:  4rem;
  --space-2xl: 6rem;
  --space-3xl: 8rem;

  /* Transitions */
  --transition-fast:  150ms ease;
  --transition-base:  280ms ease;
  --transition-slow:  550ms cubic-bezier(0.4, 0, 0.2, 1);

  /* Radius */
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --radius-full: 9999px;

  /* Z-index */
  --z-dropdown: 10;
  --z-sticky:   20;
  --z-overlay:  30;
  --z-modal:    40;
  --z-toast:    50;

  /* Logo — fixed 48px height always */
  --logo-height: 48px;
}

/* ============================================================
   GLOBAL KEYFRAMES & ANIMATIONS
   ============================================================ */
@keyframes fadeUp      { from { opacity:0; transform:translateY(28px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn      { from { opacity:0; } to { opacity:1; } }
@keyframes fadeLeft    { from { opacity:0; transform:translateX(-28px); } to { opacity:1; transform:translateX(0); } }
@keyframes fadeRight   { from { opacity:0; transform:translateX(28px); } to { opacity:1; transform:translateX(0); } }
@keyframes scaleIn     { from { opacity:0; transform:scale(0.92); } to { opacity:1; transform:scale(1); } }
@keyframes slideDown   { from { opacity:0; transform:translateY(-20px); } to { opacity:1; transform:translateY(0); } }
@keyframes shimmer     { 0% { background-position:-200% 0; } 100% { background-position:200% 0; } }
@keyframes pulse       { 0%,100% { transform:scale(1); } 50% { transform:scale(1.06); } }
@keyframes float       { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-12px); } }
@keyframes spin        { from { transform:rotate(0deg); } to { transform:rotate(360deg); } }
@keyframes heroZoom    { from { transform:scale(1.04); } to { transform:scale(1.10); } }
@keyframes scrollBounce{ 0%,100% { transform:translateY(0); opacity:1; } 50% { transform:translateY(8px); opacity:0.4; } }
@keyframes goldLine    { from { width:0; } to { width:60px; } }
@keyframes borderGlow  { 0%,100% { box-shadow:0 0 0 0 rgba(201,169,110,0); } 50% { box-shadow:0 0 0 6px rgba(201,169,110,0.25); } }
@keyframes ribbonPulse { 0%,100% { opacity:0.9; } 50% { opacity:1; } }
@keyframes particleFloat { 0%,100% { transform:translateY(0) scale(1); opacity:0.5; } 50% { transform:translateY(-24px) scale(1.2); opacity:0.8; } }
@keyframes counterUp { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

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

html { scroll-behavior:smooth; font-size:16px; }

body {
  font-family: var(--font-body);
  background-color: var(--ki-warm-white);
  color: var(--ki-text-primary);
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img { max-width:100%; height:auto; display:block; }
a { color:var(--ki-gold-dark); text-decoration:none; transition:color var(--transition-base); }
a:hover { color:var(--ki-gold); }
a:focus-visible { outline:2px solid var(--ki-gold); outline-offset:2px; border-radius:var(--radius-sm); }

h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-heading);
  color: var(--ki-text-primary);
  line-height: 1.25;
  letter-spacing: 0.03em;
}
p { margin-bottom:var(--space-sm); max-width:70ch; }

/* ============================================================
   UTILITY
   ============================================================ */
.container       { max-width:1200px; margin:0 auto; padding:0 var(--space-md); }
.container--wide { max-width:1440px; margin:0 auto; padding:0 var(--space-md); }
.text-center     { text-align:center; }
.text-gold       { color:var(--ki-gold); }
.bg-cream        { background-color:var(--ki-cream); }
.bg-linen        { background-color:var(--ki-linen); }
.bg-warm-white   { background-color:var(--ki-warm-white); }
.section-pad     { padding:var(--space-3xl) 0; }
.section-pad--sm { padding:var(--space-2xl) 0; }

/* Section heading */
.section-heading { text-align:center; margin-bottom:var(--space-2xl); }
.section-heading .eyebrow {
  display:inline-block;
  font-family:var(--font-body);
  font-size:0.72rem;
  font-weight:700;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--ki-gold-dark);
  margin-bottom:0.5rem;
  animation: fadeIn 0.6s ease both;
}
.section-heading h2 {
  font-size:clamp(1.75rem, 3.5vw, 2.85rem);
  color:var(--ki-text-primary);
  margin-bottom:0.75rem;
}
.section-heading .gold-line {
  width:0; height:3px;
  background:linear-gradient(90deg, transparent, var(--ki-gold), transparent);
  margin:0.75rem auto;
  border-radius:var(--radius-full);
  animation: goldLine 0.8s ease 0.3s forwards;
}
.section-heading p {
  font-size:1.05rem;
  color:var(--ki-text-secondary);
  max-width:580px;
  margin:0 auto;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display:inline-flex; align-items:center; gap:0.5rem;
  padding:0.875rem 1.875rem;
  font-family:var(--font-body); font-size:0.82rem;
  font-weight:700; letter-spacing:0.1em; text-transform:uppercase;
  border-radius:var(--radius-sm);
  cursor:pointer; border:2px solid transparent;
  transition:all var(--transition-base);
  text-decoration:none; min-height:44px; white-space:nowrap;
  position:relative; overflow:hidden;
}
/* Ripple shimmer on hover */
.btn::after {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.18) 50%, transparent 100%);
  transform:translateX(-100%);
  transition:transform 0.5s ease;
}
.btn:hover::after { transform:translateX(100%); }

.btn-primary {
  background:linear-gradient(135deg, var(--ki-gold), var(--ki-gold-dark));
  color:var(--ki-warm-white);
  border-color:var(--ki-gold);
  box-shadow:0 4px 18px var(--ki-shadow-gold);
}
.btn-primary:hover {
  background:linear-gradient(135deg, var(--ki-gold-dark), #8B6132);
  color:var(--ki-warm-white);
  transform:translateY(-2px);
  box-shadow:0 8px 28px var(--ki-shadow-gold);
}
.btn-outline {
  background:transparent;
  color:var(--ki-gold-dark);
  border-color:var(--ki-gold);
}
.btn-outline:hover {
  background:var(--ki-gold);
  color:var(--ki-warm-white);
  transform:translateY(-2px);
}
.btn-white {
  background:rgba(255,255,255,0.95);
  color:var(--ki-text-primary);
  border-color:transparent;
  box-shadow:0 4px 18px rgba(180,140,90,0.12);
}
.btn-white:hover {
  background:var(--ki-gold);
  color:var(--ki-warm-white);
  transform:translateY(-2px);
}
.btn-cream {
  background:var(--ki-cream);
  color:var(--ki-text-primary);
  border-color:var(--ki-border);
}
.btn-cream:hover { background:var(--ki-gold-pale); border-color:var(--ki-gold); }

/* ============================================================
   HEADER — ALWAYS LIGHT WHEN SCROLLED
   ============================================================ */
#masthead {
  position:fixed; top:0; left:0; right:0;
  z-index:var(--z-sticky);
  transition:all var(--transition-slow);
}
#masthead.top {
  background:linear-gradient(180deg, rgba(255,255,255,0.15) 0%, transparent 100%);
}
#masthead.scrolled {
  background:rgba(253,248,240,0.97);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  box-shadow:0 2px 32px rgba(180,140,90,0.12);
  border-bottom:1px solid var(--ki-border-light);
}

.site-header-inner {
  display:flex; align-items:center; justify-content:space-between;
  padding:0.75rem var(--space-md);
  max-width:1440px; margin:0 auto; gap:var(--space-md);
  min-height:70px;
}

/* ── LOGO — FIXED 48px ─────────────────────────────────────── */
.site-branding { display:flex; align-items:center; gap:0.75rem; flex-shrink:0; }

/* Every logo image — fixed height no matter what is uploaded */
.site-branding img,
.custom-logo,
.custom-logo img,
.site-logo img,
.wp-block-site-logo img {
  height: var(--logo-height) !important;
  width:  auto             !important;
  max-height: var(--logo-height) !important;
  max-width:  200px        !important;
  object-fit: contain      !important;
  display:block;
}

.site-title-text { display:flex; flex-direction:column; line-height:1; }
.site-title-text .name {
  font-family:var(--font-heading);
  font-size:1.3rem; font-weight:700;
  color:var(--ki-warm-white);
  letter-spacing:0.05em;
  transition:color var(--transition-base);
}
.site-title-text .tagline {
  font-size:0.58rem; letter-spacing:0.22em;
  text-transform:uppercase; color:rgba(255,255,255,0.75);
  transition:color var(--transition-base);
}
#masthead.scrolled .site-title-text .name   { color:var(--ki-text-primary); }
#masthead.scrolled .site-title-text .tagline { color:var(--ki-gold-dark); }

/* ── PRIMARY NAV ───────────────────────────────────────────── */
.main-navigation { display:flex; align-items:center; }
.main-navigation ul {
  list-style:none; display:flex; align-items:center; gap:0.1rem;
}
.main-navigation li { position:relative; }
.main-navigation a {
  display:block; padding:0.55rem 0.85rem;
  font-size:0.78rem; font-weight:700; letter-spacing:0.08em;
  text-transform:uppercase; color:rgba(255,255,255,0.92);
  border-radius:var(--radius-sm);
  transition:all var(--transition-base); white-space:nowrap;
  position:relative;
}
.main-navigation a::after {
  content:''; position:absolute; bottom:2px; left:50%; right:50%;
  height:2px; background:var(--ki-gold);
  transition:all var(--transition-base); border-radius:1px;
}
.main-navigation a:hover::after,
.main-navigation .current-menu-item > a::after { left:10%; right:10%; }
.main-navigation a:hover { color:var(--ki-gold-light); }
.main-navigation .current-menu-item > a { color:var(--ki-gold-light); }

#masthead.scrolled .main-navigation a { color:var(--ki-text-primary); }
#masthead.scrolled .main-navigation a:hover { color:var(--ki-gold-dark); }
#masthead.scrolled .main-navigation .current-menu-item > a { color:var(--ki-gold-dark); }

/* Dropdown */
.main-navigation .sub-menu {
  position:absolute; top:calc(100% + 0.5rem); left:0;
  min-width:220px;
  background:rgba(253,248,240,0.98);
  backdrop-filter:blur(20px);
  border:1px solid var(--ki-border-light);
  border-radius:var(--radius-md);
  box-shadow:0 10px 40px rgba(180,140,90,0.15);
  opacity:0; visibility:hidden;
  transform:translateY(-8px) scale(0.97);
  transition:all var(--transition-base);
  z-index:var(--z-dropdown);
}
.main-navigation li:hover > .sub-menu,
.main-navigation li:focus-within > .sub-menu {
  opacity:1; visibility:visible; transform:translateY(0) scale(1);
}
.main-navigation .sub-menu a {
  color:var(--ki-text-primary) !important;
  padding:0.65rem 1rem;
  font-size:0.78rem; border-radius:0;
}
.main-navigation .sub-menu a:hover { color:var(--ki-gold-dark) !important; background:var(--ki-cream); }
.main-navigation .sub-menu a::after { display:none; }
.main-navigation .sub-menu li:first-child a { border-radius:var(--radius-md) var(--radius-md) 0 0; }
.main-navigation .sub-menu li:last-child  a { border-radius:0 0 var(--radius-md) var(--radius-md); }

/* Header right */
.header-cta { display:flex; align-items:center; gap:0.65rem; }
.header-phone {
  font-size:0.78rem; font-weight:700;
  color:rgba(255,255,255,0.9);
  white-space:nowrap; transition:color var(--transition-base);
  display:flex; align-items:center; gap:0.3rem;
}
#masthead.scrolled .header-phone { color:var(--ki-gold-dark); }
.header-phone:hover { color:var(--ki-gold-light); }

/* Mobile toggle */
.menu-toggle {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:0.5rem; background:none; border:none;
  min-height:44px; min-width:44px;
  align-items:center; justify-content:center;
}
.menu-toggle span {
  display:block; width:22px; height:2px;
  background:var(--ki-warm-white); border-radius:2px;
  transition:all var(--transition-base);
}
#masthead.scrolled .menu-toggle span { background:var(--ki-text-primary); }
.menu-toggle.active span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.menu-toggle.active span:nth-child(2) { opacity:0; transform:scaleX(0); }
.menu-toggle.active span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile nav panel */
@media (max-width:1024px) {
  .menu-toggle { display:flex; }
  .main-navigation {
    position:fixed; top:0; right:-100%;
    width:min(320px, 90vw); height:100vh;
    background:var(--ki-cream);
    flex-direction:column; justify-content:flex-start;
    padding:5rem var(--space-lg) var(--space-lg);
    transition:right var(--transition-slow);
    box-shadow:-10px 0 50px rgba(180,140,90,0.15);
    z-index:var(--z-overlay); overflow-y:auto;
  }
  .main-navigation.is-open { right:0; }
  .main-navigation ul { flex-direction:column; align-items:flex-start; width:100%; gap:0; }
  .main-navigation a {
    color:var(--ki-text-primary) !important;
    font-size:0.95rem; padding:0.8rem 0;
    border-bottom:1px solid var(--ki-border-light);
    border-radius:0; width:100%; letter-spacing:0.06em;
  }
  .main-navigation a::after { display:none; }
  .main-navigation .sub-menu {
    position:static; opacity:1; visibility:visible;
    transform:none; box-shadow:none; border:none;
    background:transparent; padding-left:1rem;
  }
  .header-phone { display:none; }
}

.mobile-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(100,70,40,0.35);
  z-index:calc(var(--z-overlay) - 1);
  backdrop-filter:blur(2px);
}
.mobile-overlay.is-active { display:block; animation:fadeIn 0.25s ease; }

/* ============================================================
   HERO — MOTION / PARALLAX
   ============================================================ */
.hero-section {
  position:relative; height:100vh; min-height:640px;
  overflow:hidden; display:flex; align-items:center;
}
.hero-video-bg { position:absolute; inset:0; z-index:0; }
.hero-video-bg video {
  width:100%; height:100%; object-fit:cover;
  animation:heroZoom 24s ease-in-out infinite alternate;
}
.hero-bg-image {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  animation:heroZoom 24s ease-in-out infinite alternate;
  will-change:transform;
}
/* Subtle warm overlay — translucent warm gold, not dark */
.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(
    135deg,
    rgba(180,120,60,0.45) 0%,
    rgba(201,169,110,0.28) 50%,
    rgba(232,213,176,0.18) 100%
  );
}
.hero-content {
  position:relative; z-index:2;
  max-width:1440px; margin:0 auto;
  padding:0 var(--space-md); padding-top:80px;
  width:100%;
}
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:0.75rem;
  font-size:0.7rem; font-weight:700; letter-spacing:0.3em;
  text-transform:uppercase; color:rgba(255,255,255,0.95);
  margin-bottom:var(--space-md);
  animation:fadeUp 0.8s ease 0.3s both;
}
.hero-eyebrow::before, .hero-eyebrow::after {
  content:''; display:block;
  width:28px; height:1px; background:rgba(255,255,255,0.7);
}
.hero-title {
  font-family:var(--font-heading);
  font-size:clamp(2.25rem, 6.5vw, 5.2rem);
  font-weight:700; color:var(--ki-warm-white);
  line-height:1.08; letter-spacing:0.02em;
  margin-bottom:var(--space-md);
  animation:fadeUp 0.9s ease 0.5s both;
  text-shadow:0 2px 20px rgba(100,60,20,0.25);
}
.hero-title span { color:var(--ki-gold-light); display:block; }
.hero-subtitle {
  font-size:clamp(0.95rem, 1.8vw, 1.2rem);
  color:rgba(255,255,255,0.92); max-width:560px;
  margin-bottom:var(--space-lg); font-weight:300;
  letter-spacing:0.02em; line-height:1.7;
  animation:fadeUp 0.8s ease 0.7s both;
}
.hero-cta-group {
  display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:2.5rem;
  animation:fadeUp 0.8s ease 0.9s both;
}
.hero-stats {
  display:inline-flex; flex-wrap:wrap; gap:2rem;
  padding:1.1rem 1.75rem;
  background:rgba(255,251,245,0.18);
  backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(232,213,176,0.35);
  border-radius:var(--radius-lg);
  animation:fadeUp 0.8s ease 1.1s both;
}
.hero-stat { text-align:center; }
.hero-stat-number {
  font-family:var(--font-heading); font-size:1.85rem;
  font-weight:700; color:rgba(255,255,255,0.98); line-height:1;
}
.hero-stat-label {
  font-size:0.65rem; letter-spacing:0.14em;
  text-transform:uppercase; color:rgba(255,255,255,0.78); margin-top:0.2rem;
}
.hero-scroll {
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  z-index:2; display:flex; flex-direction:column; align-items:center; gap:0.5rem;
  cursor:pointer; animation:fadeUp 0.8s ease 1.4s both;
}
.hero-scroll span { font-size:0.62rem; letter-spacing:0.22em; text-transform:uppercase; color:rgba(255,255,255,0.65); }
.scroll-mouse {
  width:24px; height:38px; border:2px solid rgba(255,255,255,0.5);
  border-radius:12px; display:flex; justify-content:center; padding-top:5px;
}
.scroll-mouse::after {
  content:''; width:4px; height:7px; background:var(--ki-gold-light);
  border-radius:2px; animation:scrollBounce 1.6s ease infinite;
}

/* ============================================================
   TRUST BAR
   ============================================================ */
.trust-section {
  padding:1.5rem 0;
  background:var(--ki-warm-white);
  border-top:1px solid var(--ki-border-light);
  border-bottom:1px solid var(--ki-border-light);
}
.trust-logos {
  display:flex; flex-wrap:wrap; align-items:center;
  justify-content:center; gap:1.5rem;
}
.trust-badge {
  display:flex; align-items:center; gap:0.75rem;
  padding:0.65rem 1.1rem;
  background:var(--ki-cream);
  border:1px solid var(--ki-border-light);
  border-radius:var(--radius-full);
  transition:all var(--transition-base);
  animation:scaleIn 0.5s ease both;
}
.trust-badge:hover {
  border-color:var(--ki-gold-light);
  box-shadow:0 4px 18px var(--ki-shadow-gold);
  transform:translateY(-2px);
}
.trust-badge svg { width:24px; height:24px; color:var(--ki-gold); flex-shrink:0; }
.trust-badge-text strong { display:block; font-size:0.82rem; color:var(--ki-text-primary); }
.trust-badge-text span   { font-size:0.7rem; color:var(--ki-text-muted); }

/* ============================================================
   INTRO / TAGLINE
   ============================================================ */
.intro-section {
  padding:var(--space-3xl) 0; background:var(--ki-warm-white);
  position:relative; overflow:hidden;
}
.intro-section::before {
  content:'KAVANA';
  position:absolute; font-family:var(--font-heading);
  font-size:22vw; color:rgba(201,169,110,0.04);
  top:50%; left:50%; transform:translate(-50%,-50%);
  white-space:nowrap; pointer-events:none; letter-spacing:0.2em;
}
.intro-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:var(--space-2xl); align-items:center;
}
.intro-text .eyebrow {
  font-size:0.72rem; letter-spacing:0.28em; text-transform:uppercase;
  color:var(--ki-gold-dark); font-weight:700; margin-bottom:0.75rem;
  display:block;
}
.intro-text h2 { font-size:clamp(1.65rem, 3vw, 2.6rem); margin-bottom:var(--space-md); }
.intro-text h2 em { font-style:italic; color:var(--ki-gold-dark); }
.intro-text p { font-size:1rem; color:var(--ki-text-secondary); line-height:1.8; }
.intro-highlights { display:grid; grid-template-columns:1fr 1fr; gap:0.875rem; margin-top:1.75rem; }
.intro-highlight-item {
  display:flex; align-items:flex-start; gap:0.75rem;
  padding:0.875rem; background:var(--ki-cream);
  border-radius:var(--radius-md); border:1px solid var(--ki-border-light);
  transition:all var(--transition-base);
}
.intro-highlight-item:hover {
  border-color:var(--ki-gold-light);
  box-shadow:0 4px 16px var(--ki-shadow-gold);
  transform:translateY(-2px);
}
.intro-highlight-item .icon {
  width:36px; height:36px; flex-shrink:0;
  background:linear-gradient(135deg, var(--ki-gold-light), var(--ki-gold));
  border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center;
}
.intro-highlight-item .icon svg { width:18px; height:18px; color:var(--ki-warm-white); }
.intro-highlight-item strong { font-size:0.83rem; color:var(--ki-text-primary); display:block; }
.intro-highlight-item span   { font-size:0.75rem; color:var(--ki-text-muted); }
.intro-image-side { position:relative; }
.intro-image-side img {
  width:100%; height:490px; object-fit:cover;
  border-radius:var(--radius-xl);
  box-shadow:24px 24px 60px var(--ki-shadow);
  transition:transform var(--transition-slow);
}
.intro-image-side:hover img { transform:scale(1.02); }
.intro-badge {
  position:absolute; bottom:-22px; left:-22px;
  background:var(--ki-warm-white);
  border:2px solid var(--ki-gold-light);
  border-radius:var(--radius-lg); padding:1rem 1.25rem;
  box-shadow:0 10px 40px var(--ki-shadow);
  text-align:center;
  animation:float 4s ease-in-out infinite;
}
.intro-badge .num {
  font-family:var(--font-heading); font-size:2.25rem;
  font-weight:700; color:var(--ki-gold-dark); line-height:1;
}
.intro-badge .label { font-size:0.68rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--ki-text-muted); }

@media (max-width:768px) {
  .intro-grid { grid-template-columns:1fr; }
  .intro-image-side img { height:280px; }
  .intro-badge { left:10px; bottom:-15px; }
}

/* ============================================================
   COMPARISON TABLE — LIGHT COLORS ONLY
   ============================================================ */
.why-kavana { padding:var(--space-3xl) 0; background:var(--ki-linen); }
.comparison-table-wrap {
  overflow-x:auto; border-radius:var(--radius-xl);
  box-shadow:0 10px 50px var(--ki-shadow); margin-top:var(--space-xl);
  border:1px solid var(--ki-border-light);
}
.comparison-table {
  width:100%; border-collapse:collapse; font-size:0.87rem;
  background:var(--ki-warm-white); border-radius:var(--radius-xl); overflow:hidden;
}
.comparison-table th {
  padding:1.1rem 0.875rem; text-align:center;
  font-family:var(--font-heading); font-size:0.82rem; letter-spacing:0.04em;
}
.comparison-table th:first-child { text-align:left; background:var(--ki-cream-mid); color:var(--ki-text-primary); }
.comparison-table th.kavana-col {
  background:linear-gradient(135deg, var(--ki-gold-pale), var(--ki-gold-light));
  color:var(--ki-gold-dark);
}
.comparison-table th.other-col { background:var(--ki-cream-mid); color:var(--ki-text-secondary); }
.comparison-table td {
  padding:0.9rem 0.875rem; text-align:center;
  border-bottom:1px solid var(--ki-border-light);
  color:var(--ki-text-secondary); vertical-align:middle; font-size:0.84rem;
}
.comparison-table td:first-child {
  text-align:left; font-weight:600;
  color:var(--ki-text-primary); background:rgba(253,248,240,0.6);
  padding-left:1.25rem;
}
.comparison-table td.kavana-val {
  background:rgba(201,169,110,0.08);
  color:var(--ki-gold-dark); font-weight:700;
}
.comparison-table tr:hover td { background:rgba(201,169,110,0.04); }
.comparison-table tr:last-child td { border-bottom:none; }

/* ============================================================
   SERVICES / WHAT WE DO
   ============================================================ */
.services-section { padding:var(--space-3xl) 0; background:var(--ki-warm-white); }
.services-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(270px,1fr)); gap:var(--space-md);
}
.service-card {
  position:relative; overflow:hidden; border-radius:var(--radius-xl);
  cursor:pointer; box-shadow:0 4px 22px var(--ki-shadow-soft);
  transition:transform var(--transition-base), box-shadow var(--transition-base);
  border:1px solid var(--ki-border-light);
}
.service-card:hover {
  transform:translateY(-7px);
  box-shadow:0 18px 55px rgba(180,140,90,0.18);
}
.service-card-img { width:100%; height:275px; object-fit:cover; transition:transform var(--transition-slow); display:block; }
.service-card:hover .service-card-img { transform:scale(1.07); }
/* Warm gradient overlay — not dark */
.service-card-overlay {
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(250,240,220,0) 25%, rgba(180,120,60,0.75) 100%);
}
.service-card-content { position:absolute; bottom:0; left:0; right:0; padding:var(--space-md); }
.service-card-icon {
  width:46px; height:46px;
  background:rgba(255,248,235,0.25); backdrop-filter:blur(8px);
  border:1px solid rgba(232,213,176,0.5); border-radius:var(--radius-md);
  display:flex; align-items:center; justify-content:center; margin-bottom:0.65rem;
}
.service-card-icon svg { width:22px; height:22px; color:var(--ki-warm-white); }
.service-card h3 { font-size:1.05rem; color:var(--ki-warm-white); margin-bottom:0.3rem; }
.service-card p  { font-size:0.78rem; color:rgba(255,248,235,0.88); margin:0; line-height:1.5; }

/* Placeholder card (no image) */
.service-card-placeholder {
  width:100%; height:275px; display:flex; align-items:center; justify-content:center;
}

/* ============================================================
   DESIGN PORTFOLIO
   ============================================================ */
.design-section { padding:var(--space-3xl) 0; background:var(--ki-cream); }
.design-tabs {
  display:flex; flex-wrap:wrap; gap:0.5rem; justify-content:center;
  margin-bottom:var(--space-xl);
}
.design-tab {
  padding:0.55rem 1.35rem; font-size:0.78rem; font-weight:700;
  letter-spacing:0.08em; text-transform:uppercase;
  background:var(--ki-warm-white); border:1.5px solid var(--ki-border);
  border-radius:var(--radius-full); cursor:pointer; color:var(--ki-text-secondary);
  transition:all var(--transition-base);
}
.design-tab:hover { border-color:var(--ki-gold); color:var(--ki-gold-dark); }
.design-tab.active {
  background:linear-gradient(135deg, var(--ki-gold), var(--ki-gold-dark));
  color:var(--ki-warm-white); border-color:var(--ki-gold);
}
.design-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:0.875rem;
}
.design-item {
  position:relative; overflow:hidden;
  border-radius:var(--radius-lg); cursor:pointer;
  box-shadow:0 4px 18px var(--ki-shadow-soft);
  transition:transform var(--transition-base), box-shadow var(--transition-base);
}
.design-item:first-child { grid-column:span 2; }
.design-item:hover { transform:translateY(-4px); box-shadow:0 12px 40px rgba(180,140,90,0.18); }
.design-item img { width:100%; height:300px; object-fit:cover; transition:transform var(--transition-slow); display:block; }
.design-item:first-child img { height:400px; }
.design-item:hover img { transform:scale(1.06); }
.design-item-overlay {
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 45%, rgba(180,120,60,0.75) 100%);
  opacity:0; transition:opacity var(--transition-base);
  display:flex; align-items:flex-end; padding:var(--space-md);
}
.design-item:hover .design-item-overlay { opacity:1; }
.design-item-info h4   { color:var(--ki-warm-white); font-size:0.95rem; margin-bottom:0.2rem; }
.design-item-info span { color:var(--ki-gold-light); font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; }

@media (max-width:768px) {
  .design-grid { grid-template-columns:1fr 1fr; }
  .design-item:first-child { grid-column:span 2; }
}
@media (max-width:480px) {
  .design-grid { grid-template-columns:1fr; }
  .design-item:first-child { grid-column:span 1; }
  .design-item img, .design-item:first-child img { height:220px; }
}

/* ============================================================
   HOW IT WORKS / PROCESS
   ============================================================ */
.process-section { padding:var(--space-3xl) 0; background:var(--ki-cream-mid); }
.process-steps {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:2rem; position:relative; margin-top:var(--space-xl);
}
.process-steps::before {
  content:''; position:absolute;
  top:34px; left:12%; right:12%; height:2px;
  background:linear-gradient(90deg, var(--ki-gold-light), var(--ki-gold), var(--ki-gold-light));
}
.process-step { text-align:center; padding:0 0.75rem; position:relative; z-index:1; }
.step-number {
  width:68px; height:68px;
  background:linear-gradient(135deg, var(--ki-gold-light), var(--ki-gold));
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto var(--space-sm);
  font-family:var(--font-heading); font-size:1.3rem; font-weight:700;
  color:var(--ki-warm-white);
  box-shadow:0 8px 24px var(--ki-shadow-gold);
  position:relative;
  transition:transform var(--transition-base);
}
.step-number::after {
  content:''; position:absolute; inset:-4px;
  border:2px solid var(--ki-gold-light); border-radius:50%; opacity:0.55;
}
.process-step:hover .step-number { transform:scale(1.1); animation:borderGlow 1.5s ease infinite; }
.process-step h4 { font-size:0.92rem; margin-bottom:0.5rem; color:var(--ki-text-primary); }
.process-step p  { font-size:0.78rem; color:var(--ki-text-muted); line-height:1.55; margin:0; max-width:170px; margin:0 auto; }

@media (max-width:768px) { .process-steps::before { display:none; } }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials-section { padding:var(--space-3xl) 0; background:var(--ki-cream); overflow:hidden; }
.testimonials-track { display:flex; gap:var(--space-md); transition:transform var(--transition-slow); }
.testimonial-card {
  min-width:370px; flex-shrink:0;
  background:var(--ki-warm-white);
  border:1px solid var(--ki-border-light);
  border-radius:var(--radius-xl); padding:var(--space-lg);
  box-shadow:0 8px 36px var(--ki-shadow-soft);
  transition:transform var(--transition-base), box-shadow var(--transition-base);
}
.testimonial-card:hover { transform:translateY(-4px); box-shadow:0 16px 50px rgba(180,140,90,0.14); }
.testimonial-stars { color:var(--ki-gold); font-size:1rem; margin-bottom:0.75rem; letter-spacing:0.1em; }
.testimonial-text {
  font-family:var(--font-accent); font-size:1.02rem; font-style:italic;
  color:var(--ki-text-secondary); line-height:1.75; margin-bottom:var(--space-md);
}
.testimonial-author { display:flex; align-items:center; gap:0.75rem; }
.testimonial-avatar-placeholder {
  width:48px; height:48px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg, var(--ki-gold-light), var(--ki-gold));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-heading); font-size:1rem; font-weight:700; color:var(--ki-warm-white);
}
.testimonial-name    { font-weight:700; color:var(--ki-text-primary); font-size:0.88rem; }
.testimonial-info    { font-size:0.73rem; color:var(--ki-text-muted); }
.testimonial-project { font-size:0.7rem; color:var(--ki-gold-dark); font-weight:600; margin-top:0.15rem; }

.carousel-nav { display:flex; justify-content:center; align-items:center; gap:var(--space-md); margin-top:var(--space-lg); }
.carousel-btn {
  width:44px; height:44px; background:var(--ki-warm-white);
  border:1.5px solid var(--ki-border); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all var(--transition-base);
}
.carousel-btn:hover { background:var(--ki-gold); border-color:var(--ki-gold); }
.carousel-btn:hover svg { color:var(--ki-warm-white); }
.carousel-btn svg { width:18px; height:18px; color:var(--ki-text-secondary); transition:color var(--transition-base); }
.carousel-dots { display:flex; gap:0.5rem; }
.carousel-dot {
  width:8px; height:8px; background:var(--ki-border);
  border-radius:50%; cursor:pointer; border:none;
  transition:all var(--transition-base);
}
.carousel-dot.active { background:var(--ki-gold); width:24px; border-radius:4px; }

@media (max-width:640px) { .testimonial-card { min-width:300px; } }

/* ============================================================
   FAQ — ACCORDION (full light)
   ============================================================ */
.faq-section { padding:var(--space-3xl) 0; background:var(--ki-warm-white); }
.faq-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:var(--space-sm); margin-top:var(--space-xl);
}
.faq-item {
  background:var(--ki-cream);
  border:1.5px solid var(--ki-border-light);
  border-radius:var(--radius-lg); overflow:hidden;
  transition:border-color var(--transition-base), box-shadow var(--transition-base);
}
.faq-item:hover { border-color:var(--ki-gold-light); }
.faq-item.active {
  border-color:var(--ki-gold);
  box-shadow:0 6px 24px var(--ki-shadow-gold);
}
.faq-question {
  display:flex; align-items:center; justify-content:space-between;
  padding:var(--space-md); cursor:pointer;
  font-weight:600; color:var(--ki-text-primary); font-size:0.92rem;
  gap:1rem; min-height:56px; user-select:none;
  transition:background var(--transition-base);
}
.faq-question:hover { background:var(--ki-cream-mid); }
.faq-item.active .faq-question { background:var(--ki-gold-pale); }
.faq-icon {
  width:28px; height:28px; flex-shrink:0;
  background:var(--ki-gold-light); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  transition:all var(--transition-base);
}
.faq-icon svg { width:14px; height:14px; color:var(--ki-warm-white); transition:transform var(--transition-base); }
.faq-item.active .faq-icon { background:var(--ki-gold-dark); }
.faq-item.active .faq-icon svg { transform:rotate(45deg); }
.faq-answer {
  max-height:0; overflow:hidden;
  transition:max-height 0.4s cubic-bezier(0.4,0,0.2,1), padding var(--transition-base);
  padding:0 var(--space-md);
}
.faq-item.active .faq-answer { max-height:400px; padding:0 var(--space-md) var(--space-md); }
.faq-answer p { font-size:0.86rem; color:var(--ki-text-secondary); margin:0; line-height:1.72; }

@media (max-width:768px) { .faq-grid { grid-template-columns:1fr; } }

/* ============================================================
   CTA / ADVERTISEMENT BANNER — LIGHT GOLD
   ============================================================ */
.cta-banner {
  padding:var(--space-3xl) 0;
  background:linear-gradient(135deg, var(--ki-gold-pale) 0%, var(--ki-gold-light) 50%, var(--ki-gold) 100%);
  position:relative; overflow:hidden; text-align:center;
}
.cta-banner::before {
  content:'';
  position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.08'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E");
  animation:ribbonPulse 4s ease infinite;
}
.cta-banner-content { position:relative; z-index:1; }
.cta-banner h2 {
  font-size:clamp(1.85rem, 4.5vw, 3.25rem);
  color:var(--ki-warm-white); margin-bottom:0.75rem;
  font-family:var(--font-heading);
  text-shadow:0 2px 16px rgba(140,90,30,0.2);
}
.cta-banner p {
  font-size:1.1rem; color:rgba(255,255,255,0.95);
  margin:0 auto var(--space-lg); max-width:580px;
}
.cta-price-tag {
  display:inline-flex; align-items:center; gap:0.5rem;
  background:rgba(255,255,255,0.22); border:1px solid rgba(255,255,255,0.4);
  border-radius:var(--radius-full); padding:0.35rem 1rem;
  margin-bottom:0.75rem;
  font-size:0.75rem; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--ki-warm-white); animation:ribbonPulse 3s ease infinite;
}

/* ============================================================
   FACTORY VISIT
   ============================================================ */
.factory-section { padding:var(--space-3xl) 0; background:var(--ki-linen); }
.factory-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-2xl); align-items:center; }
.factory-features { list-style:none; }
.factory-features li {
  display:flex; align-items:center; gap:1rem;
  padding:0.875rem 0;
  border-bottom:1px solid var(--ki-border-light);
  font-size:0.92rem; color:var(--ki-text-secondary);
  transition:all var(--transition-base);
}
.factory-features li:last-child { border-bottom:none; }
.factory-features li:hover { color:var(--ki-text-primary); transform:translateX(4px); }
.feat-icon {
  width:36px; height:36px; flex-shrink:0;
  background:linear-gradient(135deg, var(--ki-gold-light), var(--ki-gold));
  border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center;
}
.feat-icon svg { width:18px; height:18px; color:var(--ki-warm-white); }

@media (max-width:768px) { .factory-grid { grid-template-columns:1fr; } }

/* ============================================================
   FOOTER — FULLY LIGHT CREAM (no dark background)
   ============================================================ */
#colophon {
  background:var(--ki-cream-mid);
  color:var(--ki-text-secondary);
  padding:var(--space-3xl) 0 0;
  border-top:2px solid var(--ki-border);
}
.footer-top {
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:var(--space-xl);
  padding-bottom:var(--space-2xl);
  border-bottom:1px solid var(--ki-border-light);
}
.footer-brand .site-description {
  font-size:0.875rem; line-height:1.75;
  color:var(--ki-text-secondary); margin:var(--space-sm) 0 var(--space-md);
}
/* Logo in footer — same fixed size */
.footer-brand img,
.footer-brand .custom-logo img {
  height: var(--logo-height) !important;
  width:  auto !important;
  max-width:180px !important;
  object-fit:contain !important;
}
.footer-brand-name {
  font-family:var(--font-heading); font-size:1.4rem; font-weight:700;
  color:var(--ki-gold-dark); letter-spacing:0.05em;
}
.footer-contact-item {
  display:flex; align-items:flex-start; gap:0.75rem; margin-bottom:0.75rem;
}
.footer-contact-item svg { width:16px; height:16px; color:var(--ki-gold); flex-shrink:0; margin-top:2px; }
.footer-contact-item a,
.footer-contact-item span { font-size:0.82rem; color:var(--ki-text-secondary); }
.footer-contact-item a:hover { color:var(--ki-gold-dark); }
.footer-col h4 {
  font-family:var(--font-heading); font-size:0.8rem; letter-spacing:0.15em;
  text-transform:uppercase; color:var(--ki-gold-dark);
  margin-bottom:var(--space-md); padding-bottom:0.5rem;
  border-bottom:2px solid var(--ki-gold-light);
}
.footer-links { list-style:none; }
.footer-links li { margin-bottom:0.55rem; }
.footer-links a {
  font-size:0.82rem; color:var(--ki-text-secondary);
  display:inline-flex; align-items:center; gap:0.4rem;
  transition:all var(--transition-base);
}
.footer-links a:hover { color:var(--ki-gold-dark); transform:translateX(3px); }
.footer-links a::before {
  content:''; width:4px; height:4px;
  background:var(--ki-gold-light); border-radius:50%; flex-shrink:0;
}
.social-links { display:flex; gap:0.65rem; margin-top:var(--space-md); flex-wrap:wrap; }
.social-link {
  width:38px; height:38px; border-radius:50%;
  border:1.5px solid var(--ki-border);
  background:var(--ki-warm-white);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all var(--transition-base);
  color:var(--ki-text-muted);
}
.social-link:hover {
  background:var(--ki-gold); border-color:var(--ki-gold);
  color:var(--ki-warm-white); transform:translateY(-3px);
  box-shadow:0 6px 18px var(--ki-shadow-gold);
}
.social-link svg { width:16px; height:16px; }
.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
  padding:var(--space-md) 0;
  font-size:0.77rem; color:var(--ki-text-muted);
  flex-wrap:wrap; gap:0.5rem;
  border-top:1px solid var(--ki-border-light);
}
.footer-bottom a { color:var(--ki-gold-dark); }
.footer-bottom a:hover { color:var(--ki-gold); }

/* Footer address card */
.footer-address-card {
  margin-top:1.25rem; padding:1rem;
  background:var(--ki-warm-white); border:1px solid var(--ki-border-light);
  border-radius:var(--radius-md);
}
.footer-address-card p { font-size:0.8rem; color:var(--ki-text-secondary); margin:0; line-height:1.6; }
.footer-address-card a { font-size:0.75rem; color:var(--ki-gold-dark); text-decoration:underline; display:inline-block; margin-top:0.4rem; }

@media (max-width:1024px) { .footer-top { grid-template-columns:1fr 1fr; } }
@media (max-width:640px)  { .footer-top { grid-template-columns:1fr; } .footer-bottom { justify-content:center; text-align:center; } }

/* ============================================================
   SCROLL REVEAL ANIMATIONS
   ============================================================ */
.reveal {
  opacity:0; transform:translateY(28px);
  transition:opacity 0.75s ease, transform 0.75s ease;
}
.reveal.revealed { opacity:1; transform:translateY(0); }
.reveal-left  { opacity:0; transform:translateX(-28px); transition:opacity 0.75s ease, transform 0.75s ease; }
.reveal-left.revealed { opacity:1; transform:translateX(0); }
.reveal-right { opacity:0; transform:translateX(28px);  transition:opacity 0.75s ease, transform 0.75s ease; }
.reveal-right.revealed { opacity:1; transform:translateX(0); }
.reveal-delay-1 { transition-delay:0.10s; }
.reveal-delay-2 { transition-delay:0.20s; }
.reveal-delay-3 { transition-delay:0.30s; }
.reveal-delay-4 { transition-delay:0.40s; }
.reveal-delay-5 { transition-delay:0.50s; }

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.page-hero {
  padding:calc(70px + var(--space-3xl)) 0 var(--space-2xl);
  background:linear-gradient(135deg, var(--ki-cream) 0%, var(--ki-cream-mid) 50%, var(--ki-cream-dark) 100%);
  text-align:center; position:relative; overflow:hidden;
}
.page-hero::before {
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%, rgba(201,169,110,0.15) 0%, transparent 70%);
}
.page-hero::after {
  content:''; position:absolute;
  bottom:-2px; left:0; right:0; height:50px;
  background:var(--ki-warm-white);
  clip-path:ellipse(55% 100% at 50% 100%);
}
.page-hero-eyebrow {
  color:var(--ki-gold-dark); font-size:0.72rem; letter-spacing:0.28em;
  text-transform:uppercase; font-weight:700; margin-bottom:0.75rem;
  display:block; animation:slideDown 0.6s ease both;
}
.page-hero h1 {
  font-size:clamp(2rem, 5vw, 3.75rem);
  color:var(--ki-text-primary); margin-bottom:var(--space-sm);
  animation:fadeUp 0.7s ease 0.1s both;
  position:relative;
}
.page-hero p {
  font-size:1.05rem; color:var(--ki-text-secondary);
  max-width:580px; margin:0 auto; line-height:1.75;
  animation:fadeUp 0.7s ease 0.2s both; position:relative;
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-section { padding:var(--space-3xl) 0; background:var(--ki-warm-white); }
.contact-grid {
  display:grid; grid-template-columns:1fr 1.6fr;
  gap:var(--space-2xl); align-items:start;
}
.contact-info-card {
  background:var(--ki-cream); border:1px solid var(--ki-border-light);
  border-radius:var(--radius-xl); padding:var(--space-xl);
  position:sticky; top:90px;
  animation:fadeLeft 0.6s ease both;
}
.contact-info-item {
  display:flex; align-items:flex-start; gap:1rem;
  margin-bottom:var(--space-md); padding-bottom:var(--space-md);
  border-bottom:1px solid var(--ki-border-light);
}
.contact-info-item:last-of-type { margin-bottom:0; border-bottom:none; }
.contact-info-icon {
  width:44px; height:44px; flex-shrink:0;
  background:linear-gradient(135deg, var(--ki-gold-light), var(--ki-gold));
  border-radius:var(--radius-md);
  display:flex; align-items:center; justify-content:center;
}
.contact-info-icon svg { width:20px; height:20px; color:var(--ki-warm-white); }
.contact-info-label { font-size:0.68rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--ki-text-muted); font-weight:700; }
.contact-info-value { font-size:0.92rem; color:var(--ki-text-primary); font-weight:600; }
.contact-info-value a { color:var(--ki-text-primary); }
.contact-info-value a:hover { color:var(--ki-gold-dark); }

/* Form */
.contact-form-wrap {
  background:var(--ki-warm-white); border:1.5px solid var(--ki-border-light);
  border-radius:var(--radius-xl); padding:var(--space-xl);
  box-shadow:0 10px 50px var(--ki-shadow-soft);
  animation:fadeRight 0.6s ease both;
}
.form-tabs { display:flex; gap:0.5rem; margin-bottom:var(--space-lg); flex-wrap:wrap; }
.form-tab {
  padding:0.5rem 1rem; font-size:0.76rem; font-weight:700;
  letter-spacing:0.08em; text-transform:uppercase;
  background:var(--ki-cream); border:1.5px solid var(--ki-border);
  border-radius:var(--radius-full); cursor:pointer; color:var(--ki-text-secondary);
  transition:all var(--transition-base);
}
.form-tab:hover { border-color:var(--ki-gold-light); color:var(--ki-gold-dark); }
.form-tab.active { background:var(--ki-gold); color:var(--ki-warm-white); border-color:var(--ki-gold); }
.form-panel { display:none; }
.form-panel.active { display:block; animation:fadeIn 0.3s ease both; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-sm); }
.form-group { margin-bottom:var(--space-sm); }
.form-group label {
  display:block; font-size:0.75rem; font-weight:700;
  letter-spacing:0.1em; text-transform:uppercase;
  color:var(--ki-text-secondary); margin-bottom:0.4rem;
}
.form-group input,
.form-group select,
.form-group textarea {
  width:100%; padding:0.75rem 1rem;
  background:var(--ki-cream); border:1.5px solid var(--ki-border);
  border-radius:var(--radius-md); font-family:var(--font-body);
  font-size:0.9rem; color:var(--ki-text-primary);
  transition:border-color var(--transition-base), box-shadow var(--transition-base);
  min-height:44px; outline:none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color:var(--ki-gold);
  box-shadow:0 0 0 3px rgba(201,169,110,0.15);
  background:var(--ki-warm-white);
}
.form-group textarea { min-height:100px; resize:vertical; }

@media (max-width:768px) {
  .contact-grid { grid-template-columns:1fr; }
  .contact-info-card { position:static; }
  .form-row { grid-template-columns:1fr; }
}

/* ============================================================
   DESIGN GALLERY PAGE — TABS
   ============================================================ */
.gallery-tabs-section { padding:var(--space-xl) 0 var(--space-3xl); background:var(--ki-warm-white); }
.gallery-tab-nav {
  display:flex; gap:0; flex-wrap:wrap;
  margin-bottom:var(--space-xl);
  border-bottom:2px solid var(--ki-border-light);
}
.gallery-tab-btn {
  padding:0.8rem 1.35rem; font-size:0.8rem; font-weight:700;
  letter-spacing:0.06em; text-transform:uppercase;
  background:none; border:none; cursor:pointer;
  color:var(--ki-text-muted);
  border-bottom:3px solid transparent; margin-bottom:-2px;
  transition:all var(--transition-base);
}
.gallery-tab-btn:hover { color:var(--ki-gold-dark); }
.gallery-tab-btn.active { color:var(--ki-gold-dark); border-bottom-color:var(--ki-gold); }
.gallery-panel { display:none; }
.gallery-panel.active { display:block; animation:fadeIn 0.4s ease both; }
.gallery-masonry { columns:3; column-gap:var(--space-sm); }
.gallery-masonry-item {
  break-inside:avoid; margin-bottom:var(--space-sm);
  border-radius:var(--radius-lg); overflow:hidden; cursor:pointer; position:relative;
  box-shadow:0 4px 18px var(--ki-shadow-soft);
  transition:transform var(--transition-base), box-shadow var(--transition-base);
}
.gallery-masonry-item:hover {
  transform:translateY(-4px);
  box-shadow:0 14px 40px rgba(180,140,90,0.18);
}
.gallery-masonry-item img { width:100%; height:auto; display:block; transition:transform var(--transition-slow); }
.gallery-masonry-item:hover img { transform:scale(1.04); }
.gallery-masonry-item-overlay {
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(160,100,40,0.72) 100%);
  opacity:0; transition:opacity var(--transition-base);
  display:flex; align-items:flex-end; padding:1rem;
}
.gallery-masonry-item:hover .gallery-masonry-item-overlay { opacity:1; }
.gallery-masonry-item-overlay span { color:var(--ki-warm-white); font-size:0.8rem; }

@media (max-width:768px) { .gallery-masonry { columns:2; } }
@media (max-width:480px) { .gallery-masonry { columns:1; } }

/* ============================================================
   PROJECTS GRID
   ============================================================ */
.projects-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(330px,1fr));
  gap:var(--space-lg); padding:var(--space-3xl) 0;
}
.project-card {
  background:var(--ki-warm-white); border:1px solid var(--ki-border-light);
  border-radius:var(--radius-xl); overflow:hidden;
  box-shadow:0 4px 22px var(--ki-shadow-soft);
  transition:transform var(--transition-base), box-shadow var(--transition-base);
  cursor:pointer;
}
.project-card:hover { transform:translateY(-7px); box-shadow:0 18px 55px rgba(180,140,90,0.18); }
.project-card-img { width:100%; height:230px; object-fit:cover; transition:transform var(--transition-slow); display:block; }
.project-card:hover .project-card-img { transform:scale(1.04); }
.project-card-body { padding:var(--space-md); }
.project-type { font-size:0.68rem; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--ki-gold-dark); margin-bottom:0.4rem; }
.project-card-body h3 { font-size:1.05rem; color:var(--ki-text-primary); margin-bottom:0.5rem; }
.project-card-body p  { font-size:0.82rem; color:var(--ki-text-muted); margin:0; line-height:1.6; }
.project-meta {
  display:flex; gap:var(--space-sm); margin-top:0.875rem;
  padding-top:0.875rem; border-top:1px solid var(--ki-border-light);
}
.project-meta-item { font-size:0.73rem; color:var(--ki-text-muted); }
.project-meta-item strong { color:var(--ki-text-secondary); display:block; font-size:0.8rem; }

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.values-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr));
  gap:var(--space-md); margin-top:var(--space-xl);
}
.value-card {
  text-align:center; padding:var(--space-lg);
  background:var(--ki-warm-white); border:1px solid var(--ki-border-light);
  border-radius:var(--radius-xl); transition:all var(--transition-base);
}
.value-card:hover {
  background:var(--ki-cream); border-color:var(--ki-gold-light);
  transform:translateY(-4px); box-shadow:0 12px 40px var(--ki-shadow-soft);
}
.value-icon {
  width:64px; height:64px;
  background:linear-gradient(135deg, var(--ki-gold-light), var(--ki-gold));
  border-radius:var(--radius-lg);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto var(--space-sm);
  transition:transform var(--transition-base);
}
.value-card:hover .value-icon { transform:scale(1.1) rotate(-5deg); }
.value-icon svg { width:30px; height:30px; color:var(--ki-warm-white); }
.value-card h3 { font-size:0.98rem; color:var(--ki-text-primary); margin-bottom:0.5rem; }
.value-card p  { font-size:0.8rem; color:var(--ki-text-muted); margin:0; }

.team-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(210px,1fr)); gap:var(--space-md); }
.team-card {
  text-align:center; background:var(--ki-cream);
  border-radius:var(--radius-xl); overflow:hidden;
  border:1px solid var(--ki-border-light);
  transition:transform var(--transition-base), box-shadow var(--transition-base);
}
.team-card:hover { transform:translateY(-5px); box-shadow:0 14px 42px rgba(180,140,90,0.16); }
.team-card img { width:100%; height:200px; object-fit:cover; object-position:top; }
.team-card-body { padding:var(--space-md); }
.team-card h4   { font-size:0.95rem; color:var(--ki-text-primary); margin-bottom:0.25rem; }
.team-card span { font-size:0.75rem; color:var(--ki-gold-dark); text-transform:uppercase; letter-spacing:0.1em; }

/* ============================================================
   LOGIN PAGE — LIGHT CARD
   ============================================================ */
.login-page-wrap {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, var(--ki-cream) 0%, var(--ki-cream-mid) 100%);
  padding:var(--space-md);
}
.login-card {
  width:100%; max-width:420px;
  background:var(--ki-warm-white); border:1px solid var(--ki-border-light);
  border-radius:var(--radius-xl); padding:var(--space-2xl);
  box-shadow:0 20px 60px rgba(180,140,90,0.15); text-align:center;
  animation:scaleIn 0.5s ease both;
}
.login-logo { margin-bottom:var(--space-lg); }
.login-logo img { height:var(--logo-height) !important; margin:0 auto; object-fit:contain !important; }
.login-card h2 { font-size:1.5rem; margin-bottom:0.5rem; color:var(--ki-text-primary); }
.login-card .sub { font-size:0.85rem; color:var(--ki-text-muted); margin-bottom:var(--space-lg); }
.login-card .btn { width:100%; justify-content:center; }
.login-note { font-size:0.75rem; color:var(--ki-text-muted); margin-top:var(--space-md); }
.login-note a { color:var(--ki-gold-dark); }

/* ============================================================
   MAP
   ============================================================ */
.map-section { padding:var(--space-3xl) 0; background:var(--ki-cream); }
.map-wrap {
  border-radius:var(--radius-xl); overflow:hidden;
  box-shadow:0 10px 50px var(--ki-shadow); height:400px;
  border:1px solid var(--ki-border-light);
}
.map-wrap iframe { width:100%; height:100%; border:none; }

/* ============================================================
   LIGHTBOX — LIGHT FROSTED
   ============================================================ */
.ki-lightbox {
  position:fixed; inset:0;
  background:rgba(244,236,220,0.88);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  z-index:var(--z-modal);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:all var(--transition-base);
}
.ki-lightbox.active { opacity:1; visibility:visible; }
.ki-lightbox img {
  max-width:90vw; max-height:85vh; object-fit:contain;
  border-radius:var(--radius-lg);
  box-shadow:0 20px 60px rgba(180,140,90,0.25);
  animation:scaleIn 0.3s ease both;
}
.ki-lightbox-close {
  position:absolute; top:1.5rem; right:1.5rem;
  width:44px; height:44px;
  background:var(--ki-warm-white); border:1.5px solid var(--ki-border);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--ki-text-primary);
  font-size:1.4rem; line-height:1;
  transition:all var(--transition-base); box-shadow:0 4px 16px var(--ki-shadow);
}
.ki-lightbox-close:hover { background:var(--ki-gold); color:var(--ki-warm-white); border-color:var(--ki-gold); transform:scale(1.1); }

/* ============================================================
   WHATSAPP FLOAT BUTTON
   ============================================================ */
.whatsapp-float {
  position:fixed; bottom:2rem; right:2rem;
  z-index:var(--z-toast);
  display:flex; flex-direction:column; align-items:flex-end; gap:0.5rem;
}
.whatsapp-btn {
  width:56px; height:56px; background:#25D366;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 24px rgba(37,211,102,0.38);
  cursor:pointer; transition:transform var(--transition-base), box-shadow var(--transition-base);
  text-decoration:none; border:3px solid var(--ki-warm-white);
  animation:pulse 3s ease-in-out infinite;
}
.whatsapp-btn:hover { transform:scale(1.12); box-shadow:0 10px 35px rgba(37,211,102,0.5); animation:none; }
.whatsapp-btn svg { width:26px; height:26px; color:var(--ki-warm-white); }
.whatsapp-tooltip {
  background:var(--ki-warm-white); border:1px solid var(--ki-border-light);
  border-radius:var(--radius-md); padding:0.4rem 0.75rem;
  font-size:0.73rem; color:var(--ki-text-primary); white-space:nowrap;
  box-shadow:0 4px 16px var(--ki-shadow); display:none;
}
.whatsapp-float:hover .whatsapp-tooltip { display:block; animation:fadeIn 0.2s ease; }

/* ============================================================
   BACK-TO-TOP BUTTON
   ============================================================ */
#backToTop {
  position:fixed; bottom:5.5rem; right:2rem; z-index:40;
  width:44px; height:44px;
  background:linear-gradient(135deg, var(--ki-gold-light), var(--ki-gold));
  border:none; border-radius:50%; display:none;
  align-items:center; justify-content:center;
  cursor:pointer; box-shadow:0 4px 16px var(--ki-shadow-gold);
  transition:all var(--transition-base);
}
#backToTop:hover { transform:translateY(-3px); box-shadow:0 8px 24px var(--ki-shadow-gold); }

/* ============================================================
   ADMIN BAR NOTICE
   ============================================================ */
.ki-admin-bar-notice {
  background:var(--ki-gold-pale); border-bottom:1px solid var(--ki-gold-light);
  color:var(--ki-text-primary); text-align:center;
  padding:0.5rem; font-size:0.8rem;
}
.ki-admin-bar-notice a { color:var(--ki-gold-dark); text-decoration:underline; }

/* ============================================================
   WORDPRESS CORE COMPATIBILITY
   ============================================================ */
.screen-reader-text {
  clip:rect(1px,1px,1px,1px); position:absolute;
  height:1px; width:1px; overflow:hidden;
}
.screen-reader-text:focus {
  background:var(--ki-cream); clip:auto !important;
  display:block; font-size:0.875rem; font-weight:700;
  height:auto; left:0.5rem; padding:var(--space-sm) var(--space-md);
  top:0.5rem; width:auto; z-index:100000; color:var(--ki-text-primary);
  border:2px solid var(--ki-gold); border-radius:var(--radius-md);
}
.wp-caption, .gallery-caption { color:var(--ki-text-muted); font-size:0.8rem; text-align:center; }
.alignleft  { float:left; margin:0 var(--space-md) var(--space-md) 0; }
.alignright { float:right; margin:0 0 var(--space-md) var(--space-md); }
.aligncenter { display:block; margin:0 auto; }
.site-content { padding-top:70px; }

/* ============================================================
   ELEMENTOR OVERRIDES
   ============================================================ */
.elementor-section { margin:0 !important; }
.elementor-widget-wrap { padding:0 !important; }
