/* CPA Flow — общая дизайн-система (свет + тьма).
   Все страницы подключают этот файл и используют его токены/классы.
   Цветовые токены НЕ переопределять — расширять своими классами. */

/* ─── Токены ─────────────────────────────────────────────────── */
:root{
  --ink:#13241d; --ink-soft:#3f5048; --muted:#6b7d74;
  --line:#e3e8e4; --line-soft:#eef1ee;
  --bg:#f6f8f6; --bg-elev:#ffffff; --bg-tint:#f6f8f6; --bg-tint2:#eef3ef;
  --green:#0f5132; --green-d:#0a3a23; --green-l:#e7f0ea; --green-rgb:15,81,50;
  --gold:#a07c2c; --gold-l:#fbf3e0;
  --red:#a32d2d; --red-l:#fbeded;
  --radius:14px; --radius-sm:10px; --radius-lg:18px; --maxw:1140px;
  --sans:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --serif:'Fraunces',Georgia,serif;
  --shadow:0 1px 2px rgba(var(--green-rgb),.04),0 12px 28px -18px rgba(var(--green-rgb),.18);
  --shadow-lg:0 30px 60px -30px rgba(var(--green-rgb),.28);
  --ring:0 0 0 3px rgba(var(--green-rgb),.18);
  --t:.2s cubic-bezier(.4,0,.2,1);
}
:root[data-theme="dark"]{
  --ink:#e8efe9; --ink-soft:#b7c6bd; --muted:#869a8e;
  --line:#22312a; --line-soft:#1b2922;
  --bg:#0c140f; --bg-elev:#121d17; --bg-tint:#0f1813; --bg-tint2:#16231c;
  --green:#3fae74; --green-d:#2f8d5c; --green-l:#15271d; --green-rgb:63,174,116;
  --gold:#d6b25e; --gold-l:#2a2414;
  --red:#e0807e; --red-l:#2c1817;
  --shadow:0 1px 2px rgba(0,0,0,.4),0 14px 32px -20px rgba(0,0,0,.7);
  --shadow-lg:0 30px 60px -28px rgba(0,0,0,.75);
}

/* ─── База ───────────────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;
  -webkit-font-smoothing:antialiased;font-size:16px;
  transition:background var(--t),color var(--t)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--green-l);color:var(--green-d)}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:6px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.serif{font-family:var(--serif)}
.muted{color:var(--muted)}
.hidden{display:none!important}

/* ─── Кнопки ─────────────────────────────────────────────────── */
.btn{font-family:var(--sans);font-weight:600;font-size:15px;padding:11px 22px;
  border-radius:var(--radius-sm);cursor:pointer;border:1px solid transparent;
  transition:all var(--t);display:inline-flex;align-items:center;gap:8px;
  white-space:nowrap;line-height:1}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn-solid{background:var(--green);color:#fff}
.btn-solid:hover{background:var(--green-d)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-white{background:#fff;color:var(--green)}
.btn-white:hover{background:var(--green-l)}
.btn-block{width:100%;justify-content:center}
.btn-sm{padding:8px 14px;font-size:13.5px;border-radius:8px}
.mini{font-size:13px;font-weight:600;padding:7px 13px;border-radius:8px;
  border:1px solid var(--line);background:var(--bg-elev);color:var(--ink);
  cursor:pointer;transition:all var(--t)}
.mini:hover{border-color:var(--green)}
.mini.g{background:var(--green);color:#fff;border-color:var(--green)}
.mini.g:hover{background:var(--green-d)}
.mini.r{color:var(--red);border-color:color-mix(in srgb,var(--red) 35%,transparent)}
.mini.r:hover{background:var(--red-l)}

/* ─── Карточки / поля / бейджи ──────────────────────────────── */
.card{background:var(--bg-elev);border:1px solid var(--line);
  border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);
  margin-bottom:6px;margin-top:14px}
input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line);
  border-radius:var(--radius-sm);font-size:15px;font-family:var(--sans);
  background:var(--bg-elev);color:var(--ink);transition:border var(--t),box-shadow var(--t)}
input::placeholder,textarea::placeholder{color:var(--muted)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green);box-shadow:var(--ring)}
textarea{resize:vertical;min-height:64px}
select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7d74' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:38px}
.badge{font-size:11.5px;font-weight:600;padding:4px 11px;border-radius:100px;display:inline-flex;align-items:center;gap:5px}
.badge.ok{background:var(--green-l);color:var(--green)}
.badge.wait{background:var(--gold-l);color:var(--gold)}
.badge.rej{background:var(--red-l);color:var(--red)}
.pill{font-size:11px;font-weight:600;padding:3px 9px;border-radius:100px;background:var(--bg-tint2);color:var(--ink-soft)}
.pill.off{background:var(--red-l);color:var(--red)}

