/* ============================================================
   Quillstone Index — стиль
   Концепция: технический индекс с цветовым кодом семейств.
   LLM = янтарь, Изображения = фиалка, Видео = бирюза.
   ============================================================ */

:root{
  --ink:#0c0e13;
  --ink-2:#11141b;
  --surface:#161a23;
  --surface-2:#1b2029;
  --line:rgba(255,255,255,.09);
  --line-2:rgba(255,255,255,.14);
  --text:#e9ebf2;
  --text-2:#a4abbd;
  --text-3:#6d7589;

  --llm:#f5b13d;     --llm-soft:rgba(245,177,61,.12);
  --img:#bd7bff;     --img-soft:rgba(189,123,255,.13);
  --vid:#34dfc9;     --vid-soft:rgba(52,223,201,.12);

  --accent:#e9ebf2;  /* нейтральный, перекрывается фильтром */

  --max:1180px;
  --r:16px;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --disp:'Space Grotesk',-apple-system,BlinkMacSystemFont,sans-serif;
  --body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:var(--body);
  color:var(--text);
  background:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
  /* мягкое сияние сверху — намёк на «спектр» семейств */
  background-image:
    radial-gradient(60% 50% at 18% -10%, rgba(245,177,61,.07), transparent 60%),
    radial-gradient(55% 45% at 55% -12%, rgba(189,123,255,.07), transparent 60%),
    radial-gradient(55% 45% at 88% -10%, rgba(52,223,201,.07), transparent 60%);
  background-repeat:no-repeat;
}

a{color:inherit}
.skip{position:absolute;left:-9999px;top:0;background:var(--text);color:var(--ink);padding:10px 16px;border-radius:8px;z-index:50}
.skip:focus{left:16px;top:16px}
:focus-visible{outline:2px solid var(--vid);outline-offset:3px;border-radius:4px}

/* ---------- бренд-марка: три полоски-семейства ---------- */
.brand-mark{display:inline-flex;gap:3px;align-items:flex-end;height:18px}
.brand-mark .m{width:4px;border-radius:2px;display:block}
.m-llm{height:10px;background:var(--llm)}
.m-img{height:15px;background:var(--img)}
.m-vid{height:18px;background:var(--vid)}

/* ---------- шапка ---------- */
.site-head{
  max-width:var(--max);margin:0 auto;
  padding:22px clamp(20px,4vw,40px);
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.brand{display:inline-flex;align-items:center;gap:11px;text-decoration:none}
.brand-name{font-family:var(--disp);font-weight:600;font-size:17px;letter-spacing:-.01em}
.site-nav{display:flex;gap:6px;flex-wrap:wrap}
.site-nav a{
  text-decoration:none;color:var(--text-2);font-size:14px;font-weight:500;
  padding:8px 14px;border-radius:100px;transition:color .2s,background .2s;
}
.site-nav a:hover{color:var(--text);background:rgba(255,255,255,.05)}
.site-nav a.on{color:var(--ink);background:var(--text)}

/* ---------- общий контейнер ---------- */
main{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,4vw,40px)}

.eyebrow{
  font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;color:var(--text-3);
}

/* ---------- hero ---------- */
.hero{padding:clamp(40px,7vw,84px) 0 clamp(36px,5vw,56px);max-width:880px}
.hero .eyebrow{margin-bottom:22px}
.hero-title{
  font-family:var(--disp);font-weight:700;
  font-size:clamp(40px,7.5vw,76px);line-height:1.02;letter-spacing:-.035em;
}
.hero-lede{
  margin-top:26px;max-width:620px;font-size:clamp(16px,2vw,19px);
  color:var(--text-2);line-height:1.65;
}

.legend{display:flex;gap:10px;flex-wrap:wrap;margin-top:34px}
.leg{
  font:inherit;cursor:pointer;border:1px solid var(--line);background:transparent;
  color:var(--text-2);padding:9px 15px 9px 13px;border-radius:100px;
  display:inline-flex;align-items:center;gap:9px;font-size:14px;
  transition:border-color .2s,color .2s,background .2s;
}
.leg b{font-family:var(--mono);font-weight:500;color:var(--text)}
.leg-dot{width:9px;height:9px;border-radius:50%}
.leg-llm   .leg-dot{background:var(--llm)}
.leg-image .leg-dot{background:var(--img)}
.leg-video .leg-dot{background:var(--vid)}
.leg:hover{color:var(--text);border-color:var(--line-2)}
.leg-llm:hover{background:var(--llm-soft)}
.leg-image:hover{background:var(--img-soft)}
.leg-video:hover{background:var(--vid-soft)}

