/* ===========================================================================
   Crea — main.css
   Дизайн-система (порт из index-new.html / CRE8R).
   Светлая тема, акцент #3B5BFE, шрифт Inter Tight.
   =========================================================================== */

/* ---------------------------------------------------------------------------
   1. Токены
   --------------------------------------------------------------------------- */
:root{
  --bg:#F5F6F8;
  --card:#FFFFFF;
  --text:#101010;
  --muted:#737373;
  --soft:#F1F2F4;
  --border:#E8E8E8;
  --primary:#101010;
  --accent:#3B5BFE;
  --accent-d:#2742d8;
  --ok:#1DAB6B;
  --warn:#E8A33D;
  --danger:#E5484D;

  --f:'Inter Tight',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;

  --r-sm:12px;
  --r:16px;
  --r-lg:24px;
  --r-pill:100px;

  --sh-sm:0 1px 2px rgba(16,16,16,.04),0 1px 3px rgba(16,16,16,.03);
  --sh:0 2px 8px rgba(16,16,16,.05),0 8px 24px rgba(16,16,16,.05);
  --sh-lg:0 12px 40px -8px rgba(16,16,16,.18);

  --container:1120px;
  --header-h:68px;
}

/* ---------------------------------------------------------------------------
   2. Reset / база
   --------------------------------------------------------------------------- */
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--f);
  font-size:15.5px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
ul{margin:0;padding:0;list-style:none}

/* ---------------------------------------------------------------------------
   3. Типографика
   --------------------------------------------------------------------------- */
h1,h2,h3{margin:0;font-weight:700;letter-spacing:-.025em;line-height:1.08}
h1{font-size:clamp(30px,5vw,52px);letter-spacing:-.03em;line-height:1.05}
h2{font-size:clamp(23px,3vw,34px)}
h3{font-size:20px}
p{margin:0 0 .8em}
p:last-child{margin-bottom:0}

.kick{font-size:11px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}
.lead{font-size:clamp(15px,1.6vw,18px);color:var(--muted);line-height:1.55}
.muted{color:var(--muted)}
.accent-text{color:var(--accent)}
.center{text-align:center}

/* ---------------------------------------------------------------------------
   4. Раскладка
   --------------------------------------------------------------------------- */
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 20px;
}
.site-main{min-height:60vh}
.section{padding:64px 0}
.section--tight{padding:40px 0}

.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

.stack{display:flex;flex-direction:column;gap:14px}
.row{display:flex;align-items:center;gap:12px}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}
.wrap{flex-wrap:wrap}

/* ---------------------------------------------------------------------------
   5. Кнопки
   --------------------------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:0;border-radius:var(--r);
  padding:15px 22px;
  background:var(--primary);color:#fff;
  font-family:var(--f);font-size:15.5px;font-weight:600;line-height:1;
  cursor:pointer;transition:.18s ease;white-space:nowrap;
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--sh)}
.btn:active{transform:translateY(0)}
.btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2}
.btn.accent{background:var(--accent)}
.btn.accent:hover{background:var(--accent-d)}
.btn.ghost{background:var(--card);color:var(--text);border:1px solid var(--border);box-shadow:var(--sh-sm)}
.btn.ghost:hover{border-color:#d8d8d8}
.btn.soft{background:var(--soft);color:var(--text)}
.btn.sm{padding:11px 15px;font-size:14px;border-radius:var(--r-sm)}
.btn.lg{padding:18px 28px;font-size:17px}
.btn.block{width:100%}
.btn-row{display:grid;grid-template-columns:1fr 1fr;gap:11px}

/* ---------------------------------------------------------------------------
   6. Карточки и поверхности
   --------------------------------------------------------------------------- */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:22px;
  box-shadow:var(--sh-sm);
}
.card.pad-sm{padding:16px}
.card.hover{transition:.2s}
.card.hover:hover{box-shadow:var(--sh);transform:translateY(-2px)}

