/* Стили слоя сообщества (cabinet/market/admin/community). Наследует токены landing.css.
   Buildless: подключается <link>, поверх /landing/landing.css. Бренд BunnySplit:
   ink/graphite + бирюза #19E3D6, тёплый морковный для reward. */

/* ── shell ── */
.cm-app-nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:1.6rem;
  max-width:var(--maxw);margin:0 auto;padding:.85rem 1.5rem;backdrop-filter:blur(12px)}
.cm-app-nav::before{content:"";position:fixed;inset:0 0 auto 0;height:62px;background:rgba(10,10,11,.82);z-index:-1;border-bottom:1px solid var(--line)}
.cm-nav-links{display:flex;gap:1.2rem;margin-left:1rem;font-size:.94rem;color:var(--mut);align-items:center}
.cm-nav-links a{padding:.25em .15em;border-radius:6px;transition:.18s;white-space:nowrap}
.cm-nav-links a:hover{color:var(--accent)}
.cm-nav-active{color:var(--accent)!important;font-weight:600}
.cm-nav-right{margin-left:auto;display:flex;align-items:center;gap:.6rem}
.cm-nav-user{display:inline-flex;align-items:center;gap:.5rem;padding:.4em .8em;border:1px solid var(--line);border-radius:999px;transition:.18s}
.cm-nav-user:hover{border-color:var(--line-neon)}
.cm-nav-bal{color:var(--carrot);font-weight:700;font-variant-numeric:tabular-nums}
.cm-nav-email{color:var(--txt);font-size:.9rem}

.cm-wrap{max-width:var(--maxw);margin:0 auto;padding:2rem 1.5rem 5rem}
.cm-wrap-narrow{max-width:840px}
.cm-page-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.6rem}
.cm-page-head h1{font-size:clamp(1.6rem,3vw,2.2rem);letter-spacing:-.02em}
.cm-page-head p{color:var(--mut);font-size:.95rem;margin-top:.2rem}

/* ── cards / surfaces ── */
.cm-card{background:var(--surface);backdrop-filter:blur(14px);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.4rem}
.cm-card+.cm-card{margin-top:1rem}
.cm-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}

