/* =========================================================
   TaskCamp Landing (2025) — rewritten styles.css
   Goal: clean hierarchy, modern cards, readable pricing,
   keeps original dark gradient background.
   ========================================================= */

/* -------- Base / Reset -------- */
:root{
  --bg-0:#060f18;
  --text:#eaf2ff;
  --text-2:rgba(234,242,255,.78);
  --text-3:rgba(234,242,255,.58);

  /* Карточки как на основном сайте (темнее) */
  --card: rgba(15, 23, 42, 0.65);
  --card-2: rgba(15, 23, 42, 0.75);
  --stroke: rgba(75, 85, 99, 0.6);
  --stroke-2: rgba(75, 85, 99, 0.8);

  /* Тени как на основном сайте */
  --shadow: 0 12px 36px rgba(0,0,0,.5);
  --shadow-soft: 0 8px 20px rgba(0,0,0,.5);

  --radius-lg: 24px;
  --radius-md: 18px;
  --radius-sm: 14px;

  --accent-1:#69d2ff;
  --accent-2:#a78bfa;
  --accent-3:#ff7bd4;

  --grad-accent: linear-gradient(135deg, var(--accent-1), var(--accent-2) 55%, var(--accent-3));
  --grad-accent-soft: linear-gradient(135deg, rgba(105,210,255,.22), rgba(167,139,250,.18) 55%, rgba(255,123,212,.18));

  --container: 1160px;
  --pad-x: 24px;

  --header-h: 72px;
}

*,
*::before,
*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  color:var(--text);
  font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, system-ui, Arial, sans-serif;
  line-height:1.55;
  background:
    radial-gradient(ellipse 140% 90% at 10% 15%, #152a58 0%, transparent 55%),
    radial-gradient(ellipse 110% 130% at 85% 45%, #28123d 0%, transparent 60%),
    radial-gradient(ellipse 150% 80% at 50% 90%, #0a1d30 0%, transparent 50%),
    radial-gradient(ellipse 95% 115% at 25% 60%, #171f35 0%, transparent 45%),
    var(--bg-0);
  background-attachment: fixed;
}

a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
img{ max-width:100%; display:block; }

.container{
  max-width: var(--container);
  margin:0 auto;
  padding:0 var(--pad-x);
}

section[id]{ scroll-margin-top: calc(var(--header-h) + 16px); }
/* Секции с уменьшенным scroll-margin для появления выше */
#meetings{ scroll-margin-top: calc(var(--header-h) - 79px); }
#faq{ scroll-margin-top: calc(var(--header-h) - 70px); }

/* -------- Typography -------- */
h1,h2,h3{ margin:0; letter-spacing:-0.02em; }
p{ margin:0; color:var(--text-2); }

.hero-title{
  font-size: clamp(40px, 4.6vw, 64px);
  line-height: 1.05;
  font-weight: 800;
}
.section-title{
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.15;
  font-weight: 800;
  margin-bottom: 12px;
}
.section-subtitle{
  max-width: 880px;
  margin: 0 auto 34px auto;
  color: var(--text-2);
  font-size: 16px;
}

.gradient-text{
  background: var(--grad-accent);
  -webkit-background-clip: text;
  background-clip:text;
  color: transparent;
}
.brand-highlight{
  color: var(--text);
  font-weight: 700;
}

/* -------- Common Layout -------- */
section{ padding: 96px 0; }
.hero{ padding-top: calc(var(--header-h) + 56px); padding-bottom: 72px; }

.card{
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(10px);
}
.card:hover{
  border-color: var(--stroke-2);
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--stroke);
  color: var(--text-2);
  font-size: 13px;
}

/* -------- Header -------- */
.header{
  position: fixed;
  inset: 0 0 auto 0;
  height: var(--header-h);
  z-index: 1000;
  background: rgba(6, 15, 24, .55);
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(14px);
}
.header-content{
  height: var(--header-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 18px;
}
.logo img{ height: 32px; width:auto; }

.nav{
  display:flex;
  align-items:center;
  gap: 18px;
}
.nav-link{
  color: var(--text-3);
  font-weight: 600;
  font-size: 14px;
  padding: 10px 10px;
  border-radius: 10px;
  transition: background .15s ease, color .15s ease;
}
.nav-link:hover{
  color: var(--text);
  background: rgba(255,255,255,.05);
}

.header-actions{
  display:flex;
  align-items:center;
  gap: 12px;
}

/* -------- Buttons -------- */
.btn-primary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 16px;
  border-radius: 14px;
  border: none;
  /* Soft style как кнопка "Новый список" в топбаре */
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.25), rgba(37, 99, 235, 0.20));
  color: rgba(255, 255, 255, 0.95);
  box-shadow:
    0 2px 8px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  font-weight: 800;
  font-size: 14px;
  cursor:pointer;
  transition: background .15s ease, color .15s ease, transform .15s ease;
}
.btn-primary:hover{
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.35), rgba(37, 99, 235, 0.28));
  color: white;
  transform: translateY(-2px);
  box-shadow:
    0 2px 8px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
}
.btn-primary:active{
  transform: translateY(0);
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.30), rgba(37, 99, 235, 0.24));
}

