/* Re:Vet AI — detail page styles */
/* ============================================================
   Re:Vet AI — Card Detail page (dark, authorized)
   Same tokens & chrome as homepage v2
   ============================================================ */









/* Scrollbar */
@media (min-width:1024px){
  *::-webkit-scrollbar{width:10px;height:10px}
  *::-webkit-scrollbar-track{background:transparent}
  *::-webkit-scrollbar-thumb{background:rgba(255,255,255,.06);border-radius:10px;border:2px solid var(--bg)}
  *::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.12)}
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ============================================================
   1. HEADER (modified: back arrow + filled user avatar)
   ============================================================ */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(11,16,20,.72);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--border);
  transition:height .25s ease, background .25s ease;
}
.header__inner{
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 16px;
  height:var(--header-h);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  transition:height .25s ease;
}
.header.is-compact{background:rgba(11,16,20,.88);box-shadow:0 1px 0 var(--border)}
.header.is-compact .header__inner{height:var(--header-h-compact)}

/* Back button (replaces logo) */
.back-btn{
  display:inline-flex;align-items:center;gap:8px;
  height:40px;padding:0 12px 0 8px;
  background:transparent;color:var(--text-primary);
  font-family:var(--font-b);font-weight:600;font-size:14.5px;
  border-radius:var(--r-md);
  transition:background .15s ease;
}
.back-btn:hover{background:rgba(255,255,255,.04);color:var(--primary)}
.back-btn svg{width:18px;height:18px;stroke-width:2.2;transition:transform .15s ease}
.back-btn:hover svg{transform:translateX(-2px)}
.back-btn__label{display:none}
@media (min-width:640px){.back-btn__label{display:inline}}

.nav{display:none;align-items:center;gap:2px}
@media (min-width:1024px){.nav{display:flex}}
.nav__item{
  font-family:var(--font-b);font-weight:500;font-size:14.5px;color:var(--text-secondary);
  padding:8px 14px;border-radius:var(--r-md);
  transition:color .15s ease, background .15s ease;
  position:relative;
}
.nav__item:hover{color:var(--text-primary);background:rgba(255,255,255,.04)}
.nav__item.is-active{color:var(--text-primary);font-weight:600}
.nav__item.is-active::after{
  content:"";position:absolute;left:14px;right:14px;bottom:-19px;height:2px;
  background:linear-gradient(90deg,transparent,var(--primary) 50%,transparent);
  border-radius:2px;
}
.header.is-compact .nav__item.is-active::after{bottom:-15px}

.header__right{display:flex;align-items:center;gap:6px}
.icon-btn{
  width:40px;height:40px;border-radius:var(--r-md);
  display:grid;place-items:center;color:var(--text-secondary);
  transition:background .15s ease, color .15s ease;
}
.icon-btn:hover{background:rgba(255,255,255,.05);color:var(--text-primary)}
.icon-btn:focus-visible{outline:none;box-shadow:var(--sh-focus)}
.icon-btn svg{width:20px;height:20px}

/* Authorized user avatar in header */
.header-avatar{
  width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;overflow:hidden;
  border:2px solid var(--primary);
  background:#11171D;
  transition:box-shadow .2s ease;
  cursor:pointer;
}
.header-avatar:hover{box-shadow:0 0 0 4px rgba(79,195,247,.15)}
.header-avatar svg{width:100%;height:100%}

@media (min-width:1024px){
  .header__inner{padding:0 32px;gap:48px}
}

/* Reading progress bar (top of viewport) */
.read-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:80;
  background:transparent;pointer-events:none;
}
.read-progress__fill{
  height:100%;width:0;
  background:linear-gradient(90deg, var(--primary), var(--accent));
  box-shadow:0 0 8px var(--primary);
  transition:width .08s ease-out;
}

/* ============================================================
   2. DETAIL LAYOUT
   ============================================================ */
.detail{
  max-width:var(--max-w);
  margin:0 auto;
  padding:24px 16px 112px;
}

