/* main.css — pharma.worldofcontent | clinical trust | на токенах design-system */

*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  color: var(--color-neutral-800);
  background: var(--color-surface-background);
  -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4 { font-family: var(--font-heading); font-weight: var(--fw-semibold); line-height: var(--lh-tight); color: var(--color-neutral-900); margin: 0 0 var(--space-4); }
h1 { font-size: var(--fs-3xl); letter-spacing: var(--ls-tight); }
h2 { font-size: var(--fs-xl); }
h3 { font-size: var(--fs-lg); }
p { margin: 0 0 var(--space-4); }
a { color: var(--color-primary-600); text-decoration: none; }
a:hover { text-decoration: underline; }
img { max-width: 100%; height: auto; display: block; }

.container { max-width: 1200px; margin: 0 auto; padding: 0 var(--space-5); }
.container-narrow { max-width: 760px; }
.eyebrow { font-family: var(--font-heading); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-label); color: var(--color-neutral-500); margin-bottom: var(--space-2); }
.lead { font-size: var(--fs-md); line-height: var(--lh-relaxed); color: var(--color-neutral-700); max-width: 60ch; }
.muted { color: var(--color-neutral-500); }

.skip-link { position: absolute; left: -999px; top: 0; background: var(--color-primary-700); color: #fff; padding: var(--space-3); z-index: 1000; }
.skip-link:focus { left: 0; }
:focus-visible { outline: 2px solid var(--color-primary-500); outline-offset: 2px; }

/* Buttons */
.btn { display: inline-block; font-family: var(--font-heading); font-weight: var(--fw-semibold); font-size: var(--fs-base); padding: 14px 28px; border-radius: var(--radius-md); border: 1px solid transparent; cursor: pointer; transition: transform var(--dur-normal) var(--ease-standard), box-shadow var(--dur-normal) var(--ease-standard); }
.btn:hover { text-decoration: none; transform: scale(1.02); }
.btn-primary { background: var(--color-primary-500); color: var(--color-neutral-50); }
.btn-primary:hover { box-shadow: var(--shadow-md); }
.btn-secondary { background: transparent; color: var(--color-primary-600); border-color: var(--color-primary-500); }
.btn-accent { background: var(--color-accent-500); color: var(--color-accent-contrast); }
.btn-accent:hover { box-shadow: var(--shadow-lg); }

/* Header */
.site-header { background: var(--color-surface-elevated); border-bottom: 1px solid var(--color-neutral-200); position: sticky; top: 0; z-index: 50; }
.header-inner { display: flex; align-items: center; gap: var(--space-6); padding-top: var(--space-4); padding-bottom: var(--space-4); }
.logo { font-family: var(--font-heading); font-weight: var(--fw-bold); font-size: var(--fs-lg); color: var(--color-neutral-900); }
.logo span { color: var(--color-primary-500); }
.main-nav { display: flex; gap: var(--space-5); margin-left: auto; }
.main-nav a { font-family: var(--font-heading); font-size: var(--fs-sm); color: var(--color-neutral-700); }
.main-nav a[aria-current="page"] { color: var(--color-primary-600); }
.header-cta { padding: 10px 20px; font-size: var(--fs-sm); }
.nav-toggle { display: none; background: none; border: none; font-size: var(--fs-xl); color: var(--color-neutral-800); cursor: pointer; }

/* Hero */
.hero { padding: var(--space-9) 0; }
.hero-grid { display: grid; grid-template-columns: 55% 45%; gap: var(--space-7); align-items: center; }
.hero-media { border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); aspect-ratio: 4/5; background: linear-gradient(135deg, var(--color-primary-100), var(--color-neutral-200)); display: flex; align-items: center; justify-content: center; color: var(--color-neutral-500); font-family: var(--font-heading); font-size: var(--fs-sm); }
.hero h1 { font-size: var(--fs-3xl); }
.hero .lead { margin-bottom: var(--space-5); }
.hero-metrics { display: flex; gap: var(--space-6); margin: var(--space-5) 0; }
.hero-metric .num { font-family: var(--font-heading); font-size: var(--fs-lg); font-weight: var(--fw-semibold); color: var(--color-primary-600); display: block; }
.hero-metric .label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-label); color: var(--color-neutral-500); }
.hero-cta { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-top: var(--space-5); }
.urgency-bar { background: var(--color-primary-50); border-left: 3px solid var(--color-primary-500); padding: var(--space-3) var(--space-4); font-size: var(--fs-sm); color: var(--color-neutral-700); margin-top: var(--space-6); border-radius: var(--radius-sm); }