.btn-header{ padding: 11px 14px; }

/* -------- Language Switcher -------- */
.lang-switcher{ position: relative; }
.lang-switcher-btn{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--stroke);
  color: var(--text-2);
  cursor:pointer;
  transition: border-color .15s ease, background .15s ease;
}
.lang-switcher-btn:hover{ background: rgba(255,255,255,.06); border-color: var(--stroke-2); }
.lang-switcher.open .lang-switcher-btn{ background: rgba(255,255,255,.08); border-color: var(--stroke-2); }

.lang-current{ font-weight: 800; font-size: 13px; color: var(--text); }
.lang-arrow{
  opacity:.8;
  transition: transform 0.2s ease;
}
.lang-switcher.open .lang-arrow{ transform: rotate(180deg); }

.lang-dropdown{
  position:absolute;
  right:0;
  top: calc(100% + 10px);
  width: 240px;
  padding: 8px;
  border-radius: 16px;
  background: rgba(15, 23, 42, 0.98);
  border: 1px solid var(--stroke);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(14px);
  max-height: 800px;
  overflow-y: auto;

  /* Анимация появления */
  opacity: 0;
  transform: translateY(-10px) scale(0.95);
  transform-origin: top right;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.lang-switcher.open .lang-dropdown{
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: all;
}

/* Градиент как у модалок */
.lang-dropdown::before{
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.16), transparent 60%);
  pointer-events: none;
  z-index: 0;
  border-radius: inherit;
}

/* Скроллбар */
.lang-dropdown::-webkit-scrollbar{ width: 6px; }
.lang-dropdown::-webkit-scrollbar-track{ background: transparent; }
.lang-dropdown::-webkit-scrollbar-thumb{ background: rgba(75, 85, 99, 0.5); border-radius: 3px; }
.lang-dropdown::-webkit-scrollbar-thumb:hover{ background: rgba(75, 85, 99, 0.7); }

.lang-option{
  position: relative;
  z-index: 1;
  width:100%;
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 0;
  background: transparent;
  color: var(--text-2);
  cursor:pointer;
  text-align:left;
  transition: background .15s ease, color .15s ease;
}
.lang-option:hover{ background: rgba(255,255,255,.08); color: var(--text); }
.lang-option.active{
  background: rgba(59, 130, 246, 0.15);
  color: var(--text);
}
.lang-option.active::after{
  content: "";
  position: absolute;
  right: 12px;
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none'%3E%3Cpath d='M3 8l3 3 7-7' stroke='%2369d2ff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center;
}
.lang-flag{ width: 20px; height: 14px; border-radius: 3px; object-fit: cover; }
.lang-name{ font-size: 13px; font-weight: 600; }

/* -------- Hero -------- */
.hero-content{
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}
.hero-description{
  margin-top: 16px;
  font-size: 18px;
  color: var(--text-2);
}
.hero-micro{
  margin-top: 18px;
  color: var(--text-3);
  font-weight: 650;
  font-size: 13px;
  letter-spacing: .01em;
}

