.project-detail-page{max-width:1600px;margin:0 auto;padding:2rem}.project-header{margin-bottom:2rem}.project-title-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.project-title-section h1{color:var(--text-primary);background:linear-gradient(135deg,var(--primary-color)0%,#ff6b35 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:2.5rem;display:inline-block;position:relative}.project-title-container{background:var(--card-bg);border:2px solid var(--primary-color);border-radius:12px;margin:1rem 0 .75rem;padding:.75rem 1.5rem;display:inline-block;position:relative;box-shadow:0 4px 12px #f74c0026}.project-title-container:before{content:"";background:linear-gradient(90deg,transparent,var(--primary-color),transparent);border-radius:2px;height:3px;position:absolute;top:-1px;left:20px;right:20px}.project-description{color:var(--text-secondary);margin:0;font-size:1.1rem}.status-controls{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.current-status{text-transform:uppercase;letter-spacing:.025em;border-radius:6px;padding:.4rem .85rem;font-size:.85rem;font-weight:600}.current-status.planned{background:var(--primary-color);color:#fff}.current-status.in_progress{color:#fff;background:#f59e0b}.current-status.completed{color:#fff;background:#10b981}.status-transition-buttons{gap:.5rem;display:flex}.btn-status{cursor:pointer;border:2px solid #0000;border-radius:6px;align-items:center;gap:.3rem;padding:.4rem .85rem;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-start{color:var(--primary-color);border-color:var(--primary-color);background:0 0}.btn-start:hover{background:var(--primary-color);color:#fff}.btn-complete{color:#10b981;background:0 0;border-color:#10b981}.btn-complete:hover{color:#fff;background:#10b981}.btn-reopen{color:#f59e0b;background:0 0;border-color:#f59e0b}.btn-reopen:hover{color:#fff;background:#f59e0b}.project-visibility-row{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.visibility-badge{border-radius:6px;padding:.4rem .85rem;font-size:.85rem;font-weight:600}.visibility-badge.public{color:#10b981;background:#10b98126;border:1px solid #10b981}.visibility-badge.private{color:var(--text-secondary);border:1px solid var(--border-color);background:#6b728026}button.btn-toggle-public,.btn-toggle-public{color:var(--text-secondary);cursor:pointer;border-radius:6px;flex:none;align-items:center;font-weight:500;transition:all .2s;display:inline-flex;border:1px solid var(--border-color)!important;background:0 0!important;width:auto!important;padding:.4rem .85rem!important;font-size:.85rem!important}.btn-toggle-public:hover{border-color:var(--primary-color);color:var(--primary-color)}.btn-toggle-public:disabled{opacity:.5;cursor:not-allowed}.project-content{grid-template-columns:400px 1fr;gap:2rem;display:grid}.project-left-column{flex-direction:column;gap:1.5rem;display:flex}.cost-summary-card,.task-progress-card{background:var(--card-background);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem}.cost-summary-card h2,.task-progress-card h2{color:var(--text-primary);margin:0 0 1rem;font-size:1.3rem}.pie-chart-container{margin:1.5rem 0}.pie-chart{width:100%;max-width:300px;height:auto;margin:0 auto;display:block}.empty-chart{background:var(--background-secondary);width:200px;height:200px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;margin:0 auto;display:flex}.chart-legend{margin-top:1rem}.legend-item{align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.9rem;display:flex}.legend-color{border-radius:3px;flex-shrink:0;width:16px;height:16px}.legend-label{color:var(--text-primary);flex:1}.legend-value{color:var(--text-secondary);font-weight:600}.cost-stats{border-top:1px solid var(--border-color);flex-direction:column;gap:.75rem;margin-top:1rem;padding-top:1rem;display:flex}.stat-item{justify-content:space-between;align-items:center;display:flex}.stat-label{color:var(--text-secondary);font-size:.95rem}.stat-value{color:var(--text-primary);font-size:1.1rem;font-weight:700}.budget-diff .stat-value.over{color:#e74c3c}.budget-diff .stat-value.under{color:#27ae60}.progress-bar-container{background:var(--background-secondary);border-radius:12px;width:100%;height:24px;margin-bottom:.5rem;overflow:hidden}.progress-bar{background:linear-gradient(90deg,#4ecdc4 0%,#44a08d 100%);border-radius:12px;height:100%;transition:width .3s}.progress-text{text-align:center;color:var(--text-primary);margin:0;font-weight:600}.project-right-column{flex-direction:column;gap:2rem;display:flex}.parts-section,.tasks-section,.images-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem}.images-section h2{color:var(--text-primary);margin:0 0 1rem;font-size:1.25rem}.photo-gallery-section{margin-top:1.5rem}.section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.section-header h2{color:var(--text-primary);margin:0;font-size:1.5rem}.parts-list{flex-direction:column;gap:.75rem;display:flex}.part-card{background:var(--background-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;transition:all .2s}.part-card.collapsed{padding:0}.part-card.collapsed .part-header{margin-bottom:0;padding:1rem}.part-card.expanded{border-color:var(--primary-color);box-shadow:0 4px 12px #0000001a}.part-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.part-header.clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.part-header.clickable:hover{opacity:.85}.part-title-row{flex:1;align-items:center;gap:.75rem;display:flex}.part-title-row .expand-icon{color:var(--text-secondary);width:1rem;font-size:.8rem}.part-header h3{color:var(--text-primary);margin:0;font-size:1.1rem}.purchased-badge{color:#10b981;background:#10b98126;border-radius:4px;padding:.2rem .5rem;font-size:.75rem;font-weight:500}.part-cost-preview{color:var(--primary-color);margin-left:auto;padding-left:1rem;font-size:.95rem;font-weight:600}.part-actions{align-items:center;gap:.5rem;display:flex}.btn-delete{border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;padding:.5rem;font-size:1.2rem;line-height:1;transition:all .2s;display:flex}.btn-delete:hover{background:var(--color-error);border-color:var(--color-error);transform:scale(1.05)}.btn-delete.btn-sm{width:32px;height:32px;font-size:1rem}.part-details{gap:.5rem;margin-bottom:1rem;display:grid}.part-field{align-items:center;gap:.5rem;display:flex}.part-field.total{border-top:1px solid var(--border-color);margin-top:.5rem;padding-top:.5rem;font-weight:700}.field-label{color:var(--text-secondary);font-size:.9rem}.field-value{color:var(--text-primary);font-weight:600}.part-link{color:var(--accent-color);font-weight:600;text-decoration:none}.part-link:hover{text-decoration:underline}.part-footer{border-top:1px solid var(--border-color);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-top:1rem;padding-top:1rem;display:flex}.purchased-checkbox{cursor:pointer;color:var(--text-secondary);align-items:center;gap:.5rem;display:flex}.purchased-checkbox input[type=checkbox]{cursor:pointer;width:20px;height:20px}.tasks-list{flex-direction:column;gap:.75rem;display:flex}.task-card{background:var(--background-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;transition:all .2s}.task-card.completed{opacity:.7;background:var(--background-tertiary)}.task-card.completed .task-name{color:var(--text-secondary);text-decoration:line-through}.task-content{align-items:flex-start;gap:1rem;display:flex}.task-checkbox{cursor:pointer;flex-shrink:0;width:24px;height:24px;margin-top:2px}.task-text{flex-direction:column;flex:1;gap:.25rem;display:flex}.task-name{color:var(--text-primary);font-size:1.05rem;font-weight:600}.task-notes{color:var(--text-secondary);font-size:.9rem}.btn-edit-task{color:var(--primary-color);border:1px solid var(--primary-color);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;padding:.4rem .8rem;font-size:.85rem;font-weight:500;transition:all .2s}.btn-edit-task:hover{background:var(--primary-color);color:#fff}.task-edit-modal-overlay{z-index:1100;background:#000000d9;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.task-edit-modal{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:450px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.task-edit-modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.task-edit-modal-header h3{color:var(--text-primary);margin:0;font-size:1.25rem}.task-edit-modal-header .close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1;transition:color .2s}.task-edit-modal-header .close-btn:hover{color:var(--primary-color)}.task-edit-modal-body{padding:1.5rem}.task-edit-modal-body .form-group{margin-bottom:1rem}.task-edit-modal-body .form-group label{color:var(--text-primary);margin-bottom:.5rem;font-size:.95rem;font-weight:500;display:block}.task-edit-modal-body .form-input,.task-edit-modal-body .form-textarea{border:2px solid var(--border-color);background:var(--input-bg);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:8px;padding:.75rem 1rem;font-size:1rem;transition:border-color .2s}.task-edit-modal-body .form-input:focus,.task-edit-modal-body .form-textarea:focus{border-color:var(--primary-color);outline:none}.task-edit-modal-body .form-textarea{resize:vertical;min-height:80px}.task-edit-modal-body .error-message{color:#ef4444;background:#dc354526;border:1px solid #dc35454d;border-radius:8px;margin-top:1rem;padding:.75rem 1rem;font-size:.9rem}.task-edit-modal-footer{border-top:1px solid var(--border-color);background:var(--background-color);border-radius:0 0 12px 12px;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.btn-delete-task{color:#dc2626;cursor:pointer;background:0 0;border:1px solid #dc2626;border-radius:8px;padding:.7rem 1.25rem;font-size:.95rem;font-weight:500;transition:all .2s}.btn-delete-task:hover:not(:disabled){color:#fff;background:#dc2626}.btn-delete-task:disabled{opacity:.5;cursor:not-allowed}.task-edit-modal-footer .footer-right{gap:.75rem;display:flex}.task-edit-modal-footer .btn-cancel{color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:8px;padding:.7rem 1.25rem;font-size:.95rem;font-weight:500;transition:all .2s}.task-edit-modal-footer .btn-cancel:hover:not(:disabled){border-color:var(--text-secondary)}.task-edit-modal-footer .btn-cancel:disabled{opacity:.5;cursor:not-allowed}.task-edit-modal-footer .btn-save{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.7rem 1.25rem;font-size:.95rem;font-weight:500;transition:all .2s}.task-edit-modal-footer .btn-save:hover:not(:disabled){background:#d94100}.task-edit-modal-footer .btn-save:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.task-edit-modal-overlay{align-items:flex-end;padding:0}.task-edit-modal{border-radius:16px 16px 0 0;max-width:100%;max-height:85vh}.task-edit-modal-header{padding:1rem 1.25rem}.task-edit-modal-body{padding:1.25rem}.task-edit-modal-footer{flex-direction:column;gap:.75rem;padding:1rem 1.25rem 1.5rem}.btn-delete-task{order:3;width:100%}.task-edit-modal-footer .footer-right{flex-direction:column-reverse;width:100%}.task-edit-modal-footer .footer-right button{width:100%}.btn-edit-task{padding:.35rem .6rem;font-size:.8rem}}.empty-state{text-align:center;color:var(--text-secondary);padding:3rem 1rem;font-size:1.1rem}@media (max-width:1200px){.project-content{grid-template-columns:1fr}.project-left-column{order:2}.project-right-column{order:1}}@media (max-width:768px){.project-detail-page{padding:1rem}.project-title-section h1{margin:0;font-size:1.5rem}.project-title-container{margin:.5rem 0;padding:.5rem 1rem}.project-title-row{flex-direction:column;align-items:flex-start;gap:.75rem}.status-controls{align-items:center;width:100%;display:flex}.current-status{text-align:center;min-width:100px;padding:.35rem .75rem;font-size:.8rem}.btn-status{flex:1;padding:.35rem .75rem;font-size:.8rem}.project-visibility-row{align-items:center;width:100%;display:flex}.visibility-badge{text-align:center;min-width:100px;padding:.35rem .75rem;font-size:.8rem}.btn-toggle-public{flex:1;padding:.35rem .75rem!important;font-size:.8rem!important}.build-selector-row{width:100%}.cost-summary-card,.task-progress-card,.parts-section,.tasks-section,.images-section{padding:1rem}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.part-card{padding:.75rem}.part-card.collapsed .part-header{padding:.6rem .75rem}.part-header{flex-direction:row;align-items:center;gap:.5rem}.part-header h3{font-size:.95rem}.part-title-row{gap:.5rem}.part-title-row .expand-icon{font-size:.7rem}.purchased-badge{padding:.15rem .4rem;font-size:.65rem}.part-cost-preview{padding-left:.5rem;font-size:.85rem}.part-actions{width:100%}.part-actions button{flex:1;width:auto;min-width:0}}.projects-container{padding:1rem}.projects-container h2{color:var(--text-primary);margin-bottom:1rem}.projects-controls{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.projects-sections{flex-direction:column;gap:1.5rem;display:flex}.project-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.project-section h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.1rem}.empty-section{color:var(--text-secondary);font-style:italic}.project-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.project-card-header h4{color:var(--text-primary);margin:0 0 .5rem}.project-cost{color:var(--text-secondary);gap:1rem;font-size:.9rem;display:flex}.builds-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.builds-section h3{color:var(--text-primary);margin:0 0 .5rem}.section-description{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem}.builds-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.build-card{background:var(--background-color);border:1px solid var(--border-color);border-left:4px solid var(--primary-color);border-radius:8px;padding:1rem}.build-card-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.build-card-header h4{color:var(--text-primary);margin:0}.build-status{background:var(--primary-color);color:#fff;text-transform:uppercase;border-radius:4px;padding:.25rem .5rem;font-size:.75rem}.build-description{color:var(--text-secondary);margin:.5rem 0;font-size:.9rem}.build-progress{margin:.75rem 0}.progress-bar{background:var(--border-color);border-radius:4px;height:8px;margin-bottom:.25rem;overflow:hidden}.progress-fill{background:var(--primary-color);border-radius:4px;height:100%;transition:width .3s}.progress-text{color:var(--text-secondary);font-size:.8rem}.build-actions{gap:.5rem;margin-top:.75rem;display:flex}.btn-small{cursor:pointer;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-primary);border-radius:4px;padding:.25rem .75rem;font-size:.8rem}.btn-small:hover{background:var(--background-color)}.btn-delete.btn-small{background:var(--color-error);color:#fff;border-color:var(--color-error)}.btn-delete.btn-small:hover{background:#dc2626}.build-form{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.build-form h4{color:var(--text-primary);margin:0 0 .5rem}.build-form .form-help{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem}.build-form input,.build-form textarea{border:1px solid var(--border-color);background:var(--input-bg);width:100%;color:var(--text-primary);border-radius:6px;margin-bottom:1rem;padding:.75rem;font-size:1rem}.build-form .form-buttons{justify-content:flex-end;gap:1rem;display:flex}.project-form{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.project-form h4{color:var(--text-primary);margin:0 0 .5rem}.project-form .form-help{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem}.project-form input,.project-form textarea{border:1px solid var(--border-color);background:var(--input-bg);width:100%;color:var(--text-primary);border-radius:6px;margin-bottom:1rem;padding:.75rem;font-size:1rem}.project-form button{margin-top:.5rem}@media (max-width:768px){.projects-container{padding:.75rem}.projects-controls{flex-direction:column;gap:.75rem}.projects-controls button{justify-content:center;width:100%;padding:.75rem 1rem}.builds-list,.project-cards{grid-template-columns:1fr}.build-form,.project-form{padding:1rem}.build-form .form-buttons{flex-direction:column}.build-form .form-buttons button{width:100%}}.build-card.expanded{border-color:var(--primary-color)}.build-card-header.clickable{cursor:pointer;justify-content:space-between;align-items:center;display:flex}.build-card-header.clickable:hover{opacity:.8}.build-title-row{flex:1;align-items:center;gap:.75rem;display:flex}.expand-icon{color:var(--text-secondary);font-size:.9rem}.build-projects{border-top:1px solid var(--border-color);margin-top:1rem;padding-top:1rem}.build-projects h5{color:var(--text-primary);margin:0 0 .75rem;font-size:.95rem}.build-projects-list{flex-direction:column;gap:.5rem;display:flex}.build-project-item{background:var(--card-bg);border:1px solid var(--border-color);cursor:pointer;border-radius:6px;align-items:center;gap:.75rem;padding:.75rem;transition:all .2s;display:flex}.build-project-item:hover{border-color:var(--primary-color);transform:translate(4px)}.project-status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.project-status-dot.planned{background:var(--primary-color)}.project-status-dot.in-progress{background:#f59e0b}.project-status-dot.completed{background:#10b981}.project-name{color:var(--text-primary);flex:1;font-weight:500}.project-status-text{color:var(--text-secondary);font-size:.85rem}.empty-message-small{color:var(--text-secondary);padding:.5rem 0;font-size:.9rem;font-style:italic}.build-selector-row{align-items:center;gap:.75rem;margin:.75rem 0;display:flex}.build-selector-label{color:var(--text-secondary);font-size:.95rem}.build-selector{border:1px solid var(--border-color);background:var(--input-bg);color:var(--text-primary);cursor:pointer;border-radius:6px;min-width:200px;padding:.5rem 1rem;font-size:.95rem}.build-selector:focus{border-color:var(--primary-color);outline:none}.build-selector:disabled{opacity:.6;cursor:not-allowed}.saving-indicator{color:var(--text-secondary);font-size:.85rem;font-style:italic}.error-text{color:var(--color-error);font-size:.9rem}@media (max-width:768px){.build-selector-row{flex-direction:column;align-items:flex-start;gap:.5rem}.build-selector{width:100%}}.modal-overlay{z-index:1000;background:#000000bf;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0006}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h2{color:var(--text-primary);margin:0;font-size:1.5rem}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.75rem;line-height:1;transition:color .2s}.modal-close:hover{color:var(--primary-color)}.modal-body{padding:1.5rem}.modal-description{color:var(--text-secondary);margin:0 0 1.5rem;font-size:.95rem;line-height:1.5}.modal-footer{border-top:1px solid var(--border-color);background:var(--background-color);border-radius:0 0 12px 12px;justify-content:flex-end;gap:1rem;padding:1rem 1.5rem;display:flex}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-primary);margin-bottom:.5rem;font-size:.95rem;font-weight:500;display:block}.form-input,.form-textarea{border:2px solid var(--border-color);background:var(--input-bg);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:8px;padding:.875rem 1rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #f74c0026}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-secondary);opacity:.7}.form-textarea{resize:vertical;min-height:100px}.form-error{color:#ef4444;background:#dc354526;border:1px solid #dc35454d;border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.btn-cancel{border:2px solid var(--border-color);color:var(--text-primary);cursor:pointer;background:0 0;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s}.btn-cancel:hover{border-color:var(--text-secondary);background:var(--background-color)}.modal-footer .btn-primary{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s}.modal-footer .btn-primary:hover:not(:disabled){background:#d94100;transform:translateY(-1px)}.modal-footer .btn-primary:disabled{opacity:.6;cursor:not-allowed}@media (max-width:768px){.modal-overlay{align-items:flex-end;padding:0}.modal-content{border-radius:16px 16px 0 0;max-width:100%;max-height:85vh;margin:0}.modal-header{padding:1rem 1.25rem}.modal-header h2{font-size:1.25rem}.modal-body{padding:1.25rem}.modal-footer{flex-direction:column-reverse;padding:1rem 1.25rem 1.5rem}.modal-footer button{width:100%;padding:1rem}.form-input,.form-textarea{padding:1rem;font-size:16px}}.delete-modal{max-width:450px}.delete-warning{margin-bottom:1.5rem}.delete-warning p{color:var(--text-primary);margin:0 0 .75rem;line-height:1.5}.delete-warning .warning-text{color:var(--text-secondary);font-size:.9rem}.delete-warning strong{color:var(--primary-color)}.modal-footer .btn-delete{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s}.modal-footer .btn-delete:hover:not(:disabled){background:#b91c1c}.modal-footer .btn-delete:disabled{opacity:.5;cursor:not-allowed}.build-projects .build-actions{border-top:1px solid var(--border-color);justify-content:flex-end;margin-top:1.25rem;padding-top:1rem;display:flex}.build-projects .btn-delete{color:#dc2626;cursor:pointer;background:0 0;border:1px solid #dc2626;border-radius:6px;padding:.5rem 1rem;font-size:.9rem;transition:all .2s}.build-projects .btn-delete:hover{color:#fff;background:#dc2626}.project-image-gallery{margin-top:1rem}.project-image-gallery .image-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.project-image-gallery .image-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;transition:all .2s;overflow:hidden}.project-image-gallery .image-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #00000026}.project-image-gallery .image-thumbnail{background:var(--background-color);cursor:pointer;justify-content:center;align-items:center;width:100%;height:180px;display:flex;overflow:hidden}.project-image-gallery .image-thumbnail img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.project-image-gallery .image-card:hover .image-thumbnail img{transform:scale(1.05)}.project-image-gallery .image-info{padding:.75rem}.project-image-gallery .image-description{color:var(--text-primary);margin:0 0 .5rem;font-size:.9rem;line-height:1.4}.project-image-gallery .image-date{color:var(--text-secondary);margin:0;font-size:.8rem}.project-image-gallery .edit-btn{width:100%;color:var(--primary-color);border:1px solid var(--primary-color);cursor:pointer;background:0 0;border-radius:0 0 8px 8px;padding:.6rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s}.project-image-gallery .edit-btn:hover{background:var(--primary-color);color:#fff}.project-image-gallery .image-modal-overlay{z-index:1000;cursor:pointer;background:#000000e6;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.project-image-gallery .image-modal{cursor:default;flex-direction:column;align-items:center;max-width:90vw;max-height:90vh;display:flex}.project-image-gallery .image-modal img{object-fit:contain;border-radius:8px;max-width:100%;max-height:80vh}.project-image-gallery .image-modal-description{color:#fff;text-align:center;margin-top:1rem;font-size:1rem}.project-image-gallery .close-modal-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;width:40px;height:40px;font-size:1.5rem;transition:all .2s;position:absolute;top:1.5rem;right:1.5rem}.project-image-gallery .close-modal-btn:hover{background:#fff3}.edit-modal-overlay{z-index:1100;background:#000000d9;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.edit-modal{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.edit-modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.edit-modal-header h3{color:var(--text-primary);margin:0;font-size:1.25rem}.edit-modal-header .close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1;transition:color .2s}.edit-modal-header .close-btn:hover{color:var(--primary-color)}.edit-modal-body{padding:1.5rem}.edit-preview{background:var(--background-color);border-radius:8px;justify-content:center;align-items:center;width:100%;max-height:350px;margin-bottom:1.5rem;display:flex;overflow:hidden}.edit-preview img{object-fit:contain;max-width:100%;max-height:350px;transition:transform .3s}.rotation-controls{background:var(--background-color);border-radius:8px;justify-content:center;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;display:flex}.rotate-btn,.btn-rotate{background:var(--card-bg);color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;border-radius:6px;align-items:center;gap:.4rem;padding:.6rem 1rem;font-size:.9rem;transition:all .2s;display:flex}.rotate-btn:hover,.btn-rotate:hover{border-color:var(--primary-color);color:var(--primary-color)}.rotate-btn:disabled,.btn-rotate:disabled{opacity:.5;cursor:not-allowed}.rotation-indicator{color:var(--text-primary);text-align:center;min-width:50px;font-size:1rem;font-weight:600}.description-field{margin-bottom:1rem}.description-field label{color:var(--text-primary);margin-bottom:.5rem;font-size:.95rem;font-weight:500;display:block}.description-field textarea{border:2px solid var(--border-color);background:var(--input-bg);width:100%;color:var(--text-primary);resize:vertical;box-sizing:border-box;border-radius:8px;min-height:80px;padding:.75rem 1rem;font-size:1rem;transition:border-color .2s}.description-field textarea:focus{border-color:var(--primary-color);outline:none}.description-field textarea::placeholder{color:var(--text-secondary)}.edit-modal-body .error-message{color:#ef4444;background:#dc354526;border:1px solid #dc35454d;border-radius:8px;margin-top:1rem;padding:.75rem 1rem;font-size:.9rem}.edit-modal-footer{border-top:1px solid var(--border-color);background:var(--background-color);border-radius:0 0 12px 12px;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.edit-modal-footer .delete-btn{color:#dc2626;cursor:pointer;background:0 0;border:1px solid #dc2626;border-radius:8px;padding:.7rem 1.25rem;font-size:.95rem;font-weight:500;transition:all .2s}.edit-modal-footer .delete-btn:hover:not(:disabled){color:#fff;background:#dc2626}.edit-modal-footer .delete-btn:disabled{opacity:.5;cursor:not-allowed}.footer-right{gap:.75rem;display:flex}.edit-modal-footer .cancel-btn{color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:8px;padding:.7rem 1.25rem;font-size:.95rem;font-weight:500;transition:all .2s}.edit-modal-footer .cancel-btn:hover:not(:disabled){border-color:var(--text-secondary)}.edit-modal-footer .cancel-btn:disabled{opacity:.5;cursor:not-allowed}.edit-modal-footer .save-btn{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.7rem 1.25rem;font-size:.95rem;font-weight:500;transition:all .2s}.edit-modal-footer .save-btn:hover:not(:disabled){background:#d94100}.edit-modal-footer .save-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.edit-modal-overlay{align-items:flex-end;padding:0}.edit-modal{border-radius:16px 16px 0 0;max-width:100%;max-height:90vh}.edit-modal-header{padding:1rem 1.25rem}.edit-modal-body{padding:1.25rem}.edit-preview,.edit-preview img{max-height:250px}.rotation-controls{flex-wrap:wrap;gap:.75rem}.rotate-btn{flex:1;justify-content:center;padding:.75rem 1rem}.edit-modal-footer{flex-direction:column;gap:.75rem;padding:1rem 1.25rem 1.5rem}.edit-modal-footer .delete-btn{order:3;width:100%}.footer-right{flex-direction:column-reverse;width:100%}.footer-right button{width:100%}.project-image-gallery .image-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.project-image-gallery .image-thumbnail{height:140px}}.project-image-upload{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;margin-top:1rem;padding:1.5rem}.project-image-upload h3{color:var(--text-primary);margin:0 0 1rem;font-size:1.1rem}.project-image-upload .upload-form{flex-direction:column;gap:1rem;display:flex}.project-image-upload .form-group{margin-bottom:0}.project-image-upload .form-group label{color:var(--text-primary);margin-bottom:.5rem;font-size:.9rem;font-weight:500;display:block}.project-image-upload select,.project-image-upload textarea{border:2px solid var(--border-color);background:var(--input-bg);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:8px;padding:.75rem 1rem;font-size:1rem;transition:border-color .2s}.project-image-upload select:focus,.project-image-upload textarea:focus{border-color:var(--primary-color);outline:none}.project-image-upload textarea{resize:vertical;min-height:80px}.project-image-upload .file-input-group input[type=file]{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.project-image-upload .upload-button{width:100%;padding:var(--spacing-lg);background:var(--background-color);border:2px dashed var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all var(--transition-normal);text-align:center;justify-content:center;align-items:center;min-height:60px;font-size:1rem;font-weight:500;display:flex}.project-image-upload .upload-button:hover{border-color:var(--primary-color);background:var(--accent-light);color:var(--primary-color)}.project-image-upload .upload-button:active{transform:scale(.98)}.project-image-upload .upload-button.disabled{opacity:.5;cursor:not-allowed}.project-image-upload .file-input-group input[type=file]:focus+.upload-button{outline:2px solid var(--primary-color);outline-offset:2px}.project-image-upload .image-preview{background:var(--background-color);border-radius:8px;margin-top:1rem;overflow:hidden}.project-image-upload .image-preview img{object-fit:contain;width:100%;max-height:300px}.project-image-upload .upload-status{background:var(--accent-light);text-align:center;border-radius:8px;padding:.75rem 1rem}.project-image-upload .upload-status p{color:var(--primary-color);margin:0;font-weight:500}.project-image-upload .error-message{color:#ef4444;background:#dc354526;border:1px solid #dc35454d;border-radius:8px;padding:.75rem 1rem;font-size:.9rem}@media (max-width:768px){.project-image-upload{padding:1rem}.project-image-upload .upload-button{padding:var(--spacing-md);min-height:50px}.project-image-upload .image-preview img{max-height:200px}}