:root{
  --red:#C22222; --red-d:#9e1b1b; --ink:#262626; --muted:#6b7280; --line:#E5E5E5;
  --bg:#f5f6f8; --card:#fff; --ok:#1a7f37; --warn:#b26a00; --r:17px;
  --shadow:0 1px 3px rgba(16,24,40,.06),0 6px 18px rgba(16,24,40,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Montserrat',-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg) url('/brand/bg-workshop.svg');background-size:430px;background-attachment:fixed;line-height:1.55;font-weight:500;-webkit-font-smoothing:antialiased}
a{color:var(--red);text-decoration:none}
.wrap{max-width:1060px;margin:0 auto;padding:0 18px}

/* header — белый, с настоящим логотипом (канон: не заливать красным крупные площади) */
.top{background:#fff;border-bottom:1px solid var(--line);box-shadow:0 1px 0 rgba(16,24,40,.03);position:sticky;top:0;z-index:40}
.top-in{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{height:40px;width:auto;display:block}
.brand-div{width:1px;height:30px;background:var(--line)}
.brand-sub{font-weight:600;font-size:13px;color:var(--muted);line-height:1.2;letter-spacing:.2px}
.brand-sub b{display:block;font-weight:800;font-size:15px;color:var(--ink);letter-spacing:-.1px}
/* имя менеджера — бейдж-пилюля с контуром (заметно, не по-детски) */
.who{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:13.5px;color:var(--ink);background:#fff;border:1.5px solid var(--ink);border-radius:999px;padding:7px 16px 7px 13px;box-shadow:0 1px 2px rgba(16,24,40,.05)}
.who:before{content:'';width:8px;height:8px;border-radius:50%;background:var(--red);flex:0 0 auto}
.who.admin{border-color:var(--red);color:var(--red)}

/* generic */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:22px}
.btn{appearance:none;border:0;border-radius:12px;padding:11px 18px;font:inherit;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:transform .12s,background .15s,box-shadow .15s,border-color .15s}
.ic-svg{display:block;flex:0 0 auto}
.btn:hover{transform:translateY(-1px) scale(1.025)}
.btn:active{transform:translateY(0) scale(.99)}
.btn.primary{background:var(--red);color:#fff}
.btn.primary:hover{background:var(--red-d);box-shadow:0 6px 16px rgba(194,34,34,.22)}
.btn.primary:disabled{background:#d9b3b3;cursor:not-allowed;transform:none;box-shadow:none}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--red);color:var(--red)}
.btn.sm{padding:7px 13px;font-size:13px;border-radius:10px;font-weight:700}
.muted{color:var(--muted)}
.center{display:flex;align-items:center;justify-content:center;min-height:70vh}

/* cabinet */
.section-title{font-weight:800;font-size:22px;margin:26px 0 14px;letter-spacing:-.2px}
.cases{display:grid;gap:12px}
.case-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:#fff;border:1px solid var(--line);border-radius:14px;cursor:pointer;transition:.12s}
.case-row:hover{border-color:#cfd3d8;transform:translateY(-1px)}
.case-row .t{font-weight:700}
.case-row .s{font-size:12px;color:var(--muted)}
.badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;white-space:nowrap}
.badge.draft{background:#eef0f2;color:#555}
.badge.submitted{background:#fff4d6;color:#8a6d00}
.badge.needs_info{background:#ffe8e8;color:#a12626}
.badge.accepted,.badge.published,.badge.payable,.badge.paid{background:#e7f6ec;color:#1a7f37}
.badge.rejected{background:#ffe8e8;color:#a12626}
.score-pill{font-weight:800;font-size:13px;padding:3px 10px;border-radius:999px;background:#f0f2f4}
.score-pill.good{background:#e7f6ec;color:#1a7f37}

/* editor layout */
.editor{display:grid;grid-template-columns:240px 1fr;gap:22px;align-items:start;margin-top:18px}
.steps{position:sticky;top:16px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:10px;display:grid;gap:2px}
.step-item{display:flex;align-items:center;gap:9px;padding:10px 11px;border-radius:11px;cursor:pointer;font-size:14px;font-weight:700;color:#3a3f45;transition:background .12s,transform .12s}
.step-item:hover{background:#f3f4f6;transform:translateX(2px)}
.step-item.active{background:#fbecec;color:var(--red)}
.step-item .dot{width:20px;height:20px;border-radius:50%;border:2px solid #cfd3d8;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex:0 0 auto}
.step-item.done .dot{background:var(--ok);border-color:var(--ok);color:#fff}
.step-item.done:not(.active){background:#f1faf4}
.step-item.done:not(.active) > span:last-child{color:#1a7f37}
.step-item .ic{display:inline-flex;align-items:center;flex:0 0 auto}

.panel{min-height:60vh}
.panel h2{margin:0 0 4px;font-size:25px;font-weight:800;letter-spacing:-.3px;display:flex;align-items:center;gap:11px}
.panel .intro{color:var(--muted);margin:0 0 18px;font-size:14px}

.progressbar{height:8px;background:#eceef1;border-radius:999px;overflow:hidden;margin:0 0 16px}
.progressbar > i{display:block;height:100%;background:var(--red);transition:width .25s}

/* fields */
.field{margin-bottom:20px}
.field label{display:block;font-weight:700;margin-bottom:5px;font-size:14.5px}
.field label .req{color:var(--red);margin-left:3px}
.hint{color:var(--muted);font-size:13px;margin:0 0 8px}
.example{font-size:13px;background:#f7f8fa;border-left:3px solid var(--red);border-radius:8px;padding:8px 12px;margin:0 0 8px;color:#3a3f45}
input[type=text],input[type=number],textarea,select{
  width:100%;font:inherit;padding:11px 13px;border:1px solid var(--line);border-radius:12px;background:#fff;transition:.12s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(194,34,34,.1)}
textarea{min-height:110px;resize:vertical}
.counter{font-size:12px;color:var(--muted);margin-top:4px;text-align:right}
.counter.bad{color:var(--warn)}
.opts{display:grid;gap:8px}
.opt{display:flex;align-items:flex-start;gap:9px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;cursor:pointer;font-size:14px}
.opt:hover{border-color:#cfd3d8}
.opt.checked{border-color:var(--red);background:#fdf3f3}
.opt input{margin-top:2px}

/* photos */
.photo-guide{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:6px 0 16px}
.photo-guide .col{background:#f7f8fa;border-radius:12px;padding:12px 14px;font-size:13px}
.photo-guide .col h4{margin:0 0 8px;font-size:13px}
.photo-guide ul{margin:0;padding-left:18px}
.photo-guide li{margin:3px 0}
.dropzone{border:2px dashed #cfd3d8;border-radius:14px;padding:26px;text-align:center;color:var(--muted);cursor:pointer;transition:.12s}
.dropzone.drag{border-color:var(--red);background:#fdf3f3;color:var(--red)}
.grid-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:14px}
.ph{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
.ph img{width:100%;height:120px;object-fit:cover;display:block;background:#eee}
.ph .meta{padding:8px 10px;font-size:11.5px}
.ph .meta .x{float:right;color:var(--muted);cursor:pointer;font-weight:700}
.ph.rej{border-color:#f1b6b6}
.ph .v-ok{color:var(--ok)}
.ph .v-warn{color:var(--warn)}
.ph .v-rej{color:var(--red)}

/* footer bar */
.bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:24px;padding-top:18px;border-top:1px solid var(--line)}
.bar .nav{display:flex;gap:10px}
.savestate{font-size:12.5px;color:var(--muted)}
.checklist{margin-top:14px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.checklist h4{margin:0 0 8px;font-size:14px}
.checklist .miss{color:var(--red);font-size:13px;margin:3px 0}
.checklist .warn{color:var(--warn);font-size:13px;margin:3px 0}
/* авто-анализ движка (подсказки админу при ревью) */
.analysis{margin-top:14px}
.analysis h4{margin:0 0 10px;font-size:15px;font-weight:800}
.analysis.deep{border-color:#d3c0ef;background:#fcfaff}
.af{font-size:13.5px;padding:9px 12px;border-radius:10px;margin:6px 0;border-left:3px solid #cfd3d8;background:#f7f8fa;color:#3a3f45}
.af.high{border-left-color:var(--red);background:#fdf3f3;color:#8a1f1f}
.af.med{border-left-color:var(--warn);background:#fffaf0;color:#7a5200}
.af.low{border-left-color:#9aa2ab}
.af-ok{color:var(--ok);font-weight:700;font-size:14px}
.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:#1f2328;color:#fff;padding:11px 18px;border-radius:12px;font-size:14px;opacity:0;transition:.2s;pointer-events:none;z-index:50}
.toast.show{opacity:1}

/* review (read-only просмотр кейса) */
.open-hint{color:var(--red);font-weight:700}
.rv-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px}
.rv-title{font-weight:800;font-size:20px}
.review{display:grid;gap:14px;margin-top:14px}
.rv-block h3{margin:0 0 10px;font-size:16px;color:var(--ink);display:flex;align-items:center;gap:8px}
.rv-field{padding:9px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:220px 1fr;gap:16px}
.rv-block .rv-field:first-of-type{border-top:0;padding-top:0}
.rv-label{font-weight:600;font-size:13.5px;color:var(--muted)}
.rv-val{font-size:14.5px;white-space:pre-wrap;word-break:break-word}
.rv-val.empty{color:#c3c8ce}
.rv-val ul{margin:0;padding-left:18px}
.rv-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.rv-ph{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
.rv-ph img{width:100%;height:130px;object-fit:cover;display:block;cursor:zoom-in}
.rv-ph.rej{padding:12px}
.rv-rej{color:var(--red);font-size:12.5px}
.rv-bar{position:sticky;bottom:0;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:14px 18px;margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.lb{position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:70;display:flex;align-items:center;justify-content:center;padding:24px;cursor:zoom-out}
.lb img{max-width:100%;max-height:100%;border-radius:8px}

/* фото по этапам заказа */
.pstage{border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin:12px 0;transition:border-color .12s}
.pstage:hover{border-color:#d4d4d4}
.pstage-h{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:800}
.pstage-ic{display:inline-flex;align-items:center}
.pstage-hint{color:var(--muted);font-size:12.5px;margin:5px 0 11px;line-height:1.45}
.ph .meta .v{margin:2px 0}
.ph .cap{width:100%;margin-top:6px;font:inherit;font-weight:500;font-size:12px;padding:6px 8px;border:1px solid var(--line);border-radius:8px}
.ph .cap:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 2px rgba(194,34,34,.1)}

/* review: фото, сгруппированные по этапам */
.rv-pstage{margin:12px 0}
.rv-pstage-h{font-weight:800;font-size:14px;margin:0 0 8px;display:flex;align-items:center;gap:7px}
.rv-cap{padding:6px 9px;font-size:11.5px;color:var(--ink);border-top:1px solid var(--line);background:#fafbfc}

/* админ: лидерборд (3 колонки) с раскрытием завершённых кейсов */
.lb-item{border-bottom:1px solid var(--line)}
.lb-item:last-child{border-bottom:0}
.lb-row{display:grid;grid-template-columns:1fr auto auto;gap:16px;align-items:center;padding:10px 0}
.lb-row.has{cursor:pointer;border-radius:8px;transition:background .12s}
.lb-row.has:hover{background:#fafbfc}
.lb-row .lb-n{font-weight:700}
.lb-row .lb-a{font-weight:800;color:var(--ok);white-space:nowrap}
.lb-row .lb-t{color:var(--muted);font-size:13px;white-space:nowrap;text-align:right;min-width:62px}
.lb-chev{display:inline-block;color:var(--red);font-weight:900;transition:transform .18s}
.lb-item.open .lb-chev{transform:rotate(90deg)}
.lb-cases{display:none;padding:2px 0 12px 16px}
.lb-item.open .lb-cases{display:block}
.lb-case{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 12px;margin:6px 0;border:1px solid var(--line);border-radius:10px;cursor:pointer;background:#fafbfc;transition:.12s}
.lb-case:hover{border-color:var(--red);transform:translateX(2px)}
.lb-case .t{font-weight:700;font-size:14px}
.lb-case .s{font-size:12px;color:var(--muted);font-weight:500}

/* баннер кабинета «кейс = деньги» — по центру, симметрично, капсом (Montserrat Black) */
.cab-banner{margin-top:22px;border-radius:var(--r);overflow:hidden;
  background:radial-gradient(120% 140% at 50% -20%,#d83434 0%,var(--red) 45%,var(--red-d) 100%);
  color:#fff;box-shadow:0 10px 30px rgba(194,34,34,.22)}
.cab-banner-in{position:relative;text-align:center;padding:30px 26px 32px;
  background:url('/brand/bg-workshop.svg');background-blend-mode:soft-light}
.cab-banner-badge{display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:13px;letter-spacing:.4px;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.35);border-radius:999px;padding:6px 15px;margin-bottom:14px}
.cab-banner-badge:before{content:'₽';display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#fff;color:var(--red);font-weight:900;font-size:12px}
.cab-banner-h{font-weight:900;font-size:30px;line-height:1.12;letter-spacing:.3px;margin:0 auto;max-width:18ch;text-transform:uppercase;text-shadow:0 2px 10px rgba(0,0,0,.12)}
.cab-banner-p{margin:12px auto 0;max-width:62ch;font-size:14.5px;font-weight:500;opacity:.96}

/* ряд действий под баннером */
.cab-actions{display:flex;align-items:center;gap:12px;margin-top:18px;flex-wrap:wrap}
.cab-actions .btn{font-size:15px;padding:12px 22px}
.cab-actions .spacer{flex:1}
.cab-stat{font-size:13px;color:var(--muted);font-weight:700}
.cab-stat b{color:var(--ink)}

/* модальное окно (памятка менеджера и пр.) — поверх, по центру, без проваливания */
.modal-ov{position:fixed;inset:0;background:rgba(20,16,16,.5);z-index:80;display:flex;align-items:flex-start;justify-content:center;padding:42px 18px;overflow:auto;animation:celFade .2s ease}
.modal-card{background:#fff;border-radius:var(--r);box-shadow:0 24px 70px rgba(0,0,0,.3);max-width:680px;width:100%;overflow:hidden;animation:celPop .3s cubic-bezier(.2,1.2,.5,1)}
.modal-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:20px 24px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff;z-index:2}
.modal-title{font-weight:800;font-size:20px;letter-spacing:-.2px}
.modal-sub{font-size:13px;color:var(--muted);margin-top:2px}
.modal-x{appearance:none;border:1px solid var(--line);background:#fff;border-radius:10px;width:36px;height:36px;font-size:15px;cursor:pointer;color:var(--ink);flex:0 0 auto;transition:.12s}
.modal-x:hover{border-color:var(--red);color:var(--red)}
.memo-modal .onb-acc{padding:16px 20px 20px}

/* онбординг (памятка) — аккордеон-кнопки */
.onb-acc{display:grid;gap:8px}
.onb-item{border:1px solid var(--line);border-radius:13px;background:#fff;overflow:hidden;transition:border-color .12s}
.onb-item.open{border-color:#e7b9b9}
.onb-head{display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:#fff;border:0;padding:13px 16px;font:inherit;font-weight:800;font-size:14.5px;color:var(--ink);cursor:pointer;transition:background .12s}
.onb-head:hover{background:#fbecec}
.onb-ic{display:inline-flex;align-items:center;flex:0 0 auto}
.onb-ttl{flex:1}
.onb-chev{color:var(--red);font-weight:800;transition:transform .18s}
.onb-item.open .onb-chev{transform:rotate(90deg)}
.onb-body{display:none;border-top:1px solid var(--line)}
.onb-item.open .onb-body{display:block}
.onb-inner{padding:14px 18px;font-size:13.5px}
.onb-lead{margin:0 0 10px;color:#3a3f45}
.onb-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}
.onb-list li{padding-left:17px;position:relative}
.onb-list li:before{content:'•';color:var(--red);position:absolute;left:0;font-weight:800}
.onb-list b{color:var(--ink)}
.onb-faq{display:grid;gap:11px}
.onb-q{font-weight:700;color:var(--ink)}
.onb-a{color:#3a3f45;margin-top:2px}
.onb-note{margin-top:12px;background:#f7f8fa;border-left:3px solid var(--red);border-radius:8px;padding:10px 13px;color:#3a3f45;font-size:13px}

/* празднование одобрения — конфетти + кубок + фанфары */
.cel-canvas{position:fixed;inset:0;pointer-events:none;z-index:90}
.cel-ov{position:fixed;inset:0;background:rgba(20,16,16,.55);z-index:95;display:flex;align-items:center;justify-content:center;padding:20px;animation:celFade .25s ease}
.cel-card{background:#fff;border-radius:22px;box-shadow:0 20px 60px rgba(0,0,0,.32);padding:34px 40px;text-align:center;max-width:420px;animation:celPop .42s cubic-bezier(.2,1.3,.5,1)}
.cel-trophy{line-height:1;animation:celBounce 1s ease infinite}
.cel-trophy svg{display:block;margin:0 auto}
.cel-h{font-weight:800;font-size:28px;color:var(--red);margin:8px 0 4px}
.cel-sub{font-size:15px;color:var(--ink)}
.cel-money{display:inline-block;margin:14px 0 18px;background:#e7f6ec;color:var(--ok);font-weight:800;font-size:18px;padding:8px 18px;border-radius:999px}
.cel-card .btn{font-size:16px;padding:12px 30px}
@keyframes celFade{from{opacity:0}to{opacity:1}}
@keyframes celPop{from{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes celBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-11px)}}

/* ─── Ф6.2 витрина публикационного пакета (админ) ─── */
.pub{margin-top:14px}
.pub-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.pub-head h3{margin:0;font-size:16px;display:flex;align-items:center;gap:8px}
.pub-badge{font-size:11px;font-weight:800;padding:4px 11px;border-radius:999px;white-space:nowrap}
.pub-badge.np{background:#fff4d6;color:#8a6d00}
.pub-badge.rd{background:#e7f6ec;color:#1a7f37}
.pub-badge.st{background:#ffe8e8;color:#a12626}
.pub-gate{font-size:13.5px;border-radius:12px;padding:11px 14px;margin-bottom:12px}
.pub-gate.ok{background:#f1faf4;color:#1a7f37;border:1px solid #bfe6cc}
.pub-gate.bad{background:#fff6f6;color:#8a1f1f;border:1px solid #f1b6b6}
.pub-gate ul{margin:6px 0 0;padding-left:18px}
.pub-gate li{margin:3px 0}
.pub-sub{font-weight:800;font-size:13.5px;margin:16px 0 8px;color:var(--ink)}
.pub-sub .muted{font-weight:500;font-size:12px}
.pub-stale{background:#fff6f6;border:1px solid #f1b6b6;color:#8a1f1f;border-radius:12px;padding:11px 14px;font-size:13.5px;margin-bottom:12px}
.pub code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.92em;background:#eef0f2;padding:1px 5px;border-radius:5px}
/* публичное превью */
.pp-grid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.pp-row{display:grid;grid-template-columns:160px 1fr;gap:12px;background:#fff;padding:8px 12px;font-size:13.5px}
.pp-row span{color:var(--muted);font-weight:600}
.pp-row b{font-weight:600;word-break:break-word}
.pp-row i{color:var(--muted)}
.pp-photos,.pub-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}
.pp-ph{border:1px solid var(--line);border-radius:9px;overflow:hidden;text-align:center;background:#fff}
.pp-ph img{width:100%;height:64px;object-fit:cover;display:block;cursor:zoom-in}
.pp-ph code{font-size:10px;color:var(--muted);display:block;padding:2px;word-break:break-all;background:none}
/* импорт пакета */
.pub-importbox textarea{min-height:120px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px}
.pub-importbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px;flex-wrap:wrap}
.pub-importbar .muted{font-size:12.5px}
/* ready: заголовок + табы каналов */
.pub-pkgtitle{margin:4px 0 12px;font-size:15px}
.pub-pkgtitle .muted{font-size:13px;font-weight:500;margin-top:3px}
.pub-tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:12px;flex-wrap:wrap}
.pub-tab{appearance:none;border:0;background:none;font:inherit;font-weight:700;font-size:13.5px;color:#5a6068;padding:9px 12px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:.12s}
.pub-tab:hover{color:var(--red)}
.pub-tab.on{color:var(--red);border-bottom-color:var(--red)}
.pub-chst{font-style:normal;font-size:11px}
.pub-chst.exported,.pub-chst.sent{color:var(--ok)}
.pub-ch{font-size:13.5px}
.pub-chline{font-size:12.5px;color:var(--muted);margin-bottom:8px}
.pub-chst-txt.exported,.pub-chst-txt.sent{color:var(--ok)}
.pub-chst-txt.failed{color:var(--red)}
.pub-note{font-size:13px;color:#3a3f45;background:#f7f8fa;border-left:3px solid var(--red);border-radius:8px;padding:9px 12px;margin-bottom:10px}
.pub-locked{font-size:13.5px;color:#8a1f1f;background:#fff6f6;border:1px solid #f1b6b6;border-radius:12px;padding:14px}
.pub-frame{width:100%;height:340px;border:1px solid var(--line);border-radius:12px;background:#fff}
.pub-text{white-space:pre-wrap;word-break:break-word;background:#f7f8fa;border:1px solid var(--line);border-radius:12px;padding:12px 14px;font-family:inherit;font-size:13.5px;margin:0;max-height:340px;overflow:auto}
.pub-cmd{display:flex;align-items:center;gap:10px;background:#1f2328;border-radius:10px;padding:8px 8px 8px 14px;margin-bottom:4px}
.pub-cmd code{font-family:ui-monospace,Consolas,monospace;font-size:13px;flex:1;word-break:break-all;color:#e8eaed;background:none;padding:0}
.pub-chbar{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.pub-ph{border:1px solid var(--line);border-radius:9px;overflow:hidden;background:#fff}
.pub-ph img{width:100%;height:80px;object-fit:cover;display:block;cursor:zoom-in}
.pub-alt{font-size:11px;color:var(--muted);padding:4px 6px;border-top:1px solid var(--line)}
/* журнал решений */
.pub-journal{margin-top:6px}
.pub-logrow{display:flex;align-items:center;gap:10px;padding:7px 0;border-top:1px solid var(--line);font-size:12.5px}
.pub-logch{font-weight:800;min-width:42px}
.pub-logby{flex:1;font-weight:600}
.pub-loggate.ok{color:var(--ok)}
.pub-loggate.bad{color:var(--warn)}
.pub-loghash{color:var(--muted);font-size:11px;background:none}

@media(max-width:760px){.editor{grid-template-columns:1fr}.steps{position:static;display:flex;overflow:auto;gap:6px}.step-item{white-space:nowrap}.photo-guide{grid-template-columns:1fr}
  .rv-field{grid-template-columns:1fr;gap:3px}.rv-head{flex-direction:column;align-items:flex-start}.rv-bar .nav{width:100%}.rv-bar .btn{flex:1}
  .case-row{flex-direction:column;align-items:stretch;gap:10px}.case-row > div:last-child{justify-content:space-between}
  .cel-card{padding:28px 22px}.cel-trophy{font-size:60px}.cel-h{font-size:24px}
  .pp-row{grid-template-columns:1fr;gap:2px}.pub-frame{height:280px}}