/* Hero 2-column layout */
.hero-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
}
.hero-layout .hero-content {
  text-align: left;
  max-width: none;
  margin: 0;
}
.hero-media {
  display: flex;
  justify-content: center;
  align-items: center;
}
.hero-media-placeholder {
  width: 100%;
  aspect-ratio: 16/10;
  max-width: 500px;
  background: var(--card);
  border: 2px dashed var(--stroke);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 12px;
}
.hero-media-icon {
  font-size: 48px;
}
.hero-media-text {
  color: var(--text-3);
  font-size: 14px;
}
@media (max-width: 900px) {
  .hero-layout {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .hero-layout .hero-content {
    text-align: center;
  }
  .hero-media-placeholder {
    max-width: 400px;
  }
}

/* -------- Philosophy -------- */
.philosophy-content{
  text-align: center;
  max-width: 900px;
  margin: 0 auto;
}
.philosophy-title{
  font-size: clamp(26px, 2.4vw, 36px);
  font-weight: 800;
  margin-bottom: 10px;
}
.philosophy-story{
  color: var(--text-2);
  margin-bottom: 28px;
}
.philosophy-values{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.philosophy-item{
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  padding: 18px 18px;
  box-shadow: var(--shadow-soft);
  display: flex;
  align-items: flex-start;
  gap: 14px;
  position: relative;
  overflow: hidden;
  transition: transform .12s ease, border-color .12s ease;
}
.philosophy-item::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.16), transparent 60%);
  pointer-events: none;
}
.philosophy-item:hover {
  transform: translateY(-2px);
  border-color: var(--stroke-2);
}
.philosophy-item svg {
  flex: 0 0 auto;
  color: var(--accent-1);
}
.philosophy-item-text {
  flex: 1;
  min-width: 0;
}
.philosophy-item-text h4 {
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
  margin: 0 0 4px 0;
}
.philosophy-item-text p {
  font-size: 13px;
  color: var(--text-2);
  margin: 0;
}
.philosophy-icon{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: var(--grad-accent-soft);
  border: 1px solid rgba(255,255,255,.10);
  margin-bottom: 12px;
  color: var(--text);
}
/* Pricing Philosophy Block */
.pricing-philosophy {
  margin-top: 32px;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  text-align: left;
}
.pricing-philosophy h3 {
  font-size: 20px;
  font-weight: 800;
  margin: 0 0 18px 0;
  color: var(--text);
  text-align: center;
}
.philosophy-points {
  display: grid;
  gap: 14px;
}
.philosophy-point {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 16px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
}
.philosophy-icon {
  flex: 0 0 40px;
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  font-size: 18px;
}
.philosophy-point > div {
  flex: 1;
  min-width: 0;
}
.philosophy-point strong {
  display: block;
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 4px;
}
.philosophy-point p {
  margin: 0;
  font-size: 14px;
  color: var(--text-2);
}

/* -------- Features (Why TaskCamp / Comparison blocks) -------- */
.features{ text-align:center; }
.features .section-title{ text-align:center; }
.features-grid{
  margin-top: 26px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.feature-card{
  text-align:left;
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  padding: 18px 18px;
  box-shadow: var(--shadow-soft);
  display:flex;
  gap: 14px;
  align-items:flex-start;
  transition: transform .12s ease, border-color .12s ease;
  position: relative;
  overflow: hidden;
}
.feature-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.16), transparent 60%);
  pointer-events: none;
}
.feature-card:hover{
  transform: translateY(-2px);
  border-color: var(--stroke-2);
}
.feature-icon{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: var(--grad-accent-soft);
  border: 1px solid rgba(255,255,255,.10);
  flex: 0 0 auto;
}
.feature-content h3{
  font-size: 16px;
  font-weight: 850;
  margin-bottom: 6px;
  color: var(--text);
}
.feature-content p{
  font-size: 14px;
  color: var(--text-2);
}

.features-cta{
  margin-top: 26px;
  display:flex;
  justify-content:center;
}

/* -------- AI Section (dialog demo) -------- */
.ai-section{ text-align:center; }
.ai-section-header{ max-width: 700px; margin: 0 auto 28px auto; }
.ai-section-header h2{
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 800;
  margin-bottom: 12px;
}
.ai-section-header p{ color: var(--text-2); font-size: 16px; line-height: 1.55; }

/* Dialog card */
.ai-dialog-card{
  max-width: 620px;
  margin: 0 auto;
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
  box-shadow: var(--shadow-soft);
}
.ai-dialog-card::before{
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(59,130,246,.14), transparent 60%);
  pointer-events: none;
}

