/* ============================================================
   screens.css — контейнер екранів, переходи, специфіка екранів
   ============================================================ */

/* --- контейнер та анімація появи --- */
.screen{animation:screen-in .35s var(--ease);}
@keyframes screen-in{
  from{opacity:0;transform:translateY(8px);}
  to{opacity:1;transform:translateY(0);}
}

/* ============================================================
   ЕКРАН 1 — вступ
   ============================================================ */
.intro{max-width:680px;margin:0 auto;text-align:center;padding-top:8px;}
.intro-logo{width:64px;height:64px;display:block;margin:24px auto 0;}
.intro .hero{padding-top:14px;padding-bottom:8px;}

.intro-points{
  display:flex;flex-direction:column;gap:12px;
  text-align:left;margin:28px auto 4px;max-width:520px;
}
.intro-point{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:16px 18px;
  box-shadow:var(--shadow-card);
}
.intro-point .num{
  flex-shrink:0;width:30px;height:30px;border-radius:50%;
  background:var(--green-light);color:var(--green-dark);
  font-family:var(--font-head);font-weight:700;font-size:14px;
  display:flex;align-items:center;justify-content:center;
}
.intro-point .txt{font-size:14px;line-height:1.5;}
.intro-point .txt b{display:block;margin-bottom:2px;}
.intro-point .txt span{color:var(--muted);font-size:13px;}

.intro-cta{margin-top:32px;}
.intro-note{margin-top:16px;font-size:12px;color:var(--muted);}

/* ============================================================
   ЕКРАН 2 — анкета знайомства
   ============================================================ */
.survey-head{text-align:center;padding:36px 20px 8px;}
.survey-head .hero-tag{margin-bottom:14px;}
.survey-head h1{font-family:var(--font-head);font-size:clamp(20px,3vw,28px);font-weight:700;line-height:1.25;}
.survey-head p{font-size:14px;color:var(--muted);max-width:480px;margin:10px auto 0;line-height:1.6;}

.field-group + .field-group{margin-top:18px;}
.group-label{
  font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:var(--green-dark);
  display:flex;align-items:center;gap:8px;
  margin:4px 0 6px;
}
.group-label::after{content:"";flex:1;height:1px;background:var(--border);}

/* нотатки менеджера — окремий акцент */
.manager-note{
  background:#FBFAF6;
  border:1px dashed var(--border-strong);
}
.manager-note .field:first-child{padding-top:0;}
.manager-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:600;color:var(--muted);
  margin-bottom:10px;
}
.manager-tag::before{content:"✎";}

@media(max-width:560px){
  .survey-head{padding-top:24px;}
}

/* ============================================================
   ЕКРАН 3 — діагностика потреб
   ============================================================ */
/* широкий контейнер лише для цього екрана — щоб 4 колонки помістилися в рядок */
main.app-main:has(> .screen[data-screen="diagnostics"]){max-width:1280px;}

.diag-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:6px;align-items:start;}
@media(max-width:1024px){.diag-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.diag-grid{grid-template-columns:1fr;}}

.diag-card{
  background:var(--white);border-radius:var(--radius);
  border:1px solid var(--border);box-shadow:var(--shadow-card);padding:18px 16px;
}
.diag-card-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap;
  margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border);
}
.diag-cat{min-width:0;}
.diag-cat-name{font-family:var(--font-head);font-size:16px;font-weight:700;line-height:1.2;}
.diag-cat-sub{font-size:11px;color:var(--muted);margin-top:3px;}
.diag-score{font-size:12px;color:var(--muted);font-weight:600;white-space:nowrap;text-align:right;}
.diag-score-val{
  display:inline-block;min-width:1.3em;text-align:center;
  font-family:var(--font-head);font-size:20px;font-weight:700;color:var(--green);
}

.diag-opts{display:flex;flex-direction:column;gap:8px;}
.diag-opt{
  display:flex;align-items:flex-start;gap:10px;width:100%;text-align:left;
  padding:11px 13px;border:2px solid rgba(0,0,0,.06);border-radius:12px;
  cursor:pointer;font-family:var(--font-body);font-size:13px;line-height:1.4;color:var(--text);
  transition:border-color .15s,box-shadow .15s,transform .08s;
}
.diag-opt:hover{border-color:rgba(0,0,0,.22);}
.diag-opt:active{transform:scale(.995);}
.diag-opt-txt{flex:1;}
.diag-check{
  flex-shrink:0;width:18px;height:18px;border-radius:50%;
  border:2px solid rgba(0,0,0,.3);background:rgba(255,255,255,.55);
  margin-top:1px;position:relative;transition:background .15s,border-color .15s;
}
.diag-opt.is-sel{border-color:var(--green-dark);box-shadow:0 0 0 2px rgba(15,110,86,.28);font-weight:600;}
.diag-opt.is-sel .diag-check{background:var(--green-dark);border-color:var(--green-dark);}
.diag-opt.is-sel .diag-check::after{
  content:"✓";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:11px;font-weight:700;
}

