*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}#root{align-items:center;justify-content:center}#root,.App{display:flex;min-height:100vh}.App{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-direction:column;width:100vw}.app-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-bottom:1px solid #fff3;padding:1.5rem 2rem;text-align:center}.app-header h1{font-size:3rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 2px 4px #0000004d}.app-header p{font-size:1.3rem;font-weight:300;opacity:.9}.back-btn{background:#ffffff1a;border:1px solid #ffffff4d;border-radius:25px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;margin-top:1rem;padding:.8rem 1.5rem;transition:all .3s ease}.back-btn:hover{background:#fff3;border-color:#ffffff80;transform:translateY(-2px)}.app-main{align-items:center;display:flex;flex:1 1;justify-content:center;padding:3rem 2rem;width:100%}.app-footer{background:#0003;border-top:1px solid #ffffff1a;padding:1rem;text-align:center}.app-footer p{font-size:.9rem;opacity:.8}@media (max-width:768px){.app-header{padding:1rem 1.5rem}.app-header h1{font-size:2.2rem}.app-header p{font-size:1.1rem}.app-main{padding:2rem 1rem}}@media (max-width:480px){.app-header h1{font-size:1.8rem}.app-header p{font-size:1rem}.app-main{padding:1rem}}.project-gallery{margin:0 auto;max-width:1400px;padding:0 1rem;width:100%}.gallery-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;padding:3rem}.gallery-header{margin-bottom:3rem;text-align:center}.gallery-header h2{color:#fff;font-size:2.5rem;font-weight:600;margin-bottom:.5rem}.gallery-header p{color:#ffffffe6;font-size:1.2rem;opacity:.8}.category-filter{margin-bottom:3rem;text-align:center}.category-filter h3{color:#fff;font-size:1.3rem;font-weight:500;margin-bottom:1rem}.category-buttons{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}.category-btn{background:#ffffff1a;border:1px solid #ffffff4d;border-radius:25px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:.8rem 1.5rem;transition:all .3s ease}.category-btn:hover{background:#fff3;border-color:#ffffff80;transform:translateY(-2px)}.category-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 4px 15px #667eea4d}.projects-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-bottom:2rem}.project-card{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:15px;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease}.project-card:hover{border-color:#ffffff4d;box-shadow:0 15px 35px #0003;transform:translateY(-5px)}.project-thumbnail{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;height:200px;justify-content:center;overflow:hidden;position:relative}.thumbnail-icon{font-size:4rem;opacity:.8;transition:all .3s ease}.thumbnail-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:all .3s ease}.project-card:hover .thumbnail-overlay{opacity:1}.project-card:hover .thumbnail-icon{transform:scale(1.1)}.view-icon{color:#fff;font-size:2rem}.project-info{display:flex;flex:1 1;flex-direction:column;padding:1.5rem}.project-info h3{color:#fff;font-size:1.3rem;font-weight:600;margin-bottom:.5rem}.project-description{color:#fffc;flex:1 1;font-size:.95rem;line-height:1.4;margin-bottom:1rem}.project-category{border-radius:15px;display:inline-block;font-size:.8rem;margin-bottom:1rem;padding:.3rem .8rem}.feature-tag{border-radius:10px;font-size:.8rem;padding:.3rem .6rem}.feature-tag.more{background:#ffffff0d;color:#fff9}.project-action{padding:0 1.5rem 1.5rem}.action-buttons{display:flex;flex-direction:column;gap:.8rem}.view-project-btn{align-items:center;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;padding:.8rem 1.2rem;transition:all .3s ease;width:100%}.view-project-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2)}.view-project-btn.secondary{background:linear-gradient(135deg,#ff6b6b,#ee5a24)}.view-project-btn:hover{transform:translateY(-2px)}.view-project-btn.primary:hover{box-shadow:0 8px 25px #667eea4d}.view-project-btn.secondary:hover{box-shadow:0 8px 25px #ff6b6b4d}.btn-icon{font-size:1rem}.btn-arrow{font-size:1.1rem;transition:transform .3s ease}.project-card:hover .btn-arrow{transform:translateX(3px)}.no-projects{color:#ffffffb3;padding:3rem;text-align:center}.no-projects h3{color:#fff;font-size:1.5rem;margin-bottom:.5rem}@media (max-width:768px){.gallery-container{padding:2rem 1.5rem}.gallery-header h2{font-size:2rem}.gallery-header p{font-size:1rem}.projects-grid{gap:1.5rem;grid-template-columns:1fr}.category-buttons{gap:.5rem}.category-btn{font-size:.9rem;padding:.6rem 1.2rem}.project-thumbnail{height:150px}.thumbnail-icon{font-size:3rem}.project-info{padding:1rem}.project-action{padding:0 1rem 1rem}.action-buttons{gap:.6rem}.view-project-btn{font-size:.85rem;padding:.7rem 1rem}}@media (max-width:480px){.gallery-container{padding:1.5rem 1rem}.gallery-header h2{font-size:1.8rem}.project-thumbnail{height:120px}.thumbnail-icon{font-size:2.5rem}}.project-viewer{margin:0 auto;max-width:1400px;width:100%}.viewer-header p{color:#ffffffe6;font-size:1.2rem;margin-bottom:1.5rem;margin-left:auto;margin-right:auto;max-width:800px;opacity:.8}.project-features{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1rem}.feature-tag{background:#ffffff1a;border:1px solid #fff3;border-radius:15px;color:#ffffffe6;font-size:.85rem;padding:.4rem .8rem;transition:all .3s ease}.feature-tag:hover{background:#ffffff26;transform:translateY(-1px)}.iframe-container{background:#000;border-radius:15px;box-shadow:0 10px 30px #0003;margin:0 auto 2.5rem;max-width:900px;overflow:hidden;position:relative;width:100%}.model-iframe{border:none;display:block;height:500px;transition:opacity .3s ease;width:100%}.loading-overlay{align-items:center;background:#000c;bottom:0;color:#fff;display:flex;flex-direction:column;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:40px;margin-bottom:1rem;width:40px}.loading-overlay p{font-size:1rem;font-weight:500}.error-message{padding:2rem}.viewer-controls{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:15px;padding:1.5rem}.view-model-section{margin-bottom:2rem;text-align:center}.model-preview{margin-bottom:2rem}.preview-placeholder{background:#ffffff0d;border:2px dashed #ffffff4d;border-radius:15px;margin:0 auto;max-width:500px;padding:3rem 2rem;transition:all .3s ease}.preview-placeholder:hover{background:#ffffff14;border-color:#ffffff80;transform:translateY(-2px)}.preview-icon{display:block;font-size:4rem;margin-bottom:1rem}.preview-placeholder h3{color:#fff;font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.preview-placeholder p{color:#fffc;font-size:1rem;margin:0}.view-model-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50px;box-shadow:0 8px 25px #667eea4d;color:#fff;cursor:pointer;display:inline-flex;font-size:1.2rem;font-weight:600;gap:.5rem;padding:1rem 2.5rem;transition:all .3s ease}.view-model-btn:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190);box-shadow:0 12px 35px #667eea66;transform:translateY(-2px)}.view-model-btn:active{transform:translateY(0)}.btn-icon{font-size:1.3rem}.retry-btn{margin-top:1rem}@media (max-width:768px){.viewer-container{margin:1rem;padding:1.5rem}.viewer-header h2{font-size:2rem}.viewer-header p{font-size:1rem}.iframe-container{margin-bottom:1.5rem;max-width:100%}.viewer-controls{padding:1rem}.preview-placeholder{padding:2rem 1rem}.preview-icon{font-size:3rem}.view-model-btn{font-size:1.1rem;padding:.8rem 2rem}}@media (max-width:600px){.model-iframe{height:300px}.viewer-header h2{font-size:1.8rem}.preview-placeholder h3{font-size:1.3rem}}.model-3d-viewer{margin:0 auto;max-width:1400px;width:100%}.viewer-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;padding:3rem}.viewer-header{margin-bottom:2.5rem;text-align:center}.project-title-section{margin-bottom:1rem}.viewer-header h2{color:#fff;font-size:2.5rem;font-weight:600;margin-bottom:.5rem}.project-meta{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:1rem}.project-category{background:#667eea33;border:1px solid #667eea4d;border-radius:20px;color:#667eea}.project-category,.project-id{font-size:.9rem;font-weight:500;padding:.4rem 1rem}.project-id{background:#ffffff1a;border:1px solid #fff3;border-radius:20px;color:#fffc}.project-description{color:#ffffffe6;font-size:1.2rem;margin-bottom:1.5rem;margin-left:auto;margin-right:auto;max-width:800px;opacity:.8}.model-container{margin:0 auto;max-width:1000px;position:relative;width:100%}.model-viewer{background:#000;border-radius:15px;box-shadow:0 10px 30px #0000004d;height:600px;overflow:hidden;position:relative;width:100%}.model-loader{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;text-align:center}.loader-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loader-text{font-size:1rem;font-weight:500}.model-controls{align-items:flex-start;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:15px;display:flex;gap:2rem;justify-content:space-between;margin-top:1.5rem;padding:1.5rem}.control-info h4{color:#fff;font-size:1.2rem;font-weight:600;margin-bottom:1rem}.control-info ul{list-style:none;margin:0;padding:0}.control-info li{border-bottom:1px solid #ffffff1a;color:#fffc;font-size:.95rem;padding:.5rem 0}.control-info li:last-child{border-bottom:none}.control-info li:before{color:#667eea;content:"•";display:inline-block;font-weight:700;margin-right:.5rem;width:1em}.control-actions{display:flex;flex-direction:column;gap:.8rem;min-width:150px}.control-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.8rem 1.2rem;transition:all .3s ease}.control-btn:hover{box-shadow:0 4px 15px #667eea4d;transform:translateY(-2px)}.show-controls-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000b3;border:1px solid #ffffff4d;border-radius:20px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.6rem 1rem;position:absolute;right:1rem;top:1rem;transition:all .3s ease}.show-controls-btn:hover{background:#000c;border-color:#ffffff80}.error-message{color:#fff;padding:3rem;text-align:center}.error-message h3{color:#ff6b6b;font-size:1.5rem;margin-bottom:1rem}.error-message p{font-size:1rem;margin-bottom:1.5rem;opacity:.8}.retry-btn{background:#ff6b6b;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.8rem 1.5rem;transition:all .3s ease}.retry-btn:hover{background:#ff5252;transform:translateY(-1px)}@media (max-width:768px){.viewer-container{padding:2rem 1.5rem}.viewer-header h2{font-size:2rem}.project-description{font-size:1rem}.model-viewer{height:400px}.model-controls{flex-direction:column;gap:1.5rem}.control-actions{min-width:auto}.control-btn{width:100%}}@media (max-width:480px){.viewer-container{padding:1.5rem 1rem}.viewer-header h2{font-size:1.8rem}.model-viewer{height:300px}.project-meta{align-items:center;flex-direction:column}}
/*# sourceMappingURL=main.eb8fa3c6.css.map*/