/* Sections */
.section { padding: var(--space-8) 0; }
.section-subtle { background: var(--color-surface-subtle); }
.section h2 { max-width: 24ch; }
.section-intro { max-width: 60ch; color: var(--color-neutral-600); margin-bottom: var(--space-6); }

/* Cards */
.card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); margin-top: var(--space-6); }
.service-card { display: block; background: var(--color-surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-lg); padding: var(--space-6); box-shadow: var(--shadow-sm); transition: transform var(--dur-normal) var(--ease-standard), box-shadow var(--dur-normal) var(--ease-standard), border-color var(--dur-normal); }
.service-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--color-primary-300); text-decoration: none; }
.service-card h3 { color: var(--color-neutral-900); }
.service-card p { font-size: var(--fs-sm); color: var(--color-neutral-600); line-height: var(--lh-relaxed); }
.service-card .price { font-family: var(--font-heading); font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--color-neutral-800); display: block; margin-top: var(--space-4); }
.service-card .arrow { color: var(--color-primary-500); font-size: var(--fs-lg); transition: transform var(--dur-normal); display: inline-block; }
.service-card:hover .arrow { transform: translateX(4px); }

/* Trust tiles */
.tiles { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-5); margin-top: var(--space-6); }
.tile { background: var(--color-surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-lg); padding: var(--space-5); }
.tile h3 { font-size: var(--fs-md); color: var(--color-primary-700); }
.tile p { font-size: var(--fs-sm); color: var(--color-neutral-600); margin: 0; }

/* Prose */
.prose { font-size: var(--fs-base); line-height: var(--lh-relaxed); color: var(--color-neutral-800); }
.prose h2 { margin-top: var(--space-7); }
.prose h3 { margin-top: var(--space-6); }
.prose ul, .prose ol { padding-left: var(--space-5); }
.prose li { margin-bottom: var(--space-2); }
.prose blockquote { border-left: 4px solid var(--color-primary-500); background: var(--color-primary-50); padding: var(--space-4) var(--space-5); margin: var(--space-5) 0; font-style: italic; }
.prose table { width: 100%; border-collapse: collapse; margin: var(--space-5) 0; font-size: var(--fs-sm); }
.prose th, .prose td { text-align: left; padding: var(--space-3); border-bottom: 1px solid var(--color-neutral-200); }
.prose th { font-family: var(--font-heading); }

/* CTA block */
.cta-block { background: var(--color-primary-700); color: var(--color-neutral-50); padding: var(--space-10) 0; text-align: center; margin-top: var(--space-9); }
.cta-block h2 { color: var(--color-neutral-50); max-width: 640px; margin: 0 auto var(--space-4); }
.cta-block p { color: var(--color-primary-100); max-width: 480px; margin: 0 auto var(--space-5); }
.cta-block .cta-trust { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-label); color: var(--color-primary-200); margin-top: var(--space-4); }

/* Footer */
.site-footer { background: var(--color-neutral-900); color: var(--color-neutral-300); padding: var(--space-8) 0 var(--space-5); margin-top: 0; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: var(--space-6); }
.footer-col h3 { color: var(--color-neutral-50); font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: var(--ls-wide); }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: var(--space-2); }
.footer-col a { color: var(--color-neutral-300); font-size: var(--fs-sm); }
.logo-footer { color: var(--color-neutral-50); }
.footer-slogan { font-size: var(--fs-sm); color: var(--color-neutral-400); }
.footer-bottom { display: flex; justify-content: space-between; gap: var(--space-4); border-top: 1px solid var(--color-neutral-700); padding-top: var(--space-5); margin-top: var(--space-7); font-size: var(--fs-xs); color: var(--color-neutral-500); flex-wrap: wrap; }
.footer-bottom a { color: var(--color-neutral-400); }

/* FAQ accordion */
.faq-list { margin-top: var(--space-6); border-top: 1px solid var(--color-neutral-200); }
.faq-item { border-bottom: 1px solid var(--color-neutral-200); }
.faq-item summary { font-family: var(--font-heading); font-weight: var(--fw-semibold); font-size: var(--fs-md); color: var(--color-neutral-900); padding: var(--space-4) 0; cursor: pointer; list-style: none; display: flex; justify-content: space-between; gap: var(--space-4); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; color: var(--color-primary-500); font-size: var(--fs-lg); flex-shrink: 0; }
.faq-item[open] summary::after { content: "−"; }
.faq-answer { padding: 0 0 var(--space-4); color: var(--color-neutral-700); line-height: var(--lh-relaxed); max-width: 65ch; }

