/* Shared blog-post styles for Keylink blog articles */
.post-page { background: var(--midnight); min-height: 100vh; }
.post-hero { position: relative; height: clamp(380px, 52vw, 560px); overflow: hidden; }
.post-hero__img { width: 100%; height: 100%; object-fit: cover; display: block; }
.post-hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,14,26,0.20) 0%, rgba(10,14,26,0.50) 40%, rgba(10,14,26,0.92) 80%, rgba(10,14,26,1.00) 100%); }
.post-hero__content { position: absolute; bottom: 0; left: 0; right: 0; padding: 0 0 48px; }
.post-hero__cat { display: inline-block; font-size: 0.65rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 12px; border-radius: 100px; margin-bottom: 14px; background: rgba(34,160,146,0.15); color: var(--teal-lt); border: 1px solid rgba(34,160,146,0.3); }
.post-hero__title { font-family: var(--font-head); font-size: clamp(2.2rem, 5vw, 3.8rem); line-height: 1.05; letter-spacing: 0.03em; text-transform: uppercase; color: var(--white); max-width: 820px; margin-bottom: 22px; }
.post-hero__meta { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.post-hero__author { display: flex; align-items: center; gap: 10px; }
.post-hero__avatar { width: 38px; height: 38px; border-radius: 50%; background: linear-gradient(135deg, var(--teal), var(--navy)); display: flex; align-items: center; justify-content: center; font-size: 0.85rem; font-weight: 700; color: var(--white); flex-shrink: 0; border: 2px solid rgba(34,160,146,0.4); }
.post-hero__author-info { display: flex; flex-direction: column; gap: 1px; }
.post-hero__author-name { font-size: 0.88rem; font-weight: 600; color: var(--cloud); }
.post-hero__author-role { font-size: 0.72rem; color: var(--slate); }
.post-hero__divider { width: 1px; height: 28px; background: rgba(255,255,255,0.12); }
.post-hero__date, .post-hero__readtime { font-size: 0.8rem; color: var(--slate); }
.post-hero__date time { color: var(--cloud); font-weight: 500; }
.post-nav-bar { border-bottom: 1px solid rgba(255,255,255,0.07); padding: 14px 0; }
.post-nav-bar__inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.post-nav-bar__back { display: inline-flex; align-items: center; gap: 8px; font-size: 0.82rem; font-weight: 600; color: var(--teal-lt); text-decoration: none; transition: color 0.2s, gap 0.2s; }
.post-nav-bar__back:hover { color: var(--gold); gap: 4px; }
.post-breadcrumb { font-size: 0.76rem; color: var(--slate); display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.post-breadcrumb a { color: var(--slate); text-decoration: none; transition: color 0.2s; }
.post-breadcrumb a:hover { color: var(--teal-lt); }
.post-breadcrumb__sep { opacity: 0.3; }
.post-breadcrumb__current { color: rgba(232,237,245,0.55); }
.post-body { max-width: 760px; margin: 0 auto; padding: 52px 24px 80px; }
.post-toc { background: rgba(18,41,74,0.3); border: 1px solid rgba(255,255,255,0.07); border-left: 3px solid var(--teal-lt); border-radius: 12px; padding: 22px 26px; margin-bottom: 48px; }
.post-toc__label { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--teal-lt); margin-bottom: 12px; }
.post-toc ol { padding-left: 18px; display: flex; flex-direction: column; gap: 7px; }
.post-toc li { font-size: 0.88rem; color: rgba(232,237,245,0.75); }
.post-toc a { color: inherit; text-decoration: none; transition: color 0.2s; }
.post-toc a:hover { color: var(--gold); }
.post-body p { font-size: 1.01rem; line-height: 1.88; color: rgba(232,237,245,0.82); margin-bottom: 1.4em; }
.post-body h2 { font-family: var(--font-head); font-size: clamp(1.55rem, 3vw, 2.1rem); letter-spacing: 0.04em; text-transform: uppercase; color: var(--white); margin: 52px 0 16px; scroll-margin-top: 90px; }
.post-body h3 { font-family: var(--font-body); font-size: 1.06rem; font-weight: 700; color: var(--white); margin: 30px 0 10px; }
.post-body a { color: var(--teal-lt); text-decoration: underline; text-decoration-color: rgba(34,160,146,0.35); text-underline-offset: 3px; transition: color 0.2s; }
.post-body a:hover { color: var(--gold); }
.post-body strong { color: var(--white); font-weight: 700; }
.post-body ul, .post-body ol { padding-left: 22px; margin-bottom: 1.4em; }
.post-body li { font-size: 1.01rem; line-height: 1.8; color: rgba(232,237,245,0.82); margin-bottom: 6px; }
.post-pullquote { border-left: 4px solid var(--gold); padding: 18px 26px; margin: 38px 0; background: rgba(240,168,32,0.05); border-radius: 0 12px 12px 0; }
.post-pullquote p { font-size: 1.1rem; font-style: italic; color: var(--cloud); margin: 0; opacity: 0.9; line-height: 1.7; }
.post-strategy { display: grid; gap: 14px; margin: 28px 0 40px; }
.post-strategy__item { display: flex; gap: 16px; align-items: flex-start; background: rgba(18,41,74,0.28); border: 1px solid rgba(255,255,255,0.07); border-radius: 12px; padding: 18px 20px; }
.post-strategy__num { width: 30px; height: 30px; border-radius: 50%; background: var(--teal); color: var(--white); font-size: 0.8rem; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.post-strategy__text h4 { font-size: 0.94rem; font-weight: 700; color: var(--white); margin-bottom: 5px; }
.post-strategy__text p { font-size: 0.88rem; margin: 0; line-height: 1.65; color: rgba(232,237,245,0.72); }
.post-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 36px 0; }
.post-stat { background: rgba(10,14,26,0.4); border: 1px solid rgba(255,255,255,0.07); border-radius: 12px; padding: 20px; text-align: center; }
.post-stat__num { font-family: var(--font-head); font-size: 2rem; color: var(--gold); line-height: 1; margin-bottom: 6px; }
.post-stat__label { font-size: 0.78rem; color: var(--slate); line-height: 1.4; }
.post-cta-box { background: linear-gradient(135deg, rgba(18,41,74,0.65) 0%, rgba(26,123,110,0.2) 100%); border: 1px solid rgba(34,160,146,0.25); border-radius: 16px; padding: 36px 40px; text-align: center; margin: 48px 0; }
.post-cta-box__title { font-family: var(--font-head); font-size: 1.9rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--white); margin-bottom: 10px; }
.post-cta-box p { margin-bottom: 24px; color: rgba(232,237,245,0.7); }
.post-tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 36px 0 0; }
.post-tag { font-size: 0.7rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; padding: 5px 12px; border-radius: 100px; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.2); color: #fff; }
.post-divider { border: none; border-top: 1px solid rgba(255,255,255,0.07); margin: 52px 0; }
.post-author-card { background: rgba(18,41,74,0.3); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; padding: 30px 34px; display: flex; gap: 22px; align-items: flex-start; margin: 48px 0 0; }
.post-author-card__avatar { width: 62px; height: 62px; border-radius: 50%; background: linear-gradient(135deg, var(--teal), var(--navy)); display: flex; align-items: center; justify-content: center; font-size: 1.25rem; font-weight: 700; color: var(--white); flex-shrink: 0; border: 2px solid rgba(34,160,146,0.4); }
.post-author-card__label { font-size: 0.63rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--teal-lt); margin-bottom: 5px; }
.post-author-card__name { font-size: 1.05rem; font-weight: 700; color: var(--white); margin-bottom: 3px; }
.post-author-card__role { font-size: 0.8rem; color: var(--slate); margin-bottom: 12px; }
.post-author-card__bio { font-size: 0.88rem; line-height: 1.72; color: rgba(232,237,245,0.7); margin-bottom: 12px; }
.post-author-card__email { font-size: 0.82rem; color: var(--teal-lt); text-decoration: none; transition: color 0.2s; }
.post-author-card__email:hover { color: var(--gold); }
.post-related { padding: 60px 0 80px; border-top: 1px solid rgba(255,255,255,0.06); }
.post-related .container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.post-related__label { font-family: var(--font-head); font-size: clamp(1.6rem, 3vw, 2.2rem); letter-spacing: 0.04em; text-transform: uppercase; color: var(--white); margin-bottom: 28px; }
@media (max-width: 768px) { .post-hero { height: clamp(300px, 70vw, 420px); } .post-hero__title { font-size: clamp(1.7rem, 7vw, 2.4rem); } .post-breadcrumb { display: none; } .post-body { padding: 36px 20px 60px; } .post-author-card { flex-direction: column; gap: 14px; padding: 22px; } .post-stats { grid-template-columns: 1fr; } }
