/* Klementewicz Development - main theme styles
   Design system: white, professional, restrained.
   Primary: #0a0a0a  Accent: #2563eb  Accent2: #ff7a00 (subtle)
*/

:root {
  --kd-bg:        #ffffff;
  --kd-bg-soft:   #f7f7f8;
  --kd-bg-soft2:  #f1f2f5;
  --kd-fg:        #0a0a0a;
  --kd-fg-2:      #2b2b2e;
  --kd-fg-3:      #595961;
  --kd-fg-4:      #8a8a93;
  --kd-line:      #e6e6ea;
  --kd-line-2:    #d6d6dc;
  --kd-accent:    #2563eb;
  --kd-accent-2:  #1d4ed8;
  --kd-amber:     #ff7a00;
  --kd-radius:    14px;
  --kd-radius-lg: 22px;
  --kd-shadow:    0 1px 2px rgba(10,10,10,.04), 0 8px 24px -8px rgba(10,10,10,.08);
  --kd-shadow-lg: 0 24px 60px -20px rgba(10,10,10,.18);
  --kd-container: 1180px;
  --kd-font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --kd-font-display: "Space Grotesk", var(--kd-font-sans);
  --kd-font-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body.kd-body {
  margin: 0;
  background: var(--kd-bg);
  color: var(--kd-fg);
  font-family: var(--kd-font-sans);
  font-size: 17px;
  line-height: 1.6;
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--kd-fg); text-decoration: none; transition: color .15s ease; }
a:hover { color: var(--kd-accent); }
p { margin: 0 0 1em; }
em { font-style: italic; color: var(--kd-fg-2); }
strong { font-weight: 700; }

.kd-sr {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.kd-skip {
  position: absolute; left: -9999px; top: 0; background: var(--kd-fg); color: #fff;
  padding: 10px 16px; z-index: 9999;
}
.kd-skip:focus { left: 16px; top: 16px; }

.kd-container {
  width: 100%;
  max-width: var(--kd-container);
  margin: 0 auto;
  padding: 0 24px;
}

/* ---------------- Buttons ---------------- */
.kd-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font: 600 15px/1 var(--kd-font-sans);
  letter-spacing: .01em;
  padding: 14px 22px;
  border-radius: 999px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .12s ease, background .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
  white-space: nowrap;
}
.kd-btn--primary {
  background: var(--kd-fg);
  color: #fff;
  box-shadow: 0 6px 20px -6px rgba(10,10,10,.35);
}
.kd-btn--primary:hover { background: var(--kd-accent); color: #fff; transform: translateY(-1px); }
.kd-btn--ghost {
  background: transparent;
  color: var(--kd-fg);
  border-color: var(--kd-line-2);
}
.kd-btn--ghost:hover { background: var(--kd-bg-soft); border-color: var(--kd-fg); }
.kd-btn--lg { padding: 18px 28px; font-size: 16px; }

.kd-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-weight: 600;
  color: var(--kd-accent);
  border-bottom: 1px solid transparent;
}
.kd-link:hover { color: var(--kd-accent-2); border-bottom-color: currentColor; }

/* ---------------- Header ---------------- */
.kd-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.72);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid transparent;
  transition: background .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.kd-header.is-scrolled {
  background: rgba(255,255,255,0.92);
  border-bottom-color: var(--kd-line);
  box-shadow: 0 4px 14px -10px rgba(10,10,10,.18);
}
.kd-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  min-height: 72px;
}
.kd-logo {
  display: inline-flex; align-items: center; gap: 12px;
  color: var(--kd-fg);
}
.kd-logo__mark { display: inline-flex; }
.kd-logo__text {
  display: inline-flex; flex-direction: column; line-height: 1;
  font-family: var(--kd-font-display);
}
.kd-logo__text strong { font-size: 17px; font-weight: 700; letter-spacing: -.01em; }
.kd-logo__text span { font-size: 12px; color: var(--kd-fg-3); letter-spacing: .12em; text-transform: uppercase; margin-top: 4px; }

.kd-nav { display: flex; align-items: center; gap: 22px; }
.kd-nav__list {
  list-style: none; padding: 0; margin: 0;
  display: flex; gap: 22px;
  font-size: 15px;
}
.kd-nav__actions { display: flex; align-items: center; gap: 14px; }
.kd-nav__list a { color: var(--kd-fg-2); font-weight: 500; }
.kd-nav__list a:hover { color: var(--kd-fg); }
.kd-nav__cta { padding: 10px 18px; font-size: 14px; }

.kd-lang-switch {
  display: inline-flex; align-items: center; gap: 4px;
  flex-wrap: wrap;
  padding: 4px;
  border: 1px solid var(--kd-line);
  border-radius: 999px;
  background: rgba(255,255,255,.8);
}
.kd-lang-switch__link {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 40px; height: 32px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 12px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--kd-fg-3);
}
.kd-lang-switch__link.is-active {
  background: var(--kd-fg);
  color: #fff;
}

.kd-burger {
  display: none;
  width: 40px; height: 40px;
  background: transparent; border: 1px solid var(--kd-line); border-radius: 10px;
  position: relative; cursor: pointer;
}
.kd-burger span:not(.kd-sr) {
  display: block; width: 18px; height: 2px; background: var(--kd-fg);
  position: absolute; left: 50%; transform: translateX(-50%);
  transition: transform .2s ease, opacity .2s ease, top .2s ease;
}
.kd-burger span:nth-child(1) { top: 13px; }
.kd-burger span:nth-child(2) { top: 19px; }
.kd-burger span:nth-child(3) { top: 25px; }
.kd-burger[aria-expanded="true"] span:nth-child(1) { top: 19px; transform: translateX(-50%) rotate(45deg); }
.kd-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.kd-burger[aria-expanded="true"] span:nth-child(3) { top: 19px; transform: translateX(-50%) rotate(-45deg); }

.kd-mobile {
  border-top: 1px solid var(--kd-line);
  background: #fff;
}
.kd-mobile ul { list-style: none; padding: 12px 0; margin: 0; }
.kd-mobile a {
  display: block; padding: 14px 24px;
  font-size: 16px; font-weight: 500;
  border-bottom: 1px solid var(--kd-line);
}
.kd-mobile__lang {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 16px 24px 20px;
}
.kd-mobile__lang a {
  border: 0;
  padding: 10px 14px;
  border-radius: 999px;
  background: var(--kd-bg-soft);
}

/* ---------------- Sections common ---------------- */
.kd-main { display: block; }
section { padding: 96px 0; position: relative; }
.kd-eyebrow {
  display: inline-block;
  font: 600 12px/1 var(--kd-font-sans);
  color: var(--kd-accent);
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.kd-h1 {
  font: 800 clamp(40px, 6vw, 76px)/1.04 var(--kd-font-display);
  letter-spacing: -.025em;
  margin: 0 0 24px;
  color: var(--kd-fg);
}
.kd-h1--sm { font-size: clamp(32px, 4vw, 52px); }
.kd-h2 {
  font: 700 clamp(28px, 3.4vw, 44px)/1.12 var(--kd-font-display);
  letter-spacing: -.02em;
  margin: 0 0 18px;
}
.kd-lead {
  font-size: clamp(17px, 1.4vw, 19px);
  color: var(--kd-fg-3);
  max-width: 62ch;
  line-height: 1.65;
}
.kd-underline {
  position: relative; display: inline-block; white-space: nowrap;
}
.kd-underline::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: .05em; height: .25em;
  background: linear-gradient(90deg, var(--kd-amber), #ffb066);
  border-radius: 6px; z-index: -1; opacity: .9;
}
.kd-section-head { max-width: 800px; margin-bottom: 56px; }

/* ---------------- Hero ---------------- */
.kd-hero { padding: clamp(80px, 12vw, 140px) 0 96px; overflow: hidden; }
.kd-hero__inner {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 56px;
  align-items: center;
}
.kd-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px; border-radius: 999px;
  background: var(--kd-bg-soft); border: 1px solid var(--kd-line);
  font-size: 13px; color: var(--kd-fg-3); font-weight: 500;
  margin-bottom: 28px;
}
.kd-pill__dot {
  width: 8px; height: 8px; border-radius: 999px; background: #16a34a;
  box-shadow: 0 0 0 4px rgba(22,163,74,.18);
  animation: kdPulse 2.4s infinite ease-in-out;
}
@keyframes kdPulse { 0%,100%{transform:scale(1);} 50%{transform:scale(1.2);} }

.kd-hero__actions { display: flex; gap: 12px; flex-wrap: wrap; margin: 28px 0 40px; }
.kd-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin: 0; padding: 24px 0; border-top: 1px solid var(--kd-line); }
.kd-stats div { padding-right: 12px; }
.kd-stats dt { font: 800 30px/1 var(--kd-font-display); letter-spacing: -.02em; }
.kd-stats dd { margin: 6px 0 0; font-size: 13px; color: var(--kd-fg-3); }

.kd-hero__visual { position: relative; min-height: 460px; }
.kd-orb {
  position: absolute; inset: -10% -20% 30% 10%;
  background: radial-gradient(closest-side, rgba(37,99,235,.22), rgba(37,99,235,0) 70%),
              radial-gradient(closest-side, rgba(255,122,0,.18), rgba(255,122,0,0) 70%);
  filter: blur(10px);
  border-radius: 50%;
  animation: kdFloat 9s ease-in-out infinite;
}
.kd-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(10,10,10,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(10,10,10,.06) 1px, transparent 1px);
  background-size: 28px 28px;
  -webkit-mask-image: radial-gradient(circle at 60% 50%, #000 30%, transparent 75%);
          mask-image: radial-gradient(circle at 60% 50%, #000 30%, transparent 75%);
  border-radius: 32px;
}
@keyframes kdFloat { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-14px);} }

.kd-brand-card {
  position: absolute;
  top: 12px;
  right: 0;
  width: clamp(180px, 34vw, 300px);
  padding: 14px;
  border-radius: 30px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: var(--kd-shadow-lg);
}
.kd-brand-card img {
  width: 100%;
  border-radius: 20px;
  display: block;
}

.kd-card--floating {
  position: absolute; right: 0; bottom: 24px; left: 12%;
  background: #0a0a0a; color: #f4f4f5;
  border-radius: var(--kd-radius-lg);
  box-shadow: var(--kd-shadow-lg);
  padding: 18px 20px 22px;
  font-family: var(--kd-font-mono);
  font-size: 14px;
  transform: rotate(-1.5deg);
}
.kd-card__dots { display: flex; gap: 6px; margin-bottom: 12px; }
.kd-card__dots span { width: 10px; height: 10px; border-radius: 999px; background: #3f3f46; }
.kd-card__dots span:nth-child(1) { background: #ef4444; }
.kd-card__dots span:nth-child(2) { background: #f59e0b; }
.kd-card__dots span:nth-child(3) { background: #22c55e; }
.kd-card--floating pre { margin: 0; white-space: pre-wrap; }
.kd-card--floating code { color: #e4e4e7; }

/* ---------------- About ---------------- */
.kd-about { background: var(--kd-bg-soft); border-top: 1px solid var(--kd-line); border-bottom: 1px solid var(--kd-line); }
.kd-about__inner {
  display: grid; grid-template-columns: .9fr 1.1fr; gap: 56px; align-items: center;
}
.kd-about__photo { position: relative; border-radius: var(--kd-radius-lg); overflow: hidden; box-shadow: var(--kd-shadow); }
.kd-about__photo img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/5; }
.kd-about__badge {
  position: absolute; left: 16px; bottom: 16px;
  background: rgba(10,10,10,.86); color: #fff; backdrop-filter: blur(6px);
  padding: 8px 14px; border-radius: 999px; font-size: 12px; letter-spacing: .04em;
}
.kd-checklist { list-style: none; padding: 0; margin: 22px 0 0; display: grid; grid-template-columns: 1fr 1fr; gap: 10px 22px; }
.kd-checklist li { position: relative; padding-left: 26px; color: var(--kd-fg-2); font-size: 15px; }
.kd-checklist li::before {
  content: ""; position: absolute; left: 0; top: 6px;
  width: 16px; height: 16px; border-radius: 999px;
  background:
    radial-gradient(circle at 35% 40%, #fff 0 2px, transparent 3px) no-repeat,
    var(--kd-fg);
}

/* ---------------- Services ---------------- */
.kd-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.kd-card {
  background: #fff;
  border: 1px solid var(--kd-line);
  border-radius: var(--kd-radius-lg);
  padding: 28px;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.kd-card:hover { transform: translateY(-4px); border-color: var(--kd-fg); box-shadow: var(--kd-shadow); }
.kd-card--service h3 { font: 700 19px/1.3 var(--kd-font-display); margin: 18px 0 8px; }
.kd-card--service p { color: var(--kd-fg-3); font-size: 15px; margin: 0; }
.kd-card__icon {
  width: 48px; height: 48px; border-radius: 12px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--kd-fg); color: #fff;
}

.kd-specialties {
  border-top: 1px solid var(--kd-line);
}
.kd-cards--specialties {
  grid-template-columns: repeat(2, 1fr);
}
.kd-card--specialty {
  min-height: 220px;
  background: linear-gradient(180deg, #fff 0%, var(--kd-bg-soft) 100%);
}
.kd-card--specialty h3 {
  margin: 0 0 12px;
  font: 700 22px/1.25 var(--kd-font-display);
}
.kd-card--specialty p {
  margin: 0;
  color: var(--kd-fg-3);
}

/* ---------------- Feature (Schoolovo) ---------------- */
.kd-feature {
  background: linear-gradient(180deg, #fff 0%, #fafafb 100%);
}
.kd-feature__inner {
  display: grid; grid-template-columns: 1.1fr .9fr; gap: 56px; align-items: center;
}
.kd-feature__stats { display: grid; grid-template-columns: repeat(3, auto); gap: 28px; margin: 26px 0 30px; }
.kd-feature__stats > div { display: flex; flex-direction: column; }
.kd-feature__stats strong { font: 800 26px/1 var(--kd-font-display); }
.kd-feature__stats span { font-size: 13px; color: var(--kd-fg-3); margin-top: 4px; }
.kd-feature__visual {
  position: relative;
  border-radius: var(--kd-radius-lg);
  overflow: hidden;
  background:
    radial-gradient(closest-side, rgba(37,99,235,.18), rgba(37,99,235,0) 70%),
    var(--kd-bg-soft);
  padding: 36px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--kd-line);
}
.kd-feature__visual img { max-width: 360px; width: 100%; height: auto; filter: drop-shadow(0 18px 36px rgba(10,10,10,.18)); }

/* ---------------- Blog cards ---------------- */
.kd-blog__head .kd-link { float: right; margin-top: 8px; }
.kd-cards--posts { grid-template-columns: repeat(3, 1fr); gap: 24px; }
.kd-card--post { padding: 0; overflow: hidden; display: flex; flex-direction: column; }
.kd-card__media { display: block; aspect-ratio: 16/10; overflow: hidden; background: var(--kd-bg-soft); }
.kd-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.kd-card--post:hover .kd-card__media img { transform: scale(1.04); }
.kd-card__img--placeholder {
  width: 100%; height: 100%;
  background:
    radial-gradient(circle at 30% 30%, rgba(37,99,235,.18), transparent 60%),
    radial-gradient(circle at 70% 70%, rgba(255,122,0,.18), transparent 60%),
    var(--kd-bg-soft2);
}
.kd-card__body { padding: 22px 24px 26px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.kd-card__date { color: var(--kd-fg-4); font-size: 12px; letter-spacing: .04em; text-transform: uppercase; }
.kd-card__title { font: 700 19px/1.35 var(--kd-font-display); margin: 0; }
.kd-card__title a { color: var(--kd-fg); }
.kd-card__title a:hover { color: var(--kd-accent); }
.kd-card__excerpt { color: var(--kd-fg-3); font-size: 15px; margin: 4px 0 12px; }

/* ---------------- Website offers ---------------- */
.kd-web-hero {
  padding: 112px 0 72px;
  background: linear-gradient(180deg, #fff 0%, var(--kd-bg-soft) 100%);
  border-bottom: 1px solid var(--kd-line);
}
.kd-web-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr);
  gap: 40px;
  align-items: center;
}
.kd-web-hero__panel {
  border: 1px solid var(--kd-line);
  background: #0a0a0a;
  color: #fff;
  border-radius: var(--kd-radius-lg);
  padding: 32px;
  box-shadow: var(--kd-shadow-lg);
}
.kd-web-hero__panel span {
  display: inline-flex;
  margin-bottom: 12px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.kd-web-hero__panel strong {
  display: block;
  font: 800 32px/1.1 var(--kd-font-display);
  margin-bottom: 14px;
}
.kd-web-hero__panel p { color: rgba(255,255,255,.72); margin: 0; }

.kd-web-examples { background: #fff; }
.kd-web-offers { display: grid; gap: 24px; }
.kd-web-offer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .82fr);
  gap: 28px;
  align-items: stretch;
  border: 1px solid var(--kd-line);
  border-radius: var(--kd-radius-lg);
  background: linear-gradient(180deg, #fff 0%, #fafafb 100%);
  padding: 28px;
  overflow: hidden;
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.kd-web-offer:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--kd-offer-accent) 45%, var(--kd-line));
  box-shadow: var(--kd-shadow);
}
.kd-web-offer__kicker {
  display: inline-flex;
  color: var(--kd-offer-accent);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.kd-web-offer h3 {
  font: 800 clamp(24px, 3vw, 36px)/1.1 var(--kd-font-display);
  margin: 0 0 14px;
}
.kd-web-offer p {
  color: var(--kd-fg-3);
  margin-bottom: 20px;
  max-width: 62ch;
}
.kd-web-offer ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}
.kd-web-offer li {
  position: relative;
  padding-left: 26px;
  color: var(--kd-fg-2);
  font-size: 15px;
}
.kd-web-offer li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--kd-offer-accent);
}
.kd-web-offer__live {
  width: fit-content;
  margin-top: 24px;
  background: var(--kd-offer-accent);
  box-shadow: 0 14px 28px -18px var(--kd-offer-accent);
}
.kd-web-offer__live:hover {
  background: #0a0a0a;
}
.kd-web-offer__preview {
  min-height: 280px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 20px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--kd-offer-accent) 12%, #fff) 0%, #fff 52%, var(--kd-bg-soft2) 100%);
  border: 1px solid color-mix(in srgb, var(--kd-offer-accent) 18%, var(--kd-line));
}
.kd-miniapp {
  width: min(100%, 340px);
  border-radius: 22px;
  border: 1px solid rgba(10,10,10,.12);
  background: #fff;
  box-shadow: 0 24px 56px -28px color-mix(in srgb, var(--kd-offer-accent) 50%, #000);
  overflow: hidden;
}
.kd-miniapp__bar {
  height: 42px;
  display: flex;
  gap: 6px;
  align-items: center;
  padding: 0 16px;
  background: #0a0a0a;
}
.kd-miniapp__bar span { width: 8px; height: 8px; border-radius: 999px; background: rgba(255,255,255,.28); }
.kd-miniapp__screen { padding: 22px; }
.kd-miniapp__top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: start;
}
.kd-miniapp__top span {
  font: 800 22px/1.1 var(--kd-font-display);
  color: var(--kd-fg);
}
.kd-miniapp__top strong {
  flex: 0 0 auto;
  padding: 7px 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--kd-offer-accent) 12%, #fff);
  color: var(--kd-offer-accent);
  font-size: 11px;
}
.kd-miniapp p { margin: 12px 0 18px; color: var(--kd-fg-3); font-size: 14px; }
.kd-miniapp__actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.kd-miniapp__actions span {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  border-radius: 12px;
  border: 1px solid var(--kd-line);
  color: var(--kd-fg-2);
  font-size: 12px;
  font-weight: 800;
  text-align: center;
}
.kd-miniapp__actions span:first-child {
  background: var(--kd-offer-accent);
  color: #fff;
  border-color: var(--kd-offer-accent);
}
.kd-miniapp__rows {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}
.kd-miniapp__rows span {
  height: 12px;
  border-radius: 999px;
  background: var(--kd-bg-soft2);
}
.kd-miniapp__rows span:nth-child(2) { width: 78%; }
.kd-miniapp__rows span:nth-child(3) { width: 56%; }

.kd-pricing {
  background: var(--kd-bg-soft);
  border-top: 1px solid var(--kd-line);
  border-bottom: 1px solid var(--kd-line);
}
.kd-pricing__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}
.kd-price {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  background: #fff;
  border: 1px solid var(--kd-line);
  border-radius: var(--kd-radius-lg);
  padding: 28px;
  box-shadow: 0 14px 32px -28px rgba(10,10,10,.24);
}
.kd-price h3 {
  font: 800 22px/1.2 var(--kd-font-display);
  margin: 0 0 18px;
}
.kd-price__amount {
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--kd-fg);
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.kd-price p { color: var(--kd-fg-3); font-size: 15px; }
.kd-price ul {
  margin: auto 0 0;
  padding: 18px 0 0;
  border-top: 1px solid var(--kd-line);
  list-style: none;
  display: grid;
  gap: 9px;
}
.kd-price li {
  position: relative;
  padding-left: 22px;
  color: var(--kd-fg-2);
  font-size: 14px;
}
.kd-price li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--kd-accent);
}

