:root{color-scheme:dark;--bg: #0a0a0f;--bg-elev: #12121b;--text: #f2f2f7;--muted: #b9b9c7;--line: #2d2d3f;--accent: #6366f1;--accent-2: #ec4899;--success: #22c55e;--warning: #f59e0b;--chip: #1e1e2a;--shadow: 8px 8px 0 #000}html[data-theme=light]{color-scheme:light;--bg: #f6f4ef;--bg-elev: #ffffff;--text: #161621;--muted: #57576d;--line: #d8d3c9;--accent: #4f46e5;--accent-2: #db2777;--success: #16a34a;--warning: #d97706;--chip: #f1ede4;--shadow: 8px 8px 0 #d4cebf}@keyframes pulse{50%{opacity:.5}}.animate-spin{animation:spin 1s linear infinite}.skeleton{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite;background-color:var(--line);border-radius:4px}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text)}.noise{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.08;background-image:radial-gradient(circle at 1px 1px,currentColor 1px,transparent 0);background-size:3px 3px}.wrap{width:min(1100px,calc(100% - 2rem));margin:0 auto}.topbar{position:fixed;top:0;left:0;z-index:1000;background:var(--bg);border-bottom:2px solid var(--line);width:100%}main{padding-top:80px}.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:1rem 0}.brand{display:flex;align-items:center;gap:.7rem}.logo{width:44px;height:44px;display:block;object-fit:contain;flex:0 0 auto}.brand-title,.brand-sub{margin:0}.brand-title{font-weight:800}.brand-sub{font-size:.84rem;color:var(--muted)}.actions{display:flex;gap:.5rem}.switch{border:2px solid var(--text);background:var(--bg-elev);color:var(--text);padding:.5rem .8rem;cursor:pointer;font-weight:700}.hero{padding:3.2rem 0 1.6rem}.eyebrow{font-size:.75rem;letter-spacing:.14em;color:var(--accent);margin:0;font-weight:700}.hero h1{margin:.8rem 0;font-size:clamp(2rem,5vw,3.3rem);max-width:100%;line-height:1.1}.hero-desc{color:var(--muted);line-height:1.7;max-width:100%}.hero-cta{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.2rem;align-items:center}.portal-btn{margin-left:auto}@media (max-width: 600px){.hero-cta{flex-wrap:nowrap;gap:.5rem}.hero-cta .btn{flex:1;min-width:0;padding:0 .8rem;font-size:.9rem}.portal-btn{margin-left:0;flex:0 0 auto!important;min-width:48px;padding:0 .6rem!important}.portal-btn__text{display:none}.portal-btn .portal-icon{margin-right:0}}.btn{text-decoration:none;border:2px solid var(--text);height:48px;padding:0 1.2rem;font-family:inherit;font-size:1rem;font-weight:700;color:var(--text);display:inline-flex;align-items:center;justify-content:center;transition:transform .15s ease;cursor:pointer;box-sizing:border-box}.portal-icon{margin-right:.4rem;font-size:1.2rem;line-height:1}.btn:hover{transform:translate(-2px,-2px)}.btn.primary{background:var(--accent);color:#fff}.btn.ghost{background:var(--bg-elev)}.dashboard{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}.dashboard article,.panel,.spotlight,.submit,.project-card{border:2px solid var(--line);background:var(--bg-elev);box-shadow:var(--shadow)}.dashboard article{padding:1rem}.dashboard h3{margin:0;font-size:1.4rem}.dashboard p{margin:.3rem 0 0;color:var(--muted)}.panel,.spotlight,.submit{padding:1rem;margin-top:1rem}.panel-head h2,.submit h2,.spotlight h2{margin:0}.panel-head p,.submit p,#featured-description{color:var(--muted)}.controls{margin:.9rem 0;display:grid;gap:.7rem}.controls input{border:2px solid var(--line);background:var(--bg);color:var(--text);padding:.7rem;font-size:.95rem}input[type=search]::-webkit-search-cancel-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:16px;width:16px;background-color:var(--text);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E") no-repeat center;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E") no-repeat center;-webkit-mask-size:contain;mask-size:contain;cursor:pointer;opacity:.6}input[type=search]::-webkit-search-cancel-button:hover{opacity:1}.chips{display:flex;gap:.5rem;flex-wrap:wrap}.chip{border:2px solid var(--line);padding:.4rem .72rem;background:var(--chip);color:var(--muted);font-weight:600;cursor:pointer}.chip.active{border-color:var(--accent);color:var(--text)}.project-grid{display:grid;gap:.8rem;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.project-card{padding:.9rem}.project-title{margin:0}.project-top{display:flex;justify-content:space-between;gap:.5rem}.project-category{background:var(--bg-elev);padding:.2rem .6rem;border-radius:4px;font-size:.85rem;font-weight:700;color:#f97316;text-transform:uppercase}.project-vibe{font-size:.8rem;font-weight:600;height:fit-content;color:var(--text)}.project-desc{color:var(--muted);line-height:1.55;min-height:74px}.project-footer{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.project-footer a{color:var(--text)}.spotlight{display:flex;justify-content:space-between;align-items:end;gap:1rem}.spotlight>div:first-child{margin-left:-2px}.meta{display:flex;flex-wrap:wrap;gap:.7rem;font-size:.9rem}.submit-form{display:flex;gap:1rem}.submit-form input{flex:1;border:2px solid var(--line);background:var(--bg);color:var(--text);padding:.7rem}.submit-form button{white-space:nowrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;display:grid;place-items:center;padding:1rem}.modal-content{background:var(--bg-elev);border:3px solid var(--text);box-shadow:12px 12px 0 var(--line);padding:2rem;position:relative;width:95%;max-width:600px;max-height:90vh;overflow-y:auto}@media (max-width: 640px){.modal-content{padding:2.5rem 1.5rem 1.5rem;box-shadow:8px 8px 0 var(--line)}.close-btn{top:.5rem;right:.5rem;padding:.3rem}.modal-header h2{font-size:1.5rem;padding-right:1.5rem}.magic-input-form .input-group{flex-direction:column}.magic-input-form button{width:100%}.spotlight{position:relative;padding-bottom:4rem}.spotlight button{position:absolute;bottom:1rem;right:1rem;width:auto;height:2rem;font-size:.75rem;padding:.2rem .5rem;line-height:1.2;min-height:auto}.profile-header,.project-detail{flex-direction:column}.profile-avatar{width:80px;height:80px;margin:0 auto 1rem}.profile-info{text-align:center}}.modal-header{margin-bottom:1rem}.modal-header h2{margin:0 0 .5rem;font-size:2rem}.modal-header p{margin:0;color:var(--muted)}.close-btn{position:absolute;top:1rem;right:1rem;background:none;border:2px solid var(--text);padding:.5rem;cursor:pointer;color:var(--text);display:grid;place-items:center;transition:all .2s}.close-btn:hover{background:var(--accent);color:#fff}.magic-input-form .input-group{height:48px;display:flex;gap:1rem}.magic-input-form input{flex:1;background:var(--bg);border:2px solid var(--line);color:var(--text);padding:1rem;font-size:1rem}.analyzing-state{text-align:center;padding:0 0 2rem}.loader-ring{display:flex;justify-content:center;margin-bottom:1rem}.footer{padding:1.4rem 0 2rem;color:var(--muted);text-align:center}@media (max-width: 900px){.dashboard{grid-template-columns:1fr}.spotlight{flex-direction:column;align-items:start}.submit-form{grid-template-columns:1fr}}@media (max-width: 600px){.topbar-inner{padding:.6rem 0}main{padding-top:66px}.brand{gap:.5rem}.logo{width:36px;height:36px}.brand-title{font-size:1.8rem}.brand-sub{font-size:.75rem}.switch{padding:.35rem .6rem;font-size:.85rem}.theme-text{display:none}}.teleport-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;animation:fadeIn 1.5s ease forwards}.app-container{transition:opacity .5s ease}.btn.ghost.portal-btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:.5rem}.portal-icon{display:inline-block;font-size:1.1em;animation:spin 3s linear infinite;filter:hue-rotate(0deg)}@keyframes spin{0%{transform:rotate(0);filter:hue-rotate(0deg)}50%{transform:rotate(180deg);filter:hue-rotate(60deg)}to{transform:rotate(360deg);filter:hue-rotate(0deg)}}.btn.ghost.portal-btn:hover .portal-icon{animation:spin 1s linear infinite}.btn.ghost.portal-btn{background:var(--bg-elev);color:var(--text);border:2px solid var(--text);box-shadow:none;text-shadow:none;margin-right:0;border-radius:0;font-size:inherit;padding:.65rem 1rem}.btn.ghost.portal-btn:hover{transform:translate(-2px,-2px);box-shadow:none}.auth-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:2000;display:flex;align-items:center;justify-content:center}.auth-modal__content{background:var(--bg-elev);border:1px solid var(--line);padding:2.5rem;width:min(420px,100%);box-shadow:var(--shadow-lg);position:relative;border-radius:12px}.auth-modal__close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--muted);transition:color .2s}.auth-modal__close:hover{color:var(--text)}.auth-modal__title{margin-top:0;text-align:center;margin-bottom:2rem;font-size:1.5rem;font-weight:600}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.4rem}.input-group{position:relative;display:flex;align-items:center}.input-group.with-action{display:flex;gap:.5rem}.input-group.with-action .auth-input{flex:1}.input-group.with-action .code-btn{white-space:nowrap;min-width:80px;height:40px}.field-error{color:var(--accent-2);font-size:.8rem;padding-left:.2rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.input-icon{position:absolute;left:1rem;color:var(--muted);pointer-events:none}.auth-input{width:100%;padding:.8rem 1rem .8rem 2.5rem;background:var(--bg);border:1px solid var(--line);color:var(--text);border-radius:6px;transition:border-color .2s;height:40px}.auth-input:focus{outline:none;border-color:var(--accent)}.auth-input.has-error{border-color:var(--accent-2)}.form-actions{display:flex;justify-content:flex-end;font-size:.9rem}.link-btn{background:none;border:none;color:var(--accent);cursor:pointer;padding:0;font-size:inherit}.link-btn:hover{text-decoration:underline}.block-btn{width:100%;padding:.8rem;font-weight:500}.auth-divider{display:flex;align-items:center;justify-content:center;margin:1rem 0;position:relative}.auth-divider:before{content:"";position:absolute;left:0;right:0;height:1px;background:var(--line)}.auth-divider span{background:var(--bg-elev);padding:0 1rem;color:var(--muted);font-size:.8rem;position:relative}.oauth-buttons{display:flex;gap:1rem}.oauth-buttons .btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem}.auth-footer{text-align:center;margin-top:1rem;color:var(--muted);font-size:.9rem}.auth-header-row{display:flex;align-items:center;margin-bottom:1rem}.auth-header-row .back-btn{background:none;border:none;color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:.25rem;padding:0}.auth-header-row .back-btn:hover{color:var(--text)}.auth-header-row h3{margin:0;flex:1;text-align:center;padding-right:3rem;font-size:1.2rem}.auth-modal__header-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.auth-modal__back{background:none;border:none;cursor:pointer;color:var(--text);padding:.5rem;display:flex;align-items:center;border-radius:50%}.auth-modal__back:hover{background:var(--line)}.auth-modal__step-title{font-weight:600;font-size:1.1rem}.auth-modal__hint{font-size:.9rem;color:var(--muted);margin-bottom:1rem}.auth-modal__input--code{text-align:center;font-size:1.5rem;letter-spacing:.5rem;font-family:monospace}.auth-modal__resend{text-align:center;margin-top:1rem}.auth-modal__resend-text{font-size:.85rem;color:var(--muted)}.auth-modal__resend-btn{font-size:.85rem;text-decoration:underline;color:var(--muted);background:none;border:none;cursor:pointer;padding:0}.auth-modal__resend-btn:hover{color:var(--text)}.auth-modal__resend-btn:disabled{cursor:not-allowed;text-decoration:none}.auth-modal__error{margin:0;color:var(--accent-2);font-size:.8rem}.avatar{width:var(--avatar-size);height:var(--avatar-size);border-radius:50%;object-fit:cover;border:2px solid var(--text)}.avatar--fallback{background:var(--avatar-bg);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--avatar-font);-webkit-user-select:none;user-select:none}.user-dropdown-container{position:relative}.user-dropdown-trigger{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center}.dropdown-menu{position:absolute;top:120%;right:0;width:240px;background:var(--bg-elev);border:2px solid var(--line);border-radius:8px;box-shadow:var(--shadow);z-index:1000;overflow:hidden;font-family:inherit}.dropdown-header{padding:1rem;border-bottom:1px solid var(--line)}.dropdown-name{margin:0 0 .3rem;font-weight:700;font-size:1rem}.dropdown-email{margin:0;font-size:.8rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-items{padding:.5rem 0}.dropdown-item{display:flex;align-items:center;width:100%;padding:.6rem 1rem;background:none;border:none;text-align:left;cursor:pointer;font-size:.9rem;font-family:inherit;color:var(--text);transition:background .2s}.dropdown-item:hover{background:var(--bg)}.dropdown-item--danger{color:#ff4d4f}.brand{text-decoration:none;color:inherit}.mobile-only{display:none}@media (max-width: 640px){.desktop-only{display:none}.mobile-only{display:block}.brand-sub{display:none}}.switch--theme{display:flex;align-items:center;gap:.4rem;padding:.4rem .8rem}.user-dropdown-wrap{margin-left:.5rem;display:flex;align-items:center}.nav-login-btn{height:auto;margin-left:.5rem;padding:.5rem 1rem}.hyperspeed-canvas{width:100%;height:100%;position:absolute;top:0;left:0}.pagination{display:flex;justify-content:center;gap:.5rem;margin-top:2rem}.pagination__btn{min-width:40px;height:40px;padding:0 .5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid var(--text)}.pagination__btn--nav{width:40px;padding:0}.pagination__btn--dots{border:none;background:transparent;cursor:default}.pagination__btn:disabled{opacity:.5;cursor:not-allowed}.controls-search{display:flex;align-items:center;gap:.5rem;flex:1;position:relative}.search-input{width:100%;padding-right:4.5rem}.search-input::-webkit-search-cancel-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:16px;width:16px;background-color:var(--text);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E") no-repeat center;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E") no-repeat center;-webkit-mask-size:contain;mask-size:contain;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .2s;margin-right:1.5rem;position:relative;z-index:1}.search-input:not(:placeholder-shown)::-webkit-search-cancel-button{opacity:.5;pointer-events:auto}.search-input.ai-loading::-webkit-search-cancel-button{display:none!important}.animate-spin-ease{animation:spin .6s ease-in-out infinite}@keyframes aiPulseColor{0%{color:var(--accent);opacity:.6;filter:drop-shadow(0 0 2px var(--accent))}50%{color:#8e2de2;opacity:1;filter:drop-shadow(0 0 10px #8e2de2)}to{color:var(--accent);opacity:.6;filter:drop-shadow(0 0 2px var(--accent))}}.ai-pulse{animation:aiPulseColor 2s ease-in-out infinite}.search-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);padding:.4rem;height:auto;border:none;background:transparent!important}.search-btn:hover{transform:translateY(-50%)}.search-btn:disabled,.search-btn.is-disabled{opacity:.3;cursor:not-allowed}.search-btn.is-loading{opacity:1!important;cursor:default}.search-icon{color:var(--accent)}.search-btn:hover .search-icon{animation:spin .6s ease-in-out 1}.search-btn.is-loading:hover .search-icon{animation:aiPulseColor 2s ease-in-out infinite!important}.project-grid__loading{grid-column:1 / -1}.home-captcha__placeholder{display:flex;align-items:flex-start;gap:.75rem;padding:.9rem 1rem;margin-top:1rem;border:1.5px dashed var(--line);background:var(--bg)}.home-captcha__placeholder.is-error{border-color:var(--accent-2);background:color-mix(in srgb,var(--accent-2) 8%,var(--bg))}.home-captcha__placeholder-icon{width:2rem;height:2rem;display:grid;place-items:center;border-radius:999px;border:1.5px solid var(--line);color:var(--accent);flex-shrink:0}.home-captcha__placeholder.is-error .home-captcha__placeholder-icon{color:var(--accent-2);border-color:var(--accent-2)}.home-captcha__placeholder-content{flex:1;min-width:0}.home-captcha__placeholder-title{font-size:.9rem;font-weight:700;color:var(--text)}.home-captcha__placeholder-desc{margin:.35rem 0 0;font-size:.82rem;line-height:1.45;color:var(--muted)}.home-captcha__placeholder-desc.is-error{color:var(--accent-2)}.project-grid__contents{display:contents}.project-card{height:280px;display:flex;flex-direction:column;overflow:hidden}.project-top{min-width:0}.project-top>div{min-width:0;flex:1}.project-title{display:block;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-desc{line-height:1.55;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;line-clamp:3;overflow:hidden;text-overflow:ellipsis;word-break:break-word;overflow-wrap:anywhere}.project-footer{margin-top:auto}.project-vibe{display:flex;align-items:center;margin-top:4px;gap:.3rem}.project-vibe__icon{color:var(--text);fill:currentColor}.project-tags{display:flex;gap:.3rem;flex-wrap:wrap}.project-tag{font-size:.7rem;color:var(--muted);background:var(--bg);padding:2px 6px;border:1px solid var(--line)}.project-view-btn{padding:.4rem .8rem;height:auto;font-size:.9rem;display:flex;align-items:center;gap:.2rem}.project-empty{padding:2rem;text-align:center;color:var(--muted);min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;grid-column:1 / -1}.project-empty__row{display:inline-flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.project-empty__desc{min-height:auto;margin:0}.project-empty__action{padding:.2rem .5rem;height:auto;display:flex;align-items:center;gap:.3rem;font-size:.9rem;color:var(--accent)}.spotlight.is-empty{display:flex;justify-content:center;align-items:center;min-height:110px;padding-left:1rem}.spotlight.is-clickable{cursor:pointer;transition:border-color .2s ease,transform .2s ease;height:170px;align-items:flex-start;overflow:hidden}.spotlight.is-clickable>div:first-child{flex:1;min-width:0}.spotlight.is-clickable button{align-self:flex-end;flex-shrink:0;margin-left:10px}@media (max-width: 900px){.spotlight.is-clickable{height:auto}}.spotlight.is-clickable:hover{border-color:var(--accent);transform:translateY(-1px)}.spotlight-desc{line-height:1.55;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1;line-clamp:1;overflow:hidden;text-overflow:ellipsis;word-break:break-word;overflow-wrap:anywhere}.spotlight.is-empty .spotlight-skeleton{margin-left:0;max-width:none;text-align:center}.spotlight.is-empty .btn{display:none}.spotlight-like{display:flex;align-items:center;gap:.3rem}.spotlight-like__icon{color:var(--text);fill:currentColor}.spotlight-skeleton{width:100%;max-width:600px;margin-left:1rem}.spotlight-skeleton__lines{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.spotlight-skeleton__meta{display:flex;gap:1rem}.skeleton-line{height:1rem}.skeleton-line--xs{width:100px}.skeleton-line--sm{width:150px;margin-bottom:1rem}.skeleton-line--md{width:80%}.skeleton-line--lg{height:2.5rem;width:300px;margin-bottom:1rem}.submit-guide-btn{margin-top:.6rem;background:none;border:none;padding:0;color:var(--muted);text-decoration:underline;cursor:pointer;font-size:.85rem;display:inline-flex;align-items:center;gap:.3rem}.spotlight-header{display:flex;align-items:center;gap:.5rem;margin:.5rem 0}.spotlight-logo,.spotlight-logo-placeholder{width:36px;height:36px;border-radius:8px;border:1px solid var(--line);background:var(--bg-elev);flex-shrink:0}.spotlight-logo{object-fit:fill}.spotlight-logo-placeholder{display:flex;align-items:center;justify-content:center;color:var(--muted)}.spotlight-title{margin:0}.loading-ring{width:100%;display:flex;align-items:center;justify-content:center}.loading-ring__icon{color:var(--accent)}.project-detail{padding-top:1.5rem}.project-detail__loading{min-height:420px}.detail-header{margin-bottom:2rem}.project-title-row{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.project-logo{width:48px;height:48px;object-fit:fill;border-radius:8px;border:1px solid var(--line);background:var(--bg-elev);flex-shrink:0}.project-detail__title{margin:0;font-size:2.5rem;line-height:1.2}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.main-content{grid-column:span 2}.preview-box{aspect-ratio:16 / 9;background:var(--bg-elev);border:2px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:2rem;color:var(--muted);font-size:1.2rem}.preview-box__text{color:var(--muted)}.project-about__desc{line-height:1.8;color:var(--text);font-size:1.1rem}.sidebar{min-width:0}.sidebar-panel{background:var(--bg-elev);padding:1.5rem;border:2px solid var(--line);display:flex;flex-direction:column;gap:1.5rem}.author-row{display:flex;align-items:center;gap:1rem}.author-avatar{width:48px;height:48px;border-radius:50%;border:2px solid var(--text)}.author-name{font-weight:700;font-size:1.1rem}.author-link{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.project-submit-meta{display:flex;flex-direction:column;gap:.7rem}.meta-info-group{display:flex;flex-direction:column;gap:.7rem;width:100%}.project-submit-meta__item{display:flex;flex-direction:column;gap:.25rem}.project-submit-meta__label{font-size:.78rem;color:var(--muted)}.project-submit-meta__value{font-size:.9rem;color:var(--text);word-break:break-word}.project-submit-meta__value--link{text-decoration:underline}.project-submit-meta__tags{display:flex;flex-wrap:wrap;gap:.4rem}.project-submit-meta__tag{display:inline-flex;align-items:center;padding:.2rem .55rem;border:1px solid var(--line);border-radius:999px;background:var(--bg);color:var(--text);font-size:.8rem;line-height:1.2}.project-submit-mini-qr{display:flex;flex-direction:column;gap:.5rem}.project-submit-mini-qr__img{width:140px;height:140px;object-fit:cover;border:2px solid var(--line);background:var(--bg)}.project-meta-row{display:flex;justify-content:space-between;align-items:center;width:100%}.meta-left{display:flex;flex-wrap:wrap;align-items:center;gap:.8rem;font-size:.85rem;color:var(--muted)}.meta-left .separator{color:var(--line)}.tags-inline{display:flex;gap:.5rem;flex-wrap:wrap}.tag-pill{background:var(--bg-elev);padding:.2rem .6rem;border-radius:4px;font-size:.85rem;color:var(--accent)}.meta-right{display:flex;gap:.8rem}.action-btn{display:flex;gap:.5rem;align-items:center;padding:.6rem 1rem;border:none;background:transparent!important;cursor:pointer;color:var(--text)}.action-btn:hover{background:transparent!important;opacity:.8}.action-btn .icon-heart{fill:none}.action-btn.is-liked .icon-heart{fill:currentColor}.mobile-info-panel{display:none}.mobile-only{display:none!important}@media (max-width: 768px){.detail-header{margin-bottom:.5rem}.project-detail__title{font-size:1.8rem}.detail-grid{display:flex;flex-direction:column;gap:1rem}.mobile-info-panel{display:block;margin-bottom:1.5rem;background:var(--bg-elev);padding:1.5rem;border:2px solid var(--line)}.mobile-info-panel .project-submit-meta-content{display:flex;flex-direction:row;justify-content:space-between;align-items:flex-start;gap:1rem}.mobile-info-panel .project-submit-meta{gap:0}.mobile-info-panel .meta-info-group{width:auto;flex:1}.mobile-info-panel .project-submit-mini-qr{width:auto;margin-top:0}.mobile-info-panel .project-submit-mini-qr__img{width:100px;height:100px}.project-meta-row{flex-direction:row;align-items:center;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.meta-left{width:auto;gap:.5rem;flex:1;min-width:0}.meta-right{width:auto;gap:.8rem;align-items:center}.action-btn{padding:.6rem .5rem}.mobile-hidden{display:none!important}.mobile-only{display:flex!important}.action-btn svg{width:20px;height:20px}.action-btn .like-count{display:inline-block}.sidebar{display:none}.preview-box{margin-bottom:1rem;border-radius:8px}}.profile-page{padding-top:3rem}.profile-header-container{display:flex;align-items:center;gap:2rem;margin-bottom:3rem;background:var(--bg-elev);padding:2rem;border:2px solid var(--line)}.profile-info{flex:1}.profile-name{margin:0 0 .5rem}.profile-email{color:var(--muted);margin:0}.profile-tags-container{margin-top:1rem;display:flex;gap:.8rem;flex-wrap:wrap;align-items:center}.profile-chip{background:var(--bg);border:1px solid var(--line)}.profile-tag-item{background:var(--bg);border:1px solid var(--line);position:relative;padding-right:.8rem;cursor:default;transition:padding-right .3s ease;overflow:hidden;display:flex;align-items:center}.profile-tag-item:hover{padding-right:2rem}.profile-tag-delete{position:absolute;right:0;top:0;bottom:0;width:24px;background:none;border:none;cursor:pointer;opacity:0;transform:translate(100%);transition:opacity .3s ease,transform .3s ease;display:flex;align-items:center;justify-content:center;color:var(--muted)}.profile-tag-item:hover .profile-tag-delete{opacity:1;transform:translate(0)}.profile-tag-input-wrap{position:relative}.profile-tag-input{padding:.4rem .8rem;background:var(--bg);border:1px solid var(--line);color:var(--text);font-size:.9rem;width:120px;outline:none}.profile-tag-input.is-error{border-color:var(--accent-2)}.profile-tag-error{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:.7rem;color:var(--accent-2);white-space:nowrap;width:max-content}.profile-tag-add{width:28px;height:28px;border-radius:50%;background:var(--bg);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted)}.profile-section{margin-bottom:3rem}.profile-section-title{border-bottom:2px solid var(--line);padding-bottom:.5rem;margin-bottom:1.5rem}.status-chip{background:var(--bg);color:var(--warning)}.status-chip--approved{background:var(--bg-elev);color:var(--success)}.like-chip{background:var(--bg);color:var(--accent)}.profile-project-tags{display:flex;gap:.3rem;flex-wrap:wrap;margin-bottom:.8rem}.profile-project-tag{font-size:.7rem;color:var(--muted);background:var(--bg);padding:2px 6px;border:1px solid var(--line)}.author-link{color:var(--accent);text-decoration:underline;text-underline-offset:2px;font-weight:600}.author-link:hover{opacity:.85}.profile-view-btn{padding:.2rem .5rem;height:auto;font-size:.8rem;display:inline-flex;align-items:center;gap:.2rem}.profile-empty{color:var(--muted)}.btn-like{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;gap:.3rem}.btn-like:hover{opacity:.7}.profile-avatar-wrapper{position:relative;display:inline-block;border-radius:50%;overflow:hidden}.profile-avatar-wrapper.is-editable{cursor:pointer}.profile-avatar-wrapper.is-editable:hover .profile-avatar-overlay{opacity:1}.profile-avatar-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;color:#fff;border-radius:50%}.profile-avatar-loading{width:100px;height:100px;border-radius:50%;background:var(--bg-elev);display:flex;align-items:center;justify-content:center;border:2px solid var(--line);color:var(--accent)}.profile-name-wrapper{display:flex;align-items:center;gap:.8rem}.btn-edit-profile{background:none;border:none;color:var(--muted);cursor:pointer;padding:.2rem;display:flex;align-items:center;transition:color .2s ease}.btn-edit-profile:hover{color:var(--text)}.profile-name-edit{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.profile-name-input{font-size:1.5rem;font-weight:700;background:var(--bg);border:1px solid var(--line);color:var(--text);padding:.2rem .5rem;width:100%;max-width:300px}.profile-edit-actions{display:flex;gap:.5rem}.btn-save,.btn-cancel{padding:.3rem .8rem;font-size:.85rem;border-radius:4px;cursor:pointer;font-weight:600}.btn-save{background:var(--accent);color:#fff;border:none}.btn-cancel{background:transparent;border:1px solid var(--line);color:var(--text)}@media (max-width: 640px){.profile-header-container{flex-direction:column;text-align:center;gap:1.5rem}.profile-header-container>div{width:100%}.profile-tags-container{justify-content:center;margin-top:1rem}.profile-name-wrapper{justify-content:center}.profile-name-edit{align-items:center}.profile-edit-actions{justify-content:center}}.project-title-row{display:flex;align-items:center;gap:.5rem;width:100%;margin-bottom:2px}.project-logo-small{width:24px;height:24px;object-fit:fill;border-radius:4px;border:1px solid var(--line);background:var(--bg-elev);flex-shrink:0}.admin-layout{display:flex;height:100vh;width:100vw;background-color:var(--bg);color:var(--text);overflow:hidden}.admin-layout .admin-sidebar{width:260px;background-color:var(--bg-elev);border-right:1px solid var(--line);display:flex;flex-direction:column;flex-shrink:0;transition:width .3s ease}.admin-layout .admin-sidebar .admin-logo{height:70px;display:flex;align-items:center;padding:0 24px;font-size:20px;font-weight:800;letter-spacing:-.5px;color:var(--text);border-bottom:1px solid var(--line);background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;white-space:nowrap;overflow:hidden}.admin-layout .admin-sidebar .admin-nav{padding:24px 16px;flex:1;display:flex;flex-direction:column;gap:4px}.admin-layout .admin-sidebar .admin-nav .admin-nav-item{display:flex;align-items:center;padding:12px 16px;color:var(--muted);text-decoration:none;border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:500;white-space:nowrap;overflow:hidden}.admin-layout .admin-sidebar .admin-nav .admin-nav-item .icon{margin-right:12px;font-size:20px;opacity:.7;transition:opacity .2s;min-width:24px}.admin-layout .admin-sidebar .admin-nav .admin-nav-item:hover{color:var(--text);background-color:#ffffff0d}.admin-layout .admin-sidebar .admin-nav .admin-nav-item:hover .icon{opacity:1}.admin-layout .admin-sidebar .admin-nav .admin-nav-item.active{color:#fff;background-color:var(--accent);box-shadow:0 4px 12px #6366f14d}.admin-layout .admin-sidebar .admin-nav .admin-nav-item.active .icon{opacity:1}.admin-layout .admin-sidebar .admin-nav .admin-nav-item.return-home{margin-top:auto;border:1px solid var(--line);justify-content:center}.admin-layout .admin-sidebar .admin-nav .admin-nav-item.return-home:hover{border-color:var(--accent);color:var(--accent);background:transparent}.admin-layout .admin-content{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;padding-top:0}.admin-layout .admin-content:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.05;background-image:radial-gradient(circle at 1px 1px,currentColor 1px,transparent 0);background-size:20px 20px;z-index:0}.admin-layout .admin-content .admin-header{height:70px;background-color:#12121bcc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 32px}.admin-layout .admin-content .admin-header h2{margin:0;font-size:24px;font-weight:700;letter-spacing:-.5px}.admin-layout .admin-content .admin-header .admin-user{font-size:14px;color:var(--muted);display:flex;align-items:center;gap:8px}.admin-layout .admin-content .admin-header .admin-user:before{content:"";display:block;width:8px;height:8px;background-color:var(--success);border-radius:50%;box-shadow:0 0 8px var(--success)}.admin-layout .admin-content .admin-page-container{flex:1;padding:32px;overflow-y:auto;z-index:1}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:40px}.stats-grid .stat-card{background:var(--bg-elev);padding:24px;border-radius:16px;border:1px solid var(--line);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}.stats-grid .stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border-color:var(--accent)}.stats-grid .stat-card h3{margin:0 0 12px;font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.stats-grid .stat-card .stat-value{font-size:42px;font-weight:800;color:var(--text);line-height:1;background:linear-gradient(180deg,#fff,var(--muted));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stats-grid .stat-card:after{content:"";position:absolute;top:-20px;right:-20px;width:100px;height:100px;background:radial-gradient(circle,var(--accent) 0%,transparent 70%);opacity:.1;border-radius:50%;pointer-events:none}.admin-table-container{background:var(--bg-elev);border-radius:16px;border:1px solid var(--line);box-shadow:0 4px 6px -1px #0000001a;overflow:hidden;display:flex;flex-direction:column}.admin-table-container .table-header-actions{padding:20px 24px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;background:#ffffff03}.admin-table-container .table-header-actions h3{margin:0;font-size:18px;font-weight:600}.admin-table-container .table-header-actions input{padding:10px 16px;background:var(--bg);border:1px solid var(--line);border-radius:8px;color:var(--text);width:300px;font-size:14px;transition:all .2s}.admin-table-container .table-header-actions input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #6366f133}.admin-table-container .table-header-actions input::placeholder{color:var(--muted)}.admin-table-container table{width:100%;border-collapse:collapse}.admin-table-container table th,.admin-table-container table td{padding:16px 24px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}.admin-table-container table th{background-color:#ffffff05;font-weight:600;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px;-webkit-user-select:none;user-select:none}.admin-table-container table tr{transition:background-color .15s}.admin-table-container table tr:hover{background-color:#ffffff08}.admin-table-container table tr:last-child td{border-bottom:none}.admin-table-container table td{color:var(--text)}.admin-table-container table td a{color:var(--accent);text-decoration:none;font-weight:500}.admin-table-container table td a:hover{text-decoration:underline}.admin-table-container table td .btn-icon{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.admin-table-container table td .btn-icon:hover{background:#ffffff1a;color:var(--text)}.admin-table-container table td .btn-icon.delete:hover{background:#ef44441a;color:var(--danger)}.admin-table-container table td .btn-danger{height:unset;background:#ef44441a;border:1px solid transparent;color:#ef4444;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s}.admin-table-container table td .btn-danger:hover{background:#ef444433;transform:none}.admin-table-container table td .btn-primary{height:unset;color:var(--accent);background:#6366f11a;border:1px solid transparent;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s}.admin-table-container table td .btn-primary:hover{background:#6366f133}.admin-table-container .pagination{padding:16px 24px;display:flex;justify-content:flex-end;align-items:center;gap:16px;border-top:1px solid var(--line);background:#ffffff03}.admin-table-container .pagination button{padding:6px 12px;border-radius:6px;border:1px solid var(--line);background:var(--bg);color:var(--text);font-size:13px;cursor:pointer;transition:all .2s}.admin-table-container .pagination button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.admin-table-container .pagination button:disabled{opacity:.5;cursor:not-allowed}.admin-table-container .pagination span{font-size:13px;color:var(--muted)}.badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;text-transform:capitalize}.badge.badge-admin{background-color:#6366f11a;color:var(--accent);border:1px solid rgba(99,102,241,.2)}.badge.badge-user{background-color:var(--line);color:var(--muted);border:1px solid var(--line)}.badge.badge-category{background-color:#22c55e1a;color:var(--success);border:1px solid rgba(34,197,94,.2)}@media (max-width: 768px){.admin-layout .admin-sidebar{width:70px}.admin-layout .admin-sidebar .admin-logo{justify-content:center;padding:0;font-size:0}.admin-layout .admin-sidebar .admin-logo svg{margin-right:0!important}.admin-layout .admin-sidebar .admin-nav{padding:16px 8px;align-items:center}.admin-layout .admin-sidebar .admin-nav .admin-nav-item{padding:12px;justify-content:center;width:40px;height:40px;font-size:0}.admin-layout .admin-sidebar .admin-nav .admin-nav-item .icon{margin-right:0;font-size:20px;display:flex;align-items:center;justify-content:center}.admin-layout .admin-content .admin-header{padding:0 16px;height:60px}.admin-layout .admin-content .admin-header h2{font-size:18px}.admin-layout .admin-content .admin-page-container{padding:16px}.stats-grid{grid-template-columns:1fr;gap:16px}.admin-table-container{overflow-x:auto}.admin-table-container .table-header-actions{flex-direction:column;align-items:stretch;gap:12px}.admin-table-container .table-header-actions input{width:100%}}.dashboard-container{padding-bottom:32px}.dashboard-container .dashboard-header{margin-bottom:24px}.dashboard-container .dashboard-header h2{font-size:24px;margin:0 0 8px;color:var(--text)}.dashboard-container .dashboard-header p{margin:0;font-size:14px;color:var(--muted)}.dashboard-container .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:24px}.dashboard-container .stats-grid .stat-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:12px;padding:20px;display:flex;align-items:flex-start;gap:16px;transition:transform .2s}.dashboard-container .stats-grid .stat-card:hover{transform:translateY(-2px)}.dashboard-container .stats-grid .stat-card .stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.dashboard-container .stats-grid .stat-card .stat-info{flex:1}.dashboard-container .stats-grid .stat-card .stat-info .stat-title{font-size:13px;color:var(--muted);margin-bottom:4px}.dashboard-container .stats-grid .stat-card .stat-info .stat-value{font-size:24px;font-weight:600;color:var(--text);margin-bottom:4px}.dashboard-container .stats-grid .stat-card .stat-info .stat-trend{font-size:12px;display:flex;align-items:center;gap:4px}.dashboard-container .stats-grid .stat-card .stat-info .stat-trend.up{color:#10b981}.dashboard-container .stats-grid .stat-card .stat-info .stat-trend.down{color:#ef4444}.dashboard-container .charts-layout{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}@media (max-width: 1024px){.dashboard-container .charts-layout{grid-template-columns:1fr}}.dashboard-container .charts-layout .chart-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:16px;padding:24px;height:400px;display:flex;flex-direction:column}.dashboard-container .charts-layout .chart-card.col-span-2{grid-column:span 2}@media (max-width: 1024px){.dashboard-container .charts-layout .chart-card.col-span-2{grid-column:span 1}}.dashboard-container .charts-layout .chart-card .card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.dashboard-container .charts-layout .chart-card .card-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text)}.dashboard-container .charts-layout .chart-card .card-header .refresh-btn{background:transparent;border:1px solid var(--line);color:var(--muted);width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.dashboard-container .charts-layout .chart-card .card-header .refresh-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text);border-color:var(--accent)}.dashboard-container .charts-layout .chart-card .card-header .refresh-btn:disabled{opacity:.5;cursor:not-allowed}.dashboard-container .charts-layout .chart-card .card-header .refresh-btn.spinning svg{animation:spin 1s linear infinite}.dashboard-container .charts-layout .chart-card .card-content{flex:1;position:relative;min-height:0}.dashboard-container .charts-layout .chart-card .card-content .loading-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.alert-dialog-overlay{background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000!important}.alert-dialog-overlay[data-state=open]{animation:overlayShow .15s cubic-bezier(.16,1,.3,1) forwards}.alert-dialog-content{background-color:var(--bg-elev);border:1px solid var(--line);color:var(--text);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;padding:24px;width:90%;max-width:450px;z-index:2001!important;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.alert-dialog-content[data-state=open]{animation:contentShow .15s cubic-bezier(.16,1,.3,1) forwards}.alert-dialog-content h2{color:var(--text);margin-bottom:8px}.alert-dialog-content p{color:var(--muted);line-height:1.5;margin-bottom:24px}.alert-dialog-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}@keyframes overlayShow{0%{opacity:0}to{opacity:1}}@keyframes contentShow{0%{opacity:0;transform:translate(-50%,-48%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.btn-primary{display:inline-flex;align-items:center;justify-content:center;border-radius:6px;font-size:14px;font-weight:500;height:40px;padding:0 16px;background-color:var(--accent);color:#fff;transition:all .2s;border:none;cursor:pointer}.btn-primary:hover{opacity:.9}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;border-radius:6px;font-size:14px;font-weight:500;height:40px;padding:0 16px;background-color:transparent;color:var(--text);transition:all .2s;border:1px solid var(--line);cursor:pointer;margin-right:12px}.btn-ghost:hover{background-color:#ffffff0d}.tooltip-content{background-color:var(--bg-elev);border:1px solid var(--line);color:var(--text);font-size:12px;max-width:300px;line-height:1.4;z-index:1000}.tooltip-content[data-state=delayed-open][data-side=top]{animation-name:slideDownAndFade}.tooltip-content[data-state=delayed-open][data-side=right]{animation-name:slideLeftAndFade}.tooltip-content[data-state=delayed-open][data-side=bottom]{animation-name:slideUpAndFade}.tooltip-content[data-state=delayed-open][data-side=left]{animation-name:slideRightAndFade}@keyframes slideUpAndFade{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}@keyframes slideRightAndFade{0%{opacity:0;transform:translate(-2px)}to{opacity:1;transform:translate(0)}}@keyframes slideDownAndFade{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}@keyframes slideLeftAndFade{0%{opacity:0;transform:translate(2px)}to{opacity:1;transform:translate(0)}}.project-audit-page .loading-state,.project-audit-page .empty-state{padding:40px;text-align:center;color:var(--muted)}.project-audit-page .table-wrapper{overflow-x:auto;width:100%}.project-audit-page .audit-table{min-width:2000px;table-layout:fixed;width:100%}.project-audit-page .audit-table th.col-name-zh,.project-audit-page .audit-table th.col-name-en{width:180px}.project-audit-page .audit-table th.col-desc{width:250px}.project-audit-page .audit-table th.col-link{width:200px}.project-audit-page .audit-table th.col-author{width:200px;text-align:center}.project-audit-page .audit-table th.col-product-img{width:160px}.project-audit-page .audit-table th.col-qr{width:120px}.project-audit-page .audit-table th.col-email{width:180px}.project-audit-page .audit-table th.col-repo{width:150px}.project-audit-page .audit-table th.col-cat-tag,.project-audit-page .audit-table th.col-stack{width:200px}.project-audit-page .audit-table th.col-date{width:150px}.project-audit-page .audit-table th.col-action{width:180px}.project-audit-page .col-sticky-left{position:sticky;left:0;background:var(--bg-elev);z-index:20}.project-audit-page .col-sticky-right{position:sticky;right:0;background:var(--bg-elev);z-index:10}.project-audit-page .cell-text-bold{font-weight:600;color:var(--text)}.project-audit-page .cell-text-muted{color:var(--muted)}.project-audit-page .cell-description{max-width:230px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-audit-page .link-with-icon{display:flex;align-items:center;gap:8px;color:var(--accent);text-decoration:none}.project-audit-page .link-with-icon:hover{text-decoration:underline}.project-audit-page .author-info{display:flex;align-items:center;justify-content:center;gap:8px;height:100%}.project-audit-page .author-info img{width:24px;height:24px;border-radius:50%}.project-audit-page .cell-product-img,.project-audit-page .cell-qr-img{width:40px;height:40px;object-fit:cover;border-radius:4px;border:1px solid var(--line)}.project-audit-page .cell-images-wrapper{display:flex;gap:4px;flex-wrap:wrap;align-items:center}.project-audit-page .cell-tags-wrapper{display:flex;flex-direction:column;gap:4px;align-items:flex-start}.project-audit-page .cell-tags-wrapper .tags-list{display:flex;flex-wrap:wrap;gap:4px}.project-audit-page .cell-tags-wrapper .badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:12px;font-weight:500;white-space:nowrap}.project-audit-page .cell-tags-wrapper .badge.badge-category{background:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.2)}.project-audit-page .cell-tags-wrapper .badge-tag{display:inline-flex;align-items:center;padding:2px 6px;border-radius:4px;font-size:11px;background:var(--bg-surface);border:1px solid var(--line);color:var(--text-secondary)}.project-audit-page .cell-stack-wrapper{display:flex;flex-direction:column;gap:4px;font-size:12px}.project-audit-page .cell-stack-wrapper .stack-row{display:flex;align-items:flex-start;gap:4px}.project-audit-page .cell-stack-wrapper .stack-label{color:var(--muted);margin-right:2px}.project-audit-page .action-buttons{display:flex;gap:8px;align-items:center;justify-content:center}.project-audit-page .action-buttons .btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid var(--line);background:transparent;color:var(--text);cursor:pointer;transition:all .2s}.project-audit-page .action-buttons .btn-icon:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.project-audit-page .action-buttons .btn-icon.reject:hover{border-color:#ef4444;color:#ef4444;background:#ef44441a}.project-audit-page .action-buttons .btn-icon.approve:hover{border-color:#22c55e;color:#22c55e;background:#22c55e1a}.image-preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}.image-preview-overlay .image-preview-content{position:relative;max-width:90vw;max-height:90vh}.image-preview-overlay .image-preview-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 4px 20px #00000080}.image-preview-overlay .image-preview-content .close-preview{position:absolute;top:-40px;right:0;width:32px;height:32px;background:#fff3;border:none;border-radius:50%;color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.image-preview-overlay .image-preview-content .close-preview:hover{background:#fff6}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.image-upload-container{display:flex;flex-wrap:wrap;gap:8px}.image-upload-item{position:relative;width:100px;height:100px;border-radius:8px;overflow:hidden;border:1px solid var(--line);padding:4px;background:var(--bg-card)}.image-upload-item img{width:100%;height:100%;object-fit:cover;border-radius:4px}.image-upload-item .image-upload-mask{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;border-radius:8px}.image-upload-item:hover .image-upload-mask{opacity:1}.image-upload-item .remove-btn{width:24px;height:24px;border-radius:50%;background:transparent;color:#fff;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .2s}.image-upload-item .remove-btn:hover{background:#fff3;transform:scale(1.1)}.image-upload-trigger{width:100px;height:100px;border-radius:8px;border:1px dashed var(--line);background:var(--bg-card);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);transition:all .2s}.image-upload-trigger:hover{border-color:var(--accent);color:var(--accent);background:var(--bg-hover)}.image-upload-trigger .trigger-text{font-size:12px;margin-top:8px;color:var(--text-secondary)}.submit-modal{max-width:600px;width:90%;display:flex;flex-direction:column;max-height:85vh}.submit-modal .modal-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.review-state{display:flex;flex-direction:column;height:100%;overflow:hidden}.submit-modal__content-scroll{flex:1;overflow-y:auto;padding-right:.5rem;margin-bottom:.5rem}.submit-modal__mobile{text-align:center;padding:2rem 1rem}.submit-modal__mobile-icon{margin:0 auto 1rem;color:var(--accent)}.submit-modal__mobile-desc{color:var(--muted);margin-top:.5rem}.submit-modal__error{margin-top:1rem;color:var(--accent-2);display:flex;align-items:center;gap:.5rem}.submit-modal__help-btn{background:none;border:none;padding:0;margin-top:.5rem;font-size:.85rem;color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:.3rem;text-decoration:underline;transition:color .2s}.submit-modal__help-btn:hover{color:var(--accent)}.submit-modal__guide{margin-top:1rem;padding:1rem;background:var(--bg);border:1px dashed var(--line);border-radius:8px;font-size:.85rem}.submit-modal__guide-item{margin-bottom:.8rem}.submit-modal__guide-item:last-child{margin-bottom:0}.submit-modal__guide-item h4{margin:0 0 .2rem;font-size:.9rem;color:var(--text)}.submit-modal__guide-item p{margin:0;color:var(--muted);line-height:1.4}.submit-modal__helper{margin-top:.5rem;font-size:.85rem;color:var(--muted);display:flex;align-items:center;gap:.4rem}.submit-modal__helper-icon{display:inline-block;vertical-align:-2px}.submit-modal__loader{color:var(--accent)}.submit-modal__safety-logs{margin-top:1.5rem;text-align:left;background:var(--bg);padding:1rem;border-radius:8px;font-size:.9rem;font-family:monospace}.submit-modal__safety-log{margin-bottom:.5rem;color:var(--muted);display:flex;align-items:center;gap:.5rem}.submit-modal__safety-log.is-done{color:var(--success)}.submit-modal__safety-log.is-active{color:var(--muted)}.submit-modal__safety-icon{color:var(--success);flex:0 0 12px}.submit-modal__safety-icon-placeholder{width:12px;height:12px;flex:0 0 12px}.submit-modal__safety-text{white-space:nowrap}.submit-modal__wizard-steps{display:flex;align-items:center;justify-content:center;gap:1rem}.submit-modal__wizard-step{display:flex;align-items:center;gap:.5rem}.submit-modal__wizard-circle{width:28px;height:28px;border-radius:50%;background:var(--line);color:var(--muted);display:grid;place-items:center;font-size:.9rem;font-weight:700}.submit-modal__wizard-circle.is-active{background:var(--accent);color:#fff}.submit-modal__wizard-line{width:40px;height:2px;background:var(--line)}.submit-modal__wizard-line.is-active{background:var(--accent)}.submit-modal__step{margin-bottom:1.5rem}.submit-modal__step-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.submit-modal__step-title{margin-bottom:1rem;font-size:1.2rem}.submit-modal__fields{display:flex;flex-direction:column;gap:1rem}.submit-modal__field{display:flex;flex-direction:column}.submit-modal__label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:.3rem}.submit-modal__required{color:var(--accent-2)}.submit-modal__input,.submit-modal__textarea,.submit-modal__select{width:100%;padding:.5rem;background:var(--bg-elev);border:1px solid var(--line);color:var(--text);border-radius:8px}.submit-modal__input:disabled{opacity:.6;cursor:not-allowed}.submit-modal__textarea{min-height:80px;resize:vertical}.submit-modal__input.is-error,.submit-modal__textarea.is-error,.submit-modal__select.is-error{border-color:var(--accent-2)}.submit-modal__error-text{color:var(--accent-2);font-size:.75rem;margin-top:.3rem}.submit-modal__row{display:flex;gap:1rem}.submit-modal__row.is-stacked{flex-direction:column}.submit-modal__tags{position:relative}.submit-modal__tags-display{cursor:default}.submit-modal__tags-options{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem;border:1px solid var(--line);background:var(--bg);max-height:120px;overflow-y:auto;border-radius:8px}.submit-modal__tag-option{padding:.2rem .6rem;font-size:.8rem;background:var(--bg-elev);color:var(--text);border:1px solid var(--line);border-radius:8px;cursor:pointer;transition:all .2s}.submit-modal__tag-option.is-selected{background:var(--accent);color:#fff}.submit-modal__upload{border:2px dashed var(--line);border-radius:8px;padding:1.5rem;text-align:center;cursor:pointer;background:var(--bg);height:100px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.submit-modal__upload.has-preview{padding:0}.submit-modal__upload-preview{width:100%;height:100%;object-fit:cover}.submit-modal__upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--muted)}.submit-modal__upload-input{display:none}.submit-modal__upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;gap:.5rem;color:#fff;font-size:.9rem;opacity:0;transition:opacity .2s}.submit-modal__upload.has-preview:hover .submit-modal__upload-overlay{opacity:1}.submit-modal__logo-upload .image-upload-item,.submit-modal__logo-upload .image-upload-trigger{width:48px!important;height:48px!important}.submit-modal__logo-upload .image-upload-item img{object-fit:fill!important}.submit-modal__logo-upload .trigger-text{display:none}.submit-modal__multi-select{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem;border:1px solid var(--line);background:var(--bg);border-radius:8px}.submit-modal__multi-select.is-error{border-color:var(--accent-2)}.submit-modal__multi-select--single{flex-wrap:nowrap}.submit-modal__multi-select--single .submit-modal__option{flex:1;text-align:center}.submit-modal__option{padding:.2rem .6rem;font-size:.8rem;background:var(--bg-elev);color:var(--text);border:1px solid var(--line);border-radius:8px;cursor:pointer}.submit-modal__option.is-selected{background:var(--accent);color:#fff}.submit-modal__verification{margin-bottom:1.5rem}.submit-modal__verification-text{font-size:.85rem;color:var(--muted);margin-bottom:.5rem}.submit-modal__code-wrap{position:relative}.submit-modal__code{display:block;padding:.8rem 4rem .8rem .8rem;background:var(--bg);border-radius:8px;font-size:.8rem;word-break:break-all}.submit-modal__copy-btn{position:absolute;top:50%;right:.5rem;transform:translateY(-50%);background:var(--bg-elev);border:1px solid var(--line);border-radius:8px;padding:.4rem;cursor:pointer;color:var(--text);display:flex;align-items:center;gap:.3rem;font-size:.75rem}.submit-modal__copy-btn.is-copied{color:var(--success)}.submit-modal__token-hint{font-size:.75rem;color:var(--accent-2);margin-top:.5rem}.submit-modal__qr{margin-bottom:1.5rem;border:2px dashed var(--line);padding:1rem;text-align:center;border-radius:8px}.submit-modal__qr-text{font-size:.9rem;color:var(--muted)}.submit-modal__qr-btn{margin-top:.5rem}.submit-modal__actions{display:flex;gap:1rem;justify-content:flex-end}.submit-modal__global-pending-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:3200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;pointer-events:all;cursor:wait}.submit-modal__pending-loader{color:var(--accent)}.submit-modal__pending-text{margin:0;font-size:.9rem;color:var(--text)}.submit-modal__confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2500;display:flex;align-items:center;justify-content:center;padding:1rem}.submit-modal__confirm{width:min(520px,92vw);background:var(--bg-elev);border:2px solid var(--line);box-shadow:10px 10px 0 var(--line);padding:1.2rem}.submit-modal__confirm-title{margin:0 0 .6rem;font-size:1.1rem}.submit-modal__confirm-body{color:var(--text);font-size:.9rem;line-height:1.45}.submit-modal__confirm-body p{margin:0 0 .6rem;color:var(--muted)}.submit-modal__confirm-list{margin:0 0 .6rem 1.2rem;padding:0;color:var(--muted)}.submit-modal__captcha-wrap{margin-top:1rem}.submit-modal__captcha-placeholder{display:flex;align-items:flex-start;gap:.75rem;padding:.9rem 1rem;margin-bottom:.85rem;border:1.5px dashed var(--line);background:var(--bg)}.submit-modal__captcha-placeholder.is-error{border-color:var(--accent-2);background:color-mix(in srgb,var(--accent-2) 8%,var(--bg))}.submit-modal__captcha-placeholder-icon{width:2rem;height:2rem;display:grid;place-items:center;border-radius:999px;border:1.5px solid var(--line);color:var(--accent);flex-shrink:0}.submit-modal__captcha-placeholder.is-error .submit-modal__captcha-placeholder-icon{color:var(--accent-2);border-color:var(--accent-2)}.submit-modal__captcha-placeholder-content{flex:1;min-width:0}.submit-modal__captcha-placeholder-title{font-size:.9rem;font-weight:700;color:var(--text)}.submit-modal__captcha-widget{min-height:65px;display:flex;align-items:center;justify-content:center}.submit-modal__captcha-status{margin:.35rem 0 0;font-size:.82rem;line-height:1.45;color:var(--muted)}.submit-modal__captcha-status.is-error{color:var(--accent-2)}.submit-modal__confirm-actions{display:flex;justify-content:flex-end;gap:.8rem;margin-top:1rem}.submit-modal__success{text-align:center;padding:2rem 0}.submit-modal__success-icon{width:80px;height:80px;border-radius:50%;background:var(--bg);border:2px solid var(--text);display:grid;place-items:center;margin:0 auto 1.5rem;box-shadow:4px 4px 0 var(--accent);color:var(--accent)}.submit-modal__success-title{font-size:1.5rem;margin-bottom:.5rem}.submit-modal__success-desc{color:var(--muted)}.magic-input-form{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.magic-input-form .input-group{display:flex;align-items:stretch;gap:.5rem;position:relative}.magic-input-form .input-group input{flex:1;padding:.8rem 1rem;background:var(--bg);border:2px solid var(--line);color:var(--text);font-size:1rem;outline:none;transition:all .2s;height:auto}.magic-input-form .input-group button{height:auto;white-space:nowrap;display:flex;align-items:center;gap:.5rem}
