/* Re:Vet AI — program page styles */
/* ============================================================
   Re:Vet AI — Program Detail (Навчання → Перекваліфікація)
   Same dark editorial tokens as detail.html / sections / navchannia
   ============================================================ */









@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}

/* ============================================================
   HEADER — same as detail.html
   ============================================================ */
.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-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}}

.logo{display:none;align-items:center;gap:10px;color:var(--text-primary);font-family:var(--font-h);font-weight:800;font-size:18px;letter-spacing:-.015em}
.logo__mark{
  width:32px;height:32px;border-radius:9px;
  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:15px;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)}

.nav{display:none;align-items:center;gap:2px}
.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}
.header-avatar{
  width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;overflow:hidden;
  border:2px solid var(--primary);
  background:#11171D;cursor:pointer;
  transition:box-shadow .2s ease;
}
.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}
  .back-btn{display:none}
  .logo{display:flex}
  .nav{display:flex}
}

/* ============================================================
   LAYOUT
   ============================================================ */
.detail{
  max-width:var(--max-w);
  margin:0 auto;
  padding:20px 16px 120px;
}
.detail__grid{
  display:flex;flex-direction:column;gap:28px;
}

.rail{display:none}
.meta-col{display:flex;flex-direction:column;gap:20px}

.main-col{display:flex;flex-direction:column;gap:24px;min-width:0}

.more-from-section{margin-top:8px}

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

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.breadcrumbs{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-b);font-size:13px;
  color:var(--text-muted);
  overflow:hidden;
  white-space:nowrap;
  min-width:0;
}
.breadcrumbs a{
  color:var(--text-secondary);
  font-weight:500;
  transition:color .15s ease;
  flex:0 0 auto;
}
.breadcrumbs a:hover{color:var(--primary)}
.breadcrumbs .sep{
  color:var(--gray-600);
  flex:0 0 auto;
  font-size:14px;
  line-height:1;
}
.breadcrumbs .current{
  color:var(--text-muted);
  font-weight:400;
  overflow:hidden;
  text-overflow:ellipsis;
  min-width:0;
}

@media (min-width:1024px){
  .breadcrumbs{font-size:13.5px}
}

/* ============================================================
   PROGRAM HEAD (title + organization subtitle)
   ============================================================ */
.program-head{display:flex;flex-direction:column;gap:8px}
.program-head__title{
  font-family:var(--font-h);
  font-weight:800;
  font-size:clamp(28px, 5.4vw, 40px);
  line-height:1.12;
  letter-spacing:-.02em;
  color:var(--text-primary);
  margin:0;
}
.program-head__org{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-b);
  font-size:15px;
  font-weight:500;
  color:var(--text-secondary);
  margin:0;
  line-height:1.4;
}
.program-head__org svg{
  width:15px;height:15px;
  color:var(--primary);
  flex:0 0 auto;
  stroke-width:1.9;
}

/* ============================================================
   PARAMS CARD (5 key params, icon grid)
   ============================================================ */
.params-card{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid var(--border);
}
.params-card__item{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px 14px;
  background:var(--bg-surface);
  min-width:0;
}
.params-card__item--full{grid-column:1 / -1}
.params-card__icon{
  flex:0 0 auto;
  width:36px;height:36px;
  border-radius:10px;
  display:grid;place-items:center;
  background:rgba(79,195,247,.08);
  color:var(--primary);
  border:1px solid rgba(79,195,247,.18);
}
.params-card__icon svg{width:18px;height:18px;stroke-width:1.9}
.params-card__main{
  display:flex;flex-direction:column;gap:3px;
  min-width:0;flex:1 1 auto;
  padding-top:1px;
}
.params-card__label{
  font-family:var(--font-m);
  font-size:10.5px;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:var(--text-muted);
  font-weight:500;
}
.params-card__value{
  font-family:var(--font-b);
  font-weight:600;
  font-size:14.5px;
  color:var(--text-primary);
  line-height:1.35;
  word-wrap:break-word;
}

/* free variant — sage accent */
.params-card__item--free .params-card__icon{
  background:var(--support-soft);
  color:var(--support);
  border-color:rgba(111,171,143,.26);
}
.params-card__item--free .params-card__value{color:var(--support)}

@media (min-width:520px){
  .params-card__item{padding:16px 18px;gap:14px}
  .params-card__value{font-size:15px}
}
@media (min-width:1024px){
  .params-card__item{padding:18px 20px}
  .params-card__icon{width:40px;height:40px}
  .params-card__icon svg{width:20px;height:20px}
  .params-card__value{font-size:15.5px}
}

/* ============================================================
   ACTIONS ROW (mobile only — Save + Share)
   ============================================================ */
