/* ================================================================
   PrivEsc Service — style.css
   Тёмная тема в духе ledokol, тон под банковский B2B.
   Без зависимостей. Один файл.
   ================================================================ */

/* ----- Шрифты (self-hosted, скопированы из ledokol) ------------- */
@font-face{
  font-family:"Rubik"; font-style:normal; font-weight:300 700; font-display:swap;
  src:url("/static/fonts/rubik-cyrillic.woff2") format("woff2");
  unicode-range:U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face{
  font-family:"Rubik"; font-style:normal; font-weight:300 700; font-display:swap;
  src:url("/static/fonts/rubik-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face{
  font-family:"Playfair Display"; font-style:normal; font-weight:700; font-display:swap;
  src:url("/static/fonts/playfair-display-cyrillic-700.woff2") format("woff2");
  unicode-range:U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face{
  font-family:"Playfair Display"; font-style:normal; font-weight:700; font-display:swap;
  src:url("/static/fonts/playfair-display-latin-700.woff2") format("woff2");
  unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ----- Токены дизайна -------------------------------------------- */
:root{
  /* Палитра — глубокая ночь с прохладным синим акцентом и мягким золотом для CTA */
  --bg:#0a0e14;
  --panel:#11161f;
  --panel-2:#161c27;
  --panel-3:#1c2333;
  --text:#e9eef7;
  --text-soft:#c2cfde;
  --muted:#8d9cb2;

  --accent:#6da6ff;        /* steel blue — спокойный, не неон */
  --accent-2:#8fc1ff;
  --accent-soft:rgba(109,166,255,.18);
  --accent-glow:rgba(109,166,255,.30);
  --gold:#d4ad60;          /* приглушённое золото — premium CTA */
  --gold-soft:rgba(212,173,96,.20);

  --border:rgba(140,168,210,.12);
  --border-strong:rgba(140,168,210,.28);

  --shadow-soft:0 18px 48px rgba(0,0,0,.45);
  --shadow-pop:0 28px 72px rgba(0,0,0,.55);
  --shadow-glow:0 0 60px rgba(109,166,255,.18);

  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:22px;
  --radius-pill:999px;

  --max-width:1200px;
  --gutter:clamp(20px, 5vw, 40px);
  --topbar-h:68px;

  --s-1:.5rem;
  --s-2:1rem;
  --s-3:1.5rem;
  --s-4:2rem;
  --s-5:3rem;
  --s-6:4rem;
  --s-7:5.5rem;

  --font-sans:"Rubik", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-display:"Playfair Display", "Rubik", Georgia, serif;
  --font-mono:ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;

  --gradient-soft:linear-gradient(140deg, #0e131c 0%, #0a0e14 60%, #0c121b 100%);
  --gradient-accent:linear-gradient(135deg, rgba(109,166,255,.95), rgba(143,193,255,.6));
  --gradient-gold:linear-gradient(135deg, #e6c378 0%, #c79a4d 100%);
}

/* ----- База ------------------------------------------------------ */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--font-sans);
  font-size:16px; line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  background-image:
    radial-gradient(900px 500px at 8% -10%, rgba(109,166,255,.10), transparent 60%),
    radial-gradient(700px 420px at 100% 8%, rgba(212,173,96,.06), transparent 55%);
  background-attachment:fixed;
}
.drawer-open{ overflow:hidden; }

a{ color:var(--accent); text-decoration:none; }
a:hover{ color:var(--accent-2); }

img, svg{ max-width:100%; display:block; }

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

h1, h2, h3, h4{ margin:0 0 var(--s-2); line-height:1.15; letter-spacing:-.01em; color:var(--text); }
h1{ font-family:var(--font-display); font-weight:700; font-size:clamp(2.2rem, 4.4vw, 3.6rem); letter-spacing:-.02em; }
h2{ font-family:var(--font-display); font-weight:700; font-size:clamp(1.6rem, 3vw, 2.4rem); letter-spacing:-.015em; }
h3{ font-weight:600; font-size:clamp(1.1rem, 1.8vw, 1.25rem); }
h4{ font-weight:600; font-size:1rem; }

p{ margin:0 0 var(--s-2); color:var(--text-soft); }
.lead{ font-size:clamp(1.05rem, 1.5vw, 1.18rem); color:var(--text-soft); max-width:68ch; }
.muted{ color:var(--muted); }

ul, ol{ margin:0 0 var(--s-2); padding-left:1.2rem; color:var(--text-soft); }
li + li{ margin-top:.35rem; }

hr.divider{
  border:0; height:1px; margin:var(--s-4) 0;
  background:linear-gradient(90deg, transparent, var(--border-strong), transparent);
}

::selection{ background:var(--accent-soft); color:#fff; }

/* ----- Топбар ---------------------------------------------------- */
.topbar{
  position:sticky; top:0; z-index:80;
  border-bottom:1px solid transparent;
  transition:transform .3s ease, background-color .25s ease, border-color .25s ease, backdrop-filter .25s ease;
  background:rgba(10,14,20,0);
}
.topbar--scrolled{
  background:rgba(10,14,20,.78);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom-color:var(--border);
}
.topbar--hide{ transform:translateY(calc(-100% - 4px)); }

.nav{
  display:flex; align-items:center; gap:var(--s-3);
  height:var(--topbar-h);
}
.brand{
  display:inline-flex; align-items:center; gap:.6rem;
  text-decoration:none; color:var(--text);
  font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  font-size:.95rem;
}
.brand em{ font-style:normal; color:var(--accent); font-weight:500; }
.brand__mark{
  width:34px; height:34px; display:grid; place-items:center;
  border-radius:10px; color:var(--accent);
  background:linear-gradient(135deg, rgba(109,166,255,.16), rgba(109,166,255,.04));
  border:1px solid var(--border);
}

.nav__inline{ display:flex; gap:.25rem; align-items:center; margin-left:auto; }
.nav__inline a{
  padding:.55rem .85rem; border-radius:10px;
  color:var(--text-soft); font-size:.92rem; letter-spacing:.04em;
  transition:background .2s, color .2s;
}
.nav__inline a:hover{ background:rgba(255,255,255,.04); color:var(--text); }
.nav__inline .cta{
  margin-left:.5rem;
  background:var(--gradient-accent); color:#0a0e14; font-weight:600;
  border-radius:var(--radius-pill); padding:.55rem 1.1rem;
  box-shadow:0 8px 24px rgba(109,166,255,.25);
}
.nav__inline .cta:hover{ filter:brightness(1.06); color:#0a0e14; }

.nav__toggle{ position:absolute; left:-9999px; }
.nav__btn{
  display:none; width:42px; height:42px; cursor:pointer;
  border:1px solid var(--border-strong); border-radius:12px;
  align-items:center; justify-content:center;
  background:rgba(255,255,255,.02);
  margin-left:auto;
}
.nav__btn span{
  display:block; width:18px; height:2px; background:var(--text); border-radius:2px;
  transition:transform .25s, opacity .2s;
}
.nav__btn span + span{ margin-top:4px; }

.scrim{
  position:fixed; inset:0; z-index:90;
  background:rgba(6,9,14,.55); backdrop-filter:blur(8px);
  opacity:0; pointer-events:none; transition:opacity .25s;
}
.drawer{
  position:fixed; top:0; right:0; height:100dvh; width:min(86vw, 380px);
  z-index:95; padding:calc(var(--topbar-h) + var(--s-3)) var(--s-3) var(--s-3);
  background:linear-gradient(160deg, #0c1220 0%, #0a0e14 100%);
  border-left:1px solid var(--border-strong);
  transform:translateX(102%); transition:transform .28s ease;
  display:flex; flex-direction:column; gap:.4rem;
}
.drawer nav{ display:flex; flex-direction:column; gap:.25rem; }
.drawer a{
  display:block; padding:.95rem 1rem; border-radius:12px; color:var(--text-soft);
  border:1px solid transparent;
}
.drawer a:hover{ background:rgba(255,255,255,.04); color:var(--text); border-color:var(--border); }
.drawer .cta{
  margin-top:var(--s-2); background:var(--gradient-accent); color:#0a0e14;
  text-align:center; font-weight:600; border:0;
}

.nav__toggle:checked ~ .nav__btn span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
.nav__toggle:checked ~ .nav__btn span:nth-child(2){ opacity:0; }
.nav__toggle:checked ~ .nav__btn span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }
.nav__toggle:checked ~ .drawer{ transform:translateX(0); }
.nav__toggle:checked ~ .scrim{ opacity:1; pointer-events:auto; }

@media (max-width:1024px){
  .nav__inline{ display:none; }
  .nav__btn{ display:inline-flex; }
}

/* ----- Кнопки ---------------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.85rem 1.35rem;
  background:var(--gradient-accent); color:#0a0e14;
  border:0; border-radius:var(--radius-pill); cursor:pointer;
  font-family:inherit; font-weight:600; font-size:.95rem; letter-spacing:.02em;
  text-decoration:none;
  transition:transform .15s ease, filter .15s ease, box-shadow .2s ease;
  box-shadow:0 12px 28px rgba(109,166,255,.22);
}
.btn:hover{ transform:translateY(-1px); filter:brightness(1.05); color:#0a0e14; }
.btn:active{ transform:none; }

.btn--ghost{
  background:transparent; color:var(--text);
  border:1px solid var(--border-strong);
  box-shadow:none;
}
.btn--ghost:hover{ background:rgba(109,166,255,.06); border-color:var(--accent); color:var(--text); }

.btn--gold{
  background:var(--gradient-gold); color:#0e1116;
  box-shadow:0 12px 28px rgba(212,173,96,.22);
}
.btn--gold:hover{ color:#0e1116; }

/* ----- Hero ------------------------------------------------------ */
.hero{
  position:relative;
  padding:calc(var(--topbar-h) + var(--s-6)) 0 var(--s-7);
  overflow:hidden;
  isolation:isolate;
}
.hero::before{
  content:""; position:absolute; inset:-10%;
  background:
    radial-gradient(900px 600px at 22% 18%, rgba(109,166,255,.16), transparent 55%),
    radial-gradient(720px 500px at 84% 30%, rgba(212,173,96,.08), transparent 55%),
    radial-gradient(1100px 700px at 50% 110%, rgba(109,166,255,.10), transparent 55%);
  z-index:-1;
}
.hero::after{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:-1;
  background-image:
    linear-gradient(transparent 95%, rgba(140,168,210,.06) 95%),
    linear-gradient(90deg, transparent 95%, rgba(140,168,210,.06) 95%);
  background-size:48px 48px;
  mask-image:radial-gradient(900px 600px at 50% 0%, #000 0%, transparent 70%);
}

.hero__kicker{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.4rem .85rem; border-radius:var(--radius-pill);
  background:rgba(109,166,255,.08); border:1px solid var(--border-strong);
  color:var(--accent-2); font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  font-weight:500;
  margin-bottom:var(--s-3);
}
.hero__kicker::before{
  content:""; width:6px; height:6px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 4px rgba(109,166,255,.18);
}
.hero h1{ max-width:22ch; }
.hero h1 em{ font-style:italic; color:var(--accent); font-family:var(--font-display); }
.hero .lead{ margin-top:var(--s-3); max-width:62ch; font-size:clamp(1.1rem, 1.6vw, 1.25rem); }
.hero__cta{
  display:flex; flex-wrap:wrap; gap:.9rem;
  margin-top:var(--s-4);
}

.hero__kpis{
  display:grid; gap:var(--s-2);
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  margin-top:var(--s-5);
}
.hero__kpi{
  padding:var(--s-3);
  background:linear-gradient(140deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  backdrop-filter:blur(8px);
}
.hero__kpi b{
  display:block; font-family:var(--font-display); font-size:1.6rem; color:var(--text);
  margin-bottom:.2rem;
}
.hero__kpi span{ color:var(--muted); font-size:.92rem; }

/* ----- Секции ---------------------------------------------------- */
.section{ padding:var(--s-7) 0; position:relative; }
.section--tight{ padding:var(--s-6) 0; }
.section__head{ max-width:64ch; margin-bottom:var(--s-5); }
.section__kicker{
  display:inline-block; font-size:.78rem; font-weight:500;
  letter-spacing:.22em; text-transform:uppercase; color:var(--accent);
  margin-bottom:var(--s-2);
}
.section__title{ margin-bottom:var(--s-2); }
.section__lead{ color:var(--text-soft); }

/* ----- Сетка услуг (8 шт.) -------------------------------------- */
.services{
  display:grid; gap:var(--s-3);
  grid-template-columns:repeat(12, 1fr);
}
.service-card{
  position:relative;
  grid-column:span 6;
  display:flex; flex-direction:column;
  padding:var(--s-4);
  background:linear-gradient(160deg, rgba(255,255,255,.035) 0%, rgba(255,255,255,.01) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  text-decoration:none; color:inherit;
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease, background .25s ease;
  overflow:hidden;
  isolation:isolate;
}
.service-card::before{
  content:""; position:absolute; inset:0; z-index:-1; opacity:0;
  background:radial-gradient(420px 280px at var(--mx, 50%) var(--my, 0%), rgba(109,166,255,.10), transparent 60%);
  transition:opacity .25s ease;
}
.service-card:hover{
  transform:translateY(-3px);
  border-color:var(--border-strong);
  box-shadow:var(--shadow-pop);
  background:linear-gradient(160deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.015) 100%);
}
.service-card:hover::before{ opacity:1; }

.service-card__head{
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:var(--s-2); margin-bottom:var(--s-2);
}
.service-card__num{
  font-family:var(--font-mono); font-size:.85rem; letter-spacing:.18em;
  color:var(--accent); padding:.25rem .55rem; border:1px solid var(--border-strong);
  border-radius:var(--radius-sm); background:rgba(109,166,255,.06);
}
.service-card__icon{
  width:44px; height:44px; flex:0 0 44px;
  border-radius:var(--radius-md);
  background:linear-gradient(135deg, rgba(109,166,255,.18), rgba(109,166,255,.04));
  border:1px solid var(--border-strong);
  display:grid; place-items:center; color:var(--accent);
}
.service-card h3{
  font-family:var(--font-display); font-weight:700; font-size:1.4rem;
  letter-spacing:-.01em; color:var(--text);
  margin-bottom:var(--s-2);
}
.service-card p{ color:var(--text-soft); font-size:.97rem; }
.service-card__tags{
  margin-top:auto; padding-top:var(--s-3);
  display:flex; flex-wrap:wrap; gap:.35rem;
  font-family:var(--font-mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted);
}
.service-card__tags span{
  padding:.2rem .55rem; border:1px solid var(--border); border-radius:var(--radius-pill);
  background:rgba(255,255,255,.02);
}
.service-card__more{
  display:inline-flex; align-items:center; gap:.4rem;
  margin-top:var(--s-3); color:var(--accent);
  font-size:.92rem; font-weight:500;
}
.service-card__more::after{
  content:"→"; transition:transform .2s;
}
.service-card:hover .service-card__more::after{ transform:translateX(3px); }

@media (max-width:900px){
  .service-card{ grid-column:span 12; }
}

/* ----- Подход / методология -------------------------------------- */
.steps{
  display:grid; gap:var(--s-3);
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  counter-reset:step;
}
.step{
  position:relative; padding:var(--s-3);
  background:linear-gradient(160deg, rgba(255,255,255,.035), rgba(255,255,255,.01));
  border:1px solid var(--border); border-radius:var(--radius-md);
}
.step::before{
  counter-increment:step;
  content:counter(step, decimal-leading-zero);
  position:absolute; top:var(--s-2); right:var(--s-3);
  font-family:var(--font-mono); font-size:.85rem; letter-spacing:.18em;
  color:var(--accent); opacity:.7;
}
.step h4{ font-family:var(--font-display); font-size:1.15rem; margin-bottom:.4rem; padding-right:3rem; }
.step p{ font-size:.95rem; margin:0; }

/* ----- Отрасли --------------------------------------------------- */
.industries{
  display:grid; gap:var(--s-2);
  grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));
}
.industry{
  padding:var(--s-3) var(--s-3);
  border:1px solid var(--border); border-radius:var(--radius-md);
  background:rgba(255,255,255,.02);
  display:flex; align-items:center; gap:.7rem;
  font-size:.95rem; color:var(--text-soft);
}
.industry__dot{
  width:10px; height:10px; border-radius:50%; flex:0 0 10px;
  background:var(--accent); box-shadow:0 0 0 4px rgba(109,166,255,.18);
}

/* ----- Регуляторика --------------------------------------------- */
.compliance{
  display:flex; flex-wrap:wrap; gap:.6rem;
  margin-top:var(--s-3);
}
.chip{
  padding:.5rem 1rem; border-radius:var(--radius-pill);
  background:rgba(212,173,96,.06); border:1px solid rgba(212,173,96,.32);
  color:#e6c378; font-size:.85rem; letter-spacing:.04em;
  font-family:var(--font-mono); text-transform:uppercase;
}
.chip--blue{
  background:rgba(109,166,255,.06); border-color:rgba(109,166,255,.32); color:var(--accent-2);
}

/* ----- CTA-полоса ----------------------------------------------- */
.cta-strip{
  position:relative; overflow:hidden; isolation:isolate;
  margin:var(--s-6) auto;
  padding:var(--s-5) var(--s-4);
  background:
    radial-gradient(800px 320px at 80% 20%, rgba(212,173,96,.10), transparent 60%),
    radial-gradient(700px 360px at 10% 80%, rgba(109,166,255,.20), transparent 60%),
    linear-gradient(140deg, #11171f 0%, #0d1219 100%);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-lg);
  display:grid; gap:var(--s-3); grid-template-columns:1.4fr auto;
  align-items:center;
  box-shadow:var(--shadow-soft);
}
.cta-strip h2{ margin:0 0 .3rem; font-size:clamp(1.4rem, 2.4vw, 2rem); }
.cta-strip p{ margin:0; color:var(--text-soft); }
.cta-strip__actions{ display:flex; flex-wrap:wrap; gap:.7rem; }
@media (max-width:760px){
  .cta-strip{ grid-template-columns:1fr; }
}

/* ----- Service detail page -------------------------------------- */
.detail-hero{
  position:relative; padding:calc(var(--topbar-h) + var(--s-5)) 0 var(--s-5);
  overflow:hidden; isolation:isolate;
}
.detail-hero::before{
  content:""; position:absolute; inset:-10%;
  background:
    radial-gradient(800px 500px at 18% 30%, rgba(109,166,255,.18), transparent 60%),
    radial-gradient(700px 480px at 90% 10%, rgba(212,173,96,.08), transparent 55%);
  z-index:-1;
}
.detail-hero__layout{
  display:grid; gap:var(--s-5); grid-template-columns:1.4fr 1fr; align-items:start;
}
.detail-hero__art{
  border-radius:var(--radius-lg); border:1px solid var(--border-strong);
  background:linear-gradient(140deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  padding:var(--s-3);
  aspect-ratio:1.2/1;
  display:grid; place-items:center;
  box-shadow:var(--shadow-soft);
}
@media (max-width:900px){
  .detail-hero__layout{ grid-template-columns:1fr; }
  .detail-hero__art{ aspect-ratio:1.6/1; }
}

.detail-meta{
  display:flex; flex-wrap:wrap; gap:.5rem;
  font-family:var(--font-mono); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); margin-bottom:var(--s-3);
}
.detail-meta span{
  padding:.25rem .6rem; border-radius:var(--radius-sm);
  border:1px solid var(--border); background:rgba(255,255,255,.02);
}

.deliverables{
  display:grid; gap:var(--s-2);
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
}
.deliverable{
  padding:var(--s-3);
  background:linear-gradient(160deg, rgba(255,255,255,.035), rgba(255,255,255,.01));
  border:1px solid var(--border); border-radius:var(--radius-md);
  display:flex; gap:.8rem; align-items:flex-start;
}
.deliverable::before{
  content:""; width:8px; height:8px; flex:0 0 8px; margin-top:.55rem;
  border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 4px rgba(109,166,255,.18);
}

/* ----- Форма ----------------------------------------------------- */
.contact-grid{
  display:grid; gap:var(--s-5);
  grid-template-columns:1fr 1fr;
  align-items:start;
}
@media (max-width:900px){
  .contact-grid{ grid-template-columns:1fr; }
}

.form-card{
  padding:var(--s-4);
  background:linear-gradient(160deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.01) 100%);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-soft);
}
.form-row{ margin-bottom:var(--s-3); }
.form-row label{
  display:block; font-size:.85rem; letter-spacing:.06em;
  color:var(--text-soft); margin-bottom:.35rem;
}
.input, .textarea, .select{
  width:100%; padding:.85rem 1rem;
  background:rgba(8,12,18,.6);
  border:1px solid var(--border-strong);
  color:var(--text); border-radius:var(--radius-md);
  font:inherit;
}
.input:focus, .textarea:focus, .select:focus{
  outline:none; border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
}
.textarea{ min-height:160px; resize:vertical; }

.checkbox{
  display:flex; gap:.7rem; align-items:flex-start;
  font-size:.9rem; color:var(--text-soft);
  margin-bottom:var(--s-2); cursor:pointer;
}
.checkbox input{
  margin-top:.25rem; flex:0 0 auto; accent-color:var(--accent);
}

.field-error{
  display:block; margin-top:.3rem; font-size:.85rem; color:#ff8e8e;
}

.contact-meta{
  display:flex; flex-direction:column; gap:var(--s-2);
}
.contact-meta__item{
  padding:var(--s-3); border:1px solid var(--border); border-radius:var(--radius-md);
  background:rgba(255,255,255,.02);
}
.contact-meta__item h4{ margin-bottom:.3rem; font-family:var(--font-display); }
.contact-meta__item p{ margin:0; font-size:.95rem; }

/* ----- Flash сообщения ------------------------------------------ */
.flashes{ list-style:none; padding:0; margin:var(--s-3) 0 0; display:grid; gap:.5rem; }
.flash{ padding:.8rem 1rem; border-radius:var(--radius-md); border:1px solid var(--border-strong); }
.flash--success{
  background:rgba(109,166,255,.08); border-color:rgba(109,166,255,.4); color:var(--accent-2);
}
.flash--error{
  background:rgba(255,142,142,.08); border-color:rgba(255,142,142,.4); color:#ffb1b1;
}

/* ----- Футер ----------------------------------------------------- */
.footer{
  margin-top:var(--s-7);
  padding:var(--s-5) 0 var(--s-3);
  border-top:1px solid var(--border);
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.25));
}
.footer__grid{
  display:grid; gap:var(--s-4);
  grid-template-columns:1.4fr 1fr 1fr;
  margin-bottom:var(--s-4);
}
@media (max-width:760px){
  .footer__grid{ grid-template-columns:1fr; }
}
.brand--footer{ font-size:1rem; }
.footer__tagline{ color:var(--muted); margin-top:.6rem; max-width:38ch; }
.footer__heading{
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--accent-2); margin-bottom:.7rem; font-weight:500;
}
.footer__list{ list-style:none; padding:0; margin:0; display:grid; gap:.4rem; }
.footer__list a{ color:var(--text-soft); }
.footer__list a:hover{ color:var(--text); }
.footer__copy{
  border-top:1px solid var(--border);
  padding-top:var(--s-2);
  color:var(--muted); font-size:.85rem;
}

/* ----- 404 ------------------------------------------------------- */
.notfound{ padding:var(--s-7) 0; text-align:center; }
.notfound h1{ font-size:clamp(3rem, 8vw, 6rem); margin-bottom:0; color:var(--accent); }
.notfound p{ max-width:48ch; margin:var(--s-2) auto var(--s-3); color:var(--text-soft); }

/* ----- Reduced motion ------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  *{ transition:none !important; animation:none !important; }
}
