:root{--bg-base: oklch(.11 .018 140);--bg-panel: oklch(.15 .015 140);--bg-hover: oklch(.19 .014 140);--bg-selected: oklch(.21 .018 140);--border: oklch(.25 .018 140);--border-accent: oklch(.32 .04 140);--text-primary: oklch(.93 .018 145);--text-secondary: oklch(.7 .022 145);--text-muted: oklch(.52 .02 145);--accent: oklch(.65 .2 145);--accent-dim: oklch(.2 .08 145);--accent-hover: oklch(.7 .2 145);--gem-light: oklch(.78 .15 150);--green: oklch(.72 .16 145);--yellow: oklch(.78 .15 75);--red: oklch(.62 .2 25);--header-h: 52px;--sidebar-w: 220px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 3px;--radius-md: 6px;--radius-lg: 6px;--radius-xl: 10px;--radius-full: 9999px;--shadow-sm: 0 1px 4px rgba(0,0,0,.45);--shadow-md: 0 4px 14px rgba(0,0,0,.55);--shadow-lg: 0 8px 30px rgba(0,0,0,.65);--shadow-glow: 0 0 24px oklch(.65 .2 145 / .3);--shadow-gem: inset 0 1px 0 oklch(.78 .15 150 / .2);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--ease-out: cubic-bezier(.22, 1, .36, 1);--dur-fast: .15s;--dur-normal: .3s;--dur-spring: .5s;color-scheme:dark}@media(prefers-color-scheme:light){:root{--bg-base: oklch(.96 .008 145);--bg-panel: oklch(.99 .004 145);--bg-hover: oklch(.93 .01 145);--bg-selected: oklch(.91 .012 145);--border: oklch(.84 .012 145);--border-accent: oklch(.72 .03 145);--text-primary: oklch(.14 .018 140);--text-secondary: oklch(.32 .022 145);--text-muted: oklch(.48 .018 145);color-scheme:light}}*,*:before,*:after{box-sizing:border-box}html{color-scheme:dark;font-size:14px}body{margin:0;background:var(--bg-base);color:var(--text-primary);font-family:Nunito,Noto Sans KR,sans-serif;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;line-height:1.5;min-height:100vh}body:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;background:repeating-linear-gradient(0deg,transparent 0px,transparent 2px,rgba(0,0,0,.012) 2px,rgba(0,0,0,.012) 4px)}.skip-link{position:absolute;top:-40px;left:8px;background:var(--accent);color:#000;padding:8px 16px;border-radius:var(--radius-md);text-decoration:none;font-size:12px;font-weight:700;z-index:10000;transition:top var(--dur-fast)}.skip-link:focus{top:8px}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:100;background:#080d07bf;backdrop-filter:blur(10px) saturate(1.3);-webkit-backdrop-filter:blur(10px) saturate(1.3);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 var(--space-md);gap:var(--space-md)}.body-area{display:flex;margin-top:var(--header-h);min-height:calc(100vh - var(--header-h))}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-panel);border-right:1px solid var(--border);position:fixed;top:var(--header-h);left:0;bottom:0;overflow-y:auto;overflow-x:hidden;z-index:50;scrollbar-width:thin;scrollbar-color:var(--border) transparent;transition:transform var(--dur-normal) var(--ease-out)}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.sidebar-section{padding:var(--space-sm) 0}.sidebar-label{font-family:Fira Code,monospace;font-size:9px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);padding:var(--space-xs) var(--space-md);margin-bottom:2px}.sidebar-item{display:flex;align-items:center;gap:var(--space-sm);padding:7px var(--space-md);cursor:pointer;border-left:2px solid transparent;transition:all var(--dur-fast);text-decoration:none;color:var(--text-secondary);font-size:13px;font-weight:600}.sidebar-item:hover{background:var(--bg-hover);color:var(--text-primary);border-left-color:var(--border-accent)}.sidebar-item.active{border-left-color:var(--accent);background:var(--accent-dim);color:var(--text-primary)}.sidebar-item .material-symbols-outlined{font-size:18px;color:var(--text-muted);flex-shrink:0}.sidebar-item.active .material-symbols-outlined,.sidebar-item:hover .material-symbols-outlined{color:var(--accent)}.sidebar-count{font-family:Fira Code,monospace;font-size:10px;color:var(--text-muted);margin-left:auto;background:var(--bg-base);padding:1px 5px;border-radius:var(--radius-sm);border:1px solid var(--border)}.sidebar-divider{height:1px;background:var(--border);margin:var(--space-sm) var(--space-md)}.main-content{margin-left:var(--sidebar-w);flex:1;padding:var(--space-lg);min-width:0}.logo{font-family:Fira Code,monospace;font-size:13px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);text-decoration:none;display:flex;align-items:center;gap:7px}.logo-gem{width:10px;height:10px;background:linear-gradient(135deg,var(--gem-light),var(--accent));clip-path:polygon(50% 0%,100% 38%,82% 100%,18% 100%,0% 38%);animation:gem-glow 3s ease-in-out infinite}@keyframes gem-glow{0%,to{filter:brightness(.8) drop-shadow(0 0 2px var(--accent))}50%{filter:brightness(1.3) drop-shadow(0 0 6px var(--gem-light))}}.search-wrap{flex:1;max-width:480px;position:relative}.search-input{width:100%;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-md);padding:7px 12px 7px 36px;color:var(--text-primary);font-family:Nunito,sans-serif;font-size:13px;font-weight:600;outline:none;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #11ad3226}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:18px;pointer-events:none}.header-actions{display:flex;align-items:center;gap:var(--space-sm);margin-left:auto}.header-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--dur-fast)}.header-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-accent)}.nav-toggle{display:none;width:36px;height:36px;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:0}.filter-bar{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap}.filter-heading{font-size:16px;font-weight:800;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm)}.count-badge{font-family:Fira Code,monospace;font-size:10px;background:var(--accent-dim);color:var(--accent);border:1px solid var(--border-accent);padding:2px 7px;border-radius:var(--radius-full)}.sort-tabs{display:flex;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-md);padding:2px;gap:2px;margin-left:auto}.sort-tab{font-size:11px;font-weight:700;color:var(--text-muted);padding:5px 10px;border-radius:calc(var(--radius-md) - 2px);cursor:pointer;transition:all var(--dur-fast);background:transparent;border:none;white-space:nowrap}.sort-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.sort-tab.active{background:var(--accent);color:#000;font-weight:700;box-shadow:var(--shadow-sm)}.card-grid{columns:4;column-gap:14px}.content-card{break-inside:avoid;display:block;margin-bottom:14px;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-md),var(--shadow-gem);transition:transform var(--dur-spring) var(--ease-bounce),box-shadow var(--dur-normal) var(--ease-out),border-color var(--dur-fast);animation:bounce-in var(--dur-spring) var(--ease-bounce) both}@keyframes bounce-in{0%{opacity:0;transform:scale(.88) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.content-card:nth-child(1){animation-delay:0s}.content-card:nth-child(2){animation-delay:.05s}.content-card:nth-child(3){animation-delay:.1s}.content-card:nth-child(4){animation-delay:.15s}.content-card:nth-child(5){animation-delay:.2s}.content-card:nth-child(6){animation-delay:.25s}.content-card:nth-child(7){animation-delay:.3s}.content-card:nth-child(8){animation-delay:.35s}.content-card:nth-child(9){animation-delay:.4s}.content-card:nth-child(10){animation-delay:.45s}.content-card:nth-child(11){animation-delay:.5s}.content-card:nth-child(12){animation-delay:.55s}.content-card:hover{transform:scale(1.02) translateY(-3px);box-shadow:var(--shadow-lg),var(--shadow-glow),var(--shadow-gem);border-color:var(--border-accent)}.content-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.content-card.tall .card-thumb{aspect-ratio:3/4}.content-card.wide .card-thumb{aspect-ratio:16/9}.card-thumb{aspect-ratio:4/3;position:relative;overflow:hidden;background:var(--bg-base)}.card-thumb-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.card-thumb-icon{font-size:36px;color:var(--border-accent);opacity:.6}.card-format-badge{position:absolute;bottom:6px;left:6px;font-family:Fira Code,monospace;font-size:9px;font-weight:500;background:#000000bf;color:var(--green);padding:2px 6px;border-radius:var(--radius-sm);border:1px solid oklch(.72 .16 145 / .3);text-transform:uppercase}.card-cat-tag{position:absolute;bottom:6px;right:6px;font-size:9px;font-weight:700;background:var(--accent-dim);color:var(--accent);border:1px solid oklch(.65 .2 145 / .4);padding:2px 6px;border-radius:var(--radius-sm)}.card-badge{position:absolute;top:8px;right:8px;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Fira Code,monospace;font-size:8px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;transform:rotate(-15deg);box-shadow:var(--shadow-sm)}.card-badge.new{background:#5bbe62e6;color:#000}.card-badge.hot{background:#e64343e6;color:#fff}.card-badge.sale{background:#efa831e6;color:#000}.content-card.featured:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),var(--gem-light),var(--accent),transparent);z-index:1}.content-card{position:relative}.card-info{padding:var(--space-sm) var(--space-sm) 10px}.card-title{font-size:13px;font-weight:700;color:var(--text-primary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:6px;word-break:keep-all}.card-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.card-size{font-family:Fira Code,monospace;font-size:10px;color:var(--green)}.card-views{font-family:Fira Code,monospace;font-size:10px;color:var(--text-muted);margin-left:auto}.glass-medium{background:#080d07bf;backdrop-filter:blur(10px) saturate(1.3);-webkit-backdrop-filter:blur(10px) saturate(1.3);border:1px solid oklch(.32 .04 140 / .5)}.pagination{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:var(--space-xl);padding-bottom:var(--space-lg)}.page-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-family:Fira Code,monospace;font-size:12px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--dur-fast);touch-action:manipulation}.page-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.page-btn.active{background:var(--accent);border-color:var(--accent);color:#000;font-weight:700;box-shadow:var(--shadow-glow)}.page-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.write-fab{position:fixed;bottom:28px;right:28px;display:flex;align-items:center;gap:6px;background:var(--accent);color:#000;padding:12px 20px;border-radius:var(--radius-full);border:none;cursor:pointer;font-family:Nunito,sans-serif;font-size:13px;font-weight:800;box-shadow:var(--shadow-glow),var(--shadow-md);transition:transform var(--dur-fast) var(--ease-bounce),box-shadow var(--dur-fast),filter var(--dur-fast);z-index:200;touch-action:manipulation}.write-fab:hover{transform:translateY(-2px) scale(1.04);filter:brightness(1.1)}.write-fab:active{transform:scale(.96)}.data-table{width:100%;border-collapse:collapse}.data-table thead th{font-family:Fira Code,monospace;font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--bg-panel);padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}.data-table tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--dur-fast)}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table tbody td{padding:10px 12px;font-size:13px;color:var(--text-secondary)}.data-table tbody tr.pinned{border-left:3px solid var(--accent);background:var(--accent-dim)}.table-tag{font-family:Fira Code,monospace;font-size:9px;font-weight:500;text-transform:uppercase;padding:2px 6px;border-radius:var(--radius-sm);margin-right:4px}.table-tag.notice{background:var(--accent-dim);color:var(--accent);border:1px solid oklch(.65 .2 145 / .3)}.table-tag.file{background:#5bbe6226;color:var(--green);border:1px solid oklch(.72 .16 145 / .3)}.table-tag.req{background:#efa83126;color:var(--yellow);border:1px solid oklch(.78 .15 75 / .3)}.file-badge{font-family:Fira Code,monospace;font-size:10px;color:var(--green);border:1px solid oklch(.72 .16 145 / .3);padding:2px 8px;border-radius:var(--radius-sm)}.stats-bar{display:flex;align-items:center;gap:var(--space-lg);background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:6px;font-size:12px}.stat-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.stat-label{color:var(--text-muted)}.stat-value{color:var(--text-primary);font-family:Fira Code,monospace;font-weight:500}.rank-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);display:flex;gap:var(--space-md);align-items:flex-start;transition:transform var(--dur-spring) var(--ease-bounce),box-shadow var(--dur-normal);box-shadow:var(--shadow-sm),var(--shadow-gem);animation:bounce-in var(--dur-spring) var(--ease-bounce) both}.rank-card:hover{transform:scale(1.01) translateY(-2px);box-shadow:var(--shadow-md),var(--shadow-glow)}.rank-medal{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Fira Code,monospace;font-size:16px;font-weight:700;flex-shrink:0}.rank-medal.gold{background:linear-gradient(135deg,gold,#ffb800);color:#000;box-shadow:0 0 12px #ffd70066}.rank-medal.silver{background:linear-gradient(135deg,silver,#a0a0a0);color:#000}.rank-medal.bronze{background:linear-gradient(135deg,#cd7f32,sienna);color:#fff}.rank-medal.other{background:var(--bg-hover);color:var(--text-muted);border:1px solid var(--border);font-size:13px}.rank-tabs{display:flex;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-md);padding:3px;gap:2px;margin-bottom:var(--space-md);width:fit-content}.rank-tab{font-size:12px;font-weight:700;color:var(--text-muted);padding:6px 14px;border-radius:calc(var(--radius-md) - 2px);cursor:pointer;transition:all var(--dur-fast);background:transparent;border:none}.rank-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.rank-tab[aria-selected=true]{background:var(--accent);color:#000;box-shadow:var(--shadow-sm)}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);margin-bottom:var(--space-md);flex-wrap:wrap}.breadcrumb a{color:var(--text-secondary);text-decoration:none;font-weight:600}.breadcrumb a:hover{color:var(--accent)}.article-header{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);box-shadow:var(--shadow-sm),var(--shadow-gem)}.article-title{font-size:20px;font-weight:800;color:var(--text-primary);line-height:1.3;margin-bottom:var(--space-sm);word-break:keep-all}.article-meta{display:flex;align-items:center;gap:var(--space-md);font-size:12px;color:var(--text-muted);flex-wrap:wrap}.article-meta-item{display:flex;align-items:center;gap:4px}.article-body{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);color:var(--text-secondary);line-height:1.8;font-size:14px;box-shadow:var(--shadow-sm),var(--shadow-gem);overflow-wrap:break-word;word-break:break-word}.article-body img,.article-body video,.article-body iframe,.article-body embed,.article-body object{max-width:100%;height:auto;display:block;margin:12px auto;border-radius:var(--radius-md)}.article-body table{max-width:100%;display:block;overflow-x:auto}.article-body pre{max-width:100%;overflow-x:auto}.file-card{display:flex;align-items:center;gap:var(--space-sm);background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);transition:all var(--dur-fast);cursor:pointer}.file-card:hover{border-color:var(--accent);background:var(--accent-dim)}a.file-card{text-decoration:none;color:inherit}a.file-card:hover .action-btn.primary{filter:brightness(1.1)}.comment-item{display:flex;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid var(--border)}.comment-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.sidebar-overlay{display:none;position:fixed;inset:0;background:#000000a6;z-index:40;opacity:0;transition:opacity var(--dur-normal)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.tabular-nums{font-variant-numeric:tabular-nums}@media(max-width:1200px){.card-grid{columns:3}}@media(max-width:1024px){.sidebar{transform:translate(-100%);z-index:60}.main-content{margin-left:0}.nav-toggle{display:flex}body.nav-open .sidebar{transform:translate(0)}body.nav-open .sidebar-overlay{display:block;opacity:1}}@media(max-width:900px){.card-grid{columns:2}.main-content{padding:var(--space-md)}}@media(max-width:480px){.card-grid{columns:2}}@media(max-width:360px){.card-grid{columns:1}}@media(max-width:768px){.data-table{display:block;overflow-x:auto}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.logo-gem{animation:none}}
