body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;text-align:center}.App-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #fff3;box-shadow:0 2px 20px #0000001a;padding:1rem 2rem}.App-header h1{color:#2c3e50;font-size:2.5rem;font-weight:700;text-shadow:0 2px 4px #0000001a}main{align-items:flex-start;box-sizing:border-box;display:flex;flex:1 1;justify-content:center;overflow-x:hidden}.error,.loading{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 10px 30px #0003;margin:2rem auto;max-width:500px;padding:3rem}.error h2,.loading h2{color:#2c3e50;font-size:1.8rem;margin-bottom:1rem}.error p,.loading p{color:#7f8c8d;font-size:1.1rem;margin-bottom:2rem}.error button{background:linear-gradient(45deg,#e74c3c,#c0392b);border:none;border-radius:25px;box-shadow:0 4px 15px #e74c3c4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.error button:hover{box-shadow:0 6px 20px #e74c3c66;transform:translateY(-2px)}.campus-map{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 10px 30px #0003;display:flex;gap:2rem;max-width:1400px;overflow:visible;padding:2rem 4rem;position:relative;width:calc(100% - 8rem)}.search-container{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff14;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 8px 32px #0000001a;box-sizing:border-box;max-width:calc(100vw - 24px);min-height:auto;padding:clamp(10px,1.8vw,24px);position:fixed;right:20px;top:20px;width:clamp(160px,26vw,360px);z-index:1000}.search-header{margin-bottom:20px;text-align:center}.search-title{align-items:center;display:flex;gap:10px;justify-content:center}.search-title h3{color:#2c3e50;font-size:clamp(13px,1.6vw,18px);font-weight:600;margin:0;text-shadow:0 2px 4px #0000001a}.search-title .search-icon{color:#e74c3c;font-size:24px}.search-box{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fff9;border:1px solid #fff3;border-radius:15px;box-shadow:0 8px 32px #0000001a;margin-bottom:20px;overflow:hidden;position:relative}.search-input{background:#0000;border:none;color:#333;font-size:clamp(12px,1.3vw,14px);outline:none;padding:clamp(8px,1.2vw,12px) clamp(24px,2vw,40px) clamp(8px,1.2vw,12px) clamp(10px,1.2vw,15px);width:100%}.search-input::placeholder{color:#666;font-style:italic}.search-icon{color:#667eea;pointer-events:none;position:absolute;right:16px;top:50%;transform:translateY(-50%)}.search-results{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fff9;border:1px solid #fff3;border-radius:15px;box-shadow:0 8px 32px #0000001a;max-height:200px;overflow-y:auto}.search-result-building{border-bottom:1px solid #0000001a}.search-result-building:last-child{border-bottom:none}.search-result-building-name{border-radius:8px 8px 0 0;color:#667eea;cursor:pointer;font-weight:600;padding:12px 16px;transition:background-color .2s ease}.search-result-building-name:hover{background:#667eea1a}.search-result-floor{background:#00000005;padding:8px 16px 8px 32px}.search-result-floor-name{color:#555;font-size:14px;font-weight:500;margin-bottom:4px}.search-result-room{align-items:center;display:flex;font-size:13px;justify-content:space-between;padding:4px 0}.search-result-room-name{color:#333;font-weight:500}.search-result-room-type{color:#666;font-size:12px}.search-building{border-bottom:1px solid #0000001a;padding:12px 16px}.search-building:last-child{border-bottom:none}.search-building h4{color:#667eea;font-size:14px;font-weight:600;margin:0 0 8px}.search-floor{margin-bottom:8px;margin-left:16px}.search-floor h5{color:#555;font-size:clamp(11px,1.2vw,12px);font-weight:500;margin:0 0 4px}.search-room{align-items:center;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;margin:2px 0;padding:clamp(4px,.9vw,6px) clamp(6px,1vw,8px);transition:background-color .2s ease}.search-room:hover{background:#667eea1a}.room-name{color:#333;font-size:clamp(11px,1.2vw,13px);font-weight:500}.room-number{color:#666;font-size:clamp(10px,1.1vw,12px)}.no-search-results{color:#666;font-style:italic;padding:20px;text-align:center}.map-container{align-items:center;background:#f5f5f5;display:flex;flex:1 1;justify-content:center;overflow:hidden;position:relative}.map-image{display:block;height:600px;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;max-width:100%;object-fit:contain;object-position:center;opacity:0;position:relative;visibility:hidden;width:100%;z-index:1}.map-image.loaded{opacity:1;visibility:visible}.map-image.placeholder{left:0;position:absolute;top:0;z-index:1}.map-loading{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fffc;border-radius:15px;bottom:0;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.map-loading,.map-skeleton{align-items:center;display:flex}.map-skeleton{flex-direction:column;gap:1rem}.skeleton-placeholder{animation:skeleton-loading 1.5s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;border-radius:10px;height:400px;width:100%}.loading-text{color:#666;font-size:14px;font-weight:600}@keyframes skeleton-loading{0%{background-position:-200% 0}to{background-position:200% 0}}.map-error{align-items:center;background:#fffffff2;border-radius:15px;bottom:0;display:flex;flex-direction:column;gap:1rem;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.map-error p{color:#e74c3c;font-weight:600;margin:0}.map-error button{background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.map-error button:hover{background:linear-gradient(135deg,#2980b9,#1f5f8b);transform:translateY(-2px)}.map-point{cursor:pointer;pointer-events:auto;position:absolute;transform:translate(-50%,-50%);transition:all .3s ease;z-index:20}.map-point:hover{transform:translate(-50%,-50%) scale(1.2)}.point-marker{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));height:48px;transition:all .3s ease;width:48px}.point-marker:hover{filter:drop-shadow(0 4px 8px rgba(0,0,0,.4));transform:scale(1.2)}.map-legend{background:#ffffffe6;border-radius:15px;box-shadow:0 5px 20px #0000001a;padding:1.5rem;width:clamp(180px,24vw,300px)}.map-legend h3{color:#2c3e50;font-size:clamp(.9rem,1.6vw,1.3rem);font-weight:600;margin-bottom:1rem}.legend-items{display:flex;flex-direction:column;gap:.5rem}.legend-item{align-items:center;background:#ffffff80;border-radius:8px;cursor:pointer;display:flex;gap:clamp(6px,1vw,10px);padding:clamp(6px,1vw,10px);transition:all .3s ease}.legend-item:hover{background:#e74c3c1a;transform:translateX(5px)}.legend-marker{align-items:center;display:flex;flex-shrink:0;height:clamp(12px,1.6vw,20px);justify-content:center;width:clamp(12px,1.6vw,20px)}.legend-text{color:#2c3e50;font-size:clamp(.75rem,1vw,.9rem);font-weight:500}.building-detail-new{animation:gradientShift 15s ease infinite;background:linear-gradient(135deg,#1e40af,#1e3a8a 30%,#166534 70%,#15803d);background-size:400% 400%;display:flex;flex-direction:column;min-height:100vh;overflow:hidden;position:relative;width:100%}.building-detail-new:before{background:radial-gradient(circle at 20% 80%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 80% 20%,#ffffff0d 0,#0000 50%),url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='100' height='100' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='50' cy='50' r='1' fill='rgba(255,255,255,0.03)'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.6;pointer-events:none;position:absolute;right:0;top:0}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.detail-header{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fff9;border-bottom:1px solid #ffffff1a;box-shadow:0 8px 32px #0000001a;display:flex;justify-content:space-between;padding:.01rem 1rem;position:relative;z-index:10}.detail-header:before{background:linear-gradient(90deg,#ffffff1a,#ffffff0d);border-radius:0 0 20px 20px;bottom:0;content:"";left:0;position:absolute;right:0;top:0}.header-left{gap:1rem;margin-left:2rem}.header-center,.header-left{align-items:center;display:flex}.header-center{flex:1 1;justify-content:center;left:50%;margin:0 auto;position:absolute;transform:translateX(-50%)}.building-title{text-align:center}.back-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#1e40af,#166534);border:1px solid #fff3;border-radius:50px;box-shadow:0 8px 25px #1e40af66;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:12px;overflow:hidden;padding:.8rem 1.5rem;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.back-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.back-btn:hover:before{left:100%}.back-btn:hover{box-shadow:0 12px 35px #667eea99;transform:translateY(-3px) scale(1.05)}.back-icon{font-size:1.2rem;font-weight:700}.building-title h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e2e8f0);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:2.5rem;font-weight:800;letter-spacing:-.5px;margin:0 0 .5rem;text-shadow:0 4px 20px #0000004d}.building-subtitle{color:#ffffffe6;font-size:1.3rem;font-weight:500;margin:0;text-shadow:0 2px 10px #0003}.header-right{gap:1rem}.building-logo,.header-right{align-items:center;display:flex}.building-logo{border-radius:15px;height:190px;justify-content:center;transition:all .3s ease;width:280px}.building-logo:hover{transform:translateY(-2px)}.logo-image{border-radius:10px;height:100%;object-fit:contain;padding:8px;width:100%}.building-stats{display:none}.stat-item{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff26;border:1px solid #fff3;border-radius:20px;box-shadow:0 8px 32px #0000001a;color:#fff;display:flex;flex-direction:column;gap:.5rem;min-width:120px;padding:1.5rem 2rem;transition:all .3s ease}.stat-item:hover{background:#ffffff40;box-shadow:0 12px 40px #0003;transform:translateY(-5px)}.stat-icon{font-size:2rem;opacity:.9}.stat-value{color:#fff;font-size:1.8rem;font-weight:700;text-shadow:0 2px 10px #0000004d}.stat-label{color:#fffc;font-size:.9rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.floor-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #fff3;gap:1.5rem;padding:1.5rem}.floor-card:before{background:linear-gradient(90deg,#0000,#ffffff1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s;width:100%}.floor-card:hover:before{left:100%}.floor-card:hover{background:#ffffff26;border-color:#fff6;box-shadow:0 10px 30px #0003;transform:translateY(-3px)}.floor-card.active{background:linear-gradient(135deg,#1e40af,#166534);border-color:#ffffff80;box-shadow:0 10px 30px #1e40af4d}.floor-number{color:#fffffff2;font-size:1.6rem;font-weight:800;min-width:2rem;text-align:center;text-shadow:0 2px 10px #0000004d}.floor-name,.floor-number{position:relative;z-index:1}.floor-name{color:#ffffffe6;font-size:1.2rem;font-weight:600;text-shadow:0 1px 5px #0003;white-space:nowrap}.selected-room-card{border:1px solid #fff3;border-radius:15px;color:#fff;display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.room-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.room-header h4{color:#2c3e50;font-size:1.1rem;font-weight:600;margin:0}.room-number-badge{background:#e74c3c;border-radius:8px;color:#fff;font-size:.8rem;font-weight:600;padding:4px 8px}.room-details{display:flex;flex-direction:column;gap:.8rem}.detail-row{align-items:center;border-bottom:1px solid #0000001a;display:flex;justify-content:space-between;padding:.5rem 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#7f8c8d;font-size:.9rem;font-weight:500}.detail-value{color:#2c3e50;font-size:.9rem;font-weight:600}.floor-viewer{display:flex;flex-direction:column;gap:2rem}.viewer-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff14;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 8px 32px #0000001a;justify-content:space-between;margin-bottom:2.5rem;padding:2rem}.viewer-header,.viewer-title{align-items:center;color:#fff;display:flex}.viewer-title{font-size:2rem;font-weight:700;gap:1rem;letter-spacing:-.5px;margin:0;text-shadow:0 2px 10px #0000004d}.viewer-controls{display:flex;gap:1rem}.control-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #ffffff4d;border-radius:15px;box-shadow:0 4px 15px #0000001a;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:12px 20px;transition:all .3s ease}.control-btn:hover{background:#ffffff40;border-color:#ffffff80;box-shadow:0 8px 25px #0003;transform:translateY(-2px)}.floor-image-wrapper{align-items:center;display:flex;height:100vh;justify-content:center;position:relative;width:100%}.floor-image-new{cursor:pointer;height:100%;object-fit:contain;transition:transform .3s ease;width:100%}.floor-image-new:hover{transform:scale(1.02)}.room-overlay{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.rektörlük-overlay{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(8,1fr)}.room-marker{align-items:center;background:#3498db66;border:2px solid #3498dbcc;border-radius:8px;cursor:pointer;display:flex;justify-content:center;max-height:80px;max-width:120px;min-height:30px;min-width:40px;pointer-events:auto;position:absolute;transition:all .3s ease;z-index:10}.rektörlük-marker{height:clamp(40px,6vw,70px)!important;width:clamp(60px,8vw,100px)!important}.room-marker:hover{background:#3498db99;border-color:#3498db;transform:scale(1.1)}.room-marker.selected{background:#e74c3c99;border-color:#e74c3c;box-shadow:0 0 15px #e74c3c80}.marker-number{color:#fff;font-size:11px;font-weight:700;text-shadow:1px 1px 2px #000c}.no-floor-plan{align-items:center;display:flex;flex:1 1;justify-content:center;padding:2rem}.no-plan-content{color:#fff;text-align:center}.no-plan-icon{display:block;font-size:4rem;margin-bottom:1rem}.no-plan-content h3{color:#fff;font-size:1.5rem;margin-bottom:.5rem}.no-plan-content p{color:#fffc;font-size:1rem;margin:0}.building-header{align-items:center;border-bottom:2px solid #e74c3c33;display:flex;gap:1rem;margin-bottom:2rem;padding-bottom:1rem}.back-buttons{display:flex;flex-shrink:0;gap:.5rem}.back-button{background:linear-gradient(45deg,#3498db,#2980b9);border:none;border-radius:25px;box-shadow:0 4px 15px #3498db4d;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 20px;transition:all .3s ease}.back-button:hover{box-shadow:0 6px 20px #3498db66;transform:translateY(-2px)}.back-button.video-back{background:linear-gradient(45deg,#9b59b6,#8e44ad);box-shadow:0 4px 15px #9b59b64d}.back-button.video-back:hover{box-shadow:0 6px 20px #9b59b666}.building-header h2{color:#2c3e50;flex:1 1;font-size:2rem;font-weight:700}.building-header p{color:#7f8c8d;font-size:1.1rem;margin:0}.building-content{grid-gap:2rem;display:grid;flex:1 1;gap:2rem;grid-template-columns:300px 1fr;min-height:80vh}.building-info{background:#fffc;border-radius:15px;box-shadow:0 5px 20px #0000001a;padding:1.5rem}.building-info h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.building-info ul{list-style:none;padding:0}.building-info li{border-bottom:1px solid #0000001a;color:#2c3e50;font-size:.95rem;padding:.5rem 0}.building-info li:last-child{border-bottom:none}.building-info strong{color:#e74c3c;font-weight:600}.floor-selector{background:#fffc;border-radius:15px;box-shadow:0 5px 20px #0000001a;margin-bottom:1rem;padding:1.5rem}.floor-selector h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.floor-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.floor-button{background:#fffc;border:2px solid #bdc3c7;border-radius:20px;color:#2c3e50;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .3s ease}.floor-button:hover{background:#3498db1a;border-color:#3498db}.floor-button.active{background:linear-gradient(45deg,#3498db,#2980b9);border-color:#3498db;box-shadow:0 4px 15px #3498db4d;color:#fff}.floor-plan{background:#fffc;border-radius:15px;box-shadow:0 5px 20px #0000001a;display:flex;flex-direction:column;margin:1rem 0;min-height:80vh;padding:1rem}.floor-plan h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.floor-image{border-radius:10px;box-shadow:0 5px 20px #00000026;max-width:90vw;object-fit:contain;transition:transform .3s ease;width:100%}.floor-image:hover{transform:scale(1.02)}.floor-image-container{align-items:center;display:flex;flex:1 1;justify-content:center;position:relative;width:100%}.floor-overlay{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.room-area{align-items:center;background:#3498db4d;border:2px solid #3498dbcc;border-radius:8px;cursor:pointer;display:flex;justify-content:center;pointer-events:auto;position:absolute;transition:all .3s ease;z-index:10}.room-area:hover{background:#3498db80;border-color:#3498db;transform:scale(1.1)}.room-area.selected{background:#e74c3c80;border-color:#e74c3c;box-shadow:0 0 10px #e74c3c80}.room-number{color:#fff;font-size:12px;font-weight:700;text-shadow:1px 1px 2px #000c}.rooms-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.room-card{background:#ffffffe6;border-left:4px solid #3498db;border-radius:12px;box-shadow:0 4px 15px #0000001a;padding:1rem;transition:all .3s ease}.room-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-3px)}.room-card h4{color:#2c3e50;font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.room-card p{color:#7f8c8d;font-size:.9rem;margin-bottom:.3rem}.room-card strong{color:#e74c3c;font-weight:600}.room-detail{background:#ffffffe6;border-radius:15px;box-shadow:0 5px 20px #0000001a;margin-top:1rem;padding:1.5rem}.room-detail h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.room-detail-card{background:#fffffff2;border-left:4px solid #e74c3c;border-radius:12px;box-shadow:0 4px 15px #0000001a;padding:1.5rem}.room-detail-card h4{color:#2c3e50;font-size:1.4rem;font-weight:600;margin-bottom:1rem}.room-info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.room-info-item{background:#3498db1a;border-radius:8px;color:#7f8c8d;font-size:1rem;padding:.5rem}.room-info-item strong{color:#e74c3c;font-weight:600}@media (max-width:1024px){.campus-map{flex-direction:column;padding:1rem 2rem;width:calc(100% - 4rem)}.map-legend{width:100%}.building-content{grid-template-columns:1fr}.floor-image{max-width:100%}.detail-main{padding:1rem 2rem;width:calc(100% - 4rem)}.floor-selection-panel{height:auto;min-height:150px}.floor-content-container{flex-direction:column;gap:1rem}.kroki-panel,.room-list-panel{min-height:400px;width:100%}.building-stats{gap:1rem}.stat-item{min-width:60px;padding:.8rem}}@media (max-width:768px){.App-header h1{font-size:2rem}main{padding:1rem 1.5rem}.building-detail,.campus-map{padding:1rem 1.5rem;width:calc(100% - 3rem)}.building-header{align-items:flex-start;flex-direction:column;gap:.5rem}.building-header h2{font-size:1.5rem}.rooms-grid{grid-template-columns:1fr}.detail-header{padding:1rem}.detail-header,.header-left{flex-direction:column;gap:1rem}.header-left{text-align:center}.header-center{margin:1rem 0;order:2}.building-logo{height:150px;width:220px}.building-title h1{font-size:1.8rem}.building-stats{gap:.5rem}.stat-item{min-width:50px;padding:.5rem}.stat-value{font-size:1.1rem}.detail-sidebar,.floor-viewer{padding:1rem}.viewer-header{flex-direction:column;gap:1rem;text-align:center}.viewer-title{font-size:1.4rem}.search-container{max-width:350px;padding:20px;position:fixed;right:10px;top:10px;width:350px}.search-results{max-height:300px}}@media (max-width:480px){.App-header{padding:1rem}.App-header h1{font-size:1.5rem}.map-legend{padding:1rem}.legend-text{font-size:.8rem}}.video-intro{background:linear-gradient(135deg,#667eea,#764ba2);overflow:hidden;z-index:1000}.video-container,.video-intro{zoom:1!important;align-items:center;display:flex;height:100vh!important;justify-content:center;left:0!important;max-height:100vh!important;max-width:100vw!important;min-height:100vh!important;min-width:100vw!important;position:fixed!important;scale:1!important;top:0!important;transform:none!important;width:100vw!important}.video-container{transition:filter .8s ease-in-out;z-index:1}.video-container.video-ended{filter:blur(0)}.intro-video,.video-container.video-ended{zoom:1!important;height:100vh!important;left:0!important;max-height:100vh!important;max-width:100vw!important;min-height:100vh!important;min-width:100vw!important;position:fixed!important;scale:1!important;top:0!important;transform:none!important;width:100vw!important;z-index:1}.intro-video{cursor:pointer;filter:blur(8px);object-fit:cover;transition:filter .8s ease-in-out}.intro-video.ended{zoom:1!important;cursor:default;filter:blur(0);height:100vh!important;left:0!important;max-height:100vh!important;max-width:100vw!important;min-height:100vh!important;min-width:100vw!important;object-fit:cover;pointer-events:none;position:fixed!important;scale:1!important;top:0!important;transform:none!important;width:100vw!important;z-index:1}.university-title{left:50%;pointer-events:none;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);transition:all .6s cubic-bezier(.4,0,.2,1);z-index:1000}.university-title.video-ended{left:50%;top:20px;transform:translateX(-50%)}.university-title h1{animation:titleFloat 3s ease-in-out infinite;color:#fff;font-family:Georgia,Times New Roman,serif;font-size:4.5rem;font-weight:800;letter-spacing:2px;line-height:1.2;margin:0 0 1.5rem;position:relative;text-align:center;text-shadow:0 0 40px #fffc,0 0 80px #fff9,0 0 120px #fff6,0 6px 12px #000000e6,0 3px 6px #000c;transition:all .6s cubic-bezier(.4,0,.2,1)}.university-title h1,.university-title.video-ended h1{-webkit-backdrop-filter:none;backdrop-filter:none;background:none;border:none;border-radius:0;padding:0}.university-title.video-ended h1{animation:none;font-size:1.5rem;margin:0 0 .3rem}.university-title p{animation:subtitleGlow 2s ease-in-out infinite alternate;color:#fffffff2;font-family:Georgia,Times New Roman,serif;font-size:1.8rem;font-weight:600;letter-spacing:1.5px;margin:0;text-align:center;text-shadow:0 0 30px #ffffffb3,0 0 60px #ffffff80,0 4px 8px #000c,0 2px 4px #000000b3;transition:all .6s cubic-bezier(.4,0,.2,1)}.university-title p,.university-title.video-ended p{-webkit-backdrop-filter:none;backdrop-filter:none;background:none;border:none;border-radius:0;padding:0}.university-title.video-ended p{animation:none;font-size:.8rem}@keyframes titleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes subtitleGlow{0%{opacity:.8}to{opacity:1}}.video-info{color:#fff;margin-bottom:2rem;pointer-events:none;text-align:center}.video-info h2{font-size:3rem;font-weight:700;margin-bottom:1rem;text-shadow:0 4px 8px #00000080}.video-info p{font-size:1.2rem;opacity:.9;text-shadow:0 2px 4px #00000080}.play-pause-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #fff;border-radius:50px;color:#fff;cursor:pointer;font-size:2rem;margin-bottom:1rem;padding:1rem 2rem;pointer-events:auto;transition:all .3s ease}.play-pause-btn:hover{background:#ffffff4d;transform:scale(1.1)}.skip-btn{background:linear-gradient(45deg,#e74c3c,#c0392b);border:none;border-radius:25px;box-shadow:0 4px 15px #e74c3c4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;pointer-events:auto;transition:all .3s ease}.skip-btn:hover{box-shadow:0 6px 20px #e74c3c66;transform:translateY(-2px)}.continue-btn{background:linear-gradient(45deg,#27ae60,#2ecc71);border:none;border-radius:25px;box-shadow:0 4px 15px #27ae604d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:1rem;padding:15px 30px;pointer-events:auto;transition:all .3s ease}.continue-btn:hover{box-shadow:0 6px 20px #27ae6066;transform:translateY(-2px)}.loading-spinner{color:#fff;left:50%;pointer-events:none;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin:0 auto 1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-spinner p{font-size:1.1rem;opacity:.9;text-shadow:0 2px 4px #00000080}@media (max-width:768px){.university-title h1{font-size:3rem;margin:0 0 1rem}.university-title p{font-size:1.3rem}.university-title.video-ended h1{font-size:1.2rem}.university-title.video-ended p{font-size:.7rem}}@media (max-width:480px){.university-title h1{font-size:2.2rem;margin:0 0 .8rem}.university-title p,.university-title.video-ended h1{font-size:1rem}.university-title.video-ended p{font-size:.6rem}}.video-map-points{height:100vh;left:0;pointer-events:auto;position:fixed;top:0;width:100vw;z-index:100}.video-map-point{cursor:pointer;position:absolute;transform:translate(-50%,-50%);transition:all .3s ease;z-index:100}.video-map-point:hover{transform:translate(-50%,-50%) scale(1.3)}.video-point-marker{height:48px;position:relative;width:48px;z-index:50}.video-point-marker:hover:after{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffffb3;border:2px solid #2c3e50;border:2px solid var(--pin-color,#2c3e50);border-radius:12px;bottom:100%;box-shadow:0 8px 25px #0003;color:#2c3e50;color:var(--pin-color,#2c3e50);content:attr(data-title);font-size:14px;font-weight:700;left:50%;letter-spacing:.3px;margin-bottom:10px;padding:12px 18px;position:absolute;text-shadow:none;transform:translateX(-50%);transition:all .3s ease;white-space:nowrap;z-index:1000}.video-point-marker.popup-bottom:hover:after{bottom:auto;margin-bottom:0;margin-top:10px;top:100%}.video-point-marker:hover:before{border:8px solid #0000;border-top-color:#ffffff26;bottom:100%;content:"";filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));left:50%;margin-bottom:2px;position:absolute;transform:translateX(-50%);z-index:1000}.video-point-marker.popup-bottom:hover:before{border-bottom-color:#ffffff26;border-top-color:#0000;bottom:auto;margin-bottom:0;margin-top:2px;top:100%}.video-legend{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff40;border:1px solid #ffffff4d;border-radius:12px;bottom:15px;box-shadow:0 4px 20px #0000001a;box-sizing:border-box;left:15px;padding:clamp(10px,1.6vw,16px);position:fixed;width:clamp(160px,32vw,320px);z-index:1000}.video-legend h3{color:#2c3e50;font-size:1rem;font-weight:700;margin:0 0 .8rem;text-align:center;text-shadow:0 1px 3px #ffffffe6}.video-legend .legend-items{grid-gap:.4rem;display:grid;gap:.4rem;grid-template-columns:1fr 1fr}.video-legend .legend-item{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:.4rem;padding:.3rem;transition:all .3s ease}.video-legend .legend-item:hover{background:#ffffff4d;border-radius:8px;transform:translateX(2px)}.video-legend .legend-marker{align-items:center;background:none;border:none;border-radius:0;display:flex;flex-shrink:0;height:16px;justify-content:center;width:16px}.video-legend .legend-text{color:#2c3e50;flex:1 1;font-size:clamp(.65rem,1.1vw,.9rem);font-weight:600;line-height:1.1;text-shadow:0 1px 2px #fffc}@media (max-width:900px){.search-container{padding:clamp(10px,2vw,18px);right:12px;top:12px;width:clamp(160px,34vw,320px)}.video-legend{bottom:12px;left:12px;width:clamp(160px,40vw,300px)}}@media (max-width:600px){.search-container{max-width:calc(100vw - 20px);padding:10px;right:10px;top:10px;width:calc(100vw - 20px)}.video-legend{width:calc(100vw - 24px)}.search-results{max-height:clamp(140px,35vh,260px)}}.video-legend .legend-info{border-top:1px solid #fff3;margin-top:15px;padding-top:15px}.video-legend .legend-info p{color:#2c3e50;font-size:.75rem;font-weight:600;margin:0;opacity:.9;text-align:center;text-shadow:0 1px 2px #fffc}.page-info{background:#0000;border:none;border-radius:0;bottom:30px;box-shadow:none;left:50%;padding:15px 25px;position:fixed;transform:translateX(-50%);z-index:1000}.page-info p{color:#fff;font-family:Georgia,Times New Roman,serif;font-size:1.1rem;font-weight:600;letter-spacing:1.5px;margin:0;text-align:center;text-shadow:0 0 30px #ffffffb3,0 0 60px #ffffff80,0 4px 8px #000c,0 2px 4px #000000b3;white-space:nowrap}@media (max-width:768px){.video-legend{bottom:10px;left:10px;padding:.8rem;right:10px;width:auto}.video-legend .legend-items{grid-template-columns:1fr}.video-legend .legend-text{font-size:.7rem}.video-legend h3{font-size:.9rem}}.detail-main{align-items:center;gap:2rem;margin:0 auto;padding:2rem 4rem;width:calc(100% - 8rem);z-index:5}.detail-main,.floor-selection-panel{display:flex;flex-direction:column;max-width:1800px;position:relative}.floor-selection-panel{-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);background:#ffffff1f;border:1px solid #fff3;border-radius:30px;box-shadow:0 20px 60px #00000026;gap:1.5rem;height:200px;overflow:hidden;padding:2rem;width:100%}.floor-selection-panel:before{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);border-radius:30px;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.floor-content-container{align-items:stretch;display:flex;gap:2rem;max-width:1800px;width:100%}.room-list-panel{-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);background:#ffffff1f;border:1px solid #fff3;border-radius:30px;box-shadow:0 20px 60px #00000026;display:flex;flex-direction:column;gap:1rem;min-height:600px;overflow:hidden;padding:1.5rem;position:relative;width:25%}.room-list-panel:before{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);border-radius:30px;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.kroki-panel{-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);background:#ffffff1f;border:1px solid #fff3;border-radius:30px;box-shadow:0 20px 60px #00000026;display:flex;flex-direction:column;min-height:600px;overflow:hidden;padding:2rem;position:relative;width:75%}.kroki-panel:before{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);border-radius:30px;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.detail-sidebar{-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);background:#ffffff1f;border:1px solid #fff3;border-radius:30px;box-shadow:0 20px 60px #00000026;display:flex;flex-direction:column;gap:2rem;max-width:1200px;overflow:hidden;padding:2.5rem;position:relative;width:100%}.detail-sidebar:before{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);border-radius:30px;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.section-title{align-items:center;color:#fff;display:flex;font-size:1.6rem;font-weight:700;gap:1.2rem;letter-spacing:-.5px;margin:0 0 2rem;position:relative;text-shadow:0 2px 10px #0000004d;z-index:1}.title-icon{font-size:1.8rem;opacity:.95}.floor-grid{flex-wrap:wrap;gap:1.5rem;z-index:1}.floor-card,.floor-grid{align-items:center;display:flex;justify-content:center;position:relative}.floor-card{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff14;border:1px solid #ffffff40;border-radius:20px;color:#fff;cursor:pointer;gap:1.2rem;min-width:200px;overflow:hidden;padding:1.5rem 2rem;transition:all .4s cubic-bezier(.4,0,.2,1)}.detail-content{-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);background:#ffffff1a;border:1px solid #fff3;border-radius:30px;box-shadow:0 20px 60px #00000026;display:flex;flex-direction:column;max-width:1200px;overflow:hidden;padding:3rem;position:relative;width:100%}.ocr-loading{animation:pulse 1.5s ease-in-out infinite;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000e6;border:1px solid #fff3;border-radius:15px;color:#fff;font-size:16px;font-weight:500;left:50%;padding:20px 30px;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:1000}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.room-list{gap:8px;max-height:500px;overflow-y:auto;padding-right:8px}.room-item,.room-list{display:flex;flex-direction:column}.room-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;cursor:pointer;gap:0;overflow:hidden;padding:8px;text-align:left;transition:all .3s ease}.room-item:hover{background:#fff3;box-shadow:0 4px 15px #0003;transform:translateY(-2px)}.room-item.active{background:linear-gradient(135deg,#1e40af4d,#1665344d);border-color:#1e40af80;box-shadow:0 4px 15px #1e40af4d}.room-item.expanded{padding-bottom:15px}.room-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.room-item-name{color:#1e293b;flex:1 1;font-size:12px;font-weight:600}.room-item-number{background:linear-gradient(135deg,#1e40af,#166534);border-radius:6px;color:#fff;font-size:9px;font-weight:600;padding:2px 5px}.room-item-details{align-items:center;color:#64748b;display:flex;font-size:10px;justify-content:space-between}.room-item-type{font-weight:500}.room-item-area{color:#1e40af;font-weight:600}.room-item-container{display:flex;flex-direction:column;gap:.5rem}.room-item-main{display:flex;flex-direction:column;gap:4px}.room-detail-expanded{animation:slideDown .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border-radius:8px;border-top:1px solid #fff3;margin-top:.5rem;padding:.8rem}.room-image-container{box-shadow:0 4px 12px #00000026;margin-bottom:.8rem;overflow:hidden}.room-image{display:block;height:150px;object-fit:cover;transition:transform .3s ease}.room-image.clickable{cursor:pointer}.image-modal-overlay{animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0000001a}.image-modal-content{animation:slideIn .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #1e40af1a;border-radius:20px;box-shadow:0 20px 60px #1e40af33}.image-modal-header{background:linear-gradient(135deg,#1e40af,#059669);border-bottom:1px solid #0000001a;color:#fff;padding:1.5rem 2rem}.image-modal-title{font-size:1.5rem}.image-modal-close{background:#fff3;color:#fff;font-size:1.2rem;height:40px;transition:all .3s ease;width:40px}.image-modal-close:hover{background:#ffffff4d;box-shadow:0 4px 12px #1e40af4d;transform:scale(1.1)}.image-modal-body{align-items:center;display:flex;justify-content:center;max-height:70vh;overflow:auto;padding:2rem}.image-modal-image{border:1px solid #1e40af1a;border-radius:10px;box-shadow:0 10px 30px #1e40af26;max-height:100%;max-width:100%;object-fit:contain}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:scale(.8) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.room-detail-content{display:flex;flex-direction:column;gap:.5rem}.room-detail-content .detail-row{align-items:center;display:flex;justify-content:space-between;padding:.2rem 0}.room-detail-content .detail-label{color:#1e293be6;font-size:.8rem;font-weight:600}.room-detail-content .detail-value{color:#1e293b;font-size:.8rem;font-weight:500}@keyframes slideDown{0%{max-height:0;opacity:0;transform:translateY(-10px)}to{max-height:200px;opacity:1;transform:translateY(0)}}.selected-search-result{animation:slideDown .3s ease-out;background:#fff9;border:1px solid #007bff4d;border-radius:15px;box-shadow:0 8px 25px #00000026;margin-top:20px;padding:20px}.result-header{align-items:center;border-bottom:2px solid #007bff33;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:10px}.result-header h4{color:#0056b3;font-size:18px;font-weight:600;margin:0}.close-result{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:20px;height:30px;justify-content:center;padding:5px;transition:all .3s ease;width:30px}.close-result:hover{background:#dc35451a;color:#dc3545}.result-content{grid-gap:12px;display:grid;gap:12px}.result-building,.result-floor,.result-room{background:#007bff0d;border-left:4px solid #007bff;border-radius:8px;padding:8px 12px}.result-details{grid-gap:10px;background:#28a7450d;border:1px solid #28a74533;border-radius:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-top:10px;padding:15px}.result-details div{font-size:14px;padding:5px 0}.result-details strong{color:#28a745}.result-actions{border-top:1px solid #fff3;margin-top:1rem;padding-top:1rem}.view-building-details-btn{align-items:center;background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:12px;box-shadow:0 4px 15px #3498db4d;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .3s ease;width:100%}.view-building-details-btn:hover{background:linear-gradient(135deg,#2980b9,#1f5f8b);box-shadow:0 6px 20px #3498db66;transform:translateY(-2px)}.view-building-details-btn:active{box-shadow:0 2px 10px #3498db4d;transform:translateY(0)}.room-image-container{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-top:20px;padding:15px}.room-image-container h4{color:#333;font-size:16px;font-weight:600;margin:0 0 10px}.room-image{border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;height:auto;max-width:300px;transition:transform .2s ease,box-shadow .2s ease;width:100%}.room-image:hover{box-shadow:0 4px 16px #00000026;transform:scale(1.02)}.image-click-hint{color:#666;font-size:12px;font-style:italic;margin:8px 0 0;text-align:center}.image-modal-overlay{align-items:center;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.image-modal-content{background:#fff;border-radius:12px;max-height:90vh;max-width:90vw;overflow:hidden;position:relative}.image-modal-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:15px 20px}.image-modal-title{color:#333;font-size:18px;font-weight:600;margin:0}.image-modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:background-color .2s;width:30px}.image-modal-close:hover{background-color:#e9ecef}.image-modal-content img{max-height:calc(90vh - 80px);max-width:100%;object-fit:contain}
/*# sourceMappingURL=main.e3358bd0.css.map*/