/* ============================================================
   큰사랑교회 — 디자인 시스템
   공유 CSS + 페이지별 스타일 + 동적기능(게시판/영상/관리자) 추가
   ============================================================ */
:root{
  --ink:#23302B; --ink-soft:#5B6B63;
  --paper:#FDFCF8; --paper-deep:#F4F1E8;
  --glass-amber:#E8B44C; --glass-rose:#D97B66;
  --glass-blue:#6E93B5; --glass-green:#7FA176;
  --line:#E4DFD2;
  --serif:'Gowun Batang', serif;
  --sans:'IBM Plex Sans KR', sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}

/* 헤더 */
header{position:sticky;top:0;z-index:50;background:rgba(253,252,248,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px;gap:1.2rem}
.logo{font-family:var(--serif);font-weight:700;font-size:1.25rem;letter-spacing:.06em;display:flex;align-items:center;gap:.55rem}
.logo-mark{width:14px;height:22px;border-radius:7px 7px 3px 3px;background:linear-gradient(180deg,var(--glass-amber),var(--glass-rose));display:inline-block;flex-shrink:0}
nav>ul{display:flex;gap:1.8rem;list-style:none;font-size:.92rem}
nav>ul>li{position:relative}
nav a{color:var(--ink-soft);transition:color .2s;padding:.4rem 0;display:inline-block}
nav a:hover,nav a:focus-visible{color:var(--ink)}
nav a.on{color:var(--ink);font-weight:600;border-bottom:2px solid var(--glass-amber)}
.drop{position:absolute;top:100%;left:50%;transform:translateX(-50%);background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:.5rem 0;min-width:150px;box-shadow:0 12px 30px rgba(35,48,43,.10);opacity:0;visibility:hidden;transition:all .18s;list-style:none}
nav li:hover .drop, nav li:focus-within .drop{opacity:1;visibility:visible}
.drop a{display:block;padding:.5rem 1.2rem;font-size:.88rem;white-space:nowrap}
.drop a:hover{background:var(--paper-deep)}
.nav-right{display:flex;align-items:center;gap:1rem}
.nav-cta{font-size:.85rem;font-weight:600;border:1px solid var(--ink);border-radius:999px;padding:.45rem 1.1rem;transition:all .2s;color:var(--ink)}
.nav-cta:hover{background:var(--ink);color:var(--paper)}
.user-menu{display:flex;align-items:center;gap:.8rem;font-size:.85rem;color:var(--ink-soft)}
.user-menu a:hover{color:var(--ink)}
.btn-admin{font-weight:600;background:linear-gradient(120deg,var(--glass-amber),var(--glass-rose));color:#fff!important;border-radius:999px;padding:.3rem .8rem;font-size:.8rem}
.menu-btn{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--ink)}
.m-nav{display:none}

/* 서브페이지 타이틀 밴드 */
.page-head{position:relative;overflow:hidden;padding:4.6rem 0 3.6rem;background:radial-gradient(ellipse 55% 70% at 78% 0%, rgba(232,180,76,.13), transparent 70%),var(--paper)}
.page-head .glass-panes{position:absolute;top:0;right:5%;display:flex;gap:11px;height:100%;pointer-events:none}
.pane{width:42px;border-radius:0 0 21px 21px;opacity:.18;animation:glow 9s ease-in-out infinite alternate}
.pane:nth-child(1){background:linear-gradient(180deg,var(--glass-amber),transparent);height:85%}
.pane:nth-child(2){background:linear-gradient(180deg,var(--glass-rose),transparent);height:60%;animation-delay:-3s}
.pane:nth-child(3){background:linear-gradient(180deg,var(--glass-blue),transparent);height:72%;animation-delay:-6s}
@keyframes glow{from{opacity:.12}to{opacity:.28}}
@media (prefers-reduced-motion: reduce){.pane{animation:none}html{scroll-behavior:auto}}
.crumb{font-size:.8rem;letter-spacing:.22em;color:var(--ink-soft);text-transform:uppercase;margin-bottom:1rem;font-weight:500}
.page-head h1{font-family:var(--serif);font-weight:700;font-size:clamp(1.9rem,4.5vw,2.8rem);position:relative;z-index:1}
.page-head p.lead{color:var(--ink-soft);margin-top:1rem;max-width:36em;position:relative;z-index:1}

/* 공통 섹션 */
main.sub{padding:4.5rem 0 6rem}
main.home{padding:0}
.eyebrow{font-size:.82rem;letter-spacing:.28em;color:var(--ink-soft);text-transform:uppercase;margin-bottom:.8rem;font-weight:500}
h2.sec{font-family:var(--serif);font-weight:700;font-size:clamp(1.4rem,3vw,1.9rem);margin-bottom:1.4rem}
.prose{max-width:42em;color:#3A463F;font-size:1.02rem}
.prose p{margin-bottom:1.3em}
.prose strong{font-weight:600}
.btn{display:inline-block;padding:.85rem 1.8rem;border-radius:999px;font-size:.95rem;font-weight:600;transition:all .2s;cursor:pointer;border:1px solid var(--line);background:var(--paper);color:var(--ink);font-family:var(--sans)}
.btn:hover{border-color:var(--ink)}
.btn-primary,.btn.primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-primary:hover,.btn.primary:hover{background:#36473F;transform:translateY(-1px)}
.btn-ghost{border:1px solid var(--line);background:transparent}
.btn-ghost:hover{border-color:var(--ink)}
.btn.danger{color:#9c4a39;border-color:rgba(217,123,102,.4)}
.btn.danger:hover{border-color:#9c4a39;background:rgba(217,123,102,.08)}
.btn.sm{padding:.4rem 1rem;font-size:.82rem}
.btn:disabled{opacity:.4;cursor:not-allowed}

.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.card{border:1px solid var(--line);border-radius:20px;padding:2rem 1.8rem;background:var(--paper)}
.card h3{font-family:var(--serif);font-size:1.15rem;font-weight:700;margin:.8rem 0 .6rem}
.card p{color:var(--ink-soft);font-size:.93rem}
.chip{display:inline-block;width:30px;height:5px;border-radius:3px}
.chip.amber{background:var(--glass-amber)} .chip.blue{background:var(--glass-blue)}
.chip.rose{background:var(--glass-rose)} .chip.green{background:var(--glass-green)}

.verseband{margin:4.5rem 0;padding:3.6rem 2rem;text-align:center;border-radius:24px;background:radial-gradient(ellipse 50% 90% at 50% 100%, rgba(110,147,181,.12), transparent),var(--ink);color:var(--paper)}
.verseband blockquote{font-family:var(--serif);font-size:clamp(1.1rem,2.4vw,1.4rem);line-height:1.9;max-width:32em;margin:0 auto 1rem}
.verseband cite{font-style:normal;font-size:.84rem;letter-spacing:.2em;opacity:.65}

.info-list{list-style:none;font-size:.96rem;border:1px solid var(--line);border-radius:18px;padding:.6rem 1.6rem;background:var(--paper)}
.info-list li{display:flex;gap:1.2rem;padding:.95rem 0;border-bottom:1px solid var(--line)}
.info-list li:last-child{border-bottom:none}
.info-list .label{min-width:6em;color:var(--ink-soft);font-weight:500;flex-shrink:0}

/* 스텝(새가족) */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.step{border:1px solid var(--line);border-radius:18px;padding:1.7rem 1.4rem;position:relative;background:var(--paper)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-family:var(--serif);font-weight:700;font-size:1.05rem;color:var(--glass-amber);display:block;margin-bottom:.7rem}
.step h3{font-size:1rem;font-weight:600;margin-bottom:.4rem}
.step p{font-size:.88rem;color:var(--ink-soft)}

/* 게시판 (.board 리스트) */
.board{border-top:2px solid var(--ink);list-style:none}
.board li{display:flex;align-items:baseline;gap:1.2rem;padding:1.1rem .4rem;border-bottom:1px solid var(--line);font-size:.97rem}
.board li.notice{background:rgba(232,180,76,.06)}
.board .tag{font-size:.74rem;font-weight:600;letter-spacing:.06em;padding:.18rem .6rem;border-radius:999px;flex-shrink:0}
.tag.notice{background:rgba(232,180,76,.18);color:#8a6420}
.tag.bulletin{background:rgba(110,147,181,.16);color:#3d617f}
.tag.photo{background:rgba(217,123,102,.15);color:#9c4a39}
.tag.file{background:rgba(127,161,118,.16);color:#4c6b45}
.board .num{color:var(--ink-soft);font-size:.82rem;min-width:2.2em;text-align:center;flex-shrink:0}
.board .ttl{color:var(--ink);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.board .ttl:hover{text-decoration:underline;text-underline-offset:4px}
.board .cmt-cnt{color:var(--glass-blue);font-size:.82rem;font-weight:600;margin-left:.3rem}
.board .writer{color:var(--ink-soft);font-size:.86rem;flex-shrink:0}
.board .date{margin-left:auto;color:var(--ink-soft);font-size:.84rem;flex-shrink:0}
.board-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.4rem}
.search{display:flex;gap:.5rem}
.search input{padding:.55rem .9rem;border:1px solid var(--line);border-radius:999px;background:var(--paper);font-family:var(--sans);min-width:200px}
.board-foot{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;gap:1rem;flex-wrap:wrap}

/* 게시판 페이지 — 여백/툴바/탭/빈상태 */
main.board-main{padding:2.4rem 0 5rem}
.board-tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1.8rem}
.board-tabs a{padding:.5rem 1.15rem;border-radius:999px;font-size:.92rem;color:var(--ink-soft);border:1px solid var(--line);transition:all .15s}
.board-tabs a:hover{border-color:var(--ink);color:var(--ink)}
.board-tabs a.on{background:var(--ink);color:var(--paper);border-color:var(--ink);font-weight:600}
.board-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.6rem}
.board-count{font-size:.92rem;color:var(--ink-soft)} .board-count b{color:var(--ink);font-family:var(--serif);font-size:1.05rem}
.board-tools{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.board-empty{text-align:center;padding:4.5rem 1rem;border-top:2px solid var(--ink);border-bottom:1px solid var(--line)}
.board-empty .ic{font-size:2.6rem;line-height:1;opacity:.35}
.board-empty .t{font-family:var(--serif);font-size:1.1rem;margin:.8rem 0 .3rem}
.board-empty p{color:var(--ink-soft);margin:0 0 1.4rem;font-size:.95rem}
/* 목록 컬럼 헤더 */
.board-listhead{display:flex;align-items:center;gap:1.2rem;padding:.7rem .4rem;border-top:2px solid var(--ink);border-bottom:1px solid var(--line);font-size:.82rem;letter-spacing:.08em;color:var(--ink-soft);font-weight:600}
.board-listhead .h-title{flex:1}
.board-listhead .h-writer{width:6.5em;text-align:center} .board-listhead .h-date{width:6em;text-align:right}
.board+.board-foot,.board-listhead+.board{border-top:none}
.board li{transition:background .12s} .board li:hover{background:var(--paper-deep)}
.board .writer{width:6.5em;text-align:center} .board .date{width:6em}
@media (max-width:840px){.board-toolbar{align-items:stretch}.search input{flex:1;min-width:0}.board-listhead .h-writer,.board .writer{display:none}}

/* 에디터(Quill) */
.editor-field{display:flex;flex-direction:column;gap:.4rem}
.editor-field .ed-label{font-size:.88rem;color:var(--ink-soft)}
.editor-field .ql-toolbar{border:1px solid var(--line);border-radius:12px 12px 0 0;background:var(--paper-deep);border-bottom:none}
.editor-field .ql-container{border:1px solid var(--line);border-radius:0 0 12px 12px;font-family:var(--sans);font-size:1rem;background:var(--paper)}
.editor-field .ql-editor{min-height:320px;line-height:1.8}
.editor-field .ql-editor.ql-blank::before{color:#a9a193;font-style:normal}

/* 글 본문(HTML) 렌더링 */
.post-content h1,.post-content h2,.post-content h3{font-family:var(--serif);margin:1.2em 0 .5em;line-height:1.4}
.post-content h1{font-size:1.6rem} .post-content h2{font-size:1.35rem} .post-content h3{font-size:1.15rem}
.post-content p{margin:0 0 1em}
.post-content img{max-width:100%;height:auto;border-radius:12px;margin:.6em 0}
.post-content a{color:var(--glass-blue);text-decoration:underline;text-underline-offset:3px}
.post-content blockquote{border-left:3px solid var(--glass-amber);margin:1em 0;padding:.4em 1.2em;color:var(--ink-soft);background:var(--paper-deep);border-radius:0 10px 10px 0}
.post-content ul,.post-content ol{margin:0 0 1em;padding-left:1.6em}
.post-content li{margin:.25em 0}
.post-content pre{background:var(--paper-deep);padding:1em;border-radius:10px;overflow:auto;font-size:.9rem}

/* 페이징 */
.paging{display:flex;gap:.35rem;flex-wrap:wrap}
.paging a{padding:.45rem .85rem;border:1px solid var(--line);border-radius:999px;background:var(--paper);font-size:.85rem;color:var(--ink-soft)}
.paging a:hover{border-color:var(--ink);color:var(--ink)}
.paging a.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* 글 보기 */
.view .post-title{font-family:var(--serif);font-size:clamp(1.4rem,3vw,1.9rem);border-bottom:2px solid var(--ink);padding-bottom:1rem}
.post-meta{display:flex;gap:1.2rem;color:var(--ink-soft);font-size:.86rem;margin:1rem 0 1.6rem}
.post-files{background:var(--paper-deep);border-radius:14px;padding:.8rem 1.4rem;list-style:none}
.post-files a:hover{text-decoration:underline}
.post-content{min-height:200px;padding:1.4rem .2rem;font-size:1.02rem;color:#3A463F}
.post-btns{display:flex;gap:.6rem;margin:1.6rem 0;flex-wrap:wrap}
.comments{margin-top:3rem;border-top:2px solid var(--ink);padding-top:1.6rem}
.comments h2{font-family:var(--serif);font-size:1.2rem;margin-bottom:1rem}
.comment{border:1px solid var(--line);border-radius:14px;padding:.9rem 1.2rem;margin-bottom:.6rem;background:var(--paper)}
.comment strong{margin-right:.5rem;font-family:var(--serif)}
.comment .date{color:var(--ink-soft);font-size:.78rem}
.comment .link-del{background:none;border:none;color:#9c4a39;cursor:pointer;font-size:.78rem}
.comment p{margin-top:.4rem;color:#3A463F}
.comment-form{display:flex;gap:.6rem;margin-top:1rem}
.comment-form textarea{flex:1;padding:.8rem 1rem;border:1px solid var(--line);border-radius:14px;resize:vertical;min-height:64px;font-family:var(--sans)}

/* 폼 */
.form-page{max-width:480px}
.form{display:flex;flex-direction:column;gap:1rem;border:1px solid var(--line);border-radius:20px;padding:2rem;background:var(--paper)}
.form label{display:flex;flex-direction:column;gap:.4rem;font-size:.88rem;color:var(--ink-soft)}
.form input,.form textarea,.form select{padding:.7rem .9rem;border:1px solid var(--line);border-radius:12px;font-size:1rem;font-family:var(--sans);background:var(--paper);color:var(--ink)}
.form input:focus,.form textarea:focus{outline:2px solid var(--glass-blue);outline-offset:1px;border-color:transparent}
.form label.check{flex-direction:row;align-items:center;gap:.5rem}
.form-btns,.form-foot{display:flex;gap:.6rem;margin-top:.4rem;align-items:center}
.form-foot{color:var(--ink-soft);font-size:.9rem}
.form-foot a{color:var(--ink);border-bottom:1px solid var(--line)}
.file-row{font-size:.86rem;color:var(--ink-soft)} .file-row .del{display:inline;margin-left:.5rem}

/* 시간표 */
.timetable{width:100%;border-collapse:collapse;font-size:.97rem}
.timetable th,.timetable td{padding:1.05rem 1rem;text-align:left;border-bottom:1px solid var(--line)}
.timetable thead th{font-size:.82rem;letter-spacing:.12em;color:var(--ink-soft);font-weight:600;border-bottom:2px solid var(--ink)}
.timetable td.t{font-family:var(--serif);font-weight:700}

/* 지도 */
.map-box{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--paper-deep);aspect-ratio:16/7;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:.92rem;text-align:center;padding:1rem}

/* 사역자 카드 */
.people{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.person{text-align:center;border:1px solid var(--line);border-radius:20px;padding:2.4rem 1.6rem;background:var(--paper)}
.person .face{width:88px;height:88px;border-radius:50%;margin:0 auto 1.2rem;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:700;font-size:1.5rem;color:var(--paper)}
.person h3{font-family:var(--serif);font-size:1.1rem;font-weight:700}
.person .role{font-size:.84rem;color:var(--ink-soft);letter-spacing:.08em;margin:.2rem 0 .8rem}
.person p{font-size:.9rem;color:var(--ink-soft)}

/* ───── 홈(index) ───── */
.hero-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:3.2rem;align-items:center}
.sermon-card{position:relative;z-index:1;border:1px solid var(--line);border-radius:22px;background:var(--paper);padding:1.2rem 1.2rem 1.1rem;box-shadow:0 18px 44px rgba(35,48,43,.10)}
.sermon-card .video{position:relative;width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;background:var(--paper-deep)}
.sermon-card .video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.sermon-card .video .novid{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:.9rem}
.sermon-card .cap{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:.9rem;padding:0 .2rem}
.sermon-card .cap b{font-family:var(--serif);font-size:1rem}
.sermon-card .cap a{font-size:.85rem;font-weight:600;color:var(--ink-soft)}
.sermon-card .cap a:hover{color:var(--ink)}

/* ───── 페이지별 ───── */
/* greeting */
.greet-grid{display:grid;grid-template-columns:1fr 320px;gap:3.2rem;align-items:start}
.pastor-fig{margin:0}
.pastor-fig .ph{width:100%;aspect-ratio:3/4;border-radius:20px;border:1px solid var(--line);background:linear-gradient(160deg,var(--paper-deep),#e9e3d4);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:.9rem}
.pastor-fig figcaption{text-align:center;margin-top:1rem;font-size:.9rem;color:var(--ink-soft)}
.pastor-fig figcaption b{font-family:var(--serif);font-size:1.08rem;color:var(--ink);display:block;margin-bottom:.15rem}
/* staff */
.serve-table{width:100%;border-collapse:collapse;font-size:.95rem}
.serve-table th,.serve-table td{padding:.85rem .9rem;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
.serve-table thead th{font-size:.8rem;letter-spacing:.14em;color:var(--ink-soft);font-weight:600;border-bottom:2px solid var(--ink)}
.serve-table td.k{font-weight:600;white-space:nowrap;width:9em}
.serve-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.6rem}
.mission-cols{display:grid;grid-template-columns:1fr 1fr;gap:2.6rem}
.mission-cols h3{font-family:var(--serif);font-size:1.1rem;font-weight:700;margin-bottom:.9rem}
.mission-cols ul{list-style:none;font-size:.94rem;color:#3A463F}
.mission-cols li{padding:.5rem 0;border-bottom:1px solid var(--line)}
.mission-cols li:last-child{border-bottom:none}
.biz-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.4rem 1.6rem;font-size:.94rem;color:#3A463F}
.biz-list li{padding:.5rem 0;border-bottom:1px solid var(--line)}
/* worship */
.tt-wrap{display:grid;grid-template-columns:1fr 1fr;gap:2.6rem}
.band-box{display:flex;align-items:center;justify-content:space-between;gap:1.4rem;flex-wrap:wrap;border:1px solid var(--line);border-radius:20px;padding:1.6rem 2rem;background:var(--paper-deep)}
.band-box p{margin:0}
.band-box .t{font-weight:600;font-size:1.02rem}
.band-box small{color:var(--ink-soft);display:block;margin-top:.2rem}
/* location */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.4rem}
/* character */
.month-list{display:flex;flex-direction:column;gap:1.6rem}
.month-card{border:1px solid var(--line);border-radius:22px;background:var(--paper);padding:2.4rem 2.4rem 2.2rem;position:relative;overflow:hidden}
.month-card::before{content:"";position:absolute;top:0;left:0;width:6px;height:100%}
.month-card.amber::before{background:linear-gradient(180deg,var(--glass-amber),transparent)}
.month-card.rose::before{background:linear-gradient(180deg,var(--glass-rose),transparent)}
.month-card.blue::before{background:linear-gradient(180deg,var(--glass-blue),transparent)}
.month-card.green::before{background:linear-gradient(180deg,var(--glass-green),transparent)}
.month-tag{font-size:.8rem;letter-spacing:.24em;color:var(--ink-soft);font-weight:600;margin-bottom:.9rem}
.vs-row{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap;margin-bottom:.4rem}
.vs-row .good{font-family:var(--serif);font-weight:700;font-size:1.55rem}
.vs-row .good small{font-family:var(--sans);font-weight:500;font-size:.82rem;color:var(--ink-soft);letter-spacing:.06em;margin-left:.5rem}
.vs-row .vs{font-family:var(--serif);font-style:italic;font-size:.85rem;color:var(--ink-soft)}
.vs-row .bad{font-size:1.05rem;color:var(--ink-soft);text-decoration:line-through;text-decoration-color:rgba(217,123,102,.55);text-decoration-thickness:2px}
.vs-row .bad small{font-size:.78rem;margin-left:.4rem;text-decoration:none;display:inline-block}
.defn{font-family:var(--serif);font-size:1.06rem;font-weight:700;line-height:1.8;margin:.8rem 0 1rem;padding:.9rem 1.2rem;border-radius:14px;background:var(--paper-deep)}
.defn::before{content:"정의";font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.2em;color:var(--ink-soft);display:block;margin-bottom:.3rem}
.month-card .body{color:#3A463F;font-size:.97rem;max-width:46em}

/* ───── 영상 ───── */
.video-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.video-card{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--paper);transition:transform .2s,box-shadow .2s}
.video-card:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(35,48,43,.10)}
.vthumb img{width:100%;display:block} .vthumb .vfile{display:flex;align-items:center;justify-content:center;height:120px;background:var(--paper-deep);color:var(--ink-soft);font-size:2rem}
.vinfo{padding:.9rem 1rem} .vinfo strong{display:block;font-family:var(--serif);font-size:.96rem;margin:.3rem 0}
.vcat{font-size:.72rem;background:rgba(110,147,181,.16);color:#3d617f;padding:.12rem .6rem;border-radius:999px}
.vinfo .date{color:var(--ink-soft);font-size:.8rem}
.player{position:relative;padding-top:56.25%;background:#000;border-radius:18px;overflow:hidden;border:1px solid var(--line)}
.player iframe,.player video{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-view h1{font-family:var(--serif);margin-bottom:1.2rem}
.video-desc{padding:1.4rem 0;color:#3A463F}

/* 푸터 */
footer{border-top:1px solid var(--line);background:#F1EAD9;font-size:.92rem;color:var(--ink-soft);text-align:center}
.footer-main{padding:3.6rem 0 2.6rem}
.footer-logo-text{justify-content:center;font-size:1.5rem;margin-bottom:1.4rem}
.footer-contact{display:flex;justify-content:center;align-items:center;gap:.9rem;flex-wrap:wrap}
.footer-contact span{display:inline-flex;align-items:center}
.footer-contact .dot{color:#C9BFA6}
.footer-contact a{color:var(--ink-soft)}
.footer-contact a:hover{color:var(--ink)}
.footer-account{margin-top:.7rem;font-size:.88rem;color:#9a917d}
.footer-bottom{border-top:1px solid #E0D7C2;padding:1.3rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.84rem}
.footer-bottom .legal{display:flex;gap:1.4rem}
.footer-bottom a:hover{color:var(--ink)}
.gap{height:3.6rem}

/* ───── 관리자 ───── */
body.admin{background:var(--paper-deep)}
.admin-top{background:var(--ink);color:var(--paper);height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50}
.admin-top .logo{color:var(--paper);font-size:1.1rem}
.admin-top a{color:rgba(253,252,248,.75);margin-left:1rem;font-size:.88rem}
.admin-top a:hover{color:var(--paper)}
.admin-wrap{display:flex;min-height:calc(100vh - 60px)}
.admin-side{width:210px;background:var(--paper);border-right:1px solid var(--line)}
.admin-side nav{display:flex;flex-direction:column;padding:1rem 0}
.admin-side a{padding:.85rem 1.4rem;color:var(--ink-soft)} .admin-side a:hover{background:var(--paper-deep);color:var(--ink)}
.admin-content{flex:1;padding:2rem 2.2rem}
.admin-content h1{font-family:var(--serif);margin-bottom:1.4rem}
.admin-content h2{font-family:var(--serif);font-size:1.2rem;margin:2rem 0 1rem}
.stat-cards{display:flex;gap:1rem;flex-wrap:wrap}
.stat-cards .card{border:1px solid var(--line);border-radius:18px;padding:1.4rem 2rem;text-align:center;min-width:120px;background:var(--paper)}
.stat-cards .num{display:block;font-family:var(--serif);font-size:2rem;font-weight:700;color:var(--ink)}
.admin-table{width:100%;border-collapse:collapse;background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.admin-table th,.admin-table td{padding:.8rem 1rem;border-bottom:1px solid var(--line);text-align:left;font-size:.9rem}
.admin-table th{background:var(--paper-deep);font-family:var(--sans);font-weight:600;color:var(--ink-soft)}
.admin-table .nowrap{white-space:nowrap}
.admin-form{border:1px solid var(--line);border-radius:18px;padding:1.6rem;background:var(--paper)}
.admin-form .row{display:flex;gap:1.2rem;flex-wrap:wrap;margin-bottom:1rem}
.admin-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.84rem;color:var(--ink-soft)}
.admin-form input,.admin-form select,.admin-form textarea{padding:.6rem;border:1px solid var(--line);border-radius:10px;font-family:var(--sans);background:var(--paper)}
.admin-form label.check{flex-direction:row;align-items:center;gap:.5rem}
.board-edit-list{display:flex;flex-direction:column;gap:.6rem}
.board-edit-row{display:flex;gap:.7rem;align-items:flex-end;border:1px solid var(--line);border-radius:14px;padding:.9rem 1rem;flex-wrap:wrap;background:var(--paper)}
.board-edit-row .bo-id{font-family:monospace;color:var(--ink-soft);align-self:center;min-width:70px}
.board-edit-row label{display:flex;flex-direction:column;font-size:.76rem;color:var(--ink-soft);gap:.2rem}
.board-edit-row input,.board-edit-row select{padding:.4rem;border:1px solid var(--line);border-radius:8px}
.badge{padding:.15rem .7rem;border-radius:999px;font-size:.76rem}
.badge.admin{background:linear-gradient(120deg,var(--glass-amber),var(--glass-rose));color:#fff}
.badge.user{background:var(--paper-deep);color:var(--ink-soft)}
.field-file{display:none} body.type-file .field-file{display:flex} body.type-file .field-youtube{display:none}
.empty{color:var(--ink-soft);text-align:center;padding:40px 0}
.msg-error{color:#9c4a39;background:rgba(217,123,102,.12);padding:12px 16px;border-radius:12px;border:1px solid rgba(217,123,102,.25);margin-bottom:1rem}
.msg-info{color:var(--ink-soft);background:var(--paper-deep);padding:12px 16px;border-radius:12px}

/* ───── 반응형 ───── */
:focus-visible{outline:2px solid var(--glass-blue);outline-offset:3px}
@media (max-width:840px){
  nav,.nav-cta,.user-menu{display:none}
  .menu-btn{display:block}
  .m-nav{display:none;border-top:1px solid var(--line);background:var(--paper);padding:.6rem 0 1rem}
  .m-nav.open{display:block}
  .m-nav a{display:block;padding:.65rem 24px;color:var(--ink-soft)}
  .m-nav a.on{color:var(--ink);font-weight:600}
  .m-nav .sub-link{padding-left:42px;font-size:.92rem}
  .card-grid,.people,.steps,.hero-grid,.serve-grid,.mission-cols,.biz-list,.tt-wrap,.loc-grid{grid-template-columns:1fr}
  .greet-grid{grid-template-columns:1fr} .pastor-fig{max-width:300px;margin:0 auto;order:-1}
  .video-grid{grid-template-columns:repeat(2,1fr)}
  .page-head .glass-panes{right:-30px}
  .admin-side{width:60px} .admin-side a{font-size:0;padding:1rem}
  .footer-bottom{justify-content:center;text-align:center}
}