.kd-process__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.kd-process__step {
  border: 1px solid var(--kd-line);
  border-radius: var(--kd-radius-lg);
  padding: 24px;
  background: #fff;
}
.kd-process__step span {
  display: inline-block;
  margin-bottom: 18px;
  color: var(--kd-accent);
  font: 800 13px/1 var(--kd-font-display);
}
.kd-process__step h3 {
  margin: 0 0 10px;
  font: 800 20px/1.2 var(--kd-font-display);
}
.kd-process__step p { margin: 0; color: var(--kd-fg-3); font-size: 15px; }

/* ---------------- Standalone website demos ---------------- */
body.kd-demo-body {
  margin: 0;
  background: var(--demo-bg, #fff);
  color: #111827;
  font-family: var(--kd-font-sans);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body.kd-demo-body.admin-bar .kd-demo-nav { top: 32px; }
.kd-demo {
  min-height: 100vh;
  background:
    radial-gradient(circle at 82% 12%, color-mix(in srgb, var(--demo-accent) 18%, transparent), transparent 34%),
    linear-gradient(180deg, var(--demo-bg) 0%, #fff 44%, #fff 100%);
  color: #111827;
  overflow-x: hidden;
}
.kd-demo--auto,
.kd-demo--barber {
  color: #f8fafc;
  background:
    radial-gradient(circle at 78% 10%, color-mix(in srgb, var(--demo-accent) 32%, transparent), transparent 34%),
    linear-gradient(180deg, #09090b 0%, #111827 48%, #f8fafc 48%, #f8fafc 100%);
}
.kd-demo-nav {
  position: sticky;
  top: 0;
  z-index: 30;
  width: min(1180px, calc(100% - 32px));
  min-height: 72px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 16px 0;
}
.kd-demo-nav nav {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 8px 16px;
  border: 1px solid rgba(17,24,39,.08);
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.kd-demo--auto .kd-demo-nav nav,
.kd-demo--barber .kd-demo-nav nav {
  border-color: rgba(255,255,255,.14);
  background: rgba(9,9,11,.68);
}
.kd-demo-nav nav a {
  color: inherit;
  font-size: 14px;
  font-weight: 800;
  opacity: .78;
}
.kd-demo-nav nav a:hover { opacity: 1; color: var(--demo-accent); }
.kd-demo-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: inherit;
}
.kd-demo-brand:hover { color: inherit; }
.kd-demo-brand span {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: var(--demo-accent);
  color: #fff;
  font: 900 19px/1 var(--kd-font-display);
  box-shadow: 0 16px 34px -20px var(--demo-accent);
}
.kd-demo-brand strong {
  font: 900 18px/1 var(--kd-font-display);
}
.kd-demo-nav__actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6px;
  padding: 4px;
  border: 1px solid rgba(17,24,39,.08);
  border-radius: 999px;
  background: rgba(255,255,255,.72);
}
.kd-demo--auto .kd-demo-nav__actions,
.kd-demo--barber .kd-demo-nav__actions {
  border-color: rgba(255,255,255,.14);
  background: rgba(9,9,11,.68);
}
.kd-demo-nav__actions a {
  min-width: 40px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: inherit;
  font-size: 12px;
  font-weight: 900;
}
.kd-demo-nav__actions a.is-active {
  background: var(--demo-accent);
  color: #fff;
}
.kd-demo main,
.kd-demo-footer {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
}
.kd-demo-hero {
  min-height: calc(100vh - 88px);
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, .92fr);
  gap: 48px;
  align-items: center;
  padding: 48px 0 76px;
}
.kd-demo-kicker {
  display: inline-flex;
  color: var(--demo-accent);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.kd-demo-hero h1,
.kd-demo-section__head h2,
.kd-demo-split h2,
.kd-demo-contact h2 {
  margin: 0;
  font-family: var(--kd-font-display);
  letter-spacing: -.02em;
}
.kd-demo-hero h1 {
  max-width: 880px;
  font-size: clamp(42px, 7vw, 92px);
  line-height: .96;
}
.kd-demo-hero p {
  max-width: 650px;
  margin: 24px 0 0;
  color: color-mix(in srgb, currentColor 80%, transparent);
  font-size: clamp(17px, 1.6vw, 21px);
  line-height: 1.7;
}
.kd-demo-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
}
.kd-demo-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 900;
  color: inherit;
}
.kd-demo-btn--primary {
  background: var(--demo-accent);
  color: #fff;
  box-shadow: 0 18px 34px -22px var(--demo-accent);
}
.kd-demo-btn--primary:hover { color: #fff; filter: brightness(.95); }
.kd-demo-btn--ghost {
  border-color: color-mix(in srgb, currentColor 18%, transparent);
  background: rgba(255,255,255,.36);
}
.kd-demo--auto .kd-demo-btn--ghost,
.kd-demo--barber .kd-demo-btn--ghost { background: rgba(255,255,255,.08); }
.kd-demo-btn--ghost:hover { color: var(--demo-accent); }
.kd-demo-panel {
  border-radius: 34px;
  padding: 18px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--demo-accent) 20%, #fff) 0%, rgba(255,255,255,.82) 100%);
  border: 1px solid color-mix(in srgb, var(--demo-accent) 22%, rgba(255,255,255,.62));
  box-shadow: 0 34px 82px -42px color-mix(in srgb, var(--demo-accent) 62%, #000);
}
.kd-demo--auto .kd-demo-panel,
.kd-demo--barber .kd-demo-panel {
  background: linear-gradient(135deg, color-mix(in srgb, var(--demo-accent) 26%, #111827) 0%, #18181b 100%);
  border-color: rgba(255,255,255,.12);
}
.kd-demo-panel__screen {
  min-height: 420px;
  border-radius: 24px;
  padding: 28px;
  background: rgba(255,255,255,.86);
  color: #111827;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.kd-demo--auto .kd-demo-panel__screen,
.kd-demo--barber .kd-demo-panel__screen {
  background: #09090b;
  color: #f8fafc;
}
.kd-demo-panel__screen span {
  font-weight: 900;
  color: var(--demo-accent);
}
.kd-demo-panel__screen strong {
  display: block;
  font: 900 clamp(60px, 9vw, 112px)/.9 var(--kd-font-display);
  margin: 18px 0 10px;
}
.kd-demo-panel__screen p {
  margin: 0 0 28px;
  color: color-mix(in srgb, currentColor 76%, transparent);
  font-weight: 800;
}
.kd-demo-panel__line {
  height: 14px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--demo-accent) 20%, currentColor 8%);
  margin-top: 12px;
}
.kd-demo-panel__line--short { width: 58%; }
.kd-demo-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: -32px;
  margin-bottom: 96px;
}
.kd-demo-stats div {
  border: 1px solid rgba(17,24,39,.08);
  border-radius: 24px;
  padding: 22px;
  background: rgba(255,255,255,.82);
  box-shadow: 0 18px 38px -32px rgba(17,24,39,.42);
}
.kd-demo--auto .kd-demo-stats div,
.kd-demo--barber .kd-demo-stats div {
  background: #fff;
  color: #111827;
}
.kd-demo-stats strong {
  display: block;
  color: var(--demo-accent);
  font: 900 32px/1 var(--kd-font-display);
}
.kd-demo-stats span {
  display: block;
  margin-top: 8px;
  color: #475569;
  font-size: 14px;
  font-weight: 700;
}
.kd-demo-section,
.kd-demo-split,
.kd-demo-contact {
  padding: 96px 0;
  color: #111827;
}
.kd-demo-section__head {
  max-width: 760px;
  margin-bottom: 34px;
}
.kd-demo-section__head h2,
.kd-demo-split h2,
.kd-demo-contact h2 {
  font-size: clamp(30px, 4vw, 54px);
  line-height: 1.06;
}
.kd-demo-services {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.kd-demo-services article {
  border-radius: 26px;
  padding: 26px;
  background: #fff;
  border: 1px solid rgba(17,24,39,.08);
  box-shadow: 0 20px 50px -40px rgba(17,24,39,.34);
}
.kd-demo-services article span {
  color: var(--demo-accent);
  font-weight: 900;
  font-size: 13px;
}
.kd-demo-services h3 {
  margin: 16px 0 10px;
  font: 900 22px/1.16 var(--kd-font-display);
}
.kd-demo-services p,
.kd-demo-split p,
.kd-demo-contact p {
  color: #334155;
  line-height: 1.7;
}
.kd-demo-split {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: 48px;
  align-items: start;
  border-top: 1px solid rgba(17,24,39,.08);
}
.kd-demo-split blockquote {
  margin: 28px 0 0;
  padding: 24px;
  border-left: 4px solid var(--demo-accent);
  border-radius: 0 22px 22px 0;
  background: color-mix(in srgb, var(--demo-accent) 8%, #fff);
  color: #111827;
  font: 800 20px/1.45 var(--kd-font-display);
}
.kd-demo-contact {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 32px;
  align-items: center;
  margin-bottom: 42px;
  padding: 42px;
  border-radius: 34px;
  background: #111827;
  color: #fff;
}
.kd-demo-contact p { color: rgba(255,255,255,.86); margin-bottom: 0; }
.kd-demo-contact__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: flex-end;
}
.kd-demo-contact .kd-demo-btn--ghost {
  color: #fff;
  border-color: rgba(255,255,255,.55);
  background: rgba(255,255,255,.12);
}
.kd-demo-contact .kd-demo-btn--ghost:hover {
  color: #fff;
  background: rgba(255,255,255,.2);
  border-color: #fff;
}
.kd-demo-footer {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  padding: 0 0 34px;
  color: #475569;
  font-size: 13px;
}
.kd-demo-footer a { color: inherit; font-weight: 900; }
.kd-demo--beauty .kd-demo-panel__screen { border-radius: 34px 34px 80px 34px; }
.kd-demo--auto .kd-demo-panel__screen { border-radius: 18px; }
.kd-demo--vet .kd-demo-panel__screen { border-radius: 40px; }
.kd-demo--medical .kd-demo-panel__screen { border-radius: 18px; }
.kd-demo--hair .kd-demo-panel { transform: rotate(-1deg); }
.kd-demo--barber .kd-demo-panel__screen { border-radius: 12px; }
.kd-demo--shop .kd-demo-panel__screen { border-radius: 28px; }

/* Stronger visual differentiation for demo pages */
.kd-demo {
  position: relative;
  background:
    radial-gradient(circle at 10% 10%, color-mix(in srgb, var(--demo-accent) 14%, transparent), transparent 28%),
    radial-gradient(circle at 90% 12%, color-mix(in srgb, var(--demo-accent) 18%, transparent), transparent 34%),
    linear-gradient(180deg, var(--demo-bg) 0%, color-mix(in srgb, var(--demo-bg) 54%, #fff) 46%, #fff 100%);
}
.kd-demo-texture {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
}
.kd-demo-texture span {
  position: absolute;
  display: block;
  border-radius: 999px;
  opacity: .6;
  filter: blur(8px);
}
.kd-demo-texture span:nth-child(1) {
  width: 180px;
  height: 180px;
  top: 120px;
  left: -40px;
  background: color-mix(in srgb, var(--demo-accent) 14%, transparent);
}
.kd-demo-texture span:nth-child(2) {
  width: 280px;
  height: 280px;
  top: 80px;
  right: -80px;
  background: color-mix(in srgb, var(--demo-accent) 12%, transparent);
}
.kd-demo-texture span:nth-child(3) {
  width: 12px;
  height: 12px;
  top: 38%;
  left: 18%;
  background: var(--demo-accent);
  filter: none;
}
.kd-demo-texture span:nth-child(4) {
  width: 16px;
  height: 16px;
  top: 58%;
  right: 16%;
  background: color-mix(in srgb, var(--demo-accent) 60%, #fff);
  filter: none;
}
.kd-demo--beauty {
  background:
    radial-gradient(circle at 15% 10%, rgba(255,255,255,.94), transparent 30%),
    radial-gradient(circle at 88% 18%, rgba(251,207,232,.72), transparent 34%),
    linear-gradient(180deg, #fff7fb 0%, #fff9fd 54%, #ffffff 100%);
}
.kd-demo--auto {
  color: #f8fafc;
  background:
    linear-gradient(135deg, rgba(234,88,12,.12), transparent 32%),
    linear-gradient(180deg, #05070c 0%, #0f172a 54%, #edf2f7 54%, #edf2f7 100%);
}
.kd-demo--vet {
  background:
    radial-gradient(circle at 12% 18%, rgba(255,255,255,.9), transparent 30%),
    linear-gradient(180deg, #ecfdf5 0%, #f4fff9 50%, #ffffff 100%);
}
.kd-demo--medical {
  background:
    linear-gradient(180deg, rgba(37,99,235,.08) 0%, rgba(255,255,255,.92) 38%, #ffffff 100%),
    linear-gradient(90deg, rgba(37,99,235,.05) 1px, transparent 1px),
    linear-gradient(rgba(37,99,235,.05) 1px, transparent 1px);
  background-size: auto, 48px 48px, 48px 48px;
}
.kd-demo--hair {
  background:
    radial-gradient(circle at 86% 14%, rgba(196,181,253,.54), transparent 28%),
    linear-gradient(180deg, #f5f3ff 0%, #faf7ff 52%, #ffffff 100%);
}
.kd-demo--barber {
  color: #f8fafc;
  background:
    linear-gradient(120deg, rgba(20,184,166,.12), transparent 24%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.02) 0 8px, transparent 8px 28px),
    linear-gradient(180deg, #050505 0%, #111827 54%, #f4f4f5 54%, #f4f4f5 100%);
}
.kd-demo--shop {
  background:
    linear-gradient(180deg, rgba(202,138,4,.08) 0%, rgba(255,251,235,.94) 42%, #ffffff 100%),
    radial-gradient(circle at 92% 16%, rgba(254,240,138,.44), transparent 32%);
}
.kd-demo-hero {
  padding: 56px 0 88px;
}
.kd-demo-hero__copy {
  position: relative;
  z-index: 1;
}
.kd-demo-hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}
.kd-demo-hero__chips span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--demo-accent) 18%, rgba(17,24,39,.08));
  background: rgba(255,255,255,.72);
  color: #334155;
  font-size: 13px;
  font-weight: 700;
  box-shadow: 0 16px 32px -28px rgba(15,23,42,.48);
}
.kd-demo-hero__chips strong {
  color: var(--demo-accent);
  font-size: 14px;
  font-weight: 900;
}
.kd-demo--auto .kd-demo-hero__chips span,
.kd-demo--barber .kd-demo-hero__chips span {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.12);
  color: rgba(248,250,252,.88);
}
.kd-demo-panel {
  position: relative;
  border-radius: 38px;
}
.kd-demo-device {
  position: relative;
  min-height: 470px;
  border-radius: 30px;
  padding: 18px;
  background: rgba(255,255,255,.86);
  color: #111827;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.kd-demo--auto .kd-demo-device,
.kd-demo--barber .kd-demo-device {
  background: #09090b;
  color: #f8fafc;
}
.kd-demo-device__top {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 18px;
}
.kd-demo-device__top span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--demo-accent) 12%, transparent);
  color: var(--demo-accent);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.kd-demo-device__top strong {
  font: 900 34px/1 var(--kd-font-display);
}
.kd-demo-visual {
  position: relative;
  flex: 1;
  min-height: 240px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(255,255,255,.26) 0%, rgba(255,255,255,.04) 100%);
  border: 1px solid rgba(255,255,255,.12);
  overflow: hidden;
}
.kd-demo-visual__shape {
  position: absolute;
  display: block;
}
.kd-demo-device__content {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 8px;
  margin-top: 18px;
}
.kd-demo-device__content strong {
  display: block;
  font: 900 clamp(44px, 6vw, 74px)/.94 var(--kd-font-display);
  margin: 0;
}
.kd-demo-device__content p {
  margin: 0;
}
.kd-demo-device__cards {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
}
.kd-demo-device__cards div {
  display: grid;
  gap: 6px;
  padding: 14px 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(17,24,39,.08);
}
.kd-demo--auto .kd-demo-device__cards div,
.kd-demo--barber .kd-demo-device__cards div {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.08);
}
.kd-demo-device__cards b {
  color: var(--demo-accent);
  font-size: 12px;
  font-weight: 900;
}
.kd-demo-device__cards span {
  font-size: 13px;
  font-weight: 800;
  line-height: 1.35;
}
.kd-demo-photo-stack {
  position: absolute;
  inset: 16px;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(0, .92fr);
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 12px;
  pointer-events: none;
}
.kd-demo-visual__shape { z-index: 0; }
.kd-demo-photo {
  position: relative;
  display: grid;
  align-content: end;
  min-height: 156px;
  margin: 0 0 18px;
  padding: 16px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.95) 0%, rgba(226,232,240,.92) 100%),
    linear-gradient(145deg, rgba(148,163,184,.18), rgba(255,255,255,0) 42%);
  border: 1px solid rgba(148,163,184,.24);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.46), 0 24px 50px -42px rgba(15,23,42,.34);
  overflow: hidden;
}
.kd-demo-photo::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.92), transparent 28%),
    linear-gradient(180deg, rgba(148,163,184,.18), rgba(148,163,184,0) 46%);
  pointer-events: none;
}
.kd-demo-photo::after {
  content: "";
  position: absolute;
  left: 14%;
  right: 14%;
  bottom: 14%;
  height: 42%;
  border-radius: 28px 28px 16px 16px;
  background:
    linear-gradient(180deg, rgba(148,163,184,.48), rgba(148,163,184,.16));
  box-shadow:
    0 -56px 0 -42px rgba(255,255,255,.7),
    inset 0 18px 28px -18px rgba(255,255,255,.48);
  opacity: .88;
  pointer-events: none;
}
.kd-demo-photo__chrome {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 1;
  display: inline-flex;
  gap: 6px;
}
.kd-demo-photo__chrome span {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(15,23,42,.18);
}
.kd-demo-photo__icon {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 1;
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: rgba(15,23,42,.8);
  color: #fff;
  box-shadow: 0 14px 28px -18px rgba(15,23,42,.62);
}
.kd-demo-photo__icon svg { width: 22px; height: 22px; }
.kd-demo-photo__caption {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(15,23,42,.74);
  color: #fff;
  backdrop-filter: blur(12px);
}
.kd-demo-photo__caption strong {
  font: 900 13px/1.15 var(--kd-font-display);
}
.kd-demo-photo__caption span {
  color: rgba(255,255,255,.72);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.kd-demo-photo--hero-main {
  grid-row: 1 / span 2;
  min-height: 212px;
  margin: 0;
}
.kd-demo-photo--hero-side {
  min-height: 100px;
  margin: 0;
}
.kd-demo-photo--hero-side .kd-demo-photo__caption {
  padding: 8px 10px;
}
.kd-demo-photo--hero-side .kd-demo-photo__caption strong { font-size: 12px; }
.kd-demo-photo--hero-side .kd-demo-photo__caption span { font-size: 10px; }
.kd-demo-photo--landscape {
  min-height: 126px;
}
.kd-demo-photo--portrait,
.kd-demo-photo--profile,
.kd-demo-photo--barber-portrait,
.kd-demo-photo--vet-portrait,
.kd-demo-photo--hair-portrait,
.kd-demo-photo--medical-profile {
  min-height: 178px;
}
.kd-demo-photo--beauty-beforeafter,
.kd-demo-photo--beauty-plan,
.kd-demo-photo--beauty-detail,
.kd-demo-photo--hair-cover,
.kd-demo-photo--hair-detail,
.kd-demo-photo--shop-hero,
.kd-demo-photo--shop-card {
  min-height: 132px;
}

.kd-demo-photo--beauty-beforeafter {
  border-radius: 30px;
  background:
    linear-gradient(90deg, rgba(255,255,255,.98) 0%, rgba(255,255,255,.98) 49.5%, rgba(252,231,243,.98) 50.5%, rgba(252,231,243,.98) 100%),
    linear-gradient(145deg, rgba(244,114,182,.18), rgba(255,255,255,0) 44%);
}
.kd-demo-photo--beauty-beforeafter::before {
  background:
    radial-gradient(circle at 24% 20%, rgba(255,255,255,.96), transparent 24%),
    radial-gradient(circle at 76% 20%, rgba(255,255,255,.88), transparent 28%),
    radial-gradient(circle at 26% 74%, rgba(203,213,225,.48), transparent 22%),
    radial-gradient(circle at 74% 74%, rgba(244,114,182,.22), transparent 24%);
}
.kd-demo-photo--beauty-beforeafter::after {
  left: 50%;
  top: 12%;
  bottom: 12%;
  width: 1px;
  height: auto;
  transform: translateX(-50%);
  border-radius: 999px;
  background: rgba(244,114,182,.26);
  box-shadow: none;
}
.kd-demo-photo--beauty-beforeafter .kd-demo-photo__chrome::after {
  content: "before / after";
  position: absolute;
  left: 0;
  top: 18px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.74);
  color: #db2777;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  white-space: nowrap;
}

