*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #4f46e5;--primary-hover: #4338ca;--primary-light: #eef2ff;--danger: #ef4444;--danger-hover: #dc2626;--success: #22c55e;--warning: #f59e0b;--bg: #f5f5f3;--bg-alt: #f8fafc;--surface: #ffffff;--surface-elevated: #faf9f7;--surface-hover: #f7f7f7;--surface-active: rgba(0,0,0,.07);--text-primary: #111111;--text-secondary: #666666;--text-muted: #6b6b6b;--text-faint: #a0a0a0;--text-on-primary: #ffffff;--border: rgba(0,0,0,.08);--border-medium: rgba(0,0,0,.18);--border-strong: rgba(0,0,0,.3);--border-solid: #d1d5db;--shadow-sm: 0 1px 4px rgba(0,0,0,.06);--shadow-md: 0 4px 16px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.1);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--header-height: 74px;--header-bg: #f5f5f3;--header-card-bg: #ffffff;--footer-bg: #2a2927;--footer-text: #b0aea6;--footer-text-bright: #f1efe8;--footer-text-dim: #5f5e5a;--footer-border: rgba(255,255,255,.08);--overlay-light: rgba(255,255,255,.5);--overlay-dark: rgba(0,0,0,.2);--code-bg: #1e293b;--code-text: #e2e8f0;--auth-gradient: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 100%);--badge-green-bg: #ecfdf5;--badge-green-text: #047857;--badge-green-border: rgba(4,120,87,.2);--badge-blue-bg: #eff6ff;--badge-blue-text: #1d4ed8;--badge-blue-border: rgba(29,78,216,.2);--badge-amber-bg: #fffbeb;--badge-amber-text: #b45309;--badge-amber-border: rgba(180,83,9,.2);--badge-red-bg: #fef2f2;--badge-red-text: #dc2626;--badge-red-border: rgba(220,38,38,.2);--badge-purple-bg: #faf5ff;--badge-purple-text: #7c3aed;--badge-purple-border: rgba(124,58,237,.2);--badge-indigo-bg: #eef2ff;--badge-indigo-text: #4f46e5;--badge-indigo-border: rgba(79,70,229,.2);--badge-gray-bg: #f8fafc;--badge-gray-text: #64748b;--badge-gray-border: rgba(100,116,139,.2);--badge-teal-bg: #f0fdfa;--badge-teal-text: #0d9488;--badge-teal-border: rgba(13,148,136,.2);--badge-cyan-bg: #ecfeff;--badge-cyan-text: #0891b2;--badge-cyan-border: rgba(8,145,178,.2);--btn-primary-bg: #2C2C2A;--btn-primary-hover: #444441;--btn-primary-text: #ffffff;--btn-danger-text: #5F5E5A;--btn-danger-border: #888780;--btn-danger-hover-border: #5F5E5A;--btn-danger-hover-text: #2C2C2A;--btn-outline-text: #5F5E5A;--btn-outline-border: #888780;--btn-outline-hover-border: #5F5E5A;--btn-outline-hover-text: #2C2C2A;font-size:16px;color-scheme:light}[data-theme=dark]{--bg: #0d0d0d;--bg-alt: #141414;--surface: #1a1a1a;--surface-elevated: #222222;--surface-hover: #2a2a2a;--surface-active: rgba(255,255,255,.08);--primary: #818cf8;--primary-hover: #a5b4fc;--primary-light: rgba(129,140,248,.15);--text-primary: #e8e8e8;--text-secondary: #b0b0b0;--text-muted: #a0a0a0;--text-faint: #6e6e6e;--border: rgba(255,255,255,.08);--border-medium: rgba(255,255,255,.16);--border-strong: rgba(255,255,255,.28);--border-solid: rgba(255,255,255,.16);--shadow-sm: 0 1px 4px rgba(0,0,0,.4);--shadow-md: 0 4px 16px rgba(0,0,0,.5);--shadow-lg: 0 8px 24px rgba(0,0,0,.6);--header-bg: #0d0d0d;--header-card-bg: #111111;--footer-bg: #141414;--footer-text: #888888;--footer-text-bright: #cccccc;--footer-text-dim: #555555;--footer-border: rgba(255,255,255,.08);--overlay-light: rgba(0,0,0,.5);--overlay-dark: rgba(0,0,0,.6);--code-bg: #0d0d0d;--code-text: #d1d5db;--auth-gradient: linear-gradient(135deg, #111 0%, #1a1a2e 100%);--badge-green-bg: rgba(4,120,87,.15);--badge-green-text: #6ee7b7;--badge-green-border: rgba(110,231,183,.2);--badge-blue-bg: rgba(29,78,216,.15);--badge-blue-text: #93c5fd;--badge-blue-border: rgba(147,197,253,.2);--badge-amber-bg: rgba(180,83,9,.15);--badge-amber-text: #fcd34d;--badge-amber-border: rgba(252,211,77,.2);--badge-red-bg: rgba(220,38,38,.15);--badge-red-text: #fca5a5;--badge-red-border: rgba(252,165,165,.2);--badge-purple-bg: rgba(124,58,237,.15);--badge-purple-text: #c4b5fd;--badge-purple-border: rgba(196,181,253,.2);--badge-indigo-bg: rgba(79,70,229,.15);--badge-indigo-text: #a5b4fc;--badge-indigo-border: rgba(165,180,252,.2);--badge-gray-bg: rgba(100,116,139,.15);--badge-gray-text: #94a3b8;--badge-gray-border: rgba(148,163,184,.2);--badge-teal-bg: rgba(13,148,136,.15);--badge-teal-text: #5eead4;--badge-teal-border: rgba(94,234,212,.2);--badge-cyan-bg: rgba(8,145,178,.15);--badge-cyan-text: #67e8f9;--badge-cyan-border: rgba(103,232,249,.2);--btn-primary-bg: #e8e8e8;--btn-primary-hover: #d0d0d0;--btn-primary-text: #111111;--btn-danger-text: #999999;--btn-danger-border: #555555;--btn-danger-hover-border: #999999;--btn-danger-hover-text: #e8e8e8;--btn-outline-text: #999999;--btn-outline-border: #555555;--btn-outline-hover-border: #999999;--btn-outline-hover-text: #e8e8e8;color-scheme:dark}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans KR,sans-serif;background:var(--bg);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:background .2s,color .2s}#root{min-height:100vh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea{font-family:inherit}.layout{display:flex;flex-direction:column;min-height:100vh}.layout-main{flex:1;max-width:1100px;width:100%;margin:0 auto;padding:0 16px}.header{height:var(--header-height);background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.header-inner{max-width:1100px;margin:0 auto;height:100%;padding:0 16px;display:flex;align-items:center;gap:16px}.header-logo{font-size:1.452rem;font-weight:700;color:var(--primary);white-space:nowrap;cursor:pointer;flex-shrink:0}.header-menu{display:flex;align-items:center;gap:2px;flex:1}.header-menu-item{padding:6px 14px;border-radius:var(--radius-sm);font-size:1.271rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:color .15s,background .15s;white-space:nowrap}.header-menu-item:hover{color:var(--primary);background:var(--primary-light)}.header-menu-item.active{color:var(--primary);font-weight:600;background:var(--primary-light)}.community-nav-item{position:relative}.community-nav-btn{background:none;border:none;cursor:pointer;font-family:inherit}.community-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:160px;background:var(--bg-card, #fff);border:1px solid var(--border, #e5e7eb);border-radius:var(--radius-sm);box-shadow:0 4px 16px #0000002e;z-index:200;display:flex;flex-direction:column}.community-dropdown-item{padding:10px 16px;font-size:1.15rem;color:var(--text-primary);background:none;border:none;text-align:left;cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.community-dropdown-item:hover{background:var(--primary-light);color:var(--primary)}.community-dropdown-empty{padding:10px 16px;font-size:1.089rem;color:var(--text-secondary)}.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:auto}.header-lang-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1px solid var(--border, #e5e7eb);border-radius:6px;padding:4px 8px;font-size:.992rem;color:var(--text-secondary);cursor:pointer;outline:none;transition:border-color .15s}.header-lang-select:hover,.header-lang-select:focus{border-color:var(--primary, #6366f1);color:var(--text-primary)}.header-auth-btns{display:flex;align-items:center;gap:8px}.header-user{font-size:1.162rem;color:var(--text-secondary);display:flex;align-items:center;gap:12px}.header-username{font-weight:500;color:var(--text-primary);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-hamburger{display:none;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;border-radius:var(--radius-sm);font-size:1.25rem;color:var(--text-primary);cursor:pointer;transition:background .15s}.header-hamburger:hover{background:var(--bg)}.header-mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;top:var(--header-height);z-index:98}.header-mobile-menu{position:absolute;top:var(--header-height);left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-md);padding:8px 16px 20px;z-index:99}.mobile-nav{display:flex;flex-direction:column}.mobile-menu-item{display:block;padding:13px 12px;font-size:1.21rem;font-weight:500;color:var(--text-primary);text-decoration:none;border-radius:var(--radius-sm);transition:background .1s}.mobile-menu-item:hover{background:var(--bg)}.mobile-menu-item.active{color:var(--primary);background:var(--primary-light)}.mobile-menu-divider{height:1px;background:var(--border);margin:10px 0}.mobile-menu-auth{display:flex;flex-direction:column;gap:8px;padding:4px 0}.mobile-menu-user{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-size:1.15rem;color:var(--text-secondary)}@keyframes headerFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.hdr-dropdown-item{display:block;width:100%;padding:10px 16px;font-size:14.3px;color:var(--text-primary);background:var(--surface);border:none;text-align:left;cursor:pointer;font-family:inherit;transition:background .1s}.hdr-dropdown-item:hover{background:var(--surface-hover)}.hdr-icon-btn{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:transparent;border:.5px solid var(--border-medium);cursor:pointer;flex-shrink:0;transition:background .15s;padding:0;color:var(--text-secondary)}.hdr-icon-btn:hover{background:var(--surface-hover)}.hdr-nav-btn{padding:6px 13px;border-radius:8px;font-size:14.3px;font-weight:400;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;font-family:inherit;white-space:nowrap;display:inline-flex;align-items:center;gap:3px;transition:color .12s,background .12s}.hdr-nav-btn:hover{color:var(--text-primary);background:var(--surface-active)}.hdr-nav-btn.active{font-weight:500;color:var(--text-primary);background:var(--surface-active)}.hdr-dropdown{position:absolute;top:calc(100% + 6px);background:var(--surface);border-radius:10px;border:.5px solid var(--border-medium);box-shadow:var(--shadow-md);z-index:200;min-width:160px;overflow:hidden}.hdr-user-pill{display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 8px 4px 4px;border-radius:20px;border:.5px solid var(--border-medium);background:transparent;transition:background .12s}.hdr-user-pill:hover,.hdr-user-pill.open{background:var(--surface-active)}.hdr-user-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:var(--surface);border-radius:12px;border:.5px solid var(--border-medium);box-shadow:var(--shadow-lg);min-width:172px;z-index:200;overflow:hidden;padding:6px 0}.hdr-dropdown-divider{height:.5px;background:var(--border);margin:6px 0}.hdr-dropdown-label{padding:2px 16px 6px;font-size:10px;font-weight:600;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase}.hdr-ghost-btn{padding:7px 14px;border-radius:8px;font-size:14.3px;border:.5px solid var(--border-medium);background:transparent;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.hdr-ghost-btn:hover{background:var(--surface-active);color:var(--text-primary)}.hdr-solid-btn{padding:7px 16px;border-radius:8px;font-size:14.3px;font-weight:500;border:none;background:var(--text-primary);color:var(--surface);cursor:pointer;font-family:inherit;transition:opacity .15s}.hdr-solid-btn:hover{opacity:.85}.hdr-lang-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:.5px solid var(--border-medium);border-radius:6px;padding:4px 8px;font-size:13.2px;color:var(--text-secondary);cursor:pointer;outline:none;font-family:inherit}.hdr-theme-toggle{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:transparent;border:.5px solid var(--border-medium);cursor:pointer;flex-shrink:0;transition:background .15s,transform .2s;padding:0;color:var(--text-secondary)}.hdr-theme-toggle:hover{background:var(--surface-hover);transform:rotate(15deg)}.hdr-mobile-drawer{position:fixed;top:var(--header-height);left:16px;right:16px;background:var(--surface);border-radius:0 0 14px 14px;border:.5px solid var(--border);border-top:none;box-shadow:var(--shadow-lg);z-index:99;padding:8px 8px 16px}.hdr-mobile-nav-btn{width:100%;display:flex;justify-content:space-between;align-items:center;padding:11px 12px;border-radius:8px;border:none;background:none;font-size:15.4px;font-weight:500;color:var(--text-primary);cursor:pointer;font-family:inherit}.hdr-mobile-nav-btn:hover{background:var(--surface-hover)}.hdr-mobile-sub-btn{width:100%;padding:9px 12px;border-radius:8px;border:none;background:none;font-size:14.3px;color:var(--text-secondary);text-align:left;cursor:pointer;font-family:inherit;display:block}.hdr-mobile-sub-btn:hover{background:var(--surface-hover)}@keyframes spinBack{0%{transform:rotate(0)}to{transform:rotate(-180deg)}}.back-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;background:var(--surface);border:1px solid var(--border-medium);border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-primary);font-family:inherit;white-space:nowrap;flex-shrink:0;transition:background .15s,border-color .15s,transform .1s}.back-btn:hover{background:var(--surface-hover);border-color:var(--border-strong)}.back-btn:active{transform:scale(.97)}.back-btn:hover .back-btn-icon{animation:spinBack .35s ease forwards}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 18px;border-radius:var(--radius-sm);font-size:.963rem;font-weight:500;border:none;transition:background .15s,opacity .15s,transform .1s;white-space:nowrap}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text)}.btn-primary:hover:not(:disabled){background:var(--btn-primary-hover)}.btn-danger{background:transparent;color:var(--btn-danger-text);border:1.5px solid var(--btn-danger-border)}.btn-danger:hover:not(:disabled){border-color:var(--btn-danger-hover-border);color:var(--btn-danger-hover-text)}.btn-answered{background:transparent;color:var(--badge-green-text);border:1.5px solid var(--badge-green-text)}.btn-answered:hover:not(:disabled){background:var(--badge-green-bg)}.btn-answered-active{background:var(--badge-green-text);color:var(--btn-primary-text);border:1.5px solid var(--badge-green-text)}.btn-answered-active:hover:not(:disabled){opacity:.9}.btn-outline{background:transparent;color:var(--btn-outline-text);border:1.5px solid var(--btn-outline-border)}.btn-outline:hover:not(:disabled){border-color:var(--btn-outline-hover-border);color:var(--btn-outline-hover-text)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text-primary)}.btn-sm{padding:5px 12px;font-size:.88rem}.btn-lg{padding:11px 24px;font-size:1.1rem}.btn-full{width:100%}.btn-icon{padding:8px;background:transparent;border:none;color:var(--text-secondary);border-radius:var(--radius-sm)}.btn-icon:hover{background:var(--bg);color:var(--text-primary)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.963rem;font-weight:500;color:var(--text-primary)}.form-input{width:100%;padding:10px 14px;border:1.5px solid var(--border-medium);border-radius:var(--radius-sm);font-size:.99rem;background:var(--surface);color:var(--text-primary);transition:border-color .15s,box-shadow .15s;outline:none}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-input.error{border-color:var(--danger)}.form-input:disabled{background:var(--bg);color:var(--text-muted)}.form-input-row{display:flex;gap:8px}.form-input-row .form-input{flex:1}.form-error{font-size:.88rem;color:var(--danger)}.form-hint{font-size:.88rem;color:var(--text-muted)}.form-success{font-size:.88rem;color:var(--success)}.card{background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.card-body{padding:24px}.auth-wrapper{min-height:calc(100vh - var(--header-height));display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--auth-gradient)}.profile-image-section{display:flex;flex-direction:column;align-items:center;margin-bottom:28px}.profile-image-wrapper{position:relative;width:96px;height:96px;border-radius:50%;cursor:pointer;overflow:hidden;border:2px solid var(--border, #e5e7eb);transition:border-color .2s}.profile-image-wrapper:hover{border-color:var(--color-primary, #6366f1)}.profile-image{width:100%;height:100%;object-fit:cover;display:block}.profile-image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;color:var(--text-on-primary);font-size:.88rem;font-weight:600;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.profile-image-wrapper:hover .profile-image-overlay{opacity:1}.auth-card{width:100%;max-width:440px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:40px 36px}.auth-title{font-size:1.6rem;font-weight:700;color:var(--text-primary);margin-bottom:6px}.auth-subtitle{font-size:.99rem;color:var(--text-secondary);margin-bottom:28px}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-divider{display:flex;align-items:center;gap:12px;margin:4px 0;color:var(--text-muted);font-size:.88rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-strong)}.auth-footer{text-align:center;margin-top:20px;font-size:.963rem;color:var(--text-secondary)}.auth-footer a,.auth-link{color:var(--primary);font-weight:500;cursor:pointer}.auth-link:hover{text-decoration:underline}.social-divider{display:flex;align-items:center;gap:12px;margin:20px 0 16px;color:var(--text-secondary);font-size:.88rem}.social-divider:before,.social-divider:after{content:"";flex:1;height:1px;background:var(--border-strong)}.social-login-btns{display:flex;flex-direction:column;gap:10px;margin-bottom:8px}.btn-social{display:flex;align-items:center;justify-content:center;gap:10px;font-weight:500;border-radius:var(--radius);text-decoration:none;transition:filter .15s,box-shadow .15s}.btn-social:hover{filter:brightness(.95);box-shadow:var(--shadow-sm)}.btn-google{background:var(--surface);color:var(--text-primary);border:1.5px solid var(--border-strong)}.btn-google:hover{background:var(--surface-hover)}.btn-naver{background:#03c75a;color:var(--text-on-primary);border:1.5px solid #02b350}.btn-naver:hover{background:#02b350}.naver-n{font-weight:800;font-size:1.15rem;line-height:1}.btn-kakao{background:#fee500;color:#3c1e1e;border:1.5px solid #e6ce00}.btn-kakao:hover{background:#fada00}.refresh-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:8px 16px;min-width:100px;background:var(--surface);border:1px solid var(--border-medium);border-radius:var(--radius);cursor:pointer;font-size:.88rem;font-weight:500;color:var(--text-secondary);transition:background .15s,border-color .15s,color .15s}.refresh-btn:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-strong);color:var(--text-primary)}.refresh-btn:active:not(:disabled){transform:scale(.97)}.refresh-btn:disabled{cursor:not-allowed}.refresh-btn-dots{display:flex;align-items:center;gap:4px;height:15px}.refresh-btn-dot{width:5px;height:5px;border-radius:50%;background:currentColor}@keyframes refreshDot1{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}@keyframes refreshDot2{0%,80%,to{opacity:.2;transform:scale(.8)}60%{opacity:1;transform:scale(1)}}@keyframes refreshDot3{0%,80%,to{opacity:.2;transform:scale(.8)}80%{opacity:1;transform:scale(1)}}.refresh-btn-dot:nth-child(1){animation:refreshDot1 1s infinite}.refresh-btn-dot:nth-child(2){animation:refreshDot2 1s infinite}.refresh-btn-dot:nth-child(3){animation:refreshDot3 1s infinite}.board-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}.board-search-form{display:flex;gap:8px;flex:1;min-width:0;max-width:500px}.board-search-select{padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.963rem;background:var(--surface);color:var(--text-primary);outline:none;cursor:pointer;min-width:90px}.board-search-select:focus{border-color:var(--primary)}.board-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--surface)}.board-item{padding:16px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;display:grid;grid-template-columns:1fr auto;gap:8px 16px;align-items:center}.board-item:last-child{border-bottom:none}.board-item:hover{background:var(--bg)}.board-item-title{font-size:1.045rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.board-item-meta{display:flex;align-items:center;gap:12px;font-size:.88rem;color:var(--text-muted);flex-wrap:wrap}.author-avatar{width:22px;height:22px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border, #e5e7eb);vertical-align:middle}.board-item-author{display:inline-flex;align-items:center;gap:5px;color:var(--text-secondary);font-weight:500}.board-item-stats{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--text-muted);white-space:nowrap}.stat-item{display:flex;align-items:center;gap:3px}.board-list-empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.board-item-thumbnail{width:56px;height:56px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border);flex-shrink:0}.column-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.column-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:box-shadow .15s,transform .15s;display:flex;flex-direction:column}.column-card:hover{box-shadow:0 4px 16px #0000002e;transform:translateY(-2px)}.column-card-thumbnail{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:var(--bg);flex-shrink:0}.column-card-thumbnail img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.column-card:hover .column-card-thumbnail img{transform:scale(1.03)}.column-card-thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:2.5rem;background:var(--bg)}.column-card-body{padding:14px 16px;flex:1;display:flex;flex-direction:column;gap:8px}.column-card-title{font-size:1.045rem;font-weight:600;color:var(--text-primary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.45}.column-card-meta{display:flex;align-items:center;gap:8px;font-size:.858rem;color:var(--text-muted);flex-wrap:wrap}.column-card-tags{display:flex;gap:4px;flex-wrap:wrap}.column-card-stats{display:flex;align-items:center;gap:10px;font-size:.858rem;color:var(--text-muted);margin-top:auto}.board-detail-header{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border)}.board-detail-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.4;margin-bottom:12px}.board-detail-meta{display:flex;align-items:center;gap:16px;font-size:.935rem;color:var(--text-secondary);flex-wrap:wrap}.board-detail-actions{display:flex;align-items:center;gap:8px;margin-top:12px}.board-detail-thumbnail{margin-bottom:24px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);background:var(--bg);text-align:center}.board-detail-thumbnail-img{max-width:100%;max-height:400px;object-fit:contain;display:block;margin:0 auto}.thumbnail-upload{display:flex;align-items:flex-start;gap:12px}.thumbnail-upload-btn{padding:0 20px;height:80px;border:2px dashed var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-secondary);font-size:.963rem;cursor:pointer;transition:border-color .15s,color .15s}.thumbnail-upload-btn:hover{border-color:var(--primary);color:var(--primary)}.thumbnail-upload-btn.error{border-color:var(--error, #ef4444);color:var(--error, #ef4444)}.thumbnail-preview{position:relative;display:inline-flex;gap:8px;align-items:flex-start}.thumbnail-preview-img{width:120px;height:80px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border)}.thumbnail-remove-btn{position:absolute;top:-8px;right:-8px;width:20px;height:20px;border-radius:50%;border:none;background:var(--danger);color:var(--text-on-primary);font-size:.77rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.thumbnail-change-btn{align-self:flex-end;padding:4px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:.88rem;cursor:pointer}.thumbnail-change-btn:hover{border-color:var(--primary);color:var(--primary)}.editor-uploading .editor-content{opacity:.6;pointer-events:none}.editor-uploading:after{content:"이미지 업로드 중...";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--overlay-light);font-size:.963rem;color:var(--text-secondary);pointer-events:none}.editor-wrapper{position:relative}.board-content{min-height:200px;margin-bottom:32px;line-height:1.8}.board-content h1{font-size:1.6rem;font-weight:700;margin:1em 0 .5em}.board-content h2{font-size:1.35rem;font-weight:700;margin:1em 0 .5em}.board-content h3{font-size:1.15rem;font-weight:700;margin:1em 0 .5em}.board-content p{margin-bottom:.75em}.board-content ul,.board-content ol{padding-left:1.5em;margin-bottom:.75em}.board-content blockquote{border-left:4px solid var(--primary);padding-left:1em;color:var(--text-secondary);margin:1em 0}.board-content code{background:var(--bg);padding:2px 6px;border-radius:4px;font-size:.875em;font-family:Fira Code,Consolas,monospace}.board-content pre{background:var(--code-bg);color:var(--code-text);padding:16px;border-radius:var(--radius-sm);overflow-x:auto;margin:1em 0}.board-content pre code{background:none;padding:0;color:inherit}.board-content img{max-width:100%;border-radius:var(--radius-sm)}.board-content a{color:var(--primary);text-decoration:underline}.board-content strong{font-weight:700}.board-content em{font-style:italic}.board-content u{text-decoration:underline}.board-content s{text-decoration:line-through}.board-content mark{background:var(--badge-amber-bg);padding:1px 2px;border-radius:2px}.board-content hr{border:none;border-top:1px solid var(--border);margin:1.5em 0}.recommend-section{display:flex;justify-content:center;margin:24px 0}.recommend-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 32px;border:2px solid var(--border);border-radius:var(--radius-md);background:var(--surface);font-size:.963rem;color:var(--text-secondary);cursor:pointer;transition:all .15s}.recommend-btn:hover,.recommend-btn.active{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.recommend-btn-icon{font-size:1.4rem}.recommend-btn-count{font-weight:700;font-size:1.21rem}.recommend-count-only{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 32px;border:2px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text-secondary)}.attachments-section{margin:20px 0;padding:16px 20px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border)}.attachments-title{font-size:.963rem;font-weight:600;color:var(--text-secondary);margin-bottom:10px}.attachment-list{display:flex;flex-direction:column;gap:6px}.attachment-item{display:flex;align-items:center;gap:8px;font-size:.963rem}.attachment-link{color:var(--primary);cursor:pointer;display:flex;align-items:center;gap:6px;word-break:break-all}.attachment-link:hover{text-decoration:underline}.attachment-size{color:var(--text-muted);font-size:.88rem;white-space:nowrap}.file-upload-area{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:24px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:var(--surface)}.file-upload-area:hover,.file-upload-area.drag-over{border-color:var(--primary);background:var(--primary-light)}.file-upload-text{font-size:.963rem;color:var(--text-muted);margin-top:8px}.file-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}.file-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg);border-radius:var(--radius-sm);font-size:.963rem}.file-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:8px}.file-item-size{color:var(--text-muted);font-size:.88rem;margin-right:8px;white-space:nowrap}.editor-wrapper{border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--surface);transition:border-color .15s}.editor-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.editor-toolbar{display:flex;flex-wrap:wrap;gap:2px;padding:8px 10px;background:var(--bg);border-bottom:1px solid var(--border)}.toolbar-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:4px;border:none;background:transparent;color:var(--text-secondary);font-size:.963rem;font-weight:500;cursor:pointer;transition:background .1s,color .1s}.toolbar-btn:hover{background:var(--border);color:var(--text-primary)}.toolbar-btn.active{background:var(--primary);color:var(--text-on-primary)}.toolbar-separator{width:1px;height:24px;background:var(--border);margin:3px 4px}.toolbar-select{height:30px;padding:0 8px;border:1px solid var(--border);border-radius:4px;font-size:.88rem;background:var(--surface);color:var(--text-primary);cursor:pointer;outline:none}.toolbar-select:focus{border-color:var(--primary)}.toolbar-color{width:28px;height:28px;border-radius:4px;border:1px solid var(--border);padding:2px;cursor:pointer;background:var(--surface)}.editor-content{min-height:300px;padding:16px}.editor-content .ProseMirror{min-height:260px;outline:none;line-height:1.8}.editor-content .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--text-muted);pointer-events:none;float:left;height:0}.editor-content .ProseMirror h1{font-size:1.6rem;font-weight:700;margin:.8em 0 .4em}.editor-content .ProseMirror h2{font-size:1.35rem;font-weight:700;margin:.8em 0 .4em}.editor-content .ProseMirror h3{font-size:1.15rem;font-weight:700;margin:.8em 0 .4em}.editor-content .ProseMirror p{margin-bottom:.6em}.editor-content .ProseMirror ul,.editor-content .ProseMirror ol{padding-left:1.5em;margin-bottom:.6em}.editor-content .ProseMirror blockquote{border-left:4px solid var(--primary);padding-left:1em;color:var(--text-secondary);margin:.8em 0}.editor-content .ProseMirror code{background:var(--bg);padding:2px 6px;border-radius:4px;font-size:.875em}.editor-content .ProseMirror pre{background:var(--code-bg);color:var(--code-text);padding:16px;border-radius:6px;overflow-x:auto;margin:.8em 0}.editor-content .ProseMirror pre code{background:none;padding:0;color:inherit}.editor-content .ProseMirror img{max-width:100%;border-radius:6px}.editor-content .ProseMirror a{color:var(--primary);text-decoration:underline}.editor-content .ProseMirror mark{background:var(--badge-amber-bg);padding:1px 2px;border-radius:2px}.editor-content .ProseMirror hr{border:none;border-top:1px solid var(--border);margin:1.2em 0}.comments-section{margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}.comments-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:20px}.comment-list{display:flex;flex-direction:column;gap:0}.comment-item{padding:16px 0;border-bottom:1px solid var(--border)}.comment-item:last-child{border-bottom:none}.comment-item.reply{padding-left:28px;border-bottom:none;position:relative}.comment-item.reply:before{content:"";position:absolute;left:10px;top:20px;width:12px;height:16px;border-left:2px solid var(--border);border-bottom:2px solid var(--border);border-bottom-left-radius:4px}.comment-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}.comment-author{font-weight:600;font-size:.963rem;color:var(--text-primary)}.comment-date{font-size:.88rem;color:var(--text-muted)}.comment-content{font-size:.99rem;color:var(--text-primary);line-height:1.6;white-space:pre-wrap;word-break:break-word}.comment-deleted{font-size:.963rem;color:var(--text-muted);font-style:italic}.comment-actions{display:flex;gap:6px;margin-top:8px}.comment-form{margin-top:20px;display:flex;flex-direction:column;gap:8px}.comment-textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.99rem;resize:vertical;min-height:90px;outline:none;font-family:inherit;background:var(--surface);transition:border-color .15s}.comment-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.comment-form-actions{display:flex;justify-content:flex-end;gap:8px}.reply-form{margin-top:12px;padding:12px;background:var(--bg);border-radius:var(--radius-sm)}.pagination{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:24px}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);font-size:.963rem;color:var(--text-secondary);cursor:pointer;transition:all .1s}.pagination-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.pagination-btn.active{background:var(--primary);border-color:var(--primary);color:var(--text-on-primary);font-weight:600}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.spinner-wrapper{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#fff9;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fadeIn .15s ease}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:28px 28px 24px;max-width:420px;width:100%;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-title{font-size:1.21rem;font-weight:700;margin-bottom:12px}.modal-body{font-size:.99rem;color:var(--text-secondary);margin-bottom:24px}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:12px;flex-wrap:wrap}.page-title{font-size:1.5rem;font-weight:700}.page-back{display:flex;align-items:center;gap:6px;font-size:.963rem;color:var(--text-secondary);cursor:pointer;margin-bottom:16px}.page-back:hover{color:var(--primary)}.board-form{display:flex;flex-direction:column;gap:20px}.board-form-actions{display:flex;gap:10px;justify-content:flex-end;padding-top:8px}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--code-bg);color:var(--text-on-primary);padding:10px 20px;border-radius:8px;font-size:.963rem;z-index:2000;animation:slideUp .2s ease;white-space:nowrap}.toast.success{background:var(--success)}.toast.error{background:var(--danger)}@media (max-width: 768px){:root{font-size:15px}.header-menu{display:none}.header-hamburger{display:flex}.auth-card{padding:28px 20px}.layout-main{padding:20px 12px}.board-toolbar{flex-direction:column;align-items:stretch}.board-search-form{max-width:100%}.board-item{grid-template-columns:1fr;gap:4px}.board-item-stats{margin-top:4px}.column-card-grid{grid-template-columns:repeat(2,1fr);gap:12px}.board-detail-meta{gap:10px;font-size:.88rem}.editor-toolbar{gap:1px;padding:6px 8px}.toolbar-btn{width:26px;height:26px;font-size:.88rem}.comment-item.reply{padding-left:20px}.modal{padding:24px 20px 20px}.page-header{flex-direction:column;align-items:flex-start}.board-form-actions{flex-direction:column}.board-form-actions .btn{width:100%}}@media (max-width: 480px){.header-inner{padding:0 12px}.auth-card{padding:24px 16px}.board-detail-title{font-size:1.2rem}.column-card-grid{grid-template-columns:1fr;gap:12px}}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-sm);font-size:.792rem;font-weight:600;white-space:nowrap;line-height:1.6}.badge-category{background:#e0f2fe;color:#0369a1}.badge-answered{background:#dcfce7;color:#15803d}.badge-unanswered{background:#f3f4f6;color:#6b7280}.badge-language{background:#fef3c7;color:#b45309}.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;background:var(--primary-light);color:var(--primary);border-radius:12px;font-size:.825rem;font-weight:500;white-space:nowrap;line-height:1.6}.tag-chip.removable{cursor:pointer;-webkit-user-select:none;user-select:none}.tag-chip.removable:hover{background:#ddd6fe}.board-detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.tag-selector{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;background:var(--surface);position:relative;transition:border-color .15s,box-shadow .15s}.tag-selector:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.tag-selector-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.tag-selector-input{border:none;outline:none;font-size:.99rem;background:transparent;min-width:120px;font-family:inherit;color:var(--text-primary);padding:2px 0}.tag-suggestions{position:absolute;left:0;right:0;top:calc(100% + 4px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);list-style:none;z-index:50;max-height:200px;overflow-y:auto}.tag-suggestion-item{padding:8px 14px;cursor:pointer;font-size:.963rem;color:var(--text-primary);transition:background .1s}.tag-suggestion-item:hover{background:var(--bg)}.board-filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center;padding-bottom:12px}.board-filter-select{padding:6px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.88rem;background:var(--surface);color:var(--text-secondary);outline:none;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.board-filter-select:focus{border-color:var(--primary)}.board-filter-active{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.expert-profile-card{display:flex;flex-direction:column;gap:14px}.expert-profile-row{display:flex;gap:12px;font-size:.99rem;color:var(--text-primary)}.expert-profile-label{font-weight:600;color:var(--text-secondary);min-width:96px;flex-shrink:0}.expert-verified-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;background:#dcfce7;color:#15803d;border-radius:12px;font-size:.825rem;font-weight:600}.expert-domains{display:flex;flex-wrap:wrap;gap:6px}@media (max-width: 768px){.board-filters{gap:6px}.board-filter-select{font-size:.825rem;padding:5px 8px}}.reg-bot-trigger{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;align-items:center;gap:9px;padding:10px 17px;background:var(--primary);color:var(--text-on-primary);border:none;border-radius:999px;box-shadow:0 4px 16px #4f46e566;font-size:.946rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.reg-bot-trigger:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4f46e580}.reg-bot-trigger-icon{font-size:1.21rem}.reg-bot-trigger-text{white-space:nowrap}.reg-bot-panel{position:fixed;bottom:97px;right:24px;z-index:1001;width:418px;max-width:calc(100vw - 32px);height:572px;max-height:calc(100vh - 120px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 8px 40px #00000042;display:flex;flex-direction:column;overflow:hidden}.reg-bot-header{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;background:var(--primary);color:var(--text-on-primary);flex-shrink:0}.reg-bot-header-left{display:flex;align-items:center;gap:6px}.reg-bot-header-title{font-size:1.089rem;font-weight:700}.reg-bot-header-actions{display:flex;gap:7px}.reg-bot-icon-btn{background:#fff3;border:none;color:var(--text-on-primary);width:31px;height:31px;border-radius:50%;cursor:pointer;font-size:1.089rem;display:flex;align-items:center;justify-content:center}.reg-bot-icon-btn:hover{background:#ffffff59}.reg-bot-messages{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:11px}.reg-bot-bubble-wrap{display:flex;align-items:flex-end;gap:9px}.reg-bot-bubble-wrap.user{flex-direction:row-reverse}.reg-bot-bubble-wrap.info{justify-content:center}.reg-bot-avatar{width:31px;height:31px;border-radius:50%;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:1.089rem;flex-shrink:0}.reg-bot-bubble{max-width:78%;padding:9px 13px;border-radius:var(--radius-md);font-size:1.034rem;line-height:1.55;white-space:pre-wrap}.reg-bot-bubble.bot{background:var(--bg);color:var(--text-primary);border-bottom-left-radius:4px}.reg-bot-bubble.user{background:var(--primary);color:var(--text-on-primary);border-bottom-right-radius:4px}.reg-bot-bubble.info{background:transparent;color:var(--text-muted);font-size:.946rem;font-style:italic;max-width:100%;text-align:center;padding:2px 0}.reg-bot-input-area{border-top:1px solid var(--border);padding:13px 15px;background:var(--surface);flex-shrink:0;max-height:264px;overflow-y:auto}.reg-bot-chips{display:flex;flex-direction:column;gap:9px}.reg-bot-option-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:11px 15px;background:var(--primary-light);border:1.5px solid var(--primary);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:background .1s}.reg-bot-option-btn:hover:not(:disabled){background:#e0e7ff}.reg-bot-option-btn:disabled{opacity:.45;cursor:not-allowed;background:var(--bg);border-color:var(--border)}.reg-bot-option-btn:disabled .reg-bot-option-label{color:var(--text-secondary)}.reg-bot-option-btn.compact{flex-direction:row;flex:1;justify-content:center}.reg-bot-option-btn.secondary{background:var(--bg);border-color:var(--border);color:var(--text-secondary)}.reg-bot-option-label{font-size:1.056rem;font-weight:700;color:var(--primary)}.reg-bot-option-desc{font-size:.913rem;color:var(--text-secondary)}.reg-bot-multi-select{display:flex;flex-direction:column;gap:9px}.reg-bot-chip-group{display:flex;flex-wrap:wrap;gap:7px}.reg-bot-chip{padding:6px 13px;border-radius:999px;border:1.5px solid var(--border);background:var(--surface);font-size:.968rem;cursor:pointer;transition:all .1s}.reg-bot-chip:hover{border-color:var(--primary);color:var(--primary)}.reg-bot-chip.selected{background:var(--primary);border-color:var(--primary);color:var(--text-on-primary)}.reg-bot-btn-row{display:flex;gap:9px}.reg-bot-next-btn{padding:9px 18px;background:var(--primary);color:var(--text-on-primary);border:none;border-radius:var(--radius-sm);font-size:1.034rem;font-weight:600;cursor:pointer;white-space:nowrap}.reg-bot-next-btn:hover{background:var(--primary-hover)}.reg-bot-next-btn:disabled{opacity:.5;cursor:default}.reg-bot-skip-btn{padding:9px 13px;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.99rem;cursor:pointer}.reg-bot-skip-btn:hover{border-color:var(--primary);color:var(--primary)}.reg-bot-check-btn{padding:9px 13px;background:var(--bg);color:var(--primary);border:1.5px solid var(--primary);border-radius:var(--radius-sm);font-size:.99rem;font-weight:600;cursor:pointer;white-space:nowrap}.reg-bot-check-btn:disabled{opacity:.5;cursor:default}.reg-bot-input-row{display:flex;gap:7px;align-items:center}.reg-bot-multi-input{display:flex;flex-direction:column;gap:9px}.reg-bot-text-input{flex:1;padding:9px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1.034rem;outline:none;min-width:0}.reg-bot-text-input:focus{border-color:var(--primary)}.reg-bot-textarea{width:100%;padding:9px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1.034rem;resize:vertical;outline:none}.reg-bot-textarea:focus{border-color:var(--primary)}.reg-bot-select{flex:1;padding:9px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1.034rem;background:var(--surface);outline:none;cursor:pointer}.reg-bot-select:focus{border-color:var(--primary)}.reg-bot-check-label{display:flex;align-items:center;gap:7px;font-size:1.034rem;cursor:pointer}.reg-bot-file-label{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1.5px dashed var(--border);border-radius:var(--radius-sm);font-size:.968rem;color:var(--primary);cursor:pointer;transition:border-color .15s,background .15s}.reg-bot-file-label:hover{border-color:var(--primary);background:var(--primary-light)}.reg-bot-file-label.selected{border-color:var(--primary);background:var(--primary-light);color:var(--text-primary);border-style:solid}.reg-bot-file-label input[type=file]{display:none}.reg-bot-file-icon{font-size:1.1rem;flex-shrink:0}.reg-bot-file-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reg-bot-masking-notice{padding:9px 13px;background:#fff7ed;border:1px solid #fb923c;border-radius:var(--radius-sm);font-size:.968rem}.reg-bot-masking-notice strong{display:block;margin-bottom:4px;color:#c2410c}.reg-bot-masking-notice p{color:#7c2d12;line-height:1.4}.reg-bot-company-list{display:flex;flex-direction:column;gap:4px;max-height:154px;overflow-y:auto}.reg-bot-company-item{display:flex;flex-direction:column;gap:2px;padding:9px 11px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:left}.reg-bot-company-item:hover{border-color:var(--primary);background:var(--primary-light)}.reg-bot-company-name{font-size:1.056rem;font-weight:600;color:var(--text-primary)}.reg-bot-company-meta{font-size:.946rem;color:var(--text-secondary)}.reg-bot-loading{text-align:center;color:var(--text-muted);font-size:1.034rem;padding:13px 0}.reg-bot-error{color:var(--danger);font-size:.968rem;margin-top:2px}.reg-bot-done-actions{display:flex;flex-direction:column;gap:9px}@media (max-width: 480px){.reg-bot-panel{right:8px;left:8px;width:auto;bottom:88px}.reg-bot-trigger{right:12px;bottom:16px;padding:11px 15px}.reg-bot-trigger-text{display:none}}.intro-drop-over{border-color:var(--primary)!important;background:var(--primary-light, #eef2ff)!important}.product-list-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.product-list-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.product-list-subtitle{font-size:.963rem;color:var(--text-secondary)}.product-filter-bar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:24px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md)}.product-filter-select{max-width:200px;width:auto;flex:1 1 140px}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.product-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px;display:flex;flex-direction:column;gap:12px;transition:box-shadow .15s}.product-card:hover{box-shadow:var(--shadow-md)}.product-card--inactive{opacity:.65;background:var(--bg-alt)}.product-card-header{display:flex;flex-direction:column;gap:8px}.product-card-name-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.product-card-name{font-size:1.155rem;font-weight:700;color:var(--text-primary);word-break:break-word}.product-toggle-row{display:flex;align-items:center;gap:8px;align-self:flex-end}.product-toggle-label{font-size:.88rem;color:var(--text-secondary)}.product-toggle{position:relative;width:40px;height:22px;background:var(--border);border:none;border-radius:999px;cursor:pointer;transition:background .2s;flex-shrink:0;padding:0}.product-toggle--on{background:var(--primary)}.product-toggle:disabled{cursor:not-allowed;opacity:.5}.product-toggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:left .2s;display:block}.product-toggle--on .product-toggle-thumb{left:calc(100% - 19px)}.product-card-tags{display:flex;flex-wrap:wrap;gap:6px}.product-card-meta{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.product-card-price{font-size:1.15rem;font-weight:700;color:var(--primary)}.product-card-days{font-size:.88rem;color:var(--text-secondary);white-space:nowrap}.product-card-desc{font-size:.963rem;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-card-actions{display:flex;gap:8px;margin-top:auto;padding-top:4px}.product-empty-state{display:flex;flex-direction:column;align-items:center;gap:16px;padding:80px 20px;text-align:center}.product-empty-icon{font-size:3rem}.product-empty-text{font-size:1.1rem;color:var(--text-secondary);max-width:320px}.product-form-wrapper{max-width:600px;margin:0 auto}.product-form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:36px 32px}.product-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}.product-tag-selector{display:flex;flex-wrap:wrap;gap:8px;padding:12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}.product-tag-btn{padding:4px 12px;border-radius:999px;font-size:.935rem;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--text-secondary);transition:all .15s}.product-tag-btn:hover{border-color:var(--primary);color:var(--primary)}.product-tag-btn--selected{border-color:var(--primary);background:var(--primary);color:var(--text-on-primary)}@media (max-width: 600px){.product-list-header{flex-direction:column}.product-filter-bar{gap:8px}.product-filter-select{max-width:100%;flex:1 1 100%}.product-form-card{padding:24px 16px}}.sr-form-wrapper{max-width:620px;margin:0 auto}.sr-form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:32px 28px}.sr-form-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:24px}.sr-confirm-summary{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 20px;margin-bottom:20px;display:flex;flex-direction:column;gap:10px}.sr-confirm-row{display:flex;gap:12px;font-size:.99rem}.sr-confirm-label{min-width:72px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.sr-status-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:24px}.sr-status-title{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.sr-status-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.858rem;font-weight:600}.sr-steps{display:flex;align-items:center;margin-bottom:28px;overflow-x:auto;padding-bottom:4px}.sr-step{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.sr-step-dot{width:28px;height:28px;border-radius:50%;background:var(--border);color:var(--text-muted);font-size:.88rem;font-weight:700;display:flex;align-items:center;justify-content:center}.sr-step--active .sr-step-dot{background:var(--primary);color:var(--text-on-primary)}.sr-step--done .sr-step-dot{background:var(--success);color:var(--text-on-primary)}.sr-step-label{font-size:.792rem;color:var(--text-muted);white-space:nowrap;text-align:center}.sr-step--active .sr-step-label{color:var(--primary);font-weight:600}.sr-step--done .sr-step-label{color:var(--success)}.sr-step-line{flex:1;height:2px;background:var(--border);min-width:16px;margin-bottom:18px}.sr-step-line--done{background:var(--success)}.sr-info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;margin-bottom:20px;display:flex;flex-direction:column;gap:10px}.sr-info-row{display:flex;gap:12px;font-size:.99rem;align-items:center}.sr-info-label{min-width:72px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.sr-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;margin-bottom:16px}.sr-section-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:12px}.sr-section-text{font-size:.99rem;color:var(--text-secondary);margin-bottom:8px}.sr-countdown{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#fff7ed;border:1px solid #fb923c;border-radius:var(--radius-sm);font-size:.963rem;color:#c2410c;margin-top:8px}.sr-product-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:6px}.sr-product-card--selectable{cursor:pointer;transition:border-color .15s,background .15s}.sr-product-card--selectable:hover,.sr-product-card--selected{border-color:var(--primary);background:var(--primary-light)}.sr-product-name{font-weight:700;font-size:1.1rem;color:var(--text-primary)}.sr-product-price{font-size:1.21rem;font-weight:700;color:var(--primary)}.sr-product-desc{font-size:.963rem;color:var(--text-secondary);line-height:1.5}.sr-product-meta{font-size:.88rem;color:var(--text-secondary)}.sr-payment-amount{font-size:1.15rem;margin-bottom:16px;color:var(--text-primary)}.sr-complete-banner{padding:12px 16px;background:#ecfdf5;border:1px solid #6ee7b7;border-radius:var(--radius-sm);color:#065f46;font-size:.99rem;font-weight:500}.sr-complete-banner--success{background:#f0fdf4;border-color:#4ade80}.sr-cancelled-banner{padding:12px 16px;background:#fef2f2;border:1px solid #fca5a5;border-radius:var(--radius-sm);color:#991b1b;font-size:.99rem;font-weight:500;margin-bottom:12px}.sr-rejection-reason{padding:12px 16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:6px;font-size:.963rem}.sr-request-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 20px;cursor:pointer;transition:box-shadow .15s;display:flex;flex-direction:column;gap:8px}.sr-request-card:hover{box-shadow:var(--shadow-md)}.sr-request-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.sr-request-company{font-weight:700;font-size:1.1rem;color:var(--text-primary)}.sr-request-desc{font-size:.963rem;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.sr-request-meta{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--text-muted);flex-wrap:wrap}.sr-tab-bar{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}.sr-tab{padding:6px 14px;border-radius:var(--radius-sm);font-size:.935rem;font-weight:500;background:transparent;border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:5px}.sr-tab:hover{border-color:var(--primary);color:var(--primary)}.sr-tab--active{background:var(--primary);border-color:var(--primary);color:var(--text-on-primary)}.sr-tab-badge{background:#ef4444;color:var(--text-on-primary);border-radius:999px;padding:1px 6px;font-size:.792rem;font-weight:700}.sr-expert-card{padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;transition:border-color .15s}.sr-expert-card:hover{border-color:var(--primary)}.sr-expert-card--selected{border-color:var(--primary);background:var(--primary-light)}@media (max-width: 600px){.sr-form-card{padding:20px 16px}.sr-steps{gap:2px}.sr-step-label{font-size:.715rem}}.posting-dday{display:inline-block;font-size:.825rem;font-weight:700;padding:2px 7px;border-radius:4px;background:var(--bg);border:1px solid var(--border);color:var(--text-muted)}.posting-dday--urgent{background:#fef2f2;border-color:#fca5a5;color:#dc2626}.posting-dday--done{background:var(--bg);border-color:var(--border);color:var(--text-muted);text-decoration:line-through}.posting-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 20px;cursor:pointer;transition:box-shadow .15s,border-color .15s;display:flex;flex-direction:column;gap:8px}.posting-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-light)}.posting-bid-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;transition:border-color .15s}.posting-bid-card:hover{border-color:var(--primary)}.posting-bid-card--selected{border-color:var(--primary);background:var(--primary-light)}.posting-filter-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px;align-items:center}.sr-expert-card.selected{border-color:var(--primary);background:var(--primary-light, rgba(59,130,246,.06))}.notif-bell-wrapper{position:relative;display:flex;align-items:center}.notif-bell-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;border-radius:var(--radius-sm);font-size:1.15rem;cursor:pointer;transition:background .15s;flex-shrink:0}.notif-bell-btn:hover{background:var(--bg)}.notif-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;background:var(--danger);color:var(--text-on-primary);font-size:.748rem;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;line-height:1;pointer-events:none}.notif-panel{position:absolute;top:calc(100% + 8px);right:-8px;width:380px;max-height:520px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 24px #0003;z-index:200;display:flex;flex-direction:column;overflow:hidden}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.notif-panel-title{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.notif-tabs{display:flex;gap:2px;padding:8px 12px 0;flex-shrink:0;overflow-x:auto;scrollbar-width:none}.notif-tabs::-webkit-scrollbar{display:none}.notif-tab{padding:5px 12px;font-size:.88rem;font-weight:500;border:none;background:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:color .15s,background .15s}.notif-tab:hover{background:var(--bg);color:var(--text-primary)}.notif-tab.active{background:var(--primary-light);color:var(--primary);font-weight:600}.notif-list{flex:1;overflow-y:auto;padding:8px 0}.notif-item{display:flex;align-items:flex-start;gap:10px;width:100%;padding:12px 16px;background:none;border:none;border-bottom:1px solid var(--border);text-align:left;cursor:pointer;transition:background .12s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg)}.notif-item.unread{background:var(--primary-light)}.notif-item.unread:hover{background:var(--surface-hover)}.notif-unread-dot{width:7px;height:7px;border-radius:50%;background:var(--primary);flex-shrink:0;margin-top:6px}.notif-item-body{flex:1;min-width:0}.notif-item-title{font-size:.957rem;font-weight:600;color:var(--text-primary);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-item-content{font-size:.88rem;color:var(--text-secondary);margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.45}.notif-item-meta{display:flex;align-items:center;gap:8px;font-size:.803rem;color:var(--text-muted)}.notif-category-tag{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:.77rem;font-weight:500;color:var(--text-secondary)}.notif-empty{display:flex;align-items:center;justify-content:center;padding:40px 0;color:var(--text-muted);font-size:.968rem}.notif-load-more{width:100%;padding:12px;border:none;background:none;font-size:.935rem;color:var(--primary);cursor:pointer;transition:background .12s}.notif-load-more:hover:not(:disabled){background:var(--primary-light)}.notif-load-more:disabled{color:var(--text-muted);cursor:default}.toast-container{position:fixed;top:calc(var(--header-height) + 12px);right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast-item{display:flex;align-items:flex-start;gap:10px;width:320px;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--primary);border-radius:var(--radius-md);box-shadow:0 4px 16px #0003;padding:12px 14px;pointer-events:all;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast-body{flex:1;min-width:0}.toast-title{font-size:.935rem;font-weight:600;color:var(--text-primary);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast-content{font-size:.858rem;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.45}.toast-close{background:none;border:none;color:var(--text-muted);font-size:.88rem;cursor:pointer;padding:2px 4px;flex-shrink:0;line-height:1;border-radius:4px;transition:color .12s,background .12s}.toast-close:hover{color:var(--text-primary);background:var(--bg)}.notif-toggle{position:relative;display:inline-flex;align-items:center;width:44px;height:24px;flex-shrink:0;cursor:pointer}.notif-toggle input{opacity:0;width:0;height:0;position:absolute}.notif-toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:12px;transition:background .2s}.notif-toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 4px #00000038}.notif-toggle input:checked+.notif-toggle-slider{background:var(--primary)}.notif-toggle input:checked+.notif-toggle-slider:before{transform:translate(20px)}@media (max-width: 480px){.notif-panel{width:calc(100vw - 16px);right:-16px}.toast-container{right:8px}.toast-item{width:calc(100vw - 16px)}}.home-page{min-height:100%}.home-hero{min-height:calc(100vh - var(--header-height));padding:0 24px;background:linear-gradient(160deg,var(--primary-light) 0%,var(--bg) 55%,var(--surface) 100%);border-bottom:1px solid var(--border);display:flex;flex-direction:column;align-items:center;position:relative;overflow:hidden}.home-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,var(--primary-light) 0%,transparent 70%);pointer-events:none;opacity:.6}.home-hero-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;padding:4px 12px;border-radius:20px;font-weight:600;background:#4f46e51a;color:var(--primary);border:1px solid rgba(79,70,229,.2);margin-bottom:14px;letter-spacing:.02em}.home-hero-title{font-size:34px;font-weight:700;line-height:1.2;margin-bottom:10px;color:var(--text-primary);text-align:center;letter-spacing:-.02em;white-space:nowrap}.home-hero-sub{font-size:15px;color:var(--text-muted);margin-bottom:28px;line-height:1.6;text-align:center}@keyframes homeScrollBounce{0%,to{transform:translateY(0) translate(-50%);opacity:.5}50%{transform:translateY(6px) translate(-50%);opacity:1}}.home-scroll-hint{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:4px;animation:homeScrollBounce 2s ease-in-out infinite;cursor:pointer}.home-scroll-hint svg{opacity:.4}.home-search-row{display:flex;gap:8px;margin-bottom:16px}.home-search-box{flex:1;background:#fff;border:.5px solid var(--border);border-radius:8px;padding:10px 14px;display:flex;align-items:center;gap:8px}.home-search-input{flex:1;border:none;outline:none;font-size:14px;color:var(--text-primary);background:transparent}.home-search-input::placeholder{color:var(--text-placeholder, #b4b2a9)}.home-category-chips{display:flex;gap:8px;flex-wrap:wrap}.home-chip{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;border:none;cursor:pointer;transition:opacity .15s}.home-chip:hover{opacity:.75}.chip-blue{background:#e6f1fb;color:#185fa5}.chip-green{background:#eaf3de;color:#3b6d11}.chip-amber{background:#faeeda;color:#854f0b}.chip-gray{background:var(--surface-raised, #f1efe8);color:var(--text-secondary, #5f5e5a);border:.5px solid var(--border)}.home-content{padding:0 0 32px}.home-section{padding:24px 24px 20px;border-bottom:1px solid var(--border)}.home-section:nth-of-type(odd){background:var(--bg-alt)}.home-section:nth-of-type(2n){background:var(--surface)}.home-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.home-section-label{display:inline-flex;align-items:center;font-size:17px;font-weight:700;color:var(--text-primary);padding-left:10px;border-left:4px solid var(--primary)}.home-more-link{font-size:13px;color:#185fa5;cursor:pointer;background:none;border:none;padding:0;text-decoration:none}.home-more-link:hover{text-decoration:underline}.home-divider{display:none}.home-empty{background:var(--surface-raised, #f1efe8);border-radius:8px;padding:16px;font-size:14px;color:var(--text-muted);text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}.home-service-list{display:flex;flex-direction:column;gap:8px}.home-service-card{border-left:3px solid #185fa5;border-radius:0 12px 12px 0;cursor:pointer;transition:box-shadow .2s,border-color .15s;padding:12px 14px;box-shadow:var(--shadow-sm)}.home-service-card:hover{border-color:#888780;box-shadow:var(--shadow-md)}.home-service-card-inner{display:flex;align-items:center;gap:12px}.home-service-logo{width:40px;height:40px;border-radius:8px;background:#e6f1fb;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:#185fa5;text-align:center;line-height:1.3;flex-shrink:0}.home-service-body{flex:1;min-width:0}.home-service-title-row{display:flex;align-items:center;gap:8px;margin-bottom:3px}.home-service-title{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-service-meta{font-size:13px;color:var(--text-muted)}.home-status-badge{display:inline-flex;align-items:center;font-size:12px;padding:2px 7px;border-radius:20px;font-weight:500;background:#e6f1fb;color:#185fa5;white-space:nowrap;flex-shrink:0}.home-two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.home-three-col{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.home-company-card{cursor:pointer;transition:box-shadow .2s,border-color .15s;padding:14px 16px;border-radius:12px;box-shadow:var(--shadow-sm)}.home-company-card:hover{border-color:#cbd5e1;box-shadow:var(--shadow-md)}.home-company-card-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}.home-company-logo{width:40px;height:40px;border-radius:8px;background:#e6f1fb;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:#185fa5;text-align:center;line-height:1.3;flex-shrink:0}.home-company-info{flex:1;min-width:0}.home-company-name{font-size:14px;font-weight:500;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-company-meta{font-size:12px;color:var(--text-muted)}.home-company-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.home-tag{display:inline-flex;align-items:center;font-size:12px;padding:2px 7px;border-radius:20px;font-weight:500;background:var(--surface-raised, #f1efe8);color:var(--text-secondary, #5f5e5a)}.home-tag-blue{background:#e6f1fb;color:#185fa5}.home-tag-green{background:#eaf3de;color:#3b6d11}.home-tag-amber{background:#faeeda;color:#854f0b}.home-tag-gray{background:var(--surface-raised, #f1efe8);color:var(--text-secondary, #5f5e5a)}.home-company-stats{display:flex;gap:10px;font-size:13px;color:var(--text-muted)}.home-stat-item{display:flex;align-items:center;gap:3px}.home-posting-list{display:flex;flex-direction:column;gap:8px}.home-posting-item{display:flex;align-items:center;gap:12px;cursor:pointer;transition:box-shadow .2s,border-color .15s;padding:12px 14px;border-radius:12px;box-shadow:var(--shadow-sm)}.home-posting-item:hover{border-color:#cbd5e1;box-shadow:var(--shadow-md)}.home-posting-body{flex:1;min-width:0}.home-posting-title{font-size:14px;font-weight:500;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-posting-meta-row{display:flex;align-items:center;gap:8px}.home-posting-meta{font-size:12px;color:var(--text-muted)}.home-posting-bids{font-size:12px;color:var(--text-muted);text-align:right;flex-shrink:0}.home-posting-bids strong{color:var(--text-primary);font-weight:500}.home-column-card{padding:0;overflow:hidden;cursor:pointer;transition:box-shadow .2s,border-color .15s;border-radius:12px;box-shadow:var(--shadow-sm)}.home-column-card:hover{border-color:#cbd5e1;box-shadow:var(--shadow-md)}.home-column-thumb{height:80px;background:var(--surface-raised, #f1efe8);border-bottom:.5px solid var(--border);overflow:hidden;display:flex;align-items:center;justify-content:center}.home-column-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.home-column-card:hover .home-column-thumb img{transform:scale(1.03)}.home-column-thumb-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.home-column-body{padding:10px 12px;display:flex;flex-direction:column;gap:4px}.home-column-title{font-size:13px;font-weight:500;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.home-column-stats{display:flex;gap:8px;font-size:12px;color:var(--text-muted)}.home-partner-card{--partner-accent: #378ADD;--partner-accent-light: #E6F1FB;--partner-accent-dark: #185FA5;background:var(--surface);border:2px solid var(--partner-accent);border-radius:12px;padding:1.75rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;cursor:pointer;transition:box-shadow .15s;margin:0 24px 8px}.home-partner-card:hover{box-shadow:0 4px 16px #378add1f}.home-partner-body{flex:1;min-width:0}.home-partner-title-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.home-partner-title{font-size:17px;font-weight:500;color:var(--text-primary)}.home-partner-badge{font-size:11px;font-weight:500;background:var(--partner-accent-light);color:var(--partner-accent-dark);padding:2px 9px;border-radius:8px;white-space:nowrap}.home-partner-desc{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:14px}.home-partner-features{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.home-partner-feature{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--text-secondary)}.home-partner-feature svg{flex-shrink:0}.home-partner-cta{white-space:nowrap;padding:12px 24px;font-size:14px;font-weight:500;border-radius:8px;cursor:pointer;font-family:inherit;border:1.5px solid var(--partner-accent);color:var(--partner-accent-dark);background:transparent;transition:background .15s;flex-shrink:0}.home-partner-cta:hover{background:var(--partner-accent-light)}[data-theme=dark] .home-partner-card{--partner-accent: #5ba3e6;--partner-accent-light: rgba(91,163,230,.12);--partner-accent-dark: #93c5fd}[data-theme=dark] .home-partner-cta{color:var(--partner-accent-dark)}@media (max-width: 640px){.home-hero{padding:0 14px}.home-content{padding:0 0 24px}.home-section{padding:20px 16px 16px}.home-hero-title{font-size:22px;white-space:normal}.home-hero-sub{font-size:14px;margin-bottom:22px}.home-match-grid{gap:12px}.home-match-card{min-height:180px;padding:24px 14px 20px;gap:10px}.home-match-icon{width:60px;height:60px;border-radius:16px}.home-match-label{font-size:16px}.home-match-sublabel{font-size:12px}.home-two-col{grid-template-columns:1fr}.home-three-col{grid-template-columns:repeat(2,minmax(0,1fr))}.home-search-row{flex-direction:column}.home-partner-card{flex-direction:column;align-items:stretch;gap:1rem;margin:0 16px 8px;padding:1.25rem}.home-partner-cta{width:100%;text-align:center}}.page-bg{background:var(--bg);min-height:100vh;padding:5px 16px 60px}.page-card{background:var(--surface);border-radius:16px;border:1px solid var(--border-solid);box-shadow:var(--shadow-sm);padding:24px 24px 32px}.layout-main.page-card{background:var(--surface);border-radius:16px;border:1px solid var(--border-solid);box-shadow:var(--shadow-sm);padding:32px 24px 40px}.register-page{max-width:600px;margin:0 auto;padding:24px 16px 40px}.register-page-header{margin-bottom:24px}.register-page-title{font-size:20px;font-weight:500;margin:8px 0 6px}.register-page-sub{font-size:14px;color:var(--text-muted);line-height:1.5}.register-page-body{position:relative}.reg-bot-panel.page-mode{position:static!important;width:100%!important;max-width:100%!important;height:auto!important;max-height:none!important;box-shadow:0 2px 12px #00000024!important;border-radius:12px!important;z-index:auto!important}.reg-bot-panel.page-mode .reg-bot-messages{max-height:420px}.em-page{padding:0 16px 48px;display:flex;align-items:flex-start;justify-content:center}.em-container{max-width:760px;width:100%}.em-wizard-card{background:var(--surface);border-radius:24px;border:.5px solid var(--border-medium);box-shadow:var(--shadow-lg);padding:28px 32px 32px;min-height:480px;display:flex;flex-direction:column;animation:emCardIn .3s ease both}.em-wizard-card--full{border:none;box-shadow:none;background:transparent;padding:0}@keyframes emCardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 600px){.em-page{padding:0 10px 40px}.em-wizard-card{border-radius:18px;padding:20px 18px 24px;min-height:unset}}.em-progress-wrap{padding:0 0 4px;position:relative}.em-step-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.em-step-text{font-size:11px;font-weight:600;letter-spacing:.08em}.em-step-dots{display:flex;gap:5px}.em-dot{width:6px;height:6px;border-radius:3px;background:#ddd;transition:all .3s}.em-dot--active{width:18px}.em-dot--done{opacity:.5}.em-progress-track{height:3px;background:var(--border-medium);border-radius:2px;overflow:hidden}.em-progress-fill{height:100%;border-radius:2px;transition:width .6s cubic-bezier(.4,0,.2,1)}.em-back-btn{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:8px 0 0;font-family:inherit}.em-step-content{padding:20px 0 16px;display:flex;flex-direction:column}.em-title-badge{display:inline-flex;align-items:center;gap:5px;background:#e8f5f0;border-radius:20px;padding:4px 10px;margin-bottom:14px;width:fit-content}.em-title-badge span{font-size:11px;font-weight:600;color:#1a6b55;letter-spacing:.06em}.em-title-dot{width:5px;height:5px;border-radius:50%;background:#1a6b55}.em-title{font-size:22px;font-weight:700;color:var(--text-primary);line-height:1.35;margin:0 0 8px}.em-subtitle{font-size:13px;color:var(--text-muted);line-height:1.6;margin:0 0 4px}.em-ctx-row{display:flex;align-items:center;gap:6px;margin-bottom:16px;flex-wrap:wrap}.em-ctx-badge{display:inline-flex;align-items:center;gap:6px;border-radius:20px;padding:5px 12px 5px 8px;font-size:12px;font-weight:600;letter-spacing:.04em}.em-ctx-dot{width:7px;height:7px;border-radius:50%}.em-cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px}@media (min-width: 640px){.em-cat-grid{grid-template-columns:repeat(4,1fr)}}.em-cat-card{background:var(--surface);border-radius:18px;padding:18px 14px;cursor:pointer;border:1.5px solid var(--border-medium);transition:all .22s cubic-bezier(.4,0,.2,1);position:relative;display:flex;flex-direction:column;gap:10px}.em-cat-card:hover{border-color:var(--border-strong);transform:translateY(-3px);box-shadow:var(--shadow-md)}.em-cat-card--sel{border-color:var(--cat-color)!important;background:var(--cat-light);box-shadow:0 0 0 1px var(--cat-color),var(--shadow-md)}.em-cat-check{position:absolute;top:11px;right:11px;width:20px;height:20px;background:var(--cat-color);border-radius:50%;display:flex;align-items:center;justify-content:center;animation:emCheckIn .25s cubic-bezier(.34,1.56,.64,1)}@keyframes emCheckIn{0%{opacity:0;transform:scale(.4) rotate(-30deg)}to{opacity:1;transform:scale(1) rotate(0)}}.em-cat-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center}.em-cat-name{font-size:16px;font-weight:700;color:var(--text-primary);transition:color .2s}.em-cat-card--sel .em-cat-name{color:var(--cat-color)}.em-cat-en{font-size:10px;color:var(--text-faint);font-weight:500;letter-spacing:.06em;margin-top:1px}.em-cat-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.em-cat-tag{font-size:10px;color:var(--text-muted);background:var(--surface-elevated);border-radius:5px;padding:2px 6px;font-weight:500;transition:all .2s}.em-cat-card--sel .em-cat-tag{background:var(--cat-light);color:var(--cat-color)}.em-svc-list{margin-top:12px}.em-svc-item{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.em-svc-item:last-child{border-bottom:none}.em-svc-item:hover{background:var(--surface-hover);margin:0 -16px;padding:13px 16px}.em-svc-item--sel{background:var(--cat-light)!important;margin:0 -16px;padding:13px 16px}.em-svc-icon{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.em-svc-body{flex:1;min-width:0}.em-svc-name{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.em-svc-desc{font-size:12px;color:var(--text-muted);line-height:1.4}.em-svc-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.em-svc-duration{font-size:10px;color:var(--text-muted);font-weight:500;background:var(--surface-elevated);border-radius:5px;padding:2px 7px;white-space:nowrap}.em-svc-radio{width:20px;height:20px;border-radius:50%;border:1.8px solid #DDD;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.34,1.56,.64,1)}.em-svc-item--sel .em-svc-radio{border-color:transparent}.em-svc-radio-inner{width:10px;height:10px;border-radius:50%;animation:emRadioIn .2s ease}@keyframes emRadioIn{0%{width:0;height:0}to{width:10px;height:10px}}.em-field-block{margin-bottom:20px}.em-field-label{font-size:10px;font-weight:700;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:5px}.em-req-dot{width:5px;height:5px;border-radius:50%;background:#e05a5a}.em-nat-input-wrap{position:relative;margin-bottom:10px}.em-nat-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.35}.em-nat-input{width:100%;padding:11px 14px 11px 36px;background:var(--surface);border:1.5px solid var(--border-medium);border-radius:12px;font-size:13px;font-family:inherit;color:var(--text-primary);outline:none;transition:border-color .2s;box-sizing:border-box}.em-nat-input:focus{border-color:var(--primary)}.em-nat-chips{display:flex;flex-wrap:wrap;gap:6px}.em-nat-chip{padding:6px 12px;border-radius:20px;border:1.5px solid var(--border-medium);background:var(--surface);font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .18s;display:flex;align-items:center;gap:5px;font-family:inherit}.em-nat-chip:hover{border-color:var(--border-strong);color:var(--text-primary)}.em-nat-chip--on{color:#fff}.em-nat-flag{font-size:14px;line-height:1}.em-status-chips{display:flex;flex-wrap:wrap;gap:6px}.em-status-chip{padding:7px 13px;border-radius:10px;border:1.5px solid var(--border-medium);background:var(--surface);font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .18s;font-family:inherit}.em-status-chip:hover{border-color:var(--border-strong);color:var(--text-primary)}.em-status-chip--on{color:#fff}.em-status-sub{font-size:10px;font-weight:400;opacity:.7;display:block;margin-top:1px}.em-dyn-chips{display:flex;flex-wrap:wrap;gap:6px}.em-dyn-chip{padding:7px 13px;border-radius:10px;border:1.5px solid var(--border-medium);background:var(--surface);font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .18s;font-family:inherit}.em-dyn-chip:hover{border-color:var(--border-strong);color:var(--text-primary)}.em-dyn-chip--on{color:#fff}.em-divider{display:flex;align-items:center;gap:10px;margin:6px 0 20px}.em-divider-line{flex:1;height:1px;background:var(--border-medium)}.em-divider-label{font-size:11px;font-weight:600;color:var(--text-muted);white-space:nowrap;letter-spacing:.06em}.em-location-selected{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface-elevated);border-radius:10px;border:1px solid var(--border)}.em-location-btn{width:100%;padding:10px;border-radius:10px;font-size:13px;border:1.5px dashed var(--border-strong);background:var(--surface-elevated);color:var(--text-muted);cursor:pointer;font-family:inherit;transition:border-color .2s,color .2s}.em-location-btn:hover{border-color:var(--primary);color:var(--primary)}.em-footer{padding:16px 0 0;margin-top:auto}.em-hint{text-align:center;font-size:12px;color:var(--text-faint);margin-bottom:12px;min-height:18px;transition:color .2s}.em-hint--on{color:#1a6b55}.em-btn{width:100%;padding:15px;background:#1a6b55;color:#fff;border:none;border-radius:14px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;opacity:.28;pointer-events:none;transition:all .25s ease}.em-btn--on{opacity:1;pointer-events:auto}.em-btn--on:hover{filter:brightness(.92);transform:translateY(-1px);box-shadow:0 10px 24px #00000026}.em-btn--on:active{transform:translateY(0)}.em-btn-outline{width:100%;padding:13px;background:var(--surface);color:var(--text-secondary);border:1.5px solid var(--border-medium);border-radius:14px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}.em-btn-outline:hover{border-color:var(--border-strong);color:var(--text-primary)}.em-loading{display:flex;flex-direction:column;align-items:center;padding:48px 0 32px;position:relative;min-height:520px;justify-content:center}.em-loading-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.em-loading-ring{position:absolute;border-radius:50%;border:1px solid rgba(26,107,85,.1);transform:translate(-50%,-50%);left:50%;top:42%;animation:emRingAnim 2.16s ease-out infinite}@keyframes emRingAnim{0%{width:0;height:0;opacity:.5}to{width:380px;height:380px;opacity:0}}.em-loading-body{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;width:100%}.em-loading-hex-svg{margin-bottom:12px}.em-loading-dots{display:flex;gap:8px;justify-content:center;margin-bottom:16px}.em-loading-dot{width:6px;height:6px;border-radius:3px;background:#ddd;transition:all .4s ease}.em-loading-dot--act{width:20px}.em-loading-dot--done{opacity:.6}.em-loading-nums{text-align:center;margin-bottom:16px}.em-loading-bignum{font-size:48px;font-weight:700;color:var(--text-primary);line-height:1;letter-spacing:-.03em;transition:color .6s ease}.em-loading-numlbl{font-size:12px;color:var(--text-faint);font-weight:500;margin-top:6px;min-height:18px}.em-loading-msg{text-align:center;margin-bottom:24px}.em-loading-main{font-size:20px;font-weight:700;color:var(--text-primary);line-height:1.4;min-height:56px;display:flex;align-items:center;justify-content:center;animation:emFadeUp .35s ease both}.em-loading-sub{font-size:13px;color:var(--text-faint);margin-top:8px;line-height:1.55;animation:emFadeUp .35s ease .1s both}@keyframes emFadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.em-loading-crit{text-align:center;margin-top:auto;padding-top:24px}.em-loading-crit-label{font-size:10px;font-weight:700;letter-spacing:.12em;color:var(--text-faint);margin-bottom:10px}.em-loading-crit-chips{display:flex;justify-content:center;gap:7px;flex-wrap:wrap}.em-loading-chip{padding:5px 13px;border-radius:20px;background:var(--surface-elevated);font-size:11px;font-weight:500;color:var(--text-muted);border:.5px solid var(--border)}.em-result-list{margin-top:16px;display:grid;grid-template-columns:1fr;gap:10px}@media (min-width: 640px){.em-result-list{grid-template-columns:1fr 1fr}}.em-result-card{background:var(--surface);border-radius:12px;border:.5px solid var(--border-medium);padding:14px 16px;cursor:pointer;transition:box-shadow .15s}.em-result-card:hover{box-shadow:var(--shadow-md)}.em-result-avatar{width:44px;height:44px;border-radius:50%;flex-shrink:0;background:var(--primary-light);border:.5px solid var(--border-medium);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:600;color:var(--primary)}.em-result-chip{font-size:11px;background:var(--surface-elevated);color:var(--text-muted);border:.5px solid var(--border-medium);border-radius:6px;padding:2px 8px}.em-result-chip--green{background:#eaf3de;color:#3b6d11;border-color:#3b6d114d;font-weight:500}.em-result-chip--match{background:var(--primary-light);color:var(--primary);border-color:#4f46e559}.em-result-fallback-section{margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.em-no-result{text-align:center;padding:40px 0 24px}.home-match-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;width:100%}.home-match-card{background:var(--surface);border-radius:22px;padding:32px 20px 28px;cursor:pointer;border:1.5px solid var(--border-medium);transition:all .22s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;min-height:220px;justify-content:center;position:relative;overflow:hidden}.home-match-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;opacity:0;transition:opacity .2s;background:linear-gradient(135deg,rgba(255,255,255,.08) 0%,transparent 60%)}.home-match-card:hover{transform:translateY(-5px) scale(1.02);box-shadow:0 16px 40px #00000021}.home-match-card:hover:after{opacity:1}.home-match-icon{width:72px;height:72px;border-radius:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.home-match-label{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.home-match-sublabel{font-size:13px;color:var(--text-muted);line-height:1.5}.home-match-tags{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-top:2px}.home-match-tag{font-size:11px;padding:3px 9px;border-radius:10px;background:var(--surface-elevated, #f5f4f0);color:var(--text-muted);border:.5px solid var(--border)}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.page-transition{animation:pageFadeIn .22s ease both}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tab-content-fade{animation:tabFadeIn .18s ease both}@keyframes skeletonShimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--surface-hover) 25%,rgba(0,0,0,.06) 50%,var(--surface-hover) 75%);background-size:800px 100%;animation:skeletonShimmer 1.4s ease-in-out infinite;border-radius:8px}[data-theme=dark] .skeleton{background:linear-gradient(90deg,#ffffff0f 25%,#ffffff1f,#ffffff0f 75%);background-size:800px 100%}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .form-input{padding-right:44px;width:100%}.password-toggle-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;color:var(--text-muted);line-height:0;transition:color .15s}.password-toggle-btn:hover{color:var(--text-secondary)}@media (max-width: 480px){.hero-action-btns{position:static!important;display:flex;justify-content:flex-end;gap:8px;padding:8px 12px 0;z-index:3}}
