/* ============================================================
   PIKU theme for Kapshare product pages (Kapsul · Katalyst)
   Purple-forward playful SaaS — modeled on the Piku template.
   Self-contained: no CSS-var theme switching, no React.
   Tokens: brand accent per-product (Kapsul pink / Katalyst orange).
   Font: Jost (display + UI) + Inter (body) + Caveat (script).
   ============================================================ */

/* ---------- GORDITA FONT ---------- */
@font-face{ font-family:"Gordita"; src:url("assets/fonts/gordita/Gordita-Light.woff2") format("woff2"); font-weight:300; font-style:normal; font-display:swap; }
@font-face{ font-family:"Gordita"; src:url("assets/fonts/gordita/Gordita-Regular.woff2") format("woff2"); font-weight:400; font-style:normal; font-display:swap; }
@font-face{ font-family:"Gordita"; src:url("assets/fonts/gordita/Gordita-Medium.woff2") format("woff2"); font-weight:500; font-style:normal; font-display:swap; }
@font-face{ font-family:"Gordita"; src:url("assets/fonts/gordita/Gordita-Bold.woff2") format("woff2"); font-weight:700; font-style:normal; font-display:swap; }
@font-face{ font-family:"Gordita"; src:url("assets/fonts/gordita/Gordita-Black.woff2") format("woff2"); font-weight:900; font-style:normal; font-display:swap; }

:root{
  --pk-bg:#0C0C0E;
  --pk-bg2:#0f0f12;
  --pk-surface:#161618;
  --pk-surface2:#1d1d20;
  --pk-line:rgba(255,255,255,.10);
  --pk-line2:rgba(255,255,255,.18);
  --pk-fg:#F6F4F6;
  --pk-muted:rgba(255,255,255,.6);
  --pk-faint:rgba(255,255,255,.42);
  /* brand accent — overridden per product below (default = Kapsul) */
  --pk-primary:#FF0055;
  --pk-primary-l:#FF3370;
  --pk-secondary:#4285F4;
  --pk-script:#FF1A6B;
  --pk-cyan:#00DBE4;
  --pk-lime:#E1FF2D;
  --pk-mint:#9AFFFF;
  --pk-grad:linear-gradient(98deg, var(--pk-primary) 0%, var(--pk-primary-l) 120%);
  --pk-grad-soft:linear-gradient(180deg, color-mix(in srgb,var(--pk-primary) 18%,transparent), transparent);
  --pk-glow:0 0 24px color-mix(in srgb,var(--pk-primary) 28%,transparent);
  --pk-radius:18px;
  --pk-radius-lg:30px;
  --pk-ease:cubic-bezier(.22,1,.36,1);
}