.kd-demo-photo--beauty-plan {
  border-radius: 34px 24px 34px 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(252,231,243,.98) 100%),
    linear-gradient(145deg, rgba(244,114,182,.16), rgba(255,255,255,0) 44%);
}
.kd-demo-photo--beauty-plan::before {
  background:
    radial-gradient(circle at 22% 18%, rgba(255,255,255,.96), transparent 22%),
    linear-gradient(180deg, rgba(244,114,182,.18), transparent 44%);
}
.kd-demo-photo--beauty-plan::after {
  left: 18%;
  right: 18%;
  bottom: 14%;
  height: 26%;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(244,114,182,.28), rgba(244,114,182,.08));
  box-shadow:
    0 -56px 0 -38px rgba(255,255,255,.9),
    0 -28px 0 -14px rgba(251,207,232,.86),
    inset 0 14px 22px -14px rgba(255,255,255,.44);
}

.kd-demo-photo--beauty-detail {
  border-radius: 26px;
  background:
    radial-gradient(circle at 50% 24%, rgba(255,255,255,.98), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.96) 0%, rgba(251,207,232,.9) 100%);
}
.kd-demo-photo--beauty-detail::before {
  background:
    radial-gradient(circle at 50% 24%, rgba(255,255,255,.96), transparent 24%),
    radial-gradient(circle at 50% 78%, rgba(244,114,182,.24), transparent 28%);
}
.kd-demo-photo--beauty-detail::after {
  left: 18%;
  right: 18%;
  bottom: 16%;
  height: 36%;
  border-radius: 999px 999px 24px 24px;
  background: linear-gradient(180deg, rgba(251,207,232,.86), rgba(244,114,182,.14));
  box-shadow:
    0 -46px 0 -34px rgba(255,255,255,.9),
    inset 0 18px 26px -18px rgba(255,255,255,.56);
}

.kd-demo-photo--hair-cover {
  min-height: 206px;
  border-radius: 30px 54px 28px 54px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(237,233,254,.98) 100%),
    repeating-linear-gradient(90deg, rgba(124,58,237,.12) 0 12px, rgba(255,255,255,0) 12px 22px);
}
.kd-demo-photo--hair-cover::before {
  background:
    radial-gradient(circle at 20% 18%, rgba(255,255,255,.96), transparent 22%),
    linear-gradient(180deg, rgba(124,58,237,.2), transparent 40%);
}
.kd-demo-photo--hair-cover::after {
  left: 18%;
  right: 18%;
  bottom: 12%;
  height: 54%;
  border-radius: 999px 999px 34px 34px;
  background: linear-gradient(180deg, rgba(124,58,237,.34), rgba(124,58,237,.1));
  box-shadow:
    0 -58px 0 -44px rgba(255,255,255,.9),
    0 -26px 0 -10px rgba(196,181,253,.48),
    inset 0 18px 28px -18px rgba(255,255,255,.42);
}

.kd-demo-photo--hair-detail {
  min-height: 118px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(243,232,255,.98) 100%),
    repeating-linear-gradient(100deg, rgba(124,58,237,.16) 0 10px, rgba(255,255,255,0) 10px 18px);
}
.kd-demo-photo--hair-detail::before {
  background:
    radial-gradient(circle at 22% 18%, rgba(255,255,255,.96), transparent 24%),
    linear-gradient(180deg, rgba(124,58,237,.14), transparent 48%);
}
.kd-demo-photo--hair-detail::after {
  left: 22%;
  right: 22%;
  bottom: 18%;
  height: 30%;
  border-radius: 999px 999px 18px 18px;
  background: linear-gradient(180deg, rgba(196,181,253,.84), rgba(124,58,237,.12));
  box-shadow:
    0 -30px 0 -22px rgba(255,255,255,.88),
    inset 0 14px 20px -14px rgba(255,255,255,.46);
}

.kd-demo-photo--hair-portrait {
  min-height: 186px;
  border-radius: 30px 30px 22px 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(237,233,254,.98) 100%),
    linear-gradient(145deg, rgba(124,58,237,.12), rgba(255,255,255,0) 44%);
}
.kd-demo-photo--hair-portrait::before {
  background:
    radial-gradient(circle at 28% 20%, rgba(255,255,255,.96), transparent 22%),
    linear-gradient(180deg, rgba(124,58,237,.18), transparent 42%);
}
.kd-demo-photo--hair-portrait::after {
  left: 16%;
  right: 16%;
  bottom: 12%;
  height: 52%;
  border-radius: 999px 999px 26px 26px;
  background: linear-gradient(180deg, rgba(124,58,237,.38), rgba(124,58,237,.12));
  box-shadow:
    0 -54px 0 -42px rgba(255,255,255,.86),
    inset 0 20px 28px -18px rgba(255,255,255,.42);
}

.kd-demo-photo--barber-portrait {
  min-height: 188px;
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.02) 100%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.03) 0 10px, transparent 10px 22px),
    linear-gradient(180deg, rgba(2,6,23,.98) 0%, rgba(17,24,39,.96) 100%);
}
.kd-demo-photo--barber-portrait::before {
  background:
    radial-gradient(circle at 22% 18%, rgba(255,255,255,.12), transparent 24%),
    linear-gradient(180deg, rgba(20,184,166,.18), transparent 42%);
}
.kd-demo-photo--barber-portrait::after {
  left: 16%;
  right: 16%;
  bottom: 12%;
  height: 54%;
  border-radius: 24px 24px 18px 18px;
  background: linear-gradient(180deg, rgba(71,85,105,.46), rgba(30,41,59,.12));
  box-shadow:
    0 -56px 0 -42px rgba(255,255,255,.08),
    inset 0 18px 28px -18px rgba(255,255,255,.08);
}

.kd-demo-photo--vet-portrait {
  min-height: 188px;
  border-radius: 34px 34px 24px 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(220,252,231,.96) 100%),
    linear-gradient(145deg, rgba(5,150,105,.14), rgba(255,255,255,0) 42%);
}
.kd-demo-photo--vet-portrait::before {
  background:
    radial-gradient(circle at 20% 18%, rgba(255,255,255,.96), transparent 24%),
    linear-gradient(180deg, rgba(16,185,129,.18), transparent 42%);
}
.kd-demo-photo--vet-portrait::after {
  left: 16%;
  right: 16%;
  bottom: 12%;
  height: 52%;
  border-radius: 999px 999px 26px 26px;
  background: linear-gradient(180deg, rgba(148,163,184,.32), rgba(5,150,105,.1));
  box-shadow:
    0 -54px 0 -42px rgba(255,255,255,.86),
    inset 0 18px 26px -18px rgba(255,255,255,.5);
}

.kd-demo-photo--medical-profile {
  min-height: 188px;
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(219,234,254,.98) 100%),
    linear-gradient(90deg, rgba(37,99,235,.05) 1px, transparent 1px),
    linear-gradient(rgba(37,99,235,.05) 1px, transparent 1px);
  background-size: auto, 26px 26px, 26px 26px;
}
.kd-demo-photo--medical-profile::before {
  background:
    radial-gradient(circle at 22% 18%, rgba(255,255,255,.96), transparent 22%),
    linear-gradient(180deg, rgba(37,99,235,.16), transparent 42%);
}
.kd-demo-photo--medical-profile::after {
  left: 14%;
  right: 14%;
  bottom: 14%;
  height: 30%;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(59,130,246,.18), rgba(37,99,235,.06));
  box-shadow:
    0 -58px 0 -44px rgba(255,255,255,.92),
    inset 0 18px 26px -18px rgba(255,255,255,.48);
}
.kd-demo-photo--medical-profile .kd-demo-photo__caption {
  background: rgba(37,99,235,.12);
  color: #1d4ed8;
  border: 1px solid rgba(37,99,235,.16);
}
.kd-demo-photo--medical-profile .kd-demo-photo__caption span {
  color: rgba(29,78,216,.72);
}

.kd-demo-photo--shop-hero,
.kd-demo-photo--shop-card {
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(254,249,195,.96) 100%),
    linear-gradient(145deg, rgba(202,138,4,.12), rgba(255,255,255,0) 42%);
}
.kd-demo-photo--shop-hero::after,
.kd-demo-photo--shop-card::after {
  left: 18%;
  right: 18%;
  bottom: 14%;
  height: 36%;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(202,138,4,.22), rgba(202,138,4,.08));
  box-shadow:
    0 -42px 0 -30px rgba(255,255,255,.9),
    inset 0 14px 22px -14px rgba(255,255,255,.44);
}

.kd-demo-collection--beauty-gallery article .kd-demo-photo--beauty-beforeafter {
  transform: rotate(-1.4deg);
}
.kd-demo-collection--beauty-gallery article:nth-child(2) .kd-demo-photo--beauty-plan,
.kd-demo-collection--beauty-gallery article:nth-child(4) .kd-demo-photo--beauty-detail {
  transform: rotate(1.4deg);
}
.kd-demo-collection--beauty-gallery article:nth-child(1) .kd-demo-photo,
.kd-demo-collection--beauty-gallery article:nth-child(4) .kd-demo-photo {
  min-height: 158px;
}
.kd-demo-collection--hair-lookbook article:nth-child(1) .kd-demo-photo--hair-cover,
.kd-demo-collection--hair-lookbook article:nth-child(4) .kd-demo-photo--hair-cover {
  min-height: 220px;
}
.kd-demo-collection--hair-lookbook article:nth-child(2) .kd-demo-photo--hair-detail,
.kd-demo-collection--hair-lookbook article:nth-child(3) .kd-demo-photo--hair-detail {
  min-height: 112px;
}
.kd-demo-live--hair-stylists .kd-demo-live-cards article .kd-demo-photo--hair-portrait,
.kd-demo-live--barber-slots .kd-demo-live-cards article .kd-demo-photo--barber-portrait {
  min-height: 168px;
}