/* Dialog header */
.ai-dialog-header{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px;
  border-bottom: 1px solid var(--stroke);
  background: rgba(255,255,255,.02);
  position: relative;
  z-index: 1;
}
.ai-dialog-status{
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}
.ai-dialog-dot{
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #22c55e;
  animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{
  0%,100%{ opacity:1; }
  50%{ opacity:.4; }
}
.ai-dialog-context{
  font-size: 12px;
  color: var(--text-3);
  font-style: italic;
}

/* Messages */
.ai-dialog-messages{
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
  z-index: 1;
}
.ai-msg{
  display: flex;
  align-items: flex-start;
  gap: 10px;
  max-width: 85%;
}
.ai-msg--assistant{ align-self: flex-start; }
.ai-msg--user{ align-self: flex-end; flex-direction: row-reverse; }

.ai-msg-avatar{
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--grad-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 900;
  color: rgba(7,17,26,.92);
  flex-shrink: 0;
}

.ai-msg-bubble{
  padding: 10px 14px;
  font-size: 14px;
  line-height: 1.55;
  word-wrap: break-word;
}
.ai-msg--assistant .ai-msg-bubble{
  background: rgba(105,210,255,.08);
  border: 1px solid rgba(105,210,255,.18);
  border-radius: 2px 14px 14px 14px;
  color: var(--text);
}
.ai-msg--user .ai-msg-bubble{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px 2px 14px 14px;
  color: var(--text-2);
  font-style: italic;
}
.ai-msg-bubble--confirm{
  background: rgba(34,197,94,.10) !important;
  border-color: rgba(34,197,94,.25) !important;
  font-weight: 600;
}

/* Action results */
.ai-actions-done{
  margin-top: 4px;
  margin-left: 42px;
  padding: 12px 14px;
  background: var(--grad-accent-soft);
  border: 1px solid rgba(105,210,255,.15);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ai-actions-label{
  font-size: 11px;
  font-weight: 700;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 2px;
}
.ai-action-item{
  font-size: 13px;
  color: var(--text);
  padding-left: 20px;
  position: relative;
  line-height: 1.45;
}
.ai-action-item--task::before{
  content: "\2713";
  position: absolute;
  left: 0;
  color: #22c55e;
  font-weight: 700;
}
.ai-action-item--message::before{
  content: "\2709";
  position: absolute;
  left: 0;
  color: var(--accent-1);
  font-weight: 700;
}

/* AI Capabilities grid */
.ai-capabilities{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  max-width: 660px;
  margin: 0 auto;
  text-align: left;
}
.ai-cap-item{
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 20px;
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  transition: border-color .2s, background .2s;
}
.ai-cap-item:hover{
  border-color: rgba(105,210,255,.25);
  background: rgba(105,210,255,.04);
}
.ai-cap-icon{
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: rgba(105,210,255,.10);
  border: 1px solid rgba(105,210,255,.18);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--accent-1);
}
.ai-cap-icon svg{ width: 20px; height: 20px; }
.ai-cap-text strong{
  display: block;
  font-size: 14px;
  font-weight: 750;
  color: var(--text);
  margin-bottom: 4px;
}
.ai-cap-text p{
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-2);
  margin: 0;
}

@media(max-width:600px){
  .ai-capabilities{
    grid-template-columns: 1fr;
  }
}

/* Hint */
.ai-dialog-hint{
  max-width: 620px;
  margin: 16px auto 0 auto;
  padding: 10px 16px;
  border-radius: 10px;
  background: rgba(105,210,255,.06);
  border: 1px solid rgba(105,210,255,.12);
  font-size: 13px;
  color: var(--text-2);
  text-align: center;
}

