/* =========================================================
   SONAR — CALLS section
   Карточка звонка с подсказками по бокам.
   ========================================================= */

/* ---------- SECTION ---------- */

.calls-section{
  position:relative;
  overflow:hidden;
  background:#08051a;
  padding:75px 0 10px;
  isolation:isolate;
}

.calls-section .container{
  position:relative;
  z-index:1;
}

/* ---------- HEADING ---------- */

.calls-heading{
  text-align:center;
  max-width:900px;
  margin:0 auto 28px;
  padding:0 16px;
}

.calls-title{
  margin:0;
  color:var(--sonar-headline-section-color);
  font-size:var(--sonar-headline-section-fs);
  line-height:var(--sonar-headline-section-lh);
  letter-spacing:var(--sonar-headline-section-tracking);
  font-weight:var(--sonar-headline-section-fw);
}

.calls-subtitle{
  margin:18px auto 0;
  max-width:720px;
  color:rgba(226,232,240,.66);
  line-height:var(--sonar-section-subtitle-lh);
  font-size:var(--sonar-section-subtitle-fs);
}

.calls-bridge{
  max-width:680px;
  margin:0 auto 40px;
  padding:0 16px;
  text-align:center;
  color:rgba(216,180,254,.7);
  font-size:13px;
  font-weight:500;
  letter-spacing:.02em;
}

/* ---------- STAGE — full-bleed под подсказки ---------- */

.calls-stage{
  position:relative;

  /* full-bleed */
  width:min(100vw, 1500px);
  max-width:none;
  margin:0;
  left:50%;
  transform:translateX(-50%);

  padding:0 clamp(72px, 23vw, 340px) 130px;

  /* ↓ НОВОЕ — центрируем продукт по вертикали относительно подсказок */
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:760px;   /* верхний ряд (top:40) + третий ряд (top:520) + высота карточки ~180 + запас */
}

@media (max-width:1400px){
  .calls-stage{
    width:min(100vw, 1400px);
    padding:0 clamp(64px, 21vw, 300px) 130px;
    min-height:740px;
  }
}

@media (max-width:1280px){
  .calls-stage{
    width:min(100vw, 1240px);
    padding:0 clamp(56px, 19vw, 270px) 130px;
    min-height:720px;
  }
}

/* ---------- PRODUCT — основная карточка (Dim Glass — крупный контейнер) ---------- */

.calls-product{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;

  width:100%;
  max-width:100%;

  padding:28px 30px;

  border-radius:var(--sonar-card-radius);

  background: var(--sonar-card-dim-bg);
  border: var(--sonar-card-dim-border);

  box-shadow: var(--sonar-card-dim-shadow);

  backdrop-filter: var(--sonar-card-blur);
  -webkit-backdrop-filter: var(--sonar-card-blur);

  overflow:hidden;
  isolation:isolate;
}

.calls-product::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:1px;
  background: var(--sonar-card-dim-rim-gradient);
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  pointer-events:none;
  opacity: var(--sonar-card-dim-rim-opacity);
}

.calls-product > *{
  position:relative;
  z-index:1;
}

/* ---------- TOOLBAR ---------- */

.calls-toolbar{
  position:relative;
  z-index:1;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;

  margin-bottom:22px;
  padding:0 0 16px;

  border:none;
  border-bottom:1px solid rgba(168,85,247,.1);
  background:none;
  box-shadow:none;
}

/* левая / правая группы тулбара */
.calls-toolbar-group{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}

.calls-toolbar-group--mode{
  flex-shrink:0;
}

.calls-toolbar-group--filters{
  flex:1;
  min-width:0;
  justify-content:flex-end;
  gap:12px;
}

.calls-toolbar .calls-tabs{
  display:flex;
  align-items:center;
  gap:8px;
  flex-shrink:0;
}

.calls-tab{
  height:32px;
  padding:0 16px;
  display:flex;
  align-items:center;
  border-radius:10px;
  color:rgba(248,250,252,.88);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  font-size:11px;
  font-weight:500;
  white-space:nowrap;
  letter-spacing:.02em;
}

.calls-tab.active{
  background:linear-gradient(135deg, rgba(124,58,237,.85) 0%, rgba(91,33,182,.95) 100%);
  border:1px solid rgba(192,132,252,.48);
  color:#fff;
  font-weight:600;
}

.calls-toolbar .calls-filters{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
  margin:0;
  padding:0;
  border:none;
  flex-wrap:nowrap;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}

.calls-toolbar .calls-filters::-webkit-scrollbar{ display:none; }

