:root{
  --bg:#f4f5f7; --surface:#fff; --ink:#16171c; --muted:#6c6f79; --line:#e7e9ee; --line-2:#dcdee5;
  --yellow:#ffc400; --yellow-deep:#f2a900; --yellow-soft:#fff3cf; --ok:#1f9d56; --danger:#d6485f;
  --side:#16171c; --radius:16px; --shadow:0 18px 40px -24px rgba(22,23,28,.45);
}
*{box-sizing:border-box}
body{margin:0;font-family:"Manrope",system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit}
[hidden]{display:none!important}
.muted{color:var(--muted);font-size:14px}
h1,h2,h3,h4{margin:0}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:30px;font-weight:700;font-size:14px;border:1.5px solid var(--line-2);color:var(--ink);background:#fff;transition:.15s}
.btn:hover{border-color:var(--ink)}
.btn-primary{background:var(--yellow);color:var(--ink);border-color:var(--yellow)}
.btn-primary:hover{background:var(--yellow-deep);border-color:var(--yellow-deep);transform:translateY(-1px)}
.btn-block{width:100%}
.btn-danger{color:var(--danger);border-color:#f0cdd3}
.btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-mini{padding:7px 12px;font-size:12.5px;border-radius:20px}
.btn-ghost{padding:9px 16px;font-size:13px;border-radius:24px;background:#fff}
a.btn{text-decoration:none}

/* ---- login ---- */
.login{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(120% 120% at 50% -10%,#fff6da 0%,var(--bg) 55%)}
.login-card{background:var(--surface);border-radius:24px;box-shadow:var(--shadow);padding:38px 34px;width:100%;max-width:380px;text-align:center}
.login-logo{height:60px;width:60px;border-radius:14px;object-fit:cover;display:block;margin:0 auto 12px}
.login-card h1{font-size:23px;font-weight:800;letter-spacing:.01em}
.login-card h1 .lo-atl{color:var(--yellow-deep)}
.login-sub{margin:4px 0 24px;color:var(--muted);font-size:14px}
.fld{display:block;text-align:left;margin-bottom:14px}
.fld span{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}
.fld input,.fld select,.fld textarea{width:100%;border:1.5px solid var(--line-2);border-radius:12px;padding:12px 14px;font-size:15px;color:var(--ink);background:#fff;outline:none;transition:border-color .15s}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--yellow)}
.fld textarea{min-height:80px;resize:vertical}
.login-err,.modal-err{background:#fdecee;color:var(--danger);border-radius:10px;padding:10px 12px;font-size:13px;font-weight:600;margin-bottom:14px}
.login-or{display:flex;align-items:center;text-align:center;color:var(--muted);font-size:13px;margin:16px 0}
.login-or::before,.login-or::after{content:"";flex:1;height:1px;background:var(--line)}
.login-or span{padding:0 12px}
.btn-tg{background:#27a7e7;color:#fff;border-color:#27a7e7}
.btn-tg:hover{background:#1e95d0;border-color:#1e95d0}
.tg-login-wait{text-align:center}
.tg-login-wait p{font-size:14px;margin:0 0 14px}
.tg-login-wait .btn{margin-bottom:12px}
.tg-login-wait .muted{display:block}

/* ---- app shell ---- */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.side{background:var(--side);color:#c9cbd3;display:flex;flex-direction:column;padding:22px 14px;position:sticky;top:0;height:100vh}
.side-brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:800;font-size:17px;padding:6px 10px 20px}
.side-brand .lo-atl{color:var(--yellow)}
.side-brand img{height:30px;width:30px;border-radius:8px;object-fit:cover}
.side-nav{display:flex;flex-direction:column;gap:4px;flex:1}
.nav-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:11px 14px;border-radius:12px;color:#c9cbd3;font-weight:600;font-size:14.5px;transition:.15s}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.is-active{background:var(--yellow);color:var(--ink)}
.ni-ic{width:19px;height:19px;flex:none;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.badge{margin-left:auto;background:var(--yellow);color:var(--ink);font-size:11px;font-weight:800;padding:2px 8px;border-radius:20px}
.nav-item.is-active .badge{background:var(--ink);color:#fff}
.side-logout{margin-top:auto;display:flex;align-items:center;gap:12px;color:#c9cbd3;text-align:left;padding:11px 14px;border-radius:12px;font-weight:600;font-size:14px}
.side-logout:hover{background:rgba(255,255,255,.06);color:#fff}
.btn-ic{width:16px;height:16px;flex:none;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}

.main{padding:0 30px 50px;min-width:0}
.topbar{position:sticky;top:0;background:var(--bg);display:flex;align-items:center;justify-content:space-between;padding:22px 0 16px;margin-bottom:4px;z-index:5}
.topbar h2{font-size:25px;font-weight:800}
.topbar-actions{display:flex;align-items:center;gap:14px}
.topbar-link{color:var(--yellow-deep);font-weight:700;font-size:14px;text-decoration:none}

.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;margin-top:20px}
.panel h3{margin-bottom:16px;font-size:17px;font-weight:800}
.panel .panel-sub{color:var(--muted);font-size:13px;margin:-10px 0 16px}

/* ---- stats ---- */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;transition:transform .18s,box-shadow .18s}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.stat-card .sc-label{color:var(--muted);font-size:13px;font-weight:600}
.stat-card .sc-val{font-size:29px;font-weight:800;margin-top:8px;letter-spacing:-.01em}
.stat-card.accent{background:linear-gradient(140deg,var(--yellow),var(--yellow-deep));border-color:transparent}
.stat-card.accent .sc-label{color:rgba(22,23,28,.7)}
.recent{display:flex;flex-direction:column}
.recent-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 0;border-bottom:1px solid var(--line);font-size:14px}
.recent-row:last-child{border-bottom:none}
.recent-row .r-id{font-weight:800}
.recent-row .r-cust{color:var(--muted);flex:1}

/* ---- view head ---- */
.view-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}

/* ---- products ---- */
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.pcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s,border-color .18s}
.pcard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:transparent}
.pcard-media{position:relative;height:150px;background:var(--bg);display:grid;place-items:center;overflow:hidden}
.pcard-media img{width:100%;height:100%;object-fit:cover}
.pcard-media .ph{font-size:30px;opacity:.4}
.pcard-tag{position:absolute;top:10px;left:10px;background:var(--yellow);font-size:11px;font-weight:800;padding:3px 10px;border-radius:8px}
.pcard-count{position:absolute;bottom:10px;right:10px;background:rgba(22,23,28,.78);color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:8px}
.pcard-body{padding:13px 15px;display:flex;flex-direction:column;gap:3px;flex:1}
.pcard-body h4{font-size:15px;font-weight:800;line-height:1.2}
.pcard-body .pc-cat{color:var(--muted);font-size:12px}
.pcard-foot{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-top:8px}
.pc-price{font-weight:800;font-size:16px}
.pc-old{color:var(--muted);font-size:12.5px;text-decoration:line-through}
.pcard-actions{display:flex;gap:8px;padding:0 15px 14px}
.pcard-actions .btn{flex:1;padding:9px 0;font-size:13px}

/* ---- product modal: multi-photo + specs ---- */
.modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-bg{position:absolute;inset:0;background:rgba(22,23,28,.55)}
.modal-card{position:relative;background:var(--surface);border-radius:22px;box-shadow:var(--shadow);width:100%;max-width:680px;max-height:92vh;overflow:auto;padding:30px}
.modal-x{position:absolute;top:14px;right:16px;font-size:18px;color:var(--muted);width:34px;height:34px;border-radius:50%}
.modal-x:hover{background:rgba(0,0,0,.06)}
.modal-card h3{margin-bottom:18px;font-size:21px;font-weight:800}
.fld-row{display:flex;gap:12px}.fld-row .fld{flex:1;margin:0}
.photos-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.photo-thumb{position:relative;width:84px;height:84px;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.photo-thumb img{width:100%;height:100%;object-fit:cover}
.photo-thumb .px{position:absolute;top:3px;right:3px;width:20px;height:20px;border-radius:50%;background:rgba(22,23,28,.75);color:#fff;font-size:12px;line-height:20px;text-align:center}
.photo-add{width:84px;height:84px;border:2px dashed var(--line-2);border-radius:12px;display:grid;place-items:center;color:var(--muted);font-size:26px;font-weight:300}
.photo-add:hover{border-color:var(--yellow);color:var(--yellow-deep)}
.feat-row{display:flex;flex-wrap:wrap;gap:8px 16px}
.chk{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:600;cursor:pointer}
.chk input{width:16px;height:16px;accent-color:var(--yellow-deep)}
.specs-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.spec-row{display:flex;gap:8px;align-items:center}
.spec-row input{flex:1;border:1.5px solid var(--line-2);border-radius:10px;padding:9px 11px;font-size:14px}
.spec-row .px{flex:none;width:32px;height:32px;border-radius:8px;background:var(--bg);color:var(--danger);font-size:15px}
.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:22px}

/* ---- orders ---- */
.order-filters{display:flex;gap:8px;flex-wrap:wrap}
.ofilter{padding:8px 16px;border-radius:24px;border:1.5px solid var(--line-2);background:#fff;font-weight:600;font-size:13px;color:var(--muted)}
.ofilter:hover{border-color:var(--ink);color:var(--ink)}
.ofilter.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}
.orders-table{display:flex;flex-direction:column;gap:12px}
.order-row{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;transition:box-shadow .18s,border-color .18s}
.order-row:hover{box-shadow:var(--shadow);border-color:transparent}
.order-row-top{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}
.order-row-top .o-id{font-weight:800;font-size:16px}
.order-row-top .o-date{color:var(--muted);font-size:13px;margin-left:auto}
.o-items{font-size:14px;margin-bottom:6px}
.o-meta{font-size:13px;color:var(--muted);display:flex;gap:16px;flex-wrap:wrap;margin-bottom:10px}
.o-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.o-total{font-weight:800;font-size:17px}
.o-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.o-controls select{border:1.5px solid var(--line-2);border-radius:20px;padding:7px 12px;font-size:13px;font-weight:600;background:#fff}
.paid-badge{background:#d8efdf;color:#1f7a44;font-size:11px;font-weight:700;padding:3px 9px;border-radius:14px}
.unpaid-badge{background:#fdecd0;color:#946309;font-size:11px;font-weight:700;padding:3px 9px;border-radius:14px}
.st-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:5px 12px;border-radius:30px;white-space:nowrap}
.st-pill::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.st-new{background:#f8ecd0;color:#9a6a09}.st-paid{background:#e3edfb;color:#205ea6}
.st-collecting{background:#fbe3ea;color:#b03255}.st-ontheway{background:#e7e0fb;color:#5a3fb0}
.st-done{background:#dcefe2;color:#23734e}.st-cancelled{background:#ebe9e5;color:#857f78}

/* ---- categories ---- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.cat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;display:flex;align-items:center;gap:14px}
.cat-ic{width:46px;height:46px;border-radius:12px;background:var(--yellow-soft);display:grid;place-items:center;flex:none;overflow:hidden}
.cat-ic svg{width:26px;height:26px;stroke:var(--ink);fill:none;stroke-width:1.6}
.cat-ic.has-img{background:none}
.cat-ic.has-img img{width:100%;height:100%;object-fit:cover}
.cat-body{flex:1;min-width:0}
.cat-body h4{font-size:15px;font-weight:800}
.cat-body code{font-size:12px;color:var(--muted)}
.cat-actions{display:flex;flex-direction:column;gap:6px}

/* ---- filters editor ---- */
.kv-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.kv-row{display:flex;gap:8px;align-items:center}
.kv-row input{border:1.5px solid var(--line-2);border-radius:10px;padding:9px 11px;font-size:14px}
.kv-row .kv-id{width:150px}.kv-row .kv-label{flex:1}
.kv-row .px{flex:none;width:32px;height:32px;border-radius:8px;background:var(--bg);color:var(--danger);font-size:15px}
.chips-edit{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.chip-edit{display:inline-flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--line-2);border-radius:10px;padding:6px 8px 6px 12px;font-weight:700;font-size:13px}
.chip-edit .px{width:18px;height:18px;border-radius:50%;background:rgba(22,23,28,.12);color:var(--ink);font-size:12px;line-height:18px;text-align:center}

/* ---- analytics ---- */
.an-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.bars{display:flex;flex-direction:column;gap:10px}
.bar-row{display:grid;grid-template-columns:150px 1fr 46px;gap:10px;align-items:center;font-size:13px}
.bar-row .bar-k{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
.bar-track{height:10px;background:var(--bg);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--yellow),var(--yellow-deep));border-radius:6px}
.bar-v{text-align:right;font-weight:700;color:var(--muted)}
.sess-table{display:flex;flex-direction:column;font-size:13px}
.sess-row{display:grid;grid-template-columns:1.1fr .9fr .7fr .8fr 1.6fr;gap:10px;padding:11px 0;border-bottom:1px solid var(--line);align-items:center}
.sess-row:last-child{border-bottom:none}
.sess-head{font-weight:700;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.sess-path{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---- reviews ---- */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.review-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;display:flex;flex-direction:column;gap:10px}
.rc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.rc-who b{font-size:15px;font-weight:800;display:block}
.rc-stars{color:var(--yellow-deep);font-size:13px;letter-spacing:1px}
.rc-text{margin:0;font-size:14px;line-height:1.55}
.rc-meta{font-size:12px;color:var(--muted)}

/* ---- leads ---- */
.leads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}
.lead-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;display:flex;flex-direction:column;gap:8px;transition:opacity .2s}
.lead-card.is-done{opacity:.62}
.lc-top{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--muted)}
.lc-id{font-weight:800;color:var(--ink);font-family:"Montserrat",sans-serif}
.lc-status{font-size:11px;font-weight:800;padding:2px 9px;border-radius:14px}
.lc-status.new{background:#fdecd0;color:#946309}
.lc-status.done{background:#d8efdf;color:#1f7a44}
.lc-date{margin-left:auto}
.lc-name{font-size:16px;font-weight:800;font-family:"Montserrat",sans-serif}
.lc-phone{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:15px;color:var(--ink);width:fit-content}
.lc-phone:hover{color:var(--yellow-deep)}
.lc-phone .ni-ic{width:16px;height:16px;stroke:var(--yellow-deep);fill:none;stroke-width:1.7}
.lc-meta{font-size:12.5px;color:var(--muted)}
.lc-msg{margin:2px 0 0;font-size:13.5px;line-height:1.5;background:var(--bg-soft);border-radius:10px;padding:8px 11px}
.lc-foot{display:flex;align-items:center;gap:8px;margin-top:4px}
.lc-foot .btn-danger{margin-left:auto}

/* ---- settings ---- */
.set-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.set-grid .fld{margin:0}
.fld-wide{grid-column:1/-1}
.toggle{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:600;cursor:pointer;margin-bottom:16px;user-select:none}
.toggle input{display:none}
.toggle-track{width:46px;height:26px;border-radius:20px;background:var(--line-2);position:relative;transition:.2s;flex:none}
.toggle-track::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:.2s;box-shadow:0 2px 4px rgba(0,0,0,.2)}
.toggle input:checked+.toggle-track{background:var(--ok)}
.toggle input:checked+.toggle-track::after{transform:translateX(20px)}
.methods-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}
.settings-foot{display:flex;align-items:center;gap:18px;margin-top:22px}
.city-rows{display:flex;flex-direction:column;gap:10px}
.city-row{display:grid;grid-template-columns:1fr 1.4fr auto;gap:10px;align-items:center}
.city-row input{border:1.5px solid var(--line-2);border-radius:10px;padding:10px 12px;font-size:14px}
.code-box{background:var(--bg);border:1px dashed var(--line-2);border-radius:12px;padding:12px 14px;font-family:ui-monospace,monospace;font-size:13px;word-break:break-all;margin-top:8px}

.empty{text-align:center;color:var(--muted);padding:50px 0;font-size:15px}
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:13px 22px;border-radius:30px;font-weight:600;font-size:14px;opacity:0;pointer-events:none;transition:.25s;z-index:80}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media (max-width:880px){
  .app{grid-template-columns:1fr}
  .side{position:static;height:auto;flex-direction:row;align-items:center;flex-wrap:wrap;gap:8px}
  .side-brand{padding:6px 10px}.side-nav{flex-direction:row;flex:none;flex-wrap:wrap}.side-logout{margin:0}
  .main{padding:0 16px 40px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .an-grid{grid-template-columns:1fr}
  .set-grid{grid-template-columns:1fr 1fr}
  .sess-row{grid-template-columns:1fr .8fr .6fr;font-size:12px}.sess-row span:nth-child(4),.sess-row span:nth-child(5){display:none}
}
@media (max-width:520px){.stats-grid{grid-template-columns:1fr}.fld-row{flex-direction:column}.set-grid{grid-template-columns:1fr}.city-row{grid-template-columns:1fr}}