.kd-demo-collection article .kd-demo-photo,
.kd-demo-team-grid article .kd-demo-photo,
.kd-demo-live-cards article .kd-demo-photo,
.kd-demo-medical-flow aside .kd-demo-photo {
  margin-bottom: 16px;
}
.kd-demo-team-grid article .kd-demo-photo,
.kd-demo-live--hair-stylists .kd-demo-live-cards article .kd-demo-photo,
.kd-demo-live--barber-slots .kd-demo-live-cards article .kd-demo-photo {
  min-height: 188px;
}
.kd-demo-collection article .kd-demo-photo + .kd-demo-ico,
.kd-demo-live-cards article .kd-demo-photo + .kd-demo-ico {
  margin-bottom: 12px;
}
.kd-demo-collection article .kd-demo-photo ~ h3,
.kd-demo-team-grid article .kd-demo-photo ~ h3,
.kd-demo-live-cards article .kd-demo-photo ~ h3 {
  margin-top: 16px;
}
.kd-demo-team-grid article > div {
  margin-top: -44px;
  margin-left: 18px;
  border: 6px solid rgba(255,255,255,.7);
}
.kd-demo-medical-flow aside .kd-demo-photo {
  min-height: 190px;
  margin-bottom: 20px;
}

.kd-demo--beauty .kd-demo-photo {
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(252,231,243,.94) 100%),
    linear-gradient(145deg, rgba(244,114,182,.14), rgba(255,255,255,0) 42%);
  border-color: rgba(244,114,182,.16);
}
.kd-demo--beauty .kd-demo-photo__icon {
  background: rgba(219,39,119,.12);
  color: #db2777;
}
.kd-demo--beauty .kd-demo-photo--beauty-beforeafter .kd-demo-photo__icon,
.kd-demo--beauty .kd-demo-photo--beauty-plan .kd-demo-photo__icon,
.kd-demo--beauty .kd-demo-photo--beauty-detail .kd-demo-photo__icon {
  background: rgba(255,255,255,.78);
}
.kd-demo--vet .kd-demo-photo {
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(220,252,231,.94) 100%),
    linear-gradient(145deg, rgba(5,150,105,.14), rgba(255,255,255,0) 42%);
  border-color: rgba(5,150,105,.16);
}
.kd-demo--vet .kd-demo-photo__icon {
  background: rgba(5,150,105,.12);
  color: #059669;
}
.kd-demo--vet .kd-demo-photo--vet-portrait .kd-demo-photo__icon {
  background: rgba(255,255,255,.86);
}
.kd-demo--medical .kd-demo-photo {
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(219,234,254,.96) 100%),
    linear-gradient(90deg, rgba(37,99,235,.05) 1px, transparent 1px),
    linear-gradient(rgba(37,99,235,.05) 1px, transparent 1px);
  background-size: auto, 32px 32px, 32px 32px;
  border-color: rgba(37,99,235,.14);
}
.kd-demo--medical .kd-demo-photo__icon {
  background: rgba(37,99,235,.12);
  color: #2563eb;
}
.kd-demo--hair .kd-demo-photo {
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(237,233,254,.96) 100%),
    linear-gradient(145deg, rgba(124,58,237,.14), rgba(255,255,255,0) 42%);
  border-color: rgba(124,58,237,.16);
}
.kd-demo--hair .kd-demo-photo__icon {
  background: rgba(124,58,237,.12);
  color: #7c3aed;
}
.kd-demo--hair .kd-demo-photo--hair-cover .kd-demo-photo__icon,
.kd-demo--hair .kd-demo-photo--hair-detail .kd-demo-photo__icon,
.kd-demo--hair .kd-demo-photo--hair-portrait .kd-demo-photo__icon {
  background: rgba(255,255,255,.82);
}
.kd-demo--shop .kd-demo-photo {
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(254,249,195,.94) 100%),
    linear-gradient(145deg, rgba(202,138,4,.14), rgba(255,255,255,0) 42%);
  border-color: rgba(202,138,4,.16);
}
.kd-demo--shop .kd-demo-photo__icon {
  background: rgba(202,138,4,.12);
  color: #ca8a04;
}
.kd-demo--auto .kd-demo-photo,
.kd-demo--barber .kd-demo-photo {
  background:
    linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.02) 100%),
    linear-gradient(180deg, rgba(15,23,42,.98) 0%, rgba(24,24,27,.96) 100%);
  border-color: rgba(255,255,255,.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 24px 50px -42px rgba(0,0,0,.82);
}
.kd-demo--auto .kd-demo-photo::before,
.kd-demo--barber .kd-demo-photo::before {
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.1), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0) 46%);
}
.kd-demo--auto .kd-demo-photo::after,
.kd-demo--barber .kd-demo-photo::after {
  background: linear-gradient(180deg, rgba(148,163,184,.34), rgba(148,163,184,.08));
  box-shadow:
    0 -56px 0 -42px rgba(255,255,255,.12),
    inset 0 18px 28px -18px rgba(255,255,255,.08);
}
.kd-demo--auto .kd-demo-photo__chrome span,
.kd-demo--barber .kd-demo-photo__chrome span {
  background: rgba(255,255,255,.18);
}
.kd-demo--auto .kd-demo-photo__caption,
.kd-demo--barber .kd-demo-photo__caption {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.08);
  color: #fff;
}
.kd-demo--auto .kd-demo-photo__caption span,
.kd-demo--barber .kd-demo-photo__caption span {
  color: rgba(248,250,252,.68);
}
.kd-demo--auto .kd-demo-photo__icon {
  background: rgba(251,146,60,.14);
  color: #fdba74;
}
.kd-demo--barber .kd-demo-photo__icon {
  background: rgba(94,234,212,.14);
  color: #5eead4;
}
.kd-demo--barber .kd-demo-photo--barber-portrait .kd-demo-photo__icon {
  background: rgba(5,150,105,.14);
}

@media (max-width: 1024px) {
  .kd-demo-photo-stack {
    grid-template-columns: 1fr 1fr;
  }
  .kd-demo-photo--hero-main {
    min-height: 188px;
  }
  .kd-demo-collection--hair-lookbook article:nth-child(1) .kd-demo-photo--hair-cover,
  .kd-demo-collection--hair-lookbook article:nth-child(4) .kd-demo-photo--hair-cover {
    min-height: 180px;
  }
}

@media (max-width: 720px) {
  .kd-demo-photo-stack {
    inset: 12px;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
  }
  .kd-demo-photo-stack .kd-demo-photo--hero-main {
    grid-row: auto;
    min-height: 136px;
  }
  .kd-demo-photo-stack .kd-demo-photo--hero-side:last-child {
    display: none;
  }
  .kd-demo-photo--hero-side {
    min-height: 82px;
  }
  .kd-demo-team-grid article > div {
    margin-top: -34px;
    margin-left: 14px;
  }
}
.kd-demo-service-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.kd-demo-services article b {
  color: color-mix(in srgb, currentColor 18%, transparent);
  font: 900 24px/1 var(--kd-font-display);
}
.kd-demo-split__visual {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 26px;
}
.kd-demo-split__visual span {
  min-height: 88px;
  border-radius: 22px;
  background: color-mix(in srgb, var(--demo-accent) 10%, #fff);
  border: 1px solid color-mix(in srgb, var(--demo-accent) 18%, rgba(17,24,39,.08));
}
.kd-demo-split__visual span:nth-child(1) { transform: translateY(10px); }
.kd-demo-split__visual span:nth-child(2) { min-height: 124px; }
.kd-demo-split__visual span:nth-child(3) { min-height: 124px; }
.kd-demo-split__visual span:nth-child(4) { transform: translateY(-10px); }

.kd-demo--beauty .kd-demo-panel {
  transform: rotate(-2deg);
}
.kd-demo--beauty .kd-demo-device {
  border-radius: 38px 38px 94px 38px;
}
.kd-demo--beauty .kd-demo-visual {
  background: linear-gradient(135deg, rgba(255,255,255,.72), rgba(244,114,182,.16));
}
.kd-demo--beauty .kd-demo-visual__shape--a {
  width: 72%;
  height: 72%;
  right: -6%;
  top: 8%;
  border-radius: 38% 62% 54% 46% / 46% 40% 60% 54%;
  background: linear-gradient(135deg, rgba(244,114,182,.72), rgba(255,255,255,.22));
}
.kd-demo--beauty .kd-demo-visual__shape--b {
  width: 56%;
  height: 26%;
  left: 10%;
  top: 14%;
  border-radius: 999px;
  background: rgba(255,255,255,.78);
}
.kd-demo--beauty .kd-demo-visual__shape--c,
.kd-demo--beauty .kd-demo-visual__shape--d,
.kd-demo--beauty .kd-demo-visual__shape--e {
  left: 10%;
  height: 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.62);
}
.kd-demo--beauty .kd-demo-visual__shape--c { top: 54%; right: 14%; }
.kd-demo--beauty .kd-demo-visual__shape--d { top: 64%; width: 58%; }
.kd-demo--beauty .kd-demo-visual__shape--e { top: 74%; width: 42%; }
.kd-demo--beauty .kd-demo-visual__shape--f {
  width: 94px;
  height: 94px;
  left: 10%;
  bottom: 18%;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(255,255,255,.88), rgba(244,114,182,.44));
}
.kd-demo--beauty .kd-demo-split__visual span:nth-child(odd) {
  border-radius: 28px 12px 28px 18px;
}
.kd-demo--beauty .kd-demo-split__visual span:nth-child(even) {
  border-radius: 18px 28px 14px 28px;
}

.kd-demo--auto .kd-demo-panel {
  box-shadow: 0 38px 90px -46px rgba(0,0,0,.88);
}
.kd-demo--auto .kd-demo-device {
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01)),
    #0a0f19;
}
.kd-demo--auto .kd-demo-visual {
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)),
    linear-gradient(180deg, #0f172a 0%, #1e293b 100%);
}
.kd-demo--auto .kd-demo-visual__shape--a {
  left: 8%;
  right: 8%;
  bottom: 14%;
  height: 68px;
  border-radius: 18px;
  background: linear-gradient(90deg, #1f2937, #111827);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
}
.kd-demo--auto .kd-demo-visual__shape--b {
  left: 12%;
  right: 12%;
  bottom: 34%;
  height: 4px;
  border-radius: 999px;
  background: repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0 28px, transparent 28px 48px);
}
.kd-demo--auto .kd-demo-visual__shape--c,
.kd-demo--auto .kd-demo-visual__shape--d {
  width: 72px;
  height: 72px;
  bottom: 10%;
  border-radius: 50%;
  background: radial-gradient(circle, #0f172a 32%, #e2e8f0 34%, #0f172a 56%);
}
.kd-demo--auto .kd-demo-visual__shape--c { left: 14%; }
.kd-demo--auto .kd-demo-visual__shape--d { right: 14%; }
.kd-demo--auto .kd-demo-visual__shape--e {
  top: 18%;
  left: 12%;
  width: 34%;
  height: 14px;
  border-radius: 999px;
  background: rgba(234,88,12,.82);
}
.kd-demo--auto .kd-demo-visual__shape--f {
  top: 22%;
  right: 12%;
  width: 24%;
  height: 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.22);
}
.kd-demo--auto .kd-demo-services article:nth-child(2) {
  transform: translateY(22px);
}
.kd-demo--auto .kd-demo-split__visual span {
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(234,88,12,.12), rgba(15,23,42,.08));
}

.kd-demo--vet .kd-demo-panel {
  border-radius: 36px;
}
.kd-demo--vet .kd-demo-device {
  border-radius: 42px;
  background: linear-gradient(180deg, #ffffff 0%, #f0fdf4 100%);
}
.kd-demo--vet .kd-demo-visual {
  background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(16,185,129,.08));
}
.kd-demo--vet .kd-demo-visual__shape--a,
.kd-demo--vet .kd-demo-visual__shape--b,
.kd-demo--vet .kd-demo-visual__shape--c,
.kd-demo--vet .kd-demo-visual__shape--d {
  width: 78px;
  height: 78px;
  border-radius: 50% 50% 44% 44%;
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 24px -16px rgba(5,150,105,.48);
}
.kd-demo--vet .kd-demo-visual__shape--a { left: 18%; top: 18%; }
.kd-demo--vet .kd-demo-visual__shape--b { right: 18%; top: 18%; }
.kd-demo--vet .kd-demo-visual__shape--c { left: 30%; bottom: 18%; }
.kd-demo--vet .kd-demo-visual__shape--d { right: 30%; bottom: 18%; }
.kd-demo--vet .kd-demo-visual__shape--e {
  left: 50%;
  top: 50%;
  width: 76px;
  height: 76px;
  transform: translate(-50%, -50%) rotate(45deg);
  border-radius: 20px;
  background: rgba(5,150,105,.18);
}
.kd-demo--vet .kd-demo-visual__shape--f {
  left: 50%;
  top: 50%;
  width: 16px;
  height: 76px;
  transform: translate(-50%, -50%);
  border-radius: 999px;
  background: rgba(5,150,105,.84);
  box-shadow: -30px 30px 0 0 rgba(5,150,105,.84), 30px 30px 0 0 rgba(5,150,105,.84), 0 -30px 0 0 rgba(5,150,105,.84);
}
.kd-demo--vet .kd-demo-split__visual span {
  border-radius: 999px;
}

.kd-demo--medical .kd-demo-panel {
  border-radius: 20px;
}
.kd-demo--medical .kd-demo-device {
  border-radius: 18px;
}
.kd-demo--medical .kd-demo-visual {
  border-radius: 18px;
  background:
    linear-gradient(90deg, rgba(37,99,235,.06) 1px, transparent 1px),
    linear-gradient(rgba(37,99,235,.06) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(219,234,254,.52));
  background-size: 34px 34px, 34px 34px, auto;
}
.kd-demo--medical .kd-demo-visual__shape--a,
.kd-demo--medical .kd-demo-visual__shape--b,
.kd-demo--medical .kd-demo-visual__shape--c,
.kd-demo--medical .kd-demo-visual__shape--d {
  background: rgba(37,99,235,.86);
  border-radius: 999px;
}
.kd-demo--medical .kd-demo-visual__shape--a {
  left: 50%;
  top: 18%;
  width: 20px;
  height: 132px;
  transform: translateX(-50%);
}
.kd-demo--medical .kd-demo-visual__shape--b {
  left: 50%;
  top: 50%;
  width: 132px;
  height: 20px;
  transform: translate(-50%, -50%);
}
.kd-demo--medical .kd-demo-visual__shape--c {
  right: 14%;
  bottom: 20%;
  width: 96px;
  height: 12px;
}
.kd-demo--medical .kd-demo-visual__shape--d {
  right: 14%;
  bottom: 20%;
  width: 12px;
  height: 96px;
}
.kd-demo--medical .kd-demo-visual__shape--e,
.kd-demo--medical .kd-demo-visual__shape--f {
  left: 14%;
  height: 12px;
  border-radius: 999px;
  background: rgba(37,99,235,.22);
}
.kd-demo--medical .kd-demo-visual__shape--e { top: 24%; right: 42%; }
.kd-demo--medical .kd-demo-visual__shape--f { top: 34%; width: 30%; }
.kd-demo--medical .kd-demo-services article,
.kd-demo--medical .kd-demo-contact {
  border-radius: 18px;
}
.kd-demo--medical .kd-demo-split__visual span {
  border-radius: 12px;
}

.kd-demo--hair .kd-demo-panel {
  transform: rotate(-2.2deg);
}
.kd-demo--hair .kd-demo-device {
  border-radius: 30px 60px 30px 60px;
}
.kd-demo--hair .kd-demo-visual {
  background: linear-gradient(135deg, rgba(255,255,255,.82), rgba(124,58,237,.16));
}
.kd-demo--hair .kd-demo-visual__shape--a,
.kd-demo--hair .kd-demo-visual__shape--b,
.kd-demo--hair .kd-demo-visual__shape--c {
  width: 22%;
  height: 72%;
  top: 12%;
  border-radius: 999px 999px 36px 36px;
  background: linear-gradient(180deg, rgba(124,58,237,.84), rgba(196,181,253,.18));
}
.kd-demo--hair .kd-demo-visual__shape--a { left: 14%; }
.kd-demo--hair .kd-demo-visual__shape--b { left: 39%; }
.kd-demo--hair .kd-demo-visual__shape--c { left: 64%; }
.kd-demo--hair .kd-demo-visual__shape--d,
.kd-demo--hair .kd-demo-visual__shape--e,
.kd-demo--hair .kd-demo-visual__shape--f {
  width: 26%;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.78);
}
.kd-demo--hair .kd-demo-visual__shape--d { left: 10%; bottom: 18%; }
.kd-demo--hair .kd-demo-visual__shape--e { left: 37%; bottom: 18%; }
.kd-demo--hair .kd-demo-visual__shape--f { left: 64%; bottom: 18%; }
.kd-demo--hair .kd-demo-services article:nth-child(1) { transform: rotate(-1deg); }
.kd-demo--hair .kd-demo-services article:nth-child(2) { transform: translateY(18px) rotate(1deg); }
.kd-demo--hair .kd-demo-services article:nth-child(3) { transform: rotate(-1deg); }
.kd-demo--hair .kd-demo-split__visual span {
  border-radius: 32px 12px 26px 18px;
}

