/* 쌍샘자연교회 주보 시스템 — 관리자 UI. reference/design.html 디자인 토큰 기반. */
@import url('https://fonts.googleapis.com/css2?family=Gowun+Batang:wght@400;700&family=Gothic+A1:wght@300;400;500;600;700;800&display=swap');

:root{
  --bg:#f4f1ea; --panel:#fffdf8; --ink:#2b2a26; --ink-soft:#6f6a5f;
  --line:#e2dccd; --line-strong:#d3cbb6; --rose:#d98a8a; --rose-soft:#f6e6e6;
  --rose-deep:#bb6b6b; --sage:#7d8a6a; --sage-soft:#e9ede1; --gold:#b7943f;
  --readonly:#efece3; --warn:#c9683f; --warn-soft:#f8e6dd; --ok:#5f7d5a;
  --shadow:0 1px 2px rgba(60,52,40,.06),0 8px 24px rgba(60,52,40,.08); --radius:14px;
}
*{box-sizing:border-box} html,body{margin:0;height:100%}
body{background:radial-gradient(1200px 600px at 80% -10%,#faf6ec 0%,transparent 60%),var(--bg);
  color:var(--ink);font-family:'Gothic A1',sans-serif;font-weight:400;-webkit-font-smoothing:antialiased}
.serif{font-family:'Gowun Batang',serif}
a{color:inherit}

/* shell */
.app{display:grid;grid-template-columns:230px 1fr;height:100vh}
.sidebar{background:linear-gradient(180deg,#34322c,#2a2823);color:#e9e4d6;padding:22px 16px;display:flex;flex-direction:column;gap:4px}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}
.brand .mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--rose),#caa0a0);display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px}
.brand b{font-size:15px;display:block;line-height:1.2}.brand span{font-size:11px;color:#a59f8f}
.nav-group{font-size:10.5px;letter-spacing:1.5px;color:#8f897a;margin:14px 10px 4px;font-weight:600}
.nav a{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;color:#d8d2c4;text-decoration:none;font-size:13.5px;font-weight:500;cursor:pointer}
.nav a .ico{width:17px;text-align:center;opacity:.85}
.nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.nav a.active{background:var(--rose);color:#fff;box-shadow:var(--shadow)}
.sidebar .foot{margin-top:auto;font-size:11px;color:#8a8474;padding:10px;border-top:1px solid rgba(255,255,255,.08)}
.main{overflow:auto;position:relative}
.topbar{position:sticky;top:0;z-index:20;backdrop-filter:blur(8px);background:rgba(244,241,234,.85);border-bottom:1px solid var(--line);padding:14px 28px;display:flex;align-items:center;gap:14px}
.crumb{font-size:12.5px;color:var(--ink-soft)} .crumb b{color:var(--ink)} .topbar .grow{flex:1}
.pill{font-size:11px;padding:4px 10px;border-radius:999px;border:1px solid var(--line-strong);background:var(--panel);color:var(--ink-soft);font-weight:600}
.view{padding:26px 28px 60px}
h1.page{font-family:'Gowun Batang',serif;font-size:25px;margin:0 0 3px;font-weight:700}
.sub{color:var(--ink-soft);font-size:13px;margin-bottom:22px}

/* buttons */
.btn{font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;border:none;padding:9px 16px;border-radius:10px;display:inline-flex;align-items:center;gap:7px;transition:transform .1s,background .15s}
.btn:active{transform:translateY(1px)} .btn:disabled{opacity:.5;cursor:not-allowed}
.btn.primary{background:var(--rose);color:#fff;box-shadow:var(--shadow)} .btn.primary:hover{background:var(--rose-deep)}
.btn.ghost{background:var(--panel);color:var(--ink);border:1px solid var(--line-strong)} .btn.ghost:hover{border-color:var(--rose);color:var(--rose-deep)}
.btn.dark{background:#34322c;color:#f1ece0} .btn.sm{padding:6px 11px;font-size:12px;border-radius:8px}
.btn.danger{background:var(--warn-soft);color:var(--warn)}

/* cards */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:16px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:transform .15s,border-color .15s}
.card.clk{cursor:pointer} .card.clk:hover{transform:translateY(-3px);border-color:var(--line-strong)}
.card .mon{font-family:'Gowun Batang',serif;font-size:21px;font-weight:700}
.card .iss{font-size:12px;color:var(--ink-soft);margin-top:2px}
.card .meta{display:flex;gap:7px;flex-wrap:wrap;margin:14px 0}
.tag{font-size:11px;padding:3px 9px;border-radius:7px;background:var(--sage-soft);color:#566046;font-weight:600}
.tag.alt{background:#eee7f0;color:#6b5673}
.status{font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px}
.s-draft{background:#efece3;color:#7a7565}.s-edited{background:#eaf0e6;color:#5f7d5a}
.s-rendered{background:#e6eef4;color:#456a86}.s-published{background:var(--rose-soft);color:var(--rose-deep)}
.card .row{display:flex;align-items:center;justify-content:space-between;margin-top:6px}
.card .date{font-size:11px;color:#a39d8e}
.newcard{border:1.5px dashed var(--line-strong);background:transparent;display:grid;place-items:center;min-height:172px;color:var(--ink-soft);text-align:center;cursor:pointer}
.newcard:hover{border-color:var(--rose);color:var(--rose-deep)} .newcard .plus{font-size:30px;margin-bottom:6px}

/* forms */
.field{margin-top:13px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin-bottom:5px}
.field input[type=text],.field input[type=password],.field textarea,.field select{width:100%;font-family:inherit;font-size:13.5px;color:var(--ink);background:#fff;border:1px solid var(--line-strong);border-radius:9px;padding:9px 11px}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--rose);box-shadow:0 0 0 3px var(--rose-soft)}
.field textarea{resize:vertical;min-height:64px;line-height:1.5}
.field textarea.poem{font-family:'Gowun Batang',serif;min-height:120px;white-space:pre-wrap}
.two{display:grid;grid-template-columns:1fr 110px;gap:10px} .row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hint{font-size:11px;color:#a39d8e;margin-top:4px}
.ro input,.ro textarea,input.ro,textarea.ro{background:var(--readonly);border-style:dashed!important;color:var(--ink-soft);cursor:not-allowed}
.lyr{font-size:10px;font-weight:700;padding:2px 7px;border-radius:6px;margin-left:7px;vertical-align:middle}
.lyr-A{background:#e8e4da;color:#857f6e}.lyr-E{background:#e6eef4;color:#456a86}.lyr-D{background:#f0eaf0;color:#7d6385}.lyr-B{background:#eef3e8;color:#5f7d5a}.lyr-C{background:#fbeede;color:#9a7a3a}
.counter{float:right;font-size:11px;color:#a39d8e;font-weight:600}.counter.over{color:var(--warn)}
.dropzone{border:1.5px dashed var(--line-strong);border-radius:11px;padding:16px;text-align:center;color:var(--ink-soft);background:#fcfaf4;cursor:pointer}
.dropzone:hover{border-color:var(--rose);background:#fdf6f3}
.dropzone img{max-height:150px;border-radius:6px;border:1px solid var(--line);margin-bottom:8px}
.dpi-ok{display:inline-block;font-size:11px;font-weight:700;color:var(--ok);background:#eaf0e6;padding:3px 10px;border-radius:7px}
.dpi-warn{display:inline-block;font-size:11px;font-weight:700;color:var(--warn);background:var(--warn-soft);padding:3px 10px;border-radius:7px}

/* workspace */
.ws{display:grid;grid-template-columns:280px 1fr;height:calc(100vh - 53px)}
.ws-aside{border-right:1px solid var(--line);background:var(--panel);overflow:auto;padding:16px}
.ws-aside h3{font-size:11px;letter-spacing:1.2px;color:var(--ink-soft);margin:4px 6px 12px;font-weight:700}
.page-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:9px;cursor:pointer;font-size:13px;margin-bottom:2px;border:1px solid transparent}
.page-item:hover{background:#f6f2e9}.page-item.active{background:var(--rose-soft);border-color:#eccbcb}
.page-item .seq{width:22px;height:22px;border-radius:6px;background:#ece6d8;color:#7a7565;font-size:11px;font-weight:700;display:grid;place-items:center;flex:0 0 auto}
.page-item.active .seq{background:var(--rose);color:#fff}.page-item .nm{flex:1;line-height:1.25}.page-item .nm small{display:block;color:var(--ink-soft);font-size:10.5px}
.dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto}.d-empty{background:#d8d2c2}.d-progress{background:var(--gold)}.d-done{background:var(--ok)}.d-warn{background:var(--warn)}
.ws-aside .divider{height:1px;background:var(--line);margin:12px 4px}
.ws-main{overflow:auto;padding:22px 26px}
.ws-head{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.ws-head .ttl{font-family:'Gowun Batang',serif;font-size:20px;font-weight:700}
.ws-head .occ{font-size:12px;color:var(--rose-deep);background:var(--rose-soft);padding:3px 10px;border-radius:7px;font-weight:600}.ws-head .grow{flex:1}
.section{background:var(--panel);border:1px solid var(--line);border-radius:12px;margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow)}
.section>summary{list-style:none;cursor:pointer;padding:13px 16px;font-weight:700;font-size:13.5px;background:linear-gradient(90deg,#fbf8f1,#fffdf8)}
.section>summary::-webkit-details-marker{display:none}.section .body{padding:6px 16px 16px}

/* item list */
.items .item{display:flex;align-items:flex-start;gap:9px;margin-bottom:7px}
.items .item .no{width:24px;height:34px;display:grid;place-items:center;color:var(--ink-soft);font-weight:700;font-size:12px}
.items .item input{flex:1}.items .item .del{border:none;background:transparent;color:#c5b8a0;cursor:pointer;font-size:16px}
.items .item .del:hover{color:var(--warn)}
.toggle{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:600;cursor:pointer}
.switch{width:40px;height:22px;border-radius:999px;background:#d6cfbe;position:relative;transition:background .2s}
.switch::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s}
.toggle.on .switch{background:var(--sage)}.toggle.on .switch::after{transform:translateX(18px)}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(40,36,30,.55);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:50}
.overlay.show{display:flex}
.pv{background:var(--bg);border-radius:16px;width:min(960px,94vw);max-height:92vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.pvhead{display:flex;align-items:center;gap:12px;padding:15px 20px;background:var(--panel);border-bottom:1px solid var(--line)}
.pvhead .t{font-family:'Gowun Batang',serif;font-weight:700;font-size:16px}.pvhead .grow{flex:1}
.x{border:none;background:#ece6d8;width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:16px;color:#6f6a5f}
.stage{padding:26px;overflow:auto;display:flex;gap:24px;justify-content:center;background:repeating-linear-gradient(45deg,#efebe1,#efebe1 12px,#ece7dc 12px,#ece7dc 24px)}
.stage img{background:#fff;box-shadow:0 10px 30px rgba(0,0,0,.25);max-height:74vh}
.pvfoot{padding:13px 20px;background:var(--panel);border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}
.warnline{font-size:12px;color:var(--warn);font-weight:600}
.thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:24px;overflow:auto;background:#efebe1}
.thumb{background:#fff;border-radius:3px;box-shadow:0 4px 12px rgba(0,0,0,.15);aspect-ratio:150/240;position:relative;cursor:pointer;overflow:hidden}
.thumb img{width:100%;height:100%;object-fit:contain}
.thumb .tn{position:absolute;left:6px;top:6px;font-size:9px;background:#34322c;color:#fff;padding:2px 6px;border-radius:4px;font-weight:700}
.thumb .tw{position:absolute;right:6px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--warn)}

/* wizard */
.wiz{max-width:640px}.steps{display:flex;gap:8px;margin-bottom:24px}
.step{flex:1;text-align:center;font-size:12px;color:var(--ink-soft);padding-bottom:9px;border-bottom:2px solid var(--line)}
.step.on{color:var(--rose-deep);border-color:var(--rose);font-weight:700}
.choice{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.opt{border:1.5px solid var(--line-strong);border-radius:12px;padding:18px;cursor:pointer;background:var(--panel)}
.opt.sel{border-color:var(--rose);box-shadow:0 0 0 3px var(--rose-soft)}.opt .n{font-family:'Gowun Batang',serif;font-size:30px;font-weight:700}.opt .d{font-size:12px;color:var(--ink-soft);margin-top:4px}
.calcbox{background:var(--sage-soft);border-radius:11px;padding:15px 17px;margin-top:18px;font-size:13px;color:#4f5a40}.calcbox b{color:#3c4632}
.preview-list{margin-top:14px;border:1px solid var(--line);border-radius:11px;overflow:hidden}
.preview-list .pl{display:flex;align-items:center;gap:10px;padding:8px 13px;font-size:12.5px;border-bottom:1px solid var(--line);background:var(--panel)}
.preview-list .pl:last-child{border:none}.preview-list .pl .s{width:22px;height:22px;border-radius:5px;background:#ece6d8;font-size:10px;display:grid;place-items:center;color:#7a7565;font-weight:700}
.note{font-size:12px;color:var(--ink-soft);background:#fbf8f1;border-left:3px solid var(--rose);padding:10px 13px;border-radius:0 8px 8px 0;margin-top:16px;line-height:1.6}
.dirty{font-size:11px;color:var(--warn);font-weight:700}

/* login */
.login-wrap{display:grid;place-items:center;height:100vh}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:34px 30px;width:340px;box-shadow:var(--shadow)}
.login-card h2{font-family:'Gowun Batang',serif;text-align:center;margin:6px 0 2px}
.login-card .sub{text-align:center}
.toast{position:fixed;right:18px;bottom:18px;background:#34322c;color:#f1ece0;padding:11px 16px;border-radius:10px;font-size:13px;z-index:99;opacity:0;transition:opacity .2s;max-width:360px}
.toast.show{opacity:.95}.toast.err{background:var(--warn)}
.tbl{width:100%;border-collapse:collapse;font-size:13px;background:var(--panel);border-radius:10px;overflow:hidden}
.tbl th,.tbl td{border-bottom:1px solid var(--line);padding:9px 12px;text-align:left}
.tbl th{background:#fbf8f1;font-size:12px;color:var(--ink-soft)}
.muted{color:var(--ink-soft);font-size:12px}
.spin{display:inline-block;width:14px;height:14px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
