/* ===================================================================
   ZERO-WASTE — Admin panel dizayni
   =================================================================== */
:root{
  --g-900:#0a2e1e;--g-800:#0d4329;--g-700:#115c3a;--g-600:#157a48;--g-500:#1c9d57;
  --g-400:#34c26b;--lime:#b6f04a;--mint:#eafaf0;
  --ink:#0c1a13;--body:#33433b;--muted:#69796f;--line:#e4ece7;--bg:#f4f7f5;--card:#fff;
  --radius:16px;--radius-sm:11px;--shadow:0 10px 30px -14px rgba(10,46,30,.22);
  --sans:'Manrope',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--body);font-size:15px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--sans);color:var(--ink);margin:0;font-weight:800;letter-spacing:-.02em}
svg{width:20px;height:20px}
input,textarea,select,button{font-family:inherit}

/* ---------- LOGIN ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(900px 500px at 80% -10%,rgba(54,194,107,.18),transparent 60%),
  linear-gradient(160deg,var(--g-900),var(--g-800))}
.login-card{background:#fff;border-radius:24px;padding:42px 38px;width:100%;max-width:410px;box-shadow:0 40px 80px -30px rgba(0,0,0,.4)}
.login-logo{display:flex;align-items:center;gap:12px;justify-content:center;margin-bottom:28px}
.login-logo svg,.login-logo .logo{width:48px;height:48px}
.login-logo b{font-size:1.4rem;font-weight:800;color:var(--ink)}
.login-logo span{font-size:.66rem;letter-spacing:.2em;color:var(--g-600);font-weight:700;text-transform:uppercase;display:block}
.login-card h1{font-size:1.5rem;text-align:center;margin-bottom:6px}
.login-card .sub{text-align:center;color:var(--muted);margin-bottom:28px;font-size:.94rem}
.login-err{background:#fde8e8;color:#b42318;border:1px solid #f5c2c0;padding:12px 16px;border-radius:11px;font-size:.9rem;margin-bottom:18px;display:flex;gap:9px;align-items:center}
.fld{margin-bottom:18px}
.fld label{display:block;font-weight:600;font-size:.88rem;color:var(--ink);margin-bottom:7px}
.fld input{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:11px;font-size:.97rem;transition:.2s}
.fld input:focus{outline:none;border-color:var(--g-500);box-shadow:0 0 0 4px rgba(28,157,87,.12)}
.login-card .hint{margin-top:20px;text-align:center;font-size:.82rem;color:var(--muted)}
.login-card .hint code{background:var(--mint);padding:2px 8px;border-radius:6px;color:var(--g-700);font-weight:600}

/* ---------- LAYOUT ---------- */
.admin{display:grid;grid-template-columns:262px 1fr;min-height:100vh}
/* mobil menyu foni — grid elementi BO'LMASLIGI uchun har doim fixed + yashirin */
.sb-backdrop{position:fixed;inset:0;background:rgba(8,30,20,.5);z-index:59;display:none}
.sb-backdrop.show{display:block}
.sidebar{background:var(--g-900);color:#bfe6cf;padding:24px 18px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sb-brand{display:flex;align-items:center;gap:11px;padding:6px 8px 22px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:18px}
.sb-brand svg,.sb-brand .logo{width:40px;height:40px}
.logo{object-fit:contain}
img.logo{border-radius:10px}
.sb-brand b{color:#fff;font-size:1.15rem;font-weight:800;line-height:1}
.sb-brand span{font-size:.6rem;letter-spacing:.18em;color:var(--g-400);font-weight:700;text-transform:uppercase}
.sb-nav{display:flex;flex-direction:column;gap:4px;flex:1}
.sb-nav a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:11px;font-weight:600;font-size:.94rem;color:#bfe6cf;transition:.2s}
.sb-nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.sb-nav a.active{background:var(--g-600);color:#fff;box-shadow:0 10px 20px -10px rgba(21,122,72,.8)}
.sb-nav a .badge{margin-left:auto;background:var(--lime);color:var(--g-900);font-size:.72rem;font-weight:800;padding:1px 8px;border-radius:30px}
.sb-label{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:#5f8a72;font-weight:700;padding:16px 14px 7px;margin-top:6px;border-top:1px solid rgba(255,255,255,.07)}
.sb-foot{border-top:1px solid rgba(255,255,255,.08);padding-top:16px;margin-top:16px}
.sb-foot a{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:11px;color:#9fd3b3;font-weight:600;font-size:.9rem;transition:.2s}
.sb-foot a:hover{background:rgba(255,255,255,.07);color:#fff}
.sb-view{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:11px;color:#9fd3b3;font-size:.86rem}

.main{padding:0;min-height:100vh;display:flex;flex-direction:column}
.topbar{background:#fff;border-bottom:1px solid var(--line);padding:18px 32px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:20}
.topbar h1{font-size:1.35rem}
.topbar .crumb{font-size:.82rem;color:var(--muted);margin-bottom:3px}
.topbar .user{display:flex;align-items:center;gap:11px}
.topbar .user .av{width:40px;height:40px;border-radius:50%;background:var(--g-600);color:#fff;display:grid;place-items:center;font-weight:800}
.topbar .user b{font-size:.92rem;color:var(--ink);display:block;line-height:1.2}
.topbar .user span{font-size:.78rem;color:var(--muted)}
.content{padding:32px;flex:1}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:11px;font-weight:700;font-size:.92rem;cursor:pointer;border:1.5px solid transparent;transition:.22s}
.btn svg{width:17px;height:17px}
.btn-pri{background:var(--g-600);color:#fff;box-shadow:0 12px 22px -12px rgba(21,122,72,.7)}
.btn-pri:hover{background:var(--g-700);transform:translateY(-1px)}
.btn-sec{background:#fff;color:var(--g-700);border-color:var(--line)}
.btn-sec:hover{border-color:var(--g-400)}
.btn-danger{background:#fef2f2;color:#b42318;border-color:#f5c2c0}
.btn-danger:hover{background:#fee4e2}
.btn-sm{padding:7px 13px;font-size:.84rem;border-radius:9px}

/* ---------- STAT CARDS ---------- */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:28px}
.scard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;display:flex;align-items:center;gap:16px;transition:.25s}
.scard:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.scard .ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;color:#fff;flex-shrink:0}
.scard.c1 .ic{background:linear-gradient(150deg,#34c26b,#0d4329)}
.scard.c2 .ic{background:linear-gradient(150deg,#3b9eff,#1456a0)}
.scard.c3 .ic{background:linear-gradient(150deg,#ffb13b,#b56a06)}
.scard.c4 .ic{background:linear-gradient(150deg,#b6f04a,#4d8a0a)}
.scard b{font-size:1.9rem;font-weight:800;color:var(--ink);line-height:1}
.scard span{font-size:.86rem;color:var(--muted);display:block;margin-top:3px}

/* ---------- CARD / TABLE ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.card-head{padding:20px 24px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.card-head h2{font-size:1.12rem}
.card-head .sub{color:var(--muted);font-size:.86rem;margin-top:2px}
.grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:24px}

table.tbl{width:100%;border-collapse:collapse}
table.tbl th,table.tbl td{padding:14px 24px;text-align:left;border-bottom:1px solid var(--line);font-size:.92rem;vertical-align:middle}
table.tbl thead th{background:#f8faf9;color:var(--muted);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}
table.tbl tbody tr:last-child td{border-bottom:none}
table.tbl tbody tr:hover{background:#f8faf9}
table.tbl td b{color:var(--ink)}
.t-title{max-width:380px}
.t-title b{display:block;color:var(--ink);font-weight:700}
.t-title .mini{display:block;color:var(--muted);font-size:.8rem;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:360px}
.t-thumb{width:56px;height:40px;border-radius:8px;object-fit:cover;background:var(--mint)}
.t-actions{display:flex;gap:8px;justify-content:flex-end}

.tag{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:30px;font-size:.76rem;font-weight:700}
.tag.on{background:var(--mint);color:var(--g-700)}
.tag.off{background:#f1f1f1;color:#888}
.tag.vakansiya{background:#e8f1ff;color:#1d5fbf}
.tag.tarif{background:#fff3e0;color:#c2710a}
.tag.umumiy{background:var(--mint);color:var(--g-700)}

/* ---------- FORM ---------- */
.form-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px;max-width:860px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.fgroup{margin-bottom:20px}
.fgroup label{display:block;font-weight:600;font-size:.9rem;color:var(--ink);margin-bottom:7px}
.fgroup .help{font-size:.8rem;color:var(--muted);font-weight:400;margin-left:4px}
.fgroup input[type=text],.fgroup input[type=date],.fgroup textarea,.fgroup select{
  width:100%;padding:12px 15px;border:1.5px solid var(--line);border-radius:11px;font-size:.96rem;color:var(--ink);background:#fff;transition:.2s}
.fgroup input:focus,.fgroup textarea:focus,.fgroup select:focus{outline:none;border-color:var(--g-500);box-shadow:0 0 0 4px rgba(28,157,87,.12)}
.fgroup textarea{resize:vertical;min-height:170px;line-height:1.7}
.switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.switch input{display:none}
.switch .track{width:48px;height:27px;background:#d4ded8;border-radius:30px;position:relative;transition:.25s}
.switch .track::after{content:"";position:absolute;top:3px;left:3px;width:21px;height:21px;background:#fff;border-radius:50%;transition:.25s;box-shadow:0 2px 5px rgba(0,0,0,.2)}
.switch input:checked + .track{background:var(--g-500)}
.switch input:checked + .track::after{transform:translateX(21px)}
.switch b{font-weight:600;color:var(--ink);font-size:.92rem}
/* .fgroup label{display:block} ni bekor qilish — toggle to'g'ri ko'rinishi uchun */
.fgroup label.switch{display:inline-flex;margin-bottom:0}
.upload{border:2px dashed var(--line);border-radius:13px;padding:22px;text-align:center;transition:.2s;cursor:pointer;display:block}
.upload:hover{border-color:var(--g-400);background:#f8faf9}
.upload svg{width:34px;height:34px;color:var(--g-500);margin-bottom:8px}
.upload .ut{font-weight:600;color:var(--ink)}
.upload .uh{font-size:.82rem;color:var(--muted)}
.upload input{display:none}
.cur-img{position:relative;display:inline-block;margin-top:14px}
.cur-img img{max-width:200px;border-radius:11px;border:1px solid var(--line)}
.form-actions{display:flex;gap:12px;margin-top:8px;padding-top:22px;border-top:1px solid var(--line)}

.empty-row{text-align:center;padding:60px 20px;color:var(--muted)}
.empty-row svg{width:54px;height:54px;color:var(--g-400);margin-bottom:14px}
.empty-row h3{color:var(--ink);margin-bottom:6px}

.msg-card{padding:20px 24px;border-bottom:1px solid var(--line)}
.msg-card:last-child{border-bottom:none}
.msg-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;flex-wrap:wrap}
.msg-head b{color:var(--ink)}
.msg-head .meta{font-size:.82rem;color:var(--muted);display:flex;gap:14px;flex-wrap:wrap}
.msg-body{color:var(--body);font-size:.94rem;background:#f8faf9;padding:14px 16px;border-radius:11px;margin-top:8px}

/* ---------- RESPONSIVE ---------- */
.mobile-bar{display:none}
@media (max-width:960px){
  .admin{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:262px;transform:translateX(-100%);transition:.3s;z-index:60;height:100vh}
  .sidebar.open{transform:translateX(0)}
  .sb-backdrop{position:fixed;inset:0;background:rgba(8,30,20,.5);z-index:59;display:none}
  .sb-backdrop.show{display:block}
  .mobile-bar{display:flex}
  .stat-row{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .content{padding:20px}
  .topbar{padding:16px 20px}
  .menu-btn{background:none;border:none;cursor:pointer;color:var(--ink);padding:6px}
  .menu-btn svg{width:26px;height:26px}
}
@media (max-width:520px){ .stat-row{grid-template-columns:1fr} }
@media (min-width:961px){ .menu-btn{display:none} }

/* ===================================================================
   KONSTRUKTOR (CMS) qo'shimcha uslublar
   =================================================================== */
.settings-group{margin-bottom:26px}
.settings-group .sg-head{display:flex;align-items:center;gap:11px;margin-bottom:16px}
.settings-group .sg-head .ic{width:38px;height:38px;border-radius:10px;background:var(--mint);display:grid;place-items:center;color:var(--g-600);flex-shrink:0}
.settings-group .sg-head h2{font-size:1.08rem}

.coll-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.coll-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;display:flex;flex-direction:column;gap:6px;transition:.25s;text-decoration:none}
.coll-card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--g-400)}
.coll-card .ic{width:46px;height:46px;border-radius:12px;background:linear-gradient(150deg,var(--g-500),var(--g-800));color:#fff;display:grid;place-items:center;margin-bottom:6px}
.coll-card h3{font-size:1.04rem}
.coll-card .cnt{color:var(--muted);font-size:.85rem}
.coll-card .go{margin-top:auto;color:var(--g-700);font-weight:700;font-size:.85rem;display:inline-flex;align-items:center;gap:6px}

.move-btns{display:inline-flex;gap:4px}
.move-btns button{all:unset;cursor:pointer;width:30px;height:30px;display:grid;place-items:center;border-radius:8px;border:1px solid var(--line);color:var(--muted)}
.move-btns button:hover{border-color:var(--g-400);color:var(--g-700)}

/* icon picker */
.icon-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:8px;max-height:210px;overflow-y:auto;border:1.5px solid var(--line);border-radius:12px;padding:12px;background:#fafcfb}
.icon-opt{position:relative}
.icon-opt input{position:absolute;opacity:0}
.icon-opt label{display:grid;place-items:center;height:46px;border:1.5px solid var(--line);border-radius:10px;cursor:pointer;color:var(--body);transition:.18s;background:#fff}
.icon-opt label svg{width:22px;height:22px}
.icon-opt label:hover{border-color:var(--g-400);color:var(--g-700)}
.icon-opt input:checked + label{border-color:var(--g-500);background:var(--mint);color:var(--g-700);box-shadow:0 0 0 3px rgba(28,157,87,.12)}

/* section builder */
.builder{display:flex;flex-direction:column;gap:14px}
.sec-block{border:1px solid var(--line);border-radius:var(--radius);background:var(--card);overflow:hidden}
.sec-block .sb-bar{display:flex;align-items:center;gap:12px;padding:14px 18px;background:#f8faf9;border-bottom:1px solid var(--line)}
.sec-block .sb-bar .type{font-weight:700;color:var(--ink);display:flex;align-items:center;gap:9px}
.sec-block .sb-bar .type .ic{width:30px;height:30px;border-radius:8px;background:var(--mint);display:grid;place-items:center;color:var(--g-600)}
.sec-block .sb-bar .sb-tools{margin-left:auto;display:flex;align-items:center;gap:6px}
.sec-block .sb-body{padding:18px}
.repeat-rows{display:flex;flex-direction:column;gap:12px}
.repeat-row{border:1px dashed var(--line);border-radius:11px;padding:14px;background:#fafcfb;position:relative}
.repeat-row .rr-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.repeat-row .rr-head b{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.rr-del{all:unset;cursor:pointer;color:#b42318;font-size:.82rem;font-weight:700}
.add-row{align-self:flex-start;margin-top:4px}
.type-pick{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.type-pick button{all:unset;cursor:pointer;border:1.5px solid var(--line);border-radius:12px;padding:14px;display:flex;align-items:center;gap:10px;font-weight:600;color:var(--ink);background:#fff;transition:.18s}
.type-pick button:hover{border-color:var(--g-400);background:var(--mint)}
.type-pick button .ic{width:34px;height:34px;border-radius:9px;background:var(--mint);display:grid;place-items:center;color:var(--g-600);flex-shrink:0}
.page-link-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:var(--mint);border-radius:11px;padding:12px 16px;margin-bottom:18px;font-size:.9rem}
.page-link-row code{background:#fff;padding:3px 9px;border-radius:6px;color:var(--g-700);font-weight:600}

/* ---------- WYSIWYG redaktor ---------- */
.rt-wrap{border:1.5px solid var(--line);border-radius:11px;overflow:hidden;background:#fff}
.rt-wrap:focus-within{border-color:var(--g-500);box-shadow:0 0 0 4px rgba(28,157,87,.12)}
.rt-bar{display:flex;flex-wrap:wrap;gap:3px;align-items:center;padding:7px 9px;background:#f8faf9;border-bottom:1px solid var(--line)}
.rt-btn{min-width:30px;height:30px;padding:0 7px;border:1px solid var(--line);background:#fff;border-radius:7px;cursor:pointer;font-size:.86rem;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;transition:.15s}
.rt-btn:hover{border-color:var(--g-400);background:var(--mint);color:var(--g-700)}
.rt-sep{width:1px;height:20px;background:var(--line);margin:0 4px}
.rt-area{min-height:180px;max-height:520px;overflow-y:auto;padding:14px 16px;font-size:.97rem;line-height:1.7;color:var(--ink);outline:none}
.rt-area:empty::before{content:attr(data-ph);color:var(--muted)}
.rt-area h2{font-size:1.3rem;margin:.6em 0 .3em}
.rt-area h3{font-size:1.1rem;margin:.6em 0 .3em}
.rt-area p{margin:0 0 .8em}
.rt-area ul,.rt-area ol{margin:0 0 .8em;padding-left:1.4em}
.rt-area a{color:var(--g-700);text-decoration:underline}

/* Hero slaydlar (settings gallereya) */
.hero-slides-admin{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:18px}
.hero-thumb{position:relative;aspect-ratio:16/9;border-radius:12px;overflow:hidden;border:1.5px solid var(--line);background:var(--g-900)}
.hero-thumb img{width:100%;height:100%;object-fit:cover}
.hero-thumb .ht-num{position:absolute;top:7px;left:7px;background:rgba(7,35,26,.7);color:var(--lime);font-size:.72rem;font-weight:800;padding:2px 8px;border-radius:20px}
.hero-thumb form{position:absolute;top:7px;right:7px;margin:0}
.hero-thumb button{all:unset;cursor:pointer;width:26px;height:26px;border-radius:50%;background:rgba(180,35,24,.92);color:#fff;display:grid;place-items:center;font-size:1.1rem;line-height:1}
.hero-thumb button:hover{background:#b42318}

/* ---------- Ko'p tilli tahrirlash (i18n tabs) ---------- */
.i18n-tabs{display:inline-flex;gap:4px;background:#eef3f0;border-radius:11px;padding:4px;margin-bottom:18px;flex-wrap:wrap}
.i18n-tabs button{all:unset;cursor:pointer;padding:7px 16px;border-radius:8px;font-weight:700;font-size:.84rem;color:var(--muted);transition:.15s}
.i18n-tabs button.active{background:#fff;color:var(--g-700);box-shadow:0 1px 4px rgba(0,0,0,.12)}
.i18n-tabs button:hover:not(.active){color:var(--g-700)}
/* default: uz ko'rinadi, ru/en yashirin */
.lng-ru,.lng-en{display:none}
body[data-alng="ru"] .lng-uz,body[data-alng="ru"] .lng-en{display:none}
body[data-alng="ru"] .lng-ru{display:block}
body[data-alng="en"] .lng-uz,body[data-alng="en"] .lng-ru{display:none}
body[data-alng="en"] .lng-en{display:block}
body[data-alng="uz"] .lng-ru,body[data-alng="uz"] .lng-en{display:none}
body[data-alng="uz"] .lng-uz{display:block}

/* WYSIWYG — hajm/shrift tanlash menyulari */
.rt-sel{height:30px;border:1px solid var(--line);background:#fff;border-radius:7px;font-size:.82rem;color:var(--ink);padding:0 6px;cursor:pointer;max-width:130px;font-family:inherit}
.rt-sel:hover{border-color:var(--g-400)}
.rt-sel:focus{outline:none;border-color:var(--g-500)}