.kd-demo--barber .kd-demo-panel {
  border-radius: 16px;
}
.kd-demo--barber .kd-demo-device {
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01)), #0a0a0a;
}
.kd-demo--barber .kd-demo-visual {
  border-radius: 12px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)),
    repeating-linear-gradient(90deg, rgba(255,255,255,.03) 0 10px, transparent 10px 22px),
    #111111;
}
.kd-demo--barber .kd-demo-visual__shape--a,
.kd-demo--barber .kd-demo-visual__shape--b,
.kd-demo--barber .kd-demo-visual__shape--c,
.kd-demo--barber .kd-demo-visual__shape--d {
  width: 14px;
  height: 72%;
  top: 14%;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(20,184,166,.88), rgba(20,184,166,.16));
}
.kd-demo--barber .kd-demo-visual__shape--a { left: 20%; }
.kd-demo--barber .kd-demo-visual__shape--b { left: 36%; }
.kd-demo--barber .kd-demo-visual__shape--c { left: 52%; }
.kd-demo--barber .kd-demo-visual__shape--d { left: 68%; }
.kd-demo--barber .kd-demo-visual__shape--e,
.kd-demo--barber .kd-demo-visual__shape--f {
  top: 18%;
  width: 18%;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
}
.kd-demo--barber .kd-demo-visual__shape--e { left: 12%; }
.kd-demo--barber .kd-demo-visual__shape--f { right: 12%; }
.kd-demo--barber .kd-demo-services article {
  background: linear-gradient(180deg, #ffffff 0%, #f5f5f5 100%);
}
.kd-demo--barber .kd-demo-split__visual span {
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(20,184,166,.1), rgba(255,255,255,.08));
}

.kd-demo--shop .kd-demo-nav nav {
  background: rgba(255,255,255,.9);
}
.kd-demo--shop .kd-demo-panel {
  border-radius: 30px;
}
.kd-demo--shop .kd-demo-device {
  border-radius: 28px;
}
.kd-demo--shop .kd-demo-visual {
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(254,240,138,.26));
}
.kd-demo--shop .kd-demo-visual__shape--a,
.kd-demo--shop .kd-demo-visual__shape--b,
.kd-demo--shop .kd-demo-visual__shape--c {
  width: 22%;
  height: 42%;
  bottom: 14%;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(202,138,4,.18), rgba(255,255,255,.94));
  border: 1px solid rgba(202,138,4,.22);
}
.kd-demo--shop .kd-demo-visual__shape--a { left: 10%; }
.kd-demo--shop .kd-demo-visual__shape--b { left: 39%; }
.kd-demo--shop .kd-demo-visual__shape--c { left: 68%; }
.kd-demo--shop .kd-demo-visual__shape--d,
.kd-demo--shop .kd-demo-visual__shape--e,
.kd-demo--shop .kd-demo-visual__shape--f {
  height: 12px;
  border-radius: 999px;
  background: rgba(202,138,4,.24);
}
.kd-demo--shop .kd-demo-visual__shape--d { left: 10%; top: 18%; width: 46%; }
.kd-demo--shop .kd-demo-visual__shape--e { left: 10%; top: 28%; width: 26%; }
.kd-demo--shop .kd-demo-visual__shape--f { right: 10%; top: 18%; width: 18%; }
.kd-demo--shop .kd-demo-services article:nth-child(2) {
  transform: translateY(20px);
}
.kd-demo--shop .kd-demo-split__visual span {
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(202,138,4,.1), rgba(254,240,138,.28));
}

