/* ============================================================
   «Уста» — платформа бытовых услуг. Дизайн-система.
   ============================================================ */

/* ---------- Шрифт Inter (локальный, офлайн) ---------- */
@font-face { font-family:'Inter'; font-weight:400; font-display:swap; font-style:normal;
  src:url('../fonts/inter-cyrillic-400.woff2') format('woff2'); unicode-range:U+0400-04FF,U+0500-052F; }
@font-face { font-family:'Inter'; font-weight:400; font-display:swap; font-style:normal;
  src:url('../fonts/inter-latin-400.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-weight:500; font-display:swap; font-style:normal;
  src:url('../fonts/inter-cyrillic-500.woff2') format('woff2'); unicode-range:U+0400-04FF,U+0500-052F; }
@font-face { font-family:'Inter'; font-weight:500; font-display:swap; font-style:normal;
  src:url('../fonts/inter-latin-500.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-weight:600; font-display:swap; font-style:normal;
  src:url('../fonts/inter-cyrillic-600.woff2') format('woff2'); unicode-range:U+0400-04FF,U+0500-052F; }
@font-face { font-family:'Inter'; font-weight:600; font-display:swap; font-style:normal;
  src:url('../fonts/inter-latin-600.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-weight:700; font-display:swap; font-style:normal;
  src:url('../fonts/inter-cyrillic-700.woff2') format('woff2'); unicode-range:U+0400-04FF,U+0500-052F; }
@font-face { font-family:'Inter'; font-weight:700; font-display:swap; font-style:normal;
  src:url('../fonts/inter-latin-700.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-weight:800; font-display:swap; font-style:normal;
  src:url('../fonts/inter-cyrillic-800.woff2') format('woff2'); unicode-range:U+0400-04FF,U+0500-052F; }
@font-face { font-family:'Inter'; font-weight:800; font-display:swap; font-style:normal;
  src:url('../fonts/inter-latin-800.woff2') format('woff2'); }

/* ---------- Токены темы ---------- */
:root{
  --bg:#f4f5fb; --surface:#ffffff; --surface-2:#f8f9fd; --surface-3:#eef0f8;
  --border:#e6e8f0; --border-2:#d8dbe8;
  --text:#15182b; --text-muted:#646a85; --text-soft:#8b90a8;
  --primary:#6d4afe; --primary-2:#8b5cf6; --primary-soft:#efeaff;
  --accent:#12b886; --accent-soft:#e2f8f1;
  --amber:#f59f0a; --amber-soft:#fff3dc;
  --rose:#f43f5e; --rose-soft:#ffe6ea;
  --blue:#3b82f6; --blue-soft:#e4efff;
  --grad:linear-gradient(135deg,#6d4afe 0%,#9333ea 100%);
  --grad-warm:linear-gradient(135deg,#fb7185 0%,#f59f0a 100%);
  --shadow-sm:0 1px 2px rgba(20,24,43,.06);
  --shadow:0 4px 18px rgba(30,28,70,.08);
  --shadow-lg:0 18px 48px rgba(40,34,90,.16);
  --radius:18px; --radius-sm:12px; --radius-lg:26px;
  --nav-h:68px;
}
[data-theme="dark"]{
  --bg:#0c0e1a; --surface:#15182a; --surface-2:#1b1f33; --surface-3:#232843;
  --border:#272c44; --border-2:#333a59;
  --text:#eef0fb; --text-muted:#a3a9c7; --text-soft:#7780a0;
  --primary:#8b6dff; --primary-2:#a78bfa; --primary-soft:#26223f;
  --accent:#2dd4a0; --accent-soft:#11342a;
  --amber-soft:#3a2e12; --rose-soft:#3a1d24; --blue-soft:#16243e;
  --shadow-sm:0 1px 2px rgba(0,0,0,.3);
  --shadow:0 6px 22px rgba(0,0,0,.35);
  --shadow-lg:0 20px 50px rgba(0,0,0,.5);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,'Segoe UI',Roboto,sans-serif;
  background:var(--bg); color:var(--text); line-height:1.6;
  -webkit-font-smoothing:antialiased; transition:background .25s,color .25s;
}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.container{max-width:1200px;margin:0 auto;padding:0 22px}
.container-sm{max-width:880px;margin:0 auto;padding:0 22px}

/* ---------- Навигация ---------- */
.nav{position:sticky;top:0;z-index:50;height:var(--nav-h);
  background:color-mix(in srgb,var(--surface) 86%,transparent);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.nav-inner{height:var(--nav-h);display:flex;align-items:center;gap:20px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;letter-spacing:-.5px}
.brand-logo{width:38px;height:38px;border-radius:11px;background:var(--grad);
  display:grid;place-items:center;color:#fff;font-size:20px;box-shadow:0 6px 16px rgba(109,74,254,.4)}
.brand span{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:8px}
.nav-link{padding:9px 14px;border-radius:11px;font-weight:500;color:var(--text-muted);
  font-size:14.5px;transition:.15s;display:flex;align-items:center;gap:7px}
.nav-link:hover{background:var(--surface-3);color:var(--text)}
.nav-link.active{color:var(--primary);background:var(--primary-soft)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav-badge{background:var(--rose);color:#fff;font-size:11px;font-weight:700;
  border-radius:9px;padding:1px 7px;margin-left:2px}

/* ---------- Кнопки ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;font-weight:600;font-size:14.5px;cursor:pointer;border:none;
  padding:11px 20px;border-radius:12px;transition:.16s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 8px 20px rgba(109,74,254,.32)}
.btn-primary:hover{box-shadow:0 12px 28px rgba(109,74,254,.45);transform:translateY(-1px)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{filter:brightness(1.05);transform:translateY(-1px)}
.btn-ghost{background:var(--surface-3);color:var(--text)}
.btn-ghost:hover{background:var(--border)}
.btn-outline{background:transparent;border:1.5px solid var(--border-2);color:var(--text)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-danger{background:var(--rose-soft);color:var(--rose)}
.btn-danger:hover{background:var(--rose);color:#fff}
.btn-sm{padding:8px 14px;font-size:13px;border-radius:10px}
.btn-lg{padding:15px 30px;font-size:16px;border-radius:14px}
.btn-block{width:100%}
.btn-icon{width:40px;height:40px;padding:0;border-radius:11px}

/* ---------- Аватары ---------- */
.avatar{border-radius:50%;display:grid;place-items:center;color:#fff;
  font-weight:700;flex-shrink:0;overflow:hidden}
.avatar-sm{width:34px;height:34px;font-size:13px}
.avatar-md{width:46px;height:46px;font-size:16px}
.avatar-lg{width:84px;height:84px;font-size:30px;border-radius:24px}
.avatar-xl{width:110px;height:110px;font-size:40px;border-radius:30px}

/* ---------- Бейджи ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:600;
  padding:4px 11px;border-radius:999px;line-height:1.4}
.badge-blue{background:var(--blue-soft);color:var(--blue)}
.badge-green{background:var(--accent-soft);color:var(--accent)}
.badge-violet{background:var(--primary-soft);color:var(--primary)}
.badge-amber{background:var(--amber-soft);color:var(--amber)}
.badge-rose,.badge-red{background:var(--rose-soft);color:var(--rose)}
.badge-gray{background:var(--surface-3);color:var(--text-muted)}
.badge-verified{background:var(--blue-soft);color:var(--blue)}

/* ---------- Карточки ---------- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-sm)}
.card-pad{padding:22px}
.card-hover{transition:.2s}
.card-hover:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--border-2)}

/* ---------- Формы ---------- */
.form-input,input[type=text],input[type=password],input[type=date],input[type=time],
input[type=number],input[type=email],select,textarea{
  width:100%;font-family:inherit;font-size:14.5px;color:var(--text);
  background:var(--surface-2);border:1.5px solid var(--border);border-radius:12px;
  padding:12px 14px;transition:.15s}
.form-input:focus,input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--primary);background:var(--surface);
  box-shadow:0 0 0 4px var(--primary-soft)}
textarea{resize:vertical;min-height:90px}
label{font-weight:600;font-size:13.5px;color:var(--text);display:block;margin-bottom:7px}
.field{margin-bottom:18px}
.field .helptext,.field .errorlist{font-size:12.5px;margin-top:5px}
.errorlist{color:var(--rose);list-style:none}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ---------- Звёзды рейтинга ---------- */
.stars{display:inline-flex;gap:2px;color:#f5b50a;font-size:15px;letter-spacing:1px}
.stars .empty{color:var(--border-2)}
.rating-num{font-weight:700}

/* ============================================================
   ЛЕНДИНГ
   ============================================================ */
.hero{position:relative;overflow:hidden;
  background:radial-gradient(1200px 500px at 80% -10%,rgba(155,108,255,.5),transparent 55%),
             radial-gradient(900px 500px at 10% 0%,rgba(18,184,134,.28),transparent 50%),
             linear-gradient(160deg,#13112e 0%,#1c1640 55%,#241a52 100%);
  color:#fff;padding:64px 0 88px}
.hero::after{content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:26px 26px;opacity:.5;pointer-events:none}
.hero-inner{position:relative;z-index:2;max-width:760px}
.hero h1{font-size:50px;line-height:1.08;font-weight:800;letter-spacing:-1.5px;margin-bottom:18px}
.hero h1 em{font-style:normal;background:linear-gradient(90deg,#a78bfa,#34d399);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{font-size:18px;color:#c7c9e6;max-width:560px;margin-bottom:30px}
.hero-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);padding:7px 15px;border-radius:999px;
  font-size:13.5px;font-weight:500;margin-bottom:24px;backdrop-filter:blur(6px)}
.search-box{display:flex;gap:10px;background:#fff;padding:9px;border-radius:18px;
  box-shadow:0 24px 60px rgba(10,8,40,.4);max-width:620px}
.search-box input{border:none;background:transparent;font-size:15.5px;padding:12px 14px}
.search-box input:focus{box-shadow:none}
.search-box .sel{flex:0 0 170px;border:none;background:var(--surface-2);border-radius:12px}
.hero-tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}
.hero-tag{font-size:13px;color:#d7d9f0;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);padding:6px 13px;border-radius:999px;transition:.15s}
.hero-tag:hover{background:rgba(255,255,255,.18)}
.hero-stats{display:flex;gap:36px;margin-top:40px;flex-wrap:wrap}
.hero-stat .n{font-size:30px;font-weight:800;line-height:1}
.hero-stat .l{font-size:13.5px;color:#b4b6da;margin-top:5px}

.section{padding:64px 0}
.section-head{text-align:center;max-width:620px;margin:0 auto 42px}
.section-head .eyebrow{color:var(--primary);font-weight:700;font-size:13.5px;
  text-transform:uppercase;letter-spacing:1px}
.section-head h2{font-size:34px;font-weight:800;letter-spacing:-.8px;margin:8px 0 12px}
.section-head p{color:var(--text-muted);font-size:16px}

/* Категории */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:22px;transition:.2s;cursor:pointer;position:relative;overflow:hidden}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-2)}
.cat-ico{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;
  font-size:27px;margin-bottom:14px}
.cat-card h3{font-size:16.5px;font-weight:700;margin-bottom:4px}
.cat-card .cnt{font-size:13px;color:var(--text-muted)}
.cat-card .arrow{position:absolute;top:22px;right:20px;opacity:0;transition:.2s;color:var(--primary)}
.cat-card:hover .arrow{opacity:1;transform:translateX(3px)}

/* «Как это работает» */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{text-align:center;padding:8px}
.step-num{width:58px;height:58px;border-radius:18px;background:var(--primary-soft);
  color:var(--primary);font-size:24px;font-weight:800;display:grid;place-items:center;margin:0 auto 16px}
.step h3{font-size:18px;font-weight:700;margin-bottom:8px}
.step p{color:var(--text-muted);font-size:14.5px}

/* Сетка исполнителей */
.perf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.perf-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;transition:.2s;display:flex;flex-direction:column;gap:14px}
.perf-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-2)}
.perf-top{display:flex;gap:13px;align-items:center}
.perf-name{font-weight:700;font-size:16px;display:flex;align-items:center;gap:6px}
.perf-spec{color:var(--text-muted);font-size:13.5px}
.perf-meta{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-muted);
  flex-wrap:wrap}
.perf-tags{display:flex;flex-wrap:wrap;gap:6px}
.tag{font-size:12px;background:var(--surface-3);color:var(--text-muted);
  padding:4px 10px;border-radius:8px}
.perf-foot{display:flex;align-items:center;justify-content:space-between;
  margin-top:auto;padding-top:14px;border-top:1px solid var(--border)}
.perf-price{font-size:13px;color:var(--text-muted)}
.perf-price b{font-size:17px;color:var(--text);font-weight:800}
.verified-ico{color:var(--blue)}

/* CTA-полоса */
.cta{background:var(--grad);border-radius:var(--radius-lg);padding:54px;color:#fff;
  text-align:center;position:relative;overflow:hidden}
.cta h2{font-size:32px;font-weight:800;margin-bottom:12px;letter-spacing:-.6px}
.cta p{color:rgba(255,255,255,.85);font-size:16.5px;margin-bottom:26px;max-width:520px;margin-inline:auto}

/* Отзывы на лендинге */
.review-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:22px}
.review-card .txt{font-size:14.5px;color:var(--text);margin:12px 0;line-height:1.65}
.review-author{display:flex;align-items:center;gap:11px}

/* ---------- Подвал ---------- */
.footer{background:var(--surface);border-top:1px solid var(--border);
  padding:50px 0 28px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px;margin-bottom:34px}
.footer h4{font-size:14px;font-weight:700;margin-bottom:14px}
.footer a{display:block;color:var(--text-muted);font-size:14px;padding:5px 0;transition:.15s}
.footer a:hover{color:var(--primary)}
.footer-bottom{border-top:1px solid var(--border);padding-top:22px;display:flex;
  justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  color:var(--text-muted);font-size:13.5px}
.dev-credit{font-weight:600;color:var(--text)}

/* ============================================================
   КАТАЛОГ
   ============================================================ */
.catalog-layout{display:grid;grid-template-columns:280px 1fr;gap:26px;align-items:start}
.filters{position:sticky;top:88px}
.filter-group{margin-bottom:22px}
.filter-group h4{font-size:13px;text-transform:uppercase;letter-spacing:.6px;
  color:var(--text-soft);margin-bottom:12px}
.chip-list{display:flex;flex-direction:column;gap:4px}
.chip{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:11px;
  font-size:14px;color:var(--text-muted);cursor:pointer;transition:.13s}
.chip:hover{background:var(--surface-3);color:var(--text)}
.chip.active{background:var(--primary-soft);color:var(--primary);font-weight:600}
.chip .ico{font-size:16px}
.catalog-head{display:flex;justify-content:space-between;align-items:center;
  margin-bottom:20px;flex-wrap:wrap;gap:12px}
.catalog-head h1{font-size:25px;font-weight:800}
.catalog-head .sub{color:var(--text-muted);font-size:14px;margin-top:2px}
.toolbar{display:flex;gap:10px;align-items:center}
.toolbar select{width:auto}

/* Пагинация */
.pagination{display:flex;gap:6px;justify-content:center;margin-top:34px}
.pagination a,.pagination span{min-width:40px;height:40px;display:grid;place-items:center;
  border-radius:11px;border:1px solid var(--border);background:var(--surface);
  font-size:14px;font-weight:600;color:var(--text-muted)}
.pagination a:hover{border-color:var(--primary);color:var(--primary)}
.pagination .current{background:var(--grad);color:#fff;border:none}

/* Пустое состояние */
.empty{text-align:center;padding:60px 20px;color:var(--text-muted)}
.empty .ico{font-size:54px;margin-bottom:14px}
.empty h3{font-size:19px;color:var(--text);margin-bottom:8px;font-weight:700}

/* ============================================================
   ПРОФИЛЬ ИСПОЛНИТЕЛЯ
   ============================================================ */
.profile-hero{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;margin-bottom:24px}
.profile-cover{height:120px;background:var(--grad);position:relative}
.profile-body{padding:0 28px 26px;margin-top:-46px}
.profile-head{display:flex;gap:20px;align-items:flex-end;flex-wrap:wrap}
.profile-head .avatar{border:4px solid var(--surface);box-shadow:var(--shadow)}
.profile-id h1{font-size:27px;font-weight:800;display:flex;align-items:center;gap:9px}
.profile-id .spec{color:var(--text-muted);font-size:15px;margin-top:2px}
.profile-actions{margin-left:auto;display:flex;gap:10px}
.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px}
.pstat{background:var(--surface-2);border:1px solid var(--border);border-radius:14px;
  padding:16px;text-align:center}
.pstat .n{font-size:22px;font-weight:800}
.pstat .l{font-size:12.5px;color:var(--text-muted);margin-top:3px}
.profile-cols{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}
.svc-row{display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:16px 0;border-bottom:1px solid var(--border)}
.svc-row:last-child{border-bottom:none}
.svc-row h4{font-size:15.5px;font-weight:700;margin-bottom:3px}
.svc-row p{font-size:13.5px;color:var(--text-muted)}
.svc-price{text-align:right;white-space:nowrap}
.svc-price b{font-size:17px;font-weight:800}
.svc-price span{font-size:12px;color:var(--text-muted);display:block}

/* Разбивка рейтинга */
.rating-bar{display:flex;align-items:center;gap:10px;margin-bottom:7px;font-size:13px}
.rating-bar .track{flex:1;height:8px;background:var(--surface-3);border-radius:999px;overflow:hidden}
.rating-bar .fill{height:100%;background:#f5b50a;border-radius:999px}
.review-item{padding:18px 0;border-bottom:1px solid var(--border)}
.review-item:last-child{border-bottom:none}
.review-head{display:flex;align-items:center;gap:11px;margin-bottom:9px}

/* Sticky-карточка заказа */
.book-card{position:sticky;top:88px}
.book-card .price-big{font-size:30px;font-weight:800}

/* ============================================================
   КАБИНЕТЫ (дашборды)
   ============================================================ */
.dash{display:grid;grid-template-columns:240px 1fr;gap:0;min-height:calc(100vh - var(--nav-h))}
.side{background:var(--surface);border-right:1px solid var(--border);padding:24px 16px}
.side-user{display:flex;align-items:center;gap:11px;padding:0 8px 18px;
  margin-bottom:16px;border-bottom:1px solid var(--border)}
.side-user .nm{font-weight:700;font-size:14.5px}
.side-user .rl{font-size:12px;color:var(--text-muted)}
.side-nav{display:flex;flex-direction:column;gap:3px}
.side-link{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:12px;
  font-size:14.5px;font-weight:500;color:var(--text-muted);transition:.14s}
.side-link:hover{background:var(--surface-3);color:var(--text)}
.side-link.active{background:var(--primary-soft);color:var(--primary);font-weight:600}
.side-link .ico{font-size:17px;width:20px;text-align:center}
.side-link .cnt{margin-left:auto;background:var(--rose);color:#fff;font-size:11px;
  font-weight:700;border-radius:8px;padding:1px 7px}
.dash-main{padding:30px 34px;max-width:1180px}
.dash-head{display:flex;justify-content:space-between;align-items:flex-start;
  margin-bottom:26px;flex-wrap:wrap;gap:14px}
.dash-head h1{font-size:26px;font-weight:800;letter-spacing:-.5px}
.dash-head p{color:var(--text-muted);font-size:14.5px;margin-top:3px}

/* KPI-карточки */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:26px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;position:relative;overflow:hidden;transition:.2s}
.kpi:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.kpi-ico{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;
  font-size:21px;margin-bottom:14px}
.kpi .val{font-size:28px;font-weight:800;letter-spacing:-.5px;line-height:1}
.kpi .lab{font-size:13.5px;color:var(--text-muted);margin-top:6px}
.kpi .trend{position:absolute;top:20px;right:20px;font-size:12px;font-weight:700;
  padding:3px 8px;border-radius:8px}
.kpi .up{background:var(--accent-soft);color:var(--accent)}

/* Графики */
.chart-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:18px;margin-bottom:26px}
.chart-card{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:22px}
.chart-card h3{font-size:16px;font-weight:700;margin-bottom:4px}
.chart-card .sub{font-size:13px;color:var(--text-muted);margin-bottom:18px}
.chart-wrap{position:relative;height:280px}
.chart-wrap.sm{height:240px}

/* Таблицы */
.table-card{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden}
.table-card .th{padding:18px 22px;border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center}
.table-card .th h3{font-size:16px;font-weight:700}
table.tbl{width:100%;border-collapse:collapse}
table.tbl th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.5px;
  color:var(--text-soft);font-weight:700;padding:13px 22px;background:var(--surface-2)}
table.tbl td{padding:14px 22px;border-top:1px solid var(--border);font-size:14px;vertical-align:middle}
table.tbl tr:hover td{background:var(--surface-2)}
.cell-user{display:flex;align-items:center;gap:10px}
.cell-user .nm{font-weight:600;font-size:14px}
.cell-user .sub{font-size:12.5px;color:var(--text-muted)}

/* Заявки исполнителя — карточки */
.req-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;margin-bottom:14px}
.req-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}
.req-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;
  margin:14px 0;padding:14px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.req-meta .it .l{font-size:12px;color:var(--text-soft)}
