/* Marketing kit local styles — extends colors_and_type.css */
.mk-page {
  font-family: var(--font-sans);
  background: #fff;
  color: var(--fg-1);
  -webkit-font-smoothing: antialiased;
  margin: 0;
}
.mk-container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
@media (min-width: 1024px) { .mk-container { padding: 0 48px; } }

/* nav */
.mk-nav { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.78); backdrop-filter: blur(14px) saturate(180%); -webkit-backdrop-filter: blur(14px) saturate(180%); border-bottom: 1px solid var(--border-subtle); }
.mk-nav-row { height: 64px; display:flex; align-items:center; justify-content:space-between; }
.mk-nav-links { display:flex; gap: 28px; align-items:center; }
.mk-nav-link { color: var(--fg-2); text-decoration:none; font-size: 14px; font-weight: 500; letter-spacing: 0.02em; cursor: pointer; }
.mk-nav-link:hover { color: var(--fg-1); }
.mk-nav-cta { display:flex; gap: 12px; align-items:center; }

/* btn */
.mk-btn { font-family: var(--font-sans); font-weight: 500; letter-spacing: 0.25px; height: 44px; padding: 0 20px; border-radius: 6px; border: 1px solid transparent; display:inline-flex; align-items:center; gap: 8px; cursor: pointer; font-size: 14.5px; transition: all 200ms cubic-bezier(0.16,1,0.3,1); text-decoration:none; white-space: nowrap; }
.mk-btn-lg { height: 52px; padding: 0 26px; font-size: 16px; }
.mk-btn-primary { background: #2563EB; color: #fff; }
.mk-btn-primary:hover { background: #1D4ED8; box-shadow: var(--shadow-glow-blue); transform: translateY(-1px); }
.mk-btn-primary:active { transform: scale(0.98); }
.mk-btn-secondary { background: #fff; color: var(--fg-1); border-color: var(--border-strong); }
.mk-btn-secondary:hover { background: var(--bg-surface); border-color: var(--fg-3); }
.mk-btn-ghost { background: transparent; color: var(--fg-1); }
.mk-btn-ghost:hover { background: var(--bg-surface); }

/* hero */
.mk-hero { position: relative; padding: 88px 0 96px; overflow: hidden; }
.mk-hero::before {
  content: ''; position: absolute; inset: -10% -10% auto auto; width: 70%; height: 700px; pointer-events: none;
  background: radial-gradient(60% 60% at 70% 35%, rgba(34,197,94,0.18) 0%, rgba(37,99,235,0.18) 40%, rgba(255,255,255,0) 75%);
  filter: blur(20px);
}
.mk-hero-grid { display:grid; grid-template-columns: 1fr; gap: 40px; align-items: center; position: relative; }
@media (min-width: 1024px) { .mk-hero-grid { grid-template-columns: 1.05fr 1fr; gap: 56px; } .mk-hero { padding: 112px 0 128px; } }
.mk-hero h1 { font-size: clamp(40px, 5.4vw, 64px); line-height: 1.04; font-weight: 700; letter-spacing: -0.025em; margin: 18px 0 18px; color: var(--fg-1); text-wrap: balance; }
.mk-hero h1 em { font-style: normal; background: var(--brand-gradient); -webkit-background-clip: text; background-clip: text; color: transparent; }
.mk-hero p.lede { font-size: 19px; line-height: 1.55; color: var(--fg-2); max-width: 540px; margin: 0 0 28px; }
.mk-hero-ctas { display:flex; gap: 12px; align-items:center; flex-wrap: wrap; }
.mk-hero-meta { margin-top: 18px; font-size: 13px; color: var(--fg-3); display:flex; gap: 14px; align-items:center; }
.mk-hero-meta svg { color: #10B981; }

.mk-eyebrow { display:inline-flex; align-items:center; gap: 8px; font-size: 12px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--brand-primary); padding: 6px 12px; background: linear-gradient(135deg, #EFF6FF, #ECFDF5); border: 1px solid #BFDBFE; border-radius: 9999px; }
.mk-eyebrow .dot { width: 6px; height: 6px; border-radius: 9999px; background: var(--brand-gradient); }

/* hero artwork — fake product UI */
.mk-hero-art { position: relative; min-height: 420px; }
.mk-uicard { position: absolute; background: #fff; border: 1px solid var(--border-subtle); border-radius: 14px; box-shadow: var(--shadow-lg); padding: 16px; }
.mk-uicard-head { display:flex; align-items:center; justify-content:space-between; margin-bottom: 12px; }
.mk-uicard-title { font-weight: 600; font-size: 14px; color: var(--fg-1); }
.mk-tag { display:inline-flex; align-items:center; gap: 6px; padding: 3px 9px; border-radius: 9999px; font-size: 11px; font-weight: 600; border: 1px solid; }
.mk-tag.in-progress { background: var(--tag-feature-bg); color: var(--tag-feature-fg); border-color: var(--tag-feature-bd); }
.mk-tag.paid { background: var(--tag-improvement-bg); color: var(--tag-improvement-fg); border-color: var(--tag-improvement-bd); }
.mk-line { display:flex; justify-content:space-between; padding: 7px 0; font-size: 12.5px; color: var(--fg-2); border-bottom: 1px dashed var(--border-subtle); }
.mk-line:last-child { border-bottom: 0; }
.mk-line .num { font-family: var(--font-mono); color: var(--fg-1); font-weight: 500; }
.mk-total { display:flex; justify-content:space-between; padding-top: 10px; margin-top: 6px; border-top: 1px solid var(--border-subtle); font-weight: 600; }
.mk-total .num { font-family: var(--font-mono); color: var(--brand-primary); font-size: 15px; }

/* sections */
.mk-section { padding: 96px 0; }
.mk-section-tight { padding: 64px 0; }
.mk-section-bg { background: var(--bg-page); }
.mk-section-head { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.mk-section-head h2 { font-size: clamp(32px, 3.6vw, 44px); line-height: 1.1; font-weight: 700; letter-spacing: -0.02em; margin: 14px 0 14px; color: var(--fg-1); text-wrap: balance; }
.mk-section-head p { font-size: 18px; line-height: 1.55; color: var(--fg-2); margin: 0; }

/* problem→solution */
.mk-ps { display:grid; grid-template-columns: 1fr; gap: 20px; }
@media (min-width: 900px) { .mk-ps { grid-template-columns: 1fr 1fr 1fr; gap: 24px; } }
.mk-ps-card { background: #fff; border: 1px solid var(--border-subtle); border-radius: 14px; padding: 26px; box-shadow: var(--shadow-card); transition: all 250ms; }
.mk-ps-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.mk-ps-card .icon { width: 44px; height: 44px; border-radius: 12px; display:flex; align-items:center; justify-content:center; background: #FEE2E2; color: #DC2626; margin-bottom: 14px; }
.mk-ps-card.solution .icon { background: #D1FAE5; color: #047857; }
.mk-ps-card h3 { margin: 0 0 8px; font-size: 17px; font-weight: 600; }
.mk-ps-card p { margin: 0; font-size: 14.5px; color: var(--fg-3); line-height: 1.6; }

/* features grid */
.mk-features { display:grid; grid-template-columns: 1fr; gap: 18px; }
@media (min-width: 720px) { .mk-features { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .mk-features { grid-template-columns: 1fr 1fr 1fr; } }
.mk-feature { background: #fff; border: 1px solid var(--border-subtle); border-radius: 14px; padding: 28px; box-shadow: var(--shadow-card); transition: all 250ms; }
.mk-feature:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.mk-feature .icon { width: 44px; height: 44px; border-radius: 12px; display:flex; align-items:center; justify-content:center; background: #EFF6FF; color: var(--brand-primary); margin-bottom: 16px; }
.mk-feature h3 { margin: 0 0 8px; font-size: 17px; font-weight: 600; color: var(--fg-1); }
.mk-feature p { margin: 0; font-size: 14.5px; color: var(--fg-3); line-height: 1.6; }

/* pricing */
.mk-pricing { display:grid; grid-template-columns: 1fr; gap: 22px; max-width: 980px; margin: 0 auto; }
@media (min-width: 900px) { .mk-pricing { grid-template-columns: 1fr 1fr; } }
.mk-tier { position: relative; background: #fff; border: 1px solid var(--border-subtle); border-radius: 18px; padding: 36px 32px; box-shadow: var(--shadow-card); }
.mk-tier.recommended { background: linear-gradient(180deg, #fff 0%, #F0FBF4 220%); box-shadow: var(--shadow-glow-green); border: 1.5px solid transparent; background-clip: padding-box; }
.mk-tier.recommended::before { content:''; position:absolute; inset:-1.5px; border-radius: 18px; padding: 1.5px; background: var(--brand-gradient); -webkit-mask: linear-gradient(#000,#000) content-box, linear-gradient(#000,#000); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events:none; }
.mk-tier-ribbon { position:absolute; top: 20px; right: 20px; background: var(--brand-gradient); color: #fff; font-size: 11px; font-weight: 600; padding: 5px 12px; border-radius: 9999px; letter-spacing: 0.06em; text-transform: uppercase; box-shadow: var(--shadow-sm); animation: mkPulse 2.8s ease-in-out infinite; }
@keyframes mkPulse { 0%,100% { box-shadow: var(--shadow-sm); } 50% { box-shadow: var(--shadow-glow-green); } }
.mk-tier h3 { margin: 0; font-size: 20px; font-weight: 600; color: var(--fg-1); }
.mk-tier-tagline { margin: 6px 0 22px; color: var(--fg-3); font-size: 14px; }
.mk-tier-price { display:flex; align-items: baseline; gap: 4px; margin: 0 0 4px; }
.mk-tier-price .amount { font-size: 48px; font-weight: 700; color: var(--fg-1); letter-spacing: -0.025em; }
.mk-tier-price .currency { font-size: 22px; font-weight: 600; color: var(--fg-1); }
.mk-tier-price .period { font-size: 16px; color: var(--fg-3); margin-left: 4px; }
.mk-tier-extra { font-size: 13px; color: var(--fg-3); margin-bottom: 24px; min-height: 20px; }

/* refined tier CTA */
.mk-tier-cta { position: relative; display:flex; align-items:center; justify-content:space-between; gap: 12px; height: 52px; padding: 0 22px; border-radius: 10px; text-decoration: none; font-family: var(--font-sans); font-weight: 600; font-size: 15px; letter-spacing: 0.01em; transition: all 220ms cubic-bezier(0.16,1,0.3,1); overflow: hidden; }
.mk-tier-cta .label { position: relative; z-index: 1; }
.mk-tier-cta .arrow { position: relative; z-index: 1; display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border-radius: 9999px; transition: transform 240ms cubic-bezier(0.16,1,0.3,1); }
.mk-tier-cta:hover .arrow { transform: translateX(3px); }
.mk-tier-cta:active { transform: scale(0.99); }

.mk-tier-cta.is-primary { background: var(--fg-1); color: #fff; box-shadow: 0 1px 0 rgba(255,255,255,0.1) inset, var(--shadow-sm); }
.mk-tier-cta.is-primary::after { content: ''; position: absolute; inset: 0; background: var(--brand-gradient); opacity: 0; transition: opacity 240ms ease; }
.mk-tier-cta.is-primary:hover { box-shadow: var(--shadow-glow-blue); transform: translateY(-1px); }
.mk-tier-cta.is-primary:hover::after { opacity: 1; }
.mk-tier-cta.is-primary .arrow { background: rgba(255,255,255,0.16); }

.mk-tier-cta.is-secondary { background: #fff; color: var(--fg-1); border: 1px solid var(--border-strong); }
.mk-tier-cta.is-secondary:hover { border-color: var(--fg-1); background: var(--bg-surface); }
.mk-tier-cta.is-secondary .arrow { background: var(--bg-surface); color: var(--fg-2); }
.mk-tier-cta.is-secondary:hover .arrow { background: var(--fg-1); color: #fff; }

.mk-tier-features { list-style: none; padding: 0; margin: 24px 0 0; display:flex; flex-direction:column; gap: 10px; border-top: 1px solid var(--border-subtle); padding-top: 22px; }
.mk-tier-features li { display:flex; align-items: flex-start; gap: 10px; font-size: 14.5px; color: var(--fg-2); line-height: 1.5; }
.mk-tier-features li svg { color: #10B981; flex-shrink: 0; margin-top: 3px; }

/* CTA band */
.mk-cta-band { padding: 96px 0; background: linear-gradient(135deg, #0F172A 0%, #1D4ED8 70%, #047857 130%); color: #fff; text-align:center; }
.mk-cta-band h2 { font-size: clamp(32px, 4vw, 48px); font-weight: 700; letter-spacing: -0.02em; margin: 0 0 16px; color: #fff; line-height: 1.1; text-wrap: balance; }
.mk-cta-band p { font-size: 18px; color: rgba(255,255,255,0.78); max-width: 560px; margin: 0 auto 28px; line-height: 1.5; }
.mk-cta-band .mk-btn-primary { background: #fff; color: #0F172A; }
.mk-cta-band .mk-btn-primary:hover { background: #fff; box-shadow: 0 12px 32px -8px rgba(255,255,255,0.5); }
.mk-cta-band .mk-btn-ghost { color: #fff; }
.mk-cta-band .mk-btn-ghost:hover { background: rgba(255,255,255,0.1); }

/* footer */
.mk-footer { padding: 64px 0 32px; background: var(--bg-page); border-top: 1px solid var(--border-subtle); }
.mk-footer-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
@media (max-width: 900px) { .mk-footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .mk-footer-grid { grid-template-columns: 1fr; } }
.mk-footer h4 { font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-3); margin: 0 0 16px; }
.mk-footer ul { list-style: none; padding: 0; margin: 0; display:flex; flex-direction:column; gap: 10px; }
.mk-footer a { color: var(--fg-2); text-decoration: none; font-size: 14px; cursor: pointer; }
.mk-footer a:hover { color: var(--fg-1); text-decoration: underline; }
.mk-footer-bottom { display:flex; justify-content: space-between; padding-top: 28px; border-top: 1px solid var(--border-subtle); color: var(--fg-3); font-size: 13px; gap: 16px; flex-wrap: wrap; }
.mk-footer-blurb { color: var(--fg-3); font-size: 14px; line-height: 1.6; max-width: 320px; margin: 14px 0 18px; }

/* changelog */
.mk-changelog { padding: 80px 0 64px; max-width: 760px; margin: 0 auto; }
.mk-changelog-head { padding-bottom: 28px; margin-bottom: 32px; border-bottom: 1px solid var(--border-subtle); display:flex; align-items: flex-start; gap: 16px; }
.mk-changelog-head .icon-tile { width: 44px; height: 44px; border-radius: 12px; background: #EFF6FF; color: var(--brand-primary); display:flex; align-items:center; justify-content:center; flex-shrink: 0; }
.mk-changelog-head h1 { font-size: 32px; font-weight: 700; letter-spacing: -0.02em; margin: 0; color: var(--fg-1); }
.mk-changelog-head .sub { color: var(--fg-3); margin: 4px 0 12px; font-size: 14.5px; }
.mk-changelog-head .ver { font-size: 13.5px; color: var(--fg-2); font-weight: 500; }
.mk-changelog-head .ver b { color: var(--brand-primary); font-weight: 600; }

.mk-cl-list { display:flex; flex-direction:column; gap: 18px; padding: 0; margin: 0; list-style: none; }
.mk-cl-entry { background: #fff; border: 1px solid var(--border-subtle); border-radius: 14px; box-shadow: var(--shadow-xs); overflow: hidden; }
.mk-cl-entry-head { padding: 18px 22px; border-bottom: 1px solid var(--border-subtle); display:flex; align-items:center; justify-content:space-between; gap: 12px; flex-wrap: wrap; }
.mk-cl-version { font-family: var(--font-mono); font-size: 16px; font-weight: 700; color: var(--brand-primary); letter-spacing: -0.01em; }
.mk-cl-date { font-size: 12.5px; font-weight: 500; color: var(--fg-3); }
.mk-cl-title { padding: 4px 22px 0; font-size: 16px; font-weight: 600; color: var(--fg-1); }
.mk-cl-body { padding: 14px 22px 20px; }
.mk-cl-section { border-left: 2px solid var(--border-strong); padding: 2px 0 2px 16px; margin-bottom: 16px; }
.mk-cl-section:last-child { margin-bottom: 0; }
.mk-cl-section.feature { border-color: #93C5FD; }
.mk-cl-section.fix { border-color: #FDBA74; }
.mk-cl-section.improvement { border-color: #6EE7B7; }
.mk-cl-section.hotfix { border-color: #FCA5A5; }
.mk-cl-section .label { display:flex; align-items:center; gap: 8px; margin-bottom: 8px; }
.mk-cl-section .label-text { font-size: 11.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.07em; color: var(--fg-3); }
.mk-cl-items { list-style: none; padding: 0; margin: 0; display:flex; flex-direction:column; gap: 6px; }
.mk-cl-items li { display:flex; align-items: flex-start; gap: 10px; font-size: 14px; color: var(--fg-2); line-height: 1.55; }
.mk-cl-items li::before { content:''; width: 5px; height: 5px; border-radius: 9999px; background: var(--fg-muted); margin-top: 9px; flex-shrink:0; }

.mk-cl-tag { display:inline-flex; align-items:center; gap: 6px; padding: 3px 10px; border-radius: 9999px; font-size: 11px; font-weight: 600; border: 1px solid; letter-spacing: 0.02em; }
.mk-cl-tag.feature { background: var(--tag-feature-bg); color: var(--tag-feature-fg); border-color: var(--tag-feature-bd); }
.mk-cl-tag.fix { background: var(--tag-fix-bg); color: var(--tag-fix-fg); border-color: var(--tag-fix-bd); }
.mk-cl-tag.improvement { background: var(--tag-improvement-bg); color: var(--tag-improvement-fg); border-color: var(--tag-improvement-bd); }
.mk-cl-tag.hotfix { background: var(--tag-hotfix-bg); color: var(--tag-hotfix-fg); border-color: var(--tag-hotfix-bd); }
.mk-cl-tag.internal { background: var(--tag-internal-bg); color: var(--tag-internal-fg); border-color: var(--tag-internal-bd); }

/* ============ FEATURES PAGE ============ */
.mk-feat-anchors { display:flex; flex-wrap: wrap; gap: 8px; justify-content:center; max-width: 820px; margin: 8px auto 0; }
.mk-feat-anchor { padding: 8px 14px; border-radius: 9999px; font-size: 13px; font-weight: 500; color: var(--fg-2); background: #fff; border: 1px solid var(--border-subtle); text-decoration: none; transition: all 200ms; }
.mk-feat-anchor:hover { color: var(--fg-1); border-color: var(--brand-primary); box-shadow: var(--shadow-xs); }

.mk-feat-group { padding: 72px 0; border-bottom: 1px solid var(--border-subtle); }
.mk-feat-group:last-of-type { border-bottom: 0; }
.mk-feat-group:nth-of-type(even) { background: var(--bg-page); }
.mk-feat-grid { display:grid; grid-template-columns: 1fr; gap: 48px; align-items: center; }
@media (min-width: 1024px) { .mk-feat-grid { grid-template-columns: 0.95fr 1.05fr; gap: 64px; } .mk-feat-group.flip .mk-feat-grid { grid-template-columns: 1.05fr 0.95fr; } .mk-feat-group.flip .mk-feat-copy { order: 2; } .mk-feat-group.flip .mk-feat-art { order: 1; } }
.mk-feat-copy h2 { font-size: clamp(28px, 3vw, 36px); line-height: 1.12; letter-spacing: -0.02em; font-weight: 700; margin: 14px 0 14px; color: var(--fg-1); text-wrap: balance; }
.mk-feat-copy > p { font-size: 17px; line-height: 1.55; color: var(--fg-2); margin: 0 0 24px; max-width: 540px; }
.mk-feat-items { display:grid; grid-template-columns: 1fr; gap: 18px; max-width: 540px; }
@media (min-width: 640px) { .mk-feat-items { grid-template-columns: 1fr 1fr; gap: 22px 24px; } }
.mk-feat-item { display:flex; gap: 12px; align-items: flex-start; }
.mk-feat-item .icon { flex-shrink: 0; width: 36px; height: 36px; border-radius: 10px; background: #EFF6FF; color: var(--brand-primary); display:flex; align-items:center; justify-content:center; }
.mk-feat-item h4 { margin: 0 0 4px; font-size: 14.5px; font-weight: 600; color: var(--fg-1); }
.mk-feat-item p { margin: 0; font-size: 13.5px; color: var(--fg-3); line-height: 1.55; }
.mk-feat-art { position: relative; }

/* ============ PRODUCT SCREEN MOCK ============ */
.ps-chrome { background: #fff; border: 1px solid var(--border-subtle); border-radius: 14px; box-shadow: var(--shadow-lg); overflow: hidden; transform-origin: center; }
.ps-bar { height: 36px; background: #F1F5F9; border-bottom: 1px solid var(--border-subtle); display:flex; align-items:center; justify-content:space-between; padding: 0 14px; }
.ps-dots { display:flex; gap: 6px; }
.ps-dots i { width: 10px; height: 10px; border-radius: 9999px; display:block; background: #CBD5E1; }
.ps-dots i:nth-child(1) { background: #F87171; }
.ps-dots i:nth-child(2) { background: #FBBF24; }
.ps-dots i:nth-child(3) { background: #34D399; }
.ps-url { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); background: #fff; padding: 4px 12px; border-radius: 9999px; border: 1px solid var(--border-subtle); }
.ps-app { display:flex; min-height: 420px; }
.ps-side { width: 138px; background: #FAFAF9; border-right: 1px solid var(--border-subtle); padding: 12px 8px; display:flex; flex-direction:column; gap: 2px; flex-shrink: 0; }
.ps-side-logo { display:flex; align-items:center; gap: 8px; padding: 6px 8px 14px; font-weight: 700; font-size: 13px; color: var(--fg-1); }
.ps-logo-mark { width: 18px; height: 18px; border-radius: 5px; background: var(--brand-gradient); }
.ps-side-item { display:flex; align-items:center; gap: 8px; padding: 7px 10px; border-radius: 6px; font-size: 12.5px; color: var(--fg-2); cursor: default; }
.ps-side-item .ico { width: 18px; text-align: center; color: var(--fg-3); font-size: 13px; }
.ps-side-item.active { background: #fff; color: var(--brand-primary); font-weight: 600; box-shadow: var(--shadow-xs); }
.ps-side-item.active .ico { color: var(--brand-primary); }
.ps-main { flex: 1; padding: 22px 24px; overflow: hidden; }

.ps-page-head { display:flex; justify-content:space-between; align-items:flex-start; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.ps-eyebrow { font-size: 11px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-3); margin-bottom: 2px; }
.ps-h1 { font-size: 19px; font-weight: 700; letter-spacing: -0.01em; color: var(--fg-1); }
.ps-h1-count { font-size: 14px; color: var(--fg-3); font-weight: 500; margin-left: 4px; }
.ps-h3 { font-size: 14px; font-weight: 600; color: var(--fg-1); }
.ps-pill-group { display:flex; gap: 6px; flex-wrap: wrap; align-items:center; }
.ps-chip { padding: 5px 11px; border-radius: 7px; font-size: 12px; font-weight: 500; background: #fff; border: 1px solid var(--border-subtle); color: var(--fg-2); }
.ps-chip-primary { background: #2563EB; color: #fff; border-color: #2563EB; font-weight: 600; }
.ps-chip-mini { font-size: 10.5px; font-weight: 600; padding: 2px 8px; border-radius: 9999px; background: var(--bg-surface); color: var(--fg-3); border: 1px solid var(--border-subtle); }
.ps-chip-mini.on { background: #DCFCE7; color: #166534; border-color: #BBF7D0; }
.ps-row { display:flex; align-items:center; gap: 10px; }
.ps-mono { font-family: var(--font-mono); font-size: 12.5px; }

.ps-tag { display:inline-flex; align-items:center; gap: 4px; padding: 2px 8px; border-radius: 9999px; font-size: 10.5px; font-weight: 600; border: 1px solid; letter-spacing: 0.01em; }
.ps-tag-in-progress { background: #DBEAFE; color: #1E40AF; border-color: #BFDBFE; }
.ps-tag-wait { background: #FEF3C7; color: #92400E; border-color: #FDE68A; }
.ps-tag-ready { background: #DCFCE7; color: #166534; border-color: #BBF7D0; }

/* kanban */
.ps-kanban { display:grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.ps-col { background: #FAFAF9; border: 1px solid var(--border-subtle); border-radius: 10px; padding: 10px; display:flex; flex-direction:column; gap: 8px; }
.ps-col-head { display:flex; justify-content:space-between; padding: 4px 6px 8px; border-bottom: 1px dashed var(--border-subtle); font-size: 12px; font-weight: 600; color: var(--fg-2); }
.ps-count { font-family: var(--font-mono); color: var(--fg-3); font-weight: 500; }
.ps-card-mini { background: #fff; border: 1px solid var(--border-subtle); border-radius: 8px; padding: 10px; display:flex; flex-direction:column; gap: 4px; box-shadow: var(--shadow-xs); }
.ps-card-title { font-size: 13px; font-weight: 600; color: var(--fg-1); }
.ps-card-sub { font-size: 11.5px; color: var(--fg-3); }

/* POS */
.ps-pos { display:grid; grid-template-columns: 1fr 280px; gap: 14px; }
.ps-pos-left { display:flex; flex-direction:column; gap: 12px; }
.ps-pos-search { padding: 10px 14px; border: 1px solid var(--border-subtle); border-radius: 8px; background: #fff; font-size: 12.5px; color: var(--fg-3); }
.ps-pos-grid { display:grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 8px; }
.ps-pos-item { background: #fff; border: 1px solid var(--border-subtle); border-radius: 8px; padding: 10px; }
.ps-pos-thumb { height: 36px; background: linear-gradient(135deg, #F1F5F9, #E2E8F0); border-radius: 5px; margin-bottom: 8px; }
.ps-pos-name { font-size: 11.5px; font-weight: 500; color: var(--fg-1); line-height: 1.3; margin-bottom: 4px; }
.ps-pos-price { font-family: var(--font-mono); font-size: 11.5px; font-weight: 600; color: var(--brand-primary); }
.ps-pos-right { background: #fff; border: 1px solid var(--border-subtle); border-radius: 10px; padding: 12px; display:flex; flex-direction:column; gap: 8px; }
.ps-pos-cust { padding: 8px 10px; background: #FAFAF9; border-radius: 7px; }
.ps-pos-line { display:flex; justify-content:space-between; align-items:center; padding: 6px 4px; border-bottom: 1px dashed var(--border-subtle); }
.ps-line-name { font-size: 12px; font-weight: 500; color: var(--fg-1); }
.ps-pos-totals { padding: 8px 4px 4px; font-size: 12px; color: var(--fg-2); display:flex; flex-direction:column; gap: 4px; border-top: 1px solid var(--border-subtle); margin-top: 4px; }
.ps-pos-grand { padding-top: 6px; border-top: 1px solid var(--border-subtle); margin-top: 4px; font-weight: 700; font-size: 14px; color: var(--fg-1); }
.ps-pos-pay { background: var(--brand-gradient); color: #fff; padding: 10px; border-radius: 8px; text-align:center; font-weight: 600; font-size: 13px; box-shadow: var(--shadow-glow-blue); }
.ps-pay-mini { flex: 1; padding: 6px; border: 1px solid var(--border-subtle); border-radius: 6px; text-align:center; font-size: 11.5px; color: var(--fg-2); background: #fff; }
.ps-pay-mini.active { border-color: var(--brand-primary); color: var(--brand-primary); font-weight: 600; }

/* tables */
.ps-table { background: #fff; border: 1px solid var(--border-subtle); border-radius: 10px; overflow: hidden; }
.ps-thead, .ps-trow { display:flex; align-items:center; gap: 12px; padding: 9px 14px; font-size: 12.5px; }
.ps-thead { background: #FAFAF9; border-bottom: 1px solid var(--border-subtle); font-weight: 600; color: var(--fg-3); font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; }
.ps-trow { border-bottom: 1px solid var(--border-subtle); color: var(--fg-1); }
.ps-trow:last-child { border-bottom: 0; }

/* stats */
.ps-stat-grid { display:grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 10px; }
.ps-stat { background: #fff; border: 1px solid var(--border-subtle); border-radius: 8px; padding: 12px 14px; }
.ps-stat-lbl { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--fg-3); margin-bottom: 4px; }
.ps-stat-val { font-size: 20px; font-weight: 700; color: var(--fg-1); letter-spacing: -0.01em; }
.ps-stat-sub { font-size: 11.5px; color: var(--fg-3); margin-top: 2px; }

/* chart */
.ps-chart { background: #fff; border: 1px solid var(--border-subtle); border-radius: 10px; padding: 14px; margin-top: 14px; }
.ps-chart-head { display:flex; justify-content:space-between; align-items:center; margin-bottom: 12px; }
.ps-bars { display:flex; align-items:flex-end; gap: 12px; height: 140px; padding: 0 4px; }
.ps-bar-col { flex: 1; display:flex; flex-direction:column; align-items:center; gap: 6px; height: 100%; }
.ps-bar-wrap { flex: 1; display:flex; align-items:flex-end; width: 100%; }
.ps-bar { width: 100%; background: var(--brand-gradient); border-radius: 4px 4px 0 0; min-height: 4px; }
.ps-bar-lbl { font-size: 11px; color: var(--fg-3); font-weight: 500; }

/* ============ CHANGELOG — latest badge + fade-in ============ */
.mk-cl-latest-badge {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #fff;
  background: var(--brand-gradient);
  padding: 3px 9px;
  border-radius: 9999px;
  box-shadow: 0 1px 0 rgba(255,255,255,0.2) inset, 0 2px 8px rgba(37, 99, 235, 0.25);
}
.mk-cl-entry.is-latest { border-color: rgba(37, 99, 235, 0.35); box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.08), var(--shadow-sm); }
.mk-cl-entry.is-latest .mk-cl-entry-head { background: linear-gradient(90deg, rgba(37, 99, 235, 0.04), rgba(16, 185, 129, 0.04)); }

@keyframes mk-cl-fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.mk-cl-entry { animation: mk-cl-fade-in 460ms cubic-bezier(0.2, 0.7, 0.2, 1) both; }
@media (prefers-reduced-motion: reduce) {
  .mk-cl-entry { animation: none; }
}