.calls-filter{
  height:32px;
  padding:0 12px;
  display:inline-flex;
  align-items:center;
  border-radius:10px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(226,232,240,.62);
  font-size:11px;
  font-weight:500;
  white-space:nowrap;
  flex-shrink:0;
  letter-spacing:.02em;
}

.calls-toolbar-meta{
  flex-shrink:0;
  padding:0;
  border:none;
}

.calls-top-actions{
  color:rgba(226,232,240,.5);
  font-size:11px;
  font-weight:500;
  letter-spacing:.04em;
  white-space:nowrap;
}

/* ---------- CARD content ---------- */

.calls-card-main{
  position:relative;
  z-index:1;
}

.calls-card-body{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.calls-card-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  margin-bottom:20px;
  padding:0;
  border:none;
}

.calls-user{
  display:flex;
  gap:12px;
  align-items:center;
  min-width:0;
}

.calls-user-text{ min-width:0; }

.calls-avatar{
  width:40px;
  height:40px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#a855f7 0%,#7c3aed 100%);
  color:#fff;
  font-weight:700;
  font-size:12px;
}

.calls-user-name{
  color:#fff;
  font-size:14px;
  font-weight:700;
  letter-spacing:-.015em;
}

.calls-user-meta{
  margin-top:3px;
  color:rgba(226,232,240,.52);
  font-size:11.5px;
  line-height:1.4;
}

.calls-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.calls-tag{
  height:28px;
  padding:0 10px;
  display:flex;
  align-items:center;
  border-radius:999px;
  font-size:10.5px;
  font-weight:500;
}

.calls-tag.blue{
  background:rgba(59,130,246,.07);
  color:#93c5fd;
  border:1px solid rgba(59,130,246,.38);
}

.calls-tag.orange{
  background:rgba(245,158,11,.07);
  color:#fcd34d;
  border:1px solid rgba(245,158,11,.38);
}

.calls-tag.green{
  background:rgba(16,185,129,.07);
  color:#6ee7b7;
  border:1px solid rgba(16,185,129,.38);
}

.calls-panels{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}

@media (min-width:960px){
  .calls-panels{
    grid-template-columns:1fr 1fr;
    gap:14px;
    align-items:stretch;
  }
}

.calls-panel{
  padding:18px 20px;
  border-radius:var(--sonar-card-radius-compact);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  margin:0;
  display:flex;
  flex-direction:column;
  min-height:0;
}

.calls-eyebrow{
  margin:0 0 10px;
  color:rgba(241,245,249,.92);
  font-size:10.5px;
  font-weight:700;
  font-family:inherit;
  line-height:1.3;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.calls-body-text{
  margin:0;
  color:rgba(226,232,240,.72);
  line-height:1.65;
  font-size:12.5px;
  letter-spacing:0;
}

.calls-panel .calls-body-text{ flex:1; }

.calls-panel ul.calls-remarks-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
}

.calls-panel ul.calls-remarks-list li{
  display:grid;
  grid-template-columns:6px 1fr;
  align-items:start;
  gap:10px;
  padding:0;
  margin:0;
  border:none;
  font-size:12.5px;
  font-weight:400;
  line-height:1.6;
  color:rgba(226,232,240,.65);
  letter-spacing:0;
}

.calls-remarks-dot{
  width:6px;
  height:6px;
  margin-top:5px;
  border-radius:2px;
  flex-shrink:0;
}

