body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;padding-top:0}.container{padding:0 1rem}.error-message{margin:1rem 0}.success-message{background:#51cf66;border-radius:5px;color:#fff;margin:1rem 0}.btn{border:none;border-radius:5px;cursor:pointer;display:inline-block;font-weight:600;padding:.75rem 1.5rem;text-align:center;text-decoration:none;transition:all .3s ease}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5a6fd8;transform:translateY(-2px)}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268;transform:translateY(-2px)}@media (max-width:768px){.container{padding:0 .5rem}.btn{padding:.5rem 1rem}}html{scroll-behavior:smooth}a:focus,button:focus,input:focus,select:focus,textarea:focus{outline:2px solid #667eea;outline-offset:2px}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .6s ease-out}.toast{background:#fff;border-radius:30px;box-shadow:0 4px 20px #00000026;font-family:inherit;max-width:500px;min-width:300px;opacity:0;padding:0;position:fixed;transform:translateY(-20px);transition:all .3s ease;transition:transform .3s ease,opacity .3s ease;z-index:9999}.toast.show{opacity:1;transform:translateY(0)}.toast.hide{opacity:0;transform:translateY(-20px)}.toast.top-right{right:20px;top:20px}.toast.top-left{left:20px;top:20px}.toast.bottom-right{bottom:20px;right:20px}.toast.bottom-left{bottom:20px;left:20px}.toast.top-center{left:50%;top:20px;transform:translateX(-50%)}.toast.bottom-center{bottom:20px;left:50%;transform:translateX(-50%)}.toast.success{color:#00ff3c}.toast.error{color:#ff0019}.toast.warning{color:#856404}.toast.info{color:#0c5460}.toast-content{gap:12px;padding:12px 16px}.toast-content,.toast-icon{align-items:center;display:flex}.toast-icon{flex-shrink:0;font-size:18px;font-weight:700;justify-content:center}.toast.success .toast-icon{color:#28a745}.toast.error .toast-icon{color:#dc3545}.toast.warning .toast-icon{color:#ffc107}.toast.info .toast-icon{color:#17a2b8}.toast-message{color:#313131;flex:1 1;font-size:16px;line-height:1.4}.toast-close{align-items:center;background:none;border:none;color:#0000;display:flex;font-size:20px;height:20px;justify-content:center;opacity:.7;padding:0;transition:opacity .2s ease;width:20px}.toast-close:hover{opacity:1}.toast+.toast{margin-top:10px}@media (max-width:480px){.toast{left:10px!important;max-width:calc(100vw - 20px);min-width:auto;right:10px!important}.toast.bottom-center,.toast.top-center{transform:none}}.auth-form{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:2rem;position:absolute;right:2rem;top:4rem;z-index:100}.auth-form h2,.auth-form input{margin-bottom:1rem}.auth-form input{display:block;width:100%}.auth-form button{margin-right:.5rem}.auth-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#00000059;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.auth-modal{animation:fadeInModal .2s;background:#fff;border-radius:25px;box-shadow:0 8px 32px #0000002e;margin:0;max-width:90vw;padding:2.5rem 2rem 2rem;position:relative;width:500px}@keyframes fadeInModal{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.auth-modal-close{background:none;border:none;border-radius:25px;color:#888;cursor:pointer;font-size:2rem;height:2rem;position:absolute;right:1rem;top:1rem;transition:color .2s;transition:background .2s ease,color .2s ease;width:2rem;z-index:1}.auth-modal-close:hover{background:#d5d5d5a0;color:#dc3545}.auth-modal h2{color:#333;margin-bottom:1.5rem;text-align:center}.auth-modal form{display:flex;flex-direction:column;gap:1rem}.auth-modal input{border:1px solid #ddd;border-radius:8px;font-size:1rem;margin-bottom:.5rem;padding:.7rem 1rem;transition:border-color .2s}.auth-modal input:focus{border-color:#667eea;outline:none}.auth-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:1rem 1.5rem;transition:background .2s,transform .2s}.auth-btn:hover:not(:disabled){background:linear-gradient(135deg,#764ba2,#667eea);transform:translateY(-2px)}.auth-btn:disabled{cursor:not-allowed;opacity:.7}.auth-btn.secondary{background:#f8f9fa;border:none;color:#333}.auth-btn.secondary:hover{background:#e9ecef}.error-message{color:#c00;font-size:1rem;margin-top:1rem}.navbar{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:linear-gradient(135deg,#667eea,#764ba2bd);box-shadow:0 2px 10px #0000001a;padding:1rem 0;position:sticky;top:0;z-index:1000}.nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 1rem;position:relative}.nav-logo{color:#fff;font-size:1.5rem;font-weight:700;text-decoration:none;transition:color .3s ease}.nav-logo:hover{color:#f0f0f0}.logo-container,.logo-image{height:40px;width:auto}.logo-container{align-items:center;display:flex;gap:.5rem}.nav-menu{display:flex;gap:1rem;list-style:none;margin:0;padding:0}.nav-link{border-radius:25px;color:#fff;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease}.nav-link:hover{background-color:#0000000f;transform:translateY(-2px)}.nav-link.active{background-color:#0000002c;transform:translateY(-2px)}#logoutBtn{background:#fff;color:#000;margin-left:2rem}#logoutBtn:hover{background:#000;color:#fff;transform:translateY(-2px)}.navbar-auth button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-left:.5rem;padding:.5rem 1.2rem;transition:background .2s,transform .2s}.navbar-auth button:hover{background:linear-gradient(135deg,#764ba2,#667eea);transform:translateY(-2px)}.navbar-auth span{color:#333;font-weight:500;margin-right:.5rem}.hamburger{cursor:pointer;display:none;flex-direction:column;padding:4px}.bar{background-color:#fff;border-radius:2px;height:3px;margin:3px 0;transition:.3s;width:25px}.hamburger .bar.active:first-child{transform:rotate(-45deg) translate(-5px,6px)}.hamburger .bar.active:nth-child(2){opacity:0}.hamburger .bar.active:nth-child(3){transform:rotate(45deg) translate(-5px,-6px)}@media (max-width:768px){.hamburger{display:flex}.nav-menu{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#667eea,#764ba2);border-radius:0 0 25px 25px;box-shadow:0 10px 27px #0000000d;flex-direction:column;gap:0;left:0;padding:2rem;position:fixed;text-align:center;top:-350px;transition:.3s;width:100%}.nav-menu.active{top:65px}.nav-item{margin:.3rem 0}.nav-link{display:block;font-size:1.1rem;height:2.5rem}#logoutBtn{margin-left:0;margin-top:1rem}}@media (max-width:480px){.nav-container{padding:0 .5rem}.logo-image{height:35px}}.home{align-items:center;background-image:linear-gradient(135deg,#667eea86,#764ba296);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding-bottom:2rem;position:relative;text-align:center}.home:before{background-image:url(/static/media/HomeBack.5365a98fadd4d8d4a025.png);background-position:50%;background-repeat:no-repeat;background-size:cover;bottom:0;content:"";filter:blur(5px);left:0;position:absolute;right:0;top:0;z-index:-1}.home-logo-container{align-items:center;display:flex;font-size:3rem;font-weight:700;gap:.5rem;height:40px;justify-content:center;margin-bottom:3rem;padding-top:2rem;width:auto}.home-nav-logo{color:#fff;font-size:3rem;font-weight:700;text-decoration:none;transition:color .3s ease}.home-nav-logo:hover{color:#f0f0f0}.home-logo-image{height:150px;width:auto}.hero{padding:4rem 1rem}.hero-content h1{font-size:3rem;font-weight:700;margin-bottom:1rem}.hero-content p{font-size:1.2rem;margin-bottom:2rem;opacity:.9}.cta-button{background:#fff3;border:2px solid #ffffff4d;border-radius:50px;color:#fff;display:inline-block;font-weight:600;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.cta-button:hover{background:#ffffff4d;box-shadow:0 10px 25px #0003;transform:translateY(-2px)}.stats{background:#f8f9fa2c;border-radius:25px;margin-bottom:2rem;max-width:95vw;padding:4rem;width:100%}.stats-container{margin:0 auto;text-align:center}.stats h1{color:#fff;margin-bottom:2rem}.stats-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{background:#fff;border-radius:25px;box-shadow:0 5px 15px #0000001a;padding:2rem;transition:all .3s ease}.stat-card:hover{box-shadow:0 5px 15px rgba(6,0,95,.332);transform:translateY(-5px)}.stat-card h3{color:#667eea;font-size:2.5rem;margin-bottom:.5rem}.stat-card p{color:#666;font-weight:500}.features{background:#f8f9fa2c;border-radius:25px;max-width:95vw;padding:4rem;width:100%}.features-container{margin:0 auto;text-align:center}.features h1{color:#fff;margin-bottom:3rem}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.feature-card{background:#ffffffd4;border:none;border-radius:25px;box-shadow:0 10px 30px #0000001a;color:inherit;padding:2rem;text-decoration:none;transition:all .3s ease}.feature-card:hover{background:#fff;box-shadow:0 20px 40px rgba(0,0,0,.284);transform:translateY(-15px)}.feature-card:hover .feature-icon{transform:scale(2) rotate(10deg)}.feature-card:hover h3{transform:scale(1.3)}.feature-icon{font-size:3rem;margin-bottom:2rem;transition:all .3s ease}.feature-card h3{color:#333;margin-bottom:1rem;transition:all .3s ease}.feature-card p{color:#666;line-height:1.6}.error-message{margin:1rem}@media (max-width:768px){.hero-content h1{font-size:2rem}.stats-grid{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.features-grid{grid-template-columns:1fr}}.search-bar{width:100%}.search-input-container{align-items:center;display:flex;position:relative}.search-input{background:hsla(0,0%,83%,.252);border:none;border-radius:50px;font-size:1rem;outline:none;padding:1rem 3rem 1rem 1rem;transition:all .3s ease;width:100%}.search-input:focus{border-color:#a8b6f4;box-shadow:0 0 0 3px #667eea1a}.search-button{align-items:center;background:#667eea;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:.75rem;position:absolute;right:3px;transition:all .3s ease}.search-button:hover{background:#5a6fd8;transform:scale(1.05)}.clear-button{background:#0000;border:none;color:#999;cursor:pointer;font-size:1.2rem;padding:.5rem;position:absolute;right:3.5rem;transition:color .3s ease}.clear-button:hover{color:#333}@media (max-width:768px){.search-input{padding:.75rem 3rem .75rem 1rem}}.fiber-card{background:#fff;border:1px solid #e9ecef;border-radius:25px;box-shadow:0 5px 15px #0000001a;overflow:hidden;transition:all .3s ease}.fiber-card:hover{box-shadow:0 15px 30px rgba(74,11,103,.289);transform:translateY(-5px)}.fiber-header{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:1.5rem}.fiber-name{font-size:1.3rem;margin:0}.fiber-type{border-radius:20px;color:#fff;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:.3rem .8rem;text-transform:uppercase}.fiber-details{padding:1.5rem}.detail-item{line-height:1.6;margin-bottom:1rem}.detail-item strong{color:#495057;display:inline-block;min-width:120px}.properties-grid{grid-gap:1rem;background:#f8f9fa;border-radius:8px;gap:1rem;grid-template-columns:1fr 1fr;margin:1rem 0;padding:1rem}.property-item{display:flex;flex-direction:column;gap:.25rem}.property-item label{color:#666;font-size:.8rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.property-item span{color:#333;font-weight:500}.end-uses{margin:1rem 0}.end-uses strong{color:#495057;display:block;margin-bottom:.5rem}.use-categories{display:flex;flex-wrap:wrap;gap:.5rem}.use-category{background:#667eea;border-radius:15px;color:#fff;font-size:.8rem;font-weight:500;padding:.25rem .75rem}.fiber-actions{background:#f8f9fa;border-top:1px solid #dee2e6;padding:1rem 1.5rem}.view-details-btn{background:#a0a0a0;border-radius:25px;color:#fff;display:inline-block;font-weight:600;padding:.75rem 1.5rem;text-align:center;text-decoration:none;transition:all .3s ease;width:100%}.view-details-btn:hover{background:#424242;transform:translateY(-2px)}@media (max-width:768px){.fiber-header{flex-direction:column;gap:1rem;text-align:center}.properties-grid{grid-template-columns:1fr}.use-categories{justify-content:center}}.add-fiber-form{background:#fff;border-radius:25px;box-shadow:0 5px 15px #0000001a;margin:0 auto;max-width:90vw;padding:1rem;width:800px;z-index:1002}.fiber-form-overlay{background:rgba(0,0,0,.252);z-index:1000}.fiber-form-container{background:#0000;padding:2rem 0;z-index:1001}.fiber-form-header{align-items:center;display:flex;font-size:32px;font-weight:700;justify-content:space-between;margin:0 0 2rem;padding:1rem}.form-header p{color:#333;margin:0}.close-btn{background:none;color:#666;font-size:1.5rem;padding:.5rem}.close-btn:hover{background:#f5f5f5;color:#333}.form-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;margin-bottom:2rem;padding:1rem}.form-section h3{border-bottom:1px solid #dee2e6;color:#495057;font-size:1.2rem;margin-bottom:1rem;padding-bottom:.5rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#495057;display:block;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:1px solid #ced4da;border-radius:8px;font-size:1rem;max-width:100%;padding:.75rem;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.property-group{margin-bottom:1.5rem}.property-group label{color:#495057;display:block;font-weight:600;margin-bottom:.5rem}.range-inputs input{border:1px solid #ced4da;border-radius:8px;padding:.75rem}.end-uses-group{margin-bottom:1.5rem}.end-uses-group label{color:#495057;display:block;font-weight:600;margin-bottom:.5rem}.add-item-input{display:flex;gap:.5rem;margin-bottom:1rem}.add-item-input input{border:1px solid #ced4da;border-radius:8px;flex:1 1;padding:.75rem}.add-item-input button{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:background-color .3s ease}.add-item-input button:hover{background:#5a6fd8}.items-list{display:flex;flex-wrap:wrap;gap:.5rem}.item-tag{align-items:center;background:#e9ecef;border-radius:20px;color:#495057;display:inline-flex;font-size:.9rem;padding:.5rem 1rem}.item-tag button{align-items:center;background:none;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;font-size:1rem;height:16px;justify-content:center;line-height:1;margin-left:.5rem;padding:0;width:16px}.item-tag button:hover{background:#dc3545;color:#fff}.form-actions{border-top:1px solid #dee2e6;margin-top:2rem;padding-top:2rem}.submit-btn{background:#28a745;border:none;border-radius:30px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:background-color .3s ease}.submit-btn:hover:not(:disabled){background:#218838}.submit-btn:disabled{background:#6c757d;cursor:not-allowed}#cancel-btn{background:#e92f2f}#cancel-btn:hover{background:#c82333}.error-message{border:1px solid #f5c6cb}.success-message{border-radius:15px;padding:3rem;text-align:center}.success-message h2{color:#155724;margin-bottom:1rem}.application-category,.testing-method-category{background:#fff;border:none;border-radius:8px;margin-bottom:2rem;padding:1rem}.application-category h4,.testing-method-category h4{color:#495057;font-size:1rem;font-weight:600;margin:0 0 1rem}.dropdown-container{border:none;border-radius:26px;margin-bottom:1rem}.dropdown-container select{background:#fff;border:1px solid #ced4da;border-radius:8px;font-size:1rem;padding:.75rem;width:100%}.new-item-form{background:#f8f9fa;border:none;border-radius:8px;margin:1rem 0;padding:1rem}.new-item-form h5{color:#495057;font-size:.9rem;font-weight:600;margin:0 0 1rem}.new-item-form input,.new-item-form textarea{border:1px solid #ced4da;border-radius:7px;font-size:.9rem;margin-bottom:.5rem;max-width:100%;padding:.5rem;width:100%}.new-item-form .form-actions{border:none;gap:.5rem;justify-content:flex-start;margin:.5rem 0 0;padding:0}.new-item-form .form-actions button{border:none;border-radius:4px;cursor:pointer;font-size:.9rem;padding:.5rem 1rem}.new-item-form .form-actions button:first-child{background:#28a745;color:#fff}.new-item-form .form-actions button:first-child:hover{background:#218838}.new-item-form .form-actions button:last-child{background:#6c757d;color:#fff}.new-item-form .form-actions button:last-child:hover{background:#5a6268}.selected-items{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}@media (max-width:768px){.add-fiber-form{margin:1rem;padding:1rem}.range-inputs{align-items:stretch;flex-direction:column}.range-inputs span{margin:.25rem 0;text-align:center}.add-item-input,.form-actions{flex-direction:column}}.fibers-page{background:#f8f9fa;min-height:100vh;padding:2rem 1rem}.container{margin:0 auto;max-width:1200px}.fibers-page h1{color:#333;font-size:2.5rem;margin-bottom:2rem;text-align:center}.filter-controls{align-items:center;border-radius:30px;display:flex;gap:1rem}.filter-controls label{color:#333;font-weight:600}.type-filter{border-radius:5px}.fibers-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.loading{align-items:center;color:#666;display:flex;font-size:1.2rem;height:50vh;justify-content:center}.error-message{background:#ff6b6b;border-radius:5px;color:#fff;text-align:center}.page-header{align-items:center;display:flex;justify-content:space-between}.page-header h1{color:#333;margin:0}.header-buttons{align-items:center;background:#e6e6e69a;border-radius:30px;display:flex;font-weight:500;padding:.3rem .5rem .3rem 2rem}.add-fiber-btn{align-items:center;background:#28a745;border:none;border-radius:25px;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;height:40px;margin-left:.3rem;padding:1rem 2rem;text-decoration:none;transition:background-color .3s ease}.add-fiber-btn:hover{background:#218838}#uploadBtn{background:#007bff}#uploadBtn:hover{background:#0069d9}@media (max-width:768px){.fibers-grid{grid-template-columns:1fr}.controls{padding:1rem}.filter-controls{align-items:flex-start;flex-direction:column}.page-header{flex-direction:column;gap:1rem;text-align:center}.add-fiber-btn{justify-content:center;width:100%}}.ai-suggestions-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.ai-suggestions-modal{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:900px;overflow:hidden;width:100%}.modal-header{align-items:center;background:#fff;color:#373737;display:flex;justify-content:space-between;padding:1.5rem 2rem}.modal-header h2{font-size:1.5rem;font-weight:700;margin:0}.close-btn{align-items:center;background:#d4d4d4;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;padding:0;transition:background-color .2s ease;width:40px}.close-btn:hover{background:#fff3}.modal-content{flex:1 1;overflow-y:auto;padding:2rem}.suggestion-options p{color:#666;font-size:1.1rem;margin-bottom:2rem;text-align:center}.options-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:1rem}.option-btn{align-items:center;background:#f8f9fa;border:2px solid #e9ecef;border-radius:12px;cursor:pointer;display:flex;font-size:1rem;gap:1rem;overflow:hidden;padding:1rem 1.5rem;position:relative;transition:all .1s ease}.option-btn:hover:not(:disabled){background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 5px 15px #667eea4d;color:#fff;transform:translateY(-2px)}.option-btn:disabled{cursor:not-allowed;opacity:.6}.option-btn.loading{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.option-icon{flex-shrink:0;font-size:1.5rem}.option-label{flex:1 1;font-weight:500;text-align:left}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;flex-shrink:0;height:20px;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.suggestions-result{display:flex;flex-direction:column;height:100%}.result-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.result-header h3{align-items:center;color:#333;display:flex;font-size:1.3rem;gap:.5rem;margin:0}.back-btn{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:background-color .2s ease}.back-btn:hover{background:#5a6268}.suggestions-content{color:#333;flex:1 1;line-height:1.6;overflow-y:auto}.suggestions-content h4{color:#667eea;font-size:1.1rem;font-weight:600;margin:1.5rem 0 .5rem}.suggestions-content p{margin:.5rem 0;text-align:justify}.suggestions-content li{list-style-position:inside;margin:.3rem 0}.suggestions-content br{margin:.5rem 0}@media (max-width:768px){.ai-suggestions-modal{margin:1rem;max-height:calc(100vh - 2rem);max-width:calc(100vw - 2rem)}.modal-header{padding:1rem 1.5rem}.modal-header h2{font-size:1.3rem}.modal-content{padding:1.5rem}.options-grid{gap:.8rem;grid-template-columns:1fr}.option-btn{font-size:.9rem;padding:.8rem 1rem}.result-header{align-items:flex-start;flex-direction:column;gap:1rem}.result-header h3{font-size:1.1rem}}@media (max-width:480px){.ai-suggestions-modal{border-radius:15px}.modal-content,.modal-header,.option-btn{padding:1rem}.option-btn{flex-direction:column;gap:.5rem;text-align:center}.option-icon{font-size:2rem}}.fiber-detail-page{background:#f8f9fa;min-height:100vh;padding:2rem 1rem}.back-link{color:#667eea;display:inline-block;font-weight:600;margin-bottom:2rem;text-decoration:none;transition:color .3s ease}.back-link:hover{color:#5a6fd8}.fiber-detail-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.fiber-detail-header h1{color:#333;font-size:2.5rem;margin:0;text-transform:capitalize}#aiSuggestionsBtn{align-items:center;background:linear-gradient(135deg,#ea66a1,#764ba2);display:flex;justify-items:center;transition:all .2s ease}#aiSuggestionsBtn:hover{background:linear-gradient(135deg,#c5296f,#681db2);box-shadow:0 4px 20px #681db2bd;transform:scale(1.05)}#aiSuggestionsBtn:hover .sparkle-icon{transform:scale(1.1)}.sparkle-icon{transition:all .3s ease}.fiber-type-badge{border-radius:25px;color:#fff;font-size:.9rem;font-weight:600;letter-spacing:.5px;padding:.5rem 1rem;text-transform:uppercase}.fiber-content{grid-gap:2rem;display:grid;gap:2rem}.applications-section,.basic-info,.notes-section,.properties-section,.testing-section{background:#fff;border-radius:15px;box-shadow:0 5px 15px #0000001a;padding:2rem}.applications-section h2,.basic-info h2,.notes-section h2,.properties-section h2,.testing-section h2{color:#333;font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem}.info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.info-item{background:#f8f9fa;border-radius:15px;padding:1rem;transition:background .3s ease}.info-item:hover{background:#e9ecef}.info-item strong{color:#495057;display:block;margin-bottom:.5rem}.properties-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.property-card{background:#649daa26;border:1px #667eea;border-radius:15px;color:#8a8a8a;padding:1.5rem;text-align:center;transition:transform .3s ease}.property-card:hover{background:#5acde746;transform:translateY(-5px)}.property-card h3{font-size:1.1rem;font-weight:500;margin:0 0 .5rem}.property-card p{color:#383838;font-size:1.2rem;font-weight:600;margin:0}.applications-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.application-category{background:#f8f9fa;border-radius:15px}.application-category h3{color:#333;font-size:1.2rem;margin-bottom:1rem}.application-category ul{list-style:none;margin:0;padding:0}.application-category li{border-bottom:1px solid #dee2e6;color:#666;padding:.5rem 0}.application-category li:last-child{border-bottom:none}.testing-grid{grid-gap:1rem;display:grid;gap:1rem}.test-method{background:#f8f9fa;border-left:4px solid #28a745;border-radius:8px;padding:1rem}.test-method strong{color:#495057;display:block;margin-bottom:.5rem}.notes-section p{color:#666;font-size:1.1rem;line-height:1.8}.edit-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.5rem 1.2rem}@media (max-width:768px){.fiber-header{flex-direction:column;text-align:center}.fiber-header h1{font-size:2rem}.info-grid{grid-template-columns:1fr}.properties-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.applications-grid{grid-template-columns:1fr}}.applications-page{background:#f8f9fa;min-height:100vh;padding:2rem 1rem}.applications-page h1{color:#333;font-size:2.5rem;margin-bottom:2rem;text-align:center}.controls{background:#fff;border-radius:30px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;padding:1.5rem}.category-filter{background:#fff;border:1px solid #ddd;border-radius:5px;font-size:1rem;padding:.5rem 1rem}.application-card{background:#fff;border:1px solid #e9ecef;border-radius:15px;box-shadow:0 5px 15px #0000001a;overflow:hidden;transition:all .3s ease}.application-card:hover{box-shadow:0 15px 30px #00000026;transform:translateY(-5px)}.application-header{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:.3rem 1.5rem}.application-header h3{color:#fff;font-size:1.3rem;font-weight:500;margin:0}.category-badge{font-size:.8rem}.category-apparel{background:#ff6b6b}.category-home_textiles{background:#4ecdc4}.category-technical_textiles{background:#45b7d1}.category-industrial{background:#96ceb4}.application-content{padding:1rem}.description{color:#666;line-height:1.6;margin-bottom:1rem}.link-like{border:none;border-radius:25px;cursor:pointer;margin:.2rem;padding:.5rem 1rem}.link-like:hover{background:#0000007f;color:#fff}.fiber-info p,.market-segment strong{color:#838383;display:block;font-size:14px;font-weight:600;margin-bottom:.25rem}.requirements{margin-bottom:1rem}.requirements strong{color:#495057;display:block;margin-bottom:.5rem}.requirements ul{color:#666;margin:0;padding-left:1.5rem}.requirements li{margin-bottom:.25rem}.skeleton{opacity:.95;pointer-events:none}.skeleton-header{align-items:center;display:flex;justify-content:space-between;padding:.6rem 1rem}.skeleton-line{animation:shimmer 1.2s linear infinite;background:linear-gradient(90deg,#eee 25%,#f7f7f7 50%,#eee 75%);background-size:200% 100%;border-radius:6px;height:12px;margin-bottom:.6rem;width:100%}.skeleton-line.short{height:16px;width:40%}.skeleton-line.medium{height:14px;width:70%}.skeleton-badge{border-radius:12px;height:20px;width:80px}.skeleton-badge,.skeleton-pill{animation:shimmer 1.2s linear infinite;background:linear-gradient(90deg,#eee 25%,#f7f7f7 50%,#eee 75%);background-size:200% 100%}.skeleton-pill{border-radius:25px;display:inline-block;height:26px;margin:.25rem;width:70px}#button-pill{height:40px;width:100%}.skeleton-row{font-weight:500;padding:.5rem 0;text-align:center}#fiber-info{width:30%}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (max-width:768px){.skeleton-header{align-items:flex-start;flex-direction:column;gap:.6rem}}.glossary-page{background:#f8f9fa;min-height:100vh;padding:2rem 1rem}.glossary-page h1{color:#333;font-size:2.5rem;margin:0}.add-term-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.add-term-btn:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.add-term-form{background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000001a;margin-bottom:2rem;overflow:hidden}.form-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:1.5rem 2rem}.form-header h2{font-size:1.5rem;margin:0}.add-term-form form{padding:2rem}.form-row{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.form-actions{border-top:1px solid #eee;display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem}.cancel-btn{background:#c34d4d;border:none;border-radius:30px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s ease}.cancel-btn:hover{background:#5a6268;transform:translateY(-2px)}.success-message{background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;color:#155724;margin-bottom:1rem;padding:1rem}.error-message{background:#f8d7da;border:1px solid #f5c2c7;border-radius:8px;color:#721c24;margin-bottom:1rem;padding:1rem}.filter-row{gap:2rem}.filter-group label{min-width:80px}.category-filter,.letter-filter{background:#fff;border:1px solid #ddd;border-radius:5px;font-size:1rem;min-width:150px;padding:.5rem 1rem}.glossary-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.term-card{background:#fff;border:1px solid #e9ecef;border-radius:15px;box-shadow:0 5px 15px #0000001a;overflow:hidden;transition:all .3s ease}.term-card:hover{box-shadow:0 15px 30px #00000026;transform:translateY(-5px)}.term-header{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:1.5rem}.term-title{color:#333;font-size:1.3rem;font-weight:600;margin:0;text-transform:capitalize}.category-badge{border-radius:20px;color:#fff;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.3rem .8rem;text-transform:uppercase}.term-content{padding:1.5rem}.definition{color:#666;font-size:1rem;line-height:1.6}.definition,.synonyms{margin-bottom:1rem}.synonyms strong{color:#495057;display:block;font-size:.9rem;margin-bottom:.5rem}.synonym-tags{display:flex;flex-wrap:wrap;gap:.5rem}.synonym-tag{background:#e9ecef;border-radius:12px;color:#495057;font-size:.8rem;font-weight:500;padding:.25rem .5rem}.examples{margin-bottom:1rem}.examples strong{color:#495057;display:block;font-size:.9rem;margin-bottom:.5rem}.examples ul{color:#666;margin:0;padding-left:1.5rem}.examples li{font-size:.9rem;margin-bottom:.25rem}.tags{margin-bottom:1rem}.tags strong{color:#495057;display:block;font-size:.9rem;margin-bottom:.5rem}.tag-list{display:flex;flex-wrap:wrap;gap:.3rem}.tag{background:#f8f9fa;border:1px solid #dee2e6;border-radius:10px;color:#495057;font-size:.75rem;font-weight:500;padding:.2rem .4rem}.difficulty{display:flex;justify-content:flex-end}.difficulty-badge{border-radius:15px;color:#fff;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.difficulty-beginner{background:#28a745}.difficulty-intermediate{background:#ffc107;color:#333}.difficulty-advanced{background:#dc3545}.no-results{border-radius:10px;box-shadow:0 2px 10px #0000001a}@media (max-width:768px){.form-row{gap:1rem;grid-template-columns:1fr}.form-actions{flex-direction:column}.glossary-grid{grid-template-columns:1fr}.filter-row{flex-direction:column;gap:1rem}.filter-group{align-items:flex-start;flex-direction:column}.filter-group label{min-width:auto}.category-filter,.letter-filter{min-width:100%}.term-header{flex-direction:column;gap:1rem;text-align:center}}.properties-page{background:#f8f9fa;min-height:100vh;padding:2rem 1rem}.properties-page h1{color:#333;font-size:2.5rem;text-align:center}.filters-section{display:flex;flex-direction:column;gap:1.5rem}.filter-row{flex-wrap:wrap;gap:1rem;justify-content:space-between}.filter-group,.filter-row{align-items:center;display:flex}.filter-group{gap:.5rem}.filter-group label{color:#333;font-weight:600;white-space:nowrap}.type-filter{background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:1rem;min-width:150px;padding:.5rem 1rem}.clear-filters-btn{align-items:center;background:#dc3545;border:none;border-radius:25px;color:#fff;cursor:pointer;display:flex;font-weight:600;padding:.5rem 2rem;transition:all .3s ease}.clear-filters-btn:hover:not(:disabled){box-shadow:0 5px 15px #dc354566;transform:scale(.9)}.clear-filters-btn:disabled{background:#979797;box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}#toggleRangeBtn{background:#4caf50}#toggleRangeBtn:hover:not(:disabled){background:#037d09;box-shadow:0 5px 15px #51dc3566}.range-filters{background:#d4d4d400;border-radius:25px;border-top:1px solid #e9ecef;max-height:0;opacity:0;overflow:hidden;padding:0 1rem;transform:translateY(-10px);transition:max-height .36s cubic-bezier(.2,.9,.2,1),opacity .26s ease,transform .26s ease;will-change:max-height,opacity,transform}.range-filters.open{background:hsla(0,0%,83%,.252);max-height:1200px;opacity:1;padding:1rem;transform:translateY(0)}.range-filters.closed{padding-bottom:0;padding-top:0}.range-filters .range-filters-grid .range-filter-group{opacity:0;transform:translateY(-6px);transition:opacity .3s ease,transform .3s ease}.range-filters.open .range-filters-grid .range-filter-group{opacity:1;transform:translateY(0)}.range-filters.open .range-filters-grid .range-filter-group:first-child{transition-delay:.02s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(2){transition-delay:.04s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(3){transition-delay:.06s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(4){transition-delay:.08s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(5){transition-delay:.1s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(6){transition-delay:.12s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(7){transition-delay:.14s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(8){transition-delay:.16s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(9){transition-delay:.18s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(10){transition-delay:.2s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(11){transition-delay:.22s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(12){transition-delay:.24s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(13){transition-delay:.26s}.range-filters.open .range-filters-grid .range-filter-group:nth-child(14){transition-delay:.28s}@media (max-width:768px){.range-filters{transition-duration:.28s}}.range-filters h3{color:#333;font-size:1.2rem;margin:0 0 1rem}.range-filters-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.range-filter-group{background:#fff;border-radius:15px;display:flex;flex-direction:column;gap:.5rem;padding:.5rem;transition:all .3s ease}.range-filter-group:hover{box-shadow:0 2px 10px #0000001a}.range-filter-group label{color:#555;font-size:.9rem;font-weight:600}.range-inputs{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.range-inputs input{background:#f4f4f4;border:1px solid #ddd;border-radius:10px;flex:1 1;font-size:.9rem;max-width:80px;padding:.5rem}.range-inputs input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.range-inputs span{color:#666;font-size:.9rem;font-weight:500}.active-filters{background:#e8f3ff;border:none;border-radius:25px;padding:1rem}.active-filters strong{color:#333;display:block;margin-bottom:.5rem}.active-filters-list{display:flex;flex-wrap:wrap;gap:.5rem}.active-filter-tag{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;color:#fff;font-size:.8rem;font-weight:500;padding:.25rem .75rem}.results-info{color:#666;font-weight:500;margin-bottom:1rem}.filter-info{color:#999;font-size:.9rem;margin-top:.25rem}.properties-table{background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000001a;overflow:hidden;overflow-x:auto}.table-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:grid;font-weight:600;grid-template-columns:1fr 120px 120px 120px 140px 120px;min-width:720px}.header-cell{border-right:1px solid #fff3;font-size:.9rem;padding:1rem;text-align:center}.header-cell:last-child{border-right:none}.table-row{border-bottom:1px solid #e9ecef;display:grid;grid-template-columns:1fr 120px 120px 120px 140px 120px;min-width:720px;transition:all .3s ease}.table-row:hover{background-color:#f8f9fa;box-shadow:0 2px 10px #0000001a;transform:translateY(-1px)}.table-row:last-child{border-bottom:none}.table-cell{align-items:center;border-right:1px solid #e9ecef;display:flex;font-size:.9rem;justify-content:center;padding:1rem;text-align:center}.table-cell:last-child{border-right:none}.fiber-name{color:#333;cursor:pointer;font-weight:600;justify-content:flex-start;text-transform:capitalize}.fiber-name:hover{color:#667eea}.type-badge{border-radius:15px;color:#fff;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .5rem;text-transform:uppercase}.type-natural{background:#4caf50}.type-regenerated{background:#ff9800}.type-synthetic{background:#2196f3}.type-other{background:#9e9e9e}.no-results{background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000001a;padding:3rem;text-align:center}.no-results h3{color:#333;font-size:1.5rem;margin-bottom:1rem}.no-results p{color:#666;margin-bottom:1.5rem}@media (max-width:1200px){.range-filters-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media (max-width:1024px){.properties-table{overflow-x:auto}.range-filters-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.properties-page{padding:1rem .5rem}.controls{padding:1.5rem}.filter-row{align-items:stretch;flex-direction:column}.filter-group{align-items:flex-start;flex-direction:column}.type-filter{min-width:100%}.range-filters-grid{gap:1rem;grid-template-columns:1fr}.range-inputs{flex-wrap:wrap}.range-inputs input{max-width:100px}.table-header,.table-row{font-size:.8rem;grid-template-columns:1fr 100px 100px 100px 120px 100px}.header-cell,.table-cell{padding:.75rem .5rem}.active-filters-list{justify-content:center}}@media (max-width:480px){.properties-page h1{font-size:2rem}.range-inputs{flex-direction:column;gap:.25rem}.range-inputs span{align-self:center}.range-inputs input{max-width:100%}}.bulk-container{backdrop-filter:blur(12px) saturate(180%);-webkit-backdrop-filter:blur(12px) saturate(180%);background:#ffffff2e;border:1px solid #ffffff40;border-radius:18px;box-shadow:0 8px 32px #667eea26;margin:2rem auto;max-width:1100px;padding:1.5rem}.bulk-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.bulk-header h2{color:#667eea;font-weight:800;margin:0}.bulk-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.file-input{background:#ffffff38;border:1px solid #ffffff59;border-radius:12px;color:#667eea;cursor:pointer;font-weight:600;overflow:hidden;padding:.65rem 1rem;position:relative}.file-input input[type=file]{background:#bfbfbf;cursor:pointer;inset:0;opacity:0;position:absolute}.file-input span{pointer-events:none}.bulk-actions button{backdrop-filter:blur(6px) saturate(180%);-webkit-backdrop-filter:blur(6px) saturate(180%);background:#6cee60;border:1px solid #ffffff59;border-radius:12px;box-shadow:0 2px 8px #667eea14;color:#000;cursor:pointer;font-weight:600;padding:.65rem 1rem;transition:background .2s,color .2s}.bulk-actions button:hover{background:#03166b;color:#fff}.bulk-actions .primary{background:#667eea;color:#fff}.bulk-actions .muted{color:#555}.summary{color:#333;margin:.5rem 0 1rem}.summary .hint{color:#555;font-size:.9rem}.glassy{backdrop-filter:blur(6px) saturate(180%);-webkit-backdrop-filter:blur(6px) saturate(180%);background:#ffffff38;border:1px solid #ffffff2e;border-radius:12px;box-shadow:0 2px 8px #667eea14;margin-bottom:1rem;padding:1rem}.preview h3{color:#764ba2;margin:0 0 .75rem}.table-wrapper{border-radius:8px;max-height:360px;overflow:auto}table{border-collapse:collapse;font-size:.95rem;width:100%}thead th{background:#667eea38;color:#fff;position:sticky;text-align:left;top:0}tbody td,thead th{padding:.5rem .75rem}tbody td{border-top:1px solid #ffffff4d;color:#222}.progress .bar{background:#00000014;border-radius:999px;height:10px;margin-bottom:.5rem;overflow:hidden}.progress .fill{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:999px;height:100%;transition:width .2s ease;width:0}.progress .stats{color:#333;font-size:.95rem}.results{align-items:center;color:#333;display:flex;flex-wrap:wrap;gap:1rem}.results .success{color:#2e7d32;font-weight:700}.results .fail{color:#c62828;font-weight:700}.fail-list h4{color:#c62828;margin:0 0 .5rem}.fail-list ul{margin:0;padding-left:1rem}.error-box{backdrop-filter:blur(4px) saturate(180%);-webkit-backdrop-filter:blur(4px) saturate(180%);background:#ff00501f;border:1px solid #ff00502e;border-radius:10px;box-shadow:0 2px 8px #ff005014;color:#fff;margin-bottom:1rem;padding:1rem}@media (max-width:768px){.bulk-actions{justify-content:flex-start;width:100%}}
/*# sourceMappingURL=main.3afe75f6.css.map*/