.kd-demo-showcase,
.kd-demo-live {
  padding: 96px 0;
  color: #111827;
}
.kd-demo-showcase__head,
.kd-demo-live__copy {
  max-width: 780px;
  margin-bottom: 34px;
}
.kd-demo-showcase__head h2,
.kd-demo-live__copy h2 {
  margin: 0;
  font: 900 clamp(30px, 4vw, 58px)/1.05 var(--kd-font-display);
  letter-spacing: -.02em;
}
.kd-demo-showcase__head p,
.kd-demo-live__copy p {
  margin: 18px 0 0;
  color: #475569;
  font-size: 18px;
  line-height: 1.7;
}
.kd-demo-collection {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.kd-demo-collection article,
.kd-demo-team-grid article,
.kd-demo-live-cards article {
  position: relative;
  min-height: 260px;
  padding: 24px;
  border: 1px solid rgba(17,24,39,.08);
  background: #fff;
  box-shadow: 0 20px 54px -42px rgba(15,23,42,.45);
  overflow: hidden;
}
.kd-demo-collection article::before,
.kd-demo-team-grid article::before,
.kd-demo-live-cards article::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 88% 8%, color-mix(in srgb, var(--demo-accent) 22%, transparent), transparent 38%);
  pointer-events: none;
  opacity: .55;
}
.kd-demo-collection span,
.kd-demo-team-grid span,
.kd-demo-live-cards span {
  position: relative;
  z-index: 1;
  display: inline-flex;
  color: var(--demo-accent);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.kd-demo-collection h3,
.kd-demo-team-grid h3,
.kd-demo-live-cards h3 {
  position: relative;
  z-index: 1;
  margin: 44px 0 10px;
  font: 900 25px/1.08 var(--kd-font-display);
}
.kd-demo-collection b,
.kd-demo-team-grid b,
.kd-demo-live-cards b {
  position: relative;
  z-index: 1;
  color: #1f2937;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .01em;
}
.kd-demo-collection p,
.kd-demo-team-grid p,
.kd-demo-live-cards p {
  position: relative;
  z-index: 1;
  margin: 14px 0 0;
  color: #334155;
  line-height: 1.65;
}
.kd-demo-collection--beauty-gallery article {
  border-radius: 34px 34px 84px 34px;
  background: linear-gradient(180deg, #fff 0%, #fff7fb 100%);
}
.kd-demo-collection--beauty-gallery article:nth-child(2),
.kd-demo-collection--beauty-gallery article:nth-child(4) {
  transform: translateY(34px);
  border-radius: 84px 34px 34px 34px;
}
.kd-demo-collection--hair-lookbook {
  grid-template-columns: 1.15fr .85fr .85fr 1.15fr;
  align-items: stretch;
}
.kd-demo-collection--hair-lookbook article {
  border-radius: 28px 56px 28px 56px;
  background: linear-gradient(160deg, #fff 0%, #f5f3ff 100%);
}
.kd-demo-collection--hair-lookbook article:nth-child(1),
.kd-demo-collection--hair-lookbook article:nth-child(4) {
  min-height: 340px;
}
.kd-demo-collection--hair-lookbook article:nth-child(2),
.kd-demo-collection--hair-lookbook article:nth-child(3) {
  transform: translateY(38px);
}
.kd-demo-collection--barber-lineup article {
  min-height: 330px;
  border-radius: 12px;
  background: #101010;
  color: #f8fafc;
  border-color: rgba(255,255,255,.1);
}
.kd-demo-collection--barber-lineup article::before {
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.04) 0 8px, transparent 8px 24px),
    radial-gradient(circle at 82% 16%, rgba(20,184,166,.22), transparent 34%);
}
.kd-demo-collection--barber-lineup b { color: #5eead4; }
.kd-demo-collection--barber-lineup p { color: rgba(248,250,252,.86); }
.kd-demo-collection--shop-catalog {
  grid-template-columns: 1.25fr .75fr .75fr 1.25fr;
}
.kd-demo-collection--shop-catalog article {
  border-radius: 26px;
  background: linear-gradient(180deg, #fff 0%, #fefce8 100%);
}
.kd-demo-collection--shop-catalog article:nth-child(1),
.kd-demo-collection--shop-catalog article:nth-child(4) {
  min-height: 330px;
}
.kd-demo-auto-board {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 22px;
  align-items: stretch;
}
.kd-demo-auto-board__track {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 14px;
  border-radius: 22px;
  background: #0f172a;
  color: #f8fafc;
  border: 1px solid rgba(255,255,255,.08);
}
.kd-demo-auto-board__track article {
  min-height: 300px;
  padding: 18px;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.08);
}
.kd-demo-auto-board__track span {
  display: inline-flex;
  color: var(--demo-accent);
  font: 900 24px/1 var(--kd-font-display);
}
.kd-demo-auto-board__track h3 {
  margin: 74px 0 10px;
  font: 900 23px/1.1 var(--kd-font-display);
}
.kd-demo-auto-board__track b,
.kd-demo-auto-board__track p { color: rgba(248,250,252,.86); }
.kd-demo-auto-board__track b { color: #fed7aa; }
.kd-demo-auto-board__panel,
.kd-demo-showcase__note,
.kd-demo-medical-flow aside {
  padding: 24px;
  border-radius: 26px;
  background: color-mix(in srgb, var(--demo-accent) 10%, #fff);
  border: 1px solid color-mix(in srgb, var(--demo-accent) 18%, rgba(17,24,39,.08));
}
.kd-demo-auto-board__panel > strong,
.kd-demo-showcase__note > strong,
.kd-demo-medical-flow aside > span {
  display: block;
  margin-bottom: 20px;
  font: 900 24px/1.1 var(--kd-font-display);
}
.kd-demo-team-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.kd-demo-team-grid article {
  min-height: 330px;
  border-radius: 40px;
  background: linear-gradient(180deg, #fff 0%, #f0fdf4 100%);
}
.kd-demo-team-grid article > div {
  position: relative;
  z-index: 1;
  width: 74px;
  height: 74px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 26px;
  border-radius: 50% 50% 44% 44%;
  background: #fff;
  color: var(--demo-accent);
  font: 900 26px/1 var(--kd-font-display);
  box-shadow: 0 16px 34px -26px rgba(5,150,105,.55);
}
.kd-demo-showcase__note {
  margin-top: 18px;
  background: #fff;
}
.kd-demo-medical-flow {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 22px;
}
.kd-demo-medical-flow > div {
  display: grid;
  gap: 14px;
}
.kd-demo-medical-flow article {
  display: grid;
  grid-template-columns: 74px 1fr;
  gap: 20px;
  padding: 24px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(37,99,235,.12);
  box-shadow: 0 18px 44px -38px rgba(37,99,235,.48);
}
.kd-demo-medical-flow article span {
  width: 54px;
  height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: #dbeafe;
  color: #1d4ed8;
  font-weight: 900;
}
.kd-demo-medical-flow h3 {
  margin: 0 0 8px;
  font: 900 23px/1.1 var(--kd-font-display);
}
.kd-demo-medical-flow b { color: #1d4ed8; }
.kd-demo-medical-flow p { color: #334155; }
.kd-demo-live {
  display: grid;
  grid-template-columns: minmax(0, .85fr) minmax(340px, 1.15fr);
  gap: 42px;
  align-items: center;
  border-top: 1px solid rgba(17,24,39,.08);
}
.kd-demo-live__surface {
  padding: 24px;
  border-radius: 34px;
  background: #fff;
  border: 1px solid rgba(17,24,39,.08);
  box-shadow: 0 30px 80px -54px rgba(15,23,42,.48);
}
.kd-demo-live__rows {
  display: grid;
  gap: 10px;
}
.kd-demo-live__rows div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 16px;
  border-radius: 16px;
  background: color-mix(in srgb, var(--demo-accent) 7%, #fff);
}
.kd-demo-live__rows span {
  color: #475569;
  font-size: 13px;
  font-weight: 800;
}
.kd-demo-live__rows strong {
  text-align: right;
  font-weight: 900;
  color: #0f172a;
}
.kd-demo-booking-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}
.kd-demo-booking-steps span {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 24px;
  background: #fff7fb;
  border: 1px solid rgba(219,39,119,.12);
  font-weight: 900;
}
.kd-demo-booking-steps b {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--demo-accent);
  color: #fff;
}
.kd-demo-live__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.kd-demo-live__tags span {
  padding: 10px 14px;
  border-radius: 999px;
  background: #111827;
  color: #fff;
  font-size: 13px;
  font-weight: 900;
}
.kd-demo-form-preview {
  display: grid;
  gap: 12px;
  margin-bottom: 16px;
}
.kd-demo-form-preview label {
  display: grid;
  gap: 8px;
  padding: 16px;
  border-radius: 14px;
  background: #0f172a;
  color: #f8fafc;
}
.kd-demo-form-preview span {
  color: rgba(248,250,252,.56);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.kd-demo-form-preview strong { font-weight: 900; }
.kd-demo-triage {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.kd-demo-triage__card {
  padding: 24px;
  border-radius: 32px;
  background: #f0fdf4;
  border: 1px solid rgba(5,150,105,.14);
}
.kd-demo-triage__card--urgent {
  background: #fff1f2;
  border-color: rgba(225,29,72,.16);
}
.kd-demo-triage__card h3 {
  margin: 0 0 16px;
  font: 900 24px/1.1 var(--kd-font-display);
}
.kd-demo-triage__card ul,
.kd-demo-checklist-widget {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.kd-demo-triage__card li,
.kd-demo-checklist-widget li {
  position: relative;
  padding-left: 24px;
  color: #1e293b;
  font-weight: 700;
}
.kd-demo-triage__card li::before,
.kd-demo-checklist-widget li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--demo-accent);
}
.kd-demo-checklist-widget {
  margin-bottom: 18px;
  padding: 22px;
  border-radius: 18px;
  background: #eff6ff;
}
.kd-demo-live-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}
.kd-demo-live-cards article {
  min-height: 220px;
  border-radius: 24px;
}
.kd-demo-live--barber-slots .kd-demo-live__surface,
.kd-demo-live--auto-intake .kd-demo-live__surface {
  background: #09090b;
  color: #f8fafc;
  border-color: rgba(255,255,255,.1);
}
.kd-demo-live--barber-slots .kd-demo-live-cards article {
  border-radius: 12px;
  background: #111;
  color: #f8fafc;
  border-color: rgba(255,255,255,.1);
}
.kd-demo-live--barber-slots .kd-demo-live-cards b { color: #5eead4; }
.kd-demo-live--barber-slots .kd-demo-live-cards p { color: rgba(248,250,252,.86); }
.kd-demo-live--barber-slots .kd-demo-live__rows div { background: rgba(94,234,212,.08); border: 1px solid rgba(94,234,212,.18); }
.kd-demo-live--barber-slots .kd-demo-live__rows span { color: rgba(248,250,252,.7); }
.kd-demo-live--barber-slots .kd-demo-live__rows strong { color: #fff; }
.kd-demo-live--hair-stylists .kd-demo-live-cards article {
  border-radius: 28px 48px 28px 48px;
  background: linear-gradient(160deg, #fff 0%, #f5f3ff 100%);
}
.kd-demo-live--shop-cart .kd-demo-live__surface {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(254,252,232,.96) 100%);
}
.kd-demo-live--shop-cart .kd-demo-live__surface::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 14%, rgba(254,240,138,.38), transparent 24%),
    radial-gradient(circle at 88% 14%, rgba(202,138,4,.16), transparent 26%);
  pointer-events: none;
}
.kd-demo-live--shop-cart .kd-demo-live-cards,
.kd-demo-live--shop-cart .kd-demo-live__rows,
.kd-demo-live--shop-cart .kd-demo-live__tags {
  position: relative;
  z-index: 1;
}
.kd-demo-live--shop-cart .kd-demo-live-cards {
  grid-template-columns: minmax(0, 1.08fr) minmax(0, .92fr);
  gap: 14px;
  margin-bottom: 18px;
}
.kd-demo-live--shop-cart .kd-demo-live-cards article {
  min-height: 308px;
  border-radius: 30px;
  background: linear-gradient(180deg, #fff 0%, #fefce8 100%);
  border-color: rgba(202,138,4,.14);
  box-shadow: 0 28px 60px -44px rgba(161,98,7,.34);
}
.kd-demo-live--shop-cart .kd-demo-live-cards article:nth-child(1) {
  transform: rotate(-1deg);
}
.kd-demo-live--shop-cart .kd-demo-live-cards article:nth-child(2) {
  transform: translateY(18px) rotate(1deg);
}
.kd-demo-live--shop-cart .kd-demo-live-cards article .kd-demo-photo--shop-hero {
  min-height: 170px;
}
.kd-demo-live--shop-cart .kd-demo-live-cards article .kd-demo-photo--shop-card {
  min-height: 142px;
}
.kd-demo-live--shop-cart .kd-demo-live-cards b {
  color: #92400e;
}
.kd-demo-live--shop-cart .kd-demo-live-cards p {
  color: #57534e;
}
.kd-demo-live--shop-cart .kd-demo-live__rows {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.kd-demo-live--shop-cart .kd-demo-live__rows div {
  display: grid;
  align-items: start;
  justify-content: flex-start;
  gap: 8px;
  min-height: 92px;
  padding: 16px;
  background: rgba(255,255,255,.74);
  border: 1px solid rgba(202,138,4,.14);
}
.kd-demo-live--shop-cart .kd-demo-live__rows span {
  color: #a16207;
}
.kd-demo-live--shop-cart .kd-demo-live__rows strong {
  text-align: left;
  color: #78350f;
}
.kd-demo-live--shop-cart .kd-demo-live__tags {
  margin-top: 14px;
}
.kd-demo-live--shop-cart .kd-demo-live__tags span {
  background: rgba(202,138,4,.1);
  color: #92400e;
  border: 1px solid rgba(202,138,4,.16);
}

/* ---------------- Contact ---------------- */
.kd-contact {
  background: var(--kd-bg-soft);
  border-top: 1px solid var(--kd-line);
  border-bottom: 1px solid var(--kd-line);
}
.kd-contact__grid {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 32px;
  align-items: start;
}
.kd-form {
  margin-top: 28px;
  background: #fff;
  border: 1px solid var(--kd-line);
  border-radius: var(--kd-radius-lg);
  box-shadow: var(--kd-shadow);
  padding: 28px;
}
.kd-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.kd-form__group {
  display: grid;
  gap: 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--kd-fg-2);
}
.kd-form__group--full { grid-column: 1 / -1; }
.kd-form__input {
  width: 100%;
  min-height: 48px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid var(--kd-line-2);
  background: #fff;
  color: var(--kd-fg);
  font: 500 15px/1.4 var(--kd-font-sans);
  transition: border-color .2s ease, box-shadow .2s ease;
}
.kd-form__input:focus {
  outline: none;
  border-color: var(--kd-accent);
  box-shadow: 0 0 0 4px rgba(37,99,235,.12);
}
.kd-form__textarea {
  min-height: 180px;
  resize: vertical;
}
.kd-form__select {
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--kd-fg-4) 50%), linear-gradient(135deg, var(--kd-fg-4) 50%, transparent 50%);
  background-position: calc(100% - 20px) calc(50% - 3px), calc(100% - 14px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}
.kd-form__consent {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin: 18px 0 24px;
  color: var(--kd-fg-3);
  font-size: 14px;
}
.kd-form__consent input {
  margin-top: 3px;
  width: 18px;
  height: 18px;
}
.kd-form__notice {
  margin-top: 22px;
  padding: 14px 18px;
  border-radius: 16px;
  font-weight: 600;
}
.kd-form__notice--success {
  background: rgba(22,163,74,.12);
  color: #166534;
  border: 1px solid rgba(22,163,74,.24);
}
.kd-form__notice--error {
  background: rgba(220,38,38,.10);
  color: #991b1b;
  border: 1px solid rgba(220,38,38,.18);
}
.kd-contact__aside {
  display: grid;
  gap: 18px;
}
.kd-contact__card {
  background: #0a0a0a;
  color: #fff;
  border-radius: var(--kd-radius-lg);
  padding: 28px;
  box-shadow: var(--kd-shadow-lg);
}
.kd-contact__card--soft {
  background: #fff;
  color: var(--kd-fg);
  border: 1px solid var(--kd-line);
  box-shadow: var(--kd-shadow);
}
.kd-contact__card .kd-eyebrow { color: #93c5fd; }
.kd-contact__card h3 {
  margin: 0 0 12px;
  font: 700 26px/1.2 var(--kd-font-display);
}
.kd-contact__card p {
  margin: 0 0 18px;
  color: rgba(255,255,255,.72);
}
.kd-contact__card--soft p { color: var(--kd-fg-3); }
.kd-contact__mail {
  display: inline-flex;
  font: 700 18px/1.35 var(--kd-font-display);
  color: #fff;
  word-break: break-word;
}
.kd-contact__card--soft .kd-contact__mail { color: var(--kd-fg); }
.kd-contact__meta {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}
.kd-contact__meta li {
  position: relative;
  padding-left: 20px;
  color: var(--kd-fg-2);
}
.kd-contact__meta li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--kd-accent);
}
.kd-hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
}

/* ---------------- CTA ---------------- */
.kd-cta { background: var(--kd-fg); color: #fff; }
.kd-cta__inner { text-align: center; max-width: 760px; margin: 0 auto; }
.kd-cta .kd-h2 { color: #fff; }
.kd-cta p { color: rgba(255,255,255,.72); font-size: 17px; }
.kd-cta .kd-btn--primary { background: #fff; color: var(--kd-fg); }
.kd-cta .kd-btn--primary:hover { background: var(--kd-amber); color: #fff; }

/* ---------------- Footer ---------------- */
.kd-footer { background: #0a0a0a; color: #d4d4d8; padding: 64px 0 28px; }
.kd-footer a { color: #d4d4d8; }
.kd-footer a:hover { color: #fff; }
.kd-footer__grid {
  display: grid; grid-template-columns: 1.4fr .9fr .9fr .9fr; gap: 32px;
  padding-bottom: 48px; border-bottom: 1px solid #1f1f23;
}
.kd-logo--footer .kd-logo__text strong { color: #fff; }
.kd-logo--footer .kd-logo__text span { color: #8a8a93; }
.kd-footer__col h4 { font: 600 13px/1 var(--kd-font-sans); letter-spacing: .14em; text-transform: uppercase; color: #8a8a93; margin: 4px 0 16px; }
.kd-footer__col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; font-size: 14px; }
.kd-footer__admin { margin-top: 14px; }
.kd-footer__bottom {
  padding-top: 24px;
  display: flex; justify-content: space-between; gap: 12px;
  color: #8a8a93; font-size: 13px;
}

/* ---------------- Blog / single ---------------- */
.kd-page-hero { padding: 96px 0 24px; }
.kd-admin { padding: 32px 0 96px; }
.kd-admin__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr);
  gap: 24px;
  align-items: start;
}
.kd-admin__card { padding: 32px; }
.kd-admin__card--soft { background: var(--kd-bg-soft); }
.kd-admin__hello {
  margin-bottom: 18px;
  color: var(--kd-fg-3);
  font-weight: 600;
}
.kd-admin__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.kd-admin__steps {
  margin: 16px 0 0;
  padding-left: 20px;
  color: var(--kd-fg-2);
}
.kd-admin__steps li + li { margin-top: 10px; }
.kd-blog--archive { padding-top: 32px; }
.kd-pagination { margin-top: 48px; display: flex; justify-content: center; }
.kd-pagination .page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px; padding: 0 14px; border-radius: 999px;
  font-weight: 600; font-size: 14px; color: var(--kd-fg-2);
  border: 1px solid var(--kd-line); background: #fff; margin: 0 4px;
}
.kd-pagination .page-numbers.current { background: var(--kd-fg); color: #fff; border-color: var(--kd-fg); }

.kd-post { padding: 80px 0 96px; }
.kd-post__container { max-width: 800px; }
.kd-post__date { display: block; color: var(--kd-fg-4); font-size: 13px; text-transform: uppercase; letter-spacing: .08em; margin: 16px 0; }
.kd-post__author { color: var(--kd-fg-3); }
.kd-post__cover { margin: 28px 0; border-radius: var(--kd-radius-lg); overflow: hidden; }
.kd-post__cover img { width: 100%; height: auto; }
.kd-post__footer { display: flex; gap: 12px; margin-top: 48px; flex-wrap: wrap; padding-top: 32px; border-top: 1px solid var(--kd-line); }

.kd-prose { font-size: 18px; line-height: 1.75; color: var(--kd-fg-2); }
.kd-prose h2 { font: 700 28px/1.2 var(--kd-font-display); margin: 2em 0 .6em; color: var(--kd-fg); }
.kd-prose h3 { font: 600 22px/1.2 var(--kd-font-display); margin: 1.6em 0 .5em; color: var(--kd-fg); }
.kd-prose a { color: var(--kd-accent); border-bottom: 1px solid currentColor; }
.kd-prose img { border-radius: var(--kd-radius); margin: 1.4em 0; }
.kd-prose blockquote {
  border-left: 3px solid var(--kd-fg); padding: 4px 0 4px 20px; margin: 1.2em 0;
  color: var(--kd-fg); font-style: italic;
}
.kd-prose pre, .kd-prose code { font-family: var(--kd-font-mono); font-size: .92em; }
.kd-prose pre { background: #0a0a0a; color: #f4f4f5; padding: 18px 20px; border-radius: var(--kd-radius); overflow: auto; }

.kd-empty { color: var(--kd-fg-3); font-size: 16px; }

/* ---------------- Animations ---------------- */
[data-kd-reveal] {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .65s cubic-bezier(.16,.84,.34,1), transform .65s cubic-bezier(.16,.84,.34,1);
  will-change: opacity, transform;
}
[data-kd-reveal].is-visible { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  [data-kd-reveal] { opacity: 1; transform: none; transition: none; }
  .kd-orb, .kd-pill__dot { animation: none; }
  html { scroll-behavior: auto; }
}

/* ---------------- Responsive ---------------- */
@media (max-width: 1024px) {
  .kd-cards { grid-template-columns: repeat(2, 1fr); }
  .kd-cards--specialties { grid-template-columns: 1fr 1fr; }
  .kd-cards--posts { grid-template-columns: repeat(2, 1fr); }
  .kd-hero__inner, .kd-about__inner, .kd-feature__inner, .kd-contact__grid, .kd-admin__grid, .kd-web-hero__inner, .kd-web-offer { grid-template-columns: 1fr; }
  .kd-about__photo { max-width: 480px; }
  .kd-hero__visual { min-height: 360px; order: -1; }
  .kd-brand-card { width: min(260px, 72%); }
  .kd-card--floating { left: 5%; right: 5%; }
  .kd-pricing__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .kd-process__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .kd-demo-hero, .kd-demo-split, .kd-demo-contact { grid-template-columns: 1fr; }
  .kd-demo-panel { max-width: 640px; }
  .kd-demo-device__cards { grid-template-columns: 1fr 1fr 1fr; }
  .kd-demo-contact__actions { justify-content: flex-start; }
  .kd-demo-services { grid-template-columns: 1fr; }
  .kd-demo-collection,
  .kd-demo-collection--hair-lookbook,
  .kd-demo-collection--shop-catalog,
  .kd-demo-auto-board__track,
  .kd-demo-team-grid,
  .kd-demo-live-cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .kd-demo-auto-board,
  .kd-demo-medical-flow,
  .kd-demo-live { grid-template-columns: 1fr; }
  .kd-demo-collection--beauty-gallery article:nth-child(2),
  .kd-demo-collection--beauty-gallery article:nth-child(4),
  .kd-demo-collection--hair-lookbook article:nth-child(2),
  .kd-demo-collection--hair-lookbook article:nth-child(3),
  .kd-demo--auto .kd-demo-services article:nth-child(2),
  .kd-demo--shop .kd-demo-services article:nth-child(2) { transform: none; }
}
@media (max-width: 720px) {
  section { padding: 72px 0; }
  .kd-nav { display: none; }
  .kd-burger { display: inline-flex; align-items: center; justify-content: center; }
  .kd-lang-switch__link { min-width: 36px; padding: 0 8px; }
  .kd-mobile__lang a { flex: 1 1 72px; text-align: center; }
  .kd-cards, .kd-cards--posts { grid-template-columns: 1fr; }
  .kd-cards--specialties { grid-template-columns: 1fr; }
  .kd-stats { grid-template-columns: 1fr 1fr; gap: 18px; }
  .kd-checklist { grid-template-columns: 1fr; }
  .kd-form { padding: 22px; }
  .kd-form__grid { grid-template-columns: 1fr; }
  .kd-form__group--full { grid-column: auto; }
  .kd-brand-card { width: min(220px, 78%); padding: 10px; }
  .kd-web-hero { padding: 82px 0 56px; }
  .kd-web-offer { padding: 22px; }
  .kd-web-offer__preview { min-height: 240px; padding: 16px; }
  .kd-miniapp__actions { grid-template-columns: 1fr; }
  .kd-pricing__grid, .kd-process__grid { grid-template-columns: 1fr; }
  .kd-footer__grid { grid-template-columns: 1fr 1fr; }
  body.kd-demo-body.admin-bar .kd-demo-nav { top: 46px; }
  .kd-demo-nav {
    width: min(100% - 24px, 1180px);
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 12px;
  }
  .kd-demo-brand strong { font-size: 16px; }
  .kd-demo-nav__actions { margin-left: auto; }
  .kd-demo-nav__actions a { min-width: 38px; }
  .kd-demo-nav nav { order: 3; width: 100%; justify-content: space-between; gap: 10px; border-radius: 18px; }
  .kd-demo-nav nav a { font-size: 13px; }
  .kd-demo main, .kd-demo-footer { width: min(100% - 24px, 1180px); }
  .kd-demo-hero { min-height: auto; padding: 42px 0 54px; gap: 30px; }
  .kd-demo-hero h1 { font-size: clamp(38px, 14vw, 58px); }
  .kd-demo-hero__chips { gap: 10px; }
  .kd-demo-hero__chips span { width: 100%; justify-content: space-between; }
  .kd-demo-device { min-height: auto; }
  .kd-demo-visual { min-height: 220px; }
  .kd-demo-device__cards { grid-template-columns: 1fr; }
  .kd-demo-stats { grid-template-columns: 1fr; margin-top: 0; margin-bottom: 42px; }
  .kd-demo-section, .kd-demo-split { padding: 64px 0; }
  .kd-demo-section__head h2,
  .kd-demo-split h2,
  .kd-demo-contact h2,
  .kd-demo-showcase__head h2,
  .kd-demo-live__copy h2 { font-size: clamp(30px, 10vw, 42px); }
  .kd-demo-split__visual { grid-template-columns: 1fr 1fr; }
  .kd-demo-showcase,
  .kd-demo-live { padding: 64px 0; }
  .kd-demo-showcase__head p,
  .kd-demo-live__copy p { font-size: 16px; }
  .kd-demo-collection,
  .kd-demo-collection--hair-lookbook,
  .kd-demo-collection--shop-catalog,
  .kd-demo-auto-board__track,
  .kd-demo-team-grid,
  .kd-demo-live-cards,
  .kd-demo-live--shop-cart .kd-demo-live-cards,
  .kd-demo-booking-steps,
  .kd-demo-triage { grid-template-columns: 1fr; }
  .kd-demo-collection article,
  .kd-demo-team-grid article,
  .kd-demo-live-cards article { min-height: auto; }
  .kd-demo-auto-board__track article { min-height: auto; }
  .kd-demo-auto-board__track h3 { margin-top: 32px; }
  .kd-demo-medical-flow article { grid-template-columns: 1fr; }
  .kd-demo-live__surface { padding: 16px; border-radius: 24px; }
  .kd-demo-live__rows div { align-items: flex-start; flex-direction: column; }
  .kd-demo-live__rows strong { text-align: left; }
  .kd-demo-contact { padding: 26px; }
  .kd-demo-footer { flex-direction: column; }
}
@media (max-width: 480px) {
  .kd-footer__grid { grid-template-columns: 1fr; }
  .kd-footer__bottom { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   Demo SVG icons + per-branch animations & decorations
   ============================================================ */

.kd-demo-ico {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  margin-bottom: 18px;
  border-radius: 14px;
  background: color-mix(in srgb, var(--demo-accent) 14%, #fff);
  color: var(--demo-accent);
  box-shadow: 0 12px 28px -20px color-mix(in srgb, var(--demo-accent) 80%, #000);
  transition: transform .35s cubic-bezier(.2,.8,.2,1.2), box-shadow .3s ease, background .3s ease;
}
.kd-demo-ico svg { width: 26px; height: 26px; }

/* Auto-board dark cards: icon glows orange on dark navy */
.kd-demo-auto-board__track .kd-demo-ico {
  background: rgba(234,88,12,.18);
  color: #fdba74;
  box-shadow: 0 12px 28px -16px rgba(234,88,12,.6);
}
.kd-demo-auto-board__track h3 { margin-top: 18px; }

/* Barber dark cards: teal accent icon */
.kd-demo-collection--barber-lineup .kd-demo-ico,
.kd-demo-live--barber-slots .kd-demo-live-cards .kd-demo-ico {
  background: rgba(94,234,212,.16);
  color: #5eead4;
  box-shadow: 0 12px 28px -16px rgba(20,184,166,.55);
}

/* Vet team grid: replace letter circle with SVG circle */
.kd-demo-team-grid article > div .kd-demo-ico {
  width: 100%;
  height: 100%;
  margin: 0;
  background: transparent;
  box-shadow: none;
}
.kd-demo-team-grid article > div .kd-demo-ico svg { width: 38px; height: 38px; }

/* Medical flow: bigger badge icon */
.kd-demo-medical-flow article > span .kd-demo-ico {
  width: 100%; height: 100%; margin: 0;
  background: transparent; box-shadow: none;
  color: #1d4ed8;
}
.kd-demo-medical-flow article > span { padding: 0; }
.kd-demo-medical-flow article > span .kd-demo-ico svg { width: 28px; height: 28px; }

/* Services cards: smaller inline icon */
.kd-demo-services article .kd-demo-ico {
  width: 42px; height: 42px; margin-bottom: 10px;
}
.kd-demo-services article .kd-demo-ico svg { width: 22px; height: 22px; }

/* ----- Universal hover lift on demo cards ----- */
.kd-demo-services article,
.kd-demo-collection article,
.kd-demo-team-grid article,
.kd-demo-live-cards article,
.kd-demo-medical-flow article {
  transition: transform .45s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease, border-color .3s ease;
}
.kd-demo-services article:hover,
.kd-demo-collection article:hover,
.kd-demo-team-grid article:hover,
.kd-demo-live-cards article:hover,
.kd-demo-medical-flow article:hover {
  transform: translateY(-6px);
  box-shadow: 0 30px 70px -38px color-mix(in srgb, var(--demo-accent) 70%, #0f172a);
  border-color: color-mix(in srgb, var(--demo-accent) 40%, transparent);
}
.kd-demo-services article:hover .kd-demo-ico,
.kd-demo-collection article:hover .kd-demo-ico,
.kd-demo-live-cards article:hover .kd-demo-ico {
  transform: scale(1.1) rotate(-4deg);
}

/* ----- Buttons: subtle shimmer on primary CTA ----- */
.kd-demo-btn--primary {
  position: relative;
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease, filter .25s ease;
}
.kd-demo-btn--primary::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.45) 50%, transparent 70%);
  transform: translateX(-120%);
  transition: transform .8s ease;
}
.kd-demo-btn--primary:hover { transform: translateY(-2px); box-shadow: 0 22px 40px -22px var(--demo-accent); }
.kd-demo-btn--primary:hover::after { transform: translateX(120%); }

/* ----- Gradient sweep on H2s in dem section ----- */
.kd-demo-showcase__head h2,
.kd-demo-live__copy h2,
.kd-demo-section__head h2 {
  background: linear-gradient(92deg, currentColor 0%, currentColor 60%, color-mix(in srgb, var(--demo-accent) 90%, currentColor) 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

/* ----- Animated decorative blobs in .kd-demo-texture ----- */
@keyframes kd-float {
  0%,100% { transform: translateY(0) translateX(0); }
  50% { transform: translateY(-18px) translateX(8px); }
}
@keyframes kd-float-2 {
  0%,100% { transform: translateY(0) translateX(0); }
  50% { transform: translateY(14px) translateX(-12px); }
}
@keyframes kd-spin {
  to { transform: rotate(360deg); }
}
@keyframes kd-pulse-ring {
  0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--demo-accent) 65%, transparent); }
  70% { box-shadow: 0 0 0 22px transparent; }
  100% { box-shadow: 0 0 0 0 transparent; }
}
@keyframes kd-pulse-soft {
  0%,100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.08); opacity: .85; }
}
@keyframes kd-shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
@keyframes kd-marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
@keyframes kd-draw {
  to { stroke-dashoffset: 0; }
}
@keyframes kd-twinkle {
  0%,100% { opacity: .25; transform: scale(.6); }
  50% { opacity: 1; transform: scale(1); }
}

.kd-demo-texture span {
  animation: kd-float 9s ease-in-out infinite;
}
.kd-demo-texture span:nth-child(2) { animation: kd-float-2 11s ease-in-out infinite; }
.kd-demo-texture span:nth-child(3) { animation: kd-twinkle 3.4s ease-in-out infinite; }
.kd-demo-texture span:nth-child(4) { animation: kd-twinkle 4.6s ease-in-out infinite .8s; }

/* ----- Beauty: sparkles + glow ----- */
.kd-demo--beauty .kd-demo-ico { animation: kd-pulse-soft 4s ease-in-out infinite; }
.kd-demo--beauty .kd-demo-hero::before,
.kd-demo--beauty .kd-demo-hero::after {
  content: "";
  position: absolute;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: radial-gradient(circle, #fff 0%, rgba(251,207,232,.0) 60%);
  box-shadow:
    0 0 16px 4px rgba(251,207,232,.8),
    0 0 0 2px rgba(255,255,255,.6) inset;
  animation: kd-twinkle 2.6s ease-in-out infinite;
  pointer-events: none;
}
.kd-demo--beauty .kd-demo-hero { position: relative; }
.kd-demo--beauty .kd-demo-hero::before { top: 14%; right: 28%; animation-delay: .2s; }
.kd-demo--beauty .kd-demo-hero::after { top: 56%; right: 8%; animation-delay: 1.4s; transform: scale(1.4); }
.kd-demo--beauty .kd-demo-collection article:hover .kd-demo-ico {
  animation: kd-spin 1.6s linear infinite;
}

/* ----- Auto: spinning gauge dial + brushed steel hover ----- */
.kd-demo-gauge {
  position: relative;
  margin-top: 22px;
  width: 100%;
  height: 96px;
  border-radius: 18px;
  background:
    conic-gradient(from 200deg at 50% 100%, #16a34a 0deg, #eab308 60deg, #ea580c 110deg, #dc2626 160deg, transparent 180deg),
    color-mix(in srgb, var(--demo-accent) 10%, #fff);
  overflow: hidden;
}
.kd-demo-gauge span {
  position: absolute;
  inset: 14px 14px 0;
  border-radius: 14px 14px 0 0;
  background: color-mix(in srgb, var(--demo-accent) 12%, #fff);
}
.kd-demo-gauge b {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 3px; height: 78px;
  background: #0f172a;
  border-radius: 3px;
  transform-origin: bottom center;
  transform: translateX(-50%) rotate(-60deg);
  animation: kd-gauge-needle 3.6s cubic-bezier(.6,.05,.4,1) infinite alternate;
}
@keyframes kd-gauge-needle {
  0% { transform: translateX(-50%) rotate(-72deg); }
  100% { transform: translateX(-50%) rotate(72deg); }
}
.kd-demo--auto .kd-demo-auto-board__track .kd-demo-ico { animation: kd-pulse-ring 2.8s ease-out infinite; }
.kd-demo--auto .kd-demo-services article:hover .kd-demo-ico {
  animation: kd-spin 2s linear infinite;
}

.kd-demo--auto .kd-demo-section#oferta {
  position: relative;
  margin-top: 24px;
  padding: 56px 34px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 82% 18%, rgba(251,146,60,.16), transparent 24%),
    linear-gradient(180deg, rgba(2,6,23,.97) 0%, rgba(15,23,42,.95) 100%);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 36px 90px -56px rgba(2,6,23,.98);
  overflow: hidden;
}
.kd-demo--auto .kd-demo-section#oferta::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 110px 110px;
  mask-image: linear-gradient(180deg, rgba(255,255,255,.5), transparent 82%);
  pointer-events: none;
}
.kd-demo--auto .kd-demo-section#oferta::after {
  content: "";
  position: absolute;
  left: 34px;
  right: 34px;
  top: 0;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #fb923c, rgba(251,146,60,0));
  pointer-events: none;
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-section__head,
.kd-demo--auto .kd-demo-section#oferta .kd-demo-services,
.kd-demo--auto .kd-demo-section#oferta .kd-demo-service-card__top,
.kd-demo--auto .kd-demo-section#oferta .kd-demo-services h3,
.kd-demo--auto .kd-demo-section#oferta .kd-demo-services p {
  position: relative;
  z-index: 1;
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-kicker {
  color: #fdba74;
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-section__head h2 {
  color: #f8fafc;
  background: none;
  text-shadow: 0 12px 34px rgba(234,88,12,.18);
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-services article {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.02) 100%),
    linear-gradient(180deg, rgba(15,23,42,.94) 0%, rgba(17,24,39,.9) 100%);
  color: #f8fafc;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 30px 70px -44px rgba(0,0,0,.92);
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-services article::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(251,146,60,.16), transparent 38%);
  opacity: .85;
  pointer-events: none;
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-services article::after {
  content: "";
  position: absolute;
  left: 26px;
  right: 26px;
  top: 72px;
  height: 1px;
  background: linear-gradient(90deg, rgba(251,146,60,.45), transparent);
  pointer-events: none;
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-services article:nth-child(2) {
  background:
    linear-gradient(180deg, rgba(251,146,60,.18) 0%, rgba(255,255,255,.04) 100%),
    linear-gradient(180deg, #1f2937 0%, #111827 100%);
  border-color: rgba(251,146,60,.28);
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-services article .kd-demo-ico {
  background: rgba(251,146,60,.16);
  color: #fdba74;
  box-shadow: 0 16px 34px -18px rgba(234,88,12,.62);
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-service-card__top span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(251,146,60,.14);
  color: #fdba74;
  border: 1px solid rgba(251,146,60,.18);
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-service-card__top b {
  color: rgba(248,250,252,.14);
  font-size: 34px;
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-services h3 {
  color: #fff7ed;
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-services p {
  color: rgba(248,250,252,.78);
}
.kd-demo--auto .kd-demo-section#oferta .kd-demo-services article:hover {
  border-color: rgba(251,146,60,.34);
  box-shadow: 0 34px 82px -42px rgba(0,0,0,.92);
}

.kd-demo--barber .kd-demo-section#oferta {
  position: relative;
  margin-top: 24px;
  padding: 56px 34px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 82% 16%, rgba(94,234,212,.14), transparent 24%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.03) 0 12px, transparent 12px 28px),
    linear-gradient(180deg, rgba(5,5,5,.98) 0%, rgba(17,24,39,.96) 100%);
  border: 1px solid rgba(94,234,212,.12);
  box-shadow: 0 36px 90px -56px rgba(0,0,0,.96);
  overflow: hidden;
}
.kd-demo--barber .kd-demo-section#oferta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 18% 82%, rgba(255,255,255,.04), transparent 30%);
  pointer-events: none;
}
.kd-demo--barber .kd-demo-section#oferta::after {
  content: "";
  position: absolute;
  left: 34px;
  right: 34px;
  top: 0;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #5eead4, rgba(94,234,212,0));
  pointer-events: none;
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-section__head,
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services,
.kd-demo--barber .kd-demo-section#oferta .kd-demo-service-card__top,
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services h3,
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services p {
  position: relative;
  z-index: 1;
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-section__head {
  padding-left: 18px;
  border-left: 3px solid rgba(94,234,212,.34);
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-kicker {
  color: #5eead4;
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-section__head h2 {
  color: #f8fafc;
  background: none;
  text-shadow: 0 12px 34px rgba(20,184,166,.18);
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services article {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  padding: 28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(245,245,244,.98) 100%),
    linear-gradient(140deg, rgba(20,184,166,.06), rgba(255,255,255,0) 40%);
  border: 1px solid rgba(94,234,212,.14);
  box-shadow: 0 26px 60px -42px rgba(0,0,0,.82);
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services article::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 86% 12%, rgba(94,234,212,.18), transparent 36%),
    linear-gradient(145deg, rgba(20,184,166,.06), transparent 44%);
  pointer-events: none;
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services article::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, #5eead4, rgba(20,184,166,.18));
  pointer-events: none;
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services article:nth-child(2) {
  transform: translateY(18px);
  background:
    linear-gradient(180deg, rgba(250,250,249,.96) 0%, rgba(241,245,249,.98) 100%),
    linear-gradient(140deg, rgba(20,184,166,.08), rgba(255,255,255,0) 40%);
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services article:nth-child(3) {
  background:
    linear-gradient(180deg, rgba(247,255,253,.98) 0%, rgba(236,253,250,.98) 100%),
    linear-gradient(140deg, rgba(20,184,166,.12), rgba(255,255,255,0) 42%);
  border-color: rgba(20,184,166,.26);
  box-shadow: 0 30px 72px -42px rgba(20,184,166,.28);
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services article .kd-demo-ico {
  background: #111827;
  color: #5eead4;
  box-shadow: 0 18px 36px -20px rgba(20,184,166,.44);
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-service-card__top span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: #111827;
  color: #14b8a6;
  border: 1px solid rgba(20,184,166,.18);
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-service-card__top b {
  color: rgba(15,23,42,.12);
  font-size: 34px;
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services h3 {
  color: #0f172a;
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services p {
  color: #475569;
}
.kd-demo--barber .kd-demo-section#oferta .kd-demo-services article:hover {
  border-color: rgba(20,184,166,.28);
  box-shadow: 0 30px 76px -42px rgba(20,184,166,.24);
}

.kd-demo-showcase--auto-diagnostic,
.kd-demo-live--auto-intake {
  position: relative;
  padding: 58px 34px;
  border-radius: 34px;
  overflow: hidden;
}
.kd-demo-showcase--auto-diagnostic {
  color: #f8fafc;
  background:
    radial-gradient(circle at 82% 18%, rgba(251,146,60,.16), transparent 24%),
    linear-gradient(180deg, #060b14 0%, #0f172a 100%);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 38px 90px -56px rgba(2,6,23,.98);
}
.kd-demo-live--auto-intake {
  color: #f8fafc;
  border-top: 0;
  background:
    radial-gradient(circle at 14% 18%, rgba(251,146,60,.12), transparent 24%),
    linear-gradient(180deg, #070b12 0%, #0a1120 100%);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 38px 90px -56px rgba(2,6,23,.98);
}
.kd-demo-showcase--auto-diagnostic::before,
.kd-demo-live--auto-intake::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 110px 110px;
  mask-image: linear-gradient(180deg, rgba(255,255,255,.5), transparent 86%);
  pointer-events: none;
}
.kd-demo-showcase--auto-diagnostic::after,
.kd-demo-live--auto-intake::after {
  content: "";
  position: absolute;
  left: 34px;
  right: 34px;
  top: 0;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #fb923c, rgba(251,146,60,0));
  pointer-events: none;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-showcase__head,
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board,
.kd-demo-live--auto-intake .kd-demo-live__copy,
.kd-demo-live--auto-intake .kd-demo-live__surface {
  position: relative;
  z-index: 1;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-showcase__head,
.kd-demo-live--auto-intake .kd-demo-live__copy {
  padding-left: 18px;
  border-left: 3px solid rgba(251,146,60,.42);
}
.kd-demo-showcase--auto-diagnostic .kd-demo-kicker,
.kd-demo-live--auto-intake .kd-demo-kicker {
  color: #fdba74;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-showcase__head h2,
.kd-demo-live--auto-intake .kd-demo-live__copy h2 {
  color: #f8fafc;
  background: none;
  text-shadow: 0 12px 34px rgba(234,88,12,.18);
}
.kd-demo-showcase--auto-diagnostic .kd-demo-showcase__head p,
.kd-demo-live--auto-intake .kd-demo-live__copy p {
  color: rgba(248,250,252,.76);
}

.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board {
  gap: 24px;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track {
  padding: 18px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(2,6,23,.82), rgba(15,23,42,.68));
  border-color: rgba(251,146,60,.18);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02);
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track article {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02)),
    linear-gradient(180deg, rgba(15,23,42,.96) 0%, rgba(17,24,39,.92) 100%);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 24px 54px -38px rgba(0,0,0,.9);
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track article::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(145deg, rgba(251,146,60,.15), transparent 40%);
  opacity: .88;
  pointer-events: none;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track article::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 82px;
  height: 1px;
  background: linear-gradient(90deg, rgba(251,146,60,.42), transparent);
  pointer-events: none;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track article:nth-child(2),
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track article:nth-child(4) {
  transform: translateY(18px);
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track .kd-demo-ico {
  background: rgba(251,146,60,.16);
  color: #fdba74;
  box-shadow: 0 16px 34px -18px rgba(234,88,12,.62);
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track span {
  color: #fb923c;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track h3 {
  color: #fff7ed;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track b {
  display: inline-flex;
  margin-top: 14px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(251,146,60,.12);
  border: 1px solid rgba(251,146,60,.18);
  color: #fdba74;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track p {
  color: rgba(248,250,252,.82);
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__panel {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)),
    linear-gradient(180deg, rgba(30,41,59,.98) 0%, rgba(15,23,42,.96) 100%);
  color: #f8fafc;
  border-color: rgba(251,146,60,.22);
  box-shadow: 0 30px 70px -40px rgba(0,0,0,.95);
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__panel::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 92px;
  background: radial-gradient(circle at 20% 0, rgba(251,146,60,.24), transparent 48%);
  pointer-events: none;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__panel > strong {
  position: relative;
  color: #fff7ed;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__panel .kd-demo-live__rows div {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__panel .kd-demo-live__rows span {
  color: rgba(248,250,252,.62);
}
.kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__panel .kd-demo-live__rows strong {
  color: #fff;
}
.kd-demo-showcase--auto-diagnostic .kd-demo-gauge {
  background:
    conic-gradient(from 200deg at 50% 100%, #16a34a 0deg, #eab308 60deg, #ea580c 110deg, #dc2626 160deg, transparent 180deg),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)),
    #111827;
  border: 1px solid rgba(251,146,60,.18);
}

.kd-demo-live--auto-intake .kd-demo-live__surface {
  overflow: hidden;
  padding: 30px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)),
    linear-gradient(180deg, rgba(15,23,42,.98) 0%, rgba(2,6,23,.96) 100%);
  border-color: rgba(251,146,60,.18);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02), 0 30px 80px -48px rgba(0,0,0,.96);
}
.kd-demo-live--auto-intake .kd-demo-live__surface::before {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 16px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(251,146,60,0) 0%, #fb923c 30%, rgba(251,146,60,0) 60%);
  background-size: 220% 100%;
  background-position: -120% 0;
  animation: kd-shimmer 6s linear infinite;
  pointer-events: none;
}
.kd-demo-live--auto-intake .kd-demo-live__surface::after {
  content: "";
  position: absolute;
  right: 18px;
  top: 28px;
  width: 74px;
  height: 10px;
  border-radius: 999px;
  background: repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0 12px, transparent 12px 22px);
  opacity: .75;
  pointer-events: none;
}
.kd-demo-live--auto-intake .kd-demo-form-preview {
  position: relative;
  z-index: 1;
  grid-template-columns: 1.2fr .9fr .9fr;
  gap: 14px;
  margin: 22px 0 18px;
}
.kd-demo-live--auto-intake .kd-demo-form-preview label {
  position: relative;
  overflow: hidden;
  min-height: 100px;
  padding: 20px 18px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 24px 50px -42px rgba(0,0,0,.88);
}
.kd-demo-live--auto-intake .kd-demo-form-preview label::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, #fb923c, rgba(251,146,60,0));
}
.kd-demo-live--auto-intake .kd-demo-form-preview label::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 88% 12%, rgba(251,146,60,.16), transparent 34%);
  pointer-events: none;
}
.kd-demo-live--auto-intake .kd-demo-form-preview label:nth-child(2) {
  transform: translateY(16px);
}
.kd-demo-live--auto-intake .kd-demo-form-preview label:nth-child(3) {
  transform: translateY(32px);
}
.kd-demo-live--auto-intake .kd-demo-form-preview span {
  color: rgba(248,250,252,.52);
  letter-spacing: .12em;
}
.kd-demo-live--auto-intake .kd-demo-form-preview strong {
  color: #fff7ed;
  font: 900 24px/1.15 var(--kd-font-display);
}
.kd-demo-live--auto-intake .kd-demo-live__rows {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.kd-demo-live--auto-intake .kd-demo-live__rows div {
  align-items: flex-start;
  flex-direction: column;
  gap: 8px;
  min-height: 88px;
  padding: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.08);
}
.kd-demo-live--auto-intake .kd-demo-live__rows div::before {
  top: 0;
  left: 0;
  bottom: auto;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, #fb923c, transparent);
  opacity: 1;
}
.kd-demo-live--auto-intake .kd-demo-live__rows div::after {
  background: linear-gradient(110deg, transparent 40%, rgba(251,146,60,.16) 50%, transparent 60%);
}
.kd-demo-live--auto-intake .kd-demo-live__rows span {
  color: rgba(248,250,252,.56);
  letter-spacing: .12em;
  text-transform: uppercase;
}
.kd-demo-live--auto-intake .kd-demo-live__rows strong {
  color: #fff7ed;
  text-align: left;
  font: 900 22px/1.1 var(--kd-font-display);
}

@media (max-width: 1024px) {
  .kd-demo--barber .kd-demo-section#oferta .kd-demo-services article:nth-child(2) {
    transform: none;
  }
  .kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track article:nth-child(2),
  .kd-demo-showcase--auto-diagnostic .kd-demo-auto-board__track article:nth-child(4),
  .kd-demo-live--auto-intake .kd-demo-form-preview label:nth-child(2),
  .kd-demo-live--auto-intake .kd-demo-form-preview label:nth-child(3) {
    transform: none;
  }
  .kd-demo--vet .kd-demo-team-grid article:nth-child(2),
  .kd-demo--vet .kd-demo-team-grid article:nth-child(3),
  .kd-demo--medical .kd-demo-medical-flow article:nth-child(2),
  .kd-demo--medical .kd-demo-medical-flow article:nth-child(3) {
    transform: none;
    margin-left: 0;
  }
  .kd-demo--vet .kd-demo-showcase__note,
  .kd-demo--medical .kd-demo-live--medical-prep .kd-demo-live__rows {
    grid-template-columns: 1fr;
  }
  .kd-demo--vet .kd-demo-showcase__note .kd-demo-live__rows,
  .kd-demo--medical .kd-demo-checklist-widget {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .kd-demo--barber .kd-demo-section#oferta {
    padding: 34px 18px;
    border-radius: 24px;
  }
  .kd-demo--barber .kd-demo-section#oferta::after {
    left: 18px;
    right: 18px;
  }
  .kd-demo--barber .kd-demo-section#oferta .kd-demo-section__head {
    padding-left: 14px;
  }
  .kd-demo-showcase--auto-diagnostic,
  .kd-demo-live--auto-intake {
    padding: 34px 18px;
    border-radius: 24px;
  }
  .kd-demo-showcase--auto-diagnostic::after,
  .kd-demo-live--auto-intake::after {
    left: 18px;
    right: 18px;
  }
  .kd-demo-showcase--auto-diagnostic .kd-demo-showcase__head,
  .kd-demo-live--auto-intake .kd-demo-live__copy {
    padding-left: 14px;
  }
  .kd-demo-live--auto-intake .kd-demo-form-preview,
  .kd-demo-live--auto-intake .kd-demo-live__rows {
    grid-template-columns: 1fr;
  }
  .kd-demo--vet .kd-demo-showcase__note,
  .kd-demo--medical .kd-demo-medical-flow aside {
    padding: 18px;
    border-radius: 22px;
  }
  .kd-demo--vet .kd-demo-showcase__note,
  .kd-demo--vet .kd-demo-showcase__note .kd-demo-live__rows,
  .kd-demo--medical .kd-demo-checklist-widget,
  .kd-demo--medical .kd-demo-live--medical-prep .kd-demo-live__rows {
    grid-template-columns: 1fr;
  }
  .kd-demo--medical .kd-demo-medical-flow > div {
    padding-left: 0;
  }
  .kd-demo--medical .kd-demo-medical-flow > div::before {
    display: none;
  }
}

/* ----- Vet: bouncing paw icons + soft heart pulse ----- */
.kd-demo--vet .kd-demo-team-grid article > div {
  animation: kd-pulse-soft 3.2s ease-in-out infinite;
}
.kd-demo--vet .kd-demo-team-grid article {
  position: relative;
  overflow: hidden;
  border-radius: 36px 36px 26px 26px;
  background: linear-gradient(180deg, #ffffff 0%, #ecfdf5 100%);
  border-color: rgba(5,150,105,.12);
}
.kd-demo--vet .kd-demo-team-grid article:nth-child(2) {
  transform: translateY(20px);
}
.kd-demo--vet .kd-demo-team-grid article:nth-child(3) {
  transform: translateY(8px);
}
.kd-demo--vet .kd-demo-team-grid article::after {
  content: "";
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 18px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(5,150,105,.54), rgba(16,185,129,.16));
}
.kd-demo--vet .kd-demo-showcase__note {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: 18px;
  align-items: start;
  background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(236,253,245,.92) 100%);
  border-color: rgba(5,150,105,.14);
  box-shadow: 0 26px 60px -48px rgba(5,150,105,.38);
}
.kd-demo--vet .kd-demo-showcase__note > strong {
  margin-bottom: 0;
}
.kd-demo--vet .kd-demo-showcase__note .kd-demo-live__rows {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.kd-demo--vet .kd-demo-showcase__note .kd-demo-live__rows div {
  min-height: 92px;
  display: grid;
  align-items: start;
  justify-content: flex-start;
  gap: 8px;
  padding: 16px;
  background: rgba(255,255,255,.76);
  border: 1px solid rgba(5,150,105,.12);
}
.kd-demo--vet .kd-demo-showcase__note .kd-demo-live__rows strong {
  text-align: left;
}
.kd-demo--vet .kd-demo-team-grid article:nth-child(2) > div { animation-delay: .4s; }
.kd-demo--vet .kd-demo-team-grid article:nth-child(3) > div { animation-delay: .8s; }
.kd-demo--vet .kd-demo-triage__card--urgent::after {
  content: "";
  position: absolute;
  top: 14px; right: 14px;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: #ef4444;
  animation: kd-pulse-ring 1.8s ease-out infinite;
}
.kd-demo--vet .kd-demo-triage__card {
  position: relative;
  min-height: 214px;
  overflow: hidden;
  box-shadow: 0 24px 54px -44px rgba(5,150,105,.38);
}
.kd-demo--vet .kd-demo-triage__card::before {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 16px;
  height: 4px;
  border-radius: 999px;
  background: rgba(5,150,105,.18);
}
.kd-demo--vet .kd-demo-triage__card--urgent::before {
  background: rgba(225,29,72,.22);
}
.kd-demo--vet .kd-demo-live--vet-triage .kd-demo-live__surface {
  background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(236,253,245,.94) 100%);
  border-color: rgba(5,150,105,.12);
}

/* ----- Medical: ECG line draw animation ----- */
.kd-demo-ecg {
  display: block;
  width: 100%;
  height: 56px;
  margin-top: 18px;
  color: #2563eb;
}
.kd-demo-ecg path {
  fill: none;
  stroke: currentColor;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 600;
  stroke-dashoffset: 600;
  animation: kd-draw 2.8s cubic-bezier(.4,.0,.2,1) infinite;
  filter: drop-shadow(0 4px 10px rgba(37,99,235,.35));
}
.kd-demo--medical .kd-demo-medical-flow article > span {
  position: relative;
  overflow: hidden;
}
.kd-demo--medical .kd-demo-medical-flow > div {
  position: relative;
  padding-left: 20px;
}
.kd-demo--medical .kd-demo-medical-flow > div::before {
  content: "";
  position: absolute;
  left: 6px;
  top: 18px;
  bottom: 18px;
  width: 2px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(37,99,235,.24), rgba(37,99,235,.04));
}
.kd-demo--medical .kd-demo-medical-flow article {
  position: relative;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(239,246,255,.9) 100%);
}
.kd-demo--medical .kd-demo-medical-flow article:nth-child(2) {
  margin-left: 22px;
}
.kd-demo--medical .kd-demo-medical-flow article:nth-child(3) {
  margin-left: 44px;
}
.kd-demo--medical .kd-demo-medical-flow aside {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(219,234,254,.9) 100%);
  box-shadow: 0 30px 64px -48px rgba(37,99,235,.34);
}
.kd-demo--medical .kd-demo-medical-flow aside::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 84% 14%, rgba(37,99,235,.12), transparent 26%),
    linear-gradient(90deg, rgba(37,99,235,.05) 1px, transparent 1px),
    linear-gradient(rgba(37,99,235,.05) 1px, transparent 1px);
  background-size: auto, 28px 28px, 28px 28px;
  pointer-events: none;
}
.kd-demo--medical .kd-demo-medical-flow aside > span,
.kd-demo--medical .kd-demo-medical-flow aside .kd-demo-live__rows,
.kd-demo--medical .kd-demo-medical-flow aside .kd-demo-ecg,
.kd-demo--medical .kd-demo-medical-flow aside .kd-demo-photo {
  position: relative;
  z-index: 1;
}
.kd-demo--medical .kd-demo-medical-flow aside .kd-demo-live__rows div {
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(37,99,235,.12);
}
.kd-demo--medical .kd-demo-medical-flow article > span::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle, rgba(37,99,235,.25), transparent 70%);
  animation: kd-pulse-soft 2.4s ease-in-out infinite;
}
.kd-demo--medical .kd-demo-medical-flow article > span .kd-demo-ico { position: relative; z-index: 1; }
.kd-demo--medical .kd-demo-live--medical-prep .kd-demo-live__surface {
  background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(239,246,255,.92) 100%);
  border-color: rgba(37,99,235,.12);
}
.kd-demo--medical .kd-demo-checklist-widget {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}
.kd-demo--medical .kd-demo-checklist-widget li {
  padding: 16px 16px 16px 24px;
  border-radius: 18px;
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(37,99,235,.12);
}
.kd-demo--medical .kd-demo-live--medical-prep .kd-demo-live__rows {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.kd-demo--medical .kd-demo-live--medical-prep .kd-demo-live__rows div {
  min-height: 92px;
  display: grid;
  align-items: start;
  justify-content: flex-start;
  gap: 8px;
  padding: 16px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(37,99,235,.12);
}
.kd-demo--medical .kd-demo-live--medical-prep .kd-demo-live__rows strong {
  text-align: left;
}

/* ----- Hair: scissors gentle rock + gradient sweep on cards ----- */
@keyframes kd-rock {
  0%,100% { transform: rotate(-6deg); }
  50% { transform: rotate(6deg); }
}
.kd-demo--hair .kd-demo-collection--hair-lookbook article .kd-demo-ico {
  animation: kd-rock 3.2s ease-in-out infinite;
  transform-origin: 50% 60%;
}
.kd-demo--hair .kd-demo-collection--hair-lookbook article::after,
.kd-demo--hair .kd-demo-live--hair-stylists .kd-demo-live-cards article::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 35%, rgba(196,181,253,.45) 50%, transparent 65%);
  background-size: 220% 100%;
  background-position: -120% 0;
  animation: kd-shimmer 6s linear infinite;
  pointer-events: none;
}
.kd-demo--hair .kd-demo-live--hair-stylists .kd-demo-live-cards article { position: relative; overflow: hidden; }

/* ----- Barber: neon flicker + horizontal price marquee strip ----- */
@keyframes kd-flicker {
  0%, 18%, 22%, 28%, 100% { opacity: 1; filter: drop-shadow(0 0 6px #5eead4); }
  20%, 24% { opacity: .55; filter: drop-shadow(0 0 14px #14b8a6); }
}
.kd-demo--barber .kd-demo-collection--barber-lineup article .kd-demo-ico { animation: kd-flicker 4s infinite; }
.kd-demo--barber .kd-demo-hero::before {
  content: "STRAIGHT BLADE · HOT TOWEL · COMBO CUT · SHARP FADE · BEARD TRIM · ";
  position: absolute;
  bottom: 22px;
  left: 0;
  right: 0;
  white-space: nowrap;
  overflow: hidden;
  font: 900 14px/1 var(--kd-font-display);
  letter-spacing: .26em;
  color: rgba(94,234,212,.42);
  padding: 12px 0;
  border-top: 1px solid rgba(94,234,212,.14);
  border-bottom: 1px solid rgba(94,234,212,.14);
  background: linear-gradient(90deg, transparent, rgba(20,184,166,.06), transparent);
  pointer-events: none;
}
.kd-demo--barber .kd-demo-hero { position: relative; }
.kd-demo--barber .kd-demo-stats div {
  border-top: 3px solid #14b8a6;
}

/* ----- Shop: NEW pulse badge + bag bounce ----- */
@keyframes kd-bounce {
  0%,100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}
.kd-demo--shop .kd-demo-collection--shop-catalog article .kd-demo-ico {
  animation: kd-bounce 2.4s ease-in-out infinite;
}
.kd-demo--shop .kd-demo-live--shop-cart .kd-demo-live-cards article .kd-demo-ico {
  animation: kd-bounce 2.6s ease-in-out infinite;
}
.kd-demo--shop .kd-demo-collection--shop-catalog article:nth-child(1)::after,
.kd-demo--shop .kd-demo-live--shop-cart .kd-demo-live-cards article:nth-child(1)::after {
  content: "NEW";
  position: absolute;
  top: 14px; right: 14px;
  z-index: 2;
  padding: 6px 12px;
  border-radius: 999px;
  background: #ca8a04;
  color: #fff;
  font: 900 11px/1 var(--kd-font-display);
  letter-spacing: .14em;
  box-shadow: 0 0 0 0 rgba(202,138,4,.6);
  animation: kd-pulse-ring 2s ease-out infinite;
}

/* ----- Live booking rows: per-row left accent bar shine ----- */
.kd-demo-live__rows div {
  position: relative;
  overflow: hidden;
}
.kd-demo-live__rows div::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--demo-accent);
  opacity: .75;
}
.kd-demo-live__rows div::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 40%, rgba(255,255,255,.4) 50%, transparent 60%);
  background-size: 220% 100%;
  background-position: -120% 0;
  animation: kd-shimmer 5s linear infinite;
  pointer-events: none;
}
.kd-demo-live--barber-slots .kd-demo-live__rows div::after {
  background: linear-gradient(110deg, transparent 40%, rgba(94,234,212,.18) 50%, transparent 60%);
}

/* ----- Booking step circles: pulse on the first step ----- */
.kd-demo-booking-steps span:first-child b {
  animation: kd-pulse-ring 2.4s ease-out infinite;
}

/* ----- Hero panel device screen number subtle glow ----- */
.kd-demo-panel__screen strong {
  text-shadow: 0 8px 24px color-mix(in srgb, var(--demo-accent) 40%, transparent);
}

/* ----- Stats numbers: counter underline appear ----- */
.kd-demo-stats div {
  position: relative;
  overflow: hidden;
}
.kd-demo-stats div::after {
  content: "";
  position: absolute;
  left: 22px; bottom: 12px;
  width: 32px; height: 3px;
  border-radius: 3px;
  background: var(--demo-accent);
  transform-origin: left center;
  animation: kd-pulse-soft 3s ease-in-out infinite;
}

/* Reduced motion: kill all of it */
@media (prefers-reduced-motion: reduce) {
  .kd-demo-ico,
  .kd-demo-texture span,
  .kd-demo-gauge b,
  .kd-demo-ecg path,
  .kd-demo--beauty .kd-demo-hero::before,
  .kd-demo--beauty .kd-demo-hero::after,
  .kd-demo--vet .kd-demo-team-grid article > div,
  .kd-demo--vet .kd-demo-triage__card--urgent::after,
  .kd-demo--hair .kd-demo-collection--hair-lookbook article .kd-demo-ico,
  .kd-demo--hair .kd-demo-collection--hair-lookbook article::after,
  .kd-demo--barber .kd-demo-collection--barber-lineup article .kd-demo-ico,
  .kd-demo--shop .kd-demo-collection--shop-catalog article .kd-demo-ico,
  .kd-demo--shop .kd-demo-live--shop-cart .kd-demo-live-cards article .kd-demo-ico,
  .kd-demo--shop .kd-demo-collection--shop-catalog article:nth-child(1)::after,
  .kd-demo-live__rows div::after,
  .kd-demo-stats div::after,
  .kd-demo-btn--primary::after,
  .kd-demo-booking-steps span:first-child b,
  .kd-demo-live--auto-intake .kd-demo-live__surface::before {
    animation: none !important;
  }
}

@media (max-width: 720px) {
  .kd-demo--auto .kd-demo-section#oferta {
    padding: 34px 18px;
    border-radius: 24px;
  }
  .kd-demo--auto .kd-demo-section#oferta::after {
    left: 18px;
    right: 18px;
  }
}