/* ---------- фильтр ---------- */
.catalog{padding-bottom:clamp(48px,7vw,84px)}
.filterbar{
  display:flex;gap:8px;flex-wrap:wrap;
  padding-bottom:24px;margin-bottom:6px;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:10;
  background:linear-gradient(var(--ink),var(--ink) 70%,transparent);
  padding-top:14px;
}
.chip{
  font:inherit;font-size:14px;font-weight:500;cursor:pointer;
  border:1px solid var(--line);background:transparent;color:var(--text-2);
  padding:9px 18px;border-radius:100px;transition:all .2s;
}
.chip:hover{color:var(--text);border-color:var(--line-2)}
.chip.on{background:var(--text);color:var(--ink);border-color:var(--text)}

/* ---------- сетка карточек ---------- */
.grid{
  margin-top:26px;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:18px;
}

.card{
  position:relative;overflow:hidden;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:24px 24px 20px;
  display:flex;flex-direction:column;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .35s,box-shadow .35s;
}
/* цветной «корешок» слева кодирует семейство */
.card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--cat);
}
.card.type-llm  {--cat:var(--llm);--cat-soft:var(--llm-soft)}
.card.type-image{--cat:var(--img);--cat-soft:var(--img-soft)}
.card.type-video{--cat:var(--vid);--cat-soft:var(--vid-soft)}
.card:hover{
  transform:translateY(-4px);
  border-color:color-mix(in srgb,var(--cat) 45%,var(--line));
  box-shadow:0 18px 40px -22px rgba(0,0,0,.8), 0 0 0 1px var(--cat-soft);
}

.card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.idx{font-family:var(--mono);font-size:13px;color:var(--text-3);letter-spacing:.05em}
.tag{
  font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.04em;
  padding:4px 10px;border-radius:100px;
}
.tag-llm  {color:var(--llm);background:var(--llm-soft)}
.tag-image{color:var(--img);background:var(--img-soft)}
.tag-video{color:var(--vid);background:var(--vid-soft)}

.card-name{font-family:var(--disp);font-weight:600;font-size:21px;letter-spacing:-.02em;line-height:1.15}
.card-vendor{font-size:13px;color:var(--text-2);margin-top:3px}
.card-spec{font-family:var(--mono);font-size:12px;color:var(--text-3);margin-top:10px}

.card-tagline{margin-top:16px;font-size:15px;font-weight:500;color:var(--text);line-height:1.45}
.card-why{margin-top:9px;font-size:13.5px;color:var(--text-2);line-height:1.6}

.card-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
.col-h{font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px}
.col-pro{color:var(--vid)}
.col-con{color:var(--text-3)}
.col ul{list-style:none}
.col li{
  font-size:12.5px;color:var(--text-2);line-height:1.45;
  padding-left:13px;position:relative;margin-bottom:6px;
}
.col li::before{content:"";position:absolute;left:0;top:8px;width:4px;height:4px;border-radius:50%;background:var(--text-3)}
.col-pro + ul li::before,
.col .col-pro::before{background:var(--vid)}
.card-cols .col:first-child li::before{background:color-mix(in srgb,var(--vid) 70%,transparent)}

.card-foot{
  margin-top:auto;padding-top:18px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  border-top:1px solid var(--line);margin-top:20px;
}
.access{font-family:var(--mono);font-size:11.5px;color:var(--text-3);letter-spacing:.02em}
.visit{
  text-decoration:none;font-size:14px;font-weight:600;color:var(--cat);
  padding:7px 14px;border-radius:100px;background:var(--cat-soft);
  transition:transform .2s,filter .2s;white-space:nowrap;
}
.visit:hover{filter:brightness(1.12);transform:translateX(2px)}

.empty{text-align:center;color:var(--text-3);padding:50px 0;font-size:15px}

/* фильтрация */
.card.hide{display:none}

/* ---------- внутренние страницы ---------- */
.page{max-width:720px;padding:clamp(36px,6vw,72px) 0 clamp(48px,7vw,90px)}
.page .eyebrow{margin-bottom:18px}
.page-title{font-family:var(--disp);font-weight:700;font-size:clamp(30px,5vw,48px);letter-spacing:-.03em;line-height:1.08}
.page-meta{font-family:var(--mono);font-size:12px;color:var(--text-3);margin-top:14px}