/* Mobile: stacked single column */
.detail__grid{display:block}
.rail{display:none}
.meta-col{display:none}

@media (min-width:1024px){
  .detail{padding:40px 32px 80px}
  .detail__grid{
    display:grid;
    grid-template-columns:var(--rail-w) minmax(0,var(--content-w)) var(--meta-w);
    column-gap:48px;
    row-gap:64px;
    justify-content:center;
    align-items:start;
  }
  .rail{display:flex;grid-column:1;grid-row:1;align-self:start;position:sticky;top:calc(var(--header-h) + 32px)}
  .main-col{grid-column:2;grid-row:1}
  .meta-col{display:flex;grid-column:3;grid-row:1;position:sticky;top:calc(var(--header-h) + 32px);flex-direction:column;gap:20px}
  .more-from{grid-column:2 / -1;grid-row:2}
}

/* ============================================================
   3. LEFT RAIL — actions (desktop)
   ============================================================ */
.rail{
  flex-direction:column;align-items:stretch;gap:4px;
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:8px;
  width:var(--rail-w);
}
.rail__item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;padding:12px 6px 10px;
  color:var(--text-secondary);
  border-radius:var(--r-md);
  transition:background .15s ease, color .15s ease;
  position:relative;
}
.rail__item:hover{background:rgba(255,255,255,.04);color:var(--text-primary)}
.rail__item:not(:last-child)::after{
  content:"";position:absolute;left:14px;right:14px;bottom:-2px;height:1px;background:var(--border);
}
.rail__item svg{width:22px;height:22px;stroke-width:1.9}
.rail__item .lbl{
  font-family:var(--font-b);font-weight:500;font-size:10.5px;
  line-height:1.2;text-align:center;letter-spacing:.01em;
  color:var(--text-muted);
  transition:color .15s ease;
}
.rail__item:hover .lbl{color:var(--text-secondary)}

.rail__item.is-saved{color:var(--primary)}
.rail__item.is-saved svg{fill:var(--primary);stroke:var(--primary)}
.rail__item.is-saved .lbl{color:var(--primary)}

/* ============================================================
   4. MAIN COLUMN — article content
   ============================================================ */
.main-col{display:flex;flex-direction:column;gap:24px;min-width:0}

/* Author header (top of article) */
.author-head{
  display:flex;align-items:center;gap:12px;
  padding-bottom:18px;
  border-bottom:1px solid var(--border);
}
.author-head .avatar{flex:0 0 auto}
.author-head__main{flex:1 1 auto;min-width:0}
.author-head__name{
  font-family:var(--font-h);font-weight:600;font-size:14.5px;color:var(--text-primary);
  margin:0;line-height:1.3;
}
.author-head__meta{
  font-size:12.5px;color:var(--text-muted);margin-top:1px;
  font-family:var(--font-m);letter-spacing:.01em;
}
.author-head__meta .dot{margin:0 6px;color:var(--gray-600)}
.btn-follow{
  flex:0 0 auto;
  padding:6px 12px;
  background:rgba(79,195,247,.08);
  border:1px solid rgba(79,195,247,.25);
  color:var(--primary);
  font-weight:600;font-size:13px;
  border-radius:var(--r-pill);
  transition:all .15s ease;
}
.btn-follow:hover{background:rgba(79,195,247,.16);border-color:var(--primary)}
.btn-follow.is-on{background:var(--primary);color:#06121A;border-color:var(--primary)}
.btn-follow.is-on::before{content:"✓ ";font-weight:700}

/* Article title */
.article-title{
  font-family:var(--font-h);font-weight:800;
  font-size:clamp(28px, 5.5vw, 44px);
  line-height:1.08;letter-spacing:-.025em;
  color:var(--text-primary);
  margin:0;
}
.article-title em{font-style:normal}
@media (min-width:1024px){
  .article-title{font-size:42px;line-height:1.1}
}

/* Deadline callout */
.deadline-card{
  position:relative;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:18px;
  padding:18px 20px;
  background:
    radial-gradient(400px 200px at 0% 0%, rgba(244,162,97,.14), transparent 60%),
    linear-gradient(135deg, rgba(244,162,97,.10) 0%, rgba(244,162,97,.04) 100%);
  border:1px solid rgba(244,162,97,.32);
  border-radius:var(--r-lg);
  overflow:hidden;
}
.deadline-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg, var(--accent), transparent);
}
.deadline-card__icon{
  flex:0 0 auto;width:44px;height:44px;border-radius:12px;
  background:rgba(244,162,97,.16);color:var(--accent);
  display:grid;place-items:center;
  border:1px solid rgba(244,162,97,.30);
}
.deadline-card__icon svg{width:22px;height:22px;stroke-width:2}
.deadline-card__main{min-width:0}
.deadline-card__label{
  font-family:var(--font-m);font-size:11px;letter-spacing:.10em;text-transform:uppercase;
  color:rgba(244,162,97,.85);
  margin:0 0 3px;font-weight:500;
}
.deadline-card__date{
  font-family:var(--font-h);font-weight:700;font-size:22px;color:var(--text-primary);
  line-height:1.15;letter-spacing:-.01em;margin:0;
}
.deadline-card__date small{font-weight:500;color:var(--accent);font-size:14px;display:block;margin-top:3px;letter-spacing:0}
.deadline-card__days{
  text-align:right;flex:0 0 auto;
}
.deadline-card__days .num{
  font-family:var(--font-h);font-weight:800;font-size:34px;color:var(--accent);
  line-height:1;letter-spacing:-.02em;
  font-feature-settings:"tnum" 1;
}
.deadline-card__days .lbl{
  font-family:var(--font-m);font-size:10.5px;letter-spacing:.10em;text-transform:uppercase;
  color:var(--text-muted);margin-top:5px;
}