/* Quick start */
.ai-quickstart{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  margin-top: 32px;
  flex-wrap: wrap;
}
.ai-quickstart-step{
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--text-2);
}
.ai-quickstart-num{
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: rgba(105,210,255,.15);
  border: 1px solid rgba(105,210,255,.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 800;
  color: var(--accent-1);
  flex-shrink: 0;
}
.ai-quickstart-divider{
  width: 24px;
  height: 1px;
  background: var(--stroke);
}

.ai-task-card{
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  padding: 12px;
}
.ai-task-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 10px;
  margin-bottom: 8px;
}
.ai-task-title{
  font-weight: 850;
  font-size: 14px;
  color: var(--text);
}
.ai-task-meta{
  display:flex;
  align-items:center;
  gap: 10px;
  color: var(--text-3);
  font-size: 12px;
}
.ai-task-desc{
  color: var(--text-2);
  font-size: 13px;
  margin-top: 6px;
}
.ai-task-assignee-wrapper{
  display:flex;
  align-items:center;
  gap: 8px;
  min-width: 140px;
  justify-content:flex-end;
}
.ai-assignee-avatar{
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: var(--grad-accent-soft);
  border: 1px solid rgba(255,255,255,.12);
}
.ai-assignee-name{ font-size: 12px; color: var(--text-2); font-weight: 650; }

.ai-minutes-info{
  margin-top: 14px;
  color: var(--text-3);
  font-size: 13px;
}
.ai-minutes-note{
  margin-top: 6px;
  color: var(--text-3);
  font-size: 12px;
}

/* FAQ (details) styling — global */
details{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  border-radius: 16px;
  padding: 12px 14px;
}
details + details{ margin-top: 10px; }
summary{
  list-style: none;
  cursor: pointer;
  font-weight: 850;
  color: var(--text);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
summary::-webkit-details-marker{ display:none; }
details[open]{ border-color: rgba(255,255,255,.16); background: rgba(255,255,255,.045); }
details p{ margin-top: 10px; color: var(--text-2); font-size: 14px; }


/* Transcript message styling */
.message-content{ flex: 1; min-width: 0; }
.message-text{ color: var(--text-2); font-size: 13px; margin-top: 4px; }
.transcript-message{
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
}
.transcript-message.speaker-1{ background: rgba(102,209,255,.06); border-color: rgba(102,209,255,.16); }
.transcript-message.speaker-2{ background: rgba(180,140,255,.06); border-color: rgba(180,140,255,.16); }
.transcript-message.speaker-3{ background: rgba(109,255,179,.05); border-color: rgba(109,255,179,.14); }

/* -------- Auto-Translation Section -------- */
.auto-translate {
  padding: 48px 0;
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.1), rgba(168, 85, 247, 0.1));
}

.auto-translate-content {
  display: flex;
  align-items: center;
  gap: 24px;
  max-width: 800px;
  margin: 0 auto;
  text-align: left;
}

.auto-translate-icon {
  font-size: 48px;
  flex-shrink: 0;
}

.auto-translate-text h3 {
  margin: 0 0 8px 0;
  font-size: 20px;
  color: #fff;
}

.auto-translate-text p {
  margin: 0 0 12px 0;
  color: rgba(255,255,255,0.7);
  font-size: 15px;
}

.auto-translate-badge {
  display: inline-block;
  background: rgba(99, 102, 241, 0.2);
  border: 1px solid rgba(99, 102, 241, 0.3);
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 13px;
  color: #a78bfa;
}

@media (max-width: 768px) {
  .auto-translate-content {
    flex-direction: column;
    text-align: center;
  }
}

/* -------- Meeting analysis (Planerki → Tasks) — 3-Column Layout -------- */
.meeting-analysis { text-align: center; }
.meeting-analysis-header {
  max-width: 920px;
  margin: 0 auto 24px auto;
}
.meeting-analysis-subtitle {
  max-width: 920px;
  margin: 0 auto;
  color: var(--text-2);
}

/* Упрощённый layout */
.meeting-simple {
  max-width: 400px;
  margin: 24px auto 0 auto;
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.meeting-simple::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top center, rgba(59, 130, 246, 0.16), transparent 60%);
  pointer-events: none;
}
.meeting-icon {
  font-size: 32px;
  margin-bottom: 12px;
}
.meeting-content {
  position: relative;
  z-index: 1;
}
.meeting-content h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 12px;
}
.meeting-features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: left;
  max-width: 420px;
  margin: 0 auto;
}
.meeting-features li {
  font-size: 14px;
  color: var(--text-2);
  padding-left: 24px;
  position: relative;
  line-height: 1.5;
}
.meeting-features li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--accent);
  font-weight: 700;
  font-size: 16px;
}