.prose{margin-top:30px}
.prose p{color:var(--text-2);font-size:16px;line-height:1.7;margin-bottom:18px}
.prose h2{
  font-family:var(--disp);font-weight:600;font-size:21px;letter-spacing:-.01em;
  color:var(--text);margin:34px 0 12px;
}
.prose ul{margin:0 0 18px;padding-left:0;list-style:none}
.prose li{
  color:var(--text-2);font-size:15.5px;line-height:1.6;
  padding-left:20px;position:relative;margin-bottom:10px;
}
.prose li::before{content:"";position:absolute;left:2px;top:11px;width:6px;height:6px;border-radius:50%;background:var(--img)}
.prose b{color:var(--text);font-weight:600}
.prose a{color:var(--vid);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--vid) 40%,transparent)}
.prose a:hover{border-bottom-color:var(--vid)}
.prose .muted{font-size:13.5px;color:var(--text-3);font-style:italic;margin-top:8px}

/* контакты */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:32px 0 8px}
.contact-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px}
.cc-h{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-bottom:8px}
.cc-v{font-size:15px;color:var(--text)}
.cc-v a{color:var(--vid);text-decoration:none}

/* ---------- футер ---------- */
.site-foot{border-top:1px solid var(--line);margin-top:40px}
.foot-grid{
  max-width:var(--max);margin:0 auto;
  padding:48px clamp(20px,4vw,40px) 32px;
  display:grid;grid-template-columns:1.4fr 1fr 1.4fr;gap:32px;
}
.foot-title{font-family:var(--disp);font-weight:600;font-size:16px;margin-top:12px}
.foot-tag{font-size:13.5px;color:var(--text-3);margin-top:6px;max-width:260px}
.foot-h{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-bottom:14px}
.foot-col a{display:block;text-decoration:none;color:var(--text-2);font-size:14px;margin-bottom:9px;transition:color .2s}
.foot-col a:hover{color:var(--text)}
.foot-col p{font-size:13.5px;color:var(--text-2);margin-bottom:7px;line-height:1.5}
.foot-col p a{color:var(--vid);text-decoration:none}
.foot-base{
  max-width:var(--max);margin:0 auto;
  padding:20px clamp(20px,4vw,40px);
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  font-family:var(--mono);font-size:12px;color:var(--text-3);
}

/* ---------- адаптив ---------- */
@media(max-width:720px){
  .site-head{flex-direction:column;align-items:flex-start;gap:14px}
  .card-cols{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:28px}
  .grid{grid-template-columns:1fr}
}

/* появление карточек */
@media (prefers-reduced-motion:no-preference){
  .card{opacity:0;transform:translateY(14px)}
  .card.in{opacity:1;transform:none}
}

/* ============================================================
   Team + consultation (homepage additions)
   ============================================================ */
.section-title{
  font-family:var(--disp);font-weight:700;font-size:clamp(26px,4vw,38px);
  letter-spacing:-.025em;line-height:1.1;margin-top:14px;
}

/* team */
.team{padding:clamp(40px,6vw,72px) 0 clamp(36px,5vw,56px);border-top:1px solid var(--line)}
.team-grid{
  margin-top:30px;display:grid;gap:18px;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
}
.member{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:22px;display:flex;align-items:center;gap:16px;
  transition:border-color .3s,transform .3s cubic-bezier(.2,.8,.2,1);
}
.member:hover{transform:translateY(-3px);border-color:var(--line-2)}
.avatar{
  width:62px;height:62px;border-radius:50%;object-fit:cover;flex:none;
  border:2px solid var(--surface-2);
  box-shadow:0 0 0 1px var(--line), 0 6px 16px -8px rgba(0,0,0,.7);
  background:var(--surface-2);
}
.member figcaption{display:flex;flex-direction:column;gap:3px;min-width:0}
.member-name{font-family:var(--disp);font-weight:600;font-size:16px;letter-spacing:-.01em}
.member-role{font-family:var(--mono);font-size:11.5px;color:var(--text-3);letter-spacing:.02em}