@media (max-width:640px){
  .deadline-card{grid-template-columns:auto 1fr;gap:14px;padding:16px}
  .deadline-card__days{grid-column:1 / -1;display:flex;align-items:baseline;gap:8px;justify-content:flex-start;text-align:left;padding-top:6px;border-top:1px dashed rgba(244,162,97,.20);margin-top:4px}
  .deadline-card__days .num{font-size:24px}
  .deadline-card__days .lbl{margin-top:0}
}

/* Hero image */
.article-hero{
  position:relative;aspect-ratio:16/9;
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
}
.article-hero svg{width:100%;height:100%;display:block}
.article-hero::after{
  content:"";position:absolute;inset:auto 0 0 0;height:60px;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.25));
  pointer-events:none;
}

/* Primary CTA button */
.btn-apply{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  width:100%;
  padding:15px 24px;
  background:var(--primary);color:#06121A;
  font-family:var(--font-h);font-weight:700;font-size:16px;
  letter-spacing:-.005em;
  border-radius:var(--r-md);
  transition:background .15s ease, transform .1s ease, box-shadow .15s ease;
  box-shadow:0 4px 14px rgba(79,195,247,.20);
}
.btn-apply:hover{background:var(--primary-hover);color:#06121A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(79,195,247,.30)}
.btn-apply:active{transform:translateY(0)}
.btn-apply svg{width:18px;height:18px;stroke-width:2.4;transition:transform .15s ease}
.btn-apply:hover svg{transform:translateX(2px)}
@media (min-width:640px){.btn-apply{width:auto;min-width:280px}}

.btn-apply--second{margin-top:8px}

/* Article body — long-form readable */
.article-body{
  color:var(--text-secondary);
  font-size:16px;line-height:1.7;
  max-width:65ch;
}
.article-body p{margin:0 0 14px}
.article-body strong{color:var(--text-primary);font-weight:600}

/* Section headings */
.article-section{margin-top:8px}
.article-section__title{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-h);font-weight:700;
  font-size:20px;letter-spacing:-.01em;color:var(--text-primary);
  margin:0 0 14px;line-height:1.3;
}
.article-section__title::before{
  content:"";flex:0 0 auto;width:3px;height:18px;
  background:var(--primary);border-radius:2px;
  box-shadow:0 0 8px rgba(79,195,247,.5);
}