/* Сноска под секцией */
.meeting-footnote {
  margin-top: 18px;
  font-size: 12px;
  color: var(--text-3);
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  line-height: 1.5;
}

/* -------- Pricing — 3-Column Layout -------- */
.pricing { text-align: center; }

.pricing-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 28px;
}
@media (min-width: 768px) {
  .pricing-cards {
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
    align-items: stretch; /* Одинаковая высота карточек */
    max-width: 800px; /* Ограничение ширины для центровки */
    margin-left: auto;
    margin-right: auto;
  }
}

/* Общие стили карточек */
.pricing-card {
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  padding: 20px;
  text-align: left;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.pricing-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.16), transparent 60%);
  pointer-events: none;
}

/* Карточка Тест-драйв */
.pricing-card-trial .pricing-card-badge {
  display: inline-block;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(105, 210, 255, 0.15);
  border: 1px solid rgba(105, 210, 255, 0.25);
  color: var(--accent);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: 12px;
  align-self: center;
}
.pricing-card-title {
  font-size: 18px;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 4px;
}
.pricing-card-subtitle {
  font-size: 13px;
  color: var(--text-2);
  margin-bottom: 14px;
}

/* Карточка Основной тариф */
.pricing-card-main {
  border-color: var(--accent);
}
.pricing-card-main::before {
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.16), transparent 60%);
}
.pricing-card-price {
  display: flex;
  align-items: baseline;
  gap: 2px;
  margin-bottom: 4px;
}
.price-num {
  font-size: 42px;
  font-weight: 900;
  color: var(--text);
  line-height: 1;
  letter-spacing: -0.02em;
}
.price-cur {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-2);
}
.pricing-card-period {
  font-size: 13px;
  color: var(--text-3);
  font-weight: 600;
}
.pricing-card-discount {
  font-size: 12px;
  color: #22c55e;
  font-weight: 600;
  margin-top: 6px;
  padding: 4px 10px;
  background: rgba(34, 197, 94, 0.12);
  border-radius: 6px;
  display: inline-block;
}
.pricing-card-divider {
  height: 1px;
  background: var(--stroke);
  margin: 14px 0;
}

/* Список в карточках */
.pricing-card-list {
  list-style: none;
  padding: 0;
  margin: 0 0 16px 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pricing-card-list li {
  font-size: 13px;
  color: var(--text-2);
  padding-left: 18px;
  position: relative;
}
.pricing-card-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--accent);
  font-weight: 700;
}

/* Бейдж Стандарт */
.pricing-badge-standard {
  display: inline-block;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(59, 130, 246, 0.15);
  border: 1px solid rgba(59, 130, 246, 0.3);
  color: var(--accent);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: 12px;
  align-self: center;
}

/* Карточка Enterprise */
.pricing-card-enterprise {
  display: flex;
  flex-direction: column;
  border-color: rgba(251, 191, 36, 0.4);
}
.pricing-card-enterprise::before {
  background: radial-gradient(circle at top left, rgba(251, 191, 36, 0.12), transparent 60%);
}

/* Бейдж Enterprise */
.pricing-badge-enterprise {
  display: inline-block;
  padding: 5px 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.20), rgba(245, 158, 11, 0.15));
  border: 1px solid rgba(251, 191, 36, 0.35);
  color: #fbbf24;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: 12px;
  align-self: center;
}

/* Цена Enterprise */
.pricing-enterprise-price {
  font-size: 24px;
  font-weight: 800;
  color: #fbbf24;
  margin-bottom: 4px;
}

/* Подзаголовок "Всё из Стандарта, плюс:" */
.pricing-enterprise-included {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-2);
  margin-bottom: 8px;
}

/* Enterprise список — маркер ✨ вместо ✓ */
.pricing-enterprise-list li::before {
  content: "✨";
  color: #fbbf24;
}

/* Enterprise кнопка */
.pricing-enterprise-btn {
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.20), rgba(245, 158, 11, 0.10));
  border: 1px solid rgba(251, 191, 36, 0.4);
  color: #fbbf24;
}
.pricing-enterprise-btn:hover {
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.30), rgba(245, 158, 11, 0.20));
  border-color: rgba(251, 191, 36, 0.6);
}

/* Кнопка в карточках */
.pricing-card .btn-primary {
  width: 100%;
  text-align: center;
  margin-top: auto;
}

