body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.landing-page{min-height:100vh}.navbar{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;padding:1rem 0;position:fixed;top:0;width:100%;z-index:1000}.navbar .container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.logo{font-size:1.5rem;font-weight:700}.mobile-menu-btn{background:none;border:none;color:#fff;cursor:pointer;display:none;font-size:1.8rem;padding:.5rem}.nav-links{align-items:center;display:flex;gap:2rem}.nav-links a{color:#fff;text-decoration:none;transition:opacity .3s}.nav-links a:hover{opacity:.8}@media (max-width:768px){.mobile-menu-btn{display:block}.nav-links{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 10px #0003;flex-direction:column;gap:0;left:0;padding:1rem 0;position:fixed;right:0;top:60px;transform:translateY(-120%);transition:transform .3s ease-in-out}.nav-links.active{transform:translateY(0)}.nav-links a{padding:1rem 2rem;text-align:center;width:100%}.nav-links .btn-primary,.nav-links .btn-secondary{margin:.5rem 2rem;text-align:center;width:calc(100% - 4rem)}}.hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-top:60px;padding:10rem 2rem 6rem;text-align:center}.hero h1{font-size:3rem;margin-bottom:1rem}.hero p{font-size:1.3rem;margin-bottom:2rem}.container{margin:0 auto;max-width:1200px;padding:0 2rem}section{padding:4rem 2rem}h2{color:#333;font-size:2.5rem;margin-bottom:3rem;text-align:center}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.feature-card{background:#fff;border-radius:10px;box-shadow:0 4px 15px #0000001a;padding:2rem;text-align:center;transition:transform .3s}.feature-card:hover{transform:translateY(-5px)}.feature-icon{color:#667eea;font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#333;margin-bottom:1rem}.pricing{background:#f8f9fa}.pricing-card{background:#fff;border-radius:15px;box-shadow:0 4px 20px #0000001a;margin:0 auto;max-width:400px;padding:3rem;text-align:center}.pricing-card h3{color:#667eea;margin-bottom:1rem}.price{color:#333;font-size:3rem;font-weight:700;margin:1rem 0}.price span{color:#666;font-size:1.5rem}.pricing-card ul{list-style:none;margin:2rem 0;padding:0}.pricing-card li{color:#666;padding:.5rem 0}.contact-form{display:flex;flex-direction:column;gap:1rem;margin:0 auto;max-width:600px}.contact-form input,.contact-form textarea{border:1px solid #ddd;border-radius:5px;font-size:1rem;padding:1rem}.footer{background:#333;color:#fff;padding:2rem;text-align:center}.footer-links{display:flex;gap:2rem;justify-content:center;margin-bottom:1rem}.footer-links a{color:#fff;text-decoration:none}.btn-primary{border:none;border-radius:5px;cursor:pointer;display:inline-block;padding:.75rem 1.5rem;text-decoration:none;transition:background .3s}.btn-primary:hover{background:#5568d3}.btn-primary.btn-large{font-size:1.2rem;padding:1rem 2.5rem}.btn-secondary{background:#fff!important;border:2px solid #fff;border-radius:5px;color:#5568d3!important;cursor:pointer;display:inline-block;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s}.btn-secondary:hover{background:#0000;color:#fff}.login-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.login-container{max-width:450px;width:100%}.login-card{background:#fff;border-radius:15px;box-shadow:0 10px 40px #0003;padding:3rem;text-align:center}.login-card h1{color:#333;font-size:2rem;margin-bottom:1rem}.login-card p{color:#666;margin-bottom:2rem}.google-login-wrapper{display:flex;justify-content:center;margin:2rem 0}.login-footer{border-top:1px solid #eee;margin-top:2rem;padding-top:2rem}.login-footer p{color:#999;font-size:.9rem;margin:0}.login-footer a{color:#667eea;text-decoration:none}.login-footer a:hover{text-decoration:underline}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.app-header,.header-left{align-items:center;display:flex}.app-logo{font-size:1.5rem;font-weight:700}.header-right{align-items:center;display:flex;gap:1rem}.user-avatar{border:2px solid #fff;border-radius:50%;height:40px;width:40px}.user-name{font-size:1rem}.logout-btn{background:#fff3;border:1px solid #fff;border-radius:5px;color:#fff;cursor:pointer;padding:.5rem 1rem;transition:background .3s}.logout-btn:hover{background:#ffffff4d}.app-body{display:flex;flex:1 1}.sidebar{background:#fff;border-right:1px solid #e5e7eb;padding:1.5rem 0;width:280px}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem;padding:0 .75rem}.nav-item{align-items:center;border-radius:8px;color:#6b7280;display:flex;gap:1rem;padding:.875rem 1rem;position:relative;text-decoration:none;transition:all .2s}.nav-item:hover{background:#f3f4f6;color:#1f2937}.nav-item.active{background:#ede9fe;color:#7c3aed}.nav-icon{align-items:center;color:#9ca3af;display:flex;flex-shrink:0;font-size:1.5rem;height:24px;justify-content:center;width:24px}.nav-item:hover .nav-icon{color:#6b7280}.nav-item.active .nav-icon{color:#7c3aed}.nav-text{flex:1 1;font-size:.95rem;font-weight:500}.nav-arrow{color:#3b82f6;font-size:1.5rem;opacity:0;transition:opacity .2s}.nav-item:hover .nav-arrow{opacity:1}.main-content{background:#f8f9fa;flex:1 1;overflow-y:auto;padding:2rem}@media (max-width:768px){.sidebar{padding:1rem 0;width:70px}.nav-arrow,.nav-text{display:none}.nav-item{justify-content:center;padding:.75rem}}.dashboard{max-width:1400px}.dashboard h1{color:#333;margin-bottom:2rem}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:transform .3s}.stat-card:hover{transform:translateY(-5px)}.stat-icon{color:#667eea;font-size:3rem;min-width:3rem}.stat-content{flex:1 1}.stat-value{color:#333;font-size:2rem;font-weight:700}.stat-label{color:#666;font-size:.9rem;margin-top:.5rem}.stat-card.pending{border-left:4px solid orange}.stat-card.active{border-left:4px solid #667eea}.stat-card.completed{border-left:4px solid #4caf50}.stat-card.revenue{border-left:4px solid #2196f3}.stat-card.payments{border-left:4px solid #ff5722}.dashboard-charts{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.chart-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:2rem}.chart-card h2{color:#333;font-size:1.5rem;margin-bottom:1rem}.new-task{max-width:900px}.new-task h1{color:#333;margin-bottom:2rem}.task-form{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:2rem}.form-section{border-bottom:1px solid #eee;margin-bottom:2rem;padding-bottom:2rem}.form-section:last-of-type{border-bottom:none}.form-section h2{color:#1a1a1a;font-size:1.1rem;font-weight:600;margin-bottom:1rem;text-align:left}.form-group{margin-bottom:1.25rem}.form-group label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:.95rem;padding:.875rem 1rem;transition:all .2s;width:100%}.form-group input::placeholder,.form-group textarea::placeholder{color:#9ca3af}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-group textarea{resize:vertical}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.down-payment-group{display:flex;gap:.5rem}.down-payment-group input{flex:1 1}.down-payment-group select{width:80px}.selected-customer{align-items:center;background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;display:flex;justify-content:space-between;padding:1rem}.customer-info{display:flex;flex-direction:column}.customer-info strong{color:#1a1a1a;font-weight:500;margin-bottom:.25rem}.customer-info span{color:#6b7280;font-size:.9rem}.btn-change,.btn-select{border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.btn-select{background:#3b82f6;color:#fff;width:100%}.btn-select:hover{background:#2563eb}.btn-change{background:#fff;border:1px solid #d1d5db;color:#6b7280}.btn-change:hover{background:#f9fafb;color:#374151}.form-actions{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;margin-top:2rem;padding-top:2rem}.btn-primary,.btn-secondary{border:none;border-radius:5px;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:all .3s}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5568d3}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.btn-secondary{background:#f8f9fa;border:1px solid #ddd;color:#333}.btn-secondary:hover{background:#e9ecef}.modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:85vh;max-width:500px;overflow-y:auto;padding:2.5rem;width:90%}.customer-form-modal{max-width:650px}.modal-content h2{color:#1a1a1a;font-size:1.5rem;font-weight:600;margin:0 0 2rem}.modal-content .form-group{margin-bottom:1.25rem}.modal-content .form-group label{display:none}.modal-content .form-group input,.modal-content .form-group select,.modal-content .form-group textarea{background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:.95rem;padding:.875rem 1rem;transition:all .2s;width:100%}.modal-content .form-group input::placeholder,.modal-content .form-group textarea::placeholder{color:#9ca3af}.modal-content .form-group input:focus,.modal-content .form-group select:focus,.modal-content .form-group textarea:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.modal-content .form-group textarea{min-height:100px;resize:vertical}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:2rem}.btn-cancel{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#6b7280;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.btn-cancel:hover{background:#f9fafb;color:#374151}.btn-save{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 2rem;transition:all .2s}.btn-save:hover{background:#2563eb}.btn-save:active{transform:scale(.98)}.modal-header{border-bottom:2px solid #f0f0f0;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.close-btn,.modal-header{align-items:center;display:flex}.close-btn{background:none;border:none;border-radius:50%;color:#999;cursor:pointer;font-size:1.5rem;height:35px;justify-content:center;padding:.5rem;transition:all .3s;width:35px}.close-btn:hover{background:#f8f9fa;color:#333}.label-icon{font-size:1.1rem}.btn-primary span,.label-icon{margin-right:.5rem}.customer-list{margin:1rem 0;max-height:400px;overflow-y:auto}.customer-item{border:1px solid #eee;border-radius:5px;cursor:pointer;display:flex;flex-direction:column;margin-bottom:.5rem;padding:1rem;transition:all .3s}.customer-item:hover{background:#f8f9fa;border-color:#667eea}.customer-item strong{color:#333;margin-bottom:.25rem}.customer-item span{color:#666;font-size:.9rem}.mb-2{margin-bottom:1rem}.mt-2{margin-top:1rem}.task-list-page{max-width:1400px}.page-header{justify-content:space-between}.page-header h1{color:#333;margin:0}.filter-bar{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;gap:1rem;margin-bottom:2rem;padding:1rem}.filter-bar button{background:#fff;border:1px solid #ddd;border-radius:5px;cursor:pointer;padding:.5rem 1rem;transition:all .3s}.filter-bar button.active,.filter-bar button:hover{background:#667eea;border-color:#667eea;color:#fff}.tasks-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.task-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;cursor:pointer;padding:1.5rem;transition:all .3s}.task-card:hover{box-shadow:0 4px 20px #00000026;transform:translateY(-5px)}.task-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.task-header h3{color:#333;flex:1 1;margin:0}.task-status{border-radius:15px;color:#fff;font-size:.85rem;margin-left:1rem;padding:.25rem .75rem;white-space:nowrap}.task-info p{color:#666;font-size:.9rem;margin:.5rem 0}.empty-state{color:#999;padding:4rem 2rem;text-align:center}.task-detail{max-height:85vh;max-width:700px;overflow-y:auto}.task-detail-header{align-items:flex-start;border-bottom:2px solid #eee;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.task-detail-header h2{color:#333;flex:1 1;margin:0}.detail-section{margin-bottom:2rem}.detail-section h3{color:#667eea;font-size:1.2rem;margin-bottom:1rem}.detail-section p{color:#666;line-height:1.6;margin:.5rem 0}.payments-list{gap:1rem}.payment-item{padding:1rem}.payment-item p{margin:0}.payment-date{color:#999;font-size:.85rem}.payment-status{border-radius:5px;font-size:.9rem;padding:.5rem 1rem}.payment-status.paid{background:#4caf50;color:#fff}.task-actions{border-top:1px solid #eee;display:flex;gap:1rem;margin-top:2rem;padding-top:2rem}.task-detail-page{max-width:1400px}.page-header{align-items:center;display:flex;gap:1rem;margin-bottom:2rem}.btn-back{background:#f8f9fa;border:1px solid #ddd;border-radius:5px;cursor:pointer;font-size:1rem;padding:.5rem 1rem;transition:all .3s}.btn-back:hover{background:#e9ecef}.task-status-badge{border-radius:20px;color:#fff;font-size:.9rem;font-weight:500;padding:.5rem 1rem}.task-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 400px}.main-column,.sidebar-column{display:flex;flex-direction:column;gap:1.5rem}.card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:1.5rem}.card h2{color:#333;font-size:1.2rem;margin:0 0 1rem;text-align:left}.info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.info-grid label{color:#666;display:block;font-size:.85rem;font-weight:500;margin-bottom:.25rem}.info-grid p{color:#333;margin:0}.notes-section{display:flex;flex-direction:column;gap:1rem}.notes-text{color:#333;line-height:1.6;white-space:pre-wrap}.add-note{display:flex;flex-direction:column;gap:.5rem}.add-note textarea{border:1px solid #ddd;border-radius:5px;font-family:inherit;padding:.75rem;resize:vertical}.photos-section{display:flex;flex-direction:column;gap:1rem}.photo-upload{align-items:center;display:flex;gap:1rem}.photo-upload input[type=file]{display:none}.upload-label{background:#f8f9fa;border:1px solid #ddd;border-radius:5px;cursor:pointer;padding:.75rem 1.5rem;transition:all .3s}.upload-label:hover{background:#e9ecef}.selected-files{align-items:center;display:flex;gap:1rem}.selected-files p{color:#666;margin:0}.photo-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.photo-item{aspect-ratio:1;background:#f8f9fa;border-radius:8px;overflow:hidden}.photo-item img{height:100%;object-fit:cover;width:100%}.pricing-info,.schedule-info{display:flex;flex-direction:column;gap:1rem}.price-row{border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:.75rem 0}.price-row.total{border-bottom:none;border-top:2px solid #333;font-size:1.1rem;padding-top:1rem}.schedule-info label{color:#666;display:block;font-size:.85rem;font-weight:500;margin-bottom:.25rem}.schedule-info p{color:#333;margin:0 0 1rem}.payments-list{display:flex;flex-direction:column;gap:.75rem}.payment-item{align-items:center;background:#f8f9fa;border-radius:5px;display:flex;justify-content:space-between;padding:.75rem}.payment-item strong{color:#333;display:block;margin-bottom:.25rem}.payment-due{color:#666;font-size:.85rem;margin:0}.badge-success{background:#4caf50;border-radius:15px;color:#fff;font-size:.85rem;font-weight:500;padding:.25rem .75rem}.action-buttons{display:flex;flex-direction:column;gap:.75rem}.btn-full{width:100%}.btn-sm{font-size:.9rem;padding:.5rem 1rem}.payment-schedule-modal{max-height:80vh;max-width:600px;overflow-y:auto}.schedule-table{margin:1rem 0;max-height:400px;overflow-y:auto}.schedule-table table{border-collapse:collapse;width:100%}.schedule-table td,.schedule-table th{border-bottom:1px solid #f0f0f0;padding:.75rem;text-align:left}.schedule-table th{background:#f8f9fa;color:#333;font-weight:600;position:-webkit-sticky;position:sticky;top:0}.schedule-table tr:hover{background:#f8f9fa}@media (max-width:1024px){.info-grid,.task-content{grid-template-columns:1fr}}.reports{max-width:1400px}.reports h1{color:#333;margin-bottom:2rem}.report-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.report-card{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;gap:1rem;padding:1.5rem}.report-icon{color:#667eea;font-size:3rem;min-width:3rem}.report-content{flex:1 1}.report-value{color:#333;font-size:2rem;font-weight:700}.report-label{color:#666;font-size:.9rem;margin-top:.5rem}.report-section{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem;padding:2rem}.report-section h2{color:#333;font-size:1.5rem;margin-bottom:1.5rem}.table-container{overflow-x:auto}.report-table{border-collapse:collapse;width:100%}.report-table td,.report-table th{border-bottom:1px solid #eee;padding:1rem;text-align:left}.report-table th{color:#333;font-weight:600}.report-table th,.report-table tr:hover{background:#f8f9fa}.status-breakdown{display:flex;flex-direction:column;gap:1.5rem}.status-item{grid-gap:1rem;align-items:center;display:grid;gap:1rem;grid-template-columns:200px 1fr 60px}.status-info{display:flex;flex-direction:column}.status-name{color:#333;font-weight:600}.status-count{color:#666;font-size:.9rem}.status-bar{background:#eee;border-radius:12px;height:25px;overflow:hidden}.status-bar-fill{background:linear-gradient(135deg,#667eea,#764ba2);height:100%;transition:width .3s}.status-percentage{color:#666;font-weight:600;text-align:right}@media (max-width:768px){.status-item{gap:.5rem;grid-template-columns:1fr}.status-percentage{text-align:left}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.52228844.css.map*/