:root{--y:#FFC72C;--ink:#1a1d23;--mut:#8a909a;--line:#e6e8ec;--bg:#f5f6f8}
*{box-sizing:border-box;margin:0;font-family:-apple-system,'Segoe UI',Roboto,Arial,sans-serif}
body{background:var(--bg);color:var(--ink)}
a{color:inherit;text-decoration:none}
header{background:#111;color:#fff;padding:13px 22px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.logo{font-weight:800}.logo b{color:var(--y)}
.nav{display:flex;gap:4px;margin-left:18px}
.nav a{color:#bbb;font-size:13px;padding:7px 13px;border-radius:8px;cursor:pointer;font-weight:600}
.nav a.on{background:var(--y);color:#111}
.right-h{margin-left:auto;display:flex;gap:6px;align-items:center}
.lang span{border:1px solid #444;border-radius:6px;padding:3px 9px;font-size:12px;color:#ccc;cursor:pointer}
.lang span.on{background:var(--y);color:#111;font-weight:700}
.logout{color:#bbb;font-size:12px;margin-left:10px;cursor:pointer}
.kpis{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;padding:18px 22px}
@media(max-width:900px){.kpis{grid-template-columns:repeat(2,1fr)}}
.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;cursor:pointer;transition:.12s;user-select:none}
.kpi:hover{border-color:#cfd3da}
.kpi.on{border-color:var(--y);box-shadow:0 0 0 2px var(--y) inset}
.kpi .v{font-size:26px;font-weight:800}.kpi .l{font-size:11px;color:var(--mut);display:flex;align-items:center;gap:5px;margin-top:3px}
.kpi .dot{width:8px;height:8px;border-radius:50%}
.wrap{display:flex;gap:14px;margin:0 22px 30px;align-items:flex-start}
@media(max-width:900px){.wrap{flex-direction:column}.right{width:100%!important;flex:1 1 auto!important;position:static!important}}
.left{flex:1;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;min-height:520px}
.ltools{padding:12px 14px;border-bottom:1px solid var(--line);display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.ltools input{border:1px solid var(--line);border-radius:7px;padding:7px 11px;font-size:13px;width:180px}
.ltools select{border:1px solid var(--line);border-radius:7px;padding:7px 9px;font-size:13px}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:10px 14px;font-size:13px;border-bottom:1px solid #f0f1f3;vertical-align:top}
th{font-size:11px;text-transform:uppercase;color:var(--mut);letter-spacing:.4px}
tr.r{cursor:pointer}tr.r:hover{background:#fafbfc}tr.r.sel{background:#fff8e6}
td .sn{font-family:ui-monospace,monospace;font-size:11px;color:#999}
.pill{font-size:11px;font-weight:700;color:#fff;padding:3px 9px;border-radius:12px;white-space:nowrap;display:inline-block}
.statuscell{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cflag{font-size:11px;color:#9a5400;font-weight:700;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;background:#fff0e0;border:1px solid #ffcf8f;border-radius:12px;padding:3px 9px}
.right{width:340px;flex:0 0 340px;background:#fff;border:1px solid var(--line);border-radius:14px;position:sticky;top:12px;max-height:calc(100vh - 24px);overflow-x:hidden;overflow-y:auto}
.empty{padding:60px 24px;text-align:center;color:#aaa;font-size:13px}
.rhead{padding:16px 18px;border-bottom:1px solid var(--line)}
.rhead h2{font-size:19px}.rhead .c{color:var(--mut);font-size:12px}
.resbox{margin-top:9px;background:#fff4e6;border:1px solid #ffd79e;border-radius:8px;padding:8px 11px;font-size:12px;color:#9a5400}
.resbox b{font-size:14px}
.rsec{padding:13px 18px}.rsec h4{font-size:11px;text-transform:uppercase;color:var(--mut);letter-spacing:.4px;margin-bottom:8px}
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.gal .g{aspect-ratio:4/3;border-radius:6px;overflow:hidden;background:#22262e;display:flex;align-items:center;justify-content:center}
.gal .g img{width:100%;height:100%;object-fit:cover}
.gal .ph{background:linear-gradient(135deg,#2b2b2b,#444);color:#888;font-size:10px}
.tl{list-style:none;padding-left:6px}.tl li{position:relative;padding:0 0 12px 18px;font-size:12px;color:#555;border-left:2px solid var(--line)}
.tl li b{display:block;color:#1a1d23}.tl li::before{content:'';position:absolute;left:-6px;top:2px;width:10px;height:10px;border-radius:50%;background:var(--y)}
.rfoot{padding:14px 18px}
.rfoot button[disabled]{background:#e6e8ec;color:#9aa0a8;cursor:not-allowed}
.rfoot button,.rfoot a.btn{display:block;width:100%;text-align:center;border:0;border-radius:9px;padding:12px;font-weight:700;cursor:pointer;background:var(--y);color:#111}
/* login */
.login{max-width:360px;margin:9vh auto;background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 26px;text-align:center}
.login .lg{font-weight:800;font-size:20px;margin-bottom:4px}.login .lg b{color:#111;background:var(--y);padding:0 6px;border-radius:4px}
.login p{color:var(--mut);font-size:13px;margin:6px 0 18px}
.login input{width:100%;border:1px solid var(--line);border-radius:9px;padding:12px;font-size:15px;margin-bottom:10px}
.login button{width:100%;border:0;background:#111;color:var(--y);font-weight:700;border-radius:9px;padding:12px;font-size:15px;cursor:pointer}
.login .err{color:#d33;font-size:13px;margin-bottom:10px}
/* admin */
.abar{padding:14px 22px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.abar input,.abar select{border:1px solid var(--line);border-radius:8px;padding:8px 11px;font-size:13px}
.abtn{background:#111;color:var(--y);border:0;border-radius:8px;padding:9px 14px;font-weight:700;cursor:pointer}
.abtn.y{background:var(--y);color:#111}
.acard{margin:0 22px 30px}
.drow{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding:8px 10px;border:1px solid var(--line);border-radius:8px;margin-bottom:6px;font-size:13px;background:#fff}
.drow .nm{flex:1 1 100%;margin-bottom:4px}.drow .st{color:#1f8a4c;font-weight:700}.drow .no{color:#bbb}
.up{font-size:11px;background:#111;color:var(--y);padding:5px 11px;border-radius:6px;font-weight:700;cursor:pointer}
.del{font-size:11px;color:#d33;cursor:pointer;background:none;border:1px solid #f1c2c2;padding:5px 9px;border-radius:6px}
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.5);display:none;align-items:flex-start;justify-content:center;z-index:60;padding:24px;overflow:auto}
.modal-bg.on{display:flex}
.modal{background:#fff;border-radius:14px;max-width:560px;width:100%}
.mh{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.mh h3{font-size:18px}.mx{cursor:pointer;color:#999;font-size:22px}
.mb{padding:16px 20px}
.fld{margin-bottom:12px}.fld label{display:block;font-size:12px;color:var(--mut);margin-bottom:4px}
.fld input,.fld select,.fld textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:9px;font-size:14px}
.note{font-size:12px;color:#b26b00;background:#fff7e6;border:1px solid #ffe2a8;padding:9px 12px;border-radius:8px;margin:0 22px 14px}

/* --- admin dashboard additions --- */
.di{display:flex;gap:3px}.di i{font-style:normal;opacity:.3;font-size:13px}.di i.ok{opacity:1}
.stsel{border:0;color:#fff;font-weight:700;font-size:11px;padding:4px 22px 4px 9px;border-radius:12px;cursor:pointer;-webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='6'%3E%3Cpath d='M0 0l4 6 4-6z' fill='white'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 7px center}
.seg{display:flex;gap:6px;margin:6px 0}
.seg b{flex:1;text-align:center;border:1px solid var(--line);border-radius:7px;padding:7px 4px;font-size:12px;cursor:pointer}
.seg b.on{background:var(--y);border-color:var(--y);font-weight:700}
.rsec .fld{margin-bottom:10px}
.rsec .fld label{display:block;font-size:11px;color:var(--mut);margin-bottom:3px}
.rsec .fld input,.rsec .fld select,.rsec .fld textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:8px;font-size:13px}
.gal .g{position:relative}
.gal .g .delx{position:absolute;top:2px;right:2px;background:rgba(0,0,0,.6);color:#fff;border:0;border-radius:5px;font-size:11px;padding:0 5px;cursor:pointer;line-height:1.6}
.addtile{aspect-ratio:4/3;border:1px dashed var(--line);border-radius:6px;display:flex;align-items:center;justify-content:center;color:#bbb;cursor:pointer;font-size:22px}
.abar{padding:14px 22px;display:flex;gap:10px;align-items:center}
.abar input{border:1px solid var(--line);border-radius:8px;padding:8px 11px;font-size:13px;width:280px}

/* --- lightbox --- */
.gal .g img{cursor:zoom-in}
.lb{position:fixed;inset:0;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;z-index:200}
.lb.on{display:flex}
.lb img{max-width:90vw;max-height:82vh;border-radius:8px;object-fit:contain}
.lb-bar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:10px;padding:14px 18px;color:#fff}
#lb-count{font-size:14px;font-weight:600}
.lb-btn{background:rgba(255,255,255,.16);color:#fff;border:0;border-radius:8px;padding:8px 14px;font-size:14px;font-weight:700;cursor:pointer;text-decoration:none}
.lb-btn:hover{background:rgba(255,255,255,.32)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.16);color:#fff;border:0;width:48px;height:48px;border-radius:50%;font-size:30px;line-height:1;cursor:pointer}
.lb-nav:hover{background:rgba(255,255,255,.32)}
.lb-prev{left:18px}.lb-next{right:18px}

/* одинаковая ширина статус-плашек в таблице */
td .pill{min-width:170px;text-align:center}
td .stsel{min-width:170px}

/* ============ МОБИЛЬНАЯ ВЕРСИЯ (партнёр + админ) ============ */
#mobile{display:none}
@media(max-width:760px){
  .kpis,.wrap{display:none!important}
  #mobile{display:block;padding-bottom:80px}
  header{flex-wrap:wrap;row-gap:8px;padding:12px 14px}
  header .nav{order:3;width:100%;font-size:13px}
  .logo{font-size:15px}
}
.mtop{position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid var(--line,#ececea);padding-top:10px}
.mq{padding:0 14px}
.mq input{width:100%;border:1px solid #e4e4e0;background:#f6f6f4;border-radius:10px;padding:11px 13px;font-size:15px;outline:none}
.mq input:focus{border-color:#f5c800;background:#fff}
.mfstrip{display:flex;gap:6px;overflow-x:auto;padding:10px 14px;scrollbar-width:none}.mfstrip::-webkit-scrollbar{display:none}
.mf{flex:0 0 auto;font-size:12.5px;font-weight:700;padding:7px 12px;border-radius:8px;background:#f1f1ef;color:#555;display:flex;align-items:center;gap:6px;white-space:nowrap}
.mf.on{background:#111;color:#fff}.mf .c{font-size:11px;opacity:.7}.mf .d{width:7px;height:7px;border-radius:50%}
.mcatbar{display:flex;gap:6px;overflow-x:auto;padding:0 14px 10px;scrollbar-width:none}.mcatbar::-webkit-scrollbar{display:none}
.mcc{flex:0 0 auto;font-size:12px;font-weight:600;padding:5px 11px;border-radius:20px;background:#fff;border:1px solid #e4e4e0;color:#666;white-space:nowrap}
.mcc.on{background:#f5c800;border-color:#f5c800;color:#000;font-weight:700}
.mhint{font-size:11px;color:#8d8d88;padding:9px 15px 2px}
.mrow{border-bottom:1px solid #ececea}
.mhead{display:flex;align-items:center;gap:10px;padding:13px 15px;cursor:pointer}
.mleft{min-width:0;flex:1}.mmodel{font-size:16px;font-weight:800;line-height:1.1}
.mcat{font-size:12px;color:#8d8d88;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mright{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex:0 0 auto}
.mpill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:800;color:#fff;padding:4px 9px;border-radius:7px;white-space:nowrap}
.mflag{font-size:11px;font-weight:700;color:#9a5400;background:#fff2e2;border:1px solid #ffd49a;border-radius:7px;padding:2px 7px;white-space:nowrap}
.mchev{color:#ccc;font-size:13px;transition:.2s}.mrow.open .mchev{transform:rotate(90deg);color:#888}
.mdetail{max-height:0;overflow:hidden;transition:max-height .3s ease;background:#fafafa}
.mrow.open .mdetail{max-height:620px}
.mdwrap{padding:6px 15px 16px}
.mkv{display:flex;justify-content:space-between;font-size:13px;padding:7px 0;border-bottom:1px dashed #e6e6e3}
.mkv b{color:#8d8d88;font-weight:600}.msn{font-family:ui-monospace,Menlo,monospace;font-size:12px}
.mgal{display:flex;gap:7px;overflow-x:auto;padding:11px 0 2px}.mgal img{height:74px;width:96px;object-fit:cover;border-radius:9px;flex:0 0 auto}
.mreq{display:block;text-align:center;margin-top:13px;background:#f5c800;color:#000;font-weight:800;font-size:14px;padding:13px;border-radius:11px;text-decoration:none;border:none;width:100%}
.mreq.dim{background:#eee;color:#999;pointer-events:none}
.mempty{text-align:center;color:#8d8d88;padding:50px;font-size:14px}
/* админ-редактирование в строке */
.melabel{font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#8d8d88;margin:14px 0 7px}
.mopts{display:flex;flex-wrap:wrap;gap:6px}
.mopt{font-size:12px;font-weight:700;padding:7px 11px;border-radius:8px;border:1.5px solid #e4e4e0;background:#fff;color:#555;display:flex;align-items:center;gap:6px}
.mopt.on{color:#fff;border-color:transparent}.mopt .d{width:8px;height:8px;border-radius:50%}
.mro{font-size:12px;font-weight:700;padding:7px 11px;border-radius:8px;border:1.5px solid #e4e4e0;background:#fff;color:#555}
.mro.on{background:#fff2e2;border-color:#ffbf66;color:#9a5400}.mro.clr.on{background:#f3f3f3;border-color:#ccc;color:#555}
.mact{display:flex;gap:8px;margin-top:14px}
.mbtn{flex:1;text-align:center;font-size:13px;font-weight:700;padding:11px;border-radius:10px;border:1.5px solid #e4e4e0;background:#fff;color:#333}
.mbtn.del{color:#c0392b;border-color:#f3c2bb}
.mtoast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:#111;color:#fff;font-size:13px;font-weight:600;padding:10px 16px;border-radius:10px;opacity:0;transition:.25s;z-index:60;max-width:90%;text-align:center}
.mtoast.show{opacity:1}
/* админ-моб: больше высоты + галерея/документы */
#mobile.admin .mrow.open .mdetail{max-height:1300px}
.mgal .mthumb{position:relative;flex:0 0 auto}
.mgal .mthumb img{height:74px;width:96px;object-fit:cover;border-radius:9px;display:block}
.mgal .mthumb button{position:absolute;top:3px;right:3px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:11px;line-height:1;cursor:pointer}
.maddtile{flex:0 0 auto;height:74px;width:60px;border:1.5px dashed #ccc;border-radius:9px;background:#fff;color:#999;font-size:22px;cursor:pointer}
/* статус как выпадающий список (моб. админ) */
.mstwrap{position:relative;margin-top:2px}
.mstsel{appearance:none;-webkit-appearance:none;color:#fff;font-weight:800;font-size:15px;border:none;border-radius:9px;padding:12px 40px 12px 14px;width:100%}
.mstarr{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#fff;font-size:12px;pointer-events:none}
