/* MOQV v6.0 — The Quarterly of Vessels
 * Global Stylesheet
 * © 2025-2026 MOQV / Hamel Korea
 */

:root{--bg:#FAF8F5;--bg-warm:#F3EFE9;--bg-card:#FFFFFF;--bg-dark:#0D0D0D;--text:#1A1A1A;--text-2:#4A4A4A;--text-3:#8A8A8A;--text-inv:#F5F5F5;--accent:#FF4D00;--accent-h:#E54400;--accent-soft:#FFF1EB;--navy:#16213E;--green:#16A34A;--green-soft:#F0FDF4;--red:#DC2626;--red-soft:#FEF2F2;--blue:#2563EB;--blue-soft:#EFF6FF;--border:#E2DED6;--border-dk:#D0CAC0;--shadow:0 2px 12px rgba(0,0,0,.04);--shadow-md:0 6px 24px rgba(0,0,0,.06);--r:6px;--r-md:10px;--r-lg:16px;--max:1280px}
*{margin:0;padding:0;box-sizing:border-box}body{font-family:'Noto Sans KR','Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--text);line-height:1.7;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.eng{font-family:'Plus Jakarta Sans',sans-serif}.mono{font-family:'JetBrains Mono',monospace}::selection{background:var(--accent);color:#fff}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}.fade-up{animation:fadeUp .5s ease both}
.nav{position:sticky;top:0;z-index:200;background:rgba(250,248,245,.92);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}.nav-inner{max-width:var(--max);margin:0 auto;padding:0 40px;height:60px;display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:22px;letter-spacing:.1em;cursor:pointer}.nav-logo span{color:var(--accent)}.nav-links{display:flex;gap:4px}.nav-link{font-size:13px;font-weight:500;color:var(--text-2);padding:6px 12px;border-radius:6px;cursor:pointer;transition:all .15s;white-space:nowrap}.nav-link:hover{color:var(--accent);background:var(--accent-soft)}.nav-link.active{color:var(--accent);font-weight:700}.nav-right{display:flex;align-items:center;gap:8px}
.nav-btn{font-family:'JetBrains Mono',monospace;font-size:11px;padding:7px 14px;border-radius:100px;cursor:pointer;transition:all .2s;border:1.5px solid}.nav-btn.subscribe{color:var(--accent);border-color:var(--accent)}.nav-btn.subscribe:hover{background:var(--accent);color:#fff}.nav-btn.login{color:var(--text-2);border-color:var(--border)}.nav-btn.login:hover{border-color:var(--accent);color:var(--accent)}.nav-btn.logout{color:var(--red);border-color:var(--red-soft);font-size:10px;padding:5px 10px}.nav-btn.logout:hover{background:var(--red);color:#fff}
.nav-user{display:flex;align-items:center;gap:4px;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--accent);padding:5px 12px;background:var(--accent-soft);border-radius:100px}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:300}.hamburger b{display:block;width:22px;height:2px;background:var(--text);transition:all .3s}.hamburger.open b:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.open b:nth-child(2){opacity:0}.hamburger.open b:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-menu{display:none;position:fixed;top:60px;left:0;right:0;bottom:0;background:var(--bg);z-index:150;padding:20px;overflow-y:auto}.mobile-menu.open{display:block}.mm-link{display:block;padding:14px 16px;font-size:16px;font-weight:500;border-bottom:1px solid var(--border);cursor:pointer}.mm-link:hover,.mm-link.active{color:var(--accent)}
.masthead{max-width:var(--max);margin:0 auto;padding:20px 40px 0;display:flex;justify-content:space-between;align-items:flex-end;border-bottom:3px double var(--border-dk)}.mh-left,.mh-right{padding-bottom:12px}.mh-right{text-align:right}.mh-date{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3);letter-spacing:.15em}.mh-hamel{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--accent);letter-spacing:.12em;margin-top:2px}.mh-center{text-align:center;padding-bottom:12px}.mh-title{font-family:'Playfair Display',serif;font-size:60px;font-weight:900;letter-spacing:.06em;line-height:1}.mh-title .q{color:var(--accent)}.mh-tagline{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-3);letter-spacing:.2em;margin-top:4px}.mh-edition{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3);letter-spacing:.1em}
.ticker{background:var(--bg-dark);color:var(--text-inv);overflow:hidden;white-space:nowrap}.ticker-inner{display:inline-flex;animation:ticker 45s linear infinite}.ticker-inner:hover{animation-play-state:paused}.tk-item{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;font-family:'JetBrains Mono',monospace;font-size:12px}.tk-label{color:var(--accent);font-weight:500}.tk-val{color:#fff}.tk-up{color:#22C55E}.tk-dn{color:#EF4444}.tk-sep{color:rgba(255,255,255,.12);padding:0 4px}
.content{max-width:var(--max);margin:0 auto;padding:0 40px}.sh{display:flex;align-items:center;gap:12px;padding:28px 0 18px}.sh-label{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.25em;color:var(--accent);font-weight:600;white-space:nowrap}.sh-line{flex:1;height:1px;background:var(--border)}.sh-more{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3);cursor:pointer;white-space:nowrap}.sh-more:hover{color:var(--accent)}
.cat{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;margin-bottom:8px;display:inline-block}.cat-dd{color:var(--accent)}.cat-mb{color:var(--red)}.cat-data{color:var(--blue)}.cat-hml{color:#6D28D9}.cat-ol{color:var(--green)}.cat-ic{color:#EA580C}
.hero{padding:32px 0;display:grid;grid-template-columns:1.35fr 1fr;gap:32px;border-bottom:1px solid var(--border)}.hero-cat{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;color:var(--accent);margin-bottom:12px;display:flex;align-items:center;gap:8px}.hero-cat::before{content:'';width:20px;height:2px;background:var(--accent)}.hero-title{font-family:'Noto Serif KR',serif;font-size:34px;font-weight:900;line-height:1.35;margin-bottom:14px;cursor:pointer;transition:color .2s}.hero-title:hover{color:var(--accent)}.hero-excerpt{font-size:15px;color:var(--text-2);line-height:1.85;margin-bottom:16px}.hero-meta{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-3);flex-wrap:wrap}.hero-meta .dot{width:3px;height:3px;background:var(--text-3);border-radius:50%}
.hero-img{background:var(--bg-warm);border-radius:var(--r-md);min-height:320px;display:flex;align-items:center;justify-content:center}.hero-img-inner{text-align:center;padding:32px}.hero-big{font-family:'Playfair Display',serif;font-size:56px;font-weight:900;color:var(--accent);line-height:1;opacity:.85}.hero-sublabel{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3);letter-spacing:.15em;margin-top:8px}
.sec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-bottom:1px solid var(--border)}.sec-art{padding:24px;border-right:1px solid var(--border)}.sec-art:first-child{padding-left:0}.sec-art:last-child{border-right:none;padding-right:0}.sec-title{font-family:'Noto Serif KR',serif;font-size:19px;font-weight:700;line-height:1.45;margin-bottom:8px;cursor:pointer}.sec-title:hover{color:var(--accent)}.sec-excerpt{font-size:13px;color:var(--text-2);line-height:1.7;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.sec-meta{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3)}
.ds-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.ds-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:14px;text-align:center;cursor:pointer;transition:all .2s}.ds-card:hover{border-color:var(--accent)}.ds-index{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-3)}.ds-val{font-family:'Plus Jakarta Sans',sans-serif;font-size:22px;font-weight:800}.ds-chg{font-family:'JetBrains Mono',monospace;font-size:12px}.ds-chg.up{color:var(--green)}.ds-chg.dn{color:var(--red)}
.mb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding-bottom:28px;border-bottom:1px solid var(--border)}.mb-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:all .25s}.mb-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.mb-card-top{padding:16px 20px 0;display:flex;justify-content:space-between}.mb-tag{font-family:'JetBrains Mono',monospace;font-size:10px;padding:3px 10px;border-radius:100px}.mb-tag.urgent{background:var(--red-soft);color:var(--red)}.mb-tag.data{background:var(--blue-soft);color:var(--blue)}.mb-tag.market{background:var(--green-soft);color:var(--green)}.mb-icon{font-size:22px}.mb-card-body{padding:10px 20px 16px}.mb-title{font-size:16px;font-weight:700;line-height:1.4;margin-bottom:6px}.mb-excerpt{font-size:13px;color:var(--text-2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mb-card-footer{padding:0 20px 14px;display:flex;justify-content:space-between;font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-3)}.mb-read{color:var(--accent)}
.two-col{display:grid;grid-template-columns:2fr 1fr;gap:0;padding-bottom:8px;border-bottom:1px solid var(--border)}.col-main{padding-right:32px;border-right:1px solid var(--border)}.col-side{padding-left:32px}
.al-item{padding:18px 0;border-bottom:1px solid var(--border);display:flex;gap:14px;cursor:pointer;transition:background .15s}.al-item:hover{background:var(--bg-warm);padding-left:8px;margin:0 -8px}.al-num{font-family:'Playfair Display',serif;font-size:28px;font-weight:800;color:var(--border-dk);line-height:1;min-width:32px}.al-title{font-family:'Noto Serif KR',serif;font-size:17px;font-weight:700;line-height:1.4;margin-bottom:4px}.al-item:hover .al-title{color:var(--accent)}.al-excerpt{font-size:13px;color:var(--text-2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.al-meta{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3);margin-top:4px}
.sb-nl{background:var(--bg-dark);border-radius:var(--r-md);padding:24px;margin-bottom:20px;color:var(--text-inv)}.sb-nl h3{font-family:'Playfair Display',serif;font-size:20px;margin-bottom:6px}.sb-nl p{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:14px}.sb-nl input{width:100%;padding:10px 14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:var(--r);color:#fff;font-size:14px;margin-bottom:8px;outline:none;font-family:'Noto Sans KR',sans-serif}.sb-nl button{width:100%;padding:10px;background:var(--accent);color:#fff;border:none;border-radius:var(--r);font-size:14px;font-weight:600;cursor:pointer}.sb-nl .cnt{font-family:'JetBrains Mono',monospace;font-size:10px;color:rgba(255,255,255,.25);margin-top:6px}
.sb-sh{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;color:var(--accent);margin:16px 0 10px;display:flex;align-items:center;gap:8px}.sb-sh::after{content:'';flex:1;height:1px;background:var(--border)}.sb-ti{padding:10px 0;border-bottom:1px solid var(--border);display:flex;gap:10px;cursor:pointer}.sb-tn{font-family:'Playfair Display',serif;font-size:20px;font-weight:800;color:var(--border-dk);line-height:1;min-width:24px}.sb-tt{font-size:13px;font-weight:600;line-height:1.45}.sb-ti:hover .sb-tt{color:var(--accent)}.sb-tm{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-3);margin-top:2px}
.board{padding:28px 0}.board-title{font-family:'Playfair Display',serif;font-size:32px;font-weight:800;margin-bottom:6px}.board-title span{color:var(--accent)}.board-desc{font-size:14px;color:var(--text-2);max-width:600px;margin-bottom:24px}.board-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.bc{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:24px;transition:all .25s}.bc:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.bc-title{font-family:'Noto Serif KR',serif;font-size:18px;font-weight:700;line-height:1.4;margin-bottom:6px;cursor:pointer}.bc:hover .bc-title{color:var(--accent)}.bc-excerpt{font-size:13px;color:var(--text-2);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:10px}.bc-footer{display:flex;justify-content:space-between;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3)}.bc-read{color:var(--accent);cursor:pointer}
.bc-admin{display:flex;gap:4px;margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}.admin-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--accent-soft);border:1px solid rgba(255,77,0,.15);border-radius:var(--r-md);margin-bottom:20px}.admin-bar-label{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--accent)}
.btn{padding:8px 16px;border-radius:var(--r);font-family:'JetBrains Mono',monospace;font-size:12px;cursor:pointer;border:none;transition:all .15s;display:inline-flex;align-items:center;gap:4px}.btn-sm{padding:5px 10px;font-size:10px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-h)}.btn-outline{background:none;border:1px solid var(--border);color:var(--text-2)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:none;border:1px solid var(--red-soft);color:var(--red)}.btn-danger:hover{background:var(--red);color:#fff}.btn-edit{background:none;border:1px solid var(--blue-soft);color:var(--blue)}.btn-edit:hover{background:var(--blue);color:#fff}
.status-badge{font-family:'JetBrains Mono',monospace;font-size:9px;padding:2px 8px;border-radius:100px}.status-published{background:var(--green-soft);color:var(--green)}.status-draft{background:var(--bg-warm);color:var(--text-3)}
.article-view{padding:40px 0 60px;max-width:760px;margin:0 auto}.av-back{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-3);cursor:pointer;display:inline-flex;align-items:center;gap:6px;margin-bottom:24px}.av-back:hover{color:var(--accent)}.av-cat{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.15em;padding:4px 12px;border-radius:100px;margin-bottom:16px}.av-title{font-family:'Noto Serif KR',serif;font-size:36px;font-weight:900;line-height:1.35;margin-bottom:16px}.av-meta{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--text-3);flex-wrap:wrap;padding-bottom:20px;border-bottom:1px solid var(--border)}.av-meta .dot{width:3px;height:3px;background:var(--border-dk);border-radius:50%}.av-body{padding-top:28px;font-family:'Noto Serif KR',serif;font-size:17px;line-height:2}.av-body p{margin-bottom:20px}.av-body strong{color:var(--accent)}.av-body .data-box{background:var(--bg-warm);border-left:4px solid var(--accent);padding:16px 20px;margin:24px 0;border-radius:0 var(--r) var(--r) 0;font-family:'Noto Sans KR',sans-serif;font-size:14px;line-height:1.8}.av-body .source{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-3);margin-top:-12px;margin-bottom:20px}.av-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:28px;padding-top:20px;border-top:1px solid var(--border)}.av-tags span{font-family:'JetBrains Mono',monospace;font-size:11px;padding:4px 12px;background:var(--bg-warm);border-radius:100px;color:var(--text-2)}.av-share{margin-top:24px;padding:20px;background:var(--bg-warm);border-radius:var(--r-md);text-align:center}.av-share-title{font-size:14px;font-weight:600;margin-bottom:10px}.av-share-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.av-share-btn{padding:8px 16px;border-radius:var(--r);font-family:'JetBrains Mono',monospace;font-size:11px;cursor:pointer;border:1px solid var(--border);background:var(--bg-card)}.av-share-btn:hover{border-color:var(--accent);color:var(--accent)}
.rt-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.rt-table th{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-3);text-align:left;padding:10px 14px;background:var(--bg-warm);border-bottom:1px solid var(--border)}.rt-table td{padding:10px 14px;font-size:13px;border-bottom:1px solid var(--border)}.rt-table tr:last-child td{border-bottom:none}.rt-table .up{color:var(--green)}.rt-table .dn{color:var(--red)}
.am-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.am-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;position:relative;overflow:hidden}.am-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}.am-card.scout::before{background:#0EA5E9}.am-card.writer::before{background:#6366F1}.am-card.designer::before{background:#EC4899}.am-card.publisher::before{background:#14B8A6}
.am-status{font-family:'JetBrains Mono',monospace;font-size:10px;padding:2px 8px;border-radius:100px;display:inline-flex;align-items:center;gap:4px;margin-top:6px}.am-on{background:var(--green-soft);color:var(--green)}.am-on::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}.am-partial{background:rgba(234,179,8,.1);color:#CA8A04}.am-off{background:var(--bg-warm);color:var(--text-3)}
.am-log{background:var(--bg-dark);border-radius:var(--r-md);padding:16px;max-height:250px;overflow-y:auto;font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(255,255,255,.7);line-height:1.8}.am-log .time{color:var(--accent)}.am-log .scout-c{color:#0EA5E9}.am-log .writer-c{color:#6366F1}.am-log .sys-c{color:#22C55E}
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.admin-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;text-align:center}.admin-stat .num{font-family:'Plus Jakarta Sans',sans-serif;font-size:28px;font-weight:800;color:var(--accent)}.admin-stat .label{font-size:12px;color:var(--text-3);margin-top:2px}
.admin-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.admin-table th{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-3);text-align:left;padding:8px 12px;background:var(--bg-warm);border-bottom:1px solid var(--border)}.admin-table td{padding:8px 12px;font-size:12px;border-bottom:1px solid var(--border)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-warm)}
.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:300;align-items:center;justify-content:center;padding:20px}.modal-overlay.open{display:flex}.modal{background:var(--bg);border-radius:var(--r-lg);max-width:720px;width:100%;max-height:90vh;overflow-y:auto;padding:32px}.modal-sm{max-width:400px}.modal-title{font-family:'Plus Jakarta Sans',sans-serif;font-size:20px;font-weight:700;margin-bottom:20px}
.form-group{margin-bottom:16px}.form-label{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3);margin-bottom:4px;display:block}.form-input,.form-select{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--r);font-size:14px;outline:none;background:var(--bg-card)}.form-input:focus{border-color:var(--accent)}.form-textarea{width:100%;min-height:180px;padding:14px;border:1px solid var(--border);border-radius:var(--r);font-size:14px;font-family:'Noto Serif KR',serif;line-height:1.8;outline:none;resize:vertical;background:var(--bg-card)}.form-textarea:focus{border-color:var(--accent)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.form-error{color:var(--red);font-size:12px;margin-top:4px;display:none}.form-error.show{display:block}
.powered-strip{background:var(--bg-warm);padding:10px 40px;text-align:center;border-top:1px solid var(--border)}.powered-strip span{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.2em;color:var(--text-3)}.powered-strip strong{color:var(--accent)}
.footer{background:var(--bg-dark);color:var(--text-inv);margin-top:48px;padding:48px 40px}.footer-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}.ft-logo{font-family:'Plus Jakarta Sans',sans-serif;font-size:24px;font-weight:800;letter-spacing:.08em;margin-bottom:6px}.ft-logo span{color:var(--accent)}.ft-desc{font-size:13px;color:rgba(255,255,255,.3);line-height:1.7;margin-bottom:10px}.ft-hamel{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--accent);letter-spacing:.12em;padding:4px 10px;border:1px solid rgba(255,77,0,.3);border-radius:4px;display:inline-block}.ft-col h4{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;color:var(--accent);margin-bottom:12px}.ft-col a{display:block;font-size:13px;color:rgba(255,255,255,.4);padding:3px 0;cursor:pointer}.ft-col a:hover{color:#fff}.footer-bottom{max-width:var(--max);margin:28px auto 0;padding-top:16px;border-top:1px solid rgba(255,255,255,.06);display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}.footer-bottom span{font-family:'JetBrains Mono',monospace;font-size:10px;color:rgba(255,255,255,.18)}
.pg{display:flex;justify-content:center;gap:4px;padding:20px 0}.pg-btn{padding:6px 12px;border:1px solid var(--border);border-radius:var(--r);font-family:'JetBrains Mono',monospace;font-size:11px;cursor:pointer;background:var(--bg-card)}.pg-btn:hover,.pg-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.cat-hml{color:#6D28D9}
.research-list{display:flex;flex-direction:column;gap:0}.research-item{display:flex;align-items:center;gap:16px;padding:18px 20px;border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:8px;background:var(--bg-card);transition:all .2s}.research-item:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);border-color:#6D28D9}.ri-num{font-family:'Playfair Display',serif;font-size:22px;font-weight:800;color:var(--border-dk);min-width:32px;text-align:center}.ri-icon{font-size:28px;min-width:36px;text-align:center}.ri-body{flex:1;min-width:0}.ri-title{font-family:'Noto Serif KR',serif;font-size:17px;font-weight:700;line-height:1.4;margin-bottom:4px}.research-item:hover .ri-title{color:#6D28D9}.ri-desc{font-size:13px;color:var(--text-2);line-height:1.6;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ri-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-3)}.ri-actions{display:flex;gap:6px;flex-shrink:0;flex-wrap:wrap;align-items:center}
@media(max-width:1024px){.nav-inner,.content{padding:0 24px}.hero{grid-template-columns:1fr}.sec-grid{grid-template-columns:1fr}.sec-art{border-right:none;border-bottom:1px solid var(--border);padding:18px 0}.ds-grid{grid-template-columns:repeat(3,1fr)}.mb-grid,.board-grid{grid-template-columns:1fr}.two-col{grid-template-columns:1fr}.col-main{border-right:none;padding-right:0;padding-bottom:24px;border-bottom:1px solid var(--border)}.col-side{padding-left:0;padding-top:24px}.admin-stats,.am-grid{grid-template-columns:repeat(2,1fr)}.footer-inner{grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}}
@media(max-width:768px){.nav-links{display:none}.hamburger{display:flex}.nav-inner{padding:0 16px;height:56px}.content{padding:0 16px}.masthead{flex-direction:column;align-items:center;text-align:center;padding:12px 16px 0}.mh-left,.mh-right{text-align:center}.mh-title{font-size:40px}.hero-title{font-size:26px}.ds-grid{grid-template-columns:repeat(2,1fr)}.footer-inner{grid-template-columns:1fr}.footer{padding:36px 16px}.board-title{font-size:26px}.modal{padding:20px}.am-grid{grid-template-columns:1fr}.research-item{flex-direction:column;align-items:flex-start;gap:10px}.ri-actions{width:100%;justify-content:flex-end}}

/* ═══ Auth Modal Styles ═══ */
.auth-modal{position:relative;padding:28px 32px 32px}
.auth-close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:28px;color:var(--text-3);cursor:pointer;line-height:1;padding:4px 8px;border-radius:var(--r);transition:all .15s}.auth-close:hover{color:var(--text);background:var(--bg-warm)}
.auth-tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:24px}
.auth-tab{flex:1;padding:12px 0;font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:600;color:var(--text-3);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}
.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.auth-tab:hover:not(.active){color:var(--text-2)}
.social-buttons{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.social-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px 16px;border:1px solid var(--border);border-radius:var(--r-md);font-family:'Noto Sans KR','Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;background:var(--bg-card);color:var(--text)}
.social-btn:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.social-btn svg{flex-shrink:0}
.social-google:hover{border-color:#4285F4;background:#f8faff}
.social-naver:hover{border-color:#03C75A;background:#f0fdf4}
.social-kakao:hover{border-color:#FEE500;background:#fffef0}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--text-3);font-size:12px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-submit{width:100%;padding:12px;font-size:15px;font-weight:600;border-radius:var(--r-md);margin-top:8px;justify-content:center;text-align:center}
.auth-forgot{text-align:center;font-size:12px;color:var(--text-3);margin-top:14px;cursor:pointer;transition:color .15s}
.auth-forgot:hover{color:var(--accent)}
.auth-terms{margin:12px 0 4px;font-size:12px;color:var(--text-2);display:flex;align-items:flex-start;gap:6px}
.auth-terms label{display:flex;align-items:flex-start;gap:8px;cursor:pointer;line-height:1.5}
.auth-terms input[type="checkbox"]{margin-top:3px;accent-color:var(--accent)}
.auth-pane .form-error{margin-top:8px}

/* Nav User Info (Avatar) */
.nav-user-info{display:flex;align-items:center;gap:8px;padding:4px 12px;background:var(--accent-soft);border-radius:100px}
.nav-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:2px solid var(--accent)}
.nav-avatar-placeholder{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700}
.nav-user-name{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--accent);font-weight:500}

/* Dark mode auth overrides */
[data-theme="dark"] .social-btn{background:var(--bg-card);border-color:var(--border);color:var(--text)}
[data-theme="dark"] .social-google:hover{background:#1a2235;border-color:#4285F4}
[data-theme="dark"] .social-naver:hover{background:#0d2018;border-color:#03C75A}
[data-theme="dark"] .social-kakao:hover{background:#2a2510;border-color:#FEE500}
[data-theme="dark"] .auth-close:hover{background:var(--border)}
[data-theme="dark"] .nav-user-info{background:rgba(255,77,0,.12)}

/* ═══ Skip Navigation ═══ */
.skip-nav{position:absolute;top:-100px;left:0;background:var(--accent);color:#fff;padding:8px 16px;z-index:9999;font-size:14px;text-decoration:none;transition:top .2s}
.skip-nav:focus{top:0}