:root{
  --ink:#1a1815;--ink-soft:#5a5650;--cream:#f4efe6;--paper:#fbf8f1;
  --accent:#9a3b2e;--accent-deep:#7a2c22;--gold:#b8924a;--line:#ddd4c4;
  --sidebar:#221f1a;--sidebar-soft:#332f28;--ok:#3d8168;--shadow:rgba(40,30,15,.13);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Outfit',sans-serif;background:var(--cream);color:var(--ink);min-height:100vh}
.serif{font-family:'Fraunces',serif}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none}
input,textarea,select{font-family:inherit}

aside{width:268px;background:var(--sidebar);color:#e7ddca;display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;z-index:30;transition:.35s}
.logo{padding:26px 24px;border-bottom:1px solid var(--sidebar-soft);display:flex;align-items:center;gap:12px}
.logo .m{width:40px;height:40px;border-radius:11px;background:var(--accent);display:grid;place-items:center;font-family:'Fraunces',serif;font-size:1.3rem;color:#fff;font-weight:600}
.logo b{font-family:'Fraunces',serif;font-size:1.25rem;font-weight:600;letter-spacing:.3px}
.logo small{display:block;color:#8c8473;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;margin-top:2px}
.menu{flex:1;overflow-y:auto;padding:16px 14px}
.menu::-webkit-scrollbar{width:6px}.menu::-webkit-scrollbar-thumb{background:var(--sidebar-soft);border-radius:3px}
.menu .grp{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:#7a7263;padding:18px 12px 8px}
.menu a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;color:#cabfa9;font-size:.92rem;font-weight:400;transition:.2s;margin-bottom:2px;text-decoration:none;cursor:pointer}
.menu a:hover{background:var(--sidebar-soft);color:#fff}
.menu a.active{background:var(--accent);color:#fff;font-weight:500}
.menu a svg{width:18px;height:18px;stroke-width:1.8;flex-shrink:0}

main{margin-left:268px;flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{height:70px;background:var(--paper);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:20}
.topbar .crumb{font-size:.85rem;color:var(--ink-soft)}
.topbar .crumb b{font-family:'Fraunces',serif;font-size:1.35rem;color:var(--ink);display:block;font-weight:600}
.topbar-actions{display:flex;gap:10px;align-items:center}
.hamburger{display:none;background:none;flex-direction:column;gap:4px}
.hamburger span{width:22px;height:2px;background:var(--ink);display:block}
.content{padding:32px;flex:1;max-width:1100px}

.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;font-weight:500;font-size:.9rem;transition:.25s;text-decoration:none}
.btn-primary{background:var(--ink);color:var(--paper)}.btn-primary:hover{background:var(--accent)}
.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent-deep)}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}.btn-ghost:hover{border-color:var(--ink)}
.btn-sm{padding:7px 14px;font-size:.82rem;border-radius:8px}
.btn-danger{background:#f3e3e0;color:var(--accent-deep)}.btn-danger:hover{background:var(--accent);color:#fff}
.btn svg{width:16px;height:16px;stroke-width:2}

.panel{display:none;animation:fade .4s}
.panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.panel-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px;flex-wrap:wrap;gap:14px}
.panel-head h2{font-family:'Fraunces',serif;font-size:1.7rem;font-weight:600}
.panel-head p{color:var(--ink-soft);font-size:.92rem;margin-top:2px}

.card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:26px;margin-bottom:20px}
.card h3{font-family:'Fraunces',serif;font-size:1.15rem;margin-bottom:18px;font-weight:600;display:flex;align-items:center;gap:10px}
.card h3 .num{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:.85rem;font-family:'Outfit'}

.field{margin-bottom:18px}
.field label{display:block;font-size:.82rem;font-weight:500;margin-bottom:7px;color:var(--ink)}
.field label .hint{color:var(--ink-soft);font-weight:300;font-size:.78rem}
.field input[type=text],.field input[type=email],.field input[type=tel],.field input[type=date],.field input[type=number],.field input[type=url],.field input[type=password],.field select,.field textarea{
  width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:.92rem;color:var(--ink);transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(154,59,46,.1)}
.field textarea{resize:vertical;min-height:80px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:680px){.row{grid-template-columns:1fr}}

.wysiwyg{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff}
.wys-toolbar{display:flex;gap:2px;flex-wrap:wrap;padding:6px;background:var(--cream);border-bottom:1px solid var(--line)}
.wys-toolbar button{width:32px;height:32px;border-radius:7px;background:transparent;color:var(--ink-soft);font-size:.9rem;display:grid;place-items:center;transition:.18s;font-weight:600}
.wys-toolbar button:hover{background:#fff;color:var(--accent)}
.wys-toolbar .sep{width:1px;background:var(--line);margin:4px 4px}
.wys-area{min-height:120px;padding:14px 16px;font-size:.95rem;line-height:1.6;outline:none}
.wys-area:empty:before{content:attr(data-ph);color:#b3a994}
.wys-area p{margin-bottom:8px}

.uploader{border:2px dashed var(--line);border-radius:12px;padding:22px;text-align:center;color:var(--ink-soft);cursor:pointer;transition:.25s;background:#fff}
.uploader:hover{border-color:var(--accent);background:#fffdf8}
.uploader svg{width:30px;height:30px;stroke-width:1.5;margin:0 auto 8px;display:block;stroke:var(--accent)}
.uploader small{font-size:.78rem;display:block;margin-top:4px}
.thumb-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.thumb{position:relative;width:84px;height:84px;border-radius:10px;overflow:hidden;border:1px solid var(--line)}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb .x{position:absolute;top:3px;right:3px;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;font-size:.7rem;display:grid;place-items:center;cursor:pointer}
.thumb-single{width:130px;height:130px}

.entry{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:flex-start;gap:16px;transition:.2s}
.entry:hover{border-color:var(--gold);box-shadow:0 6px 18px var(--shadow)}
.entry .ico{width:44px;height:44px;border-radius:10px;background:var(--cream);display:grid;place-items:center;font-size:1.2rem;flex-shrink:0}
.entry .info{flex:1;min-width:0}
.entry .info h4{font-size:1rem;font-weight:600;margin-bottom:3px}
.entry .info .sub{font-size:.84rem;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.entry .acts{display:flex;gap:8px;flex-shrink:0}
.entry-list-empty{text-align:center;padding:40px;color:var(--ink-soft);font-style:italic;background:#fff;border:1px dashed var(--line);border-radius:12px}

.modal-bg{position:fixed;inset:0;background:rgba(26,24,21,.55);backdrop-filter:blur(4px);z-index:100;display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.modal-bg.open{display:flex}
.modal{background:var(--paper);border-radius:18px;width:100%;max-width:640px;box-shadow:0 40px 90px rgba(0,0,0,.35);animation:pop .3s}
@keyframes pop{from{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:none}}
.modal-head{padding:22px 26px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.modal-head h3{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:600}
.modal-head .close{width:34px;height:34px;border-radius:9px;background:var(--cream);font-size:1.2rem;color:var(--ink-soft);display:grid;place-items:center}
.modal-head .close:hover{background:var(--accent);color:#fff}
.modal-body{padding:26px;max-height:65vh;overflow-y:auto}
.modal-foot{padding:18px 26px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px}

.toast{position:fixed;bottom:28px;right:28px;background:var(--ok);color:#fff;padding:14px 22px;border-radius:12px;font-weight:500;font-size:.9rem;box-shadow:0 14px 40px rgba(0,0,0,.25);transform:translateY(120px);transition:.4s;z-index:200;display:flex;align-items:center;gap:10px}
.toast.show{transform:none}
.toast svg{width:18px;height:18px;stroke-width:2.4}

.banner-preview{display:flex;gap:10px;overflow-x:auto;padding:10px;background:var(--cream);border-radius:10px;margin-top:12px}
.banner-preview .thumb{height:90px;width:auto}
.banner-preview .thumb img{width:auto;height:90px}

.overlay-mob{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:25}
.overlay-mob.show{display:block}

/* settings groups */
.set-group{margin-bottom:18px}
.set-group .grp-t{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:600;margin-bottom:14px}

/* theme color pickers */
.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.color-field{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:12px;background:#fff}
.color-field input[type=color]{width:44px;height:44px;border:none;border-radius:10px;background:none;cursor:pointer;padding:0}
.color-field input[type=color]::-webkit-color-swatch-wrapper{padding:0}
.color-field input[type=color]::-webkit-color-swatch{border:1px solid var(--line);border-radius:10px}
.color-field .cf-meta{flex:1;min-width:0}
.color-field .cf-meta label{font-size:.84rem;font-weight:500;display:block}
.color-field .cf-meta .hex{font-size:.76rem;color:var(--ink-soft);font-family:monospace}
.theme-preview{border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.theme-preview .tp-hero{padding:34px;display:flex;flex-direction:column;gap:10px}
.theme-preview .tp-eyebrow{font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;font-weight:700}
.theme-preview .tp-title{font-family:'Fraunces',serif;font-size:1.9rem;font-weight:500}
.theme-preview .tp-title em{font-style:italic}
.theme-preview .tp-sub{font-size:.92rem}
.theme-preview .tp-btns{display:flex;gap:10px;margin-top:6px}
.theme-preview .tp-btn{padding:9px 18px;border-radius:30px;font-size:.82rem;font-weight:600}

@media(max-width:880px){
  aside{transform:translateX(-100%)}
  aside.open{transform:none}
  main{margin-left:0}
  .hamburger{display:flex}
}

/* ===== login screen ===== */
.login-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at 30% 20%,#2a251e,#1a1815);z-index:500}
.login-card{background:var(--paper);border-radius:22px;padding:40px;width:100%;max-width:420px;box-shadow:0 40px 100px rgba(0,0,0,.45);animation:pop .35s}
.login-brand{display:flex;align-items:center;gap:13px;margin-bottom:26px}
.login-brand .m{width:44px;height:44px;border-radius:12px;background:var(--accent);display:grid;place-items:center;font-family:'Fraunces',serif;font-size:1.4rem;color:#fff;font-weight:600}
.login-brand b{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:600;display:block}
.login-brand small{color:var(--ink-soft);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase}
.login-card h2{font-family:'Fraunces',serif;font-size:1.6rem;font-weight:600;margin-bottom:6px}
.login-sub{color:var(--ink-soft);font-size:.92rem;margin-bottom:24px}
.login-err{color:var(--accent-deep);background:#f3e3e0;border-radius:9px;padding:10px 14px;font-size:.86rem;margin-bottom:14px;display:none}
.login-err.show{display:block}
.btn-block{width:100%;justify-content:center;padding:13px}
.login-back{display:inline-block;margin-top:18px;color:var(--ink-soft);font-size:.88rem}
.login-back:hover{color:var(--accent)}

.admin-app{display:flex;min-height:100vh}
.admin-app[hidden]{display:none}

.side-foot{padding:16px;border-top:1px solid var(--sidebar-soft);display:flex;flex-direction:column;gap:8px}
.side-foot a,.side-foot button{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:9px;font-size:.85rem;color:#cabfa9;background:transparent;text-decoration:none;transition:.2s;text-align:left;width:100%}
.side-foot a:hover,.side-foot button:hover{background:var(--sidebar-soft);color:#fff}
.topbar-actions .who{font-size:.85rem;color:var(--ink-soft);margin-right:4px}