.statcard{
  background:var(--card);border:1px solid var(--border);
  border-radius:20px;padding:18px;box-shadow:var(--sh-sm);
}
.statcard__num{font-size:26px;font-weight:700;letter-spacing:-.02em}
.statcard__label{font-size:13px;color:var(--muted);margin-top:4px}

/* ---------------------------------------------------------------------------
   7. Формы
   --------------------------------------------------------------------------- */
.field{
  width:100%;
  border:1px solid var(--border);
  background:var(--card);color:var(--text);
  border-radius:14px;
  padding:14px 16px;
  font-size:15px;font-family:var(--f);
  outline:none;transition:.18s;
}
.field:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,91,254,.12)}
.field::placeholder{color:#b3b3b3}
textarea.field{min-height:110px;resize:vertical}
.label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:7px}

/* Поле пароля с переключателем «глаз» */
.pw-wrap{position:relative}
.pw-wrap .field{padding-right:46px}
.pw-toggle{
  position:absolute;top:0;right:0;height:100%;width:44px;
  display:grid;place-items:center;
  background:none;border:0;cursor:pointer;color:var(--muted);transition:.15s;
}
.pw-toggle:hover{color:var(--text)}
.pw-toggle svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.pw-toggle .icon-eye{display:none}             /* по умолчанию пароль скрыт — глаз закрыт */
.pw-toggle.is-shown .icon-eye-off{display:none}
.pw-toggle.is-shown .icon-eye{display:block}   /* пароль показан — глаз открыт */
.form-row{margin-bottom:16px}
.form-error{color:var(--danger);font-size:13.5px;margin-top:6px}