.actions-row{
  display:flex;gap:10px;
  margin:0;
}
.actions-row__btn{
  flex:1 1 0;
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 14px;
  background:rgba(255,255,255,.03);
  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{background:rgba(255,255,255,.06);border-color:var(--border-strong)}
.actions-row__btn svg{width:17px;height:17px;stroke-width:1.9;color:var(--text-secondary);transition:color .15s ease}
.actions-row__btn:hover svg{color:var(--primary)}
.actions-row__btn.is-saved{
  color:var(--primary);
  border-color:rgba(79,195,247,.28);
  background:rgba(79,195,247,.06);
}
.actions-row__btn.is-saved svg{color:var(--primary);fill:var(--primary)}

@media (min-width:1024px){
  .actions-row{display:none}
}

/* ============================================================
   APPLY BUTTON
   ============================================================ */
.btn-apply{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;
  background:linear-gradient(135deg, var(--primary) 0%, #38B0E5 100%);
  color:#06121A;
  font-family:var(--font-h);font-weight:700;font-size:16px;
  padding:16px 24px;
  border-radius:var(--r-md);
  letter-spacing:-.005em;
  box-shadow:0 8px 24px rgba(79,195,247,.20), 0 1px 0 rgba(255,255,255,.20) inset;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
}
.btn-apply:hover{
  background:linear-gradient(135deg, var(--primary-hover) 0%, #4AC0EC 100%);
  color:#06121A;
  transform:translateY(-1px);
  box-shadow:0 12px 28px rgba(79,195,247,.30), 0 1px 0 rgba(255,255,255,.20) inset;
}
.btn-apply:active{transform:translateY(0)}
.btn-apply svg{width:18px;height:18px;stroke-width:2.4;color:#06121A;transition:transform .15s ease}
.btn-apply:hover svg{transform:translateX(3px)}
.btn-apply--second{margin-top:8px}

@media (min-width:1024px){
  .btn-apply{font-size:17px;padding:18px 28px}
}

/* ============================================================
   ARTICLE BODY (brief description)
   ============================================================ */
.article-body{
  font-family:var(--font-b);
  font-size:16px;
  line-height:1.65;
  color:var(--text-secondary);
}
.article-body p{margin:0 0 14px}
.article-body p:last-child{margin-bottom:0}
.article-body strong{color:var(--text-primary);font-weight:600}

@media (min-width:1024px){
  .article-body{font-size:17px;line-height:1.7}
}

/* ============================================================
   ARTICLE SECTIONS
   ============================================================ */
.article-section{
  display:flex;flex-direction:column;gap:14px;
  padding-top:8px;
}
.article-section__title{
  font-family:var(--font-h);
  font-weight:700;
  font-size:20px;
  line-height:1.25;
  letter-spacing:-.01em;
  color:var(--text-primary);
  margin:0;
  position:relative;
  padding-left:14px;
}
.article-section__title::before{
  content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;
  background:var(--primary);
  border-radius:2px;
}
@media (min-width:1024px){
  .article-section__title{font-size:22px;padding-left:16px}
  .article-section__title::before{width:4px}
}

/* Bullet list */
.list-bullet{
  list-style:none;
  padding:0;margin:0;
  display:flex;flex-direction:column;gap:10px;
}
.list-bullet li{
  position:relative;
  padding-left:22px;
  font-size:15.5px;
  line-height:1.55;
  color:var(--text-secondary);
}
.list-bullet li::before{
  content:"";position:absolute;left:6px;top:10px;
  width:6px;height:6px;border-radius:50%;
  background:var(--primary);
  box-shadow:0 0 6px rgba(79,195,247,.45);
}
.list-bullet li strong{color:var(--text-primary);font-weight:600}
@media (min-width:1024px){
  .list-bullet li{font-size:16px}
}

/* Steps list */
.list-steps{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:14px;
}
.list-steps li{
  display:grid;
  grid-template-columns:auto 1px 1fr;
  gap:14px;
  align-items:flex-start;
  padding:16px 0;
  border-top:1px solid var(--border);
}
.list-steps li:first-child{border-top:0;padding-top:8px}
.list-steps__num{
  font-family:var(--font-m);
  font-size:13px;
  font-weight:500;
  color:var(--primary);
  letter-spacing:.04em;
  padding-top:2px;
}
.list-steps__sep{
  width:1px;background:var(--border);align-self:stretch;
}
.list-steps__text{
  font-size:15.5px;
  line-height:1.6;
  color:var(--text-secondary);
}
.list-steps__text strong{color:var(--text-primary);font-weight:600}
@media (min-width:1024px){
  .list-steps__text{font-size:16px}
}

/* ============================================================
   CONTACTS
   ============================================================ */
.contacts{
  display:flex;flex-direction:column;gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
}
.contacts__item{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;
  background:var(--bg-surface);
  color:var(--text-primary);
  text-decoration:none;
  transition:background .15s ease;
}
.contacts__item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}
.contacts__icon{
  flex:0 0 auto;width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;
  background:rgba(79,195,247,.08);
  color:var(--primary);
  border:1px solid rgba(79,195,247,.18);
}
.contacts__icon svg{width:17px;height:17px;stroke-width:1.9}
.contacts__main{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1 1 auto}
.contacts__label{
  font-family:var(--font-m);
  font-size:10.5px;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:var(--text-muted);
  font-weight:500;
}
.contacts__val{
  font-size:14.5px;
  font-weight:500;
  color:var(--text-primary);
  line-height:1.4;
  word-break:break-word;
}
@media (min-width:520px){
  .contacts__item{padding:16px 18px}
}

/* ============================================================
   UPDATE DATE
   ============================================================ */
.update-date{
  display:flex;align-items:center;gap:8px;
  padding-top:12px;
  border-top:1px solid var(--border);
  font-family:var(--font-m);
  font-size:12px;
  letter-spacing:.02em;
  color:var(--text-muted);
}
.update-date svg{width:13px;height:13px;color:var(--text-muted);stroke-width:1.9}

/* ============================================================
   LEFT RAIL (desktop)
   ============================================================ */
.rail{
  flex-direction:column;
  gap:10px;
  padding:8px;
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  width:var(--rail-w);
}
.rail__item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  padding:12px 6px;
  border-radius:var(--r-md);
  color:var(--text-secondary);
  background:transparent;
  border:1px solid transparent;
  font-family:var(--font-b);
  font-size:11px;font-weight:500;
  line-height:1.25;
  text-align:center;
  transition:all .15s ease;
}
.rail__item svg{width:20px;height:20px;stroke-width:1.85;transition:color .15s ease}
.rail__item:hover{color:var(--text-primary);background:rgba(255,255,255,.03)}
.rail__item.is-saved{
  color:var(--primary);
  background:rgba(79,195,247,.06);
  border-color:rgba(79,195,247,.20);
}
.rail__item.is-saved svg{fill:var(--primary)}
.rail__divider{
  height:1px;background:var(--border);margin:6px 4px;
}
.rail__apply{
  display:flex;align-items:center;justify-content:center;gap:6px;
  width:100%;
  padding:14px 8px;
  font-family:var(--font-h);font-weight:700;font-size:13px;
  line-height:1.25;
  text-align:center;
  background:linear-gradient(135deg, var(--primary) 0%, #38B0E5 100%);
  color:#06121A;
  border-radius:var(--r-md);
  letter-spacing:-.005em;
  box-shadow:0 6px 16px rgba(79,195,247,.20), 0 1px 0 rgba(255,255,255,.20) inset;
  transition:transform .15s ease, box-shadow .2s ease;
}
.rail__apply:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(79,195,247,.28), 0 1px 0 rgba(255,255,255,.20) inset;color:#06121A}
.rail__apply svg{width:14px;height:14px;stroke-width:2.4}

/* ============================================================
   META BLOCK (right sidebar shared shell)
   ============================================================ */
.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);
}

/* ============================================================
   SIMILAR PROGRAMS CARD LIST
   ============================================================ */
.similar-list{display:flex;flex-direction:column;gap:12px}
.similar-card{
  display:block;
  padding:14px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  text-decoration:none;
  color:var(--text-primary);
  transition:all .15s ease;
  cursor:pointer;
}
.similar-card:hover{
  background:rgba(255,255,255,.04);
  border-color:var(--border-accent);
  transform:translateX(2px);
  color:var(--text-primary);
}
.similar-card__org{
  font-family:var(--font-m);
  font-size:11px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--primary);
  font-weight:500;
  display:block;
  margin-bottom:7px;
}
.similar-card__title{
  font-family:var(--font-h);
  font-weight:600;
  font-size:14.5px;
  line-height:1.35;
  color:var(--text-primary);
  margin:0 0 10px;
  letter-spacing:-.005em;
}
.similar-card__params{
  display:flex;align-items:center;gap:8px 12px;
  flex-wrap:wrap;
  font-family:var(--font-b);
  font-size:12.5px;
  color:var(--text-muted);
}
.similar-card__params .p{display:inline-flex;align-items:center;gap:5px}
.similar-card__params .p--free{color:var(--support)}
.similar-card__params .p svg{width:12px;height:12px;stroke-width:2}
.similar-card__params .sep{color:var(--gray-600)}