/* --- радар-діаграма --- */
.radar-card{text-align:center;}
.radar-title{font-family:var(--font-head);font-size:15px;font-weight:700;}
.radar-sub{font-size:12px;color:var(--muted);margin-top:3px;margin-bottom:12px;}
.radar-wrap{max-width:560px;margin:0 auto;}
.radar-svg{width:100%;height:auto;display:block;overflow:visible;}

/* ============================================================
   ЕКРАН 4 — питання на «ТАК»
   ============================================================ */
main.app-main:has(> .screen[data-screen="affirm"]){max-width:1140px;}

.affirm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:6px;align-items:start;}
@media(max-width:860px){.affirm-grid{grid-template-columns:1fr;}}

.affirm-col-head{
  background:#ED7D31;color:#fff;
  font-family:var(--font-head);font-weight:700;font-size:14px;
  letter-spacing:.05em;text-transform:uppercase;text-align:center;
  padding:11px;border-radius:10px;margin-bottom:12px;
}
.affirm-q{display:flex;align-items:stretch;gap:8px;margin-bottom:10px;}
.affirm-q-text{
  flex:1;display:flex;align-items:center;
  border:1px solid var(--border-strong);border-radius:10px;
  padding:10px 12px;font-size:13px;line-height:1.4;background:#fff;
  transition:background .15s;
}
.affirm-q-num{
  width:46px;flex-shrink:0;
  border:1px solid var(--border-strong);border-radius:10px;background:#fff;
  text-align:center;font-family:var(--font-head);font-weight:700;font-size:17px;color:var(--text);
}
.affirm-q-num:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(29,158,117,.14);}
.affirm-q-num::-webkit-outer-spin-button,
.affirm-q-num::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.affirm-q-num{-moz-appearance:textfield;}

/* ============================================================
   ЕКРАНИ 5–6 — підбір пакету + тариф
   ============================================================ */
.needs-list{display:flex;flex-direction:column;}
.need-item{
  display:flex;align-items:flex-start;gap:10px;
  padding:9px 10px;margin:1px -10px;border-radius:10px;cursor:pointer;
  transition:background .15s;
}
.need-item:hover{background:var(--green-light);}
.need-item label{display:flex;align-items:flex-start;gap:10px;width:100%;cursor:pointer;}
.need-item input[type=checkbox]{width:17px;height:17px;accent-color:var(--green);flex-shrink:0;margin-top:1px;cursor:pointer;}
.need-text{font-size:13.5px;line-height:1.5;flex:1;}
.need-item input:checked ~ .need-text{color:var(--green-dark);font-weight:600;}
.need-badge{margin-top:2px;}

.select-count{flex:1;text-align:center;font-size:13px;color:var(--muted);}
.select-count b{color:var(--green-dark);font-family:var(--font-head);}