/* Lead form */
.lead-form { display: flex; flex-direction: column; gap: var(--space-4); max-width: 520px; margin-top: var(--space-5); background: var(--color-surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-lg); padding: var(--space-6); }
.lead-form label { display: flex; flex-direction: column; gap: var(--space-2); font-family: var(--font-heading); font-size: var(--fs-sm); color: var(--color-neutral-700); }
.lead-form input, .lead-form textarea { font-family: var(--font-body); font-size: var(--fs-base); padding: 10px 12px; border: 1px solid var(--color-neutral-300); border-radius: var(--radius-md); background: var(--color-surface-background); }
.lead-form input:focus, .lead-form textarea:focus { border-color: var(--color-primary-500); outline: none; }
.lead-form .form-note { font-size: var(--fs-xs); color: var(--color-neutral-500); margin: 0; }

/* Clinical hero visual (lab-вайб, без анимаций — movement в фарме = тревожность) */
.hero-media { background: var(--color-surface-elevated); position: relative; overflow: hidden; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-4); border: 1px solid var(--color-neutral-200); }
.hero-media::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(var(--color-neutral-200) 1px, transparent 1px), linear-gradient(90deg, var(--color-neutral-200) 1px, transparent 1px); background-size: 28px 28px; opacity: 0.5; }
.lab-frame { position: relative; width: 56%; aspect-ratio: 1; border: 1px solid var(--color-primary-300); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; background: var(--color-surface-background); }
.lab-frame::before, .lab-frame::after { content: ""; position: absolute; width: 14px; height: 14px; border: 2px solid var(--color-primary-500); }
.lab-frame::before { top: -1px; left: -1px; border-right: none; border-bottom: none; }
.lab-frame::after { bottom: -1px; right: -1px; border-left: none; border-top: none; }
.lab-icon { color: var(--color-neutral-400); filter: grayscale(1); }
.lab-icon svg { width: 64px; height: 64px; stroke-width: 1.2; }
.lab-scan { position: absolute; left: 8%; right: 8%; top: 50%; height: 1px; background: var(--color-primary-400); opacity: 0.6; }
.lab-caption { position: relative; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--ls-wide); color: var(--color-neutral-500); margin: 0; }

/* Compliance checklist (niche-компонент) */
.compliance-grid .tile { position: relative; padding-top: var(--space-6); }
.tile-ico { display: inline-flex; color: var(--color-primary-500); margin-bottom: var(--space-3); }
.tile-tag { display: inline-block; font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--ls-wide); color: var(--color-semantic-success); margin-bottom: var(--space-2); }
.compliance-grid .tile h3 { font-size: var(--fs-md); }

/* Иконки карточек услуг (outline primary, по DS components.md §2) */
.card-ico { display: inline-flex; color: var(--color-primary-500); margin-bottom: var(--space-3); }

/* Калькулятор / ROI */
.calc { background: var(--color-surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-lg); padding: var(--space-6); max-width: 560px; margin: var(--space-6) 0; display: flex; flex-direction: column; gap: var(--space-4); }
.calc-row { display: flex; flex-direction: column; gap: var(--space-2); font-family: var(--font-heading); font-size: var(--fs-sm); color: var(--color-neutral-700); }
.calc input[type="number"] { font-family: var(--font-mono); font-size: var(--fs-md); padding: 8px 12px; border: 1px solid var(--color-neutral-300); border-radius: var(--radius-md); max-width: 140px; }
.calc-services { border: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.calc-services legend { font-family: var(--font-heading); font-size: var(--fs-sm); color: var(--color-neutral-700); margin-bottom: var(--space-2); padding: 0; }
.calc-services label, .calc-audit { display: flex; align-items: center; gap: var(--space-3); font-size: var(--fs-sm); color: var(--color-neutral-800); cursor: pointer; }
.calc-result { background: var(--color-primary-50); border-radius: var(--radius-md); padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-1); }
.calc-label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-label); color: var(--color-neutral-500); }
.calc-sum { font-family: var(--font-heading); font-size: var(--fs-2xl); font-weight: var(--fw-bold); color: var(--color-primary-700); }
.calc-note { font-size: var(--fs-xs); color: var(--color-neutral-600); }

