@import url('https://fonts.googleapis.com/css2?family=Mulish:wght@400;500;600;700;800&family=Cormorant+Garamond:wght@600&display=swap');
:root{
  --rose:#ba897c;--rose-deep:#9d6f63;--blush:#f7dede;--blush-2:#fbeeec;
  --cream:#f6f2ef;--ink:#282828;--ink-soft:#6b6460;--line:#ececec;--line2:#e3dad5;
  --white:#fff;--ok:#13612e;--warn:#b8730c;--alert:#b82105;--info:#1159af;
  --sans:'Mulish',-apple-system,Segoe UI,sans-serif;--serif:'Cormorant Garamond',serif;
  --r:14px;--shadow:0 12px 36px -24px rgba(120,80,70,.5);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);background:#f4efec;color:var(--ink);font-size:15px;line-height:1.55}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit;font-size:inherit}
img{max-width:100%;display:block}

/* layout */
.layout{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:#fff;border-right:1px solid var(--line);padding:0 0 2rem;position:sticky;top:0;height:100vh;overflow-y:auto}
.side .logo{padding:1.3rem 1.4rem;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:.6rem}
.side .logo img{height:30px}
.side .logo b{font-family:var(--serif);font-size:1.2rem}
.side nav{padding:1rem .8rem;display:flex;flex-direction:column;gap:.2rem}
.side nav a{display:flex;align-items:center;gap:.8rem;padding:.7rem .9rem;border-radius:10px;color:var(--ink-soft);font-weight:600;font-size:.92rem;transition:.2s}
.side nav a svg{width:19px;height:19px;flex-shrink:0}
.side nav a:hover{background:var(--blush-2);color:var(--rose-deep)}
.side nav a.active{background:var(--rose);color:#fff}
.side nav a .count{margin-left:auto;background:var(--blush);color:var(--rose-deep);font-size:.72rem;font-weight:800;padding:.1rem .5rem;border-radius:99px}
.side nav a.active .count{background:rgba(255,255,255,.25);color:#fff}
.side .sep{margin:.6rem 1.4rem;border-top:1px solid var(--line);height:0}

.main{padding:1.6rem clamp(1rem,3vw,2.4rem) 3rem;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.6rem;flex-wrap:wrap}
.topbar h1{font-family:var(--serif);font-size:1.9rem;font-weight:600}
.topbar .muted{color:var(--ink-soft);font-size:.9rem}
.topbar-actions{display:flex;gap:.6rem;align-items:center}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.1rem;border-radius:10px;font-weight:700;font-size:.86rem;cursor:pointer;border:1px solid transparent;transition:.2s;white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--rose);color:#fff}.btn-primary:hover{background:var(--rose-deep)}
.btn-ghost{background:#fff;border-color:var(--line2);color:var(--ink)}.btn-ghost:hover{border-color:var(--rose);color:var(--rose-deep)}
.btn-danger{background:#fff;border-color:#f0c9c2;color:var(--alert)}.btn-danger:hover{background:var(--alert);color:#fff;border-color:var(--alert)}
.btn-sm{padding:.4rem .7rem;font-size:.8rem;border-radius:8px}

/* cards / stats */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.6rem}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.2rem 1.3rem}
.stat .lab{font-size:.8rem;color:var(--ink-soft);font-weight:600;letter-spacing:.02em;display:flex;align-items:center;gap:.5rem}
.stat .lab svg{width:16px;height:16px;color:var(--rose)}
.stat .num{font-family:var(--serif);font-size:2.2rem;font-weight:600;margin-top:.3rem;line-height:1}
.stat .sub{font-size:.78rem;color:var(--ink-soft);margin-top:.3rem}

.panel{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:1.6rem}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.3rem;border-bottom:1px solid var(--line)}
.panel-head h2{font-family:var(--serif);font-size:1.35rem;font-weight:600}
.panel-body{padding:1.3rem}

/* table */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);padding:.7rem 1.3rem;border-bottom:1px solid var(--line);background:#faf7f5}
.tbl td{padding:.85rem 1.3rem;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tr:last-child td{border-bottom:0}
.tbl tr:hover td{background:#fcf9f8}
.tbl .thumb{width:44px;height:44px;border-radius:8px;object-fit:cover;background:var(--blush-2)}
.tbl .name{font-weight:700}
.tbl .muted{color:var(--ink-soft);font-size:.85rem}
.row-actions{display:flex;gap:.4rem;justify-content:flex-end}

/* badges */
.badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.74rem;font-weight:800;padding:.25rem .6rem;border-radius:99px;letter-spacing:.02em}
.b-rose{background:var(--blush);color:var(--rose-deep)}
.b-green{background:#e3f3e8;color:var(--ok)}
.b-blue{background:#e1ecfb;color:var(--info)}
.b-amber{background:#fcefd9;color:var(--warn)}
.b-red{background:#fbe3df;color:var(--alert)}
.b-gray{background:#eee;color:#555}
.dot{width:7px;height:7px;border-radius:50%;background:currentColor}

/* forms */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.2rem}
.fld{display:flex;flex-direction:column;gap:.4rem;margin-bottom:0}
.fld.full{grid-column:1/-1}
.fld label{font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft)}
.fld input,.fld select,.fld textarea{padding:.7rem .85rem;border:1px solid var(--line2);border-radius:10px;background:#fff;color:var(--ink)}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--rose);box-shadow:0 0 0 3px rgba(186,137,124,.15)}
.fld textarea{resize:vertical;min-height:90px}
.fld .hint{font-size:.76rem;color:var(--ink-soft)}
.switch{display:flex;align-items:center;gap:.6rem;font-weight:600;font-size:.9rem}
.switch input{width:18px;height:18px;accent-color:var(--rose)}

.notice{padding:.85rem 1.1rem;border-radius:10px;margin-bottom:1.3rem;font-weight:600;font-size:.9rem}
.notice-ok{background:#e3f3e8;color:var(--ok)}
.notice-err{background:#fbe3df;color:var(--alert)}

.empty{text-align:center;padding:3rem 1rem;color:var(--ink-soft)}
.empty svg{width:48px;height:48px;color:var(--rose);opacity:.6;margin:0 auto 1rem}

/* login */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:1.5rem;background:linear-gradient(160deg,var(--cream),var(--blush-2))}
.login-card{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:2.4rem;width:100%;max-width:400px}
.login-card .logo{text-align:center;margin-bottom:1.4rem}
.login-card .logo img{height:40px;margin:0 auto .6rem}
.login-card h1{font-family:var(--serif);font-size:1.6rem;text-align:center;margin-bottom:.3rem}
.login-card p{text-align:center;color:var(--ink-soft);font-size:.9rem;margin-bottom:1.6rem}

/* mobile */
.menu-toggle{display:none}
@media(max-width:880px){
  .layout{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;bottom:0;width:248px;z-index:50;transform:translateX(-100%);transition:.3s}
  body.nav-open .side{transform:none}
  .menu-toggle{display:inline-flex}
  .cards{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
  .scroll-x{overflow-x:auto}
}
@media(max-width:560px){.cards{grid-template-columns:1fr}}