/* AI-минуты компактно */
.ai-minutes-compact {
  margin-top: 18px;
  padding: 12px 16px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  font-size: 13px;
  color: var(--text-2);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}
.ai-minutes-compact strong {
  color: var(--text);
}

/* -------- FAQ Section -------- */
.faq-section {
  text-align: center;
  padding: 96px 0 40px 0; /* Уменьшен нижний отступ для плотности с CTA */
}
.faq-header {
  max-width: 700px;
  margin: 0 auto 28px auto;
}
.faq-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  max-width: 900px;
  margin: 0 auto;
}
.faq-item {
  text-align: left;
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  padding: 18px 20px;
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
  transition: transform .12s ease, border-color .12s ease;
}
.faq-item::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.16), transparent 60%);
  pointer-events: none;
}
.faq-item:hover {
  transform: translateY(-2px);
  border-color: var(--stroke-2);
}
.faq-question {
  margin: 0 0 8px 0;
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
}
.faq-answer {
  margin: 0;
  font-size: 14px;
  color: var(--text-2);
  line-height: 1.55;
}
@media (max-width: 700px) {
  .faq-grid { grid-template-columns: 1fr; }
  .faq-item { width: 100%; }
}

/* -------- Testimonials -------- */
.testimonials{ text-align:center; }
.testimonials-grid{
  margin-top: 22px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.testimonial-card{
  text-align:left;
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  padding: 18px;
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
  transition: transform .12s ease, border-color .12s ease;
}
.testimonial-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.16), transparent 60%);
  pointer-events: none;
}
.testimonial-card:hover {
  transform: translateY(-2px);
  border-color: var(--stroke-2);
}
.testimonial-content{
  color: var(--text-2);
  font-size: 14px;
}
.testimonial-author{
  margin-top: 14px;
  color: var(--text);
  font-weight: 850;
  font-size: 13px;
}

/* -------- Interface / Real cases -------- */
.real-cases{ text-align:center; }
.cases-grid{
  margin-top: 22px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.case-card{
  text-align:left;
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-lg);
  padding: 18px;
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
  transition: transform .12s ease, border-color .12s ease;
}
.case-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.16), transparent 60%);
  pointer-events: none;
}
.case-card:hover {
  transform: translateY(-2px);
  border-color: var(--stroke-2);
}
.case-icon{
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: var(--grad-accent-soft);
  border: 1px solid rgba(255,255,255,.10);
  margin-bottom: 10px;
}
.case-title{
  font-weight: 900;
  font-size: 16px;
  margin-bottom: 6px;
  color: var(--text);
}
.case-description{ color: var(--text-2); font-size: 14px; }

/* -------- CTA Section -------- */
.cta{
  padding: 32px 0 84px 0; /* Уменьшен верхний отступ */
}
.cta-content{
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius-lg);
  padding: 34px 24px;
  box-shadow: var(--shadow);
  text-align:center;
  position: relative;
  overflow:hidden;
}
.cta-content::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(circle at 20% 10%, rgba(105,210,255,.18), transparent 48%),
    radial-gradient(circle at 70% 30%, rgba(167,139,250,.18), transparent 55%),
    radial-gradient(circle at 50% 95%, rgba(255,123,212,.16), transparent 52%);
  pointer-events:none;
}
.cta-content h2{
  position:relative;
  z-index:1;
  font-size: clamp(28px, 3.2vw, 42px);
  font-weight: 900;
  margin-bottom: 10px;
}
.cta-content p{
  position:relative;
  z-index:1;
  color: var(--text-2);
  margin-bottom: 18px;
}

/* -------- Footer -------- */
.footer{
  padding: 32px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.10);
}
.footer-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.footer-left{
  flex-shrink: 0;
}
.footer-center{
  flex: 1;
  text-align: center;
}
.footer-right{
  flex-shrink: 0;
  text-align: right;
}
.footer-tech{
  color: var(--text-3);
  font-size: 12px;
  margin-bottom: 6px;
}
.footer-copyright{
  color: var(--text-3);
  font-size: 11px;
  line-height: 1.5;
}
.contact-label{
  color: var(--text-3);
  font-size: 12px;
  margin-bottom: 4px;
}
.contact-email{
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
}