/* Bulleted lists */
.list-bullet{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.list-bullet li{
  display:flex;gap:12px;align-items:flex-start;
  padding:10px 14px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  color:var(--text-secondary);font-size:15px;line-height:1.55;
  transition:background .15s ease, border-color .15s ease;
}
.list-bullet li:hover{background:rgba(255,255,255,.035);border-color:var(--border-strong)}
.list-bullet li::before{
  content:"";flex:0 0 auto;
  width:6px;height:6px;border-radius:50%;
  background:var(--primary);
  box-shadow:0 0 6px rgba(79,195,247,.5);
  margin-top:8px;
}

/* Numbered steps — editorial */
.list-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0}
.list-steps li{
  display:grid;
  grid-template-columns:auto 1px 1fr;
  gap:18px;
  padding:14px 0;
  border-bottom:1px solid var(--border);
  align-items:start;
}
.list-steps li:first-child{padding-top:0}
.list-steps li:last-child{border-bottom:0;padding-bottom:0}
.list-steps__num{
  font-family:var(--font-m);font-weight:500;font-size:13px;
  color:var(--primary);letter-spacing:.04em;
  padding-top:1px;min-width:24px;
  font-feature-settings:"tnum" 1;
}
.list-steps__sep{
  width:1px;background:linear-gradient(180deg, var(--primary), transparent);
  align-self:stretch;
}
.list-steps__text{
  color:var(--text-secondary);font-size:15px;line-height:1.6;
  padding-top:1px;
}
.list-steps__text strong{color:var(--text-primary);font-weight:600}

/* Contacts */
.contacts{
  display:flex;flex-direction:column;gap:1px;
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
}
.contacts__item{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;
  border-bottom:1px solid var(--border);
  font-size:14.5px;color:var(--text-primary);
  text-decoration:none;
  transition:background .15s ease;
}
.contacts__item:last-child{border-bottom:0}
.contacts__item:hover{background:rgba(255,255,255,.025);color:var(--primary)}
.contacts__icon{
  flex:0 0 auto;width:34px;height:34px;border-radius:8px;
  background:rgba(79,195,247,.08);color:var(--primary);
  display:grid;place-items:center;
  border:1px solid rgba(79,195,247,.16);
}
.contacts__icon svg{width:16px;height:16px;stroke-width:2}
.contacts__label{
  font-family:var(--font-m);font-size:10.5px;letter-spacing:.10em;text-transform:uppercase;
  color:var(--text-muted);font-weight:500;
  display:block;margin-bottom:2px;
}
.contacts__val{
  font-family:var(--font-b);font-size:14px;color:var(--text-primary);font-weight:500;
}
.contacts__item:hover .contacts__val{color:var(--primary)}

/* Mobile actions row (save + share) */
.actions-row{
  display:flex;gap:10px;margin-top:8px;
  padding-top:24px;border-top:1px solid var(--border);
}
.actions-row__btn{
  flex:1 1 0;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 16px;
  background:var(--bg-surface);
  border:1px solid var(--border);
  color:var(--text-primary);
  font-family:var(--font-b);font-weight:600;font-size:14px;
  border-radius:var(--r-md);
  transition:all .15s ease;
}
.actions-row__btn:hover{border-color:var(--border-strong);background:var(--bg-surface-hover)}
.actions-row__btn.is-saved{
  color:var(--primary);border-color:var(--border-accent);background:var(--primary-softer);
}
.actions-row__btn.is-saved svg{fill:var(--primary)}
.actions-row__btn svg{width:18px;height:18px;stroke-width:2;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}
@media (min-width:1024px){.actions-row{display:none}}

/* ============================================================
   5. META COLUMN (right) — desktop only
   ============================================================ */
