/* Admin dashboard — uses tokens from styles.css */
.admin-body{background:#f2efe7}

.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{background:#fff;border-radius:var(--r-xl);box-shadow:var(--shadow);padding:44px 38px;max-width:410px;width:100%}
.login-card .mark{width:54px;height:54px;border-radius:14px;background:var(--teal);color:#fff;display:grid;place-items:center;font-family:var(--fd);font-size:1.5rem;margin-bottom:20px;overflow:hidden}
.login-card .mark img{width:100%;height:100%;object-fit:cover}
.login-card h1{font-size:1.7rem;margin-bottom:6px}
.login-card p.sub{color:var(--ink-soft);margin-bottom:24px;font-size:.95rem}
.login-card .admin-field input{background:#fff}
.login-err{color:var(--coral);font-size:.9rem;margin:8px 0;min-height:1.1em}
.login-hint{font-size:.8rem;color:var(--ink-soft);margin-top:16px;text-align:center}

.dash{display:none;min-height:100vh;grid-template-columns:252px 1fr}
.dash.show{display:grid}
.side{background:var(--ink);color:#cbd6d2;padding:22px 14px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;overflow:auto}
.side .brand{display:flex;align-items:center;gap:10px;color:#fff;font-family:var(--fd);font-size:1.15rem;padding:0 8px 18px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:14px}
.side .brand .mark{width:34px;height:34px;border-radius:10px;background:var(--teal);display:grid;place-items:center;font-size:.95rem;overflow:hidden;flex-shrink:0}
.side .brand .mark img{width:100%;height:100%;object-fit:cover}
.tab-btn{display:flex;align-items:center;gap:11px;width:100%;background:none;border:0;color:#cbd6d2;text-align:left;padding:11px 13px;border-radius:11px;cursor:pointer;font-family:var(--fb);font-size:.94rem;font-weight:500;margin-bottom:3px;transition:.15s}
.tab-btn:hover{background:rgba(255,255,255,.06);color:#fff}
.tab-btn.active{background:var(--teal);color:#fff}
.tab-btn .ic{font-size:1.05rem;width:20px;text-align:center}
.side .spacer{flex:1;min-height:14px}
.side .logout{color:#9fb3ad;font-size:.9rem;border:1px solid rgba(255,255,255,.15);border-radius:11px;padding:11px;background:none;cursor:pointer;width:100%}
.side .logout:hover{border-color:var(--coral);color:#ffb7a4}
.side .view-site{color:#9fb3ad;font-size:.85rem;text-align:center;display:block;margin-top:10px}
.side .view-site:hover{color:var(--saffron)}

.main{padding:30px 34px 80px;overflow:auto}
.main .topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.main h2.page-title{font-size:1.7rem}
.savebar{display:flex;align-items:center;gap:14px}
.save-status{font-size:.88rem;color:var(--ink-soft)}
.save-status.ok{color:var(--ok);font-weight:600}
.save-status.err{color:var(--coral);font-weight:600}

.panel{display:none}.panel.show{display:block}
.card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:26px 26px 28px;margin-bottom:22px}
.card>h3{font-size:1.18rem;margin-bottom:4px}
.card>.card-hint{color:var(--ink-soft);font-size:.88rem;margin-bottom:18px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.admin-field{margin-bottom:15px}
.admin-field label{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px}
.admin-field input,.admin-field textarea{width:100%;padding:11px 13px;border-radius:10px;border:1px solid var(--line);background:#fdfcf9;font-family:var(--fb);font-size:.95rem;color:var(--ink)}
.admin-field textarea{resize:vertical;min-height:88px}
.admin-field input:focus,.admin-field textarea:focus{outline:2px solid var(--teal)}

.uploader{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.uploader .preview{width:112px;height:84px;border-radius:12px;background:var(--sand);overflow:hidden;display:grid;place-items:center;color:var(--ink-soft);font-size:.72rem;text-align:center;border:1px solid var(--line);flex-shrink:0}
.uploader .preview img{width:100%;height:100%;object-fit:cover}
.uploader .preview.qr img,.uploader .preview.logo img{object-fit:contain;background:#fff}
.up-btn{position:relative;overflow:hidden;display:inline-flex}
.up-btn input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.upload-state{font-size:.82rem;color:var(--ink-soft)}

.repeat-row{border:1px solid var(--line);border-radius:14px;padding:16px 16px 4px;margin-bottom:14px;position:relative;background:#fdfcf9}
.repeat-row .rm{position:absolute;top:10px;right:10px;background:#fde7e0;color:var(--coral);border:0;border-radius:8px;width:28px;height:28px;cursor:pointer;font-size:1rem}
.add-row{background:var(--sand);border:1px dashed var(--line);color:var(--teal);border-radius:11px;padding:11px 18px;cursor:pointer;font-weight:600;font-family:var(--fb)}
.add-row:hover{background:#e9dfc7}

.gal-manage{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:12px}
.gal-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.gal-item img{width:100%;height:100%;object-fit:cover}
.gal-item .rm{position:absolute;top:6px;right:6px;background:rgba(236,91,59,.92);color:#fff;border:0;border-radius:7px;width:26px;height:26px;cursor:pointer}
.gal-add{aspect-ratio:1;border:2px dashed var(--line);border-radius:12px;display:grid;place-items:center;color:var(--teal);cursor:pointer;position:relative;text-align:center;font-size:.82rem;font-weight:600}
.gal-add input{position:absolute;inset:0;opacity:0;cursor:pointer}

.table-tools{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.tt-left{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.count-pill{background:var(--sand);border-radius:999px;padding:6px 14px;font-weight:600;font-size:.9rem}
.search-inp{padding:9px 13px;border-radius:10px;border:1px solid var(--line);font-family:var(--fb);font-size:.9rem;min-width:200px}
.search-inp:focus{outline:2px solid var(--teal)}
.table-wrap{overflow:auto;border-radius:14px;border:1px solid var(--line);background:#fff}
table{width:100%;border-collapse:collapse;font-size:.92rem}
th,td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
th{background:#faf7f0;font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft)}
tr:last-child td{border-bottom:0}
td.wrap{white-space:normal;min-width:220px}
td a.shotlink{color:var(--teal);font-weight:600}
.empty-state{text-align:center;color:var(--ink-soft);padding:50px 20px}
.empty-state .big{font-size:2.4rem;margin-bottom:8px}

@media(max-width:760px){
  .dash.show{grid-template-columns:1fr}
  .side{position:static;height:auto;flex-direction:row;flex-wrap:wrap;gap:6px;align-items:center}
  .side .brand{border:0;margin:0;padding:0 8px 0 0;width:100%}
  .side .spacer{display:none}
  .tab-btn{width:auto}.side .view-site{margin:0}
  .grid2{grid-template-columns:1fr}
  .main{padding:22px 18px 70px}
}
