/* ============================================================================
   Evgeny Ksenchenko — Blog v3 (Linear Premium SaaS)
   Inspired by linear.app / framer.com / attio.com
   Light theme by default, dark via prefers-color-scheme
   ========================================================================== */

/* ===== Reset & base ===== */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
body.ekb-blog{margin:0;font-family:'Inter',ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;font-feature-settings:"ss03","cv11","cv01","cv02";font-size:16px;line-height:1.6;color:var(--ink);background:var(--bg);min-height:100vh;position:relative;overflow-x:hidden}
.ekb-blog img,.ekb-blog picture,.ekb-blog video,.ekb-blog svg{display:block;max-width:100%;height:auto}
.ekb-blog button,.ekb-blog input,.ekb-blog select,.ekb-blog textarea{font:inherit;color:inherit;background:none;border:0}
.ekb-blog button{cursor:pointer}
.ekb-blog a{color:inherit;text-decoration:none}
.ekb-blog hr{border:0;height:1px;background:var(--border);margin:48px 0}
.ekb-visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ===== Container ===== */
.ekb-blog .ekb-container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px;position:relative;z-index:1}
@media(max-width:640px){.ekb-blog .ekb-container{padding:0 20px}}

/* ===== Header ===== */
.ekb-blog .ekb-header{position:sticky;top:0;z-index:50;backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);background:var(--surface-glass);border-bottom:1px solid var(--border-2)}
.ekb-blog .ekb-header__inner{display:flex;align-items:center;gap:24px;height:60px}
.ekb-blog .ekb-logo{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--ink);white-space:nowrap}
.ekb-blog .ekb-logo::before{content:"ЕК";width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,#5E6AD2 0%,#4F5BC2 100%);display:grid;place-items:center;color:#fff;font-weight:700;font-size:11px;letter-spacing:-.02em;box-shadow:inset 0 1px 0 rgba(255,255,255,.2),0 1px 3px rgba(94,106,210,.35);flex-shrink:0}
.ekb-blog .ekb-logo:hover{color:var(--ink)}
.ekb-blog .ekb-nav{display:none;flex:1}
@media(min-width:881px){.ekb-blog .ekb-nav{display:block}}
.ekb-blog .ekb-nav__list{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:4px}
.ekb-blog .ekb-nav__list a{display:inline-block;font-size:13.5px;font-weight:500;color:var(--ink-2);padding:7px 12px;border-radius:var(--r-sm);transition:color .15s var(--ease),background .15s var(--ease);letter-spacing:-.005em}
.ekb-blog .ekb-nav__list a:hover{color:var(--ink);background:var(--surface-soft)}
.ekb-blog .ekb-header__actions{margin-left:auto;display:flex;align-items:center;gap:6px}
.ekb-blog .ekb-icon-btn{width:32px;height:32px;display:grid;place-items:center;border-radius:var(--r-sm);color:var(--ink-2);transition:background .15s var(--ease),color .15s var(--ease);background:transparent;border:0}
.ekb-blog .ekb-icon-btn:hover{background:var(--surface-soft);color:var(--ink)}
.ekb-blog .ekb-icon-btn svg{width:16px;height:16px}
.ekb-blog .ekb-menu-toggle{display:inline-flex}
@media(min-width:881px){.ekb-blog .ekb-menu-toggle{display:none}}
.ekb-blog .ekb-search-panel{padding:16px 0;border-top:1px solid var(--border-2)}
.ekb-blog .ekb-search-panel[hidden]{display:none}
.ekb-blog .ekb-skip{position:absolute;left:-9999px;top:auto}
.ekb-blog .ekb-skip:focus{position:fixed;top:8px;left:8px;background:var(--ink);color:var(--bg);padding:8px 12px;z-index:9999}

/* Search form (compact, Linear-style) */
.ekb-blog .ekb-search{display:flex;align-items:center;width:100%;max-width:560px;margin:0 auto;border:1px solid var(--border);background:var(--bg-elev);padding:6px 8px 6px 16px;border-radius:var(--r-md);transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}
.ekb-blog .ekb-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.ekb-blog .ekb-search input[type="search"]{flex:1;border:0;background:transparent;font:inherit;font-size:14px;color:var(--ink);padding:8px 0;outline:none;min-width:0}
.ekb-blog .ekb-search input[type="search"]::placeholder{color:var(--ink-3)}
.ekb-blog .ekb-search button{width:32px;height:32px;border-radius:var(--r-sm);background:linear-gradient(180deg,#6671DA 0%,#5560CE 100%);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.15),0 1px 2px rgba(94,106,210,.35);transition:all .15s var(--ease)}
.ekb-blog .ekb-search button:hover{background:linear-gradient(180deg,#7180E0 0%,#5E6AD2 100%)}

/* Mobile menu */
.ekb-blog .ekb-mobile-menu{position:fixed;inset:60px 0 0 0;background:var(--bg);z-index:49;overflow-y:auto;padding:24px 0;border-top:1px solid var(--border-2)}
.ekb-blog .ekb-mobile-menu[hidden]{display:none}
.ekb-blog .ekb-mobile-menu__list{list-style:none;margin:0 0 32px;padding:0}
.ekb-blog .ekb-mobile-menu__list a{display:flex;align-items:center;justify-content:space-between;padding:14px 0;font-size:16px;color:var(--ink-1);font-weight:500;border-bottom:1px solid var(--border-2);transition:color .15s var(--ease)}
.ekb-blog .ekb-mobile-menu__list a:hover{color:var(--accent)}
.ekb-blog .ekb-mobile-menu .ekb-count{font-size:12px;color:var(--ink-3);font-variant-numeric:tabular-nums;font-weight:400}

/* ===== Progress bar ===== */
.ekb-blog .ekb-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-hover));z-index:100;transition:width 80ms linear;box-shadow:0 1px 4px rgba(94,106,210,.4);will-change:width}

/* ===== Hero (главная блога / archive / search / 404) ===== */
.ekb-blog .ekb-hero{padding:80px 0 32px;position:relative;z-index:1}
@media(max-width:640px){.ekb-blog .ekb-hero{padding:56px 0 24px}}
.ekb-blog .ekb-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--accent);background:var(--accent-bg);padding:5px 12px 5px 10px;border-radius:var(--r-pill);letter-spacing:-.005em;margin-bottom:20px;border:1px solid rgba(94,106,210,.15)}
.ekb-blog .ekb-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(94,106,210,.15);animation:ekbPulse 2.4s var(--ease) infinite;flex-shrink:0}
@keyframes ekbPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.92)}}
.ekb-blog .ekb-h1-page{font-size:clamp(36px,5.5vw,56px);line-height:1.05;letter-spacing:-.025em;font-weight:600;color:var(--ink);max-width:880px;margin:0 0 18px;font-family:inherit}
.ekb-blog .ekb-hero__sub{font-size:18px;line-height:1.55;color:var(--ink-2);max-width:620px;margin:0;letter-spacing:-.005em}