.meta-block{
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:18px;
}
.meta-block__title{
  font-family:var(--font-m);font-weight:500;font-size:11px;letter-spacing:.10em;text-transform:uppercase;
  color:var(--text-muted);margin:0 0 14px;
  display:flex;align-items:center;gap:8px;
}
.meta-block__title::after{
  content:"";flex:1;height:1px;background:var(--border);
}

/* Author expanded card */
.author-expanded{padding:20px}
.author-expanded__head{
  display:flex;align-items:flex-start;gap:14px;margin-bottom:14px;
}
.author-expanded__head .avatar{width:56px;height:56px;flex:0 0 auto}
.author-expanded__main{flex:1 1 auto;min-width:0}
.author-expanded__name{
  font-family:var(--font-h);font-weight:700;font-size:16px;color:var(--text-primary);
  margin:0 0 4px;line-height:1.25;letter-spacing:-.005em;
}
.author-expanded__meta{
  font-family:var(--font-m);font-size:12px;color:var(--text-muted);letter-spacing:.02em;
}
.author-expanded__desc{
  font-size:13.5px;color:var(--text-secondary);line-height:1.55;
  margin:0 0 14px;
}
.author-expanded__btn{
  display:block;width:100%;padding:9px;background:var(--primary);color:#06121A;
  border-radius:var(--r-md);font-weight:700;text-align:center;font-size:14px;
  letter-spacing:-.005em;transition:background .15s ease;
}
.author-expanded__btn:hover{background:var(--primary-hover);color:#06121A}
.author-expanded__btn.is-on{background:rgba(79,195,247,.10);border:1px solid rgba(79,195,247,.30);color:var(--primary);padding:8px}
.author-expanded__btn.is-on::before{content:"✓ ";font-weight:700}

.author-expanded__pubs{
  margin-top:18px;padding-top:16px;
  border-top:1px solid var(--border);
  display:flex;flex-direction:column;gap:1px;
}
.pub-item{
  display:flex;flex-direction:column;gap:4px;
  padding:10px 0;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:padding .15s ease;
}
.pub-item:last-child{border-bottom:0}
.pub-item:hover{padding-left:4px}
.pub-item:hover .pub-item__title{color:var(--primary)}
.pub-item__title{
  font-size:13.5px;font-weight:500;color:var(--text-primary);line-height:1.35;
  transition:color .15s ease;
}
.pub-item__meta{
  font-family:var(--font-m);font-size:11px;letter-spacing:.02em;
  color:var(--text-muted);
}

/* Similar opportunities mini cards */
.similar-list{display:flex;flex-direction:column;gap:10px}
.similar-card{
  display:flex;flex-direction:column;gap:8px;
  padding:14px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  cursor:pointer;
  transition:all .15s ease;
}
.similar-card:hover{background:var(--bg-surface-hover);border-color:var(--border-strong);transform:translateX(2px)}
.similar-card__top{display:flex;align-items:center;gap:8px}
.similar-card__avatar{width:24px;height:24px;border-radius:50%;flex:0 0 auto;overflow:hidden;border:1.5px solid var(--gray-600)}
.similar-card__avatar.amber{border-color:var(--accent)}
.similar-card__avatar.cyan{border-color:var(--primary)}
.similar-card__author{
  font-family:var(--font-m);font-size:11px;color:var(--text-muted);
  letter-spacing:.02em;flex:1 1 auto;min-width:0;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.similar-card__title{
  font-family:var(--font-h);font-weight:600;font-size:14px;
  color:var(--text-primary);line-height:1.35;
  letter-spacing:-.005em;margin:0;
}
.similar-card__foot{display:flex;align-items:center;gap:8px;margin-top:2px}
.deadline-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 9px;background:var(--accent-soft);color:var(--accent);
  border:1px solid rgba(244,162,97,.20);
  border-radius:var(--r-pill);
  font-size:11px;font-weight:600;
  font-family:var(--font-m);letter-spacing:.01em;
}
.deadline-pill svg{width:11px;height:11px;stroke-width:2.4}
.deadline-pill.urgent{background:rgba(242,107,107,.10);color:#F26B6B;border-color:rgba(242,107,107,.25)}
.tag-mini{
  font-family:var(--font-m);font-size:10.5px;letter-spacing:.04em;
  color:var(--text-muted);
}

/* Avatars (shared) */
.avatar{
  flex:0 0 auto;width:40px;height:40px;border-radius:50%;
  display:grid;place-items:center;overflow:hidden;
  background:#11171D;
  border:2px solid var(--gray-500);
  position:relative;
}
.avatar--lg{width:56px;height:56px;border-width:2px}
.avatar--cyan{border-color:var(--primary)}
.avatar--navy{border-color:#3A4A60}
.avatar--amber{border-color:var(--accent)}
.avatar--sage{border-color:var(--support)}
.avatar--coral{border-color:var(--coral)}
.avatar--plum{border-color:var(--plum)}
.avatar svg{width:100%;height:100%}

/* ============================================================
   6. "MORE FROM AUTHOR" — full width below
   ============================================================ */
.more-from{
  margin-top:24px;
  padding-top:32px;
  border-top:1px solid var(--border);
  display:flex;flex-direction:column;gap:18px;
}
.more-from__head{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.more-from__title{
  font-family:var(--font-h);font-weight:700;font-size:20px;letter-spacing:-.01em;
  color:var(--text-primary);margin:0;line-height:1.3;
  display:flex;align-items:center;gap:10px;
}
.more-from__title::before{
  content:"";width:3px;height:18px;background:var(--accent);border-radius:2px;
  box-shadow:0 0 8px rgba(244,162,97,.45);
}
.more-from__cta{
  font-size:13.5px;font-weight:600;color:var(--primary);
  display:inline-flex;align-items:center;gap:5px;
}
.more-from__cta svg{width:14px;height:14px;stroke-width:2.2;transition:transform .15s ease}
.more-from__cta:hover svg{transform:translateX(2px)}

.more-from__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
@media (min-width:640px){.more-from__grid{grid-template-columns:1fr 1fr 1fr;gap:16px}}

.author-pub-card{
  display:flex;flex-direction:column;gap:12px;
  padding:16px;
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  cursor:pointer;
  transition:all .2s ease;
}
.author-pub-card:hover{background:var(--bg-surface-hover);border-color:var(--border-strong);transform:translateY(-2px)}
.author-pub-card__media{
  position:relative;aspect-ratio:16/10;
  background:var(--bg-elevated-0);border-radius:var(--r-md);overflow:hidden;
}
.author-pub-card__media svg{width:100%;height:100%}
.author-pub-card__meta{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-m);font-size:11px;letter-spacing:.04em;color:var(--text-muted);
}
.author-pub-card__meta .sep{color:var(--gray-600)}
.author-pub-card__title{
  font-family:var(--font-h);font-weight:700;font-size:16px;color:var(--text-primary);
  line-height:1.3;letter-spacing:-.005em;margin:0;
  /* clamp 3 lines */
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.author-pub-card__foot{display:flex;align-items:center;gap:8px;margin-top:auto}

.more-from__btn{
  align-self:center;margin-top:8px;
  padding:11px 24px;border:1px solid var(--border-strong);
  background:transparent;color:var(--text-primary);
  font-weight:600;font-size:14px;border-radius:var(--r-md);
  transition:all .15s ease;
}
.more-from__btn:hover{border-color:var(--primary);background:var(--primary-softer);color:var(--primary)}

/* ============================================================
   7. FOOTER (same as v2)
   ============================================================ */
.footer{
  background:var(--bg-elevated-0);
  border-top:1px solid var(--border);
  padding:36px 16px calc(96px + env(safe-area-inset-bottom));
  font-size:13.5px;color:var(--text-secondary);
}
.footer__inner{
  max-width:var(--max-w);margin:0 auto;
  display:flex;flex-direction:column;gap:20px;
}
.footer__brand{display:flex;align-items:center;gap:10px}
.logo{display:flex;align-items:center;gap:10px;color:var(--text-primary);font-family:var(--font-h);font-weight:800;font-size:16px;letter-spacing:-.015em}
.logo__mark{
  width:28px;height:28px;border-radius:7px;
  background:linear-gradient(135deg,#4FC3F7 0%,#0090C8 100%);
  display:grid;place-items:center;color:#06121A;font-family:var(--font-h);font-weight:800;font-size:13px;letter-spacing:-.04em;
  box-shadow:0 4px 12px rgba(79,195,247,.30), inset 0 1px 0 rgba(255,255,255,.20);
}
.logo__text{display:inline-flex;align-items:baseline}
.logo__text .colon{color:var(--primary)}
.footer__desc{margin:0;max-width:48ch;line-height:1.55}
.footer__contact{margin:0;font-family:var(--font-m);font-size:13px}
.footer__contact strong{color:var(--text-primary);font-weight:500;text-transform:uppercase;letter-spacing:.05em;font-size:11px;display:block;margin-bottom:3px}
.footer__contact a{color:var(--text-primary);font-weight:500}
.footer__links{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.footer__links a{color:var(--text-secondary)}
.footer__links a:hover{color:var(--primary)}
.footer__links span{color:var(--gray-600)}
.footer__copyright{font-family:var(--font-m);font-size:11.5px;color:var(--text-muted);letter-spacing:.04em}

@media (min-width:1024px){
  .footer{padding:40px 32px 40px}
  .footer__inner{flex-direction:row;align-items:flex-start;flex-wrap:wrap;gap:48px;justify-content:space-between}
  .footer__left{display:flex;flex-direction:column;gap:12px;max-width:340px}
  .footer__right{display:flex;flex-direction:column;gap:12px;align-items:flex-end;text-align:right}
}

/* ============================================================
   8. MOBILE BOTTOM NAV
   ============================================================ */
.bottomnav{
  position:fixed;left:0;right:0;bottom:0;z-index:60;
  background:rgba(11,16,20,.88);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-top:1px solid var(--border);
  padding:6px 0 calc(6px + env(safe-area-inset-bottom));
  display:flex;
}
.bottomnav__item{
  flex:1 1 0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  padding:6px 4px;color:var(--text-muted);
  font-size:11px;font-weight:500;
  transition:color .15s ease;
}
.bottomnav__item:hover{color:var(--text-secondary)}
.bottomnav__item svg{width:22px;height:22px;stroke-width:1.85}

@media (min-width:1024px){
  .bottomnav{display:none}
  .footer{padding-bottom:40px}
}

/* ============================================================
   9. FLOATING CHATBOT FAB (mobile only)
   ============================================================ */
.fab-bot{
  position:fixed;
  right:16px;
  bottom:calc(76px + env(safe-area-inset-bottom));
  z-index:55;
  width:52px;height:52px;border-radius:50%;
  background:var(--primary);
  color:#06121A;
  display:grid;place-items:center;
  box-shadow:
    0 6px 20px rgba(79,195,247,.30),
    0 2px 6px rgba(0,0,0,.40),
    inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform .15s ease, box-shadow .15s ease;
  border:none;cursor:pointer;
}
.fab-bot::before{
  content:"";position:absolute;inset:-4px;border-radius:50%;
  background:rgba(79,195,247,.30);
  z-index:-1;
  animation:fab-pulse 2.4s ease-in-out infinite;
}
@keyframes fab-pulse{
  0%,100%{transform:scale(1);opacity:.6}
  50%{transform:scale(1.18);opacity:0}
}
.fab-bot:hover{transform:scale(1.06);box-shadow:0 8px 24px rgba(79,195,247,.40),0 2px 6px rgba(0,0,0,.40)}
.fab-bot:active{transform:scale(0.96)}
.fab-bot svg{width:22px;height:22px;stroke-width:2}
@media (min-width:1024px){
  .fab-bot{display:none}
}

/* ============================================================
   Pulse keyframe (eyebrow dot)
   ============================================================ */
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(111,171,143,.50)}
  50%{box-shadow:0 0 0 7px rgba(111,171,143,0)}
}