:root{color:#191f28;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--text-strong:#191f28;--text:#333d4b;--text-soft:#6b7280;--text-muted:#8b95a1;--text-faint:#b0b8c1;--line:#e5e8eb;--line-soft:#f2f4f6;--surface:#fff;--surface-soft:#f8fafc;--surface-blue:#ebf3ff;--blue:#3182f6;--blue-strong:#1b64da;--shadow-sm:0 1px 3px #1118270d;--shadow-md:0 14px 32px #1118271a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;background:#fff;font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:#fff;min-width:320px;margin:0}button,input,textarea{font:inherit}button{border:0}a{color:inherit;text-decoration:none}.app{background:linear-gradient(#fff 0% 62%,#fbfcfd 100%);min-height:100vh}.site-header{z-index:50;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffdb;border-bottom:1px solid #e5e8ebcc;position:sticky;top:0}.header-inner{align-items:center;gap:28px;width:min(1120px,100% - 48px);height:72px;margin:0 auto;display:flex}.brand{color:var(--text-strong);cursor:pointer;letter-spacing:0;background:0 0;border:0;font-size:28px;font-weight:800}.brand.large{cursor:default;font-size:44px;display:inline-block}.header-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.icon-button,.heart-button{border:1px solid var(--line);background:var(--surface);color:var(--text);cursor:pointer;justify-content:center;align-items:center;transition:transform .16s,background .16s,box-shadow .16s;display:inline-flex}.icon-button{border-radius:var(--radius-sm);width:40px;height:40px;font-size:18px}.icon-button svg,.primary-button svg,.heart-button svg{stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;fill:none;width:19px;height:19px}.icon-button:hover,.icon-button.active{background:#f4f6f8}.heart-button{border-radius:var(--radius-sm);min-height:32px;color:var(--text-muted);gap:5px;padding:0 8px;font-size:13px;font-weight:750}.heart-button svg{width:16px;height:16px}.heart-button.active{color:#e5484d;background:#fff4f6;border-color:#ffd6df}.heart-button.active svg{fill:currentColor}.primary-button,.ghost-button{cursor:pointer;border-radius:10px;justify-content:center;align-items:center;min-height:48px;font-weight:700;transition:transform .16s,background .16s,border-color .16s,color .16s;display:inline-flex}.primary-button{border:1px solid var(--blue);background:var(--blue);color:#fff;gap:8px;padding:0 20px}.primary-button:hover{background:var(--blue-strong);border-color:var(--blue-strong);transform:translateY(-1px)}.primary-button:disabled,.ghost-button:disabled{cursor:not-allowed;opacity:.58;transform:none}.ghost-button{border:1px solid var(--line);color:var(--text);background:#fff;padding:0 18px}.ghost-button:hover{background:#f7f8fa;transform:translateY(-1px)}.compact{min-height:40px;padding:0 14px;font-size:14px}.full{width:100%}.page-heading h1,.detail-content h1,.profile-header h1,.auth-panel h1{color:var(--text-strong);letter-spacing:0;margin:0}.eyebrow{color:var(--blue);margin:0 0 14px;font-size:14px;font-weight:750}.search-result{border-radius:var(--radius-md);width:100%;color:inherit;cursor:pointer;text-align:left;background:#fff;align-items:center;gap:12px;display:flex}.search-result-main{min-width:0;color:inherit;cursor:pointer;text-align:left;background:0 0;flex:1;align-items:center;gap:12px;display:flex}.search-result:hover{background:#f8fafc}.search-result-main span:not(.project-initial){flex:1;gap:5px;min-width:0;display:grid}.search-result strong{color:var(--text-strong);font-size:15px}.search-result small{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.project-section,.feed-page,.form-page,.profile-page,.detail-layout{width:min(1120px,100% - 48px);margin:0 auto}.status-message{border-radius:var(--radius-md);width:min(1120px,100% - 48px);color:var(--blue-strong);background:#f5f9ff;border:1px solid #d9e8ff;margin:24px auto -24px;padding:14px 16px;font-size:14px;font-weight:700}.project-section{padding:48px 0}.feed-page{padding:34px 0 64px}.section-heading,.page-heading{justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:24px;display:flex}.section-heading h2{color:var(--text-strong);letter-spacing:0;margin:0;font-size:24px}.section-heading p{color:var(--text-muted);margin:8px 0 0}.project-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;display:grid}.feed-tabs{justify-content:center;margin-bottom:20px;display:flex}.feed-list{gap:12px;width:min(1040px,100%);margin:0 auto;display:grid}.project-card{border:1px solid var(--line-soft);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);background:#fff;transition:transform .18s,box-shadow .18s,border-color .18s;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-md);border-color:#eceef0;transform:translateY(-2px)}.card-click-area{cursor:pointer;text-align:left;background:0 0;width:100%;padding:0}.card-visual,.detail-visual{background:repeating-linear-gradient(45deg, #ffffff57 0 1px, transparent 1px 12px), linear-gradient(180deg, #ffffffbd, #f7f9fce0), var(--tint);color:var(--ink);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.card-visual{aspect-ratio:2.2}.card-visual img{object-fit:contain;width:100%;height:100%}.card-visual span{font-size:40px;font-weight:850}.card-body{padding:17px 18px 16px}.category-line{color:var(--text-faint);justify-content:space-between;align-items:center;gap:12px;font-size:12px;font-weight:700;display:flex}.card-body h3{color:var(--text-strong);margin:10px 0 0;font-size:18px;line-height:1.35}.card-body p{min-height:44px;color:var(--text-soft);margin:8px 0 0;font-size:14px;line-height:1.55}.card-meta{min-height:48px;color:var(--text-muted);border-top:1px solid #f4f5f6;justify-content:space-between;align-items:center;gap:12px;padding:11px 18px;font-size:13px;font-weight:650;display:flex}.feed-list .project-card{grid-template-columns:minmax(0,1fr) auto;align-items:stretch;display:grid}.feed-list .card-click-area{grid-template-columns:168px minmax(0,1fr);min-width:0;display:grid}.feed-list .card-visual{aspect-ratio:auto;width:168px;min-height:108px}.feed-list .card-body{align-content:start;min-width:0;padding:14px 16px;display:grid}.feed-list .card-body h3{margin-top:8px;font-size:16px}.feed-list .card-body p{-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:0;margin-top:6px;display:-webkit-box;overflow:hidden}.feed-list .card-meta{border-top:0;border-left:1px solid #f4f5f6;flex-direction:column;justify-content:space-between;align-items:flex-start;width:150px;min-height:0;padding:14px}.feed-list .card-stats{justify-content:space-between;width:100%}.card-stats{flex:none;align-items:center;gap:10px;display:flex}.maker-line,.maker-card{align-items:center;gap:8px;min-width:0;display:flex}.maker-line span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.maker-line b{color:var(--text)}.profile-link,.search-maker{min-width:0;color:var(--text);cursor:pointer;font:inherit;text-align:left;background:0 0;font-weight:750}.profile-link:hover,.search-maker:hover{color:var(--blue)}.search-maker{color:var(--text-muted);flex:none;font-size:13px}.project-initial,.avatar{background:var(--tint);color:var(--ink);border-radius:999px;flex:none;justify-content:center;align-items:center;font-weight:800;display:inline-flex}.project-initial{width:48px;height:48px;font-size:17px}.avatar{width:28px;height:28px;font-size:12px}.avatar.medium{width:44px;height:44px;font-size:17px}.avatar.large{width:78px;height:78px;font-size:28px}.feed-page,.form-page,.profile-page,.detail-layout,.auth-page{padding:64px 0}.page-heading h1{font-size:42px}.search-field{width:min(360px,100%);color:var(--text-muted);gap:7px;font-size:13px;font-weight:700;display:grid}.search-field input,.field input,.field textarea,.comment-form textarea{border:1px solid var(--line);width:100%;color:var(--text-strong);background:#fff;border-radius:10px;outline:none}.search-field input,.field input{height:48px;padding:0 14px}.search-field input:focus,.field input:focus,.field textarea:focus,.comment-form textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3182f61f}.tab-row{background:#f4f6f8;border-radius:12px;gap:4px;margin-bottom:24px;padding:4px;display:inline-flex}.tab{border-radius:var(--radius-sm);min-height:36px;color:var(--text-muted);cursor:pointer;background:0 0;padding:0 16px;font-weight:700}.tab.active{color:var(--text-strong);box-shadow:var(--shadow-sm);background:#fff}.detail-layout{grid-template-columns:minmax(0,1fr) 280px;gap:28px;display:grid}.detail-main{border:1px solid var(--line-soft);border-radius:var(--radius-lg);min-width:0;box-shadow:var(--shadow-sm);background:#fff;overflow:hidden}.detail-visual{height:320px}.detail-visual img{object-fit:contain;width:100%;height:100%}.detail-initial{font-size:84px;font-weight:850}.detail-content{min-width:0;padding:34px}.detail-content h1{margin-top:14px;font-size:42px}.detail-content>p{color:var(--text-soft);margin:16px 0 0;font-size:18px;line-height:1.72}.markdown-content{color:var(--text-soft);overflow-wrap:anywhere;word-break:break-word;gap:12px;margin-top:18px;font-size:17px;line-height:1.72;display:grid}.markdown-content h2,.markdown-content h3,.markdown-content p,.markdown-content ul,.markdown-content blockquote{margin:0}.markdown-content h2,.markdown-content h3{color:var(--text-strong);line-height:1.35}.markdown-content h2{margin-top:8px;font-size:24px}.markdown-content h3{font-size:19px}.markdown-content ul{gap:6px;padding-left:20px;display:grid}.markdown-content blockquote{border-left:3px solid var(--blue);border-radius:var(--radius-sm);background:#f7f9fc;padding:12px 14px}.markdown-content code{color:var(--text);background:#f1f3f5;border-radius:6px;padding:2px 5px;font-size:.92em}.markdown-content hr{border:0;border-top:1px solid var(--line-soft);width:100%}.detail-actions{flex-wrap:wrap;gap:10px;margin-top:28px;display:flex}.detail-heart{min-height:48px;padding:0 16px}.detail-sidebar{align-content:start;gap:12px;display:grid}.stat-card,.maker-card,.comments-section,.edit-panel,.project-form,.auth-panel,.profile-header{border:1px solid var(--line-soft);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);background:#fff}.stat-card{gap:8px;padding:18px;display:grid}.stat-card span{color:var(--text-muted);font-size:13px;font-weight:700}.stat-card strong{color:var(--text-strong);font-size:26px}.maker-card{width:100%;color:inherit;cursor:default;text-align:left;padding:18px}button.maker-card{cursor:pointer}button.maker-card:hover{background:#f8fbff;border-color:#d9e8ff}.maker-card div{gap:4px;min-width:0;display:grid}.maker-card strong{color:var(--text-strong)}.maker-card span{color:var(--text-muted);font-size:13px}.comments-section,.edit-panel{grid-column:1/-1;padding:24px}.compact-form{box-shadow:none}.comments-section .section-heading{border-bottom:1px solid var(--line-soft);align-items:center;margin-bottom:18px;padding-bottom:14px}.comments-section .section-heading span{color:var(--text-faint);font-weight:750}.comment-form{gap:10px;margin-bottom:18px;display:grid}.comment-form textarea,.field textarea{resize:vertical;min-height:116px;padding:14px;line-height:1.55}.comment-form .primary-button{justify-self:end}.login-required{border-radius:var(--radius-md);color:var(--text);background:#f5f9ff;border:1px solid #d9e8ff;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;padding:16px;font-size:14px;font-weight:700;display:flex}.comment-list{gap:12px;display:grid}.comment-item{border:1px solid var(--line-soft);border-radius:var(--radius-md);gap:12px;padding:16px;display:flex}.comment-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.comment-meta strong{color:var(--text)}.comment-meta span{color:var(--text-faint);font-size:13px;font-weight:650}.comment-item p{color:var(--text-soft);margin:7px 0 0;line-height:1.58}.project-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;padding:24px;display:grid}.field{color:var(--text);gap:8px;font-size:14px;font-weight:750;display:grid}.span-all,.form-actions{grid-column:1/-1}.form-actions{justify-content:flex-end;gap:10px;padding-top:6px;display:flex}.profile-header{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:18px;margin-bottom:36px;padding:26px;display:grid}.profile-header h1{font-size:36px}.profile-header p:not(.eyebrow){color:var(--text-soft);margin:8px 0 0;line-height:1.6}.auth-page{justify-content:center;align-items:center;min-height:calc(100vh - 280px);display:flex}.auth-panel{gap:14px;width:min(420px,100% - 48px);padding:32px;display:grid}.auth-panel h1{margin-top:4px;font-size:28px}.auth-panel p{color:var(--text-soft);margin:0 0 8px;line-height:1.6}.overlay-backdrop{z-index:80;background:#191f2847;justify-content:center;align-items:flex-start;padding:96px 24px 24px;display:flex;position:fixed;inset:0}.search-panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:#fff;width:min(680px,100%);padding:18px;box-shadow:0 24px 70px #1118273d}.search-header,.panel-heading{justify-content:space-between;align-items:center;gap:12px;display:flex}.search-field.large{flex:1;width:100%}.search-results{gap:8px;margin-top:14px;display:grid}.search-result{min-height:72px;padding:12px}.panel-heading{margin-bottom:10px}.panel-heading h2{margin:0;font-size:18px}.panel-heading button{color:var(--text-muted);cursor:pointer;background:0 0;font-weight:700}.empty-state{border:1px dashed var(--line);border-radius:var(--radius-md);min-height:220px;color:var(--text-muted);text-align:center;place-items:center;gap:8px;display:grid}.empty-state strong{color:var(--text);font-size:18px}.empty-state p{margin:0}.site-footer{border-top:1px solid var(--line-soft);width:min(1120px,100% - 48px);color:var(--text-muted);justify-content:space-between;align-items:center;gap:18px;margin:48px auto 0;padding:34px 0;display:flex}.site-footer strong{color:var(--text-strong);font-size:20px}.site-footer p{margin:6px 0 0;font-size:13px}.site-footer nav{gap:20px;font-size:13px;font-weight:650;display:flex}.submit-preview{border:1px solid var(--line-soft);border-radius:var(--radius-md);background:#fbfcfd;align-items:center;gap:12px;min-height:76px;padding:14px;display:flex}.image-file-field{border:1px solid var(--line-soft);border-radius:var(--radius-md);background:#fbfcfd;gap:12px;padding:16px;display:grid}.image-field-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.file-button{border:1px solid var(--line);border-radius:var(--radius-sm);min-height:40px;color:var(--text);cursor:pointer;background:#fff;justify-content:center;align-items:center;padding:0 14px;font-size:14px;font-weight:750;display:inline-flex}.file-button input{clip:rect(0, 0, 0, 0);width:1px;height:1px;position:absolute;overflow:hidden}.image-preview-frame,.submit-preview-image{border-radius:var(--radius-md);background:repeating-linear-gradient(45deg, #ffffff57 0 1px, transparent 1px 12px), linear-gradient(180deg, #ffffffbd, #f7f9fce0), var(--tint,#ebf3ff);color:var(--ink,#3182f6);position:relative;overflow:hidden}.image-preview-frame{aspect-ratio:1.55}.image-preview-frame img,.submit-preview-image img{object-fit:contain;width:100%;height:100%}.image-empty-state{border:1px dashed var(--line);border-radius:var(--radius-md);min-height:116px;color:var(--text-muted);text-align:center;place-items:center;font-size:14px;display:grid}.field-error{color:#e5484d;margin:0;font-size:13px;font-weight:700}.submit-preview-image{aspect-ratio:1.55;flex:none;place-items:center;width:108px;font-weight:850;display:grid}.submit-preview>span{gap:5px;min-width:0;display:grid}.submit-preview strong{color:var(--text-strong);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.submit-preview small{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}@media (width<=900px){.header-inner,.project-section,.feed-page,.form-page,.profile-page,.detail-layout,.site-footer,.status-message{width:min(100% - 32px,1120px)}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.feed-list .project-card,.feed-list .card-click-area{grid-template-columns:1fr}.feed-list .card-visual{aspect-ratio:2.2;width:100%;min-height:0}.feed-list .card-meta{border-top:1px solid #f4f5f6;border-left:0;flex-direction:row;align-items:center;width:100%;min-height:48px;padding:11px 18px}.feed-list .card-stats{width:auto}.detail-layout{grid-template-columns:1fr}.detail-sidebar{grid-template-columns:repeat(3,minmax(0,1fr))}.maker-card{grid-column:1/-1}}@media (width<=640px){.header-inner{gap:12px;height:64px}.brand{font-size:24px}.header-actions{gap:6px}.header-actions .ghost-button,.header-actions .primary-button{min-height:36px;padding:0 10px;font-size:13px}.icon-button{width:36px;height:36px}.section-heading,.page-heading,.site-footer{flex-direction:column;align-items:flex-start}.page-heading h1,.detail-content h1{font-size:32px}.project-grid,.project-form,.detail-sidebar,.profile-header{grid-template-columns:1fr}.detail-visual{height:240px}.detail-content,.comments-section,.project-form,.auth-panel{padding:20px}}
