*{margin:0;padding:0;box-sizing:border-box}html{background-color:#000}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#000,#1a1a1a);color:#e0e0e0;min-height:100vh;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-tap-highlight-color:rgba(57,255,20,.3)}@supports (padding: env(safe-area-inset-top)){body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#0000004d}::-webkit-scrollbar-thumb{background:#39ff14;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#50ff30}::selection{background:transparent;color:inherit}.page-container{max-width:1200px;margin:0 auto}.page-header{margin-bottom:2rem;text-align:center}.page-title{font-size:2rem;color:#fff;margin-bottom:.5rem;text-shadow:0 0 20px rgba(57,255,20,.3)}.page-subtitle{color:#e0e0e0;font-size:1.1rem}.loading,.error{text-align:center;padding:3rem;color:#39ff14;font-size:1.2rem}.floor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.floor-card{background:#1a1a1acc;border:2px solid #39ff14;border-radius:15px;padding:2rem;text-decoration:none;transition:all .3s;text-align:center}.floor-card:hover{transform:translateY(-5px);background:#39ff141a;box-shadow:0 10px 30px #39ff1466;border-color:#50ff30}.floor-card h2{color:#fff;font-size:1.5rem;margin-bottom:.5rem}.floor-rooms-count{color:#e0e0e0;font-size:.9rem}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.room-card{background:#1a1a1acc;border:2px solid #39ff14;border-radius:15px;padding:1.5rem;text-decoration:none;transition:all .3s}.room-card:hover{transform:translateY(-3px);background:#39ff141a;box-shadow:0 8px 20px #39ff144d}.room-card h3{color:#fff;margin-bottom:.5rem}.room-card p{color:#e0e0e0;font-size:.9rem;line-height:1.5}.species-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem}.species-card{background:#1a1a1acc;border:2px solid #39ff14;border-radius:15px;overflow:hidden;text-decoration:none;transition:all .3s}.species-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px #39ff1466;border-color:#50ff30}.species-card img{width:100%;height:180px;object-fit:cover;border-bottom:2px solid #39ff14}.species-card-content{padding:1rem}.species-card h3{color:#fff;font-size:1.1rem;margin-bottom:.5rem}.scientific-name{color:#e0e0e0;font-style:italic;font-size:.85rem}.species-detail{max-width:900px;margin:0 auto}.species-gallery{position:relative;border-radius:20px;overflow:hidden;margin-bottom:2rem;background:#00000080}.species-gallery img{width:100%;height:400px;object-fit:cover}.gallery-controls{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:1rem;background:#000000e6;padding:.5rem 1rem;border-radius:25px;border:1px solid #39ff14}.gallery-btn{background:transparent;border:none;color:#39ff14;font-size:1.2rem;cursor:pointer;padding:.5rem;transition:all .3s}.gallery-btn:hover{color:#50ff30;text-shadow:0 0 10px rgba(57,255,20,.5)}.gallery-indicator{color:#e0e0e0;font-size:.9rem}.species-info{background:#1a1a1acc;border:2px solid #39ff14;border-radius:20px;padding:2rem}.species-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.species-header h1{color:#fff;font-size:2rem;margin-bottom:.5rem;text-shadow:0 0 20px rgba(57,255,20,.2)}.species-actions{display:flex;gap:.75rem}.action-btn{background:#39ff141a;border:1px solid #39ff14;border-radius:50%;width:45px;height:45px;display:flex;align-items:center;justify-content:center;color:#39ff14;font-size:1.2rem;cursor:pointer;transition:all .3s}.action-btn:hover{background:#39ff1433;transform:scale(1.1);box-shadow:0 0 15px #39ff1466}.favorite-active{color:#ff6b4a}.conservation-badge{display:inline-block;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:600;margin-bottom:1rem}.conservation-badge.status-lc{background:#39ff14;color:#000}.conservation-badge.status-vu,.conservation-badge.status-nt{background:#fa0;color:#000}.conservation-badge.status-en,.conservation-badge.status-cr{background:#ff6b4a;color:#fff}.species-location{color:#e0e0e0;margin-bottom:1.5rem}.species-location a{color:#39ff14;text-decoration:none;border-bottom:1px dashed #39ff14;transition:all .3s}.species-location a:hover{color:#50ff30;text-shadow:0 0 10px rgba(57,255,20,.5)}.species-description,.species-facts{margin-bottom:2rem}.species-description h2,.species-facts h2{color:#fff;font-size:1.3rem;margin-bottom:1rem}.species-description p{color:#e0e0e0;line-height:1.7}.species-facts ul{list-style:none;padding:0}.species-facts li{color:#e0e0e0;padding:.75rem;margin-bottom:.5rem;background:#39ff140d;border-left:3px solid #39ff14;border-radius:5px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem;text-align:center}.loading-spinner{width:60px;height:60px;border:4px solid rgba(57,255,20,.2);border-top:4px solid #39ff14;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.qr-scanner-page{display:flex;justify-content:center;align-items:center;min-height:70vh}.scanner-container{max-width:500px;width:100%}.scanner-header{text-align:center;margin-bottom:2rem}.scanner-header h2{color:#fff;margin-bottom:.5rem}.scanner-header p{color:#e0e0e0}.video-container{position:relative;border-radius:20px;overflow:hidden;background:#000}.scanner-video{width:100%;height:400px;object-fit:cover}.scanner-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.scanner-frame{width:250px;height:250px;border:3px solid #39ff14;border-radius:20px;box-shadow:0 0 0 1000px #00000080,0 0 20px #39ff1480}.scanner-error{margin-top:1rem;padding:1rem;background:#ff6b4a33;border:1px solid #ff6b4a;border-radius:10px;color:#ff6b4a;text-align:center}.auth-page{display:flex;justify-content:center;align-items:center;min-height:70vh}.auth-container{max-width:400px;width:100%;background:#1a1a1ae6;border:2px solid #39ff14;border-radius:20px;padding:2rem;box-shadow:0 0 30px #39ff144d}.auth-container h1{color:#fff;text-align:center;margin-bottom:1.5rem;text-shadow:0 0 20px rgba(57,255,20,.3)}.auth-error{background:#ff6b4a33;border:1px solid #ff6b4a;color:#ff6b4a;padding:.75rem;border-radius:10px;margin-bottom:1rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#e0e0e0;font-size:.9rem}.form-group input{padding:.75rem;border:1px solid #39ff14;border-radius:10px;background:#00000080;color:#fff;font-size:1rem}.form-group input:focus{outline:none;border-color:#50ff30;box-shadow:0 0 10px #39ff144d}.auth-button{padding:1rem;background:#39ff14;border:none;border-radius:10px;color:#000;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;margin-top:.5rem}.auth-button:hover{background:#50ff30;transform:translateY(-2px);box-shadow:0 0 20px #39ff1480}.auth-button:disabled{opacity:.5;cursor:not-allowed}.auth-link{text-align:center;color:#e0e0e0;margin-top:1rem}.auth-link a{color:#39ff14;text-decoration:none;font-weight:600}.auth-link a:hover{text-shadow:0 0 10px rgba(57,255,20,.5)}.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#1a1a1acc;border:2px solid #39ff14;border-radius:15px;padding:1.5rem;text-align:center}.stat-value{font-size:2.5rem;color:#39ff14;font-weight:700;margin-bottom:.5rem;text-shadow:0 0 20px rgba(57,255,20,.5)}.stat-label{color:#e0e0e0;font-size:.9rem}.profile-section{margin-bottom:2rem}.profile-section h2{color:#fff;margin-bottom:1rem}.visit-list{display:flex;flex-direction:column;gap:.5rem}.visit-item{display:flex;justify-content:space-between;padding:1rem;background:#1a1a1acc;border:1px solid #39ff14;border-radius:10px;color:#fff;text-decoration:none;transition:all .3s}.visit-item:hover{background:#39ff141a;box-shadow:0 0 15px #39ff144d}.visit-date{color:#e0e0e0;font-size:.85rem}.search-form{display:flex;gap:.5rem;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}.search-input{flex:1;padding:1rem;border:2px solid #39ff14;border-radius:25px;background:#00000080;color:#fff;font-size:1rem}.search-input:focus{outline:none;border-color:#50ff30;box-shadow:0 0 15px #39ff144d}.search-button{padding:1rem 1.5rem;background:#39ff14;border:none;border-radius:25px;color:#000;font-size:1.2rem;cursor:pointer;transition:all .3s}.search-button:hover{background:#50ff30;transform:scale(1.05);box-shadow:0 0 20px #39ff1480}.no-results{text-align:center;padding:3rem;color:#e0e0e0}@media(max-width:768px){.page-title{font-size:1.5rem}.species-gallery img{height:300px}.species-header{flex-direction:column;gap:1rem}.floor-grid,.room-grid,.species-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}.species-detail{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.floating-nav{position:fixed;top:50%;left:0;right:0;transform:translateY(-50%);pointer-events:none;z-index:50;padding:0 1rem;max-width:1200px;margin:0 auto}.floating-nav-btn{position:absolute;width:60px;height:60px;border-radius:50%;background:#000000e6;border:2px solid #39ff14;display:flex;align-items:center;justify-content:center;color:#39ff14;font-size:1.5rem;pointer-events:all;cursor:pointer;transition:all .3s;box-shadow:0 0 20px #39ff144d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.floating-nav-prev{left:0}.floating-nav-next{right:0}.floating-nav-btn:hover{background:#39ff14;color:#000;transform:scale(1.1);box-shadow:0 0 30px #39ff1499}.floating-nav-btn:active{transform:scale(.95)}.species-progress{position:sticky;top:70px;z-index:40;background:#000000f2;padding:.75rem 1rem;border-radius:10px;margin-bottom:1rem;border:1px solid #39ff14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.progress-bar{height:6px;background:#39ff1433;border-radius:3px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#39ff14,#50ff30);border-radius:3px;transition:width .3s ease;box-shadow:0 0 10px #39ff1480}.progress-text{font-size:.85rem;color:#e0e0e0;display:block;text-align:center}.quick-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#39ff140d;border:1px solid #39ff14;border-radius:10px;transition:all .3s}.stat-item:hover{background:#39ff141a;transform:translateY(-2px);box-shadow:0 5px 15px #39ff144d}.stat-icon{font-size:2rem;color:#39ff14;min-width:40px}.stat-content{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.75rem;color:#a0a0a0;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:.95rem;color:#fff;font-weight:600}.facts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.fact-card{position:relative;padding:1.5rem 1.5rem 1.5rem 3.5rem;background:#39ff140d;border:1px solid #39ff14;border-radius:10px;transition:all .3s}.fact-card:hover{background:#39ff141a;transform:translateY(-3px);box-shadow:0 5px 20px #39ff144d}.fact-number{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:30px;height:30px;background:#39ff14;color:#000;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}.fact-card p{margin:0;color:#e0e0e0;line-height:1.6}.quick-actions{margin:2rem 0}.back-to-room-btn{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#39ff141a;border:2px solid #39ff14;border-radius:25px;color:#39ff14;text-decoration:none;font-weight:600;transition:all .3s}.back-to-room-btn:hover{background:#39ff14;color:#000;transform:translate(-5px);box-shadow:0 0 25px #39ff1480}.species-gallery{position:relative;animation:fadeInUp .5s ease-out;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.species-info{animation:fadeInUp .5s ease-out .2s both}.species-gallery img{animation:imageZoom .3s ease-out;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-user-drag:none;pointer-events:auto}@keyframes imageZoom{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.species-actions{display:flex;gap:.75rem;animation:fadeIn .5s ease-out .4s both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.floating-nav-btn{width:50px;height:50px;font-size:1.25rem}.species-progress{top:60px;padding:.5rem .75rem}.quick-stats,.facts-grid{grid-template-columns:1fr}.stat-item{padding:.75rem}.stat-icon{font-size:1.5rem;min-width:30px}}@media(min-width:769px)and (max-width:1024px){.floating-nav{padding:0 2rem}}@keyframes swipeHint{0%,to{transform:translate(0)}50%{transform:translate(10px)}}.species-detail:not(:hover) .floating-nav-next{animation:swipeHint 2s ease-in-out infinite}.floating-nav-btn:focus{outline:2px solid #39ff14;outline-offset:4px}.species-detail.loading{opacity:.5;pointer-events:none}.gallery-image-container{position:relative;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.gallery-open-btn{position:absolute;top:1rem;right:1rem;width:50px;height:50px;background:#000c;border:2px solid #39ff14;border-radius:10px;color:#39ff14;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gallery-open-btn:hover{background:#39ff14;color:#000;transform:scale(1.1);box-shadow:0 0 20px #39ff1499}.gallery-modal{position:fixed;inset:0;background:#000000fa;z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gallery-content{position:relative;width:90vw;height:90vh;display:flex;align-items:center;justify-content:center}.gallery-image{max-width:100%;max-height:80vh;object-fit:contain;border-radius:10px;box-shadow:0 0 50px #39ff144d;animation:imageZoom .3s ease-out;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-user-drag:none}.gallery-close{position:absolute;top:2rem;right:2rem;width:60px;height:60px;background:#000000e6;border:2px solid #39ff14;border-radius:50%;color:#39ff14;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;z-index:10001}.gallery-close:hover{background:#ff6b4a;border-color:#ff6b4a;color:#fff;transform:rotate(90deg) scale(1.1);box-shadow:0 0 25px #ff6b4a99}.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:60px;height:60px;background:#000000e6;border:2px solid #39ff14;border-radius:50%;color:#39ff14;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;z-index:10001}.gallery-nav-prev{left:2rem}.gallery-nav-next{right:2rem}.gallery-nav:hover{background:#39ff14;color:#000;transform:translateY(-50%) scale(1.15);box-shadow:0 0 30px #39ff1499}.gallery-counter{position:absolute;top:2rem;left:50%;transform:translate(-50%);background:#000000e6;border:2px solid #39ff14;border-radius:25px;padding:.75rem 1.5rem;color:#39ff14;font-size:1.1rem;font-weight:600;z-index:10001;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gallery-thumbnails{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;gap:.75rem;padding:1rem;background:#000000e6;border:2px solid #39ff14;border-radius:15px;max-width:90vw;overflow-x:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gallery-thumbnail{width:80px;height:80px;border-radius:10px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .3s;flex-shrink:0}.gallery-thumbnail img{width:100%;height:100%;object-fit:cover;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-user-drag:none}.gallery-thumbnail:hover{border-color:#39ff14;transform:scale(1.1);box-shadow:0 0 15px #39ff1480}.gallery-thumbnail.active{border-color:#39ff14;box-shadow:0 0 20px #39ff1499}@media(max-width:768px){.gallery-open-btn{width:40px;height:40px;top:.5rem;right:.5rem}.gallery-close{top:1rem;right:1rem;width:50px;height:50px}.gallery-nav{width:50px;height:50px}.gallery-nav-prev{left:1rem}.gallery-nav-next{right:1rem}.gallery-counter{top:1rem;font-size:.9rem;padding:.5rem 1rem}.gallery-thumbnails{bottom:1rem;padding:.75rem;gap:.5rem}.gallery-thumbnail{width:60px;height:60px}.gallery-image{max-height:70vh}}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}.app-layout{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#000,#1a1a1a);user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.app-header{background:#000000f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 10px #39ff1433;position:sticky;top:0;z-index:100;border-bottom:2px solid #39ff14}.header-content{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.logo a{text-decoration:none}.logo h1{color:#fff;font-size:1.5rem;margin:0;font-weight:700;text-shadow:0 0 10px rgba(57,255,20,.5)}.header-actions{display:flex;gap:1rem;align-items:center}.language-selector{position:relative}.language-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#39ff141a;border:1px solid #39ff14;border-radius:20px;color:#39ff14;cursor:pointer;transition:all .3s}.language-btn:hover{background:#39ff1433;box-shadow:0 0 10px #39ff144d}.language-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:#000000fa;border:1px solid #39ff14;border-radius:10px;box-shadow:0 4px 20px #39ff144d;min-width:150px;overflow:hidden}.language-option{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;width:100%;border:none;background:transparent;color:#e0e0e0;cursor:pointer;transition:all .2s}.language-option:hover{background:#39ff141a;color:#39ff14}.language-option.active{background:#39ff1433;color:#39ff14;font-weight:600}.language-option .flag{font-size:1.2rem}.app-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem 1.5rem 6rem}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#000000fa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:2px solid #39ff14;display:flex;justify-content:space-around;padding:.75rem 0;z-index:99;box-shadow:0 -2px 10px #39ff1433}.nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem 1rem;color:#e0e0e0;text-decoration:none;font-size:.75rem;transition:all .3s;border:none;background:transparent;cursor:pointer}.nav-item svg{font-size:1.25rem}.nav-item:hover{color:#39ff14;transform:translateY(-2px);text-shadow:0 0 10px rgba(57,255,20,.5)}.nav-item:active{transform:translateY(0)}.mobile-menu-toggle{display:none;background:transparent;border:none;color:#39ff14;font-size:1.5rem;cursor:pointer;padding:.5rem}@media(max-width:768px){.mobile-menu-toggle{display:block}.bottom-nav{transform:translateY(100%);transition:transform .3s}.bottom-nav.show{transform:translateY(0)}.logo h1{font-size:1.25rem}.app-main{padding:1.5rem 1rem 5rem}}