/* ─── Переключатель темы ────────────────────────────────────── */
.theme-toggle{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);
  background:var(--bg-elev);color:var(--ink-soft);cursor:pointer;display:inline-flex;
  align-items:center;justify-content:center;font-size:19px;transition:all var(--t);flex-shrink:0}
.theme-toggle:hover{border-color:var(--green);color:var(--green)}
:root[data-theme="dark"] .theme-toggle .ti-sun{display:inline-block}
:root[data-theme="dark"] .theme-toggle .ti-moon{display:none}
.theme-toggle .ti-sun{display:none}
.theme-toggle .ti-moon{display:inline-block}

/* ─── Скелетоны ─────────────────────────────────────────────── */
.skeleton{height:14px;border-radius:7px;
  background:linear-gradient(90deg,var(--line-soft) 25%,var(--bg-tint2) 37%,var(--line-soft) 63%);
  background-size:400% 100%;animation:shimmer 1.4s ease infinite;margin:10px 0}
.skeleton.lg{height:46px;border-radius:12px}
.skeleton.row{height:64px;border-radius:12px;margin:12px 0}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:0 0}}
@media(prefers-reduced-motion:reduce){.skeleton{animation:none}*{scroll-behavior:auto!important}}

/* ─── Спиннер ───────────────────────────────────────────────── */
.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.4);
  border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─── Пустые состояния ──────────────────────────────────────── */
.empty{color:var(--muted);padding:36px 20px;text-align:center;font-size:14.5px}
.empty .ti{font-size:34px;display:block;margin:0 auto 10px;opacity:.5}

/* ─── Тосты (управляются api.js) ────────────────────────────── */
#toasts{position:fixed;top:18px;right:18px;z-index:9999;display:flex;
  flex-direction:column;gap:10px;max-width:min(360px,calc(100vw - 36px));pointer-events:none}
.toast{pointer-events:auto;background:var(--bg-elev);border:1px solid var(--line);
  border-left:4px solid var(--muted);border-radius:12px;padding:13px 16px;
  box-shadow:var(--shadow-lg);font-size:14px;font-weight:500;color:var(--ink);
  display:flex;align-items:center;gap:11px;animation:toastIn .28s cubic-bezier(.2,.8,.2,1)}
.toast.out{animation:toastOut .25s ease forwards}
.toast .ti{font-size:20px;flex-shrink:0}
.toast.ok{border-left-color:var(--green)} .toast.ok .ti{color:var(--green)}
.toast.err{border-left-color:var(--red)} .toast.err .ti{color:var(--red)}
.toast.info{border-left-color:var(--gold)} .toast.info .ti{color:var(--gold)}
@keyframes toastIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateX(30px)}}

/* ─── Оверлей / модалка (для confirmDialog и page-модалок) ──── */
.overlay{position:fixed;inset:0;background:rgba(8,28,20,.55);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;z-index:1000;padding:20px}
.overlay.show{display:flex;animation:fadeIn .2s ease}
.modal{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:30px;max-width:420px;width:100%;box-shadow:var(--shadow-lg);
  animation:modalIn .26s cubic-bezier(.2,.8,.2,1)}
.modal h3{font-family:var(--serif);font-weight:500;font-size:24px;margin-bottom:8px}
.modal p{font-size:14.5px;color:var(--ink-soft);margin-bottom:8px}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes modalIn{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}

/* confirmDialog-разметка из api.js */
#cdlg .modal{text-align:center;max-width:400px}
#cdlg .cd-ic{width:54px;height:54px;border-radius:50%;background:var(--green-l);color:var(--green);
  display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 14px}
#cdlg.danger .cd-ic{background:var(--red-l);color:var(--red)}
#cdlg .cd-actions{display:flex;gap:10px;margin-top:22px}
#cdlg .cd-actions .btn{flex:1;justify-content:center}
