.sidebar{background-color:#161b22;border-right:1px solid #30363d;flex-direction:column;width:240px;height:100vh;padding:1.25rem 0;display:flex;position:fixed;top:0;left:0}.sidebar-logo{margin-bottom:1.5rem;padding:0 1.25rem}.sidebar-logo-text{color:#e6edf3;font-family:Instrument Serif,serif;font-size:1.35rem}.sidebar-logo-accent{color:#3fb950;margin-left:.25rem;font-family:Instrument Serif,serif;font-size:1.35rem}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:0 .75rem;display:flex}.sidebar-link{color:#8b949e;border-radius:6px;align-items:center;gap:.625rem;padding:.5rem .625rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background-color .15s,color .15s;display:flex}.sidebar-link:hover{color:#e6edf3;background-color:#1f2937}.sidebar-link.active{color:#3fb950;background-color:#3fb9501a}.sidebar-footer{border-top:1px solid #30363d;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem 1.25rem;display:flex}.sidebar-user{color:#8b949e;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.sidebar-logout{color:#8b949e;cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;padding:.25rem;transition:color .15s,background-color .15s;display:flex}.sidebar-logout:hover{color:#f85149;background-color:#f851491a}.bottom-nav{z-index:50;background-color:#161b22;border-top:1px solid #30363d;justify-content:space-around;align-items:center;height:56px;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-link{color:#8b949e;border-radius:6px;flex-direction:column;align-items:center;gap:.2rem;padding:.375rem 1rem;font-size:.6875rem;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.bottom-nav-link.active{color:#3fb950}.app-layout{background-color:#0d1117;min-height:100vh}.app-content{max-width:960px;margin:0 auto;padding:2rem 1.5rem}.app-sidebar{display:none}.app-bottom-nav{display:block}@media (width<=767px){.app-content{padding-bottom:5rem}}@media (width>=768px){.app-sidebar{display:block}.app-bottom-nav{display:none}.app-content{margin-left:240px}}.login-container{background-color:#0d1117;justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-form{flex-direction:column;width:100%;max-width:380px;display:flex}.login-logo{text-align:center;margin-bottom:.25rem}.login-logo-text{color:#e6edf3;font-family:Instrument Serif,serif;font-size:2rem}.login-logo-accent{color:#3fb950;margin-left:.35rem;font-family:Instrument Serif,serif;font-size:2rem}.login-subtitle{text-align:center;color:#8b949e;margin-bottom:2rem;font-size:.875rem}.login-error{color:#f85149;background-color:#f851491a;border:1px solid #f8514966;border-radius:6px;margin-bottom:1rem;padding:.625rem .75rem;font-size:.8125rem}.login-label{color:#e6edf3;margin-bottom:.375rem;font-size:.8125rem;font-weight:500}.login-input{color:#e6edf3;background-color:#161b22;border:1px solid #30363d;border-radius:6px;outline:none;margin-bottom:1rem;padding:.625rem .75rem;font-family:DM Sans,sans-serif;font-size:.875rem;transition:border-color .15s}.login-input::placeholder{color:#484f58}.login-input:focus{border-color:#3fb950;box-shadow:0 0 0 2px #3fb95026}.login-button{color:#0d1117;cursor:pointer;background-color:#3fb950;border:none;border-radius:6px;margin-top:.5rem;padding:.625rem;font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:600;transition:background-color .15s}.login-button:hover{background-color:#2ea043}.login-button:disabled{opacity:.6;cursor:not-allowed}.overview{max-width:1200px;padding:1.5rem}.overview-header{margin-bottom:2rem}.overview-greeting{color:#8b949e;margin-top:.25rem;font-size:.875rem}.overview-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;display:grid}.project-card{cursor:pointer;background-color:#161b22;border:1px solid #30363d;border-radius:8px;padding:1.25rem;transition:border-color .15s,background-color .15s}.project-card:hover{background-color:#1c2333;border-color:#3fb950}.project-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.project-card-info{min-width:0}.project-card-name{color:#e6edf3;white-space:nowrap;text-overflow:ellipsis;font-size:1rem;font-weight:600;overflow:hidden}.project-card-url{color:#8b949e;white-space:nowrap;text-overflow:ellipsis;margin-top:.125rem;font-size:.75rem;display:block;overflow:hidden}.project-card-health{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:.375rem;margin-left:.75rem}.project-card-metrics{gap:1.5rem;margin-bottom:1rem;display:flex}.project-card-metric{flex-direction:column;display:flex}.metric-value{color:#e6edf3;font-size:1.25rem;font-weight:700;line-height:1.2}.metric-label{color:#8b949e;text-transform:uppercase;letter-spacing:.04em;font-size:.7rem}.project-card-footer{border-top:1px solid #21262d;padding-top:.75rem}.project-card-last-event{color:#8b949e;font-size:.75rem}.overview-empty{text-align:center;color:#8b949e;padding:4rem 1rem}.overview-empty a{color:#3fb950;text-decoration:none}.overview-empty a:hover{text-decoration:underline}.project-card.skeleton{cursor:default;pointer-events:none}.skeleton-line{background:linear-gradient(90deg,#21262d 25%,#30363d 50%,#21262d 75%) 0 0/200% 100%;border-radius:4px;animation:1.5s ease-in-out infinite shimmer}.skeleton-title{width:60%;height:16px;margin-bottom:.5rem}.skeleton-url{width:40%;height:12px;margin-bottom:1rem}.skeleton-metrics{gap:1.5rem;margin-bottom:1rem;display:flex}.skeleton-metric{width:50px;height:32px}.skeleton-footer{border-top:none;width:50%;height:12px;margin-top:.75rem}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (width<=767px){.overview{padding:1rem}.overview-grid{grid-template-columns:1fr}}.project-detail{max-width:1200px;padding:1.5rem}.detail-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.detail-url{color:#8b949e;font-size:.8rem}.detail-range{border:1px solid #30363d;border-radius:6px;gap:0;display:flex;overflow:hidden}.range-btn{color:#8b949e;cursor:pointer;background:0 0;border:none;padding:.4rem .85rem;font-family:DM Sans,sans-serif;font-size:.8rem;transition:background-color .15s,color .15s}.range-btn:not(:last-child){border-right:1px solid #30363d}.range-btn:hover{color:#e6edf3;background-color:#21262d}.range-btn-active{color:#0d1117;background-color:#3fb950;font-weight:600}.range-btn-active:hover{color:#0d1117;background-color:#3fb950}.stats-grid{grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem;display:grid}.stat-card{background-color:#161b22;border:1px solid #30363d;border-radius:8px;flex-direction:column;padding:1.25rem;display:flex}.stat-value{color:#e6edf3;font-size:1.75rem;font-weight:700;line-height:1.2}.stat-label{color:#8b949e;text-transform:uppercase;letter-spacing:.04em;margin-top:.25rem;font-size:.75rem}.detail-section{margin-bottom:2rem}.section-title{color:#e6edf3;margin-bottom:1rem;font-size:1rem;font-weight:600}.chart-container{background-color:#161b22;border:1px solid #30363d;border-radius:8px;padding:1rem 1rem .5rem}.detail-table-wrap{overflow-x:auto}.detail-table{border-collapse:collapse;width:100%}.detail-table th{text-align:left;color:#8b949e;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #21262d;padding:.5rem .75rem;font-size:.7rem;font-weight:600}.detail-table td{border-bottom:1px solid #161b22;padding:.6rem .75rem;font-size:.85rem}.detail-table tbody tr:hover{background-color:#161b22}.cell-url{color:#e6edf3;white-space:nowrap;text-overflow:ellipsis;max-width:400px;overflow:hidden}.cell-count{color:#8b949e;text-align:right;white-space:nowrap}.detail-table th:last-child{text-align:right}.errors-list{flex-direction:column;gap:.5rem;display:flex}.error-item{background-color:#161b22;border:1px solid #30363d;border-radius:6px;overflow:hidden}.error-header{cursor:pointer;justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:background-color .15s;display:flex}.error-header:hover{background-color:#1c2333}.error-info{flex-direction:column;gap:.25rem;min-width:0;display:flex}.error-message{color:#f85149;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.error-meta{color:#8b949e;gap:.75rem;font-size:.75rem;display:flex}.error-toggle{color:#8b949e;flex-shrink:0;font-size:.85rem;transition:transform .15s}.error-toggle-open{transform:rotate(90deg)}.error-stack{color:#8b949e;white-space:pre-wrap;word-break:break-all;background-color:#0d1117;border-top:1px solid #21262d;margin:0;padding:.75rem 1rem;font-family:SFMono-Regular,Consolas,monospace;font-size:.75rem;line-height:1.6;overflow-x:auto}.detail-empty{text-align:center;color:#8b949e;padding:4rem 1rem}.detail-loading{animation:.3s fadeIn}.stat-card.skeleton{pointer-events:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (width<=767px){.project-detail{padding:1rem}.detail-header{flex-direction:column}.stats-grid{grid-template-columns:repeat(2,1fr)}.cell-url{max-width:200px}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}}.settings{max-width:800px;padding:1.5rem}.settings-section{margin-bottom:2.5rem}.section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.section-title{color:#e6edf3;font-size:1rem;font-weight:600}.settings-empty{color:#8b949e;padding:1.5rem 0;font-size:.875rem}.btn{cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:500;transition:background-color .15s,opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#0d1117;background-color:#3fb950}.btn-primary:hover:not(:disabled){background-color:#56d364}.btn-secondary{color:#e6edf3;background-color:#21262d;border:1px solid #30363d}.btn-secondary:hover:not(:disabled){background-color:#30363d}.btn-ghost{color:#8b949e;background:0 0}.btn-ghost:hover:not(:disabled){color:#e6edf3}.btn-small{color:#e6edf3;background-color:#21262d;border:1px solid #30363d;border-radius:4px;padding:.3rem .6rem;font-size:.75rem}.btn-small:hover:not(:disabled){background-color:#30363d}.btn-danger{color:#fff;background-color:#f85149}.btn-danger:hover:not(:disabled){background-color:#ff6e6a}.create-form{background-color:#161b22;border:1px solid #30363d;border-radius:8px;margin-bottom:1rem;padding:1.25rem}.form-field{margin-bottom:1rem}.form-field label{color:#e6edf3;margin-bottom:.35rem;font-size:.8rem;font-weight:500;display:block}.form-field input,.invite-form input,.invite-form select,.delete-confirm input{color:#e6edf3;background-color:#0d1117;border:1px solid #30363d;border-radius:6px;outline:none;width:100%;padding:.5rem .75rem;font-family:DM Sans,sans-serif;font-size:.85rem;transition:border-color .15s}.form-field input:focus,.invite-form input:focus,.invite-form select:focus,.delete-confirm input:focus{border-color:#3fb950}.form-hint{color:#8b949e;margin-top:.25rem;font-size:.7rem;display:block}.form-error{color:#f85149;margin:.5rem 0;font-size:.8rem}.form-actions{gap:.5rem;margin-top:1rem;display:flex}.projects-list{flex-direction:column;gap:.5rem;display:flex}.project-item{background-color:#161b22;border:1px solid #30363d;border-radius:8px;overflow:hidden}.project-item-expanded{border-color:#3fb950}.project-item-header{cursor:pointer;justify-content:space-between;align-items:center;padding:1rem 1.25rem;transition:background-color .15s;display:flex}.project-item-header:hover{background-color:#1c2333}.project-item-name{color:#e6edf3;font-size:.9rem;font-weight:600}.project-item-url{color:#8b949e;margin-top:.125rem;font-size:.75rem;display:block}.project-item-toggle{color:#8b949e;font-size:.9rem;transition:transform .15s}.toggle-open{transform:rotate(90deg)}.project-item-body{border-top:1px solid #21262d;padding:1.25rem}.detail-block{margin-bottom:1.5rem}.detail-block:last-child{margin-bottom:0}.detail-block-title{color:#8b949e;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.75rem;font-size:.8rem;font-weight:600}.api-key-row{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.api-key-value{color:#e6edf3;word-break:break-all;background-color:#0d1117;border:1px solid #21262d;border-radius:4px;flex:1;min-width:0;padding:.4rem .75rem;font-family:SFMono-Regular,Consolas,monospace;font-size:.8rem}.api-key-actions{flex-shrink:0;gap:.35rem;display:flex}.snippet-container{position:relative}.snippet-code{color:#e6edf3;white-space:pre;background-color:#0d1117;border:1px solid #21262d;border-radius:6px;margin:0;padding:1rem;font-family:SFMono-Regular,Consolas,monospace;font-size:.78rem;line-height:1.6;overflow-x:auto}.snippet-copy{position:absolute;top:.5rem;right:.5rem}.members-list{flex-direction:column;gap:.35rem;margin-bottom:1rem;display:flex}.member-row{border-bottom:1px solid #161b22;align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.member-email{color:#e6edf3;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.85rem;overflow:hidden}.member-role{text-transform:uppercase;letter-spacing:.04em;color:#8b949e;background-color:#21262d;border-radius:4px;padding:.2rem .5rem;font-size:.7rem;font-weight:600}.invite-form{flex-wrap:wrap;align-items:flex-start;gap:.5rem;display:flex}.invite-form input{flex:1;min-width:180px}.invite-form select{width:auto;min-width:90px}.invite-form .form-error{width:100%}.danger-zone{border-top:1px solid #30363d;padding-top:1.25rem}.danger-title{color:#f85149}.delete-warning{color:#8b949e;margin-bottom:.75rem;font-size:.85rem;line-height:1.5}.delete-warning strong{color:#e6edf3}.delete-confirm input{margin-bottom:.5rem}.account-info{background-color:#161b22;border:1px solid #30363d;border-radius:8px;padding:1.25rem}.account-row{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.account-label{color:#8b949e;font-size:.8rem}.account-value{color:#e6edf3;font-size:.85rem}.text-muted{color:#8b949e;font-size:.85rem}.skeleton-card{padding:1rem 1.25rem}.skeleton-line{background:linear-gradient(90deg,#21262d 25%,#30363d 50%,#21262d 75%) 0 0/200% 100%;border-radius:4px;animation:1.5s ease-in-out infinite shimmer;display:block}@media (width<=767px){.settings{padding:1rem}.section-header{flex-direction:column;align-items:flex-start;gap:.75rem}.api-key-row{flex-direction:column;align-items:flex-start}.api-key-value{width:100%}.invite-form{flex-direction:column}.invite-form input,.invite-form select{width:100%}.account-row{flex-direction:column;align-items:flex-start;gap:.25rem}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#e6edf3;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0d1117;font-family:DM Sans,sans-serif;font-size:14px;line-height:1.5}.page-title{color:#e6edf3;font-family:DM Sans,sans-serif;font-size:1.5rem;font-weight:600}.loading-screen{background-color:#0d1117;justify-content:center;align-items:center;min-height:100vh;display:flex}.loading-text{color:#8b949e;font-size:.875rem}
