/* =====================================================================
   SmartWP Studio - ADMIN STYLES
   ===================================================================== */
:root{
  --blue:#2f6bff; --cyan:#22d3ee; --aqua:#5eead4;
  --grad-brand:linear-gradient(115deg,var(--blue),var(--cyan));
  --grad-text:linear-gradient(105deg,var(--blue),var(--cyan));
  --ff-display:"Sora",system-ui,sans-serif;
  --ff-body:"Hanken Grotesk",system-ui,sans-serif;
  --ff-mono:"JetBrains Mono",ui-monospace,monospace;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--ff-body);background:#0a0f1f;color:#eef2ff;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
svg{display:block}
input,textarea,select,button{font-family:inherit}

/* ---- Login ---- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(120% 120% at 50% 0%,#101a3a,#070b1a)}
.login-box{width:100%;max-width:400px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:40px 34px;backdrop-filter:blur(14px)}
.login-box .logo{display:flex;align-items:center;justify-content:center;gap:11px;font-family:var(--ff-display);font-weight:700;font-size:20px;margin-bottom:22px}
.login-box .logo .mark{width:40px;height:40px;border-radius:11px;background:var(--grad-brand);display:grid;place-items:center;color:#fff;font-weight:800}
.login-box .logo b{color:var(--cyan)}
.login-box h2{font-family:var(--ff-display);font-weight:700;font-size:1.4rem;text-align:center;margin-bottom:6px}
.login-box p{text-align:center;color:#9aa6cc;font-size:.92rem;margin-bottom:24px}
.login-box label{display:block;font-weight:600;font-size:13px;margin:0 0 7px}
.login-box input{width:100%;font-size:15px;padding:13px 15px;border-radius:11px;border:1.5px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);color:#fff;margin-bottom:16px}
.login-box input:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 4px rgba(47,107,255,.18)}
.login-box .btn{width:100%;justify-content:center}
.login-box .hint{margin-top:18px;font-size:12.5px;color:#9aa6cc;text-align:center;line-height:1.5}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--ff-display);font-weight:600;font-size:14px;padding:12px 20px;border-radius:11px;border:0;cursor:pointer;color:#fff;background:var(--grad-brand);box-shadow:0 12px 28px -14px rgba(47,107,255,.8);transition:transform .3s var(--ease),filter .3s}
.btn:hover{transform:translateY(-2px);filter:brightness(1.08)}
.btn svg{width:16px;height:16px}
.btn.sm{padding:9px 14px;font-size:13px}
.btn.ghost{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);box-shadow:none;color:#fff}
.btn.ghost:hover{background:rgba(255,255,255,.1)}
.btn.danger{background:rgba(239,68,68,.14);border:1px solid rgba(239,68,68,.4);color:#ff9a9a;box-shadow:none}
.btn.danger:hover{background:rgba(239,68,68,.22)}
.btn.icon{padding:9px;width:36px;height:36px}

/* ---- Shell ---- */
.shell{display:grid;grid-template-columns:248px 1fr;grid-template-rows:64px 1fr;min-height:100vh}
.side{grid-row:1 / 3;background:#070b18;border-right:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.side .brandrow{height:64px;display:flex;align-items:center;padding:0 22px;border-bottom:1px solid rgba(255,255,255,.07);flex:none}
.side .brandrow .logo{display:flex;align-items:center;gap:10px;font-family:var(--ff-display);font-weight:700;font-size:17px}
.side .brandrow .logo .mark{width:34px;height:34px;border-radius:9px;background:var(--grad-brand);display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px}
.side nav{padding:14px 12px;display:flex;flex-direction:column;gap:3px;flex:1}
.side .navlabel{font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#5b6486;padding:14px 12px 6px}
.side a.item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:11px;color:#9aa6cc;font-weight:600;font-size:14.5px;transition:.25s}
.side a.item:hover{background:rgba(255,255,255,.05);color:#fff}
.side a.item.active{background:var(--grad-brand);color:#fff;box-shadow:0 10px 26px -12px rgba(47,107,255,.8)}
.side a.item svg{width:18px;height:18px;flex:none}
.side a.item .badge-n{margin-left:auto;background:#ff5f57;color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;padding:0 6px;border-radius:99px;display:grid;place-items:center}
.side a.item.active .badge-n{background:rgba(255,255,255,.25)}
.side .sideft{padding:14px;border-top:1px solid rgba(255,255,255,.07);flex:none;display:flex;flex-direction:column;gap:8px}

.topbar{grid-column:2;background:#0a0f1f;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:space-between;padding:0 26px;position:sticky;top:0;z-index:10}
.topbar .ttl{font-family:var(--ff-display);font-weight:600;font-size:1.1rem}
.topbar .ttl small{display:block;font-weight:500;font-size:12px;color:#9aa6cc}
.topbar .acts{display:flex;align-items:center;gap:10px}
.burger-adm{display:none;width:40px;height:40px;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);color:#fff;cursor:pointer;align-items:center;justify-content:center}
.burger-adm svg{width:20px;height:20px}

.main{grid-column:2;padding:28px 30px 80px}
.wrapc{max-width:920px}
.h1{font-family:var(--ff-display);font-weight:700;font-size:1.5rem;margin-bottom:4px}
.sub{color:#9aa6cc;font-size:.93rem;margin-bottom:24px}

/* ---- Flash ---- */
.flash{padding:13px 16px;border-radius:11px;font-weight:600;font-size:14px;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.flash.ok{background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.4);color:#7ee0b8}
.flash.bad{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.4);color:#ff9a9a}

/* ---- Stat cards ---- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
.statc{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:22px}
.statc .ic{width:40px;height:40px;border-radius:11px;background:rgba(47,107,255,.16);display:grid;place-items:center;margin-bottom:16px}
.statc .ic svg{width:20px;height:20px;color:var(--blue)}
.statc .n{font-family:var(--ff-display);font-weight:800;font-size:2rem;line-height:1;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.statc .l{color:#9aa6cc;font-size:.85rem;margin-top:8px;font-weight:500}

/* ---- Panels & items ---- */
.panel{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:24px;margin-bottom:20px}
.panel>h3{font-family:var(--ff-display);font-weight:600;font-size:1.1rem;margin-bottom:4px;display:flex;align-items:center;gap:10px}
.panel>.ph{color:#9aa6cc;font-size:.86rem;margin-bottom:18px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.field{margin-bottom:14px}
.field:last-child{margin-bottom:0}
.field label{display:block;font-weight:600;font-size:13px;margin-bottom:7px}
.field .help{font-weight:400;color:#9aa6cc;font-size:11.5px}
.field input[type=text],.field input[type=email],.field input[type=number],.field input[type=password],.field textarea,.field select{width:100%;font-size:14px;padding:11px 13px;border-radius:10px;border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:#fff;transition:.25s;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--blue);background:rgba(255,255,255,.07);box-shadow:0 0 0 3px rgba(47,107,255,.15)}
.field select option{background:#0b1126}
.color-row{display:flex;align-items:center;gap:12px}
.color-row input[type=color]{width:52px;height:42px;padding:3px;border-radius:10px;border:1.5px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);cursor:pointer}
.color-row input[type=text]{flex:1}

.item{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.09);border-radius:16px;padding:18px;margin-bottom:14px}
.item .itop{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.item .iname{font-family:var(--ff-display);font-weight:600;font-size:.98rem;display:flex;align-items:center;gap:10px;min-width:0}
.item .iname .miniico{width:32px;height:32px;border-radius:9px;background:var(--grad-brand);display:grid;place-items:center;flex:none}
.item .iname .miniico svg{width:17px;height:17px;color:#fff}
.item .iname span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.item .ictl{display:flex;gap:6px;flex:none}
.icbtn{width:34px;height:34px;border-radius:9px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:#9aa6cc;cursor:pointer;display:grid;place-items:center;transition:.25s}
.icbtn:hover{color:#fff;background:rgba(255,255,255,.1)}
.icbtn[disabled]{opacity:.3;cursor:not-allowed}
.icbtn svg{width:15px;height:15px}
form.inline{display:inline}
.res-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.thumb-prev{width:100%;max-width:240px;border-radius:10px;border:1px solid rgba(255,255,255,.12);margin-bottom:10px}
.ba-prevs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.ba-prevs figure{margin:0}
.ba-prevs img{width:150px;height:94px;object-fit:cover;border-radius:10px;border:1px solid rgba(255,255,255,.12)}
.ba-prevs figcaption{font-size:11px;color:#9aa6cc;margin-top:4px;font-family:var(--ff-mono)}
.checkrow{display:flex;align-items:center;gap:8px;font-size:13px;color:#cfd8f5;margin:8px 0}
.addnew{border:1.5px dashed rgba(95,139,255,.4);background:rgba(47,107,255,.05);border-radius:18px;padding:22px}
.addnew>h3{color:#9bb6ff}

/* ---- Messages ---- */
.msg{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.09);border-radius:14px;padding:18px;margin-bottom:12px}
.msg.unread{border-color:rgba(95,139,255,.45);background:rgba(47,107,255,.06)}
.msg .mtop{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}
.msg .mname{font-family:var(--ff-display);font-weight:600;display:flex;align-items:center;gap:9px}
.msg .dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex:none}
.msg .memail{color:var(--cyan);font-size:13px;font-family:var(--ff-mono);margin-bottom:8px}
.msg .mdate{color:#9aa6cc;font-size:12px}
.msg .mbody{font-size:.94rem;line-height:1.55;white-space:pre-wrap;color:#dde5ff}
.msg .mctl{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}

.empty{text-align:center;padding:50px 20px;color:#9aa6cc}
.empty svg{width:46px;height:46px;color:#3a4470;margin:0 auto 14px}
.empty h4{font-family:var(--ff-display);color:#fff;font-size:1.1rem;margin-bottom:6px}
.danger-zone{border-color:rgba(239,68,68,.3)}
.quicklinks{display:flex;flex-wrap:wrap;gap:10px}

@media (max-width:1024px){ .cards{grid-template-columns:repeat(2,1fr)} .grid3{grid-template-columns:1fr} }
@media (max-width:760px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;bottom:0;width:248px;z-index:50;transform:translateX(-100%);transition:transform .3s var(--ease)}
  .side.open{transform:none}
  .topbar{grid-column:1}.main{grid-column:1;padding:22px 18px 70px}
  .burger-adm{display:grid}
  .grid2{grid-template-columns:1fr}
}

/* ---- Short links ---- */
.linkrow{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:10px 12px;margin-bottom:14px}
.linkrow .url{font-family:var(--ff-mono);font-size:13px;color:var(--cyan);word-break:break-all;flex:1;min-width:160px}
.linkrow .clicks{font-family:var(--ff-mono);font-size:12px;color:#9aa6cc;background:rgba(255,255,255,.06);border-radius:99px;padding:4px 10px;white-space:nowrap}
.btn.tiny{padding:7px 12px;font-size:12.5px}
.copybtn{cursor:pointer}
.statusdot{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#9aa6cc;margin-right:4px}
.statusdot i{width:8px;height:8px;border-radius:50%}
.statusdot.on{color:#7ee0b8}.statusdot.on i{background:#22c55e}
.statusdot.off i{background:#6b7280}

/* ---- Project editor: section dividers + gallery manager ---- */
.subhead{font-family:var(--ff-display);font-weight:600;font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:var(--cyan);margin:22px 0 12px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.subhead:first-of-type{border-top:0;padding-top:0;margin-top:6px}
.subhead .help{font-family:var(--ff-body);text-transform:none;letter-spacing:0;font-weight:400;color:#8a96bd;font-size:11.5px}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-bottom:14px}
.gthumb{position:relative;display:block;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.12);cursor:pointer}
.gthumb img{width:100%;height:90px;object-fit:cover;display:block}
.gthumb .gdel{position:absolute;inset:auto 0 0 0;background:rgba(7,11,26,.82);color:#ffd0d0;font-size:11px;font-weight:600;padding:5px 8px;display:flex;align-items:center;gap:6px}
.gthumb .gdel input{accent-color:#ef4444}