/* ===== Breadcrumbs ===== */
.ekb-blog .ekb-breadcrumbs{padding:0;margin:0 0 36px;font-size:13px;color:var(--ink-3)}
@media(max-width:640px){.ekb-blog .ekb-breadcrumbs{margin:0 0 24px}}
.ekb-blog .ekb-breadcrumbs__list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.ekb-blog .ekb-breadcrumbs__item{display:inline-flex;align-items:center;gap:8px}
.ekb-blog .ekb-breadcrumbs__item:not(:last-child)::after{content:"/";color:var(--ink-4);margin-left:8px}
.ekb-blog .ekb-breadcrumbs a{color:var(--ink-2);transition:color .15s var(--ease)}
.ekb-blog .ekb-breadcrumbs a:hover{color:var(--accent)}
.ekb-blog .ekb-breadcrumbs__item:last-child span{color:var(--ink);font-weight:500}

/* ===== Cards (главная, archive, related) ===== */
.ekb-blog .ekb-card{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-xs);transition:all .3s var(--ease);position:relative}
.ekb-blog .ekb-card:hover{transform:translateY(-3px);border-color:var(--border);box-shadow:var(--shadow-md)}
.ekb-blog .ekb-card__link{display:flex;flex-direction:column;flex:1;color:inherit;text-decoration:none}
.ekb-blog .ekb-card__cover{aspect-ratio:16/9;overflow:hidden;background:var(--surface-soft);position:relative;border-bottom:1px solid var(--border-2)}
.ekb-blog .ekb-card__cover img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.ekb-blog .ekb-card:hover .ekb-card__cover img{transform:scale(1.04)}
.ekb-blog .ekb-card__body{padding:22px;display:flex;flex-direction:column;flex:1}
.ekb-blog .ekb-card__cat{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;font-weight:500;color:var(--accent);background:var(--accent-bg);border:1px solid rgba(94,106,210,.12);border-radius:var(--r-sm);letter-spacing:0;width:max-content;margin-bottom:12px}
.ekb-blog .ekb-card__cat::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0}
.ekb-blog .ekb-card__title{font-size:17px;font-weight:600;line-height:1.3;letter-spacing:-.013em;color:var(--ink);margin:0 0 8px;font-family:inherit;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;transition:color .15s var(--ease)}
.ekb-blog .ekb-card:hover .ekb-card__title{color:var(--accent)}
.ekb-blog .ekb-card__excerpt{font-size:13.5px;line-height:1.55;color:var(--ink-2);margin:0 0 18px;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-weight:400}
.ekb-blog .ekb-card__meta{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-3);padding-top:14px;border-top:1px solid var(--border-2);font-weight:500}
.ekb-blog .ekb-dot{color:var(--ink-4)}
.ekb-blog .ekb-card__read{color:var(--ink-3)}

/* ===== Card — hero variant (featured большой пост) ===== */
.ekb-blog .ekb-card--hero{margin-bottom:64px;display:grid;grid-template-columns:1.1fr 1fr;align-items:stretch;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-md);position:relative;transition:all .4s var(--ease)}
.ekb-blog .ekb-card--hero::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(94,106,210,.03),transparent 40%);pointer-events:none;border-radius:var(--r-xl);z-index:0}
.ekb-blog .ekb-card--hero:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.ekb-blog .ekb-card--hero .ekb-card__link{display:contents}
.ekb-blog .ekb-card--hero .ekb-card__cover--hero{position:relative;overflow:hidden;min-height:380px;background:var(--surface-soft);aspect-ratio:auto;border-bottom:0;border-right:1px solid var(--border-2);grid-row:1;grid-column:1}
.ekb-blog .ekb-card--hero .ekb-card__cover--hero img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.ekb-blog .ekb-card--hero:hover .ekb-card__cover--hero img{transform:scale(1.03)}
.ekb-blog .ekb-card__cover-overlay{display:none}
.ekb-blog .ekb-card__body--hero{padding:44px 44px 40px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1;grid-row:1;grid-column:2}
.ekb-blog .ekb-card__cat--hero{margin-bottom:16px}
.ekb-blog .ekb-card__title--hero{font-size:clamp(24px,2.6vw,34px);line-height:1.15;letter-spacing:-.022em;font-weight:600;color:var(--ink);margin:0 0 14px;-webkit-line-clamp:3}
.ekb-blog .ekb-card--hero:hover .ekb-card__title--hero{color:var(--ink)}
.ekb-blog .ekb-card__excerpt--hero{font-size:15.5px;line-height:1.6;color:var(--ink-2);margin:0 0 24px;-webkit-line-clamp:3}
.ekb-blog .ekb-card__meta--hero{margin-top:auto;border-top:0;padding-top:0;font-size:13px}
@media(max-width:880px){
	.ekb-blog .ekb-card--hero{grid-template-columns:1fr}
	.ekb-blog .ekb-card--hero .ekb-card__cover--hero{min-height:240px;border-right:0;border-bottom:1px solid var(--border-2)}
	.ekb-blog .ekb-card__body--hero{padding:28px 24px 32px;grid-column:1;grid-row:2}
}

/* ===== Grid ===== */
.ekb-blog .ekb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:980px){.ekb-blog .ekb-grid{grid-template-columns:repeat(2,1fr);gap:22px}}
@media(max-width:640px){.ekb-blog .ekb-grid{grid-template-columns:1fr;gap:20px}}
.ekb-blog .ekb-grid--cards{margin:0 0 80px}
.ekb-blog .ekb-grid--3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:980px){.ekb-blog .ekb-grid--3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.ekb-blog .ekb-grid--3{grid-template-columns:1fr}}

