/* ============================================================
   cms.css — Upayukta Prints content manager (MODERN)
   Matches site: Sora + Plus Jakarta Sans, rounded, soft shadows.
   ============================================================ */
:root{
  --bg:#FFFFFF;--bg-2:#F6F7F9;--bg-3:#EEF0F4;
  --ink:#15161B;--ink-2:#5A5F6B;--ink-3:#9499A5;
  --line:#EBEDF1;--line-2:#DDE0E7;--white:#fff;
  --accent:#3142E0;--accent-ink:#2333C4;--accent-tint:#EEF0FE;--accent-shadow:rgba(49,66,224,.25);
  --ok:#1F9D62;
  --display:'Sora',system-ui,sans-serif;--sans:'Plus Jakarta Sans',system-ui,sans-serif;
  --r-sm:9px;--r:12px;--r-lg:16px;--r-pill:999px;
  --sh-1:0 1px 2px rgba(20,22,30,.05),0 4px 12px -4px rgba(20,22,30,.08);
  --sh-2:0 2px 6px rgba(20,22,30,.06),0 18px 40px -16px rgba(20,22,30,.16);
  --ease:cubic-bezier(.4,.7,.25,1);--spring:cubic-bezier(.34,1.4,.5,1);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg-2);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;letter-spacing:-.01em}
a{color:inherit}button{font-family:inherit}
::selection{background:var(--accent);color:#fff}

/* ---- top bar ---- */
.topbar{position:sticky;top:0;z-index:30;height:66px;background:rgba(255,255,255,.85);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:18px;padding:0 22px}
.topbar .tb-brand{display:flex;align-items:center;gap:11px}
.topbar .tb-brand img{height:34px}
.topbar .tb-brand b{font-family:var(--display);font-weight:700;font-size:16px}
.topbar .tb-brand .tag{font-size:9px;font-weight:700;letter-spacing:.22em;color:var(--ink-3);display:block;margin-top:2px}
.tb-actions{display:flex;align-items:center;gap:9px}
.tb-status{font-size:12px;font-weight:600;color:var(--ink-3);margin-right:6px;transition:color .2s;display:inline-flex;align-items:center;gap:6px}
.tb-status.saved{color:var(--ok)}
.cms-btn{appearance:none;border:1px solid var(--line-2);background:var(--bg);color:var(--ink);border-radius:var(--r);
  font-size:13px;font-weight:600;letter-spacing:-.01em;padding:10px 16px;cursor:pointer;
  transition:transform .2s var(--spring),background .18s,color .18s,border-color .18s,box-shadow .18s;display:inline-flex;align-items:center;gap:7px}
.cms-btn:hover{transform:translateY(-1px);box-shadow:var(--sh-1);background:var(--bg-2)}
.cms-btn:active{transform:translateY(0)}
.cms-btn--accent{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 10px var(--accent-shadow)}
.cms-btn--accent:hover{background:var(--accent-ink);color:#fff}

/* ---- layout ---- */
.shell{display:grid;grid-template-columns:minmax(430px,1fr) 1.15fr;height:calc(100vh - 66px)}
.panel{overflow-y:auto;padding:26px 26px 90px;border-right:1px solid var(--line)}
.preview-pane{position:relative;background:var(--bg-3)}
.preview-bar{height:44px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border-bottom:1px solid var(--line);background:var(--bg)}
.preview-bar .pv-label{font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--ink-3)}
.preview-frame{width:100%;height:calc(100% - 44px);border:0;background:#fff;display:block}

.panel-intro{margin-bottom:24px}
.panel-intro h1{font-family:var(--display);font-weight:700;font-size:25px;letter-spacing:-.03em;margin:0 0 6px}
.panel-intro p{color:var(--ink-2);font-size:14px;margin:0;max-width:48ch}

/* ---- collapsible section ---- */
.cms-sec{border:1px solid var(--line);background:var(--bg);border-radius:var(--r-lg);margin-bottom:12px;box-shadow:var(--sh-1);overflow:hidden}
.cms-sec-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px 18px;cursor:pointer;user-select:none;transition:background .15s}
.cms-sec-head:hover{background:var(--bg-2)}
.cms-sec-head h3{font-family:var(--display);font-weight:700;font-size:16px;margin:0;letter-spacing:-.02em}
.cms-sec-head .chev{font-size:12px;color:var(--ink-3);transition:transform .25s var(--spring)}
.cms-sec.open .cms-sec-head .chev{transform:rotate(90deg)}
.cms-sec-body{display:none;padding:4px 18px 22px;border-top:1px solid var(--line)}
.cms-sec.open .cms-sec-body{display:block}
.cms-sec-head .ct{font-size:11px;font-weight:600;color:var(--ink-3);background:var(--bg-2);padding:3px 9px;border-radius:var(--r-pill)}

/* ---- fields ---- */
.fld{display:grid;gap:6px;margin-top:16px}
.fld:first-child{margin-top:10px}
.fld label{font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--ink-2)}
.fld input,.fld textarea{font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--bg-2);
  border:1px solid var(--line);border-radius:var(--r);padding:11px 13px;transition:border-color .18s,background .18s,box-shadow .18s;width:100%}
.fld input:focus,.fld textarea:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 4px var(--accent-tint)}
.fld textarea{resize:vertical;min-height:74px;line-height:1.5}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ---- repeatable items ---- */
.cms-item{border:1px solid var(--line);background:var(--bg-2);border-radius:var(--r);padding:14px 14px 16px;margin-bottom:10px;position:relative}
.cms-item .item-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}
.cms-item .item-n{font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--ink-3)}
.icon-btn{appearance:none;border:1px solid var(--line-2);background:var(--bg);color:var(--ink-2);cursor:pointer;border-radius:var(--r-pill);
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .16s}
.icon-btn:hover{background:#F0552E;color:#fff;border-color:#F0552E;transform:scale(1.05)}
.add-btn{appearance:none;border:1.5px dashed var(--line-2);background:transparent;color:var(--ink-2);cursor:pointer;border-radius:var(--r);
  font-size:13px;font-weight:600;padding:12px;width:100%;transition:all .18s;margin-top:4px}
.add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-tint)}

.cms-group{border:1px solid var(--line-2);background:var(--bg);border-radius:var(--r);padding:15px;margin-bottom:12px}
.cms-group > .grp-title{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin-bottom:4px}

.chk{display:flex;align-items:center;gap:9px;margin-top:14px;cursor:pointer;font-size:13px;font-weight:500;color:var(--ink-2)}
.chk input{width:17px;height:17px;accent-color:var(--accent)}

.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(20px);opacity:0;
  background:var(--ink);color:#fff;font-size:13px;font-weight:600;padding:12px 20px;border-radius:var(--r-pill);z-index:60;
  transition:opacity .25s,transform .3s var(--spring);pointer-events:none;box-shadow:var(--sh-2)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:900px){
  .shell{grid-template-columns:1fr;height:auto}
  .panel{border-right:0;border-bottom:1px solid var(--line);height:auto}
  .preview-pane{height:80vh}
  .preview-frame{height:calc(80vh - 44px)}
}