/* Footer mobile */
@media (max-width: 720px) {
  .footer-row{
    flex-direction: column;
    text-align: center;
    gap: 20px;
  }
  .footer-left,
  .footer-center,
  .footer-right{
    text-align: center;
  }
}


/* -------- Small UI elements (avatars, badges, audio) -------- */
.author-avatar,
.ai-assignee-avatar{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  color: rgba(7,17,26,.92);
}

.author-avatar{
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 10px 22px rgba(0,0,0,.28);
  flex: 0 0 auto;
}

.author-info{ display:flex; flex-direction:column; gap: 2px; }
.author-name{ color: var(--text); font-weight: 900; font-size: 13px; }
.author-role{ color: var(--text-3); font-weight: 650; font-size: 12px; }

.blue{ background: linear-gradient(135deg, #66d1ff, #7a9bff); }
.purple{ background: linear-gradient(135deg, #b48cff, #ff7bd4); }
.green{ background: linear-gradient(135deg, #6dffb3, #66d1ff); }
.orange{ background: linear-gradient(135deg, #ffb86b, #ff7bd4); }

.orange-badge,
.red-badge{
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 850;
  border: 1px solid rgba(255,255,255,.10);
}
.orange-badge{ background: rgba(255,184,107,.14); color: rgba(255,219,183,.92); }
.red-badge{ background: rgba(255,92,125,.14); color: rgba(255,197,208,.92); }

/* Meeting audio details */
.audio-file{
  display:flex;
  align-items:center;
  gap: 10px;
}
.audio-info{ display:flex; flex-direction:column; gap: 2px; }
.audio-name{ color: var(--text); font-weight: 900; font-size: 13px; }
.audio-duration{ color: var(--text-3); font-weight: 650; font-size: 12px; }

/* Created tasks list layout */
.created-tasks-list{ display:grid; gap: 12px; }
.ai-task-checkbox-wrapper{
  display:flex;
  align-items:flex-start;
  padding-top: 2px;
}
.ai-task-checkbox{
  width: 16px;
  height: 16px;
  accent-color: #66d1ff;
  opacity: .6;
}
.ai-task-content{ flex: 1; min-width: 0; }

/* -------- Responsive -------- */
@media (max-width: 980px){
  .nav{ display:none; }
  .philosophy-values{ grid-template-columns: 1fr; }
  .features-grid{ grid-template-columns: 1fr; }
  .feature-card{ width: 100%; }
  .ai-dialog-card{ max-width: 100%; }
  .ai-msg{ max-width: 92%; }
  .ai-actions-done{ margin-left: 0; }
  .ai-quickstart{ flex-direction: column; gap: 10px; }
  .ai-quickstart-divider{ width: 1px; height: 16px; }
  .meeting-demo{ grid-template-columns: 1fr; }
  .highlight-item{ width: 100%; }
  .pricing-simple-layout{ grid-template-columns: 1fr; }
  .testimonials-grid{ grid-template-columns: 1fr; }
  .cases-grid{ grid-template-columns: 1fr; }
  section{ padding: 80px 0; }
  .hero{ padding-top: calc(var(--header-h) + 40px); }
}

@media (max-width: 520px){
  :root{ --pad-x: 18px; }
  .btn-primary{ width: 100%; }
  .header-actions{ gap: 10px; }
  .lang-dropdown{ width: 220px; }
  .pricing-limits-list, .pricing-features-grid, .pricing-addons{ grid-template-columns: 1fr; }
}

/* -------- Closed Subscription Banners (Mobile) -------- */
.closed-subscription-hero-banner {
  box-sizing: border-box;
  max-width: 100%;
}

.closed-subscription-hero-banner form {
  max-width: 100%;
}

.closed-subscription-pricing-banner {
  box-sizing: border-box;
  max-width: 100%;
}

@media (max-width: 520px) {
  .closed-subscription-hero-banner {
    padding: 16px !important;
    margin-left: -4px;
    margin-right: -4px;
  }

  .closed-subscription-hero-banner form {
    flex-direction: column !important;
    gap: 12px !important;
  }

  .closed-subscription-hero-banner input,
  .closed-subscription-hero-banner button {
    width: 100% !important;
  }

  .closed-subscription-pricing-banner {
    padding: 24px 16px !important;
  }
}