/* --- картка тарифу --- */
.result-card{
  max-width:430px;margin:0 auto;
  background:var(--white);border:2px solid var(--green);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow-float);
}
.result-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.result-icon{
  width:44px;height:44px;border-radius:12px;background:var(--green-light);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.result-icon svg{width:22px;height:22px;stroke:var(--green);}
.result-label{font-size:11px;color:var(--muted);font-weight:500;}
.result-pkg{font-family:var(--font-head);font-size:20px;font-weight:700;}
.result-img{display:flex;justify-content:center;margin:10px 0;}
.result-img img{width:170px;height:auto;filter:drop-shadow(0 6px 16px rgba(0,0,0,.12));}
.result-price{text-align:center;margin-bottom:14px;}
.result-price .amount{font-family:var(--font-head);font-size:24px;font-weight:700;color:var(--green);}
.result-price .period{font-size:12px;color:var(--muted);}
.result-desc{font-size:13px;color:var(--muted);line-height:1.6;text-align:center;margin-bottom:16px;}
.result-progress{margin-bottom:16px;}
.result-progress-top{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:6px;}
.result-bar{height:6px;background:var(--green-light);border-radius:var(--radius-pill);overflow:hidden;}
.result-fill{height:100%;background:var(--green);border-radius:var(--radius-pill);transition:width .4s;}
.match-list{display:flex;flex-direction:column;gap:5px;margin-bottom:18px;}
.match-item{font-size:12.5px;color:var(--green-dark);display:flex;align-items:flex-start;gap:7px;line-height:1.4;}
.match-item::before{content:"✓";font-weight:700;flex-shrink:0;}
.match-more{color:var(--muted);}
.match-more::before{content:"+";}

.empty-state{text-align:center;padding:24px 10px;color:var(--muted);font-size:14px;line-height:1.6;}
.empty-icon{font-size:34px;margin-bottom:10px;}

/* --- панель КП (Сформувати пропозицію → email) --- */
.offer-wrap{max-width:430px;margin:14px auto 0;}
.offer-toggle{width:100%;}
.offer-body{
  margin-top:12px;background:var(--white);border:2px solid var(--green-light);
  border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-float);
}
.offer-body[hidden]{display:none;}
.offer-body h4{font-family:var(--font-head);font-size:15px;margin:0 0 12px 0;color:var(--green-dark);}
.offer-periods{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:14px;}
@media(min-width:520px){.offer-periods{grid-template-columns:repeat(3,1fr);}}
.offer-period{
  cursor:pointer;border:2px solid var(--green-light);border-radius:14px;
  padding:12px 10px;text-align:center;background:var(--white);
  transition:border-color .15s, background .15s;
}
.offer-period:hover{border-color:var(--green);}
.offer-period.is-active{border-color:var(--green);background:#EDF7E8;}
.offer-period .lbl{font-size:13px;font-weight:600;color:#1c3a2b;line-height:1.3;}
.offer-period .sum{font-size:13px;color:var(--green-dark);margin-top:6px;font-weight:700;}
.offer-period .savings{font-size:11px;color:var(--green);margin-top:3px;font-weight:600;}
.offer-email{
  display:flex;align-items:center;gap:8px;padding:10px 12px;
  background:#f6f8f5;border:1px solid var(--green-light);border-radius:12px;
  margin-bottom:12px;font-size:13px;
}
.offer-email .lab{color:var(--muted);}
.offer-email .val{font-weight:600;color:#1c3a2b;}
.offer-email .val.is-missing{color:#c25b3a;}
.offer-total{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;padding:10px 0;
  border-top:1px dashed var(--green-light);border-bottom:1px dashed var(--green-light);
}
.offer-total .lbl{font-size:13px;color:var(--muted);}
.offer-total .amount{font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--green);}
.offer-send{width:100%;}
.offer-status{margin-top:10px;font-size:13px;text-align:center;}
.offer-status.ok{color:var(--green);font-weight:600;}
.offer-status.err{color:#c25b3a;}

/* --- зведення пріоритетів (екран 3) --- */
.affirm-summary{margin-top:18px;}
.affirm-sum-title{font-family:var(--font-head);font-size:15px;font-weight:700;}
.affirm-sum-note{font-size:12px;color:var(--muted);margin:2px 0 14px;}
.sum-group{margin-bottom:14px;}
.sum-group:last-child{margin-bottom:0;}
.sum-head{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13px;margin-bottom:6px;}
.sum-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:6px;
  font-family:var(--font-head);font-weight:700;font-size:12px;color:#1a1a1a;flex-shrink:0;
}
.sum-item{display:flex;gap:10px;font-size:13px;line-height:1.45;padding:4px 0 4px 30px;}
.sum-cat{flex-shrink:0;min-width:56px;font-size:11px;font-weight:600;color:var(--muted);}

/* --- слайд «Як закриває JAMM School» --- */
.jamm-list{display:flex;flex-direction:column;gap:12px;max-width:640px;margin:0 auto;}
.jamm-point{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:16px 18px;box-shadow:var(--shadow-card);
}
.jamm-check{
  flex-shrink:0;width:28px;height:28px;border-radius:50%;
  background:var(--green-light);color:var(--green-dark);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;
}
.jamm-point-txt{font-size:14.5px;line-height:1.5;align-self:center;}

/* --- слайд порівняння тарифів (iframe) --- */
main.app-main:has(> .screen[data-screen="compare"]){max-width:1160px;}
.compare-bar{display:flex;align-items:center;gap:14px;margin:4px 0 14px;}
.compare-bar-title{font-family:var(--font-head);font-weight:700;font-size:15px;}
.compare-frame{width:100%;border:0;display:block;min-height:600px;background:var(--bg);border-radius:var(--radius);}