/* ---- per-product brand themes (official Kapshare design system) ---- */
body.theme-kapsul{ --pk-primary:#FF0055; --pk-primary-l:#FF5C93; --pk-secondary:#4285F4; --pk-script:#FF1A6B;
  --pk-grad:linear-gradient(98deg,#FF0055 0%,#FF5C93 120%); --pk-grad-soft:linear-gradient(180deg, rgba(255,0,85,.18), transparent); --pk-glow:0 0 24px rgba(255,0,85,.28); }
body.theme-katalyst{ --pk-primary:#FF6B00; --pk-primary-l:#FF8533; --pk-secondary:#4285F4; --pk-script:#FF6B00;
  --pk-grad:linear-gradient(98deg,#FF6B00 0%,#FF8533 120%); --pk-grad-soft:linear-gradient(180deg, rgba(255,107,0,.18), transparent); --pk-glow:0 0 24px rgba(255,107,0,.3); }

/* legacy accent aliases (kept so older rules follow the active theme) */
:root{ --pk-pink:var(--pk-primary-l); --pk-yellow:#FFC23A; }

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body.pk{
  background:var(--pk-bg); color:var(--pk-fg);
  font-family:"Inter",system-ui,sans-serif;
  font-weight:400; line-height:1.6; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.pk::selection{ background:var(--pk-primary); color:#fff; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
h1,h2,h3,h4,h5,h6,.pk-h2{ font-family:"Jost","Inter",sans-serif; font-weight:800; line-height:1.08; letter-spacing:-.02em; }

.pk-wrap{ width:100%; max-width:1240px; margin:0 auto; padding:0 28px; }
.pk-sec{ padding-block:clamp(70px,10vw,140px); position:relative; }
.pk-center{ text-align:center; }

/* ---------- EYEBROW / SECTION HEADER ---------- */
.pk-eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-size:13px; font-weight:600; letter-spacing:.02em;
  padding:8px 16px; border-radius:40px;
  background:color-mix(in srgb,var(--pk-primary) 14%,transparent); border:1px solid color-mix(in srgb,var(--pk-primary) 34%,transparent);
  color:var(--pk-primary-l); margin-bottom:22px;
}
.pk-eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:var(--pk-primary-l); }
.pk-h2{ font-size:clamp(2rem,4.6vw,3.7rem); }
.pk-lead{ color:var(--pk-muted); font-size:clamp(16px,1.5vw,19px); max-width:60ch; margin-top:20px; }
.pk-center .pk-lead{ margin-inline:auto; }
.pk-grad-txt{
  background:var(--pk-grad); -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}

/* ---------- BUTTONS ---------- */
.pk-btn{
  display:inline-flex; align-items:center; gap:10px;
  font-weight:600; font-size:16px; padding:15px 30px; border-radius:40px;
  border:1px solid transparent; cursor:pointer; white-space:nowrap;
  transition:transform .3s var(--pk-ease), box-shadow .3s var(--pk-ease), background .3s, border-color .3s, color .3s;
}
.pk-btn .i{ transition:transform .3s var(--pk-ease); }
.pk-btn:hover .i{ transform:translateX(4px); }
.pk-btn-primary{ background:var(--pk-primary); color:#fff; box-shadow:0 14px 38px -16px color-mix(in srgb,var(--pk-primary) 75%,transparent); }
.pk-btn-primary:hover{ transform:translateY(-3px); background:var(--pk-primary-l); box-shadow:0 22px 48px -16px color-mix(in srgb,var(--pk-primary) 85%,transparent); }
.pk-btn-ghost{ background:transparent; color:var(--pk-fg); border-color:var(--pk-line2); }
.pk-btn-ghost:hover{ border-color:var(--pk-primary); color:var(--pk-primary-l); transform:translateY(-3px); }
.pk-btn-light{ background:#fff; color:#150829; }
.pk-btn-light:hover{ transform:translateY(-3px); box-shadow:0 18px 40px -16px rgba(255,255,255,.5); }
.pk-btn-watch .play{ width:30px; height:30px; border-radius:50%; background:var(--pk-primary); color:#fff; display:grid; place-items:center; font-size:11px; }

/* ---------- NAV ---------- */
.pk-nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:18px clamp(20px,4vw,48px);
  background:rgba(12,1,24,.6); backdrop-filter:blur(16px);
  border-bottom:1px solid transparent; transition:background .3s, border-color .3s, padding .3s;
}
.pk-nav.scrolled{ background:rgba(12,1,24,.92); border-bottom-color:var(--pk-line); padding-top:13px; padding-bottom:13px; }
.pk-nav .logo img{ height:30px; }
.pk-nav-links{ display:flex; align-items:center; gap:30px; list-style:none; }
.pk-nav-links a{ font-size:15px; font-weight:500; color:var(--pk-muted); transition:color .2s; }
.pk-nav-links a:hover, .pk-nav-links a.active{ color:var(--pk-fg); }
.pk-nav-cta{ display:flex; align-items:center; gap:14px; }
@media(max-width:860px){ .pk-nav-links{ display:none; } }

/* ---------- HERO ---------- */
.pk-hero{ position:relative; padding-top:clamp(140px,17vw,210px); padding-bottom:clamp(50px,7vw,90px); text-align:center; overflow:hidden; }
.pk-hero .orb{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.5; z-index:0; pointer-events:none; }
.pk-hero .orb-1{ width:440px; height:440px; background:var(--pk-primary); top:-120px; left:-100px; }
.pk-hero .orb-2{ width:360px; height:360px; background:var(--pk-secondary); top:40px; right:-120px; opacity:.28; }
.pk-hero-inner{ position:relative; z-index:2; }
.pk-hero h1{ font-size:clamp(2.6rem,6.6vw,5.4rem); letter-spacing:-.03em; max-width:16ch; margin-inline:auto; }
.pk-hero .pk-lead{ font-size:clamp(17px,1.7vw,21px); max-width:54ch; }
.pk-hero-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin-top:38px; }
.pk-hero-note{ margin-top:20px; font-size:14px; color:var(--pk-faint); display:flex; gap:18px; justify-content:center; flex-wrap:wrap; }
.pk-hero-note span{ display:inline-flex; align-items:center; gap:8px; }
.pk-hero-note span::before{ content:""; width:16px; height:16px; border-radius:50%; background:var(--pk-grad); flex:none; }

/* app screenshot frame */
.pk-shot-frame{
  position:relative; z-index:2; margin-top:clamp(50px,7vw,84px);
  border-radius:var(--pk-radius-lg); padding:10px;
  background:linear-gradient(180deg, color-mix(in srgb,var(--pk-primary) 50%,transparent), transparent);
  border:1px solid var(--pk-line2);
}
.pk-shot{
  border-radius:calc(var(--pk-radius-lg) - 8px); overflow:hidden;
  background:var(--pk-surface); border:1px solid var(--pk-line);
  aspect-ratio:16/9; display:grid; place-items:center;
  color:var(--pk-faint); font-size:14px; letter-spacing:.03em; text-align:center; padding:24px; position:relative;
}
.pk-shot .tag{ position:absolute; top:16px; left:18px; font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--pk-primary-l); }

/* ---------- TRUST STRIP ---------- */
.pk-trust{ text-align:center; padding-block:46px; border-top:1px solid var(--pk-line); border-bottom:1px solid var(--pk-line); }
.pk-trust p{ font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--pk-faint); margin-bottom:24px; }
.pk-trust-row{ display:flex; gap:clamp(26px,5vw,64px); justify-content:center; align-items:center; flex-wrap:wrap; }
.pk-trust-row span{ font-size:clamp(18px,2.2vw,26px); font-weight:700; color:var(--pk-muted); opacity:.7; letter-spacing:-.01em; }

/* ---------- BENTO / FEATURE GRID ---------- */
.pk-bento{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media(max-width:900px){ .pk-bento{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:580px){ .pk-bento{ grid-template-columns:1fr; } }
.pk-card{
  background:var(--pk-surface); border:1px solid var(--pk-line); border-radius:var(--pk-radius-lg);
  padding:34px 30px; position:relative; overflow:hidden;
  transition:transform .4s var(--pk-ease), border-color .4s, background .4s;
}
.pk-card:hover{ transform:translateY(-6px); border-color:var(--pk-line2); background:var(--pk-surface2); }
.pk-card.span2{ grid-column:span 2; }
@media(max-width:580px){ .pk-card.span2{ grid-column:span 1; } }
.pk-ico{
  width:56px; height:56px; border-radius:16px; display:grid; place-items:center; margin-bottom:22px;
  background:color-mix(in srgb,var(--pk-primary) 16%,transparent); color:var(--pk-primary-l);
}
.pk-ico svg{ width:27px; height:27px; stroke:currentColor; stroke-width:1.8; fill:none; }
.pk-ico.c-pink{ background:color-mix(in srgb,var(--pk-primary) 16%,transparent); color:var(--pk-primary-l); }
.pk-ico.c-yellow{ background:color-mix(in srgb,var(--pk-secondary) 18%,transparent); color:var(--pk-secondary); }
.pk-ico.c-mint{ background:rgba(154,255,255,.14); color:var(--pk-mint); }
.pk-ico.c-lime{ background:rgba(225,255,45,.14); color:var(--pk-lime); }
.pk-card h3{ font-size:21px; margin-bottom:10px; }
.pk-card p{ color:var(--pk-muted); font-size:15.5px; }

/* ---------- ALTERNATING FEATURE ROWS ---------- */
.pk-feature{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,90px); align-items:center; }
.pk-feature + .pk-feature{ margin-top:clamp(60px,9vw,120px); }
@media(max-width:840px){ .pk-feature{ grid-template-columns:1fr; gap:36px; } .pk-feature .pk-feature-media{ order:-1; } }
.pk-feature h2{ font-size:clamp(1.8rem,3.4vw,2.8rem); margin-bottom:18px; }
.pk-feature p{ color:var(--pk-muted); font-size:17px; margin-bottom:22px; max-width:48ch; }
.pk-flist{ list-style:none; display:flex; flex-direction:column; gap:13px; }
.pk-flist li{ display:flex; gap:13px; align-items:flex-start; font-size:16px; }
.pk-flist .ck{ flex:none; width:24px; height:24px; border-radius:50%; background:var(--pk-grad); display:grid; place-items:center; font-size:13px; color:#fff; margin-top:1px; }
.pk-feature-media .pk-shot{ aspect-ratio:4/3; }
.pk-feature-media{ position:relative; }
.pk-feature-media .badge{
  position:absolute; z-index:3; bottom:-18px; right:-10px;
  background:var(--pk-surface2); border:1px solid var(--pk-line2); border-radius:16px;
  padding:14px 18px; display:flex; align-items:center; gap:12px; box-shadow:0 20px 50px -20px #000;
}
.pk-feature-media .badge .b-ic{ width:38px; height:38px; border-radius:11px; background:var(--pk-grad); display:grid; place-items:center; color:#fff; }
.pk-feature-media .badge b{ font-size:18px; } .pk-feature-media .badge small{ display:block; color:var(--pk-muted); font-size:12px; }

/* ---------- HOW IT WORKS ---------- */
.pk-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; counter-reset:step; }
@media(max-width:780px){ .pk-steps{ grid-template-columns:1fr; } }
.pk-step{ position:relative; padding-top:18px; }
.pk-step .n{ font-size:15px; font-weight:700; color:var(--pk-primary-l); margin-bottom:16px; display:flex; align-items:center; gap:12px; }
.pk-step .n::before{ counter-increment:step; content:"0" counter(step); font-size:42px; line-height:1; -webkit-text-stroke:1px var(--pk-primary); color:transparent; font-weight:900; }
.pk-step h3{ font-size:20px; margin-bottom:10px; }
.pk-step p{ color:var(--pk-muted); font-size:15.5px; }

/* ---------- PRICING ---------- */
.pk-pricing{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:start; }
@media(max-width:880px){ .pk-pricing{ grid-template-columns:1fr; max-width:440px; margin-inline:auto; } }
.pk-price{ background:var(--pk-surface); border:1px solid var(--pk-line); border-radius:var(--pk-radius-lg); padding:34px 30px; }
.pk-price.feat{ background:linear-gradient(180deg,var(--pk-surface2),var(--pk-surface)); border-color:color-mix(in srgb,var(--pk-primary) 50%,transparent); position:relative; box-shadow:0 30px 70px -34px color-mix(in srgb,var(--pk-primary) 60%,transparent); }
.pk-price .pop{ position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--pk-grad); color:#fff; font-size:12px; font-weight:700; padding:6px 14px; border-radius:30px; }
.pk-price .plan{ font-size:15px; font-weight:600; color:var(--pk-muted); }
.pk-price .amt{ font-size:48px; font-weight:900; letter-spacing:-.03em; margin:14px 0 4px; }
.pk-price .amt small{ font-size:15px; font-weight:500; color:var(--pk-muted); }
.pk-price .desc{ color:var(--pk-muted); font-size:14.5px; min-height:42px; }
.pk-price ul{ list-style:none; display:flex; flex-direction:column; gap:12px; margin:24px 0 28px; }
.pk-price li{ display:flex; gap:11px; font-size:15px; color:var(--pk-fg); }
.pk-price li .ck{ color:var(--pk-primary-l); flex:none; }
.pk-price .pk-btn{ width:100%; justify-content:center; }

/* ---------- FAQ ---------- */
.pk-faq{ max-width:820px; margin-inline:auto; }
.pk-faq-item{ border:1px solid var(--pk-line); border-radius:var(--pk-radius); margin-bottom:14px; background:var(--pk-surface); overflow:hidden; transition:border-color .3s; }
.pk-faq-item.open{ border-color:color-mix(in srgb,var(--pk-primary) 50%,transparent); }
.pk-faq-q{ width:100%; text-align:left; background:none; border:none; color:var(--pk-fg); font-family:inherit; font-size:clamp(16px,1.7vw,19px); font-weight:600; padding:24px 26px; display:flex; justify-content:space-between; gap:20px; align-items:center; cursor:pointer; }
.pk-faq-q .pm{ flex:none; width:30px; height:30px; border-radius:50%; border:1px solid var(--pk-line2); display:grid; place-items:center; font-size:18px; transition:transform .3s, background .3s, color .3s, border-color .3s; }
.pk-faq-item.open .pm{ background:var(--pk-primary); border-color:var(--pk-primary); color:#fff; transform:rotate(45deg); }
.pk-faq-a{ max-height:0; overflow:hidden; transition:max-height .4s var(--pk-ease); }
.pk-faq-item.open .pk-faq-a{ max-height:300px; }
.pk-faq-a p{ padding:0 26px 24px; color:var(--pk-muted); font-size:16px; }

/* ---------- TESTIMONIAL ---------- */
.pk-quote{ max-width:900px; margin-inline:auto; text-align:center; }
.pk-quote p{ font-size:clamp(20px,2.8vw,32px); font-weight:500; line-height:1.4; letter-spacing:-.01em; }
.pk-quote .who{ margin-top:28px; display:flex; gap:14px; align-items:center; justify-content:center; }
.pk-quote .who .av{ width:46px; height:46px; border-radius:50%; background:var(--pk-grad); display:grid; place-items:center; font-weight:700; }
.pk-quote .who b{ display:block; } .pk-quote .who small{ color:var(--pk-muted); }

/* ---------- CTA BAND ---------- */
.pk-cta{ position:relative; border-radius:var(--pk-radius-lg); overflow:hidden; padding:clamp(48px,7vw,90px); text-align:center; background:radial-gradient(120% 140% at 50% 0%, var(--pk-primary) 0%, color-mix(in srgb,var(--pk-primary) 55%, #1a0838) 45%, #120a16 100%); }
.pk-cta::after{ content:""; position:absolute; inset:0; background-image:radial-gradient(circle, rgba(255,255,255,.08) 1px, transparent 1px); background-size:26px 26px; opacity:.6; }
.pk-cta-inner{ position:relative; z-index:2; }
.pk-cta h2{ font-size:clamp(2rem,4.6vw,3.6rem); max-width:18ch; margin-inline:auto; }
.pk-cta p{ color:rgba(255,255,255,.8); max-width:46ch; margin:20px auto 32px; font-size:17px; }
.pk-cta .pk-hero-actions{ margin-top:0; }

/* ---------- FOOTER ---------- */
.pk-footer{ border-top:1px solid var(--pk-line); padding-block:clamp(56px,8vw,90px) 40px; }
.pk-footer-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; }
@media(max-width:780px){ .pk-footer-top{ grid-template-columns:1fr 1fr; gap:34px; } }
.pk-footer .logo img{ height:30px; margin-bottom:18px; }
.pk-footer .blurb{ color:var(--pk-muted); font-size:15px; max-width:32ch; }
.pk-footer h6{ font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--pk-faint); margin-bottom:18px; }
.pk-footer ul{ list-style:none; display:flex; flex-direction:column; gap:12px; }
.pk-footer ul a{ color:var(--pk-muted); font-size:15px; transition:color .2s; }
.pk-footer ul a:hover{ color:var(--pk-fg); }
.pk-footer-bot{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:48px; padding-top:24px; border-top:1px solid var(--pk-line); color:var(--pk-faint); font-size:14px; }
.pk-footer-bot .links{ display:flex; gap:22px; }

/* ---------- REVEAL ---------- */
.pk-reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--pk-ease), transform .7s var(--pk-ease); }
.pk-reveal.in{ opacity:1; transform:none; }
@media(prefers-reduced-motion:reduce){ .pk-reveal{ opacity:1; transform:none; } }

/* ---------- BREADCRUMB ---------- */
.pk-crumb{ display:flex; gap:9px; align-items:center; justify-content:center; font-size:13px; color:var(--pk-muted); margin-bottom:22px; }
.pk-crumb a:hover{ color:var(--pk-primary-l); }
.pk-crumb .sep{ opacity:.5; }
.pk-crumb .here{ color:var(--pk-fg); }

/* ============================================================
   HERO FIVE (index-5 look): black bg + gridlines, pink script,
   yellow CTA, colorful app mockup, fact-feature bar.
   ============================================================ */
.pk-hero5{ position:relative; padding-top:clamp(130px,15vw,190px); padding-bottom:clamp(50px,7vw,90px); overflow:hidden; }
.pk-hero5::before{ content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size:33.333% 100%; background-position:16.6% 0; }
.pk-hero5-grid{ position:relative; z-index:2; display:grid; grid-template-columns:0.92fr 1.08fr; gap:clamp(30px,4vw,56px); align-items:center; }
@media(max-width:980px){ .pk-hero5-grid{ grid-template-columns:1fr; gap:40px; } }
.pk-badge-tag{ display:inline-block; font-weight:600; font-size:15px; letter-spacing:-.01em; color:#000; background:#fff; padding:5px 18px; border-radius:30px; margin-bottom:26px; }
.pk-hero5 h1{ font-weight:800; font-size:clamp(2.9rem,7vw,5.8rem); line-height:1.04; letter-spacing:-.03em; margin:0 0 28px; }
.pk-hero5 h1 .pre{ display:block; color:var(--pk-faint); font-weight:800; font-size:.62em; letter-spacing:-.02em; margin-bottom:.12em; }
.pk-hero5 h1 .line2{ display:block; }
.pk-hero5 h1 .script{ font-family:"Caveat",cursive; font-weight:700; color:var(--pk-script); letter-spacing:0; font-size:1.18em; line-height:1; }
.pk-hero5 .sub{ color:var(--pk-muted); font-size:clamp(17px,1.8vw,22px); line-height:1.5; margin:0 0 32px; max-width:34ch; }
.pk-hero5-actions{ display:flex; gap:16px; align-items:center; flex-wrap:wrap; }

/* fact-feature bar */
.pk-statbar{ position:relative; z-index:2; display:flex; gap:clamp(24px,4vw,56px); flex-wrap:wrap; margin-top:clamp(54px,7vw,90px); }
.pk-fact{ display:flex; align-items:center; gap:16px; max-width:280px; }
.pk-fact .ck{ flex:none; width:46px; height:46px; border-radius:50%; border:1px solid currentColor; display:grid; place-items:center; font-size:18px; }
.pk-fact:nth-child(1) .ck{ color:var(--pk-primary); }
.pk-fact:nth-child(2) .ck{ color:var(--pk-secondary); }
.pk-fact:nth-child(3) .ck{ color:var(--pk-primary-l); }
.pk-fact h3{ font-size:18px; font-weight:600; line-height:1.25; color:var(--pk-fg); }

/* ---------- APP MOCKUP (CSS-built project board) ---------- */
.pk-app-wrap{ position:relative; }
.pk-app-wrap .scribble{ position:absolute; top:-34px; left:34px; width:60px; height:40px; z-index:3; }
.pk-app-wrap .scribble path{ stroke:var(--pk-primary); stroke-width:5; fill:none; stroke-linecap:round; }
.pk-app{
  position:relative; z-index:2;
  background:#101012; color:#f4f4f6; border-radius:14px;
  box-shadow:0 50px 110px -40px rgba(0,0,0,.8); overflow:hidden;
  border:1px solid rgba(255,255,255,.08); font-size:11px;
}
/* browser chrome */
.pk-app .app-bar{ display:flex; align-items:center; gap:14px; padding:11px 14px; background:#1a1a1d; border-bottom:1px solid rgba(255,255,255,.07); }
.pk-app .app-bar .dots{ display:flex; gap:6px; }
.pk-app .app-bar .dots i{ width:10px; height:10px; border-radius:50%; display:block; }
.pk-app .app-bar .dots i:nth-child(1){ background:#ff5f57; } .pk-app .app-bar .dots i:nth-child(2){ background:#febc2e; } .pk-app .app-bar .dots i:nth-child(3){ background:#28c840; }
.pk-app .app-bar .url{ font-size:11px; color:rgba(255,255,255,.5); font-weight:500; }
/* body grid */
.pk-app .app-body{ display:grid; grid-template-columns:150px 1fr; min-height:330px; }
@media(max-width:560px){ .pk-app .app-body{ grid-template-columns:1fr; } .pk-app .app-side{ display:none; } }
/* sidebar */
.pk-app .app-side{ background:#161618; border-right:1px solid rgba(255,255,255,.07); padding:14px 12px; display:flex; flex-direction:column; gap:5px; }
.pk-app .app-brand{ display:flex; align-items:center; gap:7px; font-weight:700; font-size:12px; }
.pk-app .app-brand .b{ width:20px; height:20px; border-radius:6px; background:var(--pk-grad); display:grid; place-items:center; color:#fff; font-size:11px; }
.pk-app .app-wslabel{ margin:10px 0 8px; }
.pk-app .app-wslabel b{ display:block; font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.85); }
.pk-app .app-wslabel span{ font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.4); }
.pk-app .app-search{ display:flex; align-items:center; justify-content:space-between; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:7px; padding:6px 9px; font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:8px; }
.pk-app .app-search kbd{ font-size:8px; background:rgba(255,255,255,.08); border-radius:3px; padding:1px 4px; }
.pk-app .app-nav{ display:flex; align-items:center; gap:9px; padding:7px 8px; border-radius:7px; color:rgba(255,255,255,.6); font-weight:500; font-size:11px; }
.pk-app .app-nav .d{ width:13px; height:13px; border-radius:4px; background:rgba(255,255,255,.14); flex:none; }
.pk-app .app-nav.on{ background:color-mix(in srgb,var(--pk-primary) 22%,transparent); color:#fff; }
.pk-app .app-nav.on .d{ background:var(--pk-primary); }
.pk-app .app-sec{ font-size:8.5px; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.32); margin:12px 0 5px; display:flex; justify-content:space-between; }
.pk-app .app-proj{ display:flex; align-items:center; gap:8px; padding:4px 8px; font-weight:500; font-size:10.5px; color:rgba(255,255,255,.72); }
.pk-app .app-proj .dot{ width:6px; height:6px; border-radius:50%; flex:none; }
.pk-app .app-storage{ margin-top:auto; padding-top:12px; }
.pk-app .app-storage .lbl{ display:flex; justify-content:space-between; font-size:8.5px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:6px; }
.pk-app .app-storage .lbl b{ color:var(--pk-primary); }
.pk-app .app-storage .track{ height:4px; border-radius:3px; background:rgba(255,255,255,.1); overflow:hidden; }
.pk-app .app-storage .track i{ display:block; height:100%; width:68%; background:var(--pk-grad); border-radius:3px; }
/* main */
.pk-app .app-main{ padding:16px 16px; background:#101012; }
.pk-app .app-top{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:14px; }
.pk-app .app-greet h4{ font-size:16px; font-weight:700; letter-spacing:-.01em; margin-bottom:3px; }
.pk-app .app-greet span{ display:block; font-size:8.5px; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.4); }
.pk-app .app-find{ font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.4); background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:7px; padding:7px 11px; white-space:nowrap; }
.pk-app .app-cols{ display:grid; grid-template-columns:1.55fr 1fr; gap:11px; }
.pk-app .panel{ background:#161618; border:1px solid rgba(255,255,255,.07); border-radius:11px; padding:12px; }
.pk-app .panel + .panel{ margin-top:11px; }
.pk-app .panel .ph{ display:flex; align-items:center; justify-content:space-between; font-size:8.5px; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.45); margin-bottom:11px; }
.pk-app .panel .ph .lg{ display:inline-flex; align-items:center; gap:5px; }
.pk-app .panel .ph .lg em{ width:6px; height:6px; border-radius:50%; background:var(--pk-primary); font-style:normal; }
.pk-app .panel .ph .lg em.b{ background:rgba(255,255,255,.3); }
/* bar chart */
.pk-app .chart{ display:grid; grid-template-columns:repeat(7,1fr); gap:7px; align-items:end; height:74px; }
.pk-app .chart .col{ display:flex; flex-direction:column; align-items:center; gap:6px; height:100%; justify-content:flex-end; }
.pk-app .chart .bx{ width:60%; border-radius:3px 3px 0 0; background:var(--pk-grad); }
.pk-app .chart .bx.dim{ background:rgba(255,255,255,.14); }
.pk-app .chart .dy{ font-size:7.5px; letter-spacing:.06em; text-transform:uppercase; color:rgba(255,255,255,.35); }
/* recent activity */
.pk-app .act{ display:flex; gap:9px; align-items:flex-start; padding:7px 0; border-top:1px solid rgba(255,255,255,.06); }
.pk-app .act:first-of-type{ border-top:none; }
.pk-app .act .ai{ width:24px; height:24px; border-radius:7px; flex:none; display:grid; place-items:center; font-size:11px; }
.pk-app .act b{ display:block; font-size:10.5px; font-weight:600; color:#fff; }
.pk-app .act span{ font-size:9px; color:rgba(255,255,255,.42); }
/* team members */
.pk-app .team-ava{ display:flex; margin-bottom:9px; }
.pk-app .team-ava i{ width:26px; height:26px; border-radius:50%; margin-left:-7px; border:2px solid #161618; display:grid; place-items:center; font-size:8.5px; font-weight:700; color:#fff; }
.pk-app .team-ava i:first-child{ margin-left:0; }
.pk-app .team-cap{ font-size:8.5px; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.4); }
/* quick actions */
.pk-app .qa{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.pk-app .qa .q{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:9px; padding:11px 8px; text-align:center; }
.pk-app .qa .q .qi{ width:26px; height:26px; border-radius:8px; margin:0 auto 7px; display:grid; place-items:center; background:color-mix(in srgb,var(--pk-primary) 18%,transparent); color:var(--pk-primary); font-size:13px; }
.pk-app .qa .q span{ font-size:8.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.75); }
@media(max-width:640px){ .pk-app .app-cols{ grid-template-columns:1fr; } }

/* ---- Katalyst solo dashboard (gamified roadmap) ---- */
.pk-app .app-solo{ padding:16px 18px; }
.pk-app .kt-top{ display:flex; align-items:center; justify-content:space-between; padding-bottom:13px; border-bottom:1px solid rgba(255,255,255,.07); margin-bottom:14px; }
.pk-app .kt-top .kt-brand{ display:flex; align-items:center; gap:9px; font-weight:700; font-size:12px; }
.pk-app .kt-top .kt-brand .b{ width:20px; height:20px; border-radius:6px; background:var(--pk-grad); display:grid; place-items:center; color:#fff; font-size:11px; }
.pk-app .kt-top .kt-brand .tag{ background:var(--pk-primary); color:#fff; font-size:8.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:3px 8px; border-radius:20px; }
.pk-app .kt-stats{ display:flex; align-items:center; gap:12px; font-size:10px; font-weight:600; color:rgba(255,255,255,.7); }
.pk-app .kt-stats .xp{ color:var(--pk-primary); }
.pk-app .kt-stats .av{ width:24px; height:24px; border-radius:50%; background:var(--pk-grad); display:grid; place-items:center; font-size:9px; font-weight:700; color:#fff; }
.pk-app .kt-eyebrow{ font-size:8.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--pk-primary); font-weight:700; margin-bottom:6px; }
.pk-app .kt-welcome{ font-size:17px; font-weight:700; letter-spacing:-.01em; margin-bottom:6px; }
.pk-app .kt-sub{ font-size:11px; color:rgba(255,255,255,.55); margin-bottom:14px; }
.pk-app .kt-sub b{ color:#fff; }
.pk-app .kt-level{ display:flex; align-items:center; gap:11px; background:#161618; border:1px solid rgba(255,255,255,.07); border-radius:11px; padding:12px; margin-bottom:14px; }
.pk-app .kt-level .lv{ width:30px; height:30px; border-radius:50%; background:var(--pk-grad); display:grid; place-items:center; font-weight:800; font-size:13px; color:#fff; flex:none; }
.pk-app .kt-level .lvb{ flex:1; }
.pk-app .kt-level .lvb .row{ display:flex; justify-content:space-between; font-size:10px; margin-bottom:6px; }
.pk-app .kt-level .lvb .row b{ font-weight:600; } .pk-app .kt-level .lvb .row span{ color:rgba(255,255,255,.45); }
.pk-app .kt-level .track{ height:5px; border-radius:3px; background:rgba(255,255,255,.1); overflow:hidden; }
.pk-app .kt-level .track i{ display:block; height:100%; width:48%; background:var(--pk-grad); border-radius:3px; }
.pk-app .kt-caph{ font-size:8.5px; letter-spacing:.13em; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:9px; }
.pk-app .kt-task{ display:flex; align-items:center; gap:10px; padding:8px 0; border-top:1px solid rgba(255,255,255,.06); font-size:11px; }
.pk-app .kt-task:first-of-type{ border-top:none; }
.pk-app .kt-task .ck{ width:20px; height:20px; border-radius:50%; flex:none; display:grid; place-items:center; font-size:10px; }
.pk-app .kt-task .ck.done{ background:#37CC8D; color:#06281b; }
.pk-app .kt-task .ck.prog{ background:color-mix(in srgb,var(--pk-primary) 22%,transparent); color:var(--pk-primary); border:1px solid var(--pk-primary); }
.pk-app .kt-task .badge{ margin-left:auto; font-size:8px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--pk-primary); background:color-mix(in srgb,var(--pk-primary) 16%,transparent); padding:3px 7px; border-radius:20px; }
.pk-app .kt-action{ display:flex; align-items:center; gap:10px; background:#161618; border:1px solid rgba(255,255,255,.07); border-radius:10px; padding:11px; margin-top:12px; font-size:11px; }
.pk-app .kt-action .d{ width:7px; height:7px; border-radius:50%; background:#37CC8D; flex:none; }
.pk-app .kt-action .tg{ font-size:8px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:#37CC8D; background:rgba(55,204,141,.16); padding:3px 7px; border-radius:6px; }
.pk-app .kt-action .mark{ margin-left:auto; font-size:8.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--pk-primary); background:color-mix(in srgb,var(--pk-primary) 16%,transparent); padding:5px 10px; border-radius:7px; }

/* ---------- CLIENT STRIP ---------- */
.pk-clients{ border-block:1px solid var(--pk-line); padding-block:34px; }
.pk-clients-row{ display:flex; gap:clamp(28px,5vw,68px); justify-content:center; align-items:center; flex-wrap:wrap; opacity:.6; }
.pk-clients-row span{ font-size:clamp(17px,2vw,23px); font-weight:700; color:var(--pk-muted); letter-spacing:-.01em; }

/* ---------- NUMBERED HIGHLIGHTS (card-style-seven) ---------- */
.pk-highlights{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media(max-width:820px){ .pk-highlights{ grid-template-columns:1fr; } }
.pk-hl{ background:var(--pk-surface); border:1px solid var(--pk-line); border-radius:var(--pk-radius-lg); padding:clamp(28px,3vw,40px); transition:transform .4s var(--pk-ease), border-color .4s; }
.pk-hl:hover{ transform:translateY(-6px); border-color:var(--pk-line2); }
.pk-hl .no{ width:46px; height:46px; border-radius:50%; display:grid; place-items:center; font-weight:700; font-size:18px; margin-bottom:22px; }
.pk-hl:nth-child(1) .no{ background:color-mix(in srgb,var(--pk-primary) 16%,transparent); color:var(--pk-primary-l); }
.pk-hl:nth-child(2) .no{ background:color-mix(in srgb,var(--pk-secondary) 18%,transparent); color:var(--pk-secondary); }
.pk-hl:nth-child(3) .no{ background:color-mix(in srgb,var(--pk-cyan) 16%,transparent); color:var(--pk-cyan); }
.pk-hl h3{ font-size:21px; margin-bottom:11px; }
.pk-hl p{ color:var(--pk-muted); font-size:15.5px; }

/* ---------- INTEGRATIONS GRID ---------- */
.pk-integr{ display:flex; flex-wrap:wrap; gap:16px; justify-content:center; }
.pk-integr .tile{ width:78px; height:78px; border-radius:20px; background:var(--pk-surface); border:1px solid var(--pk-line); display:grid; place-items:center; font-size:26px; transition:transform .3s var(--pk-ease), border-color .3s; }
.pk-integr .tile:hover{ transform:translateY(-5px); border-color:var(--pk-primary-l); }

/* ---------- FEEDBACK / COMMUNITY ---------- */
.pk-feedback{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media(max-width:820px){ .pk-feedback{ grid-template-columns:1fr; } }
.pk-fb{ background:var(--pk-surface); border:1px solid var(--pk-line); border-radius:var(--pk-radius-lg); padding:30px; display:flex; flex-direction:column; gap:18px; }
.pk-fb .stars{ color:#FFC23A; letter-spacing:2px; font-size:14px; }
.pk-fb p{ color:var(--pk-fg); font-size:16px; line-height:1.5; flex:1; }
.pk-fb .who{ display:flex; align-items:center; gap:12px; }
.pk-fb .who .av{ width:42px; height:42px; border-radius:50%; background:var(--pk-grad); flex:none; }
.pk-fb .who b{ display:block; font-size:15px; } .pk-fb .who small{ color:var(--pk-muted); font-size:13px; }