/* consultation CTA */
.consult{padding:0 0 clamp(48px,7vw,80px)}
.consult-inner{
  position:relative;overflow:hidden;border-radius:24px;
  border:1px solid var(--line-2);
  background:
    radial-gradient(80% 120% at 0% 0%, var(--llm-soft), transparent 55%),
    radial-gradient(80% 120% at 50% 0%, var(--img-soft), transparent 55%),
    radial-gradient(90% 130% at 100% 0%, var(--vid-soft), transparent 55%),
    var(--ink-2);
  padding:clamp(28px,4vw,46px);
  display:grid;grid-template-columns:1.25fr 1fr;gap:34px;align-items:center;
}
.eyebrow-dark{color:var(--vid)}
.consult-title{
  font-family:var(--disp);font-weight:700;font-size:clamp(24px,3.4vw,34px);
  letter-spacing:-.025em;line-height:1.12;margin-top:14px;
}
.consult-lede{margin-top:14px;color:var(--text-2);font-size:16px;line-height:1.6;max-width:440px}
.consult-phone{margin-top:18px;font-family:var(--mono);font-size:14px;color:var(--text-2)}
.consult-phone a{color:var(--text);text-decoration:none;border-bottom:1px solid var(--line-2)}
.consult-phone a:hover{border-bottom-color:var(--vid)}

.consult-form{
  background:rgba(12,14,19,.55);border:1px solid var(--line);
  border-radius:var(--r);padding:22px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.field{display:block}
.field-label{
  display:block;font-family:var(--mono);font-size:11px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--text-3);margin-bottom:8px;
}
.consult-form input[type=tel]{
  width:100%;font:inherit;font-size:16px;color:var(--text);
  background:var(--surface);border:1px solid var(--line-2);border-radius:11px;
  padding:13px 15px;transition:border-color .2s,box-shadow .2s;
}
.consult-form input::placeholder{color:var(--text-3)}
.consult-form input:focus{outline:none;border-color:var(--vid);box-shadow:0 0 0 3px var(--vid-soft)}
.submit{
  width:100%;margin-top:14px;font:inherit;font-size:15px;font-weight:600;cursor:pointer;
  color:var(--ink);background:var(--vid);border:none;border-radius:11px;padding:14px;
  transition:filter .2s,transform .2s;
}
.submit:hover{filter:brightness(1.06)}
.submit:active{transform:scale(.99)}
.form-note{margin-top:12px;font-size:13px;color:var(--vid);min-height:18px;line-height:1.4}
.form-note.err{color:#ff7a7a}

@media(max-width:720px){
  .consult-inner{grid-template-columns:1fr;gap:24px}
  .member{flex-direction:column;text-align:center}
}

@media (prefers-reduced-motion:no-preference){
  .member{opacity:0;transform:translateY(12px)}
  .member.in{opacity:1;transform:none;transition:opacity .5s ease,transform .5s cubic-bezier(.2,.8,.2,1)}
}

/* expanded consultation copy */
.consult-inner{align-items:start}
.consult-body{margin-top:14px;color:var(--text-2);font-size:15px;line-height:1.65;max-width:520px}
.consult-who-h{
  margin-top:22px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--text-3);
}
.consult-who{list-style:none;margin:12px 0 0;padding:0;max-width:520px}
.consult-who li{
  position:relative;padding-left:18px;margin-bottom:9px;
  font-size:14.5px;color:var(--text-2);line-height:1.5;
}
.consult-who li::before{
  content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;
  background:var(--vid);
}
.consult-who b{color:var(--text);font-weight:600}
@media(min-width:721px){
  .consult-form{position:sticky;top:24px}
}

/* standalone mission / strategy section */
.mission{padding:clamp(40px,6vw,72px) 0 clamp(8px,2vw,20px)}
.mission-body{
  margin-top:26px;
  display:grid;grid-template-columns:1fr 1fr;gap:28px;
  max-width:920px;
}
.mission-body p{color:var(--text-2);font-size:15.5px;line-height:1.7}
.mission-who-h{
  margin-top:34px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--text-3);
}
.mission-who{
  list-style:none;margin:16px 0 0;padding:0;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px 28px;
  max-width:920px;
}
.mission-who li{
  position:relative;padding-left:18px;
  font-size:14.5px;color:var(--text-2);line-height:1.55;
}
.mission-who li::before{
  content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:var(--vid);
}
.mission-who b{color:var(--text);font-weight:600}
@media(max-width:720px){.mission-body{grid-template-columns:1fr;gap:16px}}