.calls-panel ul.calls-remarks-list li:nth-child(1) .calls-remarks-dot{ background:#e9d5ff; }
.calls-panel ul.calls-remarks-list li:nth-child(2) .calls-remarks-dot{ background:#c084fc; }
.calls-panel ul.calls-remarks-list li:nth-child(3) .calls-remarks-dot{ background:#a855f7; }

.calls-remarks-text{
  display:block;
  min-width:0;
}

.calls-insight{
  padding:18px 20px;
  border-radius:var(--sonar-card-radius-compact);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:none;
}

.calls-insight .calls-eyebrow{ margin-bottom:10px; }

.calls-footer{
  display:flex;
  align-items:center;
  gap:8px;
  margin-top:22px;
  padding:18px 0 0;
  border:none;
  border-top:1px solid rgba(168,85,247,.1);
}

.calls-footer-spacer{ flex:1; }

.calls-btn{
  height:36px;
  padding:0 14px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:transparent;
  color:rgba(255,255,255,.82);
  font-size:11.5px;
  font-weight:600;
  cursor:pointer;
}

.calls-btn:hover{
  border-color:rgba(168,85,247,.35);
  color:#fff;
}

.calls-btn.primary{
  background:linear-gradient(135deg,#a855f7 0%,#7c3aed 100%);
  border:1px solid rgba(192,132,252,.42);
  color:#fff;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.15),
    0 0 0 1px rgba(124,58,237,.25),
    0 0 32px rgba(168,85,247,.45),
    0 10px 36px -10px rgba(124,58,237,.55);
}

.calls-btn.primary:hover{ filter:brightness(1.06); }

.calls-link{
  background:none;
  border:none;
  color:rgba(203,213,225,.48);
  font-size:11px;
  font-weight:500;
  cursor:pointer;
}

.calls-link:hover{ color:#fff; }

/* =========================================================
   HINTS — liquid-glass подсказки + SVG-провода
   ========================================================= */

/* SVG-слой проводов, генерируется JS */
.calls-wires{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  pointer-events:none;
  z-index:2;
  overflow:visible;
}

.calls-hints{
  position:absolute;
  inset:0;
  z-index:4;
  pointer-events:none;
}

.calls-hint{
  position:absolute;
  width:min(248px, 19vw);
  pointer-events:auto;
}

/* стеклянная подложка — единый light-glass материал (без диагонального блика) */
.calls-hint-glass{
  position:relative;
  isolation:isolate;
  padding:16px 18px 16px;
  border-radius:18px;
  overflow:hidden;

  background: var(--sonar-card-bg);
  border: var(--sonar-card-border);

  backdrop-filter: var(--sonar-card-blur);
  -webkit-backdrop-filter: var(--sonar-card-blur);

  box-shadow: var(--sonar-card-shadow);
}

/* только тонкий градиентный обод — как у .sonar-card, без радиального/диагонального блика */
.calls-hint-glass::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:1px;
  background: var(--sonar-card-rim-gradient);
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  pointer-events:none;
  opacity: var(--sonar-card-rim-opacity);
}

.calls-hint-glass::after{
  content:none;
  display:none;
}

.calls-hint-glass > *{
  position:relative;
  z-index:1;
}

/* лейбл в правом верхнем углу */
.calls-hint-kicker{
  position:absolute;
  top:14px;
  right:16px;

  display:inline-flex;
  align-items:center;
  gap:6px;

  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size:9.5px;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(226,232,240,.45);
  line-height:1;
  white-space:nowrap;
}

.calls-hint-kicker::after{
  content:"";
  display:inline-block;
  width:4px;
  height:4px;
  border-radius:50%;
  background:rgba(255,255,255,.7);
  box-shadow:0 0 6px rgba(255,255,255,.45);
}

/* номер-монограмма в левом верхнем углу
   (заполняется JS-скриптом через атрибут data-num) */
.calls-hint::after{
  content:attr(data-num);
  display:block;
  position:absolute;
  top:14px;
  left:18px;
  z-index:5;

  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size:11px;
  font-weight:600;
  letter-spacing:.04em;
  color:rgba(255,255,255,.78);
}

.calls-hint-title{
  margin:32px 0 6px;
  padding:0;
  font-size:15.5px;
  font-weight:600;
  letter-spacing:-.015em;
  line-height:1.25;
  color:#f8fafc;
}

.calls-hint-text{
  margin:0;
  padding:0;
  font-size:12px;
  line-height:1.55;
  color:rgba(226,232,240,.62);
  font-weight:400;
}

/* ---------- РАСПОЛОЖЕНИЕ ПОДСКАЗОК — 3 уровня × 2 колонки ---------- */

/* три уровня по вертикали (от верха .calls-stage) */
.calls-hint--tabs,
.calls-hint--filters{
  top: 40px;
}

.calls-hint--summary,
.calls-hint--tags{
  top: 280px;
}

.calls-hint--actions,
.calls-hint--details{
  top: 520px;
}

/* левая колонна */
.calls-hint--tabs,
.calls-hint--summary,
.calls-hint--actions{
  left: 4px;
}

/* правая колонна */
.calls-hint--filters,
.calls-hint--tags,
.calls-hint--details{
  right: 4px;
}

/* actions больше не плавает снизу по центру — сбрасываем старые правила */
.calls-hint--actions{
  bottom: auto;
  transform: none;
  width: min(248px, 19vw);
}

/* ---------- АНИМАЦИЯ ---------- */



/* =========================================================
   ОТЗЫВЧИВОСТЬ
   ========================================================= */

@media (max-width:1200px){
  .calls-stage{
    width:100% !important;
    max-width:none;
    left:auto;
    transform:none;
    padding:0 16px 40px !important;
    /* Подсказки уже не absolute — высота сценария не нужна, иначе на планшетах/телефонах пустота ~760px */
    min-height:0 !important;
    justify-content:flex-start;
  }

  .calls-wires{ display:none; }

  .calls-hints{
    position:static;
    inset:auto;
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:12px;
    margin-top:20px;
    z-index:1;
  }

  .calls-hint{
    position:static;
    width:auto;
    transform:none !important;
  }

  .calls-hint::after{ display:none; }
  .calls-hint .calls-hint-title{ margin-top:0; }
  .calls-hint .calls-hint-kicker{
    position:static;
    margin-bottom:10px;
  }

  .calls-hints .calls-hint-glass{ animation:none !important; }
}

@media (max-width:992px){
  .calls-toolbar{
    flex-wrap:wrap;
    align-items:stretch;
    gap:12px;
  }

  .calls-toolbar-group--mode{
    flex:1 1 100%;
    min-width:0;
  }

  .calls-toolbar-group--filters{
    flex:1 1 100%;
    min-width:0;
    flex-wrap:nowrap;
    justify-content:space-between;
    gap:10px;
  }

  .calls-toolbar .calls-tabs{
    width:100%;
  }

  .calls-toolbar .calls-tab{
    flex:1 1 0;
    min-width:0;
    justify-content:center;
  }

  .calls-toolbar .calls-filters{
    flex:1 1 auto;
    min-width:0;
    flex-wrap:nowrap;
    overflow-x:auto;
  }

  .calls-toolbar-meta{
    flex:0 0 auto;
    flex-shrink:0;
  }
}

@media (max-width:768px){
  .calls-section{
    padding:52px 0 64px;
  }

  .calls-heading{
    margin-bottom:20px;
    padding:0 4px;
  }

  .calls-title{
    font-size:clamp(22px, 5.5vw, 36px);
    line-height:1.15;
  }

  .calls-subtitle{
    margin-top:14px;
    font-size:clamp(14px, 3.6vw, 17px);
    line-height:1.6;
  }

  .calls-bridge{
    margin-bottom:22px;
    padding:0 4px;
    font-size:12.5px;
    line-height:1.5;
  }

  .calls-stage{
    padding:0 0 32px !important;
  }

  .calls-product{
    padding:18px 14px;
    border-radius:16px;
  }

  .calls-toolbar{
    margin-bottom:16px;
    padding:0 0 12px;
  }

  .calls-toolbar .calls-tab{
    padding:0 10px;
    font-size:10.5px;
  }

  .calls-user-text{
    min-width:0;
  }

  .calls-user-name{
    overflow-wrap:anywhere;
    word-break:break-word;
  }

  .calls-user-meta{
    overflow-wrap:anywhere;
  }

  .calls-card-top{
    flex-direction:column;
    align-items:stretch;
    gap:12px;
    margin-bottom:16px;
  }

  .calls-tags{
    max-width:none;
    justify-content:flex-start;
    gap:6px;
  }

  .calls-tag{
    height:auto;
    min-height:28px;
    padding:6px 10px;
    white-space:normal;
    text-align:center;
    line-height:1.25;
  }

  .calls-panel{
    padding:14px 14px;
  }

  .calls-insight{
    padding:14px 14px;
  }

  .calls-body-text{
    font-size:13px;
  }

  .calls-footer{
    flex-wrap:wrap;
    margin-top:16px;
    padding:14px 0 0;
    gap:10px;
  }

  .calls-footer-spacer{
    display:none;
  }

  .calls-btn{
    flex:1 1 calc(50% - 5px);
    min-width:0;
    height:auto;
    min-height:40px;
    padding:10px 12px;
    white-space:normal;
    text-align:center;
    line-height:1.25;
  }

  .calls-link{
    flex:1 1 100%;
    text-align:center;
    padding:8px 0 0;
  }

  .calls-hints{
    margin-top:16px;
    gap:10px;
  }

  .calls-hint-glass{
    padding:14px 14px 14px;
    border-radius:16px;
  }

  .calls-hint-title{
    font-size:14px;
  }

  .calls-hint-text{
    font-size:11.5px;
  }
}

@media (max-width:540px){
  .calls-hints{ grid-template-columns:1fr; }

  .calls-toolbar{
    gap:10px;
    padding:0;
  }

  .calls-filter{
    padding:0 10px;
    font-size:10.5px;
  }

  .calls-btn.primary{
    flex:1 1 100%;
  }

  .calls-btn:not(.primary){
    flex:1 1 calc(50% - 5px);
  }
}