/* Quiz-визард */
.quiz { background: var(--color-surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-lg); padding: var(--space-7); max-width: 600px; margin: var(--space-6) 0; }
.quiz-q { font-family: var(--font-heading); font-size: var(--fs-lg); font-weight: var(--fw-semibold); color: var(--color-neutral-900); margin-bottom: var(--space-5); }
.quiz-opt { display: block; width: 100%; text-align: left; background: var(--color-surface-background); border: 1px solid var(--color-neutral-300); border-radius: var(--radius-md); padding: 14px 18px; margin-bottom: var(--space-3); font-family: var(--font-body); font-size: var(--fs-base); color: var(--color-neutral-800); cursor: pointer; transition: border-color var(--dur-normal), background var(--dur-normal); }
.quiz-opt:hover { border-color: var(--color-primary-400); background: var(--color-primary-50); }
.quiz-rec { font-family: var(--font-heading); font-size: var(--fs-xl); font-weight: var(--fw-semibold); color: var(--color-primary-700); margin-bottom: var(--space-3); }
.quiz-rec-note { color: var(--color-neutral-700); margin-bottom: var(--space-5); }
.quiz-result .btn { margin-right: var(--space-3); }

/* ROI compare */
.roi-compare { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.roi-col { background: var(--color-surface-subtle); border-radius: var(--radius-md); padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-1); }
.roi-col.roi-ours { background: var(--color-primary-50); border: 1px solid var(--color-primary-300); }
.roi-col .calc-sum { font-size: var(--fs-xl); }

/* Видео-демо */
.video-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); margin: var(--space-6) 0; }
.video-card { margin: 0; background: var(--color-surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-lg); overflow: hidden; }
.video-ph { aspect-ratio: 9/16; background: var(--color-neutral-100); display: flex; align-items: center; justify-content: center; font-size: var(--fs-2xl); color: var(--color-primary-400); border-bottom: 1px solid var(--color-neutral-200); }
.video-card figcaption { padding: var(--space-4); }
.video-card h3 { font-size: var(--fs-md); margin-bottom: var(--space-2); }
.video-card p { font-size: var(--fs-sm); color: var(--color-neutral-600); margin: 0; }

/* Отзывы */
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); margin: var(--space-6) 0; }
.review-card { margin: 0; background: var(--color-surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-lg); padding: var(--space-5); border-left: 4px solid var(--color-primary-300); }
.review-text { font-size: var(--fs-sm); color: var(--color-neutral-600); font-style: italic; margin-bottom: var(--space-4); }
.review-author { display: flex; align-items: center; gap: var(--space-3); font-size: var(--fs-sm); color: var(--color-neutral-700); }
.review-avatar { width: 36px; height: 36px; border-radius: var(--radius-full); background: var(--color-neutral-200); display: flex; align-items: center; justify-content: center; color: var(--color-neutral-500); flex-shrink: 0; }

/* Timeline (процесс) */
.timeline { list-style: none; padding: 0; margin: var(--space-6) 0; max-width: 720px; }
.timeline-step { display: flex; gap: var(--space-5); padding-bottom: var(--space-6); position: relative; }
.timeline-step:not(:last-child)::before { content: ""; position: absolute; left: 17px; top: 40px; bottom: 0; width: 2px; background: var(--color-neutral-200); }
.timeline-num { flex-shrink: 0; width: 36px; height: 36px; border-radius: var(--radius-full); background: var(--color-primary-500); color: var(--color-neutral-50); font-family: var(--font-heading); font-weight: var(--fw-semibold); display: flex; align-items: center; justify-content: center; z-index: 1; }
.timeline-step h3 { font-size: var(--fs-md); margin-bottom: var(--space-1); }
.timeline-step p { font-size: var(--fs-sm); color: var(--color-neutral-600); margin-bottom: var(--space-2); }
.timeline-when { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--ls-wide); color: var(--color-primary-600); }

/* Mobile */
@media (max-width: 768px) {
  h1, .hero h1 { font-size: var(--fs-xl); }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-media { order: -1; aspect-ratio: 3/4; }
  .card-grid, .tiles { grid-template-columns: 1fr; }
  .video-grid, .reviews-grid { grid-template-columns: 1fr; }
  .roi-compare { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .main-nav { display: none; }
  .header-cta { display: none; }
  .nav-toggle { display: block; margin-left: auto; }
  .main-nav.open { display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: var(--color-surface-elevated); border-bottom: 1px solid var(--color-neutral-200); padding: var(--space-4) var(--space-5); gap: var(--space-4); margin: 0; }
  .footer-bottom { flex-direction: column; }
}
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; scroll-behavior: auto !important; }
}