/* карточка заказа/публикации */
.cm-tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:transform .25s var(--ease),border-color .25s}
.cm-tile:hover{transform:translateY(-3px);border-color:var(--line-neon)}
.cm-tile-media{aspect-ratio:16/10;background:var(--bg2);display:grid;place-items:center;overflow:hidden}
.cm-tile-media img,.cm-tile-media model-viewer{width:100%;height:100%;object-fit:cover}
.cm-tile-media .cm-noimg{color:var(--dim);font-size:2rem}
.cm-tile-body{padding:1rem 1.1rem 1.2rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.cm-tile-title{font-weight:700;font-size:1.05rem;letter-spacing:-.01em;line-height:1.25}
.cm-tile-meta{display:flex;flex-wrap:wrap;gap:.5rem .9rem;color:var(--mut);font-size:.85rem}
.cm-tile-meta b{color:var(--txt);font-weight:600}
.cm-tile-desc{color:var(--mut);font-size:.9rem;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cm-tile-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding-top:.4rem}

/* ── status pills ── */
.cm-pill{display:inline-flex;align-items:center;font-size:.72rem;font-weight:600;letter-spacing:.02em;
  padding:.3em .7em;border-radius:999px;border:1px solid transparent;white-space:nowrap}
.cm-pill-accent{color:var(--accent);background:var(--accent-soft);border-color:var(--line-neon)}
.cm-pill-ok{color:var(--ok);background:rgba(52,211,153,.1);border-color:rgba(52,211,153,.3)}
.cm-pill-warn{color:var(--warn);background:rgba(251,191,36,.1);border-color:rgba(251,191,36,.3)}
.cm-pill-err{color:var(--err);background:rgba(251,113,133,.1);border-color:rgba(251,113,133,.3)}
.cm-pill-mut{color:var(--mut);background:rgba(255,255,255,.04);border-color:var(--line)}

/* теги (need_model / need_print / город) */
.cm-tag{display:inline-flex;align-items:center;gap:.3em;font-size:.74rem;color:var(--mut);
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:6px;padding:.25em .55em}
.cm-tag-accent{color:var(--accent);border-color:var(--line-neon);background:var(--accent-soft)}

/* ── tabs ── */
.cm-tabs{display:flex;gap:.3rem;background:var(--bg2);border:1px solid var(--line);border-radius:999px;
  padding:.3rem;margin-bottom:1.5rem;flex-wrap:wrap}
.cm-tab{border:0;background:transparent;color:var(--mut);font:inherit;font-weight:600;font-size:.9rem;
  padding:.55em 1.1em;border-radius:999px;cursor:pointer;transition:.16s;display:inline-flex;align-items:center;gap:.45em}
.cm-tab:hover{color:var(--txt)}
.cm-tab.cm-tab-active{background:var(--accent);color:var(--accent-ink)}
.cm-tab-count{font-size:.72rem;background:rgba(255,255,255,.12);border-radius:999px;padding:.05em .5em;font-variant-numeric:tabular-nums}
.cm-tab.cm-tab-active .cm-tab-count{background:rgba(6,43,41,.25)}
.cm-tabpanel{animation:cmFade .25s var(--ease)}
@keyframes cmFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ── forms ── */
.cm-field{display:block;margin-bottom:1rem}
.cm-field>span{display:block;font-size:.82rem;color:var(--mut);margin-bottom:.35rem;font-weight:500}
.cm-field input,.cm-field textarea,.cm-field select{width:100%;background:var(--bg2);border:1px solid var(--line);
  border-radius:var(--radius-sm);color:var(--txt);font:inherit;padding:.7em .9em;transition:.15s}
.cm-field textarea{resize:vertical;min-height:92px;line-height:1.5}
.cm-field input:focus-visible,.cm-field textarea:focus-visible,.cm-field select:focus-visible{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}
.cm-field-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.cm-check{display:flex;gap:.55em;align-items:flex-start;font-size:.9rem;color:var(--txt);margin-bottom:.8rem;cursor:pointer}
.cm-check input{margin-top:.25em;accent-color:var(--accent)}
.cm-check small{color:var(--mut);display:block}
.cm-warn{font-size:.82rem;color:var(--warn);background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.3);
  border-radius:var(--radius-sm);padding:.6em .8em;margin-bottom:.9rem}
.cm-formmsg{font-size:.88rem;min-height:1.2em;margin:.2rem 0 .8rem}
.cm-formmsg.err{color:var(--err)} .cm-formmsg.ok{color:var(--ok)}

/* ── buttons ── (наследуем .btn из landing.css; добавляем размеры/варианты) */
.btn-sm{padding:.5em .9em;font-size:.86rem}
.btn-danger{background:rgba(251,113,133,.14);color:var(--err);border:1px solid rgba(251,113,133,.35)}
.btn-danger:hover{background:rgba(251,113,133,.22)}
.btn-row{display:flex;gap:.6rem;flex-wrap:wrap}

/* ── tables (admin) ── */
.cm-table{width:100%;border-collapse:collapse;font-size:.9rem}
.cm-table th{text-align:left;color:var(--mut);font-weight:600;font-size:.8rem;text-transform:uppercase;
  letter-spacing:.04em;padding:.7em .8em;border-bottom:1px solid var(--line)}
.cm-table td{padding:.7em .8em;border-bottom:1px solid var(--line);vertical-align:middle}
.cm-table tr:hover td{background:rgba(255,255,255,.02)}
.cm-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}
.cm-mono{font-variant-numeric:tabular-nums;color:var(--mut);font-size:.85rem}

/* ── empty/loading/error states ── */
.cm-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.7rem;
  padding:3rem 1.5rem;color:var(--mut)}
.cm-mascot{width:140px;height:auto;opacity:.95;filter:drop-shadow(0 12px 28px rgba(0,0,0,.4))}
.cm-state-title{font-size:1.2rem;color:var(--txt)}
.cm-state-txt{font-size:.95rem;max-width:42ch}
.cm-state .btn{margin-top:.4rem}
.cm-spinner{width:38px;height:38px;border:3px solid var(--line2);border-top-color:var(--accent);
  border-radius:50%;animation:cmSpin .8s linear infinite}
