/* ============================================================
   alinatrocenko.pro — Админка · стили
   ============================================================ */
:root{
  --bg:#f5f5f3; --panel:#ffffff; --ink:#0e0e0e; --muted:#71716e; --faint:#a3a3a0;
  --line:rgba(14,14,14,.10); --line-2:rgba(14,14,14,.16);
  --accent:#0e0e0e; --ok:#1f8a4c; --warn:#c2410c; --danger:#b42318;
  --sidebar:#121211; --sidebar-ink:#ededeb; --sidebar-muted:#8a8a86;
  --font:"Onest",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --display:"Golos Text",var(--font);
  --r:10px; --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;}
html,body{height:100%;}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;}
button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;}
a{color:inherit;}
::selection{background:#0e0e0e;color:#fff;}
.mono{font-variant-numeric:tabular-nums;}

/* ---------- boot / login ---------- */
.boot{position:fixed;inset:0;display:grid;place-items:center;background:var(--bg);}
.spin{display:inline-block;width:18px;height:18px;border:2px solid rgba(14,14,14,.18);border-top-color:var(--ink);border-radius:50%;animation:spin .8s linear infinite;}
.spin--big{width:32px;height:32px;border-width:3px;}
@keyframes spin{to{transform:rotate(360deg);}}

.login{min-height:100vh;display:grid;place-items:center;padding:20px;background:var(--bg);}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:34px 30px;width:360px;max-width:100%;box-shadow:0 12px 40px rgba(0,0,0,.06);}
.login-brand{font-family:var(--display);font-size:13px;color:var(--muted);letter-spacing:.05em;}
.login-card h1{font-family:var(--display);font-weight:600;font-size:24px;letter-spacing:-.02em;margin:6px 0 6px;}
.login-card p{margin:0 0 18px;color:var(--muted);font-size:13.5px;}
.err-line{color:var(--danger);font-size:13px;line-height:1.4;background:rgba(180,35,24,.08);border:1px solid rgba(180,35,24,.2);border-radius:7px;padding:7px 10px;margin-top:8px;}

/* ---------- app shell ---------- */
.app{display:grid;grid-template-columns:248px 1fr;grid-template-rows:60px 1fr;height:100vh;grid-template-areas:"side top" "side main";}
.topbar{grid-area:top;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 22px;background:var(--panel);border-bottom:1px solid var(--line);}
.sidebar{grid-area:side;background:var(--sidebar);color:var(--sidebar-ink);display:flex;flex-direction:column;overflow:hidden;}
.main{grid-area:main;overflow:hidden;display:block;}
.editor{overflow-y:auto;height:100%;padding:30px 34px 80px;max-width:920px;margin:0 auto;}

/* ---------- sidebar ---------- */
.brandbox{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08);}
.brandbox .b1{font-family:var(--display);font-weight:700;font-size:15px;letter-spacing:-.01em;}
.brandbox .b2{font-size:12px;color:var(--sidebar-muted);margin-top:3px;}
.navlist{flex:1;overflow-y:auto;padding:10px 10px;}
.navitem{display:flex;align-items:center;gap:12px;width:100%;border:0;background:transparent;color:var(--sidebar-muted);
  padding:10px 12px;border-radius:8px;cursor:pointer;text-align:left;transition:background .15s,color .15s;font-size:14.5px;}
