@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Manrope:wght@400;500;600;700;800&display=swap');

:root {
  --kl-text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --kl-text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --kl-text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --kl-text-lg: clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --kl-text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --kl-space-2: 0.5rem;
  --kl-space-3: 0.75rem;
  --kl-space-4: 1rem;
  --kl-space-6: 1.5rem;
  --kl-space-8: 2rem;
  --kl-space-10: 2.5rem;
  --kl-space-12: 3rem;
  --kl-space-16: 4rem;
  --kl-space-24: 6rem;
  --kl-bg: #121110;
  --kl-surface: #171615;
  --kl-surface-2: #1d1b19;
  --kl-surface-3: #22201d;
  --kl-border: rgba(244,239,230,.10);
  --kl-divider: rgba(244,239,230,.08);
  --kl-text: #ebe5d9;
  --kl-text-muted: #b0a89b;
  --kl-text-faint: #7f786d;
  --kl-primary: #5f9ea0;
  --kl-primary-hover: #84b7b8;
  --kl-accent: #d2a85d;
  --kl-shadow-sm: 0 1px 2px rgba(0,0,0,.25);
  --kl-shadow-md: 0 12px 30px rgba(0,0,0,.28);
  --kl-shadow-lg: 0 24px 60px rgba(0,0,0,.45);
  --kl-radius-md: .9rem;
  --kl-radius-lg: 1.4rem;
  --kl-radius-xl: 2rem;
  --kl-radius-full: 999px;
  --kl-content: 1160px;
  --kl-wide: 1280px;
  --kl-font-display: 'Cormorant Garamond', Georgia, serif;
  --kl-font-body: 'Manrope', Inter, sans-serif;
  --kl-transition: 240ms cubic-bezier(.16,1,.3,1);
}