@keyframes cmSpin{to{transform:rotate(360deg)}}

/* ── toasts ── */
.cm-toasts{position:fixed;right:1.2rem;bottom:1.2rem;z-index:200;display:flex;flex-direction:column;gap:.6rem;pointer-events:none}
.cm-toast{pointer-events:auto;min-width:220px;max-width:340px;padding:.8em 1em;border-radius:var(--radius-sm);
  font-size:.9rem;font-weight:500;color:var(--txt);background:var(--surface-solid);border:1px solid var(--line);
  box-shadow:0 18px 40px -18px rgba(0,0,0,.7);opacity:0;transform:translateX(20px);transition:.3s var(--ease)}
.cm-toast-in{opacity:1;transform:none}
.cm-toast-ok{border-color:rgba(52,211,153,.4)}
.cm-toast-err{border-color:rgba(251,113,133,.45)}
.cm-toast-warn{border-color:rgba(251,191,36,.4)}

/* ── modal ── */
.cm-modal-back{position:fixed;inset:0;z-index:150;background:rgba(5,5,7,.72);backdrop-filter:blur(6px);
  display:grid;place-items:center;padding:1.5rem;animation:cmFade .2s var(--ease)}
.cm-modal{width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;
  background:var(--surface-solid);border:1px solid var(--line2);border-radius:var(--radius);
  box-shadow:0 30px 80px -30px rgba(0,0,0,.8);overflow:hidden}
.cm-modal-wide{max-width:760px}
.cm-modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.4rem;border-bottom:1px solid var(--line)}
.cm-modal-head h2{font-size:1.2rem}
.cm-modal-x{background:none;border:0;color:var(--mut);font-size:1.6rem;line-height:1;cursor:pointer;padding:.1em .3em;border-radius:8px;transition:.15s}
.cm-modal-x:hover{color:var(--txt);background:rgba(255,255,255,.06)}
.cm-modal-body{padding:1.4rem;overflow-y:auto}
.cm-modal-foot{padding:1rem 1.4rem;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:.6rem}

/* ── profile / cabinet specifics ── */
.cm-profile{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap}
.cm-avatar{width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--accent-h));
  color:var(--accent-ink);display:grid;place-items:center;font-weight:800;font-size:1.5rem;flex-shrink:0}
.cm-profile-main{flex:1;min-width:180px}
.cm-profile-main h2{font-size:1.25rem}
.cm-profile-main .cm-email{color:var(--mut);font-size:.9rem}
.cm-roles{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.5rem}
.cm-balance{text-align:right}
.cm-balance .cm-bal-num{font-size:1.8rem;font-weight:800;color:var(--carrot);font-variant-numeric:tabular-nums;line-height:1}
.cm-balance .cm-bal-lbl{color:var(--mut);font-size:.8rem}

