/* ============================================================
   Kitzine — Homepage redesign (front-page only)
   Scoped under .kh-home so it never collides with the theme's
   existing clientlib CSS, Bootstrap or the header/hero.
   Loaded only on the front page (see functions.php).
   Header, menu bar and hero video/text are NOT styled here.
============================================================ */
.kh-home, .kh-home *, .kh-home *::before, .kh-home *::after{ box-sizing:border-box; }
.kh-home{ margin:0; }
.kh-home img{ display:block; max-width:100%; height:auto; }
.kh-home a{ text-decoration:none; color:inherit; }
.kh-home ul{ list-style:none; margin:0; padding:0; }
.kh-home button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
.kh-home ::selection{ background:#52B135; color:#fff; }

.kh-home{
  --gold:#D4A44C;
  --gold-d:#b8882e;
  --gold-l:#f0c060;
  --yellow:#F2C93A;
  --green:#52B135;
  --green-d:#3f8a28;
  --grad: linear-gradient(135deg, #F2C93A 0%, #D8C730 30%, #95BE2F 65%, #52B135 100%);
  --ink:#1c1a15;
  --body:#5c5648;
  --muted:#8a8272;
  --bg:#faf8f3;
  --bg2:#ffffff;
  --line:rgba(180,140,60,.18);
  --ease:cubic-bezier(.7,0,.2,1);

  --font-head:'Inter', 'Helvetica Neue', Arial, sans-serif;
  --font-body:'Inter', 'Helvetica Neue', Arial, sans-serif;
  --fs-h2:clamp(2rem, 3.6vw, 2.6rem);
  --fs-h3:clamp(1.4rem, 2.2vw, 1.75rem);
  --fs-body:1rem;
  --fs-nav:.9375rem;
  --fs-small:.8125rem;

  background:var(--bg); color:var(--body);
  font-family:var(--font-body); font-size:var(--fs-body);
  -webkit-font-smoothing:antialiased;
}

.kh-wrap{ max-width:1300px; margin:0 auto; padding:0 clamp(20px,6vw,90px); }
.kh-sec{ position:relative; z-index:2; padding:clamp(64px,8vw,116px) 0; }
.kh-sec--alt{ background:linear-gradient(180deg,#ffffff,#f6efe0); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.kh-grad{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.kh-kick{ font-size:var(--fs-small); letter-spacing:.32em; text-transform:uppercase; font-weight:700; color:var(--gold-d);
  display:inline-flex; align-items:center; gap:12px; margin-bottom:16px; }
.kh-kick::before{ content:''; width:30px; height:2px; border-radius:2px; background:var(--grad); }
.kh-h2{ font-family:var(--font-head); font-weight:800; letter-spacing:-.01em; line-height:1.1; font-size:var(--fs-h2); color:var(--ink); }
.kh-sub{ margin-top:16px; font-weight:300; font-size:var(--fs-body); line-height:1.7; color:var(--body); }
.kh-sec-head{ max-width:760px; margin:0 auto clamp(44px,5vw,68px); text-align:center; }
.kh-sec-head .kh-kick{ justify-content:center; }

.kh-glass{ background:linear-gradient(160deg, rgba(255,255,255,.94), rgba(255,255,255,.66));
  border:1px solid var(--line); box-shadow:0 16px 36px rgba(90,60,10,.08), inset 0 1px 0 #fff; }

/* buttons */
.kh-btn{ display:inline-flex; align-items:center; gap:10px; font-size:.875rem; letter-spacing:.06em; text-transform:uppercase;
  font-weight:700; padding:15px 30px; border-radius:8px; transition:.3s var(--ease); white-space:nowrap; font-family:var(--font-body); }
.kh-btn .arr{ transition:transform .3s; } .kh-btn:hover .arr{ transform:translateX(4px); }
.kh-btn-primary{ color:#fff; background:var(--grad); box-shadow:0 10px 26px rgba(82,177,53,.32), inset 0 1px 0 rgba(255,255,255,.4); }
.kh-btn-primary:hover{ transform:translateY(-3px); filter:brightness(1.05); }
.kh-btn-ghost{ color:var(--ink); border:1px solid var(--line); background:#fff; }
.kh-btn-ghost:hover{ border-color:var(--gold); transform:translateY(-3px); }
.kh-btn-white{ color:var(--gold-d); background:#fff; box-shadow:0 12px 26px rgba(0,0,0,.15); }
.kh-btn-white:hover{ transform:translateY(-3px); }

.kh-pill{ display:inline-flex; align-items:center; gap:9px; font-size:.875rem; letter-spacing:.05em; text-transform:uppercase;
  font-weight:700; padding:14px 26px; border-radius:8px; color:#fff; background:var(--grad);
  box-shadow:0 10px 24px rgba(82,177,53,.32), inset 0 1px 0 rgba(255,255,255,.4); transition:.3s var(--ease); }
.kh-pill:hover{ transform:translateY(-2px); filter:brightness(1.05); }

/* reveal-on-scroll */
.kh-reveal{ opacity:0; transform:translateY(36px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.kh-reveal.kh-in{ opacity:1; transform:none; }
.kh-reveal.kh-left{ transform:translateX(-50px); } .kh-reveal.kh-right{ transform:translateX(50px); }
.kh-reveal.kh-left.kh-in, .kh-reveal.kh-right.kh-in{ transform:none; }
.kh-reveal.kh-d1{ transition-delay:.08s } .kh-reveal.kh-d2{ transition-delay:.16s } .kh-reveal.kh-d3{ transition-delay:.24s }
.kh-reveal.kh-d4{ transition-delay:.32s } .kh-reveal.kh-d5{ transition-delay:.40s }
@media (prefers-reduced-motion:reduce){
  .kh-home *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; }
  .kh-reveal{ opacity:1; transform:none; }
}

/* ============================================================
   HERO POSTER FACADE — defers the heavy YouTube iframe.
   Poster mirrors the .ktz-yt-frame cover sizing exactly, then
   fades out once the real iframe (injected on idle) has loaded.
   The hero markup, text and animation stay unchanged.
============================================================ */
.ktz-yt-poster{ position:absolute; top:50%; left:50%; width:100vw; height:56.25vw; min-height:100vh; min-width:177.78vh;
  transform:translate(-50%,-50%); object-fit:cover; z-index:0; transition:opacity .6s ease; }
.ktz-yt-poster.kh-hidden{ opacity:0; }

/* ============================================================
   TRUST STRIP
============================================================ */
.kh-trust{ position:relative; z-index:5; background:#fff; border-bottom:1px solid var(--line); }
.kh-trust .kh-wrap{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; padding-top:28px; padding-bottom:28px; }
.kh-tcell{ display:flex; align-items:center; gap:14px; }
.kh-tcell .kh-ic{ width:48px; height:48px; flex:0 0 auto; border-radius:13px; display:grid; place-items:center; color:var(--gold-d);
  background:linear-gradient(150deg, rgba(242,201,58,.18), rgba(82,177,53,.16)); border:1px solid var(--line); box-shadow:inset 0 1px 0 #fff; }
.kh-tcell .kh-ic svg{ width:24px; height:24px; }
.kh-tcell b{ display:block; font-family:var(--font-head); font-size:15px; color:var(--ink); }
.kh-tcell span{ font-size:var(--fs-small); color:var(--muted); }

/* ============================================================
   ABOUT
============================================================ */
.kh-about-grid{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(30px,5vw,72px); align-items:center; }
.kh-about-copy blockquote{ font-family:var(--font-head); font-style:italic; font-size:1.15rem; line-height:1.5; color:var(--ink);
  border-left:3px solid var(--gold); padding-left:18px; margin:18px 0; }
.kh-about-copy p{ margin-top:16px; font-weight:300; line-height:1.75; color:var(--body); max-width:560px; }
.kh-about-copy .kh-checks{ margin-top:22px; display:grid; grid-template-columns:1fr 1fr; gap:10px 22px; max-width:520px; }
.kh-about-copy .kh-checks li{ font-size:var(--fs-nav); color:var(--ink); display:flex; align-items:center; gap:10px; font-weight:600; }
.kh-about-copy .kh-checks li::before{ content:'✓'; width:22px; height:22px; flex:0 0 auto; border-radius:50%; display:grid; place-items:center;
  font-size:12px; color:#fff; background:var(--grad); }
.kh-about-copy .kh-pill{ margin-top:26px; }
.kh-about-media{ position:relative; border-radius:20px; overflow:hidden; aspect-ratio:5/4; border:1px solid var(--line);
  box-shadow:0 30px 64px rgba(90,60,10,.16), inset 0 1px 0 #fff; }
.kh-about-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.kh-about-media:hover img{ transform:scale(1.05); }
.kh-about-media .kh-ribbon{ position:absolute; top:16px; left:16px; z-index:2; padding:10px 16px; border-radius:30px; font-size:12px;
  font-weight:700; letter-spacing:.03em; color:#fff; background:var(--grad); box-shadow:0 10px 22px rgba(82,177,53,.35); }
.kh-about-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:clamp(46px,5vw,68px); }
.kh-stat{ padding:28px 20px; border-radius:18px; text-align:center; }
.kh-stat b{ display:block; font-family:var(--font-head); font-weight:800; line-height:1; font-size:clamp(26px,3.4vw,42px); }
.kh-stat span{ display:block; margin-top:10px; font-size:var(--fs-small); letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }

@media (max-width:980px){
  .kh-trust .kh-wrap{ grid-template-columns:1fr 1fr; }
  .kh-about-grid{ grid-template-columns:1fr; gap:30px; }
  .kh-about-stats{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px){
  .kh-trust .kh-wrap{ grid-template-columns:1fr; }
  .kh-about-copy .kh-checks{ grid-template-columns:1fr; }
}

/* ============================================================
   MODULAR KITCHEN STYLES — expanding accordion gallery
============================================================ */
.kh-styles{ background:var(--bg); overflow:hidden; }
.kh-styles-slider{ position:relative; }
.kh-gal{ display:flex; gap:10px; height:clamp(340px,46vw,460px); overflow-x:auto; overflow-y:hidden;
  padding:6px clamp(20px,6vw,90px) 20px; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; scrollbar-width:thin; scrollbar-color:var(--gold) transparent; }
.kh-gal::-webkit-scrollbar{ height:8px; }
.kh-gal::-webkit-scrollbar-track{ background:transparent; }
.kh-gal::-webkit-scrollbar-thumb{ background:var(--gold); border-radius:8px; }
.kh-gal-item{ position:relative; flex:0 0 clamp(150px,20vw,210px); scroll-snap-align:center; border-radius:16px; overflow:hidden;
  border:1px solid var(--line); box-shadow:0 16px 40px rgba(90,60,10,.12); transition:flex-basis .55s var(--ease); }
.kh-gal-item img{ width:100%; height:100%; object-fit:cover; object-position:center; transition:transform .6s var(--ease); }
.kh-gal-item::after{ content:''; position:absolute; inset:0; background:linear-gradient(0deg, rgba(15,12,6,.72) 0%, transparent 48%); opacity:.85; transition:opacity .4s var(--ease); }
.kh-gal-cap{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:18px 20px; color:#fff; opacity:0; transform:translateY(12px); transition:.45s var(--ease); }
.kh-gal-cap .kh-gal-eyebrow{ font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-l); font-weight:700; }
.kh-gal-cap h3{ font-family:var(--font-head); font-size:18px; margin:5px 0 0; white-space:nowrap; }
.kh-styles-hint{ text-align:center; margin-top:6px; font-size:var(--fs-small); letter-spacing:.06em; color:var(--muted); }
.kh-gal-arrow{ position:absolute; top:calc(50% - 14px); transform:translateY(-50%); z-index:5; width:48px; height:48px; border-radius:50%;
  display:grid; place-items:center; font-size:20px; color:var(--gold-d); background:rgba(255,255,255,.94); border:1px solid var(--line);
  box-shadow:0 10px 24px rgba(90,60,10,.16); transition:.3s var(--ease); }
.kh-gal-arrow:hover{ color:#fff; background:var(--grad); border-color:transparent; }
.kh-gal-arrow--prev{ left:clamp(8px,2vw,26px); } .kh-gal-arrow--next{ right:clamp(8px,2vw,26px); }
@media (hover:hover) and (pointer:fine){
  .kh-gal-item:hover{ flex-basis:min(460px,58vw); }
  .kh-gal-item:hover img{ transform:scale(1.05); }
  .kh-gal-item:hover::after{ opacity:1; }
  .kh-gal-item:hover .kh-gal-cap{ opacity:1; transform:none; }
}
@media (hover:none){
  .kh-gal-item{ flex-basis:76vw; }
  .kh-gal-cap{ opacity:1; transform:none; }
  .kh-gal-arrow{ display:none; }
}

/* ============================================================
   SERVICES — sticky-stacking panels
============================================================ */
.kh-services{ position:relative; z-index:4; background:var(--bg); }
.kh-svc-head{ margin:0 auto; padding:clamp(64px,9vw,130px) clamp(20px,7vw,130px) clamp(10px,3vw,36px); text-align:center; max-width:820px; }
.kh-svc-block{ position:sticky; top:0; min-height:100vh; display:grid; grid-template-columns:1.05fr 1fr 1.25fr; gap:clamp(24px,3.5vw,56px);
  align-items:center; align-content:center; padding:clamp(52px,8vh,110px) clamp(20px,7vw,130px);
  background:
    radial-gradient(70% 60% at 84% 10%, rgba(242,201,58,.14), transparent 60%),
    radial-gradient(60% 60% at 6% 90%, rgba(82,177,53,.10), transparent 60%),
    linear-gradient(180deg,#ffffff 0%, #fbf6ea 70%, #f6efe0 100%);
  border-top:1px solid var(--line); border-radius:30px 30px 0 0; box-shadow:0 -22px 54px rgba(90,60,10,.10); }
.kh-svc-block:first-of-type{ border-radius:0; box-shadow:none; border-top:none; }
.kh-svc-block:nth-of-type(even) .kh-svc-media{ order:-1; }
.kh-svc-num{ font-family:var(--font-head); font-size:var(--fs-small); font-weight:700; letter-spacing:.16em; }
.kh-svc-title{ font-family:var(--font-head); font-weight:800; color:var(--ink); line-height:1.1; font-size:var(--fs-h3); margin:12px 0 14px; }
.kh-svc-desc{ font-weight:300; line-height:1.65; color:var(--body); max-width:380px; margin-bottom:22px; }
.kh-svc-list li a{ position:relative; display:flex; align-items:center; justify-content:space-between; gap:12px; padding:12px 16px; border-radius:12px;
  color:var(--ink); font-size:var(--fs-nav); font-weight:600; border:1px solid transparent; transition:.3s var(--ease); }
.kh-svc-list li a .kh-dot{ width:8px; height:8px; border-radius:50%; flex:0 0 auto; background:var(--grad); margin-right:2px; }
.kh-svc-list li a .kh-tx{ flex:1; }
.kh-svc-list li a .kh-ar{ opacity:0; transform:translateX(-8px); transition:.3s var(--ease); color:var(--gold-d); }
.kh-svc-list li a::before{ content:''; position:absolute; inset:0; border-radius:12px; opacity:0;
  background:linear-gradient(120deg, rgba(242,201,58,.12), rgba(82,177,53,.10)); transition:.3s var(--ease); }
.kh-svc-list li a:hover{ border-color:var(--line); transform:translateX(6px); }
.kh-svc-list li a:hover::before{ opacity:1; }
.kh-svc-list li a:hover .kh-ar{ opacity:1; transform:translateX(0); }
.kh-svc-list li a span{ position:relative; z-index:1; }
.kh-svc-media{ position:relative; border-radius:20px; overflow:hidden; aspect-ratio:4/3; border:1px solid var(--line);
  box-shadow:0 26px 54px rgba(90,60,10,.16), inset 0 1px 0 #fff; }
.kh-svc-media img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.1s var(--ease); }
.kh-svc-media:hover img{ transform:scale(1.06); }
.kh-svc-media .kh-tagchip{ position:absolute; left:14px; bottom:14px; z-index:2; padding:8px 14px; border-radius:30px; font-size:var(--fs-small);
  font-weight:700; color:#fff; background:rgba(20,16,8,.55); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,.25); }

@media (max-width:980px){
  .kh-svc-block{ position:relative; min-height:auto; grid-template-columns:1fr; gap:22px; padding:52px 20px; border-radius:0; box-shadow:none; }
  .kh-svc-block:nth-of-type(even) .kh-svc-media{ order:0; }
  .kh-svc-media{ aspect-ratio:16/10; } .kh-svc-desc{ max-width:none; }
}

/* ============================================================
   AVAILABILITY — floating pill buttons
============================================================ */
.kh-avail-cloud{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; max-width:1040px; margin:0 auto; }
.kh-avail-btn{ display:inline-flex; align-items:center; gap:11px; padding:13px 22px; border-radius:40px; font-weight:600; font-size:var(--fs-nav); color:var(--ink);
  background:linear-gradient(160deg, rgba(255,255,255,.96), rgba(255,255,255,.7)); border:1px solid var(--line);
  box-shadow:0 10px 22px rgba(90,60,10,.08), inset 0 1px 0 #fff; transition:transform .3s var(--ease), box-shadow .3s var(--ease), color .3s, background .3s, border-color .3s;
  animation:kh-floaty 4.5s ease-in-out infinite; animation-delay:calc(var(--i) * .14s); }
.kh-avail-btn .kh-dot{ width:9px; height:9px; border-radius:50%; flex:0 0 auto; background:var(--grad); }
.kh-avail-btn:hover{ animation-play-state:paused; transform:translateY(-4px) scale(1.03); color:#fff; background:var(--grad); border-color:transparent;
  box-shadow:0 18px 36px rgba(82,177,53,.34); }
.kh-avail-btn:hover .kh-dot{ background:#fff; }
@keyframes kh-floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-6px); } }

/* ============================================================
   WHY CHOOSE US
============================================================ */
.kh-why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.kh-wcard{ padding:30px 26px; border-radius:20px; transition:.35s var(--ease); }
.kh-wcard:hover{ transform:translateY(-8px); border-color:var(--gold); box-shadow:0 24px 50px rgba(90,60,10,.14); }
.kh-wcard .kh-ico{ width:52px; height:52px; border-radius:14px; display:grid; place-items:center; margin-bottom:16px; color:var(--gold-d);
  background:linear-gradient(150deg, rgba(242,201,58,.18), rgba(82,177,53,.16)); border:1px solid var(--line); }
.kh-wcard .kh-ico svg{ width:26px; height:26px; }
.kh-wcard h3{ font-family:var(--font-head); font-size:17px; color:var(--ink); margin:0 0 9px; }
.kh-wcard p{ font-size:var(--fs-body); line-height:1.6; color:var(--body); margin:0; }

/* ============================================================
   PROCESS — real newkit step icons + dotted connectors
============================================================ */
.kh-proc-steps{ display:grid; grid-template-columns:repeat(5,1fr); gap:12px; max-width:1180px; margin:0 auto; }
.kh-proc-item{ position:relative; text-align:center; padding:0 6px; }
.kh-proc-icon-wrap{ position:relative; width:clamp(94px,9vw,118px); height:clamp(94px,9vw,118px); margin:0 auto 18px; border-radius:50%;
  background:#fff; border:1px solid var(--line); box-shadow:0 14px 32px rgba(90,60,10,.12), inset 0 1px 0 #fff; display:grid; place-items:center; }
.kh-proc-icon-wrap img{ width:clamp(46px,5vw,62px); height:auto; }
.kh-proc-num{ position:absolute; top:-2px; right:-2px; width:34px; height:34px; border-radius:50%; display:grid; place-items:center;
  font-family:var(--font-head); font-weight:700; font-size:13px; color:#fff; background:linear-gradient(135deg,#d6a850,#bd842b);
  box-shadow:0 6px 14px rgba(168,114,32,.42); }
.kh-proc-connector{ position:absolute; top:clamp(38px,4vw,52px); left:76%; width:58%; height:auto; opacity:.5; pointer-events:none; }
.kh-proc-item h3{ font-family:var(--font-head); font-weight:700; font-size:clamp(1rem,1.3vw,1.15rem); color:var(--ink); margin:0 0 6px; }
.kh-proc-item p{ font-size:.9rem; line-height:1.55; color:var(--body); margin:0 auto; max-width:210px; }

@media (max-width:980px){
  .kh-why-grid{ grid-template-columns:1fr 1fr; }
  .kh-proc-steps{ grid-template-columns:repeat(2,1fr); gap:28px 12px; }
  .kh-proc-connector{ display:none; }
}
@media (max-width:600px){
  .kh-why-grid{ grid-template-columns:1fr; }
}

/* ============================================================
   WORK / PROJECTS GALLERY
============================================================ */
.kh-work-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.kh-work-card{ position:relative; border-radius:20px; overflow:hidden; aspect-ratio:4/3; border:1px solid var(--line); display:block;
  box-shadow:0 16px 40px rgba(90,60,10,.10); }
.kh-work-card img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease); }
.kh-work-card::after{ content:''; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(15,12,6,.86)); }
.kh-work-card .kh-info{ position:absolute; left:0; right:0; bottom:0; padding:20px; z-index:2; }
.kh-work-card .kh-cat{ font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-l); font-weight:700; }
.kh-work-card h3{ font-family:var(--font-head); font-size:17px; color:#fff; margin:6px 0 0; }
.kh-work-card .kh-go{ opacity:0; transform:translateY(8px); transition:.35s var(--ease); color:#f4ecd8; font-size:13px; margin-top:7px; display:inline-block; }
.kh-work-card:hover img{ transform:scale(1.08); }
.kh-work-card:hover .kh-go{ opacity:1; transform:translateY(0); }

/* ============================================================
   TESTIMONIALS
============================================================ */
.kh-tst-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.kh-tst{ padding:30px; border-radius:20px; }
.kh-tst .kh-stars{ color:#f0b429; letter-spacing:3px; font-size:15px; margin-bottom:14px; }
.kh-tst .kh-q{ font-size:var(--fs-body); line-height:1.7; color:var(--ink); margin:0; }
.kh-tst .kh-who{ display:flex; align-items:center; gap:12px; margin-top:22px; }
.kh-tst .kh-av{ width:44px; height:44px; border-radius:50%; display:grid; place-items:center; font-family:var(--font-head); font-weight:700; color:#fff;
  background:var(--grad); flex:0 0 auto; }
.kh-tst .kh-who b{ display:block; color:var(--ink); font-size:14px; } .kh-tst .kh-who span{ color:var(--muted); font-size:12.5px; }

/* ============================================================
   AREAS WE SERVE — marquee + chips
============================================================ */
.kh-area-marquee{ display:flex; flex-direction:column; gap:16px; margin:clamp(28px,4vw,48px) 0 0; overflow:hidden;
  -webkit-mask:linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
  mask:linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); }
.kh-mq-row{ display:flex; gap:16px; width:max-content; }
.kh-mq-row--1{ animation:kh-mqleft 32s linear infinite; }
.kh-mq-row--2{ animation:kh-mqright 36s linear infinite; }
.kh-area-marquee:hover .kh-mq-row{ animation-play-state:paused; }
@keyframes kh-mqleft{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@keyframes kh-mqright{ from{ transform:translateX(-50%); } to{ transform:translateX(0); } }
.kh-area-card{ display:inline-flex; align-items:center; gap:12px; padding:15px 24px; border-radius:14px; white-space:nowrap;
  background:linear-gradient(160deg,#ffffff,#f6efe0); border:1px solid var(--line); font-family:var(--font-head); font-weight:700; font-size:15px; color:var(--ink); }
.kh-area-card .kh-pin{ width:28px; height:28px; border-radius:50%; display:grid; place-items:center; font-size:13px; flex:0 0 auto;
  background:linear-gradient(150deg, rgba(242,201,58,.18), rgba(82,177,53,.16)); }
.kh-chips{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; max-width:980px; margin:clamp(28px,3.5vw,44px) auto 0; }
.kh-chip{ padding:12px 22px; border-radius:30px; font-size:var(--fs-nav); font-weight:600; color:var(--ink); transition:.3s var(--ease);
  background:linear-gradient(160deg, rgba(255,255,255,.94), rgba(255,255,255,.66)); border:1px solid var(--line); }
.kh-chip:hover{ transform:translateY(-3px); border-color:var(--gold); }

/* ============================================================
   CTA BAND
============================================================ */
.kh-cta{ position:relative; z-index:4; text-align:center; padding:clamp(70px,9vw,116px) 0; overflow:hidden; background:var(--grad); }
.kh-cta::before{ content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(60% 80% at 18% 12%, rgba(255,255,255,.25), transparent 55%), radial-gradient(50% 70% at 90% 90%, rgba(255,255,255,.16), transparent 55%); }
.kh-cta .kh-wrap{ position:relative; z-index:2; }
.kh-cta h2{ color:#fff; max-width:780px; margin:0 auto; font-family:var(--font-head); font-weight:800; font-size:var(--fs-h2); line-height:1.1; }
.kh-cta p{ color:rgba(255,255,255,.94); max-width:580px; margin:16px auto 0; font-weight:400; }
.kh-cta .kh-btns{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:32px; }
.kh-cta .kh-offer{ display:inline-block; margin-bottom:16px; padding:9px 18px; border-radius:30px; font-size:var(--fs-small); font-weight:700;
  letter-spacing:.05em; text-transform:uppercase; color:var(--green-d); background:#fff; }

@media (max-width:980px){
  .kh-work-grid, .kh-tst-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:600px){
  .kh-work-grid, .kh-tst-grid{ grid-template-columns:1fr; }
}