/* ===== Pagination ===== */
.ekb-blog .ekb-pagination{margin:48px 0 80px}
.ekb-blog .ekb-pagination ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:4px}
.ekb-blog .ekb-pagination a,.ekb-blog .ekb-pagination .current,.ekb-blog .ekb-pagination .dots{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 12px;font-size:13.5px;font-weight:500;color:var(--ink-1);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-xs);font-variant-numeric:tabular-nums;transition:all .15s var(--ease);text-decoration:none}
.ekb-blog .ekb-pagination a:hover{background:var(--surface-soft);transform:translateY(-1px);box-shadow:var(--shadow-sm);color:var(--ink)}
.ekb-blog .ekb-pagination .current{background:linear-gradient(180deg,#6671DA 0%,#5560CE 100%);color:#fff;border-color:transparent;box-shadow:inset 0 1px 0 rgba(255,255,255,.15),0 1px 2px rgba(94,106,210,.35)}
.ekb-blog .ekb-pagination .dots{background:transparent;border-color:transparent;box-shadow:none;color:var(--ink-3)}

/* ===== Single article ===== */
.ekb-blog .ekb-article__header{padding:48px 0 64px}
@media(min-width:768px){.ekb-blog .ekb-article__header{padding:64px 0 80px}}
.ekb-blog .ekb-h1-article{font-size:clamp(28px,4.2vw,48px);line-height:1.15;letter-spacing:-.025em;font-weight:600;color:var(--ink);margin:0 0 32px;max-width:780px;font-family:inherit}
@media(min-width:768px){.ekb-blog .ekb-h1-article{margin:0 0 36px}}
.ekb-blog .ekb-article__lead{font-size:19px;line-height:1.6;color:var(--ink-2);max-width:720px;margin:0 0 48px;letter-spacing:-.005em;font-weight:400}
@media(min-width:768px){.ekb-blog .ekb-article__lead{font-size:20px;margin:0 0 56px}}
.ekb-blog .ekb-article__hero{position:relative;border-radius:var(--r-xl);overflow:hidden;margin:32px 0 48px;background:var(--surface-soft);box-shadow:var(--shadow-md);border:1px solid var(--border-2)}
.ekb-blog .ekb-article__hero img{width:100%;display:block;aspect-ratio:16/7;object-fit:cover}

/* Article layout: condition-driven grid
   - with TOC: [220px TOC | content max 720px | 56px share], центрировано
   - without TOC: [content full-width | 56px share], растянуто */
.ekb-blog .ekb-article__layout{display:block;margin:0 auto;position:relative;padding-bottom:48px}
@media(min-width:981px){
	.ekb-blog .ekb-article__layout--with-toc{display:grid;grid-template-columns:220px minmax(0,720px) 56px;gap:48px;align-items:start;justify-content:center}
	.ekb-blog .ekb-article__layout--no-toc{display:grid;grid-template-columns:minmax(0,1fr) 56px;gap:48px;align-items:start}
	/* При отсутствии TOC контент тянется на всю ширину, max-width 720px отключаем. */
	.ekb-blog .ekb-article__layout--no-toc .ekb-article__content{max-width:none}
}
/* Fallback без модификатора */
@media(min-width:981px){
	.ekb-blog .ekb-article__layout:not(.ekb-article__layout--with-toc):not(.ekb-article__layout--no-toc){display:grid;grid-template-columns:minmax(0,1fr) 56px;gap:48px;align-items:start}
	.ekb-blog .ekb-article__layout:not(.ekb-article__layout--with-toc):not(.ekb-article__layout--no-toc) .ekb-article__content{max-width:none}
}
/* Lead-параграф в обычном Gutenberg-контенте page-страниц — тот же стиль что .ekb-article__lead в header single. */
.ekb-blog .ekb-article__content > p.lead{font-size:20px;line-height:1.6;font-weight:400;color:var(--ink-2);margin:0 0 1.4em;letter-spacing:-.003em}
.ekb-blog .ekb-article__content > p.lead.has-large-font-size{font-size:20px}

.ekb-blog .ekb-article__content{max-width:720px;margin:0;font-size:17px;line-height:1.72;color:var(--ink-1);font-weight:400}
.ekb-blog .ekb-article__content > *{margin-top:0;margin-bottom:1em}
.ekb-blog .ekb-article__content p{margin:1.1em 0;letter-spacing:-.003em}
.ekb-blog .ekb-article__content p:first-child{margin-top:0}
.ekb-blog .ekb-article__content h2{font-size:clamp(22px,2.3vw,28px);font-weight:600;letter-spacing:-.02em;color:var(--ink);margin-top:2.2em;margin-bottom:.4em;line-height:1.25;scroll-margin-top:90px;font-family:inherit}
.ekb-blog .ekb-article__content h2::before{content:"";display:block;width:28px;height:2px;background:linear-gradient(90deg,var(--accent),transparent);border-radius:1px;margin-bottom:16px}
.ekb-blog .ekb-article__content h3{font-size:20px;font-weight:600;letter-spacing:-.015em;color:var(--ink);margin-top:1.8em;margin-bottom:.4em;line-height:1.3;scroll-margin-top:90px;font-family:inherit}
.ekb-blog .ekb-article__content h4{font-size:17px;font-weight:600;color:var(--ink);margin-top:1.5em;margin-bottom:.4em}
.ekb-blog .ekb-article__content strong{font-weight:600;color:var(--ink)}
.ekb-blog .ekb-article__content a{color:var(--accent);font-weight:500;background-image:linear-gradient(var(--accent),var(--accent));background-size:0% 1px;background-position:0 92%;background-repeat:no-repeat;transition:background-size .3s var(--ease);text-decoration:none}
.ekb-blog .ekb-article__content a:hover{background-size:100% 1px}
.ekb-blog .ekb-article__content ul,.ekb-blog .ekb-article__content ol{margin:1em 0;padding-left:0;list-style:none}
.ekb-blog .ekb-article__content ul li,.ekb-blog .ekb-article__content ol li{position:relative;padding-left:28px;margin-bottom:10px}
.ekb-blog .ekb-article__content ul li::before{content:"";position:absolute;left:8px;top:12px;width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.ekb-blog .ekb-article__content ol{counter-reset:proseLi}
.ekb-blog .ekb-article__content ol li{counter-increment:proseLi}
.ekb-blog .ekb-article__content ol li::before{content:counter(proseLi);position:absolute;left:0;top:2px;width:22px;height:22px;display:grid;place-items:center;font-size:12px;font-weight:600;color:var(--accent);background:var(--accent-bg);border-radius:var(--r-sm);line-height:1;font-variant-numeric:tabular-nums}
.ekb-blog .ekb-article__content blockquote{margin:1.5em 0;padding:18px 24px;border:0;border-left:3px solid var(--accent);background:var(--accent-bg-soft);border-radius:0 var(--r-md) var(--r-md) 0;font-style:italic;color:var(--ink-1)}
.ekb-blog .ekb-article__content blockquote p:last-child{margin-bottom:0}
.ekb-blog .ekb-article__content img{border-radius:var(--r-md);margin:1.6em 0;box-shadow:var(--shadow-sm);border:1px solid var(--border-2)}
.ekb-blog .ekb-article__content figure{margin:1.6em 0}
.ekb-blog .ekb-article__content figcaption{font-size:13px;color:var(--ink-3);text-align:center;margin-top:8px}
.ekb-blog .ekb-article__content code{font-family:ui-monospace,"SF Mono","Cascadia Code","JetBrains Mono",Menlo,Consolas,monospace;font-size:14px;background:var(--surface-soft);border:1px solid var(--border-2);padding:1px 6px;border-radius:4px;color:var(--accent-strong)}
.ekb-blog .ekb-article__content pre{background:#0F1011;color:#E4E4E7;padding:20px 24px;border-radius:var(--r-md);overflow-x:auto;margin:1.5em 0;font-size:13.5px;line-height:1.6;position:relative;border:1px solid #1F2123}
.ekb-blog .ekb-article__content pre code{background:transparent;border:0;padding:0;color:inherit;font-size:inherit}
.ekb-blog .ekb-article__content table{width:100%;border-collapse:collapse;margin:1.5em 0;font-size:14.5px}
.ekb-blog .ekb-article__content th,.ekb-blog .ekb-article__content td{border-bottom:1px solid var(--border-2);padding:12px 0;text-align:left}
.ekb-blog .ekb-article__content th{font-weight:600;color:var(--ink)}

/* ===== Post meta (под title) ===== */
.ekb-blog .ekb-post-meta{display:flex;align-items:center;flex-wrap:wrap;gap:16px;padding:24px 0;border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-2);margin:0;font-size:14px;color:var(--ink-3);font-weight:500}
.ekb-blog .ekb-post-meta__author{display:inline-flex;align-items:center;gap:10px}
.ekb-blog .ekb-post-meta__avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid var(--border-2);background:var(--surface-soft);flex-shrink:0}
.ekb-blog .ekb-post-meta__name{color:var(--ink-1);font-weight:500;font-size:14.5px;text-decoration:none;transition:color .15s var(--ease)}
.ekb-blog .ekb-post-meta__name:hover{color:var(--accent)}
.ekb-blog .ekb-post-meta__read{color:var(--ink-3)}
.ekb-blog .ekb-post-meta__cat{color:var(--accent);font-weight:500;text-decoration:none}

/* ===== Share rail (sticky RIGHT desktop, inline mobile) ===== */
.ekb-blog .ekb-share{display:flex;gap:4px;margin:0 0 24px;flex-wrap:wrap}
@media(min-width:981px){
	.ekb-blog .ekb-share{flex-direction:column;position:sticky;top:96px;align-self:start;margin:0;gap:6px}
}
.ekb-blog .ekb-share__btn{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-2);background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-sm);transition:all .15s var(--ease);box-shadow:var(--shadow-xs)}
.ekb-blog .ekb-share__btn:hover{color:var(--accent);background:var(--surface-soft);border-color:var(--border);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.ekb-blog .ekb-share__btn--copy.is-copied{color:#fff;background:var(--accent);border-color:var(--accent)}

/* ===== TOC right rail (desktop) + inline collapsible (mobile) ===== */
.ekb-blog .ekb-toc{margin:0 0 32px}
.ekb-blog .ekb-toc__toggle{display:flex;align-items:center;justify-content:space-between;width:100%;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);padding:0 0 12px;margin-bottom:8px;border-bottom:1px solid var(--border-2)}
.ekb-blog .ekb-toc__toggle svg{transition:transform .2s}
.ekb-blog .ekb-toc__toggle[aria-expanded="false"] svg{transform:rotate(-90deg)}
.ekb-blog .ekb-toc__list{list-style:none;margin:0;padding:0}
.ekb-blog .ekb-toc__item{margin:0 0 2px}
.ekb-blog .ekb-toc__item a{display:block;padding:6px 12px;font-size:13px;line-height:1.4;color:var(--ink-2);border-left:2px solid var(--border);transition:all .15s var(--ease);letter-spacing:-.005em;text-decoration:none}
.ekb-blog .ekb-toc__item--h3 a{padding-left:24px;font-size:12.5px}
.ekb-blog .ekb-toc__item a:hover{color:var(--ink);border-left-color:var(--ink-3)}
.ekb-blog .ekb-toc__item a.is-active{color:var(--accent);border-left-color:var(--accent);font-weight:500;background:var(--accent-bg-soft)}
.ekb-blog .ekb-article__toc-rail{display:none}
@media(min-width:981px){
	.ekb-blog .ekb-article__toc-rail{display:block}
	.ekb-blog .ekb-toc-rail__inner{position:sticky;top:96px;padding:4px 0}
	.ekb-blog .ekb-article__toc-rail .ekb-toc{margin:0}
	.ekb-blog .ekb-article__toc-rail .ekb-toc__toggle{display:none}
	.ekb-blog .ekb-article__content > .ekb-toc{display:none}
}

/* ===== Author bio ===== */
.ekb-blog .ekb-author-bio{display:flex;align-items:flex-start;gap:20px;margin:56px 0;padding:32px;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
@media(max-width:480px){.ekb-blog .ekb-author-bio{flex-direction:column;padding:24px}}
.ekb-blog .ekb-author-bio__avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;border:1px solid var(--border-2);background:var(--surface-soft);flex-shrink:0}
.ekb-blog .ekb-author-bio__content{flex:1;min-width:0}
.ekb-blog .ekb-author-bio__name{font-size:17px;font-weight:600;letter-spacing:-.015em;color:var(--ink);margin:0 0 8px;font-family:inherit}
.ekb-blog .ekb-author-bio__text{font-size:14px;line-height:1.55;color:var(--ink-2);margin:0 0 14px;font-weight:400}
.ekb-blog .ekb-author-bio__socials{list-style:none;margin:0;padding:0;display:flex;gap:8px;flex-wrap:wrap}
.ekb-blog .ekb-author-bio__socials a{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:12.5px;font-weight:500;color:var(--ink-1);background:var(--surface-soft);border:1px solid var(--border-2);border-radius:var(--r-sm);transition:all .15s var(--ease);text-decoration:none}
.ekb-blog .ekb-author-bio__socials a:hover{color:var(--accent);border-color:rgba(94,106,210,.3);background:var(--accent-bg-soft)}
.ekb-blog .ekb-author-bio__unlinked{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;font-size:12.5px;color:var(--ink-2);background:var(--surface-soft);border:1px dashed var(--border-2);border-radius:var(--r-sm);cursor:default}
.ekb-blog .ekb-author-bio__unlinked sup{color:var(--ink-3);margin-right:1px;font-size:10px}
.ekb-blog .ekb-author-bio__unlinked strong{font-weight:600;color:var(--ink-1);user-select:all}
.ekb-blog .ekb-author-bio__disclaimer{margin:14px 0 0;font-size:11.5px;line-height:1.5;color:var(--ink-3);font-weight:400}

/* ===== Footer unlinked socials + Meta disclaimer ===== */
.ekb-blog .ekb-footer__unlinked{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:4px;font-size:12.5px;color:var(--ink-2)}
.ekb-blog .ekb-footer__unlinked li{padding:0}
.ekb-blog .ekb-footer__unlinked sup{color:var(--ink-3);margin-right:1px;font-size:10px}
.ekb-blog .ekb-footer__unlinked strong{font-weight:600;color:var(--ink-1);user-select:all}
.ekb-blog .ekb-footer__meta-disclaimer{margin:24px 0 0;padding:16px 0 0;border-top:1px dashed var(--border-2);font-size:11.5px;line-height:1.5;color:var(--ink-3);font-weight:400;max-width:none}
.ekb-blog .ekb-meta-disclaimer{display:block}

/* ===== Newsletter (Linear-style premium card) ===== */
.ekb-blog .ekb-newsletter{margin:48px 0 64px;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-xl);padding:56px 56px;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}
.ekb-blog .ekb-newsletter::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 600px 300px at 100% 0%,rgba(94,106,210,.10),transparent 60%),radial-gradient(ellipse 400px 200px at 0% 100%,rgba(123,138,247,.08),transparent 60%);pointer-events:none}
@media(max-width:768px){.ekb-blog .ekb-newsletter{padding:36px 24px}}
.ekb-blog .ekb-newsletter__inner{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center;max-width:none;margin:0}
@media(max-width:768px){.ekb-blog .ekb-newsletter__inner{grid-template-columns:1fr;gap:24px}}
.ekb-blog .ekb-newsletter__text{display:flex;flex-direction:column}
.ekb-blog .ekb-newsletter__title{font-size:clamp(22px,2.5vw,28px);font-weight:600;letter-spacing:-.02em;color:var(--ink);margin:0 0 8px;font-family:inherit}
.ekb-blog .ekb-newsletter__sub{font-size:14.5px;line-height:1.55;color:var(--ink-2);margin:0;max-width:480px}
.ekb-blog .ekb-newsletter__cta{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;font-size:14px;font-weight:500;color:#fff;background:linear-gradient(180deg,#6671DA 0%,#5560CE 100%);border-radius:var(--r-sm);box-shadow:inset 0 1px 0 rgba(255,255,255,.15),inset 0 -1px 0 rgba(0,0,0,.05),0 1px 2px rgba(94,106,210,.35);transition:all .15s var(--ease);letter-spacing:-.005em;text-decoration:none;justify-self:start;white-space:nowrap}
.ekb-blog .ekb-newsletter__cta:hover{background:linear-gradient(180deg,#7180E0 0%,#5E6AD2 100%);box-shadow:inset 0 1px 0 rgba(255,255,255,.2),inset 0 -1px 0 rgba(0,0,0,.05),0 4px 12px rgba(94,106,210,.4);transform:translateY(-1px)}
@media(max-width:768px){.ekb-blog .ekb-newsletter__cta{justify-self:stretch;justify-content:center}}

/* ===== Related ===== */
.ekb-blog .ekb-related{margin:32px 0 0;padding-top:56px;border-top:1px solid var(--border-2)}
.ekb-blog .ekb-related__title{font-size:22px;font-weight:600;letter-spacing:-.018em;color:var(--ink);margin:0 0 28px;font-family:inherit}

/* ===== Post-nav (prev/next) ===== */
.ekb-blog .ekb-postnav{display:grid;grid-template-columns:1fr;gap:0;margin:48px 0;border-top:1px solid var(--border-2)}
@media(min-width:768px){.ekb-blog .ekb-postnav{grid-template-columns:1fr 1fr;border-bottom:1px solid var(--border-2)}}
.ekb-blog .ekb-postnav a{display:block;padding:24px 0;transition:background .15s var(--ease);color:var(--ink);text-decoration:none}
@media(min-width:768px){.ekb-blog .ekb-postnav a{padding:24px 28px}.ekb-blog .ekb-postnav__prev{border-right:1px solid var(--border-2)}}
.ekb-blog .ekb-postnav a:hover{background:var(--surface-soft)}
@media(max-width:767px){.ekb-blog .ekb-postnav a{border-bottom:1px solid var(--border-2)}}
.ekb-blog .ekb-postnav__next{text-align:right}
.ekb-blog .ekb-postnav__label{display:block;font-size:11.5px;color:var(--ink-3);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.ekb-blog .ekb-postnav__title{display:block;font-weight:600;font-size:16px;line-height:1.3;color:var(--ink);letter-spacing:-.015em}
.ekb-blog .ekb-postnav a:hover .ekb-postnav__title{color:var(--accent)}

/* ===== Chips / tags ===== */
.ekb-blog .ekb-chip{display:inline-flex;align-items:center;padding:5px 12px;background:var(--surface);border:1px solid var(--border);font-size:12.5px;color:var(--ink-2);border-radius:var(--r-pill);transition:all .15s var(--ease);font-weight:500;text-decoration:none}
.ekb-blog .ekb-chip:hover{color:var(--accent);border-color:rgba(94,106,210,.3);background:var(--accent-bg-soft)}
.ekb-blog .ekb-article__tags{display:flex;flex-wrap:wrap;gap:8px;margin:32px 0}

/* ===== Empty state ===== */
.ekb-blog .ekb-empty{text-align:center;padding:96px 16px;max-width:560px;margin:0 auto}
.ekb-blog .ekb-empty__icon{color:var(--ink-4);margin:0 auto 16px}
.ekb-blog .ekb-empty__title{font-size:clamp(24px,3vw,32px);margin:0 0 12px;letter-spacing:-.02em;font-weight:600;font-family:inherit;color:var(--ink)}
.ekb-blog .ekb-empty__sub{color:var(--ink-2);margin:0 0 24px;line-height:1.55;font-size:15px}
.ekb-blog .ekb-empty__catslabel{display:block;font-size:11.5px;color:var(--ink-3);margin:24px 0 12px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.ekb-blog .ekb-empty__cats{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:24px}

/* ===== 404 ===== */
.ekb-blog .ekb-404{text-align:center;padding:96px 16px}
.ekb-blog .ekb-404__big{font-size:clamp(96px,16vw,180px);font-weight:600;line-height:.9;letter-spacing:-.05em;margin:0 0 24px;background:linear-gradient(180deg,var(--accent) 0%,var(--accent-strong) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;font-family:inherit}
.ekb-blog .ekb-404__sub{color:var(--ink-2);max-width:520px;margin:0 auto 32px;font-size:16px;line-height:1.55}
.ekb-blog .ekb-404__cats{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:24px}
.ekb-blog .ekb-404__recent{margin:96px 0}

/* ===== Footer ===== */
.ekb-blog .ekb-footer{padding:72px 0 36px;border-top:1px solid var(--border-2);background:var(--surface-soft);position:relative;z-index:1;margin-top:96px}
.ekb-blog .ekb-footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.4fr;gap:48px;margin-bottom:48px;align-items:start}
@media(max-width:980px){.ekb-blog .ekb-footer__grid{grid-template-columns:1fr 1fr;gap:40px 32px}}
@media(max-width:480px){.ekb-blog .ekb-footer__grid{grid-template-columns:1fr}}
.ekb-blog .ekb-footer__col{display:flex;flex-direction:column;min-width:0}
.ekb-blog .ekb-footer__col--brand{max-width:340px}
@media(max-width:980px){.ekb-blog .ekb-footer__col--brand{grid-column:1/-1;max-width:none}}
.ekb-blog .ekb-footer__col--cta{padding:20px;background:var(--ink);color:#fafafa;border-radius:var(--r-lg);position:relative;overflow:hidden}
.ekb-blog .ekb-footer__col--cta::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 240px 140px at 100% 0%,rgba(94,106,210,.4),transparent 60%);pointer-events:none}
.ekb-blog .ekb-footer__col--cta > *{position:relative}
.ekb-blog .ekb-footer__col--cta .ekb-footer__title{color:rgba(255,255,255,.5)}
.ekb-blog .ekb-footer__col--cta .ekb-footer__cta-text{font-size:13.5px;line-height:1.55;color:#d4d4d8;margin:0 0 16px}
.ekb-blog .ekb-footer__cta-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;font-size:13.5px;font-weight:500;background:#fafafa;color:var(--ink);border-radius:var(--r-sm);text-decoration:none;transition:background .15s var(--ease),transform .15s var(--ease);width:max-content}
.ekb-blog .ekb-footer__cta-btn:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}
.ekb-blog .ekb-footer__brand{font-size:16px;font-weight:600;letter-spacing:-.01em;color:var(--ink);margin-bottom:16px;display:inline-flex;align-items:center;gap:10px}
.ekb-blog .ekb-footer__brand::before{content:"ЕК";width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#5E6AD2 0%,#4F5BC2 100%);display:grid;place-items:center;color:#fff;font-weight:700;font-size:11.5px;letter-spacing:-.02em;box-shadow:inset 0 1px 0 rgba(255,255,255,.2),0 1px 3px rgba(94,106,210,.35);flex-shrink:0}
.ekb-blog .ekb-footer__about{font-size:14px;color:var(--ink-2);line-height:1.6;margin:0 0 18px;font-weight:400}
.ekb-blog .ekb-footer__socials{list-style:none;margin:0;padding:0;display:flex;gap:6px;flex-wrap:wrap}
.ekb-blog .ekb-footer__socials a{width:36px;height:36px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-sm);color:var(--ink-2);transition:all .15s var(--ease)}
.ekb-blog .ekb-footer__socials a:hover{color:var(--accent);border-color:rgba(94,106,210,.3);background:var(--accent-bg-soft);transform:translateY(-1px)}
.ekb-blog .ekb-footer__title{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin:0 0 16px;font-weight:600}
.ekb-blog .ekb-footer__list{list-style:none;margin:0;padding:0}
.ekb-blog .ekb-footer__list li{margin-bottom:10px}
.ekb-blog .ekb-footer__list a{color:var(--ink-1);font-size:14px;font-weight:500;text-decoration:none;transition:color .15s var(--ease)}
.ekb-blog .ekb-footer__list a:hover{color:var(--accent)}
.ekb-blog .ekb-footer__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid var(--border-2);font-size:13px;color:var(--ink-3);gap:16px;flex-wrap:wrap;font-weight:500}
@media(max-width:480px){.ekb-blog .ekb-footer__bottom{flex-direction:column;justify-content:flex-start;align-items:flex-start}}
.ekb-blog .ekb-footer__bottom p{margin:0}
.ekb-blog .ekb-footer__legal{display:inline-flex;align-items:center;gap:10px}
.ekb-blog .ekb-footer__legal a{color:var(--ink-3);text-decoration:none}
.ekb-blog .ekb-footer__legal a:hover{color:var(--accent)}
.ekb-blog .ekb-footer__legal span{color:var(--ink-mute)}

/* ===== Comments ===== */
.ekb-blog .ekb-comments{max-width:720px;margin:96px auto 64px;padding:48px 0 0;border-top:1px solid var(--border-2)}
.ekb-blog .ekb-comments__top{margin:0 0 32px}
.ekb-blog .ekb-comments__title{font-size:22px;margin:0;font-weight:600;letter-spacing:-.02em;font-family:inherit;color:var(--ink)}
.ekb-blog .ekb-comments__sub{font-size:14.5px;color:var(--ink-2);margin:8px 0 0;line-height:1.5}
.ekb-blog .ekb-comments__closed{font-size:14px;color:var(--ink-3);padding:32px;background:var(--surface-soft);border-radius:var(--r-md);text-align:center;margin:24px 0 0}

.ekb-blog .ekb-comments__list{list-style:none;margin:0 0 32px;padding:0}
.ekb-blog .ekb-comments__list ol.children{list-style:none;margin:16px 0 0 0;padding:0 0 0 28px;border-left:2px solid var(--border-2)}
.ekb-blog .ekb-comments__list .ekb-comment{margin:0 0 24px}
.ekb-blog .ekb-comment__inner{display:flex;gap:12px;align-items:flex-start}
.ekb-blog .ekb-comment__avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:1px solid var(--border-2);background:var(--surface-soft);flex-shrink:0}
.ekb-blog .ekb-comment__body{flex:1;min-width:0;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-md);padding:14px 18px;box-shadow:var(--shadow-xs)}
.ekb-blog .ekb-comment__meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13px;color:var(--ink-3);margin-bottom:8px}
.ekb-blog .ekb-comment__author{font-weight:600;color:var(--ink);font-size:14px}
.ekb-blog .ekb-comment__author a{color:inherit}
.ekb-blog .ekb-comment__author a:hover{color:var(--accent)}
.ekb-blog .ekb-comment__badge{display:inline-block;font-size:11px;padding:2px 8px;background:var(--accent-bg);color:var(--accent);border-radius:var(--r-pill);font-weight:500;border:1px solid rgba(94,106,210,.18)}
.ekb-blog .ekb-comment__date{margin-left:auto;font-size:12.5px;color:var(--ink-3);font-variant-numeric:tabular-nums}
.ekb-blog .ekb-comment__content{font-size:15px;line-height:1.6;color:var(--ink-1);word-wrap:break-word;overflow-wrap:break-word}
.ekb-blog .ekb-comment__content p{margin:0 0 .6em}
.ekb-blog .ekb-comment__content p:last-child{margin-bottom:0}
.ekb-blog .ekb-comment__content a{color:var(--accent);text-decoration:underline;text-decoration-color:rgba(94,106,210,.4);text-underline-offset:2px}
.ekb-blog .ekb-comment__content a:hover{text-decoration-color:var(--accent)}
.ekb-blog .ekb-comment__actions{margin-top:10px;display:flex;gap:14px}
.ekb-blog .ekb-comment__actions .comment-reply-link{font-size:12.5px;font-weight:500;color:var(--ink-3);background:transparent;border:0;padding:0;cursor:pointer;transition:color .15s var(--ease)}
.ekb-blog .ekb-comment__actions .comment-reply-link:hover{color:var(--accent)}