.cm-tg-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  padding:1.1rem 1.3rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);margin-top:1rem}
.cm-tg-info{display:flex;align-items:center;gap:.8rem}
.cm-tg-ico{width:40px;height:40px;border-radius:12px;background:rgba(34,158,217,.14);display:grid;place-items:center;color:#34a9e6}
.cm-tg-info b{display:block}
.cm-tg-info span{color:var(--mut);font-size:.86rem}

/* notifications */
.cm-notif{display:flex;gap:.8rem;align-items:flex-start;padding:.9rem 1.1rem;border:1px solid var(--line);
  border-radius:var(--radius-sm);background:var(--surface);margin-bottom:.6rem;transition:.18s}
.cm-notif.cm-notif-pending{border-color:var(--line-neon)}
.cm-notif-dot{width:8px;height:8px;border-radius:50%;background:var(--mut);margin-top:.45em;flex-shrink:0}
.cm-notif-pending .cm-notif-dot{background:var(--accent);box-shadow:0 0 8px var(--accent)}
.cm-notif-body{flex:1}
.cm-notif-body p{font-size:.92rem;line-height:1.4}
.cm-notif-time{color:var(--dim);font-size:.78rem;margin-top:.2rem}
.cm-notif-read{background:none;border:0;color:var(--accent);font:inherit;font-size:.82rem;cursor:pointer;white-space:nowrap}

/* offers list (order detail) */
.cm-offer{border:1px solid var(--line);border-radius:var(--radius-sm);padding:1rem 1.1rem;margin-bottom:.7rem;background:var(--surface)}
.cm-offer-head{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:.5rem}
.cm-offer-master{font-weight:600}
.cm-offer-meta{display:flex;gap:1.1rem;flex-wrap:wrap;color:var(--mut);font-size:.86rem;margin-bottom:.5rem}
.cm-offer-meta b{color:var(--txt)}
.cm-offer-comment{color:var(--txt);font-size:.92rem;line-height:1.5;white-space:pre-wrap}

/* reactions */
.cm-react{display:inline-flex;align-items:center;gap:.35em;background:rgba(255,255,255,.04);border:1px solid var(--line);
  border-radius:999px;padding:.35em .8em;font:inherit;font-size:.84rem;color:var(--mut);cursor:pointer;transition:.16s}
.cm-react:hover{border-color:var(--line-neon);color:var(--accent)}
.cm-react.cm-react-on{color:var(--accent);border-color:var(--line-neon);background:var(--accent-soft)}
.cm-react-row{display:flex;gap:.5rem;flex-wrap:wrap}

/* filter bar */
.cm-filters{display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:1.4rem;align-items:center}
.cm-filters input,.cm-filters select{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius-sm);
  color:var(--txt);font:inherit;font-size:.9rem;padding:.55em .8em}
.cm-filters input:focus-visible,.cm-filters select:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}

/* detail layout */
.cm-detail{display:grid;grid-template-columns:1.4fr 1fr;gap:1.5rem;align-items:start}
.cm-detail-meta{display:grid;gap:.7rem}
.cm-detail-meta .cm-row{display:flex;justify-content:space-between;gap:1rem;padding:.5em 0;border-bottom:1px solid var(--line)}
.cm-detail-meta .cm-row span:first-child{color:var(--mut)}
.cm-back{display:inline-flex;align-items:center;gap:.4em;color:var(--mut);font-size:.9rem;margin-bottom:1rem}
.cm-back:hover{color:var(--accent)}

@media(max-width:760px){
  .cm-detail{grid-template-columns:1fr}
  .cm-field-row{grid-template-columns:1fr}
  .cm-nav-links{display:none}
  .cm-mascot{width:110px}
}

/* ════════════════════════════════════════════════════════════════════
   POP design на платформе (Биржа/Сообщество/Кабинет/Админка) = ТОТ ЖЕ
   светлый Gen-Z, что профиль/группы/витрина. Страницы грузят pop.css
   (хедер pp-nav, токены, шрифты Inter/Unbounded, мягкие тени), а тут
   cm-* компоненты ВЫРОВНЕНЫ под pop.css: карточки с soft-shadow и
   радиусом 22px, заголовки Unbounded, кнопки-пилюли коралл→фиолет.
   pop.css задаёт --bg/--ink/--line/--card/--grad-hero/--r/шрифты;
   тут — только cm-only токены + выравнивание cm-компонентов.
   Редактор /app остаётся ТЁМНЫМ (инструмент).
   ════════════════════════════════════════════════════════════════════ */
:root{
  --surface:#FFFFFF; --surface2:#FFFFFF; --surface-solid:#FFFFFF; --panel:#FFFFFF;
  --txt:#141414; --mut:#5B5B66; --dim:#8A8A92; --muted:#8A8A92;
  --line-neon:rgba(124,92,255,.42);
  --accent:#7C5CFF; --accent-h:#6B4AEE; --accent-ink:#FFFFFF;
  --cyan:#7C5CFF; --carrot:#FF7A1A; --magenta:#FF5E7E; --accent2:#FF7A1A;
  --accent-soft:rgba(124,92,255,.10); --accent-ring:rgba(124,92,255,.22);
  --radius:22px; --radius-sm:14px;
  --glow-blue:none; --glow-cyan:none; --glow-magenta:none;
}
/* фон НЕ задаём — candy-подсветки (radial коралл/фиолет) приходят из pop.css body */
body{color:var(--txt);font-family:'Inter',system-ui,-apple-system,sans-serif}