/* ============================================================
   AUTHOR ROZDILU (section author block, desktop-only)
   ============================================================ */
.section-author{display:none}
@media (min-width:1024px){
  .section-author{display:block}
}
.section-author__head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.section-author__avatar{
  width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;overflow:hidden;
  border:2px solid var(--primary);
  background:#11171D;flex:0 0 auto;
}
.section-author__avatar svg{width:100%;height:100%}
.section-author__main{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1 1 auto}
.section-author__name{
  font-family:var(--font-h);font-weight:700;
  font-size:15px;line-height:1.25;
  color:var(--text-primary);
  margin:0;letter-spacing:-.005em;
}
.section-author__meta{
  font-family:var(--font-m);
  font-size:11.5px;
  color:var(--text-muted);
  margin:0;letter-spacing:.02em;
}
.section-author__desc{
  font-size:13.5px;
  line-height:1.55;
  color:var(--text-secondary);
  margin:0 0 14px;
}
.section-author__btn{
  display:flex;align-items:center;justify-content:center;gap:6px;
  width:100%;padding:10px 14px;
  background:rgba(79,195,247,.08);
  border:1px solid rgba(79,195,247,.25);
  color:var(--primary);
  font-family:var(--font-b);font-weight:600;font-size:14px;
  border-radius:var(--r-md);
  transition:all .15s ease;
}
.section-author__btn:hover{background:rgba(79,195,247,.16);border-color:var(--primary)}
.section-author__btn.is-on{background:var(--primary);color:#06121A;border-color:var(--primary)}
.section-author__btn.is-on::before{content:"✓ ";font-weight:700}

/* ============================================================
   MORE-FROM / Останні публікації за темою (full-width)
   ============================================================ */
.more-from-section{
  display:flex;flex-direction:column;gap:20px;
}
.more-from__head{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;
  padding-bottom:14px;
  border-bottom:1px solid var(--border);
}
.more-from__title{
  font-family:var(--font-h);
  font-weight:700;
  font-size:22px;
  letter-spacing:-.01em;
  color:var(--text-primary);
  margin:0;
}
.more-from__cta{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--primary);
  font-weight:600;font-size:13.5px;
  white-space:nowrap;
}
.more-from__cta svg{width:14px;height:14px;stroke-width:2.2;transition:transform .15s ease}
.more-from__cta:hover svg{transform:translateX(3px)}