body.home {
  background:
    radial-gradient(circle at top left, rgba(210,168,93,.16), transparent 28%),
    radial-gradient(circle at 85% 15%, rgba(95,158,160,.14), transparent 22%),
    linear-gradient(180deg, #0e0d0c, var(--kl-bg) 32%, var(--kl-surface) 100%);
  color: var(--kl-text);
}

.kl-homepage, .kl-homepage * { box-sizing: border-box; }
.kl-homepage { font-family: var(--kl-font-body); font-size: var(--kl-text-base); line-height: 1.6; }
.kl-homepage a { color: inherit; text-decoration: none; }
.kl-container, .kl-wide { width: min(calc(100% - 2rem), var(--kl-content)); margin: 0 auto; }
.kl-wide { width: min(calc(100% - 2rem), var(--kl-wide)); }
.kl-eyebrow { display: inline-flex; align-items: center; gap: .75rem; padding: .5rem .85rem; border: 1px solid var(--kl-border); border-radius: var(--kl-radius-full); font-size: var(--kl-text-xs); text-transform: uppercase; letter-spacing: .18em; color: var(--kl-text-muted); background: rgba(23,22,21,.75); backdrop-filter: blur(14px); }
.kl-eyebrow::before { content: ''; width: .45rem; height: .45rem; border-radius: 50%; background: var(--kl-accent); box-shadow: 0 0 0 6px rgba(210,168,93,.12); }
.kl-button { display: inline-flex; align-items: center; justify-content: center; gap: .6rem; min-height: 44px; padding: .85rem 1.2rem; border-radius: var(--kl-radius-full); border: 1px solid var(--kl-border); font-weight: 700; transition: transform var(--kl-transition), background var(--kl-transition), border-color var(--kl-transition); }
.kl-button:hover { transform: translateY(-1px); border-color: rgba(95,158,160,.45); }
.kl-button--primary { background: var(--kl-primary); color: white; border-color: transparent; box-shadow: var(--kl-shadow-md); }
.kl-button--primary:hover { background: var(--kl-primary-hover); }
.kl-button--ghost { background: transparent; }
.kl-hero { padding: clamp(4rem, 10vw, 8rem) 0 clamp(3rem, 8vw, 6rem); }
.kl-hero-grid, .kl-section-heading, .kl-about-shell, .kl-contact-banner__grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(2rem, 4vw, 4rem); align-items: end; }
.kl-hero-copy h1, .kl-section-heading h2, .kl-contact-banner h2 { font-family: var(--kl-font-display); letter-spacing: -.04em; line-height: .94; }
.kl-hero-copy h1 { margin: 1rem 0 1.5rem; font-size: clamp(3.4rem, 7vw, 6.8rem); max-width: 11ch; }
.kl-hero-copy p, .kl-section-heading p, .kl-practice-card p, .kl-about-story p, .kl-team-card p, .kl-contact-banner p { color: var(--kl-text-muted); }
.kl-hero-actions, .kl-contact-points { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2rem; }
.kl-hero-proof { display: flex; flex-wrap: wrap; gap: 1.5rem; margin-top: 2.2rem; color: var(--kl-text-muted); font-size: var(--kl-text-sm); }
.kl-hero-proof span strong, .kl-metric strong { display: block; color: var(--kl-text); }
.kl-hero-panel, .kl-about-panel, .kl-about-story, .kl-contact-banner, .kl-practice-card, .kl-team-card { border: 1px solid var(--kl-border); background: rgba(23,22,21,.86); }
.kl-hero-panel { position: relative; padding: 1.5rem; border-radius: var(--kl-radius-xl); box-shadow: var(--kl-shadow-lg); overflow: hidden; }
.kl-hero-card { min-height: 34rem; border-radius: calc(var(--kl-radius-xl) - .7rem); padding: 1.25rem; background: linear-gradient(180deg, rgba(11,10,9,.16), rgba(11,10,9,.58)), radial-gradient(circle at top, rgba(210,168,93,.28), transparent 34%), linear-gradient(135deg, #2a2622, #181614 62%, #222826); display: flex; flex-direction: column; justify-content: space-between; }
.kl-hero-card__top { display: flex; justify-content: space-between; gap: 1rem; color: #f5efe5; }
.kl-hero-card__badge, .kl-contact-pill { padding: .55rem .75rem; border-radius: var(--kl-radius-full); border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.06); }
.kl-hero-card__badge { font-size: .78rem; letter-spacing: .14em; text-transform: uppercase; }
.kl-hero-card__lines { width: 8rem; opacity: .65; }
.kl-hero-card__lines span { display: block; height: 1px; background: rgba(255,255,255,.18); margin-bottom: .6rem; }
.kl-hero-card__quote { padding: 1.1rem; max-width: 19rem; margin-left: auto; border-radius: 1.3rem; background: rgba(244,239,230,.08); border: 1px solid rgba(244,239,230,.12); }
.kl-hero-card__quote strong { display: block; margin-bottom: .45rem; font-size: .88rem; letter-spacing: .1em; text-transform: uppercase; color: #f3dfb6; }
.kl-section { padding: clamp(3.5rem, 8vw, 6rem) 0; }
.kl-section-heading { margin-bottom: 2rem; }
.kl-section-heading h2, .kl-contact-banner h2 { margin: .8rem 0 0; font-size: clamp(2.4rem, 4vw, 4.2rem); }
.kl-practice-grid, .kl-team-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 1rem; }
.kl-practice-card, .kl-team-card { grid-column: span 4; padding: 1.4rem; border-radius: var(--kl-radius-lg); box-shadow: var(--kl-shadow-sm); min-height: 18rem; display: flex; flex-direction: column; justify-content: space-between; transition: transform var(--kl-transition), border-color var(--kl-transition), box-shadow var(--kl-transition); }
.kl-practice-card:nth-child(1), .kl-practice-card:nth-child(6), .kl-team-card--lead { grid-column: span 6; }
.kl-practice-card:hover, .kl-team-card:hover { transform: translateY(-5px); border-color: rgba(95,158,160,.55); box-shadow: var(--kl-shadow-md); }
.kl-practice-card__index { font-size: .76rem; letter-spacing: .18em; text-transform: uppercase; color: var(--kl-accent); }
.kl-practice-card h3, .kl-team-card h3 { margin: .8rem 0; font-size: var(--kl-text-lg); }
.kl-about-panel, .kl-about-story, .kl-contact-banner { padding: clamp(1.5rem, 2vw, 2rem); border-radius: var(--kl-radius-xl); }
.kl-metrics { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.kl-metric { padding: 1.2rem; border-radius: 1.2rem; background: rgba(34,32,29,.85); border: 1px solid var(--kl-border); }
.kl-metric strong { font-size: clamp(1.8rem, 4vw, 2.8rem); font-family: var(--kl-font-display); }
.kl-metric span, .kl-quote, .kl-team-card ul { color: var(--kl-text-muted); }
.kl-quote { margin-top: .5rem; padding-top: 1rem; border-top: 1px solid var(--kl-divider); }
.kl-quote strong { display: block; color: var(--kl-text); margin-bottom: .45rem; }
.kl-avatar { width: 3.5rem; height: 3.5rem; border-radius: 1rem; display: grid; place-items: center; font-weight: 800; color: var(--kl-text); background: linear-gradient(135deg, rgba(210,168,93,.28), rgba(95,158,160,.18)); border: 1px solid var(--kl-border); margin-bottom: 1rem; }
.kl-team-card ul { list-style: none; padding: 0; margin: 1rem 0 0; display: grid; gap: .55rem; }
.kl-team-card li strong { color: var(--kl-text); }
.kl-contact-banner { box-shadow: var(--kl-shadow-lg); }
.kl-reveal { opacity: 0; transform: translateY(28px); transition: opacity 700ms ease, transform 700ms ease; }
.kl-reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 1100px) {
  .kl-hero-grid, .kl-section-heading, .kl-about-shell, .kl-contact-banner__grid { grid-template-columns: 1fr; }
  .kl-practice-card, .kl-practice-card:nth-child(1), .kl-practice-card:nth-child(6), .kl-team-card, .kl-team-card--lead { grid-column: span 6; }
}

@media (max-width: 760px) {
  .kl-hero-copy h1 { max-width: 100%; }
  .kl-practice-card, .kl-practice-card:nth-child(1), .kl-practice-card:nth-child(6), .kl-team-card, .kl-team-card--lead { grid-column: span 12; }
  .kl-metrics { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .kl-reveal { opacity: 1; transform: none; }
}