@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--bg: #fafafa;--surface: #ffffff;--surface-hover: #f5f5f5;--border: #e5e5e5;--border-light: #d4d4d4;--text: #18181b;--text-secondary: #52525b;--text-muted: #a1a1aa;--primary: #f59e0b;--primary-hover: #d97706;--primary-light: #fbbf24;--primary-bg: rgba(245, 158, 11, .08);--primary-bg-strong: rgba(245, 158, 11, .15);--success: #22c55e;--success-bg: rgba(34, 197, 94, .08);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .08);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .08);--radius: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .08)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--primary-hover);text-decoration:none}a:hover{color:var(--primary)}.app-layout{display:flex;min-height:100vh;background-color:var(--bg);background-image:radial-gradient(var(--border-light) 1px,transparent 1px);background-size:24px 24px;position:relative}[data-theme=dark]{--bg: #09090b;--surface: #18181b;--surface-hover: #27272a;--border: #27272a;--border-light: #3f3f46;--text: #f4f4f5;--text-secondary: #a1a1aa;--text-muted: #71717a;--primary: #f59e0b;--primary-hover: #d97706;--primary-light: #fbbf24;--primary-bg: rgba(245, 158, 11, .15);--primary-bg-strong: rgba(245, 158, 11, .25);--success: #22c55e;--success-bg: rgba(34, 197, 94, .15);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .15);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .15);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 2px 8px rgba(0, 0, 0, .6);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .8)}.sidebar{width:260px;background:var(--surface);border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:0 12px;margin-bottom:32px}.sidebar-logo-icon{width:32px;height:32px;border-radius:8px;background:var(--primary);color:#fff;font-size:16px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #f59e0b33}.sidebar-logo-text{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.5px}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:4px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:var(--text-secondary);font-size:14px;font-weight:500;transition:all .2s;cursor:pointer;border:none;background:none;width:100%;text-align:left;position:relative}.sidebar-link:hover{background:var(--surface-hover);color:var(--text)}.sidebar-link.active{background:var(--primary-bg);color:var(--primary-hover);font-weight:600}.active-indicator{position:absolute;left:0;top:10px;bottom:10px;width:3px;background:var(--primary);border-radius:0 4px 4px 0}.sidebar-footer{padding-top:16px;border-top:1px solid var(--border);margin-top:auto}.sidebar-user-card{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg);border-radius:12px;border:1px solid transparent;transition:all .2s}.sidebar-user-card:hover{border-color:var(--border);background:var(--surface-hover)}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:#fff;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s}.logout-btn:hover{color:var(--danger);border-color:var(--danger-bg);background:var(--danger-bg)}.main-content{flex:1;margin-left:260px;padding:32px 40px;min-height:100vh}.mobile-header{display:none;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:90;margin:-32px -40px 32px}.mobile-header-logo{font-weight:700;font-size:18px;display:flex;align-items:center;gap:8px;color:var(--text)}.menu-toggle{background:none;border:none;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:95;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media(max-width:768px){.mobile-header{display:flex;margin:-20px -16px 24px}.sidebar{transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar.open{transform:translate(0)}.sidebar-overlay.open{display:block}.mobile-close-btn{display:flex!important}.main-content{margin-left:0;padding:20px 16px}.page-header{flex-wrap:wrap;gap:8px}.page-title{font-size:24px}.tabs{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.tabs::-webkit-scrollbar{display:none}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;transition:transform .2s ease,box-shadow .2s ease}.card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000000d,0 4px 6px -2px #00000006}.card-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:16px;font-weight:600}.card-body{padding:24px}.comments-layout{display:flex;gap:24px}.comments-sidebar{width:260px;flex-shrink:0}@media(max-width:768px){.comments-layout{flex-direction:column}.comments-sidebar{width:100%}}.page-header{margin-bottom:32px}.page-title{font-size:28px;font-weight:700;margin-bottom:4px}.page-subtitle{font-size:14px;color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);transition:all .2s}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.stat-label{font-size:12px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-value{font-size:28px;font-weight:700}.stat-value.primary{color:var(--primary)}.stat-value.success{color:var(--success)}.stat-value.danger{color:var(--danger)}.stat-value.warning{color:var(--warning)}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.project-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 8px 24px #f59e0b1f}.project-card-name{font-size:18px;font-weight:600;margin-bottom:4px}.project-card-url{font-size:13px;color:var(--text-muted);margin-bottom:16px}.project-card-stats{display:flex;gap:16px}.project-card-stat{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.project-card-stat .dot{width:8px;height:8px;border-radius:50%}.dot.open{background:var(--primary)}.dot.resolved{background:var(--success)}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border:none;border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.btn-primary{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff;box-shadow:0 2px 8px #f59e0b40}.btn-primary:hover{background:linear-gradient(135deg,#d97706,#f59e0b);box-shadow:0 4px 12px #f59e0b59;transform:translateY(-1px)}.btn-secondary{background:var(--surface-hover);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-light)}.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:6px 12px;font-size:12px}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--surface-hover);color:var(--text)}.input-group{margin-bottom:16px}.input-label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.input{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.input::placeholder{color:var(--text-muted)}.comment-list{display:flex;flex-direction:column;gap:12px}.comment-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;transition:all .15s;box-shadow:var(--shadow-sm)}.comment-item:hover{border-color:var(--border-light);box-shadow:var(--shadow)}.comment-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.comment-author{display:flex;align-items:center;gap:8px}.comment-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.comment-author-name{font-size:13px;font-weight:600}.comment-date{font-size:11px;color:var(--text-muted)}.comment-text{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:12px}.comment-meta{display:flex;align-items:center;gap:12px}.comment-page{font-size:12px;color:var(--text-muted);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.badge-open{background:var(--primary-bg);color:var(--primary-hover)}.badge-resolved{background:var(--success-bg);color:var(--success)}.reply-list{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.reply-item{padding-left:20px;border-left:2px solid var(--primary-bg-strong)}.modal-overlay{position:fixed;inset:0;background:#0000004d;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:480px;max-width:90vw;overflow:hidden;box-shadow:var(--shadow-lg)}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:16px;font-weight:600}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fffbeb,#fef3c7,#fafafa)}.auth-card{width:400px;max-width:90vw}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff;font-size:22px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 4px 16px #f59e0b4d}.auth-title{font-size:24px;font-weight:700}.auth-subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px}.auth-toggle{text-align:center;margin-top:20px;font-size:13px;color:var(--text-muted)}.auth-toggle a{color:var(--primary-hover);cursor:pointer;font-weight:600}.error-msg{padding:10px 14px;background:var(--danger-bg);color:var(--danger);border-radius:var(--radius);font-size:13px;margin-bottom:16px}.page-list{display:flex;flex-direction:column;gap:4px;margin-bottom:24px}.page-item{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius);cursor:pointer;font-size:13px;color:var(--text-secondary);transition:all .15s}.page-item:hover{background:var(--surface-hover)}.notification-bell-wrapper{display:flex;align-items:center;justify-content:center}.notif-badge{position:absolute;top:-2px;right:-2px;background:var(--danger);color:#fff;font-size:9px;font-weight:700;min-width:14px;height:14px;border-radius:7px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid var(--surface)}.notif-dropdown{position:absolute;bottom:40px;left:0;width:320px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;z-index:1000;max-height:400px}.notif-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg)}.notif-title{font-size:13px;font-weight:600;color:var(--text)}.notif-action{font-size:11px;color:var(--primary);background:none;border:none;cursor:pointer}.notif-action:hover{text-decoration:underline}.notif-list{overflow-y:auto;max-height:320px}.notif-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-light);cursor:pointer;transition:all .15s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--surface-hover)}.notif-item.unread{background:var(--primary-bg)}.notif-icon{margin-top:2px;color:var(--primary)}.notif-content{flex:1}.notif-text{font-size:13px;color:var(--text);line-height:1.4;margin-bottom:4px}.notif-time{font-size:11px;color:var(--text-muted)}.notif-dot{width:6px;height:6px;border-radius:50%;background:var(--primary);margin-top:6px}.notif-empty{padding:24px;text-align:center;color:var(--text-muted);font-size:13px}.notif-loading{padding:16px;text-align:center;font-size:12px;color:var(--text-muted)}.members-list{display:flex;flex-direction:column;gap:8px}.member-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg);border-radius:var(--radius)}.member-info{display:flex;align-items:center;gap:10px}.member-name{font-size:14px;font-weight:500}.member-email{font-size:12px;color:var(--text-muted)}.member-role{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--primary-hover)}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:24px}.tab{padding:10px 20px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;transition:all .15s;font-family:inherit}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--primary-hover);border-bottom-color:var(--primary)}.api-key-box{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-family:SF Mono,Fira Code,monospace;font-size:13px;color:var(--text-secondary)}.api-key-box code{flex:1;word-break:break-all}.share-link-box{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg);border-radius:var(--radius);margin-bottom:8px}.share-link-box code{flex:1;font-size:12px;color:var(--text-secondary);word-break:break-all}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--text-muted);font-size:14px}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.3}.empty-state-title{font-size:16px;font-weight:600;color:var(--text-secondary);margin-bottom:4px}.empty-state-desc{font-size:13px}.select{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;font-family:inherit;outline:none;cursor:pointer;appearance:none}.select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.landing-page{min-height:100vh;background:#fff;overflow-x:hidden}.landing-nav{display:flex;align-items:center;justify-content:space-between;padding:20px 48px;position:fixed;top:0;left:0;right:0;z-index:100;background:#ffffffd9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(0,0,0,.04)}.landing-nav-logo{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:800;color:var(--text)}.landing-nav-logo-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff;font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:center}.landing-hero{display:flex;align-items:center;justify-content:center;flex-direction:column;min-height:100vh;padding:120px 48px 80px;text-align:center;position:relative}.landing-hero-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;background:var(--primary-bg);border:1px solid rgba(245,158,11,.15);border-radius:100px;font-size:13px;font-weight:600;color:var(--primary-hover);margin-bottom:24px;animation:fadeUp .6s ease-out}.landing-hero h1{font-size:64px;font-weight:900;line-height:1.05;letter-spacing:-2px;margin-bottom:20px;animation:fadeUp .6s ease-out .1s both}.landing-hero h1 .highlight{background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-hero-sub{font-size:18px;color:var(--text-secondary);max-width:520px;line-height:1.7;margin-bottom:36px;animation:fadeUp .6s ease-out .2s both}.landing-hero-cta{display:flex;gap:12px;animation:fadeUp .6s ease-out .3s both}.landing-cta-btn{padding:14px 32px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit;border:none;text-decoration:none}.landing-cta-primary{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff;box-shadow:0 4px 20px #f59e0b4d}.landing-cta-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px #f59e0b66}.landing-cta-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.landing-cta-secondary:hover{border-color:var(--primary);background:var(--primary-bg)}.landing-preview{margin-top:64px;perspective:1200px;animation:fadeUp .8s ease-out .4s both}.landing-preview-window{width:800px;max-width:85vw;background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 32px 80px #0000001f,0 0 0 1px #0000000a;transform:rotateX(6deg) rotateY(-3deg);transition:transform .4s ease}.landing-preview-window:hover{transform:rotateX(2deg) rotateY(-1deg) translateY(-4px)}.landing-preview-titlebar{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--bg);border-bottom:1px solid var(--border)}.landing-preview-dot{width:10px;height:10px;border-radius:50%}.landing-preview-dot.red{background:#ef4444}.landing-preview-dot.yellow{background:#fbbf24}.landing-preview-dot.green{background:#22c55e}.landing-preview-content{padding:24px;min-height:300px;display:flex;flex-direction:column;gap:16px}.preview-comment-pin{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:var(--bg);border-radius:var(--radius);animation:shimmer 3s infinite}.preview-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#fbbf24);flex-shrink:0}.preview-line{height:10px;border-radius:4px;background:var(--border)}.preview-line-short{width:80px}.preview-line-med{width:160px;margin-top:6px}.preview-line-long{width:240px;margin-top:6px}.landing-dots{position:absolute;inset:0;pointer-events:none;overflow:hidden}.landing-dot{position:absolute;border-radius:50%;background:#f59e0b1f;animation:floatDot linear infinite}.landing-features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1000px;margin:0 auto;padding:80px 48px}.landing-feature{padding:32px;background:var(--surface);border:1px solid var(--border);border-radius:16px;text-align:center;transition:all .2s}.landing-feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary)}.landing-feature-icon{width:48px;height:48px;border-radius:14px;background:var(--primary-bg);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 16px}.landing-feature h3{font-size:16px;font-weight:700;margin-bottom:8px}.landing-feature p{font-size:13px;color:var(--text-secondary);line-height:1.6}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%,to{opacity:1}50%{opacity:.7}}@keyframes floatDot{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-10vh) scale(1);opacity:0}}@keyframes spin{to{transform:rotate(360deg)}}.typewriter-btn{display:inline-flex;align-items:center;justify-content:center;font-family:Space Mono,Fira Code,Courier New,monospace;font-weight:700;font-size:15px;letter-spacing:-.5px;background:#18181b;color:#f59e0b;border:2px solid #18181b;box-shadow:4px 4px #f59e0b;border-radius:8px;padding:12px 24px;cursor:pointer;transition:all .1s ease-in-out;text-transform:lowercase}.typewriter-btn.secondary{background:#fff;color:#18181b;border:2px solid #18181b;box-shadow:4px 4px #18181b}.typewriter-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px #f59e0b}.typewriter-btn.secondary:hover{box-shadow:6px 6px #18181b}.typewriter-btn:active{transform:translate(4px,4px);box-shadow:0 0 #f59e0b}.typewriter-btn.secondary:active{box-shadow:0 0 #18181b}.typewriter-content{display:flex;align-items:center;gap:8px;position:relative}.typewriter-icon{display:flex;align-items:center;opacity:.8}.typewriter-text{min-width:1ch;display:inline-block}.typewriter-cursor{display:inline-block;color:inherit;margin-left:2px;font-weight:900}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.typewriter-cursor.blinking{animation:blink-cursor 1s step-end infinite}.typewriter-cursor.typing{opacity:1}