/* Comment form wrapper (для logged-in) */
.ekb-blog .ekb-comment-form-wrap{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:20px 22px;box-shadow:var(--shadow-xs)}
.ekb-blog .ekb-comment-form-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border-2)}
.ekb-blog .ekb-comment-form-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid var(--border-2);flex-shrink:0}
.ekb-blog .ekb-comment-form-meta{flex:1;display:flex;align-items:center;justify-content:space-between;font-size:13.5px}
.ekb-blog .ekb-comment-form-name{font-weight:600;color:var(--ink)}
.ekb-blog .ekb-comment-form-logout{background:transparent;border:0;font-size:13px;color:var(--ink-3);cursor:pointer;padding:4px 0;transition:color .15s var(--ease)}
.ekb-blog .ekb-comment-form-logout:hover{color:var(--accent)}
.ekb-blog .ekb-comment-form-wrap .comment-form{margin:0}
.ekb-blog .ekb-comment-form-field{margin:0 0 14px}
.ekb-blog .ekb-comment-form-actions{margin:0;display:flex;align-items:center;gap:12px}

/* Reply form (вложенная) */
.ekb-blog .ekb-comments #respond{margin-top:16px}
.ekb-blog .ekb-comments .comment-reply-title{font-size:14px;font-weight:600;color:var(--ink);margin:0 0 10px}
.ekb-blog .ekb-comments .comment-reply-title small{font-weight:400;margin-left:8px}
.ekb-blog .ekb-comments .comment-reply-title small a{color:var(--ink-3);font-size:12px;text-decoration:underline}