.navitem svg{width:18px;height:18px;flex:0 0 auto;opacity:.9;}
.navitem:hover{background:rgba(255,255,255,.05);color:var(--sidebar-ink);}
.navitem.active{background:#ffffff;color:#0e0e0e;font-weight:600;}
.navitem .dot{margin-left:auto;width:7px;height:7px;border-radius:50%;background:var(--warn);opacity:0;}
.navitem.dirty .dot{opacity:1;}
.sidefoot{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:var(--sidebar-muted);display:flex;align-items:center;gap:9px;}
.avatar{width:30px;height:30px;border-radius:50%;background:#3a3a37;color:#fff;display:grid;place-items:center;font-weight:600;font-size:12px;}
.logout-side{border:0;background:transparent;color:var(--sidebar-muted);cursor:pointer;font-size:18px;padding:6px 8px;border-radius:6px;}
.logout-side:hover{background:rgba(255,255,255,.05);color:#fff;}

/* ---------- topbar ---------- */
.tb-left{display:flex;align-items:center;gap:14px;min-width:0;}
.tb-title{font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:-.01em;white-space:nowrap;}
.status{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:500;padding:5px 11px;border-radius:999px;border:1px solid var(--line-2);color:var(--muted);white-space:nowrap;}
.status i{width:7px;height:7px;border-radius:50%;background:var(--faint);}
.status.published{color:var(--ok);border-color:rgba(31,138,76,.3);background:rgba(31,138,76,.07);}
.status.published i{background:var(--ok);}
.status.draft{color:var(--warn);border-color:rgba(194,65,12,.28);background:rgba(194,65,12,.07);}
.status.draft i{background:var(--warn);animation:bp 2s var(--ease) infinite;}
@keyframes bp{0%,100%{opacity:.4}50%{opacity:1}}
.tb-right{display:flex;align-items:center;gap:10px;}
.btn{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 16px;border-radius:8px;border:1px solid var(--line-2);
  background:var(--panel);color:var(--ink);font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,transform .1s;}
.btn:hover:not(:disabled){background:#f0f0ee;}
.btn:active{transform:translateY(1px);}
.btn svg{width:16px;height:16px;}
.btn--primary{background:var(--accent);color:#fff;border-color:var(--accent);}
.btn--primary:hover:not(:disabled){background:#2a2a28;}
.btn--ghost{background:transparent;}
.btn--sm{height:32px;padding:0 12px;font-size:13.5px;border-radius:7px;}
.btn:disabled{opacity:.45;cursor:not-allowed;}
.iconbtn{width:38px;height:38px;display:grid;place-items:center;border-radius:8px;border:1px solid var(--line-2);background:var(--panel);cursor:pointer;}
.iconbtn:hover{background:#f0f0ee;}
.iconbtn svg{width:18px;height:18px;}

/* ---------- editor ---------- */
.sec-head{margin-bottom:24px;}
.sec-head h1{font-family:var(--display);font-weight:600;font-size:26px;letter-spacing:-.02em;margin:0 0 4px;}
.sec-head p{margin:0;color:var(--muted);font-size:14px;}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:6px 22px 8px;margin-bottom:18px;}
.field{padding:16px 0;border-bottom:1px solid var(--line);}
.field:last-child{border-bottom:0;}
.field-top{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:8px;}
.field-label{font-weight:600;font-size:13.5px;}
.field-hint{font-size:12.5px;color:var(--faint);margin-top:-4px;margin-bottom:8px;}
.counter{font-size:12px;color:var(--faint);font-variant-numeric:tabular-nums;}
.counter.over{color:var(--danger);font-weight:600;}
.inp,.ta{width:100%;border:1px solid var(--line-2);border-radius:8px;padding:10px 12px;background:#fcfcfb;transition:border-color .15s,box-shadow .15s;}
.inp:focus,.ta:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(14,14,14,.07);}
.inp.over,.ta.over{border-color:var(--danger);}
.ta{resize:vertical;min-height:76px;line-height:1.5;}
.inp.url{font-size:13.5px;color:#1a4fae;}

/* list / chips */
.rows{display:flex;flex-direction:column;gap:8px;}
.row{display:flex;gap:8px;align-items:center;}
.row .inp{flex:1;}
.row-handle{cursor:grab;color:var(--faint);display:grid;place-items:center;width:26px;height:38px;flex:0 0 auto;}
.row-del{flex:0 0 auto;width:34px;height:34px;border-radius:7px;border:1px solid var(--line-2);background:var(--panel);color:var(--muted);cursor:pointer;display:grid;place-items:center;font-size:14px;}
.row-del:hover{color:var(--danger);border-color:rgba(180,35,24,.4);}
.addbtn{align-self:flex-start;margin-top:4px;display:inline-flex;align-items:center;gap:7px;font-size:13.5px;color:var(--ink);background:transparent;border:1px dashed var(--line-2);border-radius:8px;padding:8px 14px;cursor:pointer;}
.addbtn:hover{background:#f0f0ee;border-style:solid;}
.chips{display:flex;flex-wrap:wrap;gap:8px;}
.chip{display:inline-flex;align-items:center;gap:8px;background:#f0f0ee;border:1px solid var(--line-2);border-radius:999px;padding:6px 8px 6px 13px;font-size:13.5px;}
.chip button{border:0;background:transparent;cursor:pointer;color:var(--muted);width:18px;height:18px;display:grid;place-items:center;border-radius:50%;}
.chip button:hover{background:#e2e2df;color:var(--danger);}
.chip-add{display:flex;gap:8px;margin-top:10px;}
.chip-add .inp{flex:1;}

/* image / video uploaders */
.uploader{display:flex;gap:14px;align-items:flex-start;}
.thumb{width:120px;height:150px;border-radius:8px;overflow:hidden;background:#e9e9e6;border:1px solid var(--line);flex:0 0 auto;position:relative;display:flex;align-items:center;justify-content:center;}
.thumb img,.thumb video{width:100%;height:100%;object-fit:cover;display:block;}
.thumb--wide{width:200px;height:120px;}
.thumb--loading::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.7);}
.thumb--loading .spin{position:relative;z-index:2;}
.drop{flex:1;border:1.5px dashed var(--line-2);border-radius:8px;padding:18px;text-align:center;color:var(--muted);cursor:pointer;transition:background .15s,border-color .15s;display:block;}
.drop:hover,.drop.over{background:#f0f0ee;border-color:var(--ink);color:var(--ink);}
.drop b{color:var(--ink);display:block;}
.drop small{display:block;margin-top:6px;color:var(--faint);font-size:12px;}
.opt-badge{display:inline-flex;align-items:center;gap:6px;margin-top:8px;font-size:11.5px;color:var(--ok);}

/* gallery manager */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
.gal-item{position:relative;border-radius:8px;overflow:hidden;background:#e9e9e6;aspect-ratio:3/4;cursor:grab;border:1px solid var(--line);}
.gal-item.dragging{opacity:.4;}
.gal-item.over{outline:2px solid var(--ink);outline-offset:-2px;}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;}
.gal-item .num{position:absolute;top:6px;left:6px;background:rgba(0,0,0,.6);color:#fff;font-size:11px;font-weight:600;padding:2px 7px;border-radius:5px;}
.gal-item .x{position:absolute;top:6px;right:6px;width:26px;height:26px;border:0;border-radius:6px;background:rgba(0,0,0,.6);color:#fff;cursor:pointer;display:grid;place-items:center;opacity:0;transition:opacity .15s;}
.gal-item:hover .x{opacity:1;}
.gal-move{position:absolute;bottom:6px;width:28px;height:28px;border:0;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;cursor:pointer;display:grid;place-items:center;font-size:16px;line-height:1;padding:0;opacity:0;transition:opacity .15s;}
.gal-item:hover .gal-move{opacity:1;}
.gal-move--prev{left:6px;}
.gal-move--next{left:40px;}
.gal-add{border:1.5px dashed var(--line-2);border-radius:8px;display:grid;place-items:center;aspect-ratio:3/4;color:var(--muted);cursor:pointer;text-align:center;font-size:12.5px;padding:8px;gap:6px;}
.gal-add:hover{background:#f0f0ee;border-color:var(--ink);color:var(--ink);}
.gal-add--loading{background:#f0f0ee;cursor:wait;}

/* packages editor */
.pk-edit{border:1px solid var(--line-2);border-radius:10px;padding:16px;margin-bottom:14px;background:#fcfcfb;}
.pk-edit__head{display:flex;align-items:center;gap:8px;margin-bottom:12px;}
.pk-edit__head .inp{flex:1;}
.pk-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.toggle{display:inline-flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;user-select:none;}
.toggle input{display:none;}
.toggle .tr{width:38px;height:22px;border-radius:999px;background:#d6d6d2;position:relative;transition:background .15s;flex:0 0 auto;}
.toggle .tr::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .15s;box-shadow:0 1px 2px rgba(0,0,0,.2);}
.toggle input:checked + .tr{background:var(--ink);}
.toggle input:checked + .tr::after{transform:translateX(16px);}
.sub-label{font-size:11px;color:var(--muted);margin:4px 0;font-weight:600;text-transform:uppercase;letter-spacing:.04em;}

/* steps */
.step-row{display:flex;gap:10px;align-items:center;}
.step-row .n{width:50px;}
.step-row .inp{flex:1;}

/* ---------- toast ---------- */
.toast-wrap{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:9000;display:flex;flex-direction:column;gap:8px;align-items:center;}
.toast{display:flex;align-items:center;gap:10px;background:#111;color:#fff;padding:11px 18px;border-radius:10px;font-size:14px;box-shadow:0 12px 36px rgba(0,0,0,.3);animation:toastin .25s var(--ease);}
.toast svg{width:17px;height:17px;}
.toast--ok svg{color:#5fd08a;}
.toast--err{background:#b42318;}
.toast--err svg{color:#fff;}
@keyframes toastin{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}

/* ---------- modal / history ---------- */
.overlay{position:fixed;inset:0;background:rgba(10,10,10,.45);z-index:8000;display:flex;justify-content:flex-end;animation:fade .2s;}
@keyframes fade{from{opacity:0}to{opacity:1}}
.drawer{width:440px;max-width:92vw;background:var(--panel);height:100%;display:flex;flex-direction:column;animation:slidein .26s var(--ease);}
@keyframes slidein{from{transform:translateX(30px);opacity:.6;}to{transform:none;opacity:1;}}
.drawer__head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line);}
.drawer__head h3{margin:0;font-family:var(--display);font-size:18px;font-weight:600;}
.drawer__body{flex:1;overflow-y:auto;padding:12px 16px;}
.ver{display:flex;align-items:center;gap:12px;padding:13px 12px;border-radius:9px;border:1px solid var(--line);margin-bottom:9px;}
.ver:hover{background:#fafaf9;}
.ver .vmeta{flex:1;min-width:0;}
.ver .vmeta .vt{font-weight:600;font-size:13.5px;}
.ver .vmeta .vd{font-size:12px;color:var(--muted);}
.ver .badge-cur{font-size:11px;color:var(--ok);font-weight:600;}

/* ---------- mobile ---------- */
.menu-toggle{display:none;}
@media(max-width:760px){
  .app{grid-template-columns:1fr;grid-template-areas:"top" "main";}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:264px;z-index:200;transform:translateX(-100%);transition:transform .26s var(--ease);box-shadow:0 0 60px rgba(0,0,0,.4);padding-top:env(safe-area-inset-top);}
  .sidebar.open{transform:none;}
  .menu-toggle{display:grid;}
  .editor{padding:20px 16px 90px;}
  .tb-title{font-size:14px;}
  .pk-grid{grid-template-columns:1fr;}
  .gal{grid-template-columns:repeat(3,1fr);}
  .tb-right .btn span{display:none;}
  .tb-right .btn{padding:0 11px;height:38px;}
  .tb-right .iconbtn{width:38px;height:38px;}
  .tb-right{gap:6px;}
  .scrim-m{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:150;}
  /* iOS не зумит инпуты с font-size >= 16px */
  .inp,.ta{font-size:16px;padding:11px 12px;}
  /* кнопки переноса в галерее на тапе всегда видимые */
  .gal-item .x,.gal-item .gal-move{opacity:1;}
  .gal-item .x{width:28px;height:28px;}
  .gal-move{width:30px;height:30px;}
  .gal-move--next{left:42px;}
  .uploader{flex-direction:column;}
  .thumb,.thumb--wide{width:100%;height:auto;aspect-ratio:1/1;max-width:200px;}
  body{padding-bottom:env(safe-area-inset-bottom);}
  .toast-wrap{bottom:max(22px,calc(env(safe-area-inset-bottom) + 14px));}
}