/* Кастомный календарь (date picker) */
.dp{position:relative}
.dp .dp__display{cursor:pointer;padding-right:42px}
.dp__icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.dp.is-open .dp__icon{color:var(--accent)}
.dp__pop{
  position:absolute;z-index:80;top:calc(100% + 8px);left:0;
  width:300px;max-width:calc(100vw - 40px);
  background:var(--card);border:1px solid var(--border);border-radius:18px;
  box-shadow:var(--sh-lg);padding:14px;
}
.dp__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.dp__title{font-weight:700;font-size:15px}
.dp__nav{
  width:32px;height:32px;border:0;border-radius:10px;background:var(--soft);
  color:var(--text);font-size:18px;line-height:1;cursor:pointer;
  display:grid;place-items:center;transition:.15s;font-family:inherit;
}
.dp__nav:hover{background:#e7e9ee}
.dp__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.dp__wd{margin-bottom:4px}
.dp__wd span{text-align:center;font-size:11px;font-weight:700;color:var(--muted);padding:4px 0}
.dp__day{
  height:36px;border:0;border-radius:10px;background:transparent;cursor:pointer;
  font-family:inherit;font-size:14px;font-weight:600;color:var(--text);transition:.12s;
}
.dp__day:hover{background:var(--soft)}
.dp__day.is-today{color:var(--accent)}
.dp__day.is-selected{background:var(--accent);color:#fff}
.dp__day.is-selected:hover{background:var(--accent-d)}
.dp__clear{
  margin-top:10px;width:100%;border:0;border-radius:10px;background:var(--soft);
  color:var(--text);padding:9px;font-size:13px;font-weight:600;cursor:pointer;
  font-family:inherit;transition:.15s;
}
.dp__clear:hover{background:#e7e9ee}
@media (max-width:560px){ .dp__pop{width:280px} }

/* ---------------------------------------------------------------------------
   8. Теги / пилюли / бейджи
   --------------------------------------------------------------------------- */
.tag{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 14px;border-radius:var(--r-pill);
  border:1.5px solid var(--border);background:var(--card);
  font-size:13.5px;font-weight:600;color:var(--muted);
  cursor:pointer;transition:.2s;
}
.tag.is-active{border-color:var(--text);color:var(--text);background:var(--text);color:#fff}
.tagrow{display:flex;flex-wrap:wrap;gap:9px}

.metricpill{
  font-size:12px;font-weight:600;color:var(--muted);background:var(--soft);
  padding:7px 11px;border-radius:var(--r-pill);
  display:inline-flex;align-items:center;gap:6px;
}
.badge{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11px;font-weight:700;padding:5px 10px;border-radius:var(--r-pill);
  background:var(--soft);color:var(--muted);
}
.badge.ok{background:rgba(29,171,107,.12);color:var(--ok)}
.badge.warn{background:rgba(232,163,61,.14);color:#b9791a}
.badge.accent{background:rgba(59,91,254,.12);color:var(--accent)}
.role-badge{
  display:inline-flex;align-items:center;
  font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  padding:3px 8px;border-radius:var(--r-pill);
  background:rgba(59,91,254,.12);color:var(--accent);margin-left:6px;
}

.av{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(140deg,#2b2b30,#101012);
  border:2px solid #fff;box-shadow:var(--sh-sm);
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:15px;flex:0 0 auto;
}

/* ---------------------------------------------------------------------------
   9. Бренд / логотип
   --------------------------------------------------------------------------- */
.brand{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:19px;letter-spacing:-.02em}
.brand__dot{
  position:relative;flex:0 0 auto;
  width:13px;height:13px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 4px rgba(59,91,254,.16);
  animation:logo-dot-pulse 2.6s ease-in-out infinite;
}
.brand__dot::after{
  content:"";position:absolute;inset:-7px;border-radius:50%;
  border:1px solid rgba(59,91,254,.35);
  opacity:0;transform:scale(.68);
  animation:logo-dot-ring 2.6s ease-out infinite;
}
.brand__name{color:var(--text)}
@keyframes logo-dot-pulse{
  0%,100%{transform:scale(1);box-shadow:0 0 0 4px rgba(59,91,254,.16)}
  50%{transform:scale(1.12);box-shadow:0 0 0 6px rgba(59,91,254,.1)}
}
@keyframes logo-dot-ring{
  0%{opacity:.45;transform:scale(.68)}
  70%,100%{opacity:0;transform:scale(1.18)}
}
@media (prefers-reduced-motion:reduce){
  .brand__dot,.brand__dot::after{animation:none}
}

/* ---------------------------------------------------------------------------
   10. Шапка сайта
   --------------------------------------------------------------------------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(245,246,248,.82);
  backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--border);
}
.site-header__in{display:flex;align-items:center;gap:20px;height:var(--header-h)}
.site-nav{display:flex;align-items:center;gap:6px;margin-left:8px}
.site-nav__link{
  padding:9px 14px;border-radius:var(--r-pill);
  font-size:14.5px;font-weight:500;color:var(--muted);transition:.18s;
}
.site-nav__link:hover{color:var(--text);background:var(--soft)}
.site-nav__link.is-active{color:var(--text);background:var(--soft)}
.site-header__auth{display:flex;align-items:center;gap:10px;margin-left:auto}
.site-header__user{display:inline-flex;align-items:center;font-size:14px;font-weight:600}
.lang-menu{position:relative}
.lang-menu__button{
  height:38px;display:inline-flex;align-items:center;gap:6px;
  padding:0 10px;border:0;border-radius:12px;background:transparent;color:var(--text);
  font-size:14px;font-weight:600;letter-spacing:0;cursor:pointer;transition:.15s ease;
}
.lang-menu__button:hover,.lang-menu.is-open .lang-menu__button{background:var(--soft)}
.lang-menu__flag{width:20px;height:20px;object-fit:contain;flex:none}
.lang-opt__flag{width:20px;height:20px;object-fit:contain;flex:none;margin-right:8px}
.lang-menu__chev{
  width:15px;height:15px;flex:none;
  stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;
  color:var(--muted);transition:transform .18s ease;
}
.lang-menu.is-open .lang-menu__chev{transform:rotate(180deg)}
.lang-menu__dropdown{
  position:absolute;right:0;top:calc(100% + 8px);z-index:70;
  min-width:128px;padding:7px;border:1px solid var(--border);border-radius:16px;
  background:var(--card);box-shadow:var(--sh-lg);
  opacity:0;transform:translateY(-4px);pointer-events:none;transition:.16s ease;
}
.lang-menu.is-open .lang-menu__dropdown{opacity:1;transform:translateY(0);pointer-events:auto}
.lang-menu__dropdown button{
  width:100%;min-height:36px;display:flex;align-items:center;
  padding:8px 10px;border:0;border-radius:11px;background:transparent;
  color:var(--text);font-size:14px;font-weight:600;text-align:left;cursor:pointer;
}
.lang-menu__dropdown button:hover,.lang-menu__dropdown button.is-active{background:var(--soft);color:var(--accent)}
.account-menu{position:relative}
.account-menu__button{
  width:42px;height:42px;display:grid;place-items:center;
  padding:0;border:0;border-radius:50%;background:transparent;
  cursor:pointer;color:var(--text);box-shadow:none;
  transition:transform .16s ease,opacity .16s ease;
}
.account-menu__button:hover,.account-menu.is-open .account-menu__button{
  background:transparent;box-shadow:none;
}
.account-menu__avatar{
  width:34px;height:34px;border-radius:50%;overflow:hidden;display:grid;place-items:center;
  background:var(--accent);color:#fff;border:0;font-weight:800;font-size:14px;
  transition:box-shadow .15s ease;
}
.account-menu__button:hover .account-menu__avatar,
.account-menu.is-open .account-menu__avatar{box-shadow:0 0 0 3px rgba(59,91,254,.18)}
.account-menu__avatar img{width:100%;height:100%;object-fit:cover}
.account-menu__dropdown{
  position:absolute;right:0;top:calc(100% + 8px);z-index:70;
  width:240px;padding:8px;border:1px solid var(--border);border-radius:18px;
  background:var(--card);box-shadow:var(--sh-lg);
  opacity:0;transform:translateY(-4px);pointer-events:none;transition:.16s ease;
}
.account-menu.is-open .account-menu__dropdown{opacity:1;transform:translateY(0);pointer-events:auto}
.account-menu__head{padding:10px 11px 12px;border-bottom:1px solid var(--border);margin-bottom:6px}
.account-menu__head strong{display:block;font-size:14.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.account-menu__head span{display:block;margin-top:3px;font-size:12.5px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.account-menu__dropdown a{
  display:flex;align-items:center;min-height:38px;padding:9px 11px;border-radius:12px;
  color:var(--text);font-size:14px;font-weight:600;transition:.14s ease;
}
.account-menu__dropdown a svg{
  width:17px;height:17px;flex:none;margin-right:10px;
  stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  color:var(--muted);transition:color .14s ease;
}
.account-menu__dropdown a:hover{background:var(--soft);color:var(--accent)}
.account-menu__dropdown a:hover svg{color:var(--accent)}
.account-menu__dropdown a.is-danger{color:var(--danger)}
.account-menu__dropdown a.is-danger svg{color:var(--danger)}
.account-menu__dropdown a.is-danger:hover{background:rgba(229,72,77,.10);color:var(--danger)}
.account-menu__dropdown a.is-danger:hover svg{color:var(--danger)}

/* Колокольчик уведомлений */
.notif-menu{position:relative}
.notif-menu__button{
  position:relative;width:38px;height:38px;display:grid;place-items:center;
  padding:0;border:0;border-radius:12px;background:transparent;color:var(--text);
  cursor:pointer;transition:.15s ease;
}
.notif-menu__button:hover,.notif-menu.is-open .notif-menu__button{background:var(--soft)}
.notif-menu__button svg{width:20px;height:20px;color:var(--muted);transition:color .14s ease}
.notif-menu__button:hover svg,.notif-menu.is-open .notif-menu__button svg{color:var(--text)}
.notif-menu__badge{
  position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;
  display:grid;place-items:center;border-radius:100px;
  background:var(--danger);color:#fff;font-size:10px;font-weight:700;line-height:1;
  border:2px solid var(--card);
}
.notif-menu__dropdown{
  position:absolute;right:0;top:calc(100% + 8px);z-index:70;
  width:320px;max-width:calc(100vw - 32px);padding:8px;
  border:1px solid var(--border);border-radius:18px;
  background:var(--card);box-shadow:var(--sh-lg);
  opacity:0;transform:translateY(-4px);pointer-events:none;transition:.16s ease;
}
.notif-menu.is-open .notif-menu__dropdown{opacity:1;transform:translateY(0);pointer-events:auto}
.notif-menu__head{padding:8px 11px 10px;border-bottom:1px solid var(--border);margin-bottom:6px}
.notif-menu__head strong{font-size:14.5px}
.notif-menu__empty{padding:22px 12px;text-align:center;color:var(--muted);font-size:13.5px}
.notif-menu__list{max-height:360px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.notif-item{
  display:flex;flex-direction:column;gap:2px;padding:9px 11px;border-radius:12px;
  transition:.14s ease;
}
.notif-item:hover{background:var(--soft)}
.notif-item__title{font-size:13.5px;font-weight:600;color:var(--text)}
.notif-item__body{font-size:12.5px;color:var(--muted)}
.notif-item__time{font-size:11.5px;color:var(--muted);margin-top:2px}
.notif-item.is-unread{background:rgba(59,91,254,.06)}
.notif-item.is-unread .notif-item__title{position:relative;padding-left:14px}
.notif-item.is-unread .notif-item__title::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:7px;height:7px;border-radius:50%;background:var(--accent);
}
.notif-menu__all{display:block;text-align:center;margin-top:6px;padding:10px;border-top:1px solid var(--border);
  font-size:13.5px;font-weight:600;color:var(--accent)}
.notif-menu__all:hover{background:var(--soft);border-radius:0 0 12px 12px}

.site-header__burger{
  display:none;margin-left:auto;
  width:42px;height:42px;border:1px solid var(--border);border-radius:12px;
  background:var(--card);cursor:pointer;
  flex-direction:column;align-items:center;justify-content:center;gap:4px;
}
.site-header__burger span{display:block;width:18px;height:2px;background:var(--text);border-radius:2px;transition:.2s}

/* ---------------------------------------------------------------------------
   11. Hero / лендинг
   --------------------------------------------------------------------------- */
.hero{padding:72px 0 56px;text-align:center}
.hero__title{margin:18px auto 16px;max-width:14ch}
.hero__lead{max-width:56ch;margin:0 auto 28px}
.hero__cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.hero__stats{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:40px}

.feature{padding:24px}
.feature__icon{
  width:46px;height:46px;border-radius:14px;display:grid;place-items:center;
  background:var(--soft);margin-bottom:14px;font-size:22px;
}
.feature h3{margin-bottom:8px}
.feature p{color:var(--muted);font-size:15px}

.step{display:flex;gap:16px;align-items:flex-start}
.step__num{
  flex:0 0 auto;width:38px;height:38px;border-radius:50%;
  background:var(--text);color:#fff;display:grid;place-items:center;font-weight:700;
}

/* ---------------------------------------------------------------------------
   12. Кабинет бренда
   --------------------------------------------------------------------------- */
.dashboard{padding-top:34px;padding-bottom:24px}
.dash-hero{
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
  padding:26px 0 22px;border-bottom:1px solid var(--border);
}
.dash-hero h1{font-size:clamp(28px,4vw,44px)}
.dash-hero__lead{max-width:58ch;margin-top:12px}
.dash-hero__actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}

.dash-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  margin:22px 0 24px;
}
.dash-stat{
  min-height:132px;
  background:var(--card);border:1px solid var(--border);border-radius:18px;
  padding:18px;box-shadow:var(--sh-sm);
  display:flex;flex-direction:column;justify-content:space-between;gap:8px;
}
.dash-stat__label{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.dash-stat strong{font-size:30px;line-height:1;letter-spacing:-.02em}
.dash-stat span:last-child{font-size:13px;color:var(--muted)}

.dash-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:20px;align-items:start}
.dash-panel{padding:0;overflow:hidden}
.dash-panel__head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
  padding:22px;border-bottom:1px solid var(--border);
}
.dash-panel__head h2{font-size:25px}

.campaign-list{display:flex;flex-direction:column}
.campaign-row{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:18px 22px;border-bottom:1px solid var(--border);
  color:inherit;text-decoration:none;border-radius:14px;
  transition:background .15s ease, box-shadow .15s ease;
}
.campaign-row:last-child{border-bottom:0}
.campaign-row:hover{background:var(--soft)}
.campaign-row__logo{flex:none;width:46px;height:46px;border-radius:12px;overflow:hidden;background:var(--soft);display:grid;place-items:center;border:1px solid var(--border)}
.campaign-row__logo img{width:100%;height:100%;object-fit:cover}
.campaign-row:hover h3{color:var(--accent)}
.campaign-row__main{min-width:0}
.campaign-row__top{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px}
.campaign-row h3{font-size:18px;margin-bottom:8px;overflow-wrap:anywhere}
.campaign-row__meta{display:flex;flex-wrap:wrap;gap:8px 14px;color:var(--muted);font-size:13.5px}
.campaign-row__side{
  min-width:128px;text-align:right;display:flex;flex-direction:column;align-items:flex-end;
}
.campaign-row__side strong{font-size:20px;letter-spacing:-.02em}
.campaign-row__side span{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--muted)}

.dash-side{display:flex;flex-direction:column;gap:20px}
.quick-card,.account-card{border-radius:18px}
.quick-actions{display:flex;flex-direction:column;gap:10px}
.quick-actions a{
  display:block;padding:14px;border:1px solid var(--border);border-radius:14px;
  background:var(--soft);transition:.18s;
}
.quick-actions a:hover{background:#fff;box-shadow:var(--sh-sm);transform:translateY(-1px)}
.quick-actions strong{display:block;font-size:15px;margin-bottom:4px}
.quick-actions span{display:block;color:var(--muted);font-size:13px}

.account-card__user{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.account-card__user strong{display:block;font-size:16px}
.account-card__user span:not(.av){display:block;color:var(--muted);font-size:13px;overflow-wrap:anywhere}
.account-card__rows{display:flex;flex-direction:column;gap:12px;margin-top:16px}
.account-card__rows div{display:flex;align-items:center;justify-content:space-between;gap:12px}
.account-card__rows span{color:var(--muted);font-size:13px}
.account-card__rows strong{font-size:13px;text-transform:uppercase;letter-spacing:.04em}

.empty-state{
  min-height:340px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;text-align:center;padding:42px 22px;
}
.empty-state__mark{
  width:54px;height:54px;border-radius:50%;display:grid;place-items:center;
  background:rgba(59,91,254,.1);color:var(--accent);font-size:32px;font-weight:600;
}
.empty-state p{max-width:42ch}

/* ---------------------------------------------------------------------------
   13. Настройки бренда
   --------------------------------------------------------------------------- */
.settings-page{padding-top:34px;padding-bottom:24px}
.settings-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
  padding:26px 0 22px;border-bottom:1px solid var(--border);
}
.settings-head h1{font-size:clamp(28px,4vw,44px)}
.settings-head__lead{max-width:56ch;margin-top:12px}
.settings-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:20px;align-items:start;margin-top:24px}
.settings-panel{padding:0;overflow:hidden}
.settings-panel__head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
  padding:22px;border-bottom:1px solid var(--border);
}
.settings-panel__head h2{font-size:25px}
.settings-panel__title{margin:0 22px 18px}
.settings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 16px;padding:0 22px}
.settings-logo{padding:22px}
.settings-hint{font-size:13px;margin-top:7px}
.logo-upload{
  display:grid;grid-template-columns:82px minmax(0,1fr) auto;align-items:center;gap:16px;
  padding:14px;border:1px solid var(--border);border-radius:18px;background:var(--card);
  box-shadow:var(--sh-sm);cursor:pointer;
  transition:border-color .16s ease, box-shadow .16s ease, transform .16s ease, background .16s ease;
}
.logo-upload:hover{border-color:rgba(59,91,254,.45);box-shadow:var(--sh);transform:translateY(-1px)}
.logo-upload:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px rgba(59,91,254,.12)}
.logo-upload input{position:absolute;inline-size:1px;block-size:1px;opacity:0;pointer-events:none}
.logo-upload__preview{
  width:82px;height:82px;border-radius:18px;overflow:hidden;
  border:1px solid var(--border);background:var(--soft);
  display:grid;place-items:center;box-shadow:inset 0 0 0 1px rgba(255,255,255,.65);
}
.logo-upload__preview img{width:100%;height:100%;object-fit:cover}
.logo-upload__preview span{font-size:31px;font-weight:700;color:var(--accent)}
.logo-upload__body{min-width:0;display:flex;flex-direction:column;gap:4px}
.logo-upload__body .label{margin-bottom:0}
.logo-upload__body strong{font-size:17px;line-height:1.2}
.logo-upload__body > span:last-child{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.logo-upload__action{
  align-self:center;border-radius:12px;background:var(--text);color:#fff;
  padding:11px 15px;font-size:13px;font-weight:700;white-space:nowrap;
}
.settings-divider{height:1px;background:var(--border);margin:6px 22px 22px}
.settings-panel > .form-row{padding:0 22px 6px}
.settings-side{display:flex;flex-direction:column;gap:20px}
.password-card{border-radius:18px}
.password-card h2{font-size:24px}

/* ---------------------------------------------------------------------------
   14. Auth-страницы (login/register)
   --------------------------------------------------------------------------- */
.auth-wrap{max-width:420px;margin:56px auto;padding:0 20px}
.auth-card{padding:30px}
.auth-card h1{font-size:26px;margin-bottom:6px}
.auth-card .lead{margin-bottom:24px}
.auth-switch{text-align:center;margin-top:18px;font-size:14px;color:var(--muted)}
.auth-switch a{color:var(--accent);font-weight:600}

/* ---------------------------------------------------------------------------
   15. Подвал
   --------------------------------------------------------------------------- */
.site-footer{margin-top:64px;border-top:1px solid var(--border);background:var(--card)}
.site-footer__in{display:flex;gap:40px;justify-content:space-between;flex-wrap:wrap;padding:48px 20px 28px}
.site-footer__brand{max-width:360px}
.site-footer__tagline{color:var(--muted);font-size:14.5px;margin-top:12px}
.site-footer__links{display:flex;flex-direction:column;gap:10px}
.site-footer__links a{color:var(--muted);font-size:14.5px;transition:.15s}
.site-footer__links a:hover{color:var(--text)}
.site-footer__bottom{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
  padding:18px 20px;border-top:1px solid var(--border);
  color:var(--muted);font-size:13px;
}

/* ---------------------------------------------------------------------------
   16. Утилиты
   --------------------------------------------------------------------------- */
.mt-0{margin-top:0}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-40{margin-top:40px}
.mb-0{margin-bottom:0}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.hidden{display:none}
.flash{padding:13px 16px;border-radius:14px;font-size:14px;margin-bottom:16px}
.flash.error{background:rgba(229,72,77,.1);color:var(--danger)}
.flash.ok{background:rgba(29,171,107,.12);color:var(--ok)}
.flash.info{background:rgba(59,91,254,.1);color:var(--accent)}

/* ---------------------------------------------------------------------------
   17. Адаптив
   --------------------------------------------------------------------------- */
@media (max-width:860px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .dash-hero{align-items:flex-start;flex-direction:column}
  .dash-hero__actions{justify-content:flex-start}
  .dash-stats{grid-template-columns:repeat(2,1fr)}
  .dash-layout{grid-template-columns:1fr}
  .settings-head{align-items:flex-start;flex-direction:column}
  .settings-layout{grid-template-columns:1fr}
  .site-nav,.site-header__auth{display:none}
  .site-header__burger{display:flex}
  .site-header.is-open .site-nav{
    display:flex;position:absolute;top:var(--header-h);left:0;right:0;
    flex-direction:column;gap:2px;margin:0;padding:12px 20px;
    background:var(--card);border-bottom:1px solid var(--border);box-shadow:var(--sh);
  }
  .site-header.is-open .site-header__auth{
    display:flex;position:absolute;top:calc(var(--header-h) + 1px);left:0;right:0;
    padding:0 20px 16px;background:var(--card);justify-content:stretch;
  }
  .site-header.is-open .site-header__auth .btn{flex:1}
  .site-header.is-open .lang-menu{margin-left:auto}
  .site-header.is-open .account-menu{flex:0 0 auto}
  .site-header.is-open .account-menu__dropdown{left:0;right:0;width:100%}
  .site-header.is-open .lang-menu__dropdown{right:0}
}
@media (max-width:560px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .dashboard{padding-top:18px}
  .dash-stats{grid-template-columns:1fr}
  .dash-stat{min-height:112px}
  .dash-panel__head{flex-direction:column}
  .campaign-row{align-items:flex-start;flex-direction:column}
  .campaign-row__side{min-width:0;text-align:left;align-items:flex-start}
  .dash-hero__actions,.dash-hero__actions .btn{width:100%}
  .settings-page{padding-top:18px}
  .settings-head .btn{width:100%}
  .settings-panel__head{flex-direction:column}
  .settings-panel__head .btn{width:100%}
  .settings-grid{grid-template-columns:1fr}
  .logo-upload{grid-template-columns:64px minmax(0,1fr);gap:12px}
  .logo-upload__preview{width:64px;height:64px;border-radius:16px}
  .logo-upload__action{grid-column:1 / -1;text-align:center}
  .section{padding:44px 0}
  .hero{padding:48px 0 36px}
  .btn-row{grid-template-columns:1fr}
}

/* ---------------------------------------------------------------------------
   Модалка (переиспользуемая): .modal + data-modal*
   --------------------------------------------------------------------------- */
.modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}
.modal[hidden]{display:none}
.modal__overlay{position:absolute;inset:0;background:rgba(16,16,16,.5);backdrop-filter:blur(2px);
  opacity:0;transition:opacity .18s ease}