/* Все input/textarea одинаково */
.ekb-blog .ekb-comments textarea,
.ekb-blog .ekb-comments input[type=text],
.ekb-blog .ekb-comments input[type=email],
.ekb-blog .ekb-comments input[type=url],
.ekb-blog .ekb-comments input[type=password],
.ekb-blog .ekb-auth input[type=text],
.ekb-blog .ekb-auth input[type=email],
.ekb-blog .ekb-auth input[type=password]{
	width:100%;padding:11px 14px;border:1px solid var(--border);background:var(--bg-elev);
	font:inherit;font-size:14.5px;color:var(--ink);border-radius:var(--r-sm);
	transition:border-color .15s var(--ease),box-shadow .15s var(--ease)
}
.ekb-blog .ekb-comments textarea{resize:vertical;min-height:96px;font-family:inherit;line-height:1.5}
.ekb-blog .ekb-comments textarea:focus,
.ekb-blog .ekb-comments input:focus,
.ekb-blog .ekb-auth input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}

/* ===== Auth form (login / register / forgot) ===== */
.ekb-blog .ekb-auth{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-xs);position:relative;overflow:hidden}
.ekb-blog .ekb-auth::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 360px 180px at 100% 0%,rgba(94,106,210,.06),transparent 60%);pointer-events:none}
.ekb-blog .ekb-auth__header{position:relative;margin:0 0 22px}
.ekb-blog .ekb-auth__title{font-size:18px;font-weight:600;letter-spacing:-.015em;color:var(--ink);margin:0 0 6px}
.ekb-blog .ekb-auth__sub{font-size:13.5px;line-height:1.5;color:var(--ink-2);margin:0}
.ekb-blog .ekb-auth__tabs{position:relative;display:inline-flex;background:var(--surface-soft);border:1px solid var(--border-2);border-radius:var(--r-pill);padding:3px;gap:2px;margin-bottom:20px}
.ekb-blog .ekb-auth__tab{padding:6px 16px;font-size:13.5px;font-weight:500;color:var(--ink-2);border-radius:var(--r-pill);background:transparent;border:0;cursor:pointer;transition:all .15s var(--ease)}
.ekb-blog .ekb-auth__tab:hover{color:var(--ink)}
.ekb-blog .ekb-auth__tab.is-active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-xs)}
.ekb-blog .ekb-auth__panel{position:relative}
.ekb-blog .ekb-auth__panel[hidden]{display:none}
.ekb-blog .ekb-auth__form{display:flex;flex-direction:column;gap:14px}
.ekb-blog .ekb-auth__field{position:relative;display:flex;flex-direction:column;gap:6px}
.ekb-blog .ekb-auth__field label{font-size:13px;font-weight:500;color:var(--ink-1)}
.ekb-blog .ekb-auth__field .ekb-auth__hint{color:var(--ink-3);font-weight:400}
.ekb-blog .ekb-auth__pwtoggle{position:absolute;right:8px;top:30px;width:32px;height:32px;display:grid;place-items:center;background:transparent;border:0;color:var(--ink-3);cursor:pointer;border-radius:var(--r-sm);transition:color .15s var(--ease),background .15s var(--ease)}
.ekb-blog .ekb-auth__pwtoggle:hover{color:var(--ink);background:var(--surface-soft)}
.ekb-blog .ekb-auth input[type=password]{padding-right:44px}
.ekb-blog .ekb-auth__row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-top:-2px}
.ekb-blog .ekb-auth__check{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--ink-2);cursor:pointer}
.ekb-blog .ekb-auth__check input{accent-color:var(--accent)}
.ekb-blog .ekb-auth__forgot,.ekb-blog .ekb-auth__back{background:transparent;border:0;font-size:13px;color:var(--ink-3);cursor:pointer;padding:4px 0;transition:color .15s var(--ease)}
.ekb-blog .ekb-auth__forgot:hover,.ekb-blog .ekb-auth__back:hover{color:var(--accent)}
.ekb-blog .ekb-auth__back{margin-top:4px}
.ekb-blog .ekb-auth__note{font-size:12px;line-height:1.5;color:var(--ink-3);margin:-2px 0 4px}
.ekb-blog .ekb-auth__submit{justify-content:center;width:100%;padding:13px 20px;font-size:14.5px}
.ekb-blog .ekb-auth__msg{font-size:13px;line-height:1.5;margin:0;padding:10px 14px;border-radius:var(--r-sm);display:none}
.ekb-blog .ekb-auth__msg.is-error{display:block;background:#FEF2F2;color:#B91C1C;border:1px solid #FECACA}
@media (prefers-color-scheme:dark){.ekb-blog .ekb-auth__msg.is-error{background:#3B0F0F;color:#FCA5A5;border-color:#7F1D1D}}
.ekb-blog .ekb-auth__msg.is-ok{display:block;background:#F0FDF4;color:#15803D;border:1px solid #BBF7D0}
@media (prefers-color-scheme:dark){.ekb-blog .ekb-auth__msg.is-ok{background:#0F2A18;color:#86EFAC;border-color:#14532D}}
.ekb-blog .ekb-auth__field.is-invalid input{border-color:#DC2626;box-shadow:0 0 0 3px rgba(220,38,38,.10)}
.ekb-blog [name="hp"]{position:absolute!important;left:-9999px;width:1px;height:1px;opacity:0}

/* ===== User menu (header) ===== */
.ekb-blog .ekb-header__login{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;font-size:13.5px;font-weight:500;color:#fff;background:linear-gradient(180deg,#6671DA 0%,#5560CE 100%);border:0;border-radius:var(--r-sm);box-shadow:inset 0 1px 0 rgba(255,255,255,.15),0 1px 2px rgba(94,106,210,.35);cursor:pointer;transition:all .15s var(--ease);letter-spacing:-.005em}
.ekb-blog .ekb-header__login:hover{background:linear-gradient(180deg,#7180E0 0%,#5E6AD2 100%);box-shadow:inset 0 1px 0 rgba(255,255,255,.2),0 4px 12px rgba(94,106,210,.4);transform:translateY(-1px)}
.ekb-blog .ekb-user{position:relative}
.ekb-blog .ekb-user__trigger{display:inline-flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;background:transparent;border:1px solid transparent;border-radius:var(--r-pill);cursor:pointer;transition:background .15s var(--ease),border-color .15s var(--ease)}
.ekb-blog .ekb-user__trigger:hover{background:var(--surface-soft);border-color:var(--border-2)}
.ekb-blog .ekb-user__avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid var(--border-2);background:var(--surface-soft);flex-shrink:0}
.ekb-blog .ekb-user__name{font-size:13px;font-weight:500;color:var(--ink-1);max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (max-width:640px){.ekb-blog .ekb-user__name{display:none}}
.ekb-blog .ekb-user__dropdown{position:absolute;right:0;top:calc(100% + 8px);min-width:180px;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-md);box-shadow:var(--shadow-md);padding:6px;z-index:60}
.ekb-blog .ekb-user__dropdown[hidden]{display:none}
.ekb-blog .ekb-user__item{display:block;width:100%;text-align:left;padding:8px 10px;font-size:13.5px;color:var(--ink-1);background:transparent;border:0;border-radius:var(--r-sm);cursor:pointer;transition:background .15s var(--ease),color .15s var(--ease);font-family:inherit}
.ekb-blog .ekb-user__item:hover{background:var(--surface-soft);color:var(--accent)}

.ekb-blog .ekb-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 22px;font-weight:500;font-size:14px;transition:all .15s var(--ease);cursor:pointer;border:0;border-radius:var(--r-sm);letter-spacing:-.005em;font-family:inherit}
.ekb-blog .ekb-btn--primary{background:linear-gradient(180deg,#6671DA 0%,#5560CE 100%);color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.15),0 1px 2px rgba(94,106,210,.35)}
.ekb-blog .ekb-btn--primary:hover{background:linear-gradient(180deg,#7180E0 0%,#5E6AD2 100%);box-shadow:inset 0 1px 0 rgba(255,255,255,.2),0 4px 12px rgba(94,106,210,.4);transform:translateY(-1px)}
.ekb-blog .ekb-btn--primary[disabled]{opacity:.6;cursor:wait;transform:none}

/* ===== Motion ===== */
@media(prefers-reduced-motion:reduce){
	.ekb-blog *,.ekb-blog *::before,.ekb-blog *::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* ===== Print ===== */
@media print{
	.ekb-blog .ekb-header,.ekb-blog .ekb-footer,.ekb-blog .ekb-share,.ekb-blog .ekb-article__toc-rail,.ekb-blog .ekb-newsletter,.ekb-blog .ekb-related,.ekb-blog .ekb-postnav,.ekb-blog .ekb-progress{display:none!important}
	.ekb-blog .ekb-article__content{font-size:12pt;color:#000}
	.ekb-blog .ekb-article__content a{color:#000;text-decoration:underline}
	.ekb-blog body::before{display:none!important}
}

/* ===== Selection (override for prose) ===== */
.ekb-blog ::selection{background:var(--accent-bg);color:var(--accent-strong)}

/* ===== :focus-visible (keyboard a11y) ===== */
.ekb-blog *:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
.ekb-blog .ekb-card__link:focus-visible,
.ekb-blog .ekb-card--hero .ekb-card__link:focus-visible{outline-offset:4px;border-radius:var(--r-lg)}
.ekb-blog .ekb-icon-btn:focus-visible,
.ekb-blog .ekb-share__btn:focus-visible{outline-offset:2px;border-radius:var(--r-sm)}
.ekb-blog .ekb-nav__list a:focus-visible{background:var(--surface-soft)}
.ekb-blog button:focus-visible,
.ekb-blog a:focus-visible{outline-offset:3px}

/* ============================================================
   Infinite Feed — sentinel, skeleton, loading, end state, load-more
   ============================================================ */
.ekb-blog .ekb-feed{position:relative}
.ekb-blog .ekb-feed--js + .ekb-pagination--js-hidden,
.ekb-blog .ekb-pagination--js-hidden{display:none}
.ekb-blog .ekb-feed-sentinel{height:1px;width:100%;margin-top:16px;pointer-events:none}
.ekb-blog .ekb-feed-live{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.ekb-blog .ekb-feed-loadmore{display:flex;justify-content:center;margin:40px 0 16px}
.ekb-blog .ekb-feed-loadmore[hidden]{display:none}
.ekb-blog .ekb-btn--ghost{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;font-size:14px;font-weight:500;color:var(--ink-1);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-xs);transition:all .15s var(--ease);cursor:pointer}
.ekb-blog .ekb-btn--ghost:hover:not([disabled]){background:var(--surface-soft);transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:var(--accent);color:var(--accent)}
.ekb-blog .ekb-btn--ghost[disabled]{opacity:.6;cursor:wait}
.ekb-blog .ekb-feed-end{text-align:center;color:var(--ink-3);font-size:14px;letter-spacing:.02em;padding:40px 0 16px;margin:0;font-weight:500}
.ekb-blog .ekb-feed-end[hidden]{display:none}
.ekb-blog .ekb-feed-end span{display:inline-block;margin:0 8px;opacity:.5}

/* Skeleton */
.ekb-blog .ekb-feed-skeleton{margin-top:24px}
.ekb-blog .ekb-card--skeleton{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);overflow:hidden;pointer-events:none;box-shadow:var(--shadow-xs)}
.ekb-blog .ekb-card--skeleton .ekb-card__cover{aspect-ratio:16/9;background:linear-gradient(90deg,var(--surface-soft) 0%,var(--surface-2) 50%,var(--surface-soft) 100%);background-size:200% 100%;animation:ekbSkelShimmer 1.4s infinite;border-bottom:1px solid var(--border-2)}
.ekb-blog .ekb-card--skeleton .ekb-card__body{padding:22px}
.ekb-blog .ekb-skel{display:block;background:linear-gradient(90deg,var(--surface-soft) 0%,var(--surface-2) 50%,var(--surface-soft) 100%);background-size:200% 100%;animation:ekbSkelShimmer 1.4s infinite;border-radius:6px;margin-bottom:10px}
.ekb-blog .ekb-skel--cat{width:35%;height:12px}
.ekb-blog .ekb-skel--title{width:90%;height:16px}
.ekb-blog .ekb-skel--title.ekb-skel--short{width:55%}
.ekb-blog .ekb-skel--meta{width:45%;height:12px;margin-top:14px}
@keyframes ekbSkelShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Loading spinner у sentinel */
.ekb-blog .ekb-feed--loading .ekb-feed-sentinel::after{content:'';display:block;width:24px;height:24px;margin:16px auto 0;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:ekbSpin .8s linear infinite}
@keyframes ekbSpin{to{transform:rotate(360deg)}}

@media (prefers-reduced-motion:reduce){
	.ekb-blog .ekb-card--skeleton .ekb-card__cover,
	.ekb-blog .ekb-skel{animation:none;background:var(--surface-soft)}
	.ekb-blog .ekb-feed--loading .ekb-feed-sentinel::after{animation:none}
}

/* Отступ хлебных крошек на листингах = как .ekb-article__header на single (48px mobile / 64px desktop). */
.ekb-home .ekb-breadcrumbs,.archive .ekb-breadcrumbs,.search .ekb-breadcrumbs,.error404 .ekb-breadcrumbs{margin-top:48px}
@media(min-width:768px){.ekb-home .ekb-breadcrumbs,.archive .ekb-breadcrumbs,.search .ekb-breadcrumbs,.error404 .ekb-breadcrumbs{margin-top:64px}}

/* Мета-блок кейса keystype (Клиент / Тип / Формат) в стиле блога */
.ekb-case-meta{list-style:none;display:flex;flex-wrap:wrap;gap:14px 30px;margin:24px 0 0;padding:20px 0 0;border-top:1px solid var(--border-2,#e3e1ea)}
.ekb-case-meta li{display:flex;flex-direction:column;gap:4px}
.ekb-case-meta span{font-size:11.5px;color:var(--ink-3,#71717a);text-transform:uppercase;letter-spacing:.06em}
.ekb-case-meta strong{font-size:15px;color:var(--ink,#303030);font-weight:600}