.req-meta .it .v{font-size:14px;font-weight:600;margin-top:2px}
.req-actions{display:flex;gap:10px;flex-wrap:wrap}

/* Вкладки-фильтры */
.tabs{display:flex;gap:6px;background:var(--surface-3);padding:5px;border-radius:13px;
  margin-bottom:22px;width:fit-content}
.tab{padding:9px 18px;border-radius:10px;font-size:14px;font-weight:600;
  color:var(--text-muted);cursor:pointer;transition:.14s}
.tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}

/* ---------- Сообщения (тосты) ---------- */
.toasts{position:fixed;top:80px;right:20px;z-index:200;display:flex;flex-direction:column;gap:10px}
.toast{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--primary);
  border-radius:12px;padding:14px 18px;box-shadow:var(--shadow-lg);font-size:14px;
  min-width:280px;animation:slideIn .3s ease}
.toast.success{border-left-color:var(--accent)}
.toast.error{border-left-color:var(--rose)}
.toast.info{border-left-color:var(--blue)}
@keyframes slideIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:none}}

/* ---------- Переключатель темы ---------- */
.theme-toggle{width:40px;height:40px;border-radius:11px;border:1px solid var(--border);
  background:var(--surface-2);cursor:pointer;font-size:18px;display:grid;place-items:center;
  transition:.15s}