.modal__box{
  position:relative;display:flex;flex-direction:column;width:100%;max-width:560px;max-height:88vh;
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-lg);
  opacity:0;transform:translateY(8px) scale(.985);transition:opacity .18s ease,transform .18s ease;
}
.modal.is-open .modal__overlay{opacity:1}
.modal.is-open .modal__box{opacity:1;transform:none}
.modal__head{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:18px 22px;border-bottom:1px solid var(--border);flex:none}
.modal__head h3{margin:0;font-size:17px}
.modal__x{width:34px;height:34px;display:grid;place-items:center;flex:none;
  border:0;border-radius:10px;background:transparent;color:var(--muted);cursor:pointer;transition:.14s ease}
.modal__x:hover{background:var(--soft);color:var(--text)}
.modal__body{padding:18px 22px;overflow-y:auto;flex:1 1 auto;font-size:14px;line-height:1.6;color:var(--text)}
.modal__body h4{margin:18px 0 6px;font-size:14.5px}
.modal__body h4:first-of-type{margin-top:14px}
.modal__body p{margin:0 0 4px;color:var(--muted)}
.modal__foot{padding:16px 22px;border-top:1px solid var(--border);flex:none;background:var(--card);
  border-radius:0 0 var(--r-lg) var(--r-lg)}
.modal__foot .btn[disabled]{opacity:.5;cursor:not-allowed}
@media (max-width:560px){
  .modal{padding:0}
  .modal__box{max-width:none;max-height:100vh;height:100vh;border-radius:0;border:0}
}