/* host шапки нейтрализуем: pp-nav (из pop.css) рисует mountNav внутрь него,
   у pp-nav свой sticky/фон — старый тёмный cm-бар не нужен */
.cm-app-nav{position:static;display:block;max-width:none;margin:0;padding:0;backdrop-filter:none}
.cm-app-nav::before{display:none}

/* заголовки → Unbounded (как в pop) */
.cm-page-head h1,.cm-card-title,.cm-tile-title,.cm-state-title,.cm-modal-head h2,
.cm-profile-main h2,.cm-balance .cm-bal-num{font-family:'Unbounded',system-ui,sans-serif;letter-spacing:-.02em}

/* карточки/поверхности → глубокая Pop-тень с фиолетовой подсветкой, крупный радиус */
.cm-card,.cm-tile,.cm-table-wrap,.cm-tg-row,.cm-notif,.cm-offer{
  background:#fff;border:1px solid var(--line);border-radius:24px;
  box-shadow:0 10px 34px -16px rgba(124,92,255,.20), 0 2px 10px rgba(20,20,20,.05)}
.cm-card{padding:1.6rem}
.cm-tile:hover{transform:translateY(-3px);border-color:var(--line);box-shadow:0 18px 44px -14px rgba(124,92,255,.30)}
.cm-tile-media{background:var(--bg2)}
.cm-wrap{padding-top:2.6rem}

/* кнопки → пилюли; primary = градиент коралл→фиолет с НЕОНОВОЙ подсветкой (канон lp-btn) */
.btn{border-radius:999px;font-weight:700}
.btn-primary{background:linear-gradient(135deg,#FF5E7E,#7C5CFF);color:#fff;border:none;
  box-shadow:0 12px 28px -10px rgba(124,92,255,.7);transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s}
.btn-primary:hover{background:linear-gradient(135deg,#FF5E7E,#7C5CFF);box-shadow:0 18px 36px -10px rgba(124,92,255,.85);transform:translateY(-2px)}
.btn-ghost,.btn-secondary{background:#fff;color:var(--txt);border:1.5px solid var(--line2)}
.btn-ghost:hover{border-color:#7C5CFF;box-shadow:none}
.btn-danger{background:rgba(255,77,94,.10);color:var(--err);border:1px solid rgba(255,77,94,.30)}

/* табы → трек bg2, активная = белая пилюля с тенью (как pp-roleswitch) */
.cm-tabs{background:var(--bg2);border:1px solid var(--line)}
.cm-tab.cm-tab-active{background:#fff;color:var(--ink);box-shadow:0 8px 30px rgba(20,20,20,.06)}
.cm-tab-count{background:rgba(20,20,20,.07)}
.cm-tab.cm-tab-active .cm-tab-count{background:var(--accent-soft);color:var(--accent)}

/* поля ввода → pp-input (радиус, фиолетовый фокус) */
.cm-field input,.cm-field textarea,.cm-field select,.cm-filters input,.cm-filters select{
  background:#fff;border:1.5px solid var(--line);border-radius:14px;color:var(--ink)}
.cm-field input:focus-visible,.cm-field textarea:focus-visible,.cm-field select:focus-visible,
.cm-filters input:focus-visible,.cm-filters select:focus-visible{
  border-color:#7C5CFF;box-shadow:0 0 0 3px rgba(124,92,255,.15)}

/* статус-пилюли/теги/реакции — светлые подложки */
.cm-pill-mut{background:rgba(20,20,20,.05)}
.cm-tag{background:rgba(20,20,20,.04)}
.cm-react{background:#fff;border:1px solid var(--line2)}
.cm-react.cm-react-on{background:var(--accent-soft);border-color:#7C5CFF;color:var(--accent)}
.cm-table tr:hover td{background:rgba(124,92,255,.05)}
.cm-modal-x:hover{background:rgba(20,20,20,.06)}
.cm-avatar{background:linear-gradient(120deg,#2E6BFF,#7C5CFF)}
.cm-mascot{filter:drop-shadow(0 12px 28px rgba(124,92,255,.18))}
.cm-spinner{border-color:var(--line2);border-top-color:#7C5CFF}