.more-from__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
}
@media (min-width:640px){
  .more-from__grid{grid-template-columns:1fr 1fr}
}
@media (min-width:1024px){
  .more-from__title{font-size:24px}
  .more-from__grid{grid-template-columns:1fr 1fr 1fr;gap:20px}
}

/* Pub card */
.pub-card{
  display:flex;flex-direction:column;gap:12px;
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  transition:all .2s ease;
  cursor:pointer;
}
.pub-card:hover{
  background:var(--bg-surface-hover);
  border-color:var(--border-strong);
  transform:translateY(-2px);
  box-shadow:var(--sh-md);
}
.pub-card__media{
  width:100%;aspect-ratio:16/10;
  background:var(--bg-elevated-0);
  overflow:hidden;
}
.pub-card__media svg{width:100%;height:100%;display:block}
.pub-card__body{padding:0 16px 16px;display:flex;flex-direction:column;gap:8px}
.pub-card__meta{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-m);
  font-size:11.5px;
  letter-spacing:.04em;
  color:var(--text-muted);
}
.pub-card__meta .sep{color:var(--gray-600)}
.pub-card__title{
  font-family:var(--font-h);
  font-weight:700;
  font-size:16px;
  line-height:1.35;
  letter-spacing:-.005em;
  color:var(--text-primary);
  margin:0;
}
.pub-card__tags{display:flex;flex-wrap:wrap;gap:6px}
.tag-mini{
  font-family:var(--font-b);
  font-size:11.5px;font-weight:500;
  color:var(--text-secondary);
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  padding:3px 9px;
  border-radius:var(--r-pill);
}
@media (min-width:1024px){
  .pub-card__title{font-size:17px}
}

/* ============================================================
   FOOTER (same as detail.html)
   ============================================================ */
.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}
.footer .logo{display:flex;font-size:16px}
.footer .logo__mark{width:28px;height:28px;border-radius:7px;font-size:13px}
.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}
}

/* ============================================================
   MOBILE BOTTOM NAV (no active state — this is detail-style page)
   ============================================================ */
.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;
}
.bottomnav__item svg{width:22px;height:22px;stroke-width:1.85}
@media (min-width:1024px){
  .bottomnav{display:none}
  .footer{padding-bottom:40px}
}

/* ============================================================
   FAB chatbot (mobile only)
   ============================================================ */
.fab-bot{
  position:fixed;
  right:16px;
  bottom:calc(74px + env(safe-area-inset-bottom));
  z-index:55;
  width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(135deg, var(--primary) 0%, #38B0E5 100%);
  color:#06121A;
  box-shadow:0 8px 24px rgba(79,195,247,.36), inset 0 1px 0 rgba(255,255,255,.20);
  transition:transform .15s ease;
}
.fab-bot:hover{transform:scale(1.05)}
.fab-bot svg{width:22px;height:22px;stroke-width:2}
@media (min-width:1024px){
  .fab-bot{display:none}
}