/* ============================================================
   Pharm-Vision site — component styles
   Depends on colors_and_type.css tokens.
   ============================================================ */

/* ---------- Top bar / header ---------- */
.site-header{
  position: sticky; top:0; z-index:50;
  background: rgba(255,255,255,.86);
  backdrop-filter: saturate(150%) blur(14px);
  border-bottom: 1px solid var(--line);
}
.nav{
  max-width: var(--maxw); margin-inline:auto;
  padding: 14px var(--gutter);
  display:flex; align-items:center; gap: 28px;
}
.nav__logo{ height:34px; width:auto; flex:none; }
.pvlogo{ display:inline-flex; align-items:center; gap:9px; font-family:var(--font); font-weight:800; font-size:22px; letter-spacing:-.03em; color:var(--ink); line-height:1; white-space:nowrap; }
.pvlogo b{ color:var(--orange); font-weight:800; }
.pvlogo__mark{ width:1.2em; height:1.2em; flex:none; display:block; }
.pvlogo--foot{ color:#fff; }
.nav__logo-wrap{ display:flex; align-items:center; gap:11px; }
.nav__badge{ font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--orange); border:1px solid #f3d9cd; background:var(--orange-soft-2);
  padding:3px 8px; border-radius:var(--r-pill); }
.nav__links{ display:flex; align-items:center; gap:26px; margin-left:8px; }
.nav__links a{ font-weight:600; font-size:15px; color:var(--body); transition:color .18s; position:relative; }
.nav__links a::after{ content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px;
  background:var(--orange); transform:scaleX(0); transform-origin:left; transition:transform .22s var(--ease); }
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after, .nav__links a.active::after{ transform:scaleX(1); }
.nav__links a.active{ color:var(--ink); }
.nav__spacer{ flex:1; }
.nav__cta{ display:flex; align-items:center; gap:10px; }
.nav__login{ font-weight:600; font-size:15px; color:var(--ink); padding:9px 4px; }
.nav__login:hover{ color:var(--orange); }
.burger{ display:none; }

@media (max-width: 940px){
  .nav__links{ display:none; }
  .nav__login{ display:none; }
}

/* ---------- Background line motif (echoes deck's faint geometry) ---------- */
.bg-motif{ position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:0; }
.bg-motif svg{ position:absolute; opacity:.5; }

/* ---------- Hero ---------- */
.hero{ position:relative; overflow:hidden; padding: clamp(54px,8vw,104px) 0 clamp(48px,6vw,86px); }
.hero__inner{ position:relative; z-index:2; max-width: 920px; }
.hero .h1{ margin-top:18px; }
.hero__sub{ margin-top:22px; max-width: 720px; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }

/* floating capsule motif (glossy two-piece pharma capsule, brand-orange) */
.capsule{ position:absolute; z-index:1; border-radius:var(--r-pill); overflow:hidden;
  background:
    linear-gradient(177deg, rgba(255,255,255,.70) 0%, rgba(255,255,255,.10) 24%, rgba(255,255,255,0) 46%, rgba(140,38,4,.30) 82%, rgba(116,26,0,.52) 100%),
    linear-gradient(90deg, #F0732F 0%, #EA5A1E 43%, #C7420E 45.5%, #AF370A 47%, #E2531A 49%, #EC6526 100%);
  box-shadow: 0 24px 44px rgba(150,45,8,.30), inset 0 2px 5px rgba(255,255,255,.40), inset 0 -9px 20px rgba(116,26,0,.42);
}
.capsule::before{ content:""; position:absolute; left:7%; right:7%; top:15%; height:24%; border-radius:999px; filter:blur(2.5px);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.92) 35%, rgba(255,255,255,.30) 65%, transparent); }
.capsule::after{ content:""; position:absolute; left:5%; top:18%; width:20%; height:64%; border-radius:999px; filter:blur(3px);
  background: radial-gradient(closest-side, rgba(255,255,255,.55), transparent); }

/* real capsule artwork (from the deck) — floating */
.capsule-img{ position:absolute; z-index:1; pointer-events:none; user-select:none;
  filter: drop-shadow(0 26px 38px rgba(150,45,8,.22));
  animation: floaty 7s var(--ease) infinite; }
@keyframes floaty{ 0%,100%{ transform: translateY(0) rotate(0deg); } 50%{ transform: translateY(-18px) rotate(-2.5deg); } }
@media (prefers-reduced-motion: reduce){ .capsule-img{ animation:none; } }

/* ---------- Stat tiles (deck style) ---------- */
.stat-row{ display:grid; grid-template-columns: repeat(4,1fr); gap:14px; }
.stat{ position:relative; padding:22px 22px 20px; border:1px solid var(--line); border-radius:var(--r-sm); background:var(--surface); }
.stat--orange{ background:var(--orange); border-color:var(--orange); color:#fff; }
.stat--wide{ grid-column: span 2; }
.stat__num{ font-weight:800; font-size: clamp(26px,3vw,40px); letter-spacing:-.02em; color:var(--orange); line-height:1; }
.stat--orange .stat__num{ color:#fff; }
.stat__cap{ margin-top:10px; font-weight:600; color:var(--muted); }
.stat--orange .stat__cap{ color:rgba(255,255,255,.92); }
.stat .icon-tile{ position:absolute; top:16px; right:16px; }
.stat--orange .icon-tile{ background:#fff; color:var(--orange); }

/* ---------- Section header ---------- */
.sec-head{ max-width: 760px; }
.sec-head .h2{ margin-top:16px; }
.sec-head p{ margin-top:16px; }

/* ---------- Feature cards grid ---------- */
.features{ display:grid; grid-template-columns: repeat(3,1fr); gap:18px; margin-top:48px; }
.feature{ position:relative; }
.feature__icon{ width:48px; height:48px; border-radius:var(--r-sm); display:grid; place-items:center;
  background:var(--orange-soft); color:var(--orange); margin-bottom:18px; }
.feature__icon svg{ width:26px; height:26px; }
.feature h3{ font-size:21px; margin-bottom:10px; }
.feature p{ color:var(--muted); font-size:15.5px; }
.feature__num{ position:absolute; top:24px; right:26px; font-weight:800; color:var(--line); font-size:30px; }

/* ---------- Steps (horizontal 1-2-3-4) ---------- */
.steps{ display:grid; grid-template-columns: repeat(4,1fr); gap:16px; margin-top:48px; position:relative; }
.step{ position:relative; padding:26px 24px 30px; border:1px solid var(--line); border-radius:var(--r-sm); background:var(--surface); }
.step:last-child{ background:var(--navy); border-color:var(--navy); color:#dce6f1; }
.step__n{ font-weight:800; font-size:34px; color:var(--faint); line-height:1; }
.step:last-child .step__n{ color:var(--orange); }
.step h3{ font-size:19px; margin:20px 0 12px; }
.step:last-child h3{ color:#fff; }
.step p{ font-size:14.5px; color:var(--muted); }
.step:last-child p{ color:#aebfd2; }
.step .icon-tile{ position:absolute; top:18px; right:18px; }
.step:not(:last-child)::after{ content:""; position:absolute; top:64px; right:-9px; width:18px; height:2px; background:var(--orange); z-index:2; }

/* ---------- Callout bar (peach, deck footer style) ---------- */
.callout{ margin-top:42px; background:var(--orange-soft-2); border:1px solid #f6ddd2; border-radius:var(--r-sm);
  padding:22px 28px; display:flex; align-items:center; gap:14px; justify-content:center;
  color:var(--orange-700); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:15px; text-align:center; }
.callout::before{ content:"→"; font-weight:800; }

/* ---------- Pricing table ---------- */
.ptable-wrap{ border:1.5px solid var(--orange); border-radius:var(--r-sm); overflow:hidden; margin-top:44px; box-shadow:var(--sh-2); background:#fff; }
.ptable{ width:100%; border-collapse:collapse; font-variant-numeric: tabular-nums; }
.ptable thead th{ background:var(--orange); color:#fff; font-weight:700; text-transform:uppercase; letter-spacing:.06em;
  font-size:13px; padding:18px 20px; text-align:right; }
.ptable thead th:first-child{ text-align:left; }
.ptable tbody td{ padding:17px 20px; text-align:right; font-weight:700; color:var(--ink); border-top:1px dotted #d6d5d3; white-space:nowrap; }
.ptable tbody td:first-child{ text-align:left; font-weight:600; color:var(--body); white-space:normal; }
.ptable tbody tr:hover{ background:var(--orange-soft-2); }
.ptable tbody tr.is-highlight{ background:var(--orange-soft); }
.ptable tbody tr.is-highlight td:first-child{ color:var(--orange-700); }
.ptable .rub{ color:var(--muted); font-weight:600; }
.ptable .row-tag{ display:inline-block; margin-left:8px; font-size:11px; font-weight:700; letter-spacing:.08em;
  text-transform:uppercase; color:var(--orange); background:var(--orange-soft); padding:2px 7px; border-radius:var(--r-pill); vertical-align:middle; }

/* ---------- Metrics list (analytics page) ---------- */
.metric-list{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:40px; }
.metric{ display:flex; align-items:center; gap:16px; padding:20px 22px; background:#fff; border:1px solid var(--line); border-radius:var(--r-sm); }
.metric__dot{ width:12px; height:12px; border-radius:50%; background:var(--orange); flex:none; }
.metric strong{ color:var(--ink); font-weight:700; }

/* ---------- Specialist base grid (deck slide 9) ---------- */
.basebar{ display:flex; flex-wrap:wrap; align-items:baseline; gap:10px 22px; margin-top:30px; }
.basebar__big{ font-weight:800; font-size:clamp(40px,5.5vw,68px); color:var(--orange); letter-spacing:-.02em; line-height:1; }
.basebar__cap{ color:var(--muted); font-weight:600; font-size:17px; }
.specdb{ display:grid; grid-template-columns:repeat(6,1fr); gap:12px; margin-top:34px; }
.specdb__item{ padding:18px 16px; border:1px solid var(--line); border-radius:var(--r-sm); background:#fff; transition:transform .25s var(--ease), box-shadow .25s var(--ease); }
.specdb__item:hover{ transform:translateY(-3px); box-shadow:var(--sh-2); }
.specdb__item.is-hl{ background:var(--navy); border-color:var(--navy); }
.specdb__icon{ width:30px; height:30px; color:var(--orange); margin-bottom:12px; }
.specdb__item.is-hl .specdb__icon{ color:#fff; }
.specdb__n{ font-weight:800; font-size:23px; color:var(--ink); letter-spacing:-.01em; font-variant-numeric:tabular-nums; }
.specdb__item.is-hl .specdb__n{ color:#fff; }
.specdb__l{ font-size:12.5px; color:var(--muted); margin-top:5px; line-height:1.25; }
.specdb__item.is-hl .specdb__l{ color:#aebfd2; }

/* ---------- Attention stats (deck slide 11) ---------- */
.attn{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:46px; }
.attn__card{ padding:30px 26px; border:1px solid var(--line); border-radius:var(--r-sm); background:#fff; }
.attn__card:first-child{ background:var(--orange); border-color:var(--orange); color:#fff; }
.attn__n{ font-weight:800; font-size:clamp(40px,5vw,60px); color:var(--orange); line-height:1; letter-spacing:-.02em; }
.attn__card:first-child .attn__n{ color:#fff; }
.attn__t{ margin-top:14px; font-weight:600; color:var(--muted); font-size:15.5px; }
.attn__card:first-child .attn__t{ color:rgba(255,255,255,.92); }

/* ---------- Generations scroll-swap (deck slides 14-15) ---------- */
.gens{ position:relative; }
.gens__inner{ display:grid; grid-template-columns:0.92fr 1.08fr; gap:clamp(28px,5vw,64px); align-items:start; }
.gens__sticky{ position:sticky; top:96px; align-self:start; }
.gens__stage{ position:relative; width:100%; aspect-ratio:4/5; border-radius:var(--r-md); overflow:hidden;
  border:1px solid var(--line); background:var(--surface-2); box-shadow:var(--sh-2); }
.gens__photo{ position:absolute; inset:0; opacity:0; transform:scale(1.04); transition:opacity .6s var(--ease), transform 1.2s var(--ease); }
.gens__photo.is-active{ opacity:1; transform:scale(1); }
.gens__photo image-slot{ width:100%; height:100%; display:block; }
.gens__tag{ position:absolute; left:16px; bottom:16px; z-index:3; display:flex; gap:8px; align-items:center;
  background:rgba(26,26,28,.62); backdrop-filter:blur(8px); color:#fff; padding:9px 14px; border-radius:var(--r-pill);
  font-weight:700; font-size:14px; opacity:0; transform:translateY(8px); transition:.5s var(--ease); }
.gens__tag.is-active{ opacity:1; transform:none; }
.gens__tag b{ color:#ffb38e; }
.gen-block{ padding:14vh 0; border-top:1px solid var(--line); }
.gen-block:first-child{ border-top:0; padding-top:4vh; }
.gen-block__age{ display:inline-block; font-weight:800; font-size:13px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--orange); background:var(--orange-soft-2); border:1px solid #f3d9cd; padding:5px 12px; border-radius:var(--r-pill); }
.gen-block h3{ font-size:clamp(24px,2.6vw,34px); margin:18px 0 8px; }
.gen-block .gen-sub{ color:var(--muted); }
.gen-chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:22px; }
.gen-chip{ display:flex; align-items:center; gap:10px; padding:11px 16px; border:1px solid var(--line); border-radius:var(--r-pill);
  background:#fff; font-weight:600; font-size:14.5px; color:var(--body); }
.gen-chip b{ color:var(--orange); font-weight:800; font-variant-numeric:tabular-nums; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--navy); color:#c7d4e3; margin-top:0; }
.site-footer .wrap{ padding-block: 56px 40px; }
.foot-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap:32px; }
.site-footer a{ color:#c7d4e3; }
.site-footer a:hover{ color:#fff; }
.foot-logo{ height:34px; filter: brightness(0) invert(1); opacity:.96; }
.site-footer .foot-skolkovo{ display:inline-flex; align-items:center; gap:11px; margin-top:22px; background:#fff; padding:9px 15px; border-radius:10px; box-shadow:var(--sh-1); }
.foot-skolkovo__cap{ font-size:12px; font-weight:700; color:var(--ink); letter-spacing:.02em; text-transform:uppercase; }
.foot-skolkovo__logo{ height:24px; width:auto; display:block; }
.foot-skolkovo__sep{ width:1px; height:24px; background:var(--line); }

/* ---------- Attention bullets (highlighted) ---------- */
.attn-bullets{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.attn-bullet{ display:flex; align-items:center; gap:14px; padding:18px 22px; background:var(--orange-soft);
  border:1px solid #f3cdbd; border-radius:var(--r-sm); font-weight:700; color:var(--orange-700); font-size:16px; }
.attn-bullet svg{ width:22px; height:22px; color:var(--orange); flex:none; }

/* ---------- Channels bubble chart (deck slide 19) ---------- */
.seg{ display:inline-flex; background:var(--bg); border:1px solid var(--line); border-radius:var(--r-pill); padding:5px; gap:4px; }
.seg button{ border:0; background:transparent; padding:10px 20px; border-radius:var(--r-pill); font:inherit; font-weight:700;
  font-size:14.5px; color:var(--muted); cursor:pointer; transition:.2s var(--ease); }
.seg button.active{ background:var(--orange); color:#fff; box-shadow:var(--sh-orange); }
.seg button:not(.active):hover{ color:var(--ink); }
.bubble-chart{ position:relative; height:480px; margin:14px 0 8px; padding:0 0 0 38px; }
.bc-plot{ position:relative; height:100%; border-left:2px solid var(--line); border-bottom:2px solid var(--line); }
.bc-ylab{ position:absolute; left:-26px; top:50%; transform:rotate(-90deg) translateX(50%); transform-origin:left;
  font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); white-space:nowrap; }
.bc-xlab{ position:absolute; right:0; bottom:-30px; font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); }
.bc-grid{ position:absolute; inset:0; }
.bc-grid i{ position:absolute; left:0; right:0; border-top:1px dashed #ececea; }
.bubble{ position:absolute; transform:translate(-50%,50%); border-radius:50%; transition:bottom 1.1s var(--ease-out), left .6s var(--ease);
  box-shadow:0 8px 18px rgba(16,35,56,.16), inset 0 -3px 8px rgba(0,0,0,.22), inset 0 3px 7px rgba(255,255,255,.45); cursor:default; }
.bubble.b-orange{ background:radial-gradient(circle at 32% 28%, #ffc09e, var(--orange) 56%, var(--orange-700)); }
.bubble.b-navy{ background:radial-gradient(circle at 32% 28%, #6b8db2, var(--navy) 56%, var(--navy-900)); }
.bubble.b-gray{ background:radial-gradient(circle at 32% 28%, #e2e5e8, #a3aab1 56%, #767c83); }
.bubble__lab{ position:absolute; left:calc(100% + 9px); top:50%; transform:translateY(-50%); white-space:nowrap;
  font-size:12.5px; font-weight:600; color:var(--body); }
.bubble.lbl-left .bubble__lab{ left:auto; right:calc(100% + 9px); }
.bc-note{ margin-top:42px; text-align:center; font-weight:700; color:var(--ink); font-size:clamp(16px,2vw,20px); max-width:760px; margin-inline:auto; }
.bc-note span{ color:var(--orange); }

/* ---------- Generations radar over silhouette (deck slide 14-15) ---------- */
.radar-stage{ position:relative; width:100%; max-width:440px; margin-inline:auto; aspect-ratio:1/1.12; }
.radar-bust{ position:absolute; left:50%; bottom:0; transform:translateX(-50%); width:66%; color:#dcdcda; z-index:1; }
.radar-wrap{ position:absolute; left:50%; top:0; transform:translateX(-50%); width:100%; z-index:2; }
.radar-svg{ width:100%; height:auto; display:block; overflow:visible; }
.radar-poly{ transition:fill .5s ease; }
.radar-age{ font-weight:800; letter-spacing:-.01em; text-anchor:middle; }
.radar-name{ text-anchor:middle; font-weight:700; }
.radar-axislab{ font-size:9.5px; font-weight:600; fill:var(--faint); }
.radar-axislab.hot{ fill:var(--orange); font-weight:800; }
.foot-col h5{ color:#fff; font-size:13px; letter-spacing:.14em; text-transform:uppercase; margin:0 0 16px; font-weight:700; }
.foot-col a{ display:block; padding:5px 0; font-size:15px; }
.foot-bottom{ border-top:1px solid rgba(255,255,255,.12); margin-top:40px; padding-top:22px;
  display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; font-size:13px; color:#8ea2ba; }
.foot-soc{ display:flex; gap:10px; }
.foot-soc a{ width:38px; height:38px; border-radius:var(--r-sm); display:grid; place-items:center;
  background:rgba(255,255,255,.08); transition:background .2s; }
.foot-soc a:hover{ background:var(--orange); }
.foot-soc svg{ width:18px; height:18px; }

@media (max-width: 980px){
  .features,.steps,.stat-row{ grid-template-columns: repeat(2,1fr); }
  .metric-list{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
  .step:not(:last-child)::after{ display:none; }
  .stat--wide{ grid-column: span 2; }
  .specdb{ grid-template-columns:repeat(3,1fr); }
  .attn{ grid-template-columns:1fr; }
  .gens__inner{ grid-template-columns:1fr; }
  .gens__sticky{ position:relative; top:0; max-width:380px; margin:0 auto 8px; }
  .gen-block{ padding:8vh 0; text-align:center; }
  .gen-chips{ justify-content:center; }
  .attn-bullets{ grid-template-columns:1fr; }
  .bubble__lab{ font-size:11px; }
}
@media (max-width: 600px){
  .features,.steps{ grid-template-columns:1fr; }
  .ptable thead th,.ptable tbody td{ padding:13px 12px; font-size:13px; }
  .specdb{ grid-template-columns:repeat(2,1fr); }
  .bubble-chart{ height:380px; }
}
