/* ============================================================
   GBTI — Габен-типология. Неоновый стиль сайта + «лабораторная»
   строгость 16personalities. Самодостаточный файл (как wanted.css).
   ============================================================ */
:root{
  --bg:#0a0a14; --panel:rgba(18,18,30,0.95); --line:rgba(168,85,247,0.35);
  --txt:#e8e8f2; --mut:#9a95b0; --neon:#a855f7; --cyan:#00f0ff;
  --mp:#ff4655; --mb:#33a1ff; --op:#a86cff; --ob:#4ecb71;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{
  background:var(--bg); color:var(--txt); font-family:'Exo 2',sans-serif; min-height:100vh;
  background-image:
    radial-gradient(ellipse 60% 40% at 20% 0%, rgba(109,40,217,0.18), transparent),
    radial-gradient(ellipse 50% 35% at 85% 15%, rgba(0,240,255,0.08), transparent);
  padding-bottom:30px;
}

/* ---- шапка-панель + боковая навигация (общий паттерн сайта) ---- */
.panel{
  position:relative; max-width:760px; margin:34px auto 18px; padding:26px 30px 22px;
  background:var(--panel); backdrop-filter:blur(10px);
  border:1px solid var(--line); border-radius:16px;
  box-shadow:0 0 30px rgba(168,85,247,0.18); text-align:center;
}
.panel h1{
  font-family:'Orbitron',sans-serif; font-size:1.7rem; letter-spacing:2px;
  background:linear-gradient(135deg,#a855f7,#00f0ff); -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; margin-bottom:10px;
}
.panel .subtitle{color:var(--mut); font-size:0.92rem; line-height:1.5; max-width:600px; margin:0 auto;}
.nav-left:hover{width:210px; left:-210px;}
@media (max-width:560px){ .panel h1{font-size:1.25rem;} .panel{margin:22px 12px 14px;} }

/* ---- общие кнопки ---- */
.gb-btn{
  cursor:pointer; font-family:'Orbitron',sans-serif; font-weight:700; font-size:0.95rem;
  letter-spacing:1px; color:#fff; background:rgba(255,255,255,0.06);
  border:1px solid var(--line); border-radius:12px; padding:14px 28px; transition:.2s;
}
.gb-btn:hover{border-color:var(--neon); box-shadow:0 0 16px rgba(168,85,247,0.45);}
.gb-btn-primary{background:linear-gradient(135deg,#6d28d9,#a855f7); border:none;}
.gb-btn-primary:hover{filter:brightness(1.15); box-shadow:0 0 22px rgba(168,85,247,0.6);}
.gb-btn-ghost{background:transparent; color:var(--mut);}
.gb-btn:disabled{opacity:.5; cursor:default;}

/* ============================================================
   ЭКРАН 1 — ВСТУПЛЕНИЕ
   ============================================================ */
.gb-screen{max-width:760px; margin:0 auto; padding:0 14px;}
.gb-intro-box{
  background:var(--panel); border:1px solid var(--line); border-radius:16px;
  padding:30px 32px; text-align:center; box-shadow:0 0 24px rgba(168,85,247,0.12);
}
.gb-intro-badges{display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:20px;}
.gb-ibadge{
  font-family:'Jura',sans-serif; font-size:0.78rem; font-weight:700; letter-spacing:0.5px;
  color:var(--cyan); border:1px solid rgba(0,240,255,0.35); border-radius:20px; padding:6px 14px;
  background:rgba(0,240,255,0.06);
}
.gb-intro-text{color:#cfcbe0; font-size:0.98rem; line-height:1.65; text-align:left; margin-bottom:24px;}
.gb-intro-text p{margin-bottom:12px;}
.gb-intro-text em{color:var(--neon); font-style:normal; font-weight:600;}
.gb-intro-fineprint{color:#565170; font-size:0.72rem; margin-top:16px; line-height:1.5;}

/* ============================================================
   ЭКРАН 2 — ТЕСТ
   ============================================================ */
.gb-progress-wrap{margin:6px 0 20px;}
.gb-progress-label{font-family:'Jura',sans-serif; color:var(--mut); font-size:0.8rem; text-align:center; margin-bottom:8px; letter-spacing:1px;}
.gb-progress{height:8px; background:rgba(255,255,255,0.07); border-radius:6px; overflow:hidden;}
.gb-progress-fill{height:100%; width:0; background:linear-gradient(90deg,#6d28d9,#a855f7,#00f0ff); border-radius:6px; transition:width .35s ease;}

.gb-qcard{
  position:relative; background:var(--panel); border:1px solid var(--line); border-radius:16px;
  padding:38px 34px 34px; text-align:center; box-shadow:0 0 24px rgba(168,85,247,0.12);
  animation:gbIn .3s ease;
}
@keyframes gbIn{from{opacity:0; transform:translateY(10px);}to{opacity:1; transform:none;}}
.gb-qnum{font-family:'Orbitron',sans-serif; color:var(--cyan); font-size:0.75rem; letter-spacing:2px; margin-bottom:14px;}
.gb-qtext{font-size:1.18rem; font-weight:600; line-height:1.5; min-height:3.2em; display:flex; align-items:center; justify-content:center; margin-bottom:28px;}
.gb-scale{display:flex; align-items:center; justify-content:center; gap:16px;}
.gb-scale-side{font-family:'Jura',sans-serif; font-size:0.78rem; font-weight:700; width:86px; flex-shrink:0;}
.gb-disagree{color:#ff4655; text-align:right;}
.gb-agree{color:#4ecb71; text-align:left;}
.gb-dots{display:flex; align-items:center; gap:12px;}
.gb-dot{
  border-radius:50%; cursor:pointer; border:2px solid rgba(255,255,255,0.28);
  background:transparent; transition:.15s; flex-shrink:0;
}
.gb-dot:hover{transform:scale(1.15);}
.gb-dot.d3{width:44px;height:44px;} .gb-dot.d2{width:36px;height:36px;} .gb-dot.d1{width:28px;height:28px;} .gb-dot.d0{width:22px;height:22px;}
.gb-dot.side-a{border-color:rgba(78,203,113,0.7);} .gb-dot.side-a:hover,.gb-dot.side-a.on{background:#4ecb71; border-color:#4ecb71; box-shadow:0 0 12px rgba(78,203,113,0.6);}
.gb-dot.side-d{border-color:rgba(255,70,85,0.7);} .gb-dot.side-d:hover,.gb-dot.side-d.on{background:#ff4655; border-color:#ff4655; box-shadow:0 0 12px rgba(255,70,85,0.6);}
.gb-dot.side-n{border-color:rgba(255,255,255,0.3);} .gb-dot.side-n:hover,.gb-dot.side-n.on{background:#9a95b0; border-color:#9a95b0;}
.gb-back{
  position:absolute; left:14px; top:14px; background:none; border:1px solid rgba(255,255,255,0.15);
  color:var(--mut); border-radius:8px; width:36px; height:36px; cursor:pointer; font-size:1rem;
}
.gb-back:hover{color:#fff; border-color:var(--neon);}
@media (max-width:560px){
  .gb-qcard{padding:38px 12px 28px;}
  .gb-qnum{padding:0 44px;} /* не налезает на кнопку «назад» */
  .gb-qtext{font-size:1.02rem;}
  /* подписи — отдельной строкой над точками, чтобы ничего не выходило за экран */
  .gb-scale{flex-wrap:wrap; gap:10px 0;}
  .gb-scale-side{width:50%; font-size:0.72rem;}
  .gb-disagree{order:1; text-align:left; padding-left:4px;}
  .gb-agree{order:2; text-align:right; padding-right:4px;}
  .gb-dots{order:3; flex-basis:100%; justify-content:center; gap:6px;}
  .gb-dot.d3{width:40px;height:40px;} .gb-dot.d2{width:33px;height:33px;} .gb-dot.d1{width:27px;height:27px;} .gb-dot.d0{width:22px;height:22px;}
  .gb-actions .gb-btn{padding:10px 14px; font-size:0.78rem;}
  .gb-intro-box{padding:24px 16px;}
}

/* ============================================================
   ЭКРАН 3 — РЕЗУЛЬТАТ
   ============================================================ */
.gb-guest-note{
  background:rgba(0,240,255,0.07); border:1px solid rgba(0,240,255,0.3); border-radius:12px;
  color:#bfeff7; padding:12px 16px; font-size:0.88rem; text-align:center; margin:18px auto 0; max-width:640px;
}
.gb-result{max-width:820px;}

/* ---- Карточка (фикс. 1000px, скейлится под вьюпорт, экспорт в PNG) ---- */
.gb-card-viewport{width:100%; overflow:visible; display:flex; justify-content:center;}
.gb-card-scale{transform-origin:top center;}
.gb-card{
  --acc:#a855f7;            /* акцент группы; производные rgba задаёт JS: */
  --accSoft:rgba(168,85,247,0.28);
  --accBorder:rgba(168,85,247,0.55);
  --accGlow:rgba(168,85,247,0.26);
  --accText:rgba(168,85,247,0.6);
  width:1000px; padding:44px 52px 40px; border-radius:26px; text-align:center;
  background:
    radial-gradient(ellipse 90% 42% at 50% -6%, var(--accSoft), transparent),
    linear-gradient(160deg,#141422 0%, #0c0c16 55%, #10101c 100%);
  border:2px solid var(--accBorder);
  box-shadow:0 0 46px var(--accGlow), inset 0 0 90px rgba(0,0,0,0.5);
  font-family:'Exo 2',sans-serif; color:#eee;
}
.gb-card-head{display:flex; justify-content:space-between; align-items:center; margin-bottom:8px;}
.gb-card-logo{font-family:'Orbitron',sans-serif; font-weight:900; font-size:1.5rem; letter-spacing:4px; color:var(--acc);}
.gb-card-headright{font-family:'Jura',sans-serif; color:#7d7896; font-size:0.98rem; letter-spacing:1px;}
.gb-char{display:block; width:480px; height:560px; margin:0 auto; object-fit:contain;}
.gb-card-code{
  font-family:'Orbitron',sans-serif; font-weight:900; font-size:5.6rem; letter-spacing:14px;
  line-height:1; margin:6px 0 4px; color:var(--acc);
  text-shadow:0 0 34px var(--accText);
}
.gb-ident{font-size:0.42em; color:#8d87a6; letter-spacing:4px; vertical-align:8px; text-shadow:none;}
.gb-card-name{font-family:'Orbitron',sans-serif; font-size:1.9rem; font-weight:700; letter-spacing:1px; color:#fff; margin-bottom:6px;}
.gb-card-group{font-family:'Jura',sans-serif; font-size:1.05rem; color:#9a95b0; margin-bottom:14px;}
.gb-card-group b{color:var(--acc);}
.gb-card-quote{font-size:1.15rem; font-style:italic; color:#c6c1da; max-width:760px; margin:0 auto 26px; line-height:1.5;}
.gb-card-bars{display:flex; flex-direction:column; gap:14px; max-width:780px; margin:0 auto 28px; text-align:left;}
.gb-bar-row{display:grid; grid-template-columns:170px 1fr 170px; align-items:center; gap:14px;}
.gb-bar-pole{font-family:'Jura',sans-serif; font-size:0.95rem; font-weight:700; color:#7d7896;}
.gb-bar-pole.r{text-align:right;} /* левая подпись — по правому краю к бару */
.gb-bar-pole.win{color:#fff;}
.gb-bar-pole .pct{color:var(--acc); margin:0 6px; font-weight:900;}
.gb-bar-pole .pct.dim{color:#5a5470; font-weight:700;}
.gb-bar-track{height:16px; background:rgba(255,255,255,0.10); border:1px solid rgba(255,255,255,0.14); border-radius:9px; position:relative; overflow:hidden;}
.gb-bar-fill{position:absolute; top:0; bottom:0; background:var(--acc); border-radius:8px;}
.gb-bar-rest{position:absolute; top:0; bottom:0; background:rgba(255,255,255,0.16); border-radius:8px;}
.gb-card-traits{display:grid; grid-template-columns:1fr 1fr; gap:22px; max-width:820px; margin:0 auto 24px; text-align:left;}
.gb-tcol-title{font-family:'Orbitron',sans-serif; font-size:0.95rem; letter-spacing:1px; color:#4ecb71; margin-bottom:10px;}
.gb-tcol-title.gb-weak{color:#ff4655;}
.gb-card-tcol ul{list-style:none;}
.gb-card-tcol li{font-size:1rem; color:#cfcbe0; padding:5px 0 5px 22px; position:relative; line-height:1.4;}
.gb-card-tcol li::before{content:'▸'; position:absolute; left:2px; color:var(--acc);}
.gb-card-mates{display:flex; justify-content:center; gap:18px; flex-wrap:wrap; margin-bottom:24px;}
.gb-mate-chip{
  border:1px solid rgba(255,255,255,0.16); border-radius:14px; padding:12px 22px; min-width:280px;
  background:rgba(255,255,255,0.04); text-align:center;
}
.gb-mate-chip .lbl{font-family:'Jura',sans-serif; font-size:0.8rem; color:#7d7896; letter-spacing:1px; margin-bottom:4px;}
.gb-mate-chip .who{font-family:'Orbitron',sans-serif; font-weight:700; font-size:1.05rem;}
.gb-mate-chip.good .who{color:#4ecb71;} .gb-mate-chip.bad .who{color:#ff4655;}
.gb-card-foot{font-family:'Jura',sans-serif; color:#565170; font-size:0.95rem; letter-spacing:2px; border-top:1px solid rgba(255,255,255,0.08); padding-top:16px;}

/* ---- протокол сопоставления (вызов друга) ---- */
.gb-vs{
  background:var(--panel); border:1px solid rgba(0,240,255,0.35); border-radius:16px;
  padding:22px 24px; margin-bottom:20px; text-align:center;
  box-shadow:0 0 24px rgba(0,240,255,0.12);
}
.gb-vs-title{font-family:'Orbitron',sans-serif; letter-spacing:2px; color:var(--cyan); font-size:1rem; margin-bottom:16px;}
.gb-vs-row{display:flex; align-items:center; justify-content:center; gap:18px; flex-wrap:wrap; margin-bottom:14px;}
.gb-vs-chip{border:1px solid var(--vc,#a855f7); border-radius:14px; padding:10px 20px; min-width:180px; background:rgba(255,255,255,0.03);}
.gb-vs-chip .lbl{font-family:'Jura',sans-serif; font-size:0.72rem; color:#7d7896; letter-spacing:1px;}
.gb-vs-chip .who{font-family:'Orbitron',sans-serif; font-weight:900; font-size:1.35rem; color:var(--vc); letter-spacing:2px;}
.gb-vs-chip .nm{font-size:0.8rem; color:#c6c1da;}
.gb-vs-pct{font-family:'Orbitron',sans-serif; font-weight:700; font-size:1.05rem; color:#fff;}
.gb-vs-axes{display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-bottom:12px;}
.gb-vs-ax{font-family:'Jura',sans-serif; font-size:0.74rem; font-weight:700; border-radius:16px; padding:5px 11px; border:1px solid;}
.gb-vs-ax.same{color:#4ecb71; border-color:rgba(78,203,113,0.5); background:rgba(78,203,113,0.07);}
.gb-vs-ax.diff{color:#ff4655; border-color:rgba(255,70,85,0.5); background:rgba(255,70,85,0.07);}
.gb-vs-verdict{color:#e8e2f2; font-size:1rem; line-height:1.55; max-width:560px; margin:0 auto 8px;}
.gb-vs-note{color:#565170; font-size:0.72rem;}

/* ---- действия (в шапке; видны только на экране результата) ---- */
.gb-actions{display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin:18px auto 2px; padding-top:16px; border-top:1px solid rgba(255,255,255,0.08);}
.gb-actions .gb-btn{padding:11px 20px; font-size:0.85rem;}

/* ---- «научная» статья ---- */
.gb-article{
  background:var(--panel); border:1px solid var(--line); border-radius:16px;
  padding:30px 34px; line-height:1.7; font-size:0.98rem; color:#d5d1e6; margin-bottom:30px;
}
.gb-article h2{
  font-family:'Orbitron',sans-serif; font-size:1.05rem; letter-spacing:1.5px; color:var(--cyan);
  margin:26px 0 12px; border-bottom:1px solid rgba(0,240,255,0.2); padding-bottom:8px;
}
.gb-article h2:first-child{margin-top:0;}
.gb-article p{margin-bottom:12px;}
.gb-article em{color:var(--neon); font-style:normal; font-weight:600;}
.gb-article ul{margin:0 0 12px 20px;}
.gb-article li{margin-bottom:7px;}
.gb-func-row{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:12px;}
.gb-func{
  border:1px solid rgba(168,85,247,0.4); border-radius:10px; padding:8px 14px;
  background:rgba(168,85,247,0.07); font-size:0.85rem;
}
.gb-func b{font-family:'Orbitron',sans-serif; color:var(--neon); margin-right:6px;}
.gb-func .role{display:block; font-size:0.7rem; color:#7d7896; letter-spacing:1px; text-transform:uppercase;}

/* ---- матрица совместимости (в статье) ---- */
.gb-compat{display:grid; grid-template-columns:repeat(5,1fr); gap:8px; margin:4px 0 12px;}
.gb-ccell{
  border:1px solid rgba(255,255,255,0.12); border-radius:10px; padding:9px 4px 7px;
  text-align:center; background:rgba(255,255,255,0.03); --tc:#a855f7;
}
.gb-ccell .c{font-family:'Orbitron',sans-serif; font-weight:900; letter-spacing:1px; color:var(--tc); font-size:0.82rem;}
.gb-ccell .p{font-size:1.02rem; font-weight:700; margin-top:2px;}
.gb-ccell.good .p{color:#4ecb71;} .gb-ccell.mid .p{color:#e6be5a;} .gb-ccell.bad .p{color:#ff4655;}
.gb-ccell .t{font-size:0.62rem; color:#7d7896; text-transform:uppercase; letter-spacing:1px; margin-top:1px;}
@media (max-width:640px){ .gb-compat{grid-template-columns:repeat(3,1fr);} }

/* ---- сетка всех 16 типов ---- */
.gb-alltypes-title{font-family:'Orbitron',sans-serif; text-align:center; letter-spacing:2px; color:var(--mut); font-size:0.9rem; margin-bottom:14px;}
.gb-alltypes{display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:26px;}
.gb-tcell{
  border:1px solid rgba(255,255,255,0.1); border-radius:12px; padding:12px 8px; text-align:center;
  cursor:pointer; transition:.15s; background:rgba(255,255,255,0.03);
  --tc:#a855f7; --tcGlow:rgba(168,85,247,0.4); --tcBg:rgba(168,85,247,0.12);
}
.gb-tcell:hover{transform:translateY(-2px); border-color:var(--tc); box-shadow:0 0 14px var(--tcGlow);}
.gb-tcell.me{border-color:var(--tc); background:var(--tcBg);}
.gb-tcell .cd{font-family:'Orbitron',sans-serif; font-weight:900; letter-spacing:2px; color:var(--tc); font-size:1.05rem;}
.gb-tcell .nm{font-size:0.68rem; color:#9a95b0; margin-top:4px; line-height:1.25;}
@media (max-width:640px){ .gb-alltypes{grid-template-columns:repeat(2,1fr);} .gb-article{padding:22px 16px;} }

.gb-seo{max-width:760px; margin:10px auto 0; padding:0 16px; color:#565170; font-size:0.78rem; line-height:1.6; text-align:center;}
