/* 참빛디자인 — 관리자 CMS */
:root{
  --paper:#F4F2ED; --panel:#FFFFFF; --ink:#16140F; --muted:#837B6E; --line:#E6E1D8;
  --accent:#E8533B; --accent-soft:rgba(232,83,59,.1); --sidebar:#1A1916; --sidebar-2:#221F1B;
  --line-dark:#322E28; --font:"Pretendard","Pretendard Variable",-apple-system,system-ui,sans-serif;
  --radius:10px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
ul{list-style:none}
::selection{background:var(--accent);color:#fff}

.cms{display:grid;grid-template-columns:264px 1fr;min-height:100vh}

/* Sidebar */
.side{background:var(--sidebar);color:#fff;padding:1.6rem 1.1rem;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;overflow-y:auto}
.side-brand{display:flex;align-items:center;gap:.7rem;font-weight:800;font-size:1.15rem;padding:.4rem .6rem 1.6rem;letter-spacing:-.02em}
.side-brand .mark{width:30px;height:30px;border-radius:8px;background:var(--accent);display:grid;place-items:center;font-weight:900;flex:none}
.side-brand small{display:block;font-size:.6rem;letter-spacing:.12em;opacity:.5;text-transform:uppercase;font-weight:500}
.side-group{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:#6f685c;font-weight:600;padding:1.2rem .8rem .5rem}
.side-nav button{display:flex;align-items:center;gap:.75rem;width:100%;padding:.7rem .8rem;border-radius:8px;color:#b9b2a6;font-size:.9rem;font-weight:500;text-align:left;transition:.2s;margin-bottom:2px}
.side-nav button:hover{background:var(--sidebar-2);color:#fff}
.side-nav button.active{background:var(--accent);color:#fff}
.side-nav button svg{width:18px;height:18px;flex:none}
.side-nav button .badge{margin-left:auto;background:var(--accent);color:#fff;font-size:.7rem;font-weight:700;padding:.05rem .45rem;border-radius:100px}
.side-nav button.active .badge{background:rgba(255,255,255,.25)}
.side-foot{margin-top:auto;padding-top:1.2rem;border-top:1px solid var(--line-dark);display:flex;align-items:center;gap:.7rem;font-size:.82rem;color:#b9b2a6}
.side-foot .av{width:34px;height:34px;border-radius:50%;background:var(--sidebar-2);display:grid;place-items:center;font-weight:700;color:#fff}
.side-foot a{margin-left:auto;color:#6f685c;font-size:.78rem}
.side-foot a:hover{color:#fff}

/* Main */
.main{padding:0;overflow:hidden}
.topbar{position:sticky;top:0;z-index:20;background:rgba(244,242,237,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:1.1rem 2.2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.topbar .crumb{font-size:.78rem;color:var(--muted);letter-spacing:.04em}
.topbar h1{font-size:1.35rem;font-weight:800;letter-spacing:-.02em;margin-top:.2rem}
.topbar-actions{display:flex;gap:.6rem;align-items:center}
.view-site{font-size:.82rem;color:var(--muted);display:flex;align-items:center;gap:.4rem}
.view-site:hover{color:var(--ink)}

.btn{display:inline-flex;align-items:center;gap:.5em;padding:.7em 1.2em;border-radius:8px;font-size:.85rem;font-weight:600;transition:.2s}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:#c8412b}
.btn-ghost{border:1px solid var(--line);color:var(--ink);background:#fff}
.btn-ghost:hover{border-color:var(--ink)}
.btn-sm{padding:.45em .8em;font-size:.78rem}

.content{padding:2.2rem;max-width:1180px}
.panel{display:none}
.panel.active{display:block;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.sect-title{font-size:1rem;font-weight:700;margin-bottom:.3rem}
.sect-desc{font-size:.85rem;color:var(--muted);margin-bottom:1.4rem;max-width:60ch}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem}
.card+.card{margin-top:1.1rem}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.6rem}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem}
.stat .n{font-size:2rem;font-weight:800;letter-spacing:-.02em}
.stat .l{font-size:.8rem;color:var(--muted);margin-top:.2rem}
.stat .d{font-size:.72rem;color:var(--accent);font-weight:600;margin-top:.5rem}

/* hero slide manager */
.hero-rows{display:flex;flex-direction:column;gap:1rem}
.hero-row{display:grid;grid-template-columns:46px 150px 1fr auto;gap:1.2rem;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.2rem}
.drag{color:#c3bdb1;cursor:grab;display:grid;place-items:center}
.thumb{width:150px;aspect-ratio:16/9;border-radius:8px;position:relative;overflow:hidden;background:#ddd}
.thumb .lbl{position:absolute;left:0;right:0;bottom:0;padding:.4rem .5rem;font-size:.62rem;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.6));text-transform:uppercase;letter-spacing:.08em}
.thumb .play{position:absolute;inset:0;display:grid;place-items:center;color:#fff;opacity:.85}
.hr-fields{display:grid;gap:.5rem}
.hr-fields .main-txt{font-weight:700;font-size:1rem}
.hr-fields .sub-txt{font-size:.78rem;color:var(--accent);letter-spacing:.08em}
.hr-fields .lnk{font-size:.76rem;color:var(--muted)}
.row-actions{display:flex;gap:.4rem}
.icon-btn{width:34px;height:34px;border-radius:7px;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);background:#fff;transition:.2s}
.icon-btn:hover{border-color:var(--accent);color:var(--accent)}

/* portfolio table */
.ptable{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.ptable th{text-align:left;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600;padding:.9rem 1.1rem;border-bottom:1px solid var(--line);background:#faf9f6}
.ptable td{padding:.85rem 1.1rem;border-bottom:1px solid var(--line);font-size:.88rem;vertical-align:middle}
.ptable tr:last-child td{border-bottom:none}
.ptable tr:hover td{background:#faf9f6}
.pt-thumb{width:60px;height:42px;border-radius:6px;overflow:hidden}
.pt-name{font-weight:600}
.pt-loc{font-size:.78rem;color:var(--muted)}
.tag{display:inline-block;font-size:.72rem;padding:.2rem .6rem;border-radius:100px;background:var(--accent-soft);color:var(--accent);font-weight:600}
.dot{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem}
.dot::before{content:"";width:7px;height:7px;border-radius:50%;background:#3FB27F}
.dot.draft::before{background:#c3bdb1}
.dot.feat::before{background:var(--accent)}

/* cat chips */
.cats{display:flex;flex-wrap:wrap;gap:.6rem}
.cat-chip{display:flex;align-items:center;gap:.5rem;background:var(--panel);border:1px solid var(--line);border-radius:100px;padding:.5rem .9rem;font-size:.85rem}
.cat-chip button{color:#c3bdb1;font-size:1rem;line-height:1}
.cat-chip button:hover{color:var(--accent)}

/* uploader grid */
.up-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}
.up-item{aspect-ratio:1;border-radius:var(--radius);position:relative;overflow:hidden;border:1px solid var(--line)}
.up-item .lbl{position:absolute;left:0;right:0;bottom:0;padding:.5rem;font-size:.66rem;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.65));letter-spacing:.04em}
.up-item .rm{position:absolute;top:.5rem;right:.5rem;width:26px;height:26px;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;display:grid;place-items:center;font-size:.9rem;opacity:0;transition:.2s}
.up-item:hover .rm{opacity:1}
.up-add{aspect-ratio:1;border:1.5px dashed var(--line);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--muted);font-size:.8rem;transition:.2s}
.up-add:hover{border-color:var(--accent);color:var(--accent)}

/* form fields */
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.fgrid .full{grid-column:1/-1}
.f label{display:block;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:.45rem}
.f input,.f select,.f textarea{width:100%;background:#fff;border:1px solid var(--line);border-radius:8px;padding:.7rem .85rem;font-size:.9rem;color:var(--ink);transition:.2s}
.f textarea{min-height:90px;resize:vertical}
.f input:focus,.f select:focus,.f textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* inquiry list */
.inq{display:flex;flex-direction:column;gap:.7rem}
.inq-item{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.2rem;transition:.2s}
.inq-item:hover{border-color:#d8d2c8}
.inq-item.unread{border-left:3px solid var(--accent)}
.inq-av{width:42px;height:42px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-weight:700}
.inq-main .nm{font-weight:700;font-size:.92rem}
.inq-main .meta{font-size:.78rem;color:var(--muted);margin-top:.15rem}
.inq-main .msg{font-size:.82rem;color:#5a554c;margin-top:.4rem;max-width:60ch}
.inq-right{text-align:right;font-size:.74rem;color:var(--muted)}
.inq-right .tg{margin-bottom:.4rem}

.toast{position:fixed;bottom:1.6rem;right:1.6rem;background:var(--ink);color:#fff;padding:.9rem 1.3rem;border-radius:10px;font-size:.85rem;font-weight:500;opacity:0;transform:translateY(12px);transition:.3s;z-index:60;display:flex;align-items:center;gap:.6rem}
.toast.show{opacity:1;transform:none}
.toast .ok{color:#5fd39a}

.menu-mob{display:none}

@media(max-width:920px){
  .cms{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;z-index:50;transform:translateX(-100%);transition:.3s;width:264px}
  .side.open{transform:none}
  .menu-mob{display:grid;place-items:center;width:40px;height:40px;border-radius:8px;border:1px solid var(--line);background:#fff}
  .stats{grid-template-columns:1fr 1fr}
  .fgrid{grid-template-columns:1fr}
  .hero-row{grid-template-columns:1fr;gap:.8rem}
  .content{padding:1.3rem}
  .topbar{padding:1rem 1.3rem}
}
