:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#59d7d6,#1eabab)}.login-box{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px}.login-box h1{margin:0 0 1.5rem;text-align:center;color:#2c2c2c}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#666;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #DDDDDD;border-radius:4px;font-size:1rem;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#59d7d6}.login-button{width:100%;padding:.75rem;background:#59d7d6;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:1rem}.login-button:hover:not(:disabled){background:#1eabab}.login-button:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem;text-align:center}.dashboard{padding:2rem}.dashboard h1{margin-bottom:2rem;color:#2c2c2c}.dashboard-loading,.dashboard-error{padding:2rem;text-align:center;color:#666}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.stat-card h3{margin:0 0 .5rem;font-size:.9rem;color:#666;font-weight:500}.stat-value{margin:0;font-size:2rem;font-weight:700;color:#2c2c2c}.chart-container{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:2rem}.chart-container h2{margin:0 0 1.5rem;font-size:1.25rem;color:#2c2c2c}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.chart-header h2{margin:0}.time-period-toggle{display:flex;gap:.5rem}.time-period-toggle button{padding:.5rem 1rem;background:#f9f9f9;color:#666;border:1px solid #DDDDDD;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.time-period-toggle button:hover{background:#f5f5f5}.time-period-toggle button.active{background:#59d7d6;color:#fff;border-color:#59d7d6}.time-period-toggle button:disabled{opacity:.5;cursor:not-allowed}.chart-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:#666}.spinner{border:3px solid #F5F5F5;border-top:3px solid #59D7D6;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chart-loading p{margin:0;font-size:.9rem}.projects{padding:2rem}.projects h1{margin-bottom:2rem;color:#2c2c2c}.projects-list{display:flex;flex-direction:column;gap:1rem}.project-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.project-card-link{text-decoration:none;color:inherit;transition:transform .2s;display:block}.project-card-link:hover{transform:translateY(-2px)}.project-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;transition:box-shadow .2s;cursor:pointer}.project-card-link:hover .project-card{box-shadow:0 4px 8px #00000026}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.project-header h3{margin:0;color:#2c2c2c;font-size:1.25rem;transition:color .2s}.project-card-link:hover .project-header h3{color:#59d7d6}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;text-transform:capitalize}.project-description{color:#666;margin:.5rem 0;line-height:1.5}.project-meta{display:flex;gap:1rem;margin-top:1rem;font-size:.875rem;color:#888}.profiles{padding:2rem}.profiles h1{margin-bottom:2rem;color:#2c2c2c}.profiles-list{display:flex;flex-direction:column;gap:1rem}.profile-card-link{text-decoration:none;color:inherit;transition:transform .2s}.profile-card-link:hover{transform:translateY(-2px)}.profile-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;transition:box-shadow .2s}.profile-card-link:hover .profile-card{box-shadow:0 4px 8px #00000026}.profile-header{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.profile-image-small{width:60px;height:60px;border-radius:50%;object-fit:cover;border:2px solid #e0e0e0;flex-shrink:0}.profile-header-content{display:flex;justify-content:space-between;align-items:center;flex:1}.profile-header-content h3{margin:0;color:#2c2c2c;font-size:1.25rem}.role-badge{padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;text-transform:capitalize}.role-contractor{background:#e0f7f7;color:#1eabab}.role-project_owner{background:#e6f7f7;color:#59d7d6}.profile-info{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.profile-email{color:#666;font-size:.9rem}.profile-date{color:#888;font-size:.875rem}.loading,.end-message{text-align:center;padding:2rem;color:#666}.load-more-button{display:block;margin:2rem auto;padding:.75rem 2rem;background:#59d7d6;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer}.load-more-button:hover{background:#1eabab}.project-detail{padding:2rem}.project-detail-header{margin-bottom:2rem}.project-detail-header h1{margin:1rem 0 0;color:#2c2c2c}.project-detail-content{display:grid;grid-template-columns:1fr 300px;gap:2rem}.project-detail-main{display:flex;flex-direction:column;gap:2rem}.project-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.project-section h2{margin:0 0 1rem;color:#2c2c2c;font-size:1.25rem}.project-section p{color:#666;line-height:1.6;margin:0}.detail-item span:not(.detail-label){color:#2c2c2c}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;text-transform:capitalize;width:fit-content}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem}.project-detail-sidebar{display:flex;flex-direction:column;gap:2rem}.owner-info{display:flex;flex-direction:column;gap:.5rem}.owner-link{text-decoration:none;color:#59d7d6;transition:color .2s}.owner-link:hover{color:#1eabab}.owner-link h3{margin:0;font-size:1.125rem}.owner-email{color:#666;font-size:.875rem;margin:0}.video-thumbnail-container{position:relative;margin:1rem 0;border-radius:8px;overflow:hidden;cursor:pointer;background:#000}.video-thumbnail{width:100%;height:auto;display:block;max-height:400px;object-fit:contain}.play-button-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);cursor:pointer;transition:opacity .2s}.video-thumbnail-container:hover .play-button-overlay{opacity:.9}.video-processing-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;background:#f5f5f5;color:#666;min-height:200px}.processing-spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top-color:#59d7d6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.video-modal-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.video-modal-content{position:relative;background:#1a1a1a;border-radius:8px;padding:2rem;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.video-modal-close{position:absolute;top:1rem;right:1rem;background:#fff3;border:none;color:#fff;font-size:2rem;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .2s}.video-modal-close:hover{background:#ffffff4d}.video-modal-title{color:#fff;margin:0 0 1rem;font-size:1.5rem;text-align:center}.video-modal-player{background:#000;border-radius:4px}@media(max-width:968px){.project-detail-content,.detail-grid{grid-template-columns:1fr}}.profile-detail{padding:2rem}.profile-detail-header{margin-bottom:2rem}.back-link{display:inline-block;margin-bottom:1rem;color:#59d7d6;text-decoration:none;font-weight:500;transition:color .2s}.back-link:hover{color:#1eabab}.profile-header-content{display:flex;align-items:center;gap:2rem;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.profile-image-large{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid #59d7d6}.profile-header-content h1{margin:0 0 .5rem;color:#2c2c2c}.profile-email{margin:0 0 .5rem;color:#666;font-size:.875rem}.profile-detail-content,.profile-detail-main{display:flex;flex-direction:column;gap:2rem}.profile-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.profile-section h2{margin:0 0 1rem;color:#2c2c2c;font-size:1.25rem}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item.full-width{grid-column:1 / -1}.detail-label{font-weight:600;color:#666;font-size:.875rem}.detail-value{color:#2c2c2c;word-break:break-word}.detail-value p{margin:0;color:#666;line-height:1.6}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;text-transform:capitalize;width:fit-content}.role-contractor{background:#e6f7f7;color:#1eabab}.role-project_owner{background:#e0f7f7;color:#59d7d6}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.tag{padding:.375rem .75rem;background:#f0f0f0;border-radius:4px;font-size:.875rem;color:#2c2c2c}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem}.portfolio-image{width:100%;height:200px;object-fit:cover;border-radius:8px;cursor:pointer;transition:transform .2s}.portfolio-image:hover{transform:scale(1.05)}.projects-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.project-link{text-decoration:none;color:inherit}.project-item{padding:1rem;background:#f9f9f9;border-radius:8px;transition:background .2s}.project-link:hover .project-item{background:#f0f0f0}.project-item h3{margin:0 0 .5rem;color:#2c2c2c;font-size:1rem}.project-item-meta{display:flex;gap:1rem;align-items:center}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;text-transform:capitalize}.status-open{background:#e6f7f7;color:#1eabab}.status-closed{background:#f8d7da;color:#721c24}.status-accepted{background:#e0f7f7;color:#59d7d6}.project-date{color:#666;font-size:.875rem}.loading,.error{text-align:center;padding:2rem;color:#666}.error{color:#dc3545}@media(max-width:768px){.profile-header-content{flex-direction:column;text-align:center}.detail-grid{grid-template-columns:1fr}.portfolio-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5}.app-loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.25rem;color:#666}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.app-header h1{margin:0;color:#2c2c2c;font-size:1.5rem}.sign-out-button{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:4px;font-size:.875rem;font-weight:600;cursor:pointer}.sign-out-button:hover{background:#c82333}.app-nav{background:#fff;padding:0 2rem;box-shadow:0 2px 4px #0000001a;display:flex;gap:.5rem;border-top:1px solid #dddddd}.nav-button{padding:1rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;font-size:1rem;font-weight:500;color:#666;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}.nav-button:hover{color:#2c2c2c;background:#f9f9f9}.nav-button.active{color:#59d7d6;border-bottom-color:#59d7d6}.app-main{flex:1;overflow-y:auto;max-width:1400px;width:100%;margin:0 auto}