.theme-toggle:hover{background:var(--surface-3)}

/* ---------- Карточка авторизации ---------- */
.auth-wrap{min-height:calc(100vh - var(--nav-h));display:grid;place-items:center;padding:40px 20px;
  background:radial-gradient(900px 500px at 50% -10%,var(--primary-soft),transparent 60%)}
.auth-card{width:100%;max-width:430px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:34px;box-shadow:var(--shadow-lg)}
.auth-card h1{font-size:25px;font-weight:800;text-align:center;margin-bottom:6px}
.auth-card .sub{text-align:center;color:var(--text-muted);font-size:14.5px;margin-bottom:26px}
.demo-box{margin-top:24px;padding-top:22px;border-top:1px solid var(--border)}
.demo-box .lbl{text-align:center;font-size:12.5px;color:var(--text-soft);
  text-transform:uppercase;letter-spacing:.6px;margin-bottom:14px}
.demo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.demo-btn{display:flex;flex-direction:column;align-items:center;gap:7px;padding:15px 8px;
  border-radius:14px;border:1.5px solid var(--border);background:var(--surface-2);
  cursor:pointer;transition:.16s;text-align:center}
.demo-btn:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow)}
.demo-btn .em{font-size:26px}
.demo-btn .nm{font-weight:700;font-size:13.5px}
.demo-btn .ds{font-size:11px;color:var(--text-muted)}
.divider{display:flex;align-items:center;gap:12px;color:var(--text-soft);font-size:13px;margin:20px 0}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* Радио выбора роли */
.role-pick{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.role-pick label{border:1.5px solid var(--border);border-radius:14px;padding:16px;cursor:pointer;
  margin:0;transition:.15s;text-align:center}
.role-pick label:has(input:checked){border-color:var(--primary);background:var(--primary-soft)}
.role-pick input{display:none}
.role-pick .em{font-size:26px;display:block;margin-bottom:6px}

/* Утилиты */
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}
.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.text-muted{color:var(--text-muted)}.text-sm{font-size:13px}.text-center{text-align:center}
.fw-700{font-weight:700}.fw-800{font-weight:800}.ml-auto{margin-left:auto}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.section-title{font-size:18px;font-weight:700;margin-bottom:16px}
.divider-line{height:1px;background:var(--border);margin:20px 0}

/* ---------- Адаптив ---------- */
@media(max-width:980px){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .perf-grid,.steps{grid-template-columns:1fr 1fr}
  .catalog-layout{grid-template-columns:1fr}
  .filters{position:static}
  .profile-cols{grid-template-columns:1fr}
  .chart-grid{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .dash{grid-template-columns:1fr}
  .side{display:none}
  .hero h1{font-size:36px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
}
@media(max-width:560px){
  .perf-grid,.steps,.cat-grid,.kpi-grid,.demo-grid,.form-row,.role-pick,.profile-stats{grid-template-columns:1fr}
  .search-box{flex-direction:column}
}
