@import url(https://fonts.googleapis.com/css2?family=Prompt:wght@300;400;500;600&display=swap);.desktop-scroll-container{-webkit-overflow-scrolling:touch;display:flex;gap:1rem;overflow-x:auto;position:relative;scroll-snap-type:x mandatory}.desktop-scroll-container::-webkit-scrollbar{display:none}.desktop-nav-item{background:#fff;border:1px solid #ccc;border-radius:8px;cursor:pointer;flex:0 0 33.333%;font-size:.875rem;padding:.75rem 1rem;scroll-snap-align:center;text-align:center;transition:all .2s ease;white-space:nowrap}.desktop-nav-item:hover{background:#f0f0f0}.desktop-nav-item.active{background:#1976d2;border-color:#1976d2;color:#fff}.desktop-nav-item.active:hover{background:#1565c0}.scroll-container{-webkit-overflow-scrolling:touch;display:flex;gap:.75rem;height:auto;overflow-x:scroll;overflow-y:hidden;padding:.5rem;position:relative;scroll-snap-type:x mandatory;scrollbar-width:none;width:100%}.scroll-container::-webkit-scrollbar{display:none;height:0;width:0}.nav-item{-webkit-tap-highlight-color:transparent;background:#fff;border:1px solid #ccc;border-radius:16px;cursor:pointer;flex:0 0 auto;font-size:.75rem;min-width:100px;padding:.5rem 1rem;scroll-snap-align:start;text-align:center;transition:all .2s ease;-webkit-user-select:none;user-select:none;white-space:nowrap;width:auto}.nav-item:hover{background:#f5f5f5}.nav-item.active{background:#1976d2;border-color:#1976d2;color:#fff}.nav-item.active:hover{background:#1565c0}body,html{height:100%;margin:0;overflow-x:hidden;padding:0}.event-upload-wrapper{background-color:#f5f5f5;min-height:100vh;padding:20px}.event-upload-container{margin:0 auto;max-height:100vh;max-width:95%;overflow-y:auto;padding-right:10px}.event-upload-card{margin-bottom:20px}.card-header{position:-webkit-sticky;position:sticky;top:0;z-index:100}.instructions{background-color:#f9f9f9;border-left:4px solid #007bff;border-radius:4px;margin-bottom:20px;padding:15px}.instructions p{line-height:1.5;margin:8px 0}.format-note{color:#666;font-size:.85rem;line-height:1.4}.text-muted{margin-top:4px}.progress-bar{font-weight:500}.conflict-section,.preview-section,.validation-errors{margin:25px 0}.conflict-section h3,.preview-section h3{background-color:#fff;border-bottom:2px solid #dee2e6;color:#343a40;font-weight:600;margin-bottom:15px;padding-bottom:8px;padding-top:5px}.table-container{border:1px solid #dee2e6;border-radius:4px;margin-bottom:20px;max-height:400px;overflow-y:auto;position:relative}.conflict-table,.preview-table{border-collapse:collapse;font-size:.9rem;table-layout:auto;width:100%}.conflict-table td,.conflict-table th,.preview-table td,.preview-table th{border:1px solid #dee2e6;max-width:200px;overflow:hidden;padding:10px 12px;text-align:left;text-overflow:ellipsis;white-space:nowrap}.conflict-table th,.preview-table th{background-color:#f8f9fa;box-shadow:0 2px 2px -1px #0000001a;font-weight:600;position:-webkit-sticky;position:sticky;top:0;z-index:10}.conflict-table tr:nth-child(2n),.preview-table tr:nth-child(2n){background-color:#f8f9fa}.conflict-table tr:hover,.preview-table tr:hover{background-color:#f1f1f1}.alert h4{font-weight:600;margin-bottom:10px;margin-top:0}.alert ul{margin:8px 0 0;max-height:200px;overflow-y:auto;padding-left:20px}.alert ul li{margin-bottom:4px}.button-container{border-top:1px solid #e9ecef;margin-top:30px}.btn-primary,.btn-secondary{padding:10px 25px;transition:all .2s ease}.btn-primary:hover:not(:disabled),.btn-secondary:hover:not(:disabled){transform:translateY(-1px)}.table-container{overflow-x:auto}.conflict-table,.preview-table{min-width:100%}.conflict-table td,.conflict-table th,.preview-table td,.preview-table th{min-width:120px}@media (max-width:768px){.event-upload-container{max-width:100%;padding:10px}.table-container{max-height:300px}.button-container{flex-direction:column;gap:10px}.btn-primary,.btn-secondary{width:100%}}.button-container{background-color:#fff;bottom:0;padding:15px 0;position:-webkit-sticky;position:sticky;z-index:20}@media (max-height:800px){.event-upload-container{margin:20px auto;max-height:85vh}.table-container{max-height:200px}}.event-upload-container{margin:40px auto;max-width:800px;padding:20px}.event-upload-card{background-color:#fff;border-radius:8px;box-shadow:0 4px 8px #0000001a;overflow:hidden}.card-header{background-color:#f8f9fa;border-bottom:1px solid #e9ecef;padding:16px}.card-header h2{font-size:1.5rem;text-align:center}.card-body{padding:20px}.form-group label{font-weight:500}.form-control{border:1px solid #ced4da;margin-bottom:8px;padding:10px}.form-control:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.form-control:disabled{background-color:#e9ecef;cursor:not-allowed}.text-muted{color:#6c757d;display:block;font-size:.875rem}.progress-container{margin:20px 0}.progress{background-color:#e9ecef;border-radius:4px;height:25px;overflow:hidden}.progress-bar{background-color:#007bff;color:#fff;height:100%;line-height:25px;text-align:center}.alert{font-size:1rem;margin-bottom:20px;padding:12px 16px}.alert-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert-warning{background-color:#fff3cd;border:1px solid #ffeeba;color:#856404}.alert-danger{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.button-container{display:flex;justify-content:space-between;margin-top:24px}.btn-primary,.btn-secondary{border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 20px;transition:background-color .2s}.btn-primary{background-color:#007bff}.btn-primary:hover:not(:disabled){background-color:#0069d9}.btn-secondary{background-color:#6c757d}.btn-secondary:hover:not(:disabled){background-color:#5a6268}.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.65}.login-container{align-items:center;background-color:#f5f5f5;display:flex;font-family:Prompt,sans-serif;justify-content:center;min-height:100vh;padding:20px}.login-card{background-color:#fff;border-radius:12px;box-shadow:0 8px 16px #0000001a;max-width:420px;padding:40px 30px;width:100%}.logo-container{margin-bottom:30px;text-align:center}.logo-container h1{color:#6babff;font-size:32px;margin:0}h2{color:#333;font-size:24px;margin-bottom:30px;text-align:center}label{color:#555;display:block;font-weight:500;margin-bottom:8px}input,label{font-size:16px}input{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;padding:12px 15px;transition:border-color .3s;width:100%}input:focus{border-color:#6babff;box-shadow:0 0 0 2px #6babff33;outline:none}.submit-button{background-color:#6babff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:18px;font-weight:600;margin-top:10px;padding:14px;transition:background-color .3s;width:100%}.submit-button:hover{background-color:#2f29e1}.submit-button:disabled{background-color:#ffb5b5;cursor:not-allowed}.error-message{background-color:#ffebee;border-radius:6px;color:#e53935;margin-bottom:20px;padding:12px}.switch-mode{color:#666;font-size:14px;margin-top:25px;text-align:center}.switch-mode button{background:none;border:none;color:#6babff;cursor:pointer;font-size:14px;font-weight:600;padding:0;text-decoration:underline}.switch-mode button:hover{color:#2f29e1}.social-login{margin:30px 0 20px}.separator{margin:20px 0;position:relative;text-align:center}.separator:before{background-color:#e0e0e0;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.separator span{background-color:#fff;color:#999;font-size:14px;padding:0 15px}.line-button{align-items:center;background-color:#00c300;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;margin-top:10px;padding:14px;transition:background-color .3s;width:100%}.line-button:hover{background-color:#00b300}.line-button:disabled{background-color:#ccc;cursor:not-allowed}.line-button svg{flex-shrink:0}@media (max-width:480px){.login-container{padding:10px}.login-card{padding:30px 20px}.logo-container h1{font-size:28px}h2{font-size:20px}}.return-info{background:#667eea1a;border:1px solid #667eea4d;border-radius:8px;margin-bottom:20px;padding:12px 16px}.return-info p{color:#667eea;font-size:14px;font-weight:500;margin:0;text-align:center}:root{--primary:#3498db;--primary-dark:#2980b9;--secondary:#2c3e50;--secondary-dark:#1a252f;--success-light:#2ecc71;--danger-dark:#c0392b;--warning-light:#f1c40f;--info-light:#5dade2;--admin-primary:#2c3e50;--admin-accent:#e74c3c;--admin-highlight:#3498db;--user-primary:#1e88e5;--user-accent:#43a047;--user-highlight:#f57c00;--white:#fff;--light:#f8f9fa;--light-gray:#e9ecef;--gray:#adb5bd;--dark-gray:#6c757d;--dark:#343a40;--black:#212529;--font-family-sans:"Roboto",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue",Arial,sans-serif;--font-family-mono:"Roboto Mono",Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-5:1.5rem;--spacing-6:2rem;--spacing-8:3rem;--spacing-10:4rem;--border-radius-sm:0.25rem;--border-radius:0.375rem;--border-radius-lg:0.5rem;--border-radius-xl:0.75rem;--border-radius-2xl:1rem;--border-radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--z-negative:-1;--z-elevate:1;--z-dropdown:10;--z-sticky:100;--z-fixed:200;--z-modal:300;--z-popover:400;--z-tooltip:500;--transition-fast:150ms;--transition-normal:250ms;--transition-slow:350ms;--transition-ease:cubic-bezier(0.4,0,0.2,1)}*,:after,:before{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;font-size:16px;line-height:1.5}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;background-color:var(--light);color:#212529;color:var(--black);font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,Arial,sans-serif;font-family:var(--font-family-sans);font-size:1rem;font-size:var(--font-size-base);font-weight:400}h1,h2,h3,h4,h5,h6{color:#2c3e50;color:var(--secondary);font-weight:500;line-height:1.2;margin-bottom:1rem;margin-bottom:var(--spacing-4);margin-top:0}h1{font-size:2.25rem;font-size:var(--font-size-4xl)}h2{font-size:1.875rem;font-size:var(--font-size-3xl)}h3{font-size:1.5rem;font-size:var(--font-size-2xl)}h4{font-size:1.25rem;font-size:var(--font-size-xl)}h5{font-size:1.125rem;font-size:var(--font-size-lg)}h6{font-size:1rem;font-size:var(--font-size-base)}p{margin-bottom:1rem;margin-bottom:var(--spacing-4);margin-top:0}a{color:#3498db;color:var(--primary);text-decoration:none;transition:color .15s ease;transition:color var(--transition-fast) ease}a:hover{color:#2980b9;color:var(--primary-dark);text-decoration:underline}ol,ul{margin-bottom:1rem;margin-bottom:var(--spacing-4);margin-top:0;padding-left:2rem;padding-left:var(--spacing-6)}img{height:auto;max-width:100%;vertical-align:middle}table{border-collapse:collapse;width:100%}button,input,optgroup,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit;margin:0}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}button:focus,input:focus,select:focus,textarea:focus{outline:none}.d-none{display:none!important}.d-inline{display:inline!important}.d-inline-block{display:inline-block!important}.d-block{display:block!important}.d-flex{display:flex!important}.d-grid{display:grid!important}.flex-row{flex-direction:row!important}.flex-column{flex-direction:column!important}.flex-wrap{flex-wrap:wrap!important}.flex-nowrap{flex-wrap:nowrap!important}.justify-content-start{justify-content:flex-start!important}.justify-content-end{justify-content:flex-end!important}.justify-content-center{justify-content:center!important}.justify-content-between{justify-content:space-between!important}.justify-content-around{justify-content:space-around!important}.align-items-start{align-items:flex-start!important}.align-items-end{align-items:flex-end!important}.align-items-center{align-items:center!important}.align-items-baseline{align-items:baseline!important}.align-items-stretch{align-items:stretch!important}.text-left{text-align:left!important}.text-right{text-align:right!important}.text-center{text-align:center!important}.text-justify{text-align:justify!important}.text-lowercase{text-transform:lowercase!important}.text-uppercase{text-transform:uppercase!important}.text-capitalize{text-transform:capitalize!important}.font-weight-light{font-weight:300!important}.font-weight-normal{font-weight:400!important}.font-weight-medium{font-weight:500!important}.font-weight-bold{font-weight:700!important}.text-primary{color:#3498db!important;color:var(--primary)!important}.text-secondary{color:#2c3e50!important;color:var(--secondary)!important}.text-success{color:#27ae60!important;color:var(--success)!important}.text-danger{color:#e74c3c!important;color:var(--danger)!important}.text-warning{color:#f39c12!important;color:var(--warning)!important}.text-info{color:#3498db!important;color:var(--info)!important}.text-light{color:#f8f9fa!important;color:var(--light)!important}.text-dark{color:#343a40!important;color:var(--dark)!important}.text-muted{color:#6c757d!important;color:var(--dark-gray)!important}.bg-primary{background-color:#3498db!important;background-color:var(--primary)!important}.bg-secondary{background-color:#2c3e50!important;background-color:var(--secondary)!important}.bg-success{background-color:#27ae60!important;background-color:var(--success)!important}.bg-danger{background-color:#e74c3c!important;background-color:var(--danger)!important}.bg-warning{background-color:#f39c12!important;background-color:var(--warning)!important}.bg-info{background-color:#3498db!important;background-color:var(--info)!important}.bg-light{background-color:#f8f9fa!important;background-color:var(--light)!important}.bg-dark{background-color:#343a40!important;background-color:var(--dark)!important}.bg-white{background-color:#fff!important;background-color:var(--white)!important}.border{border:1px solid #e9ecef!important;border:1px solid var(--light-gray)!important}.border-top{border-top:1px solid #e9ecef!important;border-top:1px solid var(--light-gray)!important}.border-right{border-right:1px solid #e9ecef!important;border-right:1px solid var(--light-gray)!important}.border-bottom{border-bottom:1px solid #e9ecef!important;border-bottom:1px solid var(--light-gray)!important}.border-left{border-left:1px solid #e9ecef!important;border-left:1px solid var(--light-gray)!important}.border-0{border:0!important}.rounded{border-radius:.375rem!important;border-radius:var(--border-radius)!important}.rounded-lg{border-radius:.5rem!important;border-radius:var(--border-radius-lg)!important}.rounded-circle{border-radius:50%!important}.rounded-0{border-radius:0!important}.m-0{margin:0!important}.mt-0{margin-top:0!important}.mr-0{margin-right:0!important}.mb-0{margin-bottom:0!important}.ml-0{margin-left:0!important}.m-1{margin:.25rem!important;margin:var(--spacing-1)!important}.mt-1{margin-top:.25rem!important;margin-top:var(--spacing-1)!important}.mr-1{margin-right:.25rem!important;margin-right:var(--spacing-1)!important}.mb-1{margin-bottom:.25rem!important;margin-bottom:var(--spacing-1)!important}.ml-1{margin-left:.25rem!important;margin-left:var(--spacing-1)!important}.m-2{margin:.5rem!important;margin:var(--spacing-2)!important}.mt-2{margin-top:.5rem!important;margin-top:var(--spacing-2)!important}.mr-2{margin-right:.5rem!important;margin-right:var(--spacing-2)!important}.mb-2{margin-bottom:.5rem!important;margin-bottom:var(--spacing-2)!important}.ml-2{margin-left:.5rem!important;margin-left:var(--spacing-2)!important}.m-3{margin:.75rem!important;margin:var(--spacing-3)!important}.mt-3{margin-top:.75rem!important;margin-top:var(--spacing-3)!important}.mr-3{margin-right:.75rem!important;margin-right:var(--spacing-3)!important}.mb-3{margin-bottom:.75rem!important;margin-bottom:var(--spacing-3)!important}.ml-3{margin-left:.75rem!important;margin-left:var(--spacing-3)!important}.m-4{margin:1rem!important;margin:var(--spacing-4)!important}.mt-4{margin-top:1rem!important;margin-top:var(--spacing-4)!important}.mr-4{margin-right:1rem!important;margin-right:var(--spacing-4)!important}.mb-4{margin-bottom:1rem!important;margin-bottom:var(--spacing-4)!important}.ml-4{margin-left:1rem!important;margin-left:var(--spacing-4)!important}.m-5{margin:1.5rem!important;margin:var(--spacing-5)!important}.mt-5{margin-top:1.5rem!important;margin-top:var(--spacing-5)!important}.mr-5{margin-right:1.5rem!important;margin-right:var(--spacing-5)!important}.mb-5{margin-bottom:1.5rem!important;margin-bottom:var(--spacing-5)!important}.ml-5{margin-left:1.5rem!important;margin-left:var(--spacing-5)!important}.p-0{padding:0!important}.pt-0{padding-top:0!important}.pr-0{padding-right:0!important}.pb-0{padding-bottom:0!important}.pl-0{padding-left:0!important}.p-1{padding:.25rem!important;padding:var(--spacing-1)!important}.pt-1{padding-top:.25rem!important;padding-top:var(--spacing-1)!important}.pr-1{padding-right:.25rem!important;padding-right:var(--spacing-1)!important}.pb-1{padding-bottom:.25rem!important;padding-bottom:var(--spacing-1)!important}.pl-1{padding-left:.25rem!important;padding-left:var(--spacing-1)!important}.p-2{padding:.5rem!important;padding:var(--spacing-2)!important}.pt-2{padding-top:.5rem!important;padding-top:var(--spacing-2)!important}.pr-2{padding-right:.5rem!important;padding-right:var(--spacing-2)!important}.pb-2{padding-bottom:.5rem!important;padding-bottom:var(--spacing-2)!important}.pl-2{padding-left:.5rem!important;padding-left:var(--spacing-2)!important}.p-3{padding:.75rem!important;padding:var(--spacing-3)!important}.pt-3{padding-top:.75rem!important;padding-top:var(--spacing-3)!important}.pr-3{padding-right:.75rem!important;padding-right:var(--spacing-3)!important}.pb-3{padding-bottom:.75rem!important;padding-bottom:var(--spacing-3)!important}.pl-3{padding-left:.75rem!important;padding-left:var(--spacing-3)!important}.p-4{padding:1rem!important;padding:var(--spacing-4)!important}.pt-4{padding-top:1rem!important;padding-top:var(--spacing-4)!important}.pr-4{padding-right:1rem!important;padding-right:var(--spacing-4)!important}.pb-4{padding-bottom:1rem!important;padding-bottom:var(--spacing-4)!important}.pl-4{padding-left:1rem!important;padding-left:var(--spacing-4)!important}.p-5{padding:1.5rem!important;padding:var(--spacing-5)!important}.pt-5{padding-top:1.5rem!important;padding-top:var(--spacing-5)!important}.pr-5{padding-right:1.5rem!important;padding-right:var(--spacing-5)!important}.pb-5{padding-bottom:1.5rem!important;padding-bottom:var(--spacing-5)!important}.pl-5{padding-left:1.5rem!important;padding-left:var(--spacing-5)!important}.w-25{width:25%!important}.w-50{width:50%!important}.w-75{width:75%!important}.w-100{width:100%!important}.h-25{height:25%!important}.h-50{height:50%!important}.h-75{height:75%!important}.h-100{height:100%!important}.visible{visibility:visible!important}.invisible{visibility:hidden!important}.shadow-sm{box-shadow:0 1px 2px 0 #0000000d!important;box-shadow:var(--shadow-sm)!important}.shadow{box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f!important;box-shadow:var(--shadow)!important}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f!important;box-shadow:var(--shadow-md)!important}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d!important;box-shadow:var(--shadow-lg)!important}.shadow-none{box-shadow:none!important}.float-left{float:left!important}.float-right{float:right!important}.float-none{float:none!important}.clearfix:after{clear:both;content:"";display:block}.overflow-auto{overflow:auto!important}.overflow-hidden{overflow:hidden!important}.overflow-visible{overflow:visible!important}.overflow-scroll{overflow:scroll!important}.position-static{position:static!important}.position-relative{position:relative!important}.position-absolute{position:absolute!important}.position-fixed{position:fixed!important}.position-sticky{position:-webkit-sticky!important;position:sticky!important}.fixed-top{top:0}.fixed-bottom,.fixed-top{left:0;position:fixed;right:0;z-index:200;z-index:var(--z-fixed)}.fixed-bottom{bottom:0}.sticky-top{position:-webkit-sticky;position:sticky;top:0;z-index:100;z-index:var(--z-sticky)}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.btn{padding:.6rem 1.2rem;transition:background-color .2s,transform .1s}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background-color:#3498db}.btn-primary:hover{background-color:#2980b9}.btn-success{background-color:#27ae60;color:#fff}.btn-success:hover{background-color:#2ecc71}.btn-danger{background-color:#e74c3c;color:#fff}.btn-danger:hover{background-color:#c0392b}.btn-neutral{background-color:#2c3e50;color:#fff}.btn-neutral:hover{background-color:#3a5066}.btn-link{color:#3498db;padding:.2rem .5rem}.btn-link:hover{background:#3498db1a;color:#2980b9}.card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.card-header{margin-bottom:1rem;padding-bottom:.8rem}.card-header h3{color:#2c3e50;font-size:1.2rem;margin:0}.card-body{padding:.5rem 0}.card-footer{border-top:1px solid #f0f0f0;display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem}.badge{border-radius:50px;display:inline-block;font-size:.8rem;font-weight:500;padding:.2rem .6rem}.badge-primary{background-color:#3498db;color:#fff}.badge-success{background-color:#27ae60;color:#fff}.badge-warning{background-color:#f39c12;color:#fff}.badge-danger{background-color:#e74c3c;color:#fff}.badge-neutral{background-color:#2c3e50;color:#fff}.badge-light{background-color:#f8f9fa;color:#2c3e50}.list{list-style:none;margin:0;padding:0}.list-item{border-bottom:1px solid #f0f0f0;padding:1rem}.list-item:last-child{border-bottom:none}.list-item-action{align-items:center;display:flex;justify-content:space-between}.form-group{margin-bottom:1.5rem}.form-label{color:#2c3e50;display:block;font-weight:500;margin-bottom:.5rem}.form-control{border:1px solid #e0e0e0;border-radius:4px;font-size:1rem;padding:.8rem;transition:border .2s;width:100%}.form-control:focus{border-color:#3498db;outline:none}.form-control::placeholder{color:#aaa}.form-help{color:#888}.form-error,.form-help{font-size:.85rem;margin-top:.5rem}.form-error{color:#e74c3c}.alert{border-radius:4px;margin-bottom:1rem;padding:1rem}.alert-primary{background-color:#d6eaf8;border-left:4px solid #3498db;color:#2980b9}.alert-success{background-color:#d5f5e3;border-left:4px solid #2ecc71;color:#27ae60}.alert-warning{background-color:#fef5e7;border-left:4px solid #f1c40f;color:#f39c12}.alert-danger{background-color:#fadbd8;border-left:4px solid #e74c3c;color:#c0392b}.avatar{border-radius:50%;height:40px;overflow:hidden;width:40px}.avatar-sm{height:30px;width:30px}.avatar-lg{height:60px;width:60px}.avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{background-color:#3498db;font-size:1rem;font-weight:700}.table{border-collapse:collapse;margin-bottom:1rem;width:100%}.table th{border-bottom:2px solid #e0e0e0;color:#2c3e50;font-weight:600;padding:.75rem;text-align:left}.table td{border-bottom:1px solid #f0f0f0;padding:.75rem}.table tr:last-child td{border-bottom:none}.table tr:hover,.table-striped tbody tr:nth-child(odd){background-color:#f8f9fa}.empty-state{color:#888}.empty-state-message,.tabs{margin-bottom:1.5rem}.tabs{border-bottom:1px solid #e0e0e0;display:flex}.tab{border-bottom:3px solid #0000;cursor:pointer;padding:.75rem 1.5rem;transition:all .2s}.tab.active,.tab:hover{color:#3498db}.tab.active{border-bottom-color:#3498db}.tab-content{padding:1rem 0}.container{margin-left:auto;margin-right:auto;padding-left:15px;padding-right:15px;width:100%}@media (min-width:576px){.container{max-width:540px}}@media (min-width:768px){.container{max-width:720px}}@media (min-width:992px){.container{max-width:960px}}@media (min-width:1200px){.container{max-width:1140px}}.container-fluid{margin-left:auto;margin-right:auto;padding-left:15px;padding-right:15px;width:100%}.row{display:flex;flex-wrap:wrap;margin-left:-15px;margin-right:-15px}.no-gutters{margin-left:0;margin-right:0}.no-gutters>.col,.no-gutters>[class*=col-]{padding-left:0;padding-right:0}.col{flex-basis:0;flex-grow:1;max-width:100%;padding-left:15px;padding-right:15px;position:relative;width:100%}.col-1{flex:0 0 8.333333%;max-width:8.333333%}.col-2{flex:0 0 16.666667%;max-width:16.666667%}.col-3{flex:0 0 25%;max-width:25%}.col-4{flex:0 0 33.333333%;max-width:33.333333%}.col-5{flex:0 0 41.666667%;max-width:41.666667%}.col-6{flex:0 0 50%;max-width:50%}.col-7{flex:0 0 58.333333%;max-width:58.333333%}.col-8{flex:0 0 66.666667%;max-width:66.666667%}.col-9{flex:0 0 75%;max-width:75%}.col-10{flex:0 0 83.333333%;max-width:83.333333%}.col-11{flex:0 0 91.666667%;max-width:91.666667%}.col-12{flex:0 0 100%;max-width:100%}@media (min-width:576px){.col-sm-1{flex:0 0 8.333333%;max-width:8.333333%}.col-sm-2{flex:0 0 16.666667%;max-width:16.666667%}.col-sm-3{flex:0 0 25%;max-width:25%}.col-sm-4{flex:0 0 33.333333%;max-width:33.333333%}.col-sm-5{flex:0 0 41.666667%;max-width:41.666667%}.col-sm-6{flex:0 0 50%;max-width:50%}.col-sm-7{flex:0 0 58.333333%;max-width:58.333333%}.col-sm-8{flex:0 0 66.666667%;max-width:66.666667%}.col-sm-9{flex:0 0 75%;max-width:75%}.col-sm-10{flex:0 0 83.333333%;max-width:83.333333%}.col-sm-11{flex:0 0 91.666667%;max-width:91.666667%}.col-sm-12{flex:0 0 100%;max-width:100%}}@media (min-width:768px){.col-md-1{flex:0 0 8.333333%;max-width:8.333333%}.col-md-2{flex:0 0 16.666667%;max-width:16.666667%}.col-md-3{flex:0 0 25%;max-width:25%}.col-md-4{flex:0 0 33.333333%;max-width:33.333333%}.col-md-5{flex:0 0 41.666667%;max-width:41.666667%}.col-md-6{flex:0 0 50%;max-width:50%}.col-md-7{flex:0 0 58.333333%;max-width:58.333333%}.col-md-8{flex:0 0 66.666667%;max-width:66.666667%}.col-md-9{flex:0 0 75%;max-width:75%}.col-md-10{flex:0 0 83.333333%;max-width:83.333333%}.col-md-11{flex:0 0 91.666667%;max-width:91.666667%}.col-md-12{flex:0 0 100%;max-width:100%}}@media (min-width:992px){.col-lg-1{flex:0 0 8.333333%;max-width:8.333333%}.col-lg-2{flex:0 0 16.666667%;max-width:16.666667%}.col-lg-3{flex:0 0 25%;max-width:25%}.col-lg-4{flex:0 0 33.333333%;max-width:33.333333%}.col-lg-5{flex:0 0 41.666667%;max-width:41.666667%}.col-lg-6{flex:0 0 50%;max-width:50%}.col-lg-7{flex:0 0 58.333333%;max-width:58.333333%}.col-lg-8{flex:0 0 66.666667%;max-width:66.666667%}.col-lg-9{flex:0 0 75%;max-width:75%}.col-lg-10{flex:0 0 83.333333%;max-width:83.333333%}.col-lg-11{flex:0 0 91.666667%;max-width:91.666667%}.col-lg-12{flex:0 0 100%;max-width:100%}}@media (min-width:1200px){.col-xl-1{flex:0 0 8.333333%;max-width:8.333333%}.col-xl-2{flex:0 0 16.666667%;max-width:16.666667%}.col-xl-3{flex:0 0 25%;max-width:25%}.col-xl-4{flex:0 0 33.333333%;max-width:33.333333%}.col-xl-5{flex:0 0 41.666667%;max-width:41.666667%}.col-xl-6{flex:0 0 50%;max-width:50%}.col-xl-7{flex:0 0 58.333333%;max-width:58.333333%}.col-xl-8{flex:0 0 66.666667%;max-width:66.666667%}.col-xl-9{flex:0 0 75%;max-width:75%}.col-xl-10{flex:0 0 83.333333%;max-width:83.333333%}.col-xl-11{flex:0 0 91.666667%;max-width:91.666667%}.col-xl-12{flex:0 0 100%;max-width:100%}}.grid{grid-gap:1rem;display:grid}.grid-gap-0{grid-gap:0}.grid-gap-1{grid-gap:.25rem}.grid-gap-2{grid-gap:.5rem}.grid-gap-3{grid-gap:1rem}.grid-gap-4{grid-gap:1.5rem}.grid-gap-5{grid-gap:3rem}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.grid-cols-5{grid-template-columns:repeat(5,1fr)}.grid-cols-6{grid-template-columns:repeat(6,1fr)}@media (min-width:576px){.grid-cols-sm-1{grid-template-columns:repeat(1,1fr)}.grid-cols-sm-2{grid-template-columns:repeat(2,1fr)}.grid-cols-sm-3{grid-template-columns:repeat(3,1fr)}.grid-cols-sm-4{grid-template-columns:repeat(4,1fr)}.grid-cols-sm-5{grid-template-columns:repeat(5,1fr)}.grid-cols-sm-6{grid-template-columns:repeat(6,1fr)}}@media (min-width:768px){.grid-cols-md-1{grid-template-columns:repeat(1,1fr)}.grid-cols-md-2{grid-template-columns:repeat(2,1fr)}.grid-cols-md-3{grid-template-columns:repeat(3,1fr)}.grid-cols-md-4{grid-template-columns:repeat(4,1fr)}.grid-cols-md-5{grid-template-columns:repeat(5,1fr)}.grid-cols-md-6{grid-template-columns:repeat(6,1fr)}}@media (min-width:992px){.grid-cols-lg-1{grid-template-columns:repeat(1,1fr)}.grid-cols-lg-2{grid-template-columns:repeat(2,1fr)}.grid-cols-lg-3{grid-template-columns:repeat(3,1fr)}.grid-cols-lg-4{grid-template-columns:repeat(4,1fr)}.grid-cols-lg-5{grid-template-columns:repeat(5,1fr)}.grid-cols-lg-6{grid-template-columns:repeat(6,1fr)}}@media (min-width:1200px){.grid-cols-xl-1{grid-template-columns:repeat(1,1fr)}.grid-cols-xl-2{grid-template-columns:repeat(2,1fr)}.grid-cols-xl-3{grid-template-columns:repeat(3,1fr)}.grid-cols-xl-4{grid-template-columns:repeat(4,1fr)}.grid-cols-xl-5{grid-template-columns:repeat(5,1fr)}.grid-cols-xl-6{grid-template-columns:repeat(6,1fr)}}.page-container{display:flex;flex-direction:column;min-height:100vh}.page-header{flex-shrink:0}.page-content{flex:1 0 auto}.page-footer{flex-shrink:0}.two-column-layout{display:flex;flex-wrap:wrap}.main-content,.sidebar{flex:0 0 100%}@media (min-width:992px){.sidebar{flex:0 0 250px}.main-content{flex:1 1}}.three-column-layout{display:flex;flex-wrap:wrap}.center-content,.left-sidebar,.right-sidebar{flex:0 0 100%}@media (min-width:992px){.left-sidebar,.right-sidebar{flex:0 0 250px}.center-content{flex:1 1}}.dashboard-layout{display:flex;flex-direction:column;min-height:100vh}.dashboard-header{flex-shrink:0}.dashboard-content{background:#f9fafc;flex:1 1 auto;overflow-y:auto}@media (min-width:992px){.dashboard-content{flex-direction:row}}.dashboard-sidebar{flex-shrink:0;width:100%}.dashboard-main{max-height:100vh;max-width:580px;overflow-y:auto;padding:0 10px 20px}@media (min-width:992px){.dashboard-sidebar{width:250px}}.fixed-sidebar-layout{display:flex;flex-direction:column;min-height:100vh}@media (min-width:992px){.fixed-sidebar-layout{flex-direction:row}.fixed-sidebar{bottom:0;overflow-y:auto;position:fixed;top:0;width:250px}.fixed-sidebar-content{margin-left:250px;width:calc(100% - 250px)}}.dashboard-header{background-color:#fff;box-shadow:0 2px 5px #00000014;box-shadow:var(--header-shadow,0 2px 5px #00000014);height:70px;padding:.75rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.logo{cursor:pointer;font-size:1.75rem;font-weight:700;font-weight:var(--font-weight-bold,700);letter-spacing:-.5px;margin-right:2.5rem;transform:translateY(-1px)}.logo,.logo i{color:#4a6cf7;color:var(--primary-color,#4a6cf7)}.logo i{font-size:1.65rem;margin-right:8px}.search-container{position:relative;width:300px}.search-container form{display:flex;width:100%}.search-container input{background-color:#f8f9fa;background-color:var(--gray-100,#f8f9fa);border:1px solid #dee2e6;border:1px solid var(--gray-300,#dee2e6);border-radius:12px;border-radius:var(--border-radius-lg,12px);font-size:.9rem;padding:10px 40px 10px 16px;transition:.2s;transition:var(--transition-fast,.2s);width:100%}.search-container input:focus{background-color:#fff;border-color:#4a6cf7;border-color:var(--primary-color,#4a6cf7);box-shadow:0 0 0 3px #4361ee26;outline:none}.search-container button{background:none;border:none;color:#6c757d;color:var(--gray-600,#6c757d);cursor:pointer;font-size:1rem;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:.2s;transition:var(--transition-fast,.2s)}.search-container button:hover{color:#4a6cf7;color:var(--primary-color,#4a6cf7)}.header-right{align-items:center;display:flex;gap:20px}.home-button{background-color:#f0f4ff;border-radius:20px;box-shadow:0 2px 5px #0000001a;color:#4a6cf7;gap:6px;margin-right:10px;padding:6px 12px;transition:all .3s ease}.home-button:hover{background-color:#4a6cf7;box-shadow:0 3px 8px #00000026;color:#fff;transform:scale(1.05)}.home-button i{font-size:1.2rem}.icon-text{font-size:.9rem;font-weight:500}.header-buttons{gap:20px;margin-left:auto}.header-buttons,.header-left{align-items:center;display:flex}.header-left{flex:1 1;justify-content:space-between;width:100%}.header-right{display:none}.logo{align-items:center;display:flex;flex-shrink:0}.mobile-content{margin-top:0!important;padding-top:.5rem!important}.mobile-tab-content{padding-top:10px!important}.mobile-tab-header{margin-top:0!important}@media (max-width:768px){.dashboard-header{height:70px;left:0;margin-bottom:0;min-height:70px;padding:.75rem 1rem;position:fixed;right:0;top:0;width:100vw;z-index:1000}.dashboard-header,.header-left{align-items:center;display:flex;justify-content:space-between}.header-left{flex:1 1;width:100%}.header-buttons{gap:12px;margin-left:auto}.header-buttons,.logo{align-items:center;display:flex;flex-shrink:0}.logo{font-size:1.3rem;line-height:1;margin-right:1rem}.logo i{font-size:1.2rem;margin-right:6px}.profile-name{display:none}.dashboard-content{margin-top:0!important;padding-top:0!important}.mobile-content{margin-top:0!important;padding:0 .5rem .5rem!important}.mobile-tab-content{height:calc(100vh - 150px)!important;padding-top:5px!important}.mobile-tab-header{margin-bottom:16px!important;margin-top:0!important}.header-buttons .home-button,.header-buttons .profile-button,.header-buttons .tour-guide-button{border-radius:16px;margin:0;padding:4px 8px}.header-buttons .home-button,.header-buttons .notification-dropdown,.header-buttons .notification-dropdown .notification-button,.header-buttons .notification-dropdown button,.header-buttons .profile-button,.header-buttons .tour-guide-button{align-items:center;display:flex;flex-shrink:0;height:32px;justify-content:center;max-height:32px;min-height:32px}.header-buttons .notification-dropdown .notification-button,.header-buttons .notification-dropdown button{margin:0;max-width:32px;min-width:32px;padding:0;width:32px}.header-buttons .profile-button,.header-buttons .profile-section{align-items:center;display:flex;flex-shrink:0;height:32px;max-height:32px;min-height:32px}.header-buttons .profile-button{justify-content:center;margin:0;padding:2px 4px}.header-buttons .profile-image{border-radius:50%;flex-shrink:0;height:24px;margin:0;object-fit:cover;width:24px}.header-buttons .home-button i{font-size:1rem}.header-buttons .compass-people-icon{font-size:.9rem}}@media (max-width:480px){.header-buttons{gap:10px}.logo{font-size:1.2rem;margin-right:.5rem}.logo i{font-size:1.1rem;margin-right:4px}.header-buttons .home-button,.header-buttons .notification-dropdown .notification-button,.header-buttons .notification-dropdown button,.header-buttons .profile-button,.header-buttons .tour-guide-button{height:28px;max-height:28px;min-height:28px;min-width:28px;padding:2px 4px;width:28px}.header-buttons .profile-image{height:20px;width:20px}}.event-card{border:1px solid var(--gray-200,#eaeaea);border-radius:var(--border-radius,8px)}.event-card,.save-button{transition:.3s;transition:var(--transition,.3s)}.save-button{color:var(--gray-600,#6c757d)}.save-button.saved-interested{color:#fa8c16}.save-button.saved-going{color:#52c41a}.event-info h3{color:var(--gray-800,#343a40)}.event-date,.event-location{color:var(--gray-600,#6c757d)}.event-date i,.event-location i{color:var(--primary-color,#4a6cf7)}.event-description,.no-data-container{color:var(--gray-600,#6c757d)}.no-data-container i{color:var(--gray-400,#ced4da)}.no-data{color:var(--gray-600,#6c757d)}@media (min-width:769px){.pe-tag-delete{background:linear-gradient(135deg,#ef4444,#dc2626)!important;border:none!important;box-shadow:0 2px 8px #ef44444d!important;color:#fff!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important}.pe-tag-delete:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)!important;box-shadow:0 4px 12px #ef444466!important;transform:translateY(-1px)!important}.pe-tag-delete:active{box-shadow:0 2px 6px #ef444466!important;transform:translateY(0)!important}.pe-tag{border:none!important;border-radius:8px!important;cursor:pointer!important;font-size:.85rem!important;font-weight:500!important;padding:6px 12px!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important}.pe-tag:hover:not(.pe-tag-disabled){box-shadow:0 4px 12px #00000026!important;transform:translateY(-1px)!important}.pe-tag-going{background:linear-gradient(135deg,#10b981,#059669)!important;color:#fff!important}.pe-tag-interested-yellow{background:linear-gradient(135deg,#f59e0b,#d97706)!important;color:#fff!important}.pe-tag-cancel{background:linear-gradient(135deg,#6b7280,#4b5563)!important;color:#fff!important}.pe-tag-past{background:linear-gradient(135deg,#94a3b8,#64748b)!important;color:#fff!important}.pe-tag-cancelled{background:linear-gradient(135deg,#f87171,#ef4444)!important;color:#fff!important}.pe-tag-disabled{box-shadow:none!important;cursor:not-allowed!important;opacity:.6!important;transform:none!important}.pe-tag-updating{opacity:.7!important;pointer-events:none!important}.pe-button-group{display:flex!important;flex-shrink:0!important;gap:.5rem!important}.pe-item{background:#fff!important;border:1px solid #f3f4f6!important;border-radius:.75rem!important;box-shadow:0 2px 8px #0000001a!important;cursor:pointer!important;padding:1.25rem!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important}.pe-item:hover{box-shadow:0 4px 12px #00000026!important;transform:translateY(-1px)!important}.pe-item-grey{background:#f8fafc!important;opacity:.8!important}.pe-item-header{align-items:flex-start!important;display:flex!important;gap:1rem!important;justify-content:space-between!important;margin-bottom:.75rem!important}.pe-item-title{color:#111827!important;flex:1 1!important;font-size:1.1rem!important;font-weight:600!important;line-height:1.4!important;margin:0!important}.pe-item-date,.pe-title-grey{color:#6b7280!important}.pe-item-date{font-size:.9rem!important;margin-bottom:.5rem!important}.pe-date-grey{color:#9ca3af!important}.pe-item-location{align-items:center!important;color:#6b7280!important;display:flex!important;font-size:.85rem!important;gap:.25rem!important}.pe-location-grey{color:#9ca3af!important}}.profile-section{position:relative}.profile-button{align-items:center;border-radius:8px;border-radius:var(--border-radius,8px);cursor:pointer;display:flex;gap:10px;padding:6px 10px;transition:.2s;transition:var(--transition-fast,.2s)}.profile-button:hover{background-color:#4361ee14}.profile-image{border:2px solid #4a6cf7;border:2px solid var(--primary-color,#4a6cf7);border-radius:50%;box-shadow:0 2px 4px #0000001a;height:38px;object-fit:cover;width:38px}.profile-button span{color:#343a40;color:var(--gray-800,#343a40);font-size:.95rem;font-weight:500;font-weight:var(--font-weight-medium,500)}.profile-menu{background-color:#fff;border-radius:12px;border-radius:var(--border-radius-lg,12px);box-shadow:0 5px 15px #0000001a,0 3px 6px #0000000d;opacity:1;overflow:hidden;position:absolute;right:0;top:60px;transform:translateY(0);transition:opacity .3s ease,transform .3s ease,visibility .3s ease;visibility:visible;width:300px;z-index:1001}.profile-header{align-items:center;background:linear-gradient(135deg,#4895ef,#4a6cf7);background:linear-gradient(135deg,var(--primary-light,#4895ef) 0,var(--primary-color,#4a6cf7) 100%);color:#fff;display:flex;gap:15px;padding:20px}.profile-menu-image{border:3px solid #fffc;border-radius:50%;box-shadow:0 2px 10px #0003;height:60px;object-fit:cover;width:60px}.profile-user-info h3{color:#fff;font-size:1.1rem;font-weight:600;font-weight:var(--font-weight-semibold,600);margin-bottom:3px}.profile-user-info p{color:#ffffffd9;font-size:.85rem;margin-bottom:0}.profile-menu ul{padding:8px 0}.profile-menu ul li{align-items:center;color:#495057;color:var(--gray-700,#495057);cursor:pointer;display:flex;font-size:.95rem;padding:12px 20px}.profile-menu ul li,.profile-menu ul li i{transition:.2s;transition:var(--transition-fast,.2s)}.profile-menu ul li i{color:#6c757d;color:var(--gray-600,#6c757d);font-size:1.05rem;margin-right:12px;text-align:center;width:20px}.profile-menu ul li:hover{background-color:#f8f9fa;background-color:var(--gray-100,#f8f9fa)}.profile-menu ul li:hover,.profile-menu ul li:hover i{color:#4a6cf7;color:var(--primary-color,#4a6cf7)}.profile-menu ul li:active{background-color:#e9ecef;background-color:var(--gray-200,#e9ecef)}.role-request-item,.role-request-item i{color:#4a6cf7!important;color:var(--primary-color,#4a6cf7)!important}.pending-request{cursor:default!important}.pending-request,.pending-request i{color:#f39c12!important;color:var(--warning-color,#f39c12)!important}.pending-request:hover{background-color:initial!important}.logout-item{border-top:1px solid #e9ecef;border-top:1px solid var(--gray-200,#e9ecef);margin-top:8px}.logout-item,.logout-item i{color:#e74c3c!important;color:var(--danger-color,#e74c3c)!important}.logout-item:hover{background-color:#e74c3c14!important}.chat-list{display:flex;flex-direction:column;gap:15px;height:100%;min-height:350px}.chat-item{align-items:center;border:1px solid #f0f4ff;border-radius:8px;cursor:pointer;display:flex;margin-bottom:5px;padding:15px;transition:background-color .3s}.chat-item:hover{background-color:#f5f7ff}.chat-avatar{border-radius:50%;height:45px;margin-right:12px;object-fit:cover;width:45px}.chat-info{flex:1 1}.chat-info h4{font-size:.95rem;margin:0 0 5px}.chat-preview{color:#666;font-size:.85rem;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-menu .disabled-item{color:#999!important;cursor:not-allowed!important;opacity:.6!important;pointer-events:none!important}.profile-menu .disabled-item:hover{background-color:initial!important;color:#999!important;cursor:not-allowed!important}.profile-menu .disabled-item i{color:#999!important}.header-buttons .profile-section .profile-avatar-fallback{border:2px solid #4a6cf7!important;border:2px solid var(--primary-color,#4a6cf7)!important;border-radius:50%!important;box-shadow:0 2px 4px #0000001a!important;height:38px!important;width:38px!important}.header-buttons .profile-section .profile-avatar-fallback,.profile-menu .profile-menu-avatar-fallback{align-items:center!important;background:linear-gradient(135deg,#667eea,#764ba2)!important;display:flex!important;flex-shrink:0!important;justify-content:center!important}.profile-menu .profile-menu-avatar-fallback{border:3px solid #fffc!important;border-radius:50%!important;box-shadow:0 2px 10px #0003!important;height:60px!important;width:60px!important}.avatar-letter{color:#fff!important;font-size:16px!important;font-weight:700!important;line-height:1!important;text-align:center!important;text-shadow:0 1px 2px #0000001a!important}.profile-menu-avatar-fallback .avatar-letter{font-size:20px!important}@media (max-width:768px){.header-buttons .profile-section .profile-avatar-fallback{border:1px solid #4a6cf7!important;border:1px solid var(--primary-color,#4a6cf7)!important;height:24px!important;width:24px!important}.header-buttons .profile-section .profile-avatar-fallback .avatar-letter{font-size:12px!important}}@media (max-width:480px){.header-buttons .profile-section .profile-avatar-fallback{height:20px!important;width:20px!important}.header-buttons .profile-section .profile-avatar-fallback .avatar-letter{font-size:11px!important}}.avatar-fallback{align-items:center;background:linear-gradient(135deg,#999,#777);background:linear-gradient(135deg,var(--bg-color,#999) 0,var(--bg-color-dark,#777) 100%);border-radius:50%;box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;flex-shrink:0;font-weight:700;justify-content:center;text-shadow:0 1px 2px #0003;-webkit-user-select:none;user-select:none}.avatar-fallback-small{font-size:12px;height:32px;width:32px}.avatar-fallback-normal{font-size:16px;height:40px;width:40px}.avatar-fallback-large{font-size:24px;height:60px;width:60px}.avatar-letter{line-height:1;-webkit-user-select:none;user-select:none}.friend-avatar-container{cursor:pointer;flex-shrink:0;transition:transform .2s ease}.friend-avatar-container:hover{transform:scale(1.05)}.friend-avatar{border:2px solid #fffc;box-shadow:0 2px 4px #0000001a;transition:border-color .2s ease}.friend-avatar:hover{border-color:#007bff}.avatar-fallback.small,.friend-avatar.small{height:32px;width:32px}.avatar-fallback,.friend-avatar{height:40px;width:40px}.avatar-fallback.large,.friend-avatar.large{height:60px;width:60px}.friend-list-container{border-radius:8px}.friend-list-header{background:#fff;border-bottom:1px solid #e0e0e0;flex-shrink:0;padding:16px}.friend-list-header h2{align-items:center;display:flex;font-size:18px;font-weight:600;gap:8px;margin:0}.friend-list-content{flex:1 1;overflow-y:auto;padding:8px}.friend-list{display:flex;flex-direction:column;gap:4px}.friend-item{background:#fff;border:1px solid #0000;border-radius:8px;padding:12px;transition:all .2s ease}.friend-item:hover{background-color:#f8f9fa;border-color:#007bff;box-shadow:0 2px 4px #0000001a}.friend-item.active{background-color:#e3f2fd;border-color:#007bff}.friend-info{flex:1 1;margin-left:12px;min-width:0}.friend-info h4{color:#333;font-size:14px}.friend-email,.friend-info h4{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-email{color:#666;font-size:12px;margin:4px 0 0}.friend-actions{align-items:center;color:#007bff;display:flex;font-size:16px;padding:4px}.show-more-container{border-top:1px solid #e0e0e0;margin-top:8px;padding:12px;text-align:center}.btn{font-size:14px;gap:8px;padding:8px 16px}.btn-primary{background:#007bff}.btn-primary:hover{background:#0056b3}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#545b62}.btn-link{background:none;color:#007bff;text-decoration:underline}.btn-link:hover{color:#0056b3}.btn-sm{font-size:12px;padding:4px 8px}.no-data-container{color:#666;padding:40px 20px}.no-data-container svg{color:#ccc;font-size:48px;margin-bottom:16px}.no-data{font-size:16px;margin:16px 0}.error-container{padding:40px 20px;text-align:center}.error-container svg{color:#dc3545;font-size:48px;margin-bottom:16px}.error-message{font-size:16px;margin:16px 0}.loading-container{align-items:center;color:#666;display:flex;gap:12px;justify-content:center;padding:40px 20px}.loading-spinner-small{border:3px solid #f3f3f3;height:24px;width:24px}.chat-messages{background:#f8f9fa;max-height:400px;padding:16px}.message{align-items:flex-start;margin-bottom:16px;max-width:100%}.message-avatar{margin-top:4px}.message-bubble,.message-content{word-wrap:break-word}.message-bubble{line-height:1.4;padding:8px 12px}.message.sent .message-bubble{border-bottom-right-radius:4px}.message.received .message-bubble{background:#fff;border:1px solid #e0e0e0;border-bottom-left-radius:4px}.message-bubble p{word-break:break-word}.message-time{color:#666;margin-top:4px;text-align:center}.message.sent .message-time{text-align:right}.message.received .message-time{text-align:left}.no-messages svg{color:#ccc;font-size:48px;margin-bottom:16px}.no-messages p{font-size:16px;margin:16px 0}.chat-input-container{flex-shrink:0;padding:16px}.chat-input-fixed-bottom{bottom:0;position:-webkit-sticky;position:sticky;z-index:10}.chat-input-form{width:100%}.input-wrapper{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:24px;gap:8px;padding:4px}.message-input{background:none;font-size:14px;padding:8px 12px;resize:none}.send-button{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:background-color .2s ease;width:32px}.send-button,.send-button:disabled{background:#ccc}.send-button.active{background:#007bff}.send-button.active:hover{background:#0056b3}.chat-header-avatar{border:2px solid #fffc;height:32px;margin-right:8px;width:32px}.back-button{background:none;border:none;color:#666;padding:4px;transition:color .2s ease}.back-button:hover{color:#007bff}@media (max-width:768px){.friend-list-container{height:100vh}.friend-list-header{padding:12px 16px}.friend-list-header h2{font-size:16px}.friend-item{padding:10px 12px}.friend-info h4{font-size:13px}.friend-email{font-size:11px}.chat-messages{max-height:calc(100vh - 200px);padding:12px}.message-content{max-width:85%}.chat-input-container{padding:12px 16px}.no-data-container{padding:30px 16px}.no-data-container svg{font-size:36px}.no-data{font-size:14px}}@media (prefers-color-scheme:dark){.friend-list-container{background:#1a1a1a;color:#fff}.friend-list-header{background:#1a1a1a;border-bottom-color:#333}.friend-item{background:#2a2a2a;border-color:#333}.friend-item:hover{background:#3a3a3a}.friend-item.active{background:#1e3a8a}.chat-messages{background:#2a2a2a}.message.received .message-bubble{color:#fff}.input-wrapper,.message.received .message-bubble{background:#3a3a3a;border-color:#555}.message-input{color:#fff}.message-input::placeholder{color:#aaa}}.chat-messages::-webkit-scrollbar,.friend-list-content::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track,.friend-list-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb,.friend-list-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover,.friend-list-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.btn:focus,.friend-item:focus,.message-input:focus,.send-button:focus{outline:2px solid #007bff;outline-offset:2px}.friend-item:focus{outline-offset:-2px}@media (prefers-contrast:high){.friend-item{border:2px solid #000}.friend-item.active,.friend-item:hover{background:#fff;border-color:#007bff}.message-bubble{border:1px solid #000}.send-button.active{border:2px solid #000}}@media print{.chat-input-container,.friend-actions,.send-button{display:none}.chat-messages{background:#fff;box-shadow:none}.message-bubble{background:#fff!important;border:1px solid #ccc;color:#000!important}}.dashboard-footer{background-color:#2b3144;color:#f5f7fa;margin-top:auto;padding:3rem 2rem 1rem}.footer-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(4,1fr);margin:0 auto;max-width:1200px}.footer-section h3{color:#fff;font-size:1.2rem;font-weight:600;margin-bottom:1.5rem;position:relative}.footer-section h3:after{background-color:#4a6cf7;border-radius:2px;bottom:-.5rem;content:"";height:3px;left:0;position:absolute;width:40px}.footer-section p{font-size:.9rem;line-height:1.6;margin-bottom:1rem;opacity:.8}.social-links{display:flex;gap:1rem;margin-top:1.5rem}.social-links a{align-items:center;background-color:#ffffff1a;border-radius:50%;color:#fff;display:flex;height:40px;justify-content:center;transition:all .3s ease;width:40px}.social-links a:hover{background-color:#4a6cf7;color:#fff;transform:translateY(-3px)}.footer-section ul li{margin-bottom:.8rem}.footer-section ul li a{color:#f5f7fa;display:block;font-size:.9rem;opacity:.8;transition:all .2s ease}.footer-section ul li a:hover{color:#fff;opacity:1;padding-left:5px}.footer-section p i{color:#4895ef;margin-right:10px;text-align:center;width:20px}.footer-bottom{border-top:1px solid #ffffff1a;font-size:.9rem;margin:2rem auto 0;max-width:1200px;opacity:.7;padding-top:2rem;text-align:center}@media (max-width:1200px){.footer-content{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.footer-content{grid-template-columns:1fr}}.dashboard-container{display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100%}.dashboard-content{background-color:#f9fafc;padding:0;width:100%}.scrollable{-webkit-overflow-scrolling:touch;overflow-y:auto;scrollbar-color:#d1d5db #f1f1f1;scrollbar-width:thin}.scrollable::-webkit-scrollbar{width:8px}.scrollable::-webkit-scrollbar-track{background:#f1f1f1}.scrollable::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:4px}.dashboard-main{margin:0 auto;max-width:1200px;padding:0 15px 20px}.small-banner{border-radius:8px;height:170px;margin-bottom:15px;overflow:hidden;width:100%}.small-banner img{display:block;height:100%;object-fit:cover;width:100%}.dashboard-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto;margin-bottom:20px}.grid-item-lg{grid-column:1/-1}.dashboard-card{background:#fff;border:1px solid #eaeaea;border-radius:8px;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;height:100%;min-height:320px;overflow:hidden}.grid-item-lg .dashboard-card{min-height:auto}.card-header{border-bottom:1px solid #f0f0f0;justify-content:space-between;padding:15px 20px}.card-header,.card-header h2{align-items:center;display:flex}.card-header h2{color:#333;font-size:1.1rem;margin:0}.card-header h2 i{color:#4a6cf7;margin-right:8px}.view-all{align-items:center;color:#4a6cf7;display:flex;font-size:.85rem;text-decoration:none}.view-all i{font-size:.7rem;margin-left:5px}.card-body{flex-grow:1;padding:15px}.copyright{color:#666;font-size:14px;margin-top:20px;padding:15px 0;text-align:center}.loading{background-color:#ffffffe6;height:100vh;left:0;position:fixed;top:0;width:100%;z-index:9999}.loading-spinner{animation:spin 1s ease-in-out infinite;border:3px solid #4a6cf733;border-top-color:#4a6cf7;height:50px;width:50px}.loading span{color:#4a6cf7;font-size:1.1rem;margin-top:10px}.btn{align-items:center;border-radius:4px;box-shadow:0 1px 2px #0000000d;display:inline-flex;justify-content:center;line-height:1.5;padding:.5rem 1.25rem;text-align:center;transition:all .2s ease}.btn-primary:hover{background-color:#3a5bd7;box-shadow:0 4px 10px #4361ee4d;color:#fff}@media (max-width:1024px) and (min-width:769px){.dashboard-main{max-width:900px}.dashboard-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:auto auto auto}.grid-item-lg,.grid-item:nth-child(3){grid-column:1/-1}}@media (max-width:768px){.dashboard-main{max-width:100%;padding:0 10px 20px}.dashboard-grid{gap:12px;grid-template-columns:1fr;grid-template-rows:repeat(4,auto)}.grid-item-lg{grid-column:auto}.dashboard-card{min-height:280px}.dashboard-header{padding:.75rem 1rem}.search-container{width:200px}.card-header{padding:12px 15px}.card-body{padding:12px}}@media (max-width:480px){.dashboard-main{padding:0 8px 15px}.dashboard-grid{gap:10px}.card-header{align-items:flex-start;flex-direction:column;gap:5px;padding:10px 12px}.card-body{padding:10px}}.calendar-view{border:1px solid #eaeaea;border:1px solid var(--gray-200,#eaeaea);border-radius:var(--border-radius,8px);box-shadow:0 1px 3px #0000000d}.calendar-header{background-color:#4361ee}.calendar-header h3{color:#fff;font-size:1.2rem;font-weight:500;font-weight:var(--font-weight-medium,500)}.calendar-nav{align-items:center;gap:5px}.calendar-nav-btn{transition:.2s;transition:var(--transition-fast,.2s)}.today-btn{margin:0 5px}.calendar-weekdays{background-color:#f8f9fa;background-color:var(--gray-100,#f8f9fa);border-bottom:1px solid #eaeaea;border-bottom:1px solid var(--gray-200,#eaeaea)}.weekday{color:var(--gray-700,#495057);font-size:.9rem;font-weight:var(--font-weight-medium,500)}.calendar-days{grid-auto-rows:minmax(90px,auto)}.calendar-day{border-bottom:1px solid var(--gray-200,#eaeaea);border-right:1px solid var(--gray-200,#eaeaea);min-height:90px;padding:10px}.calendar-day:nth-child(7n){border-right:none}.calendar-day.empty{background-color:#f8f9fa;background-color:var(--gray-100,#f8f9fa)}.day-number{color:var(--gray-700,#495057);display:block;font-size:.95rem;font-weight:var(--font-weight-medium,500)}.calendar-day.today{background-color:#4361ee0d}.calendar-day.today .day-number{background-color:#4a6cf7;background-color:var(--primary-color,#4a6cf7)}.calendar-day.has-events{cursor:pointer}.user-events{margin-bottom:8px}.event-dot{background-color:#4361ee1a;display:block;transition:.2s;transition:var(--transition-fast,.2s)}.event-dot:hover{background-color:#4361ee33;box-shadow:0 2px 4px #4361ee4d;transform:translateY(-1px)}.event-dot:before{background-color:#4a6cf7;background-color:var(--primary-color,#4a6cf7)}.event-dot.user-event{background-color:#28a7451a}.event-dot.user-event:hover{background-color:#28a74533;box-shadow:0 2px 4px #28a7454d}.event-dot.user-event:before{background-color:#28a745}.event-dot.user-event.going{background-color:#ffb6c14d}.event-dot.user-event.going:hover{background-color:#ffb6c180;box-shadow:0 2px 4px #ff14934d}.event-dot.user-event.going:before{background-color:#ff69b4}.more-events{border-radius:3px;color:#4a6cf7;color:var(--primary-color,#4a6cf7);cursor:pointer;display:block;font-size:.75rem;margin-top:5px;padding:2px 4px;text-align:center;transition:.2s;transition:var(--transition-fast,.2s)}.more-events:hover{background-color:#4361ee1a;transform:translateY(-1px)}.friend-event-name{background-color:#ffc1071a;box-shadow:0 1px 2px #0000000d;font-weight:500;font-weight:var(--font-weight-medium,500);max-width:100%;transition:.2s;transition:var(--transition-fast,.2s)}.friend-event-name:before{background-color:#ffc107}.friend-event-name:hover{background-color:#ffc10733;border-color:#ffc10780;box-shadow:0 2px 4px #ffc10733;color:#e65100}.more-friends{background-color:#ffc1071a;border-radius:3px;color:#f57f17;cursor:pointer;display:block;font-size:.75rem;margin-top:3px;padding:2px 4px;text-align:center;transition:.2s;transition:var(--transition-fast,.2s)}.more-friends:hover{background-color:#ffc10733;transform:translateY(-1px)}.calendar-legend{background-color:#f8f9fa;background-color:var(--gray-100,#f8f9fa);border-top:1px solid var(--gray-200,#eaeaea);font-size:.85rem;gap:1.5rem;padding:.75rem 1rem}.legend-item{color:var(--gray-700,#495057);font-weight:var(--font-weight-medium,500)}.legend-item .event-dot{height:12px;min-width:12px;width:12px}.friend-event-sample{font-weight:var(--font-weight-medium,500)}.modal-overlay{animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.event-modal{animation:slideUp .3s ease;background:#fff;border:1px solid #eaeaea;border:1px solid var(--gray-200,#eaeaea);border-radius:8px;border-radius:var(--border-radius,8px);box-shadow:0 20px 40px #00000026;max-height:80vh;max-width:500px;overflow-y:auto;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{background-color:#f8f9fa;background-color:var(--gray-100,#f8f9fa);border-bottom:1px solid #eaeaea;border-bottom:1px solid var(--gray-200,#eaeaea);border-radius:8px 8px 0 0;border-radius:var(--border-radius,8px) var(--border-radius,8px) 0 0}.modal-header h3{color:var(--gray-700,#495057);font-weight:500;font-weight:var(--font-weight-medium,500)}.close-btn{color:var(--gray-600,#6c757d);transition:.2s;transition:var(--transition-fast,.2s)}.close-btn:hover{background:#6c757d1a}.close-btn:hover,.event-info p{color:#495057;color:var(--gray-700,#495057)}.event-info p{line-height:1.6;margin:.75rem 0}.event-info strong{color:#212529;color:var(--gray-900,#212529);font-weight:500;font-weight:var(--font-weight-medium,500)}.modal-actions{border-top:1px solid #eaeaea;border-top:1px solid var(--gray-200,#eaeaea);margin-top:1.5rem;padding-top:1rem;text-align:right}.btn{border:none;border-radius:6px;border-radius:var(--border-radius,6px);cursor:pointer;display:inline-block;font-size:.9rem;font-weight:500;font-weight:var(--font-weight-medium,500);padding:.75rem 1.5rem;text-decoration:none;transition:.2s;transition:var(--transition-fast,.2s)}.btn-primary{background-color:#4a6cf7;background-color:var(--primary-color,#4a6cf7);box-shadow:0 2px 4px #4a6cf733;color:#fff}.btn-primary:hover{background-color:#3c5ddb;box-shadow:0 4px 8px #4a6cf74d;transform:translateY(-1px)}.day-view-modal{animation:slideUp .3s ease;background:#fff;border:1px solid #eaeaea;border:1px solid var(--gray-200,#eaeaea);border-radius:8px;border-radius:var(--border-radius,8px);box-shadow:0 20px 40px #00000026;max-height:80vh;overflow-y:auto;width:90%}.no-events{color:var(--gray-600,#6c757d)}.day-events-list{padding:.5rem 0}.day-event-card{background:#fff;border:1px solid #eaeaea;border:1px solid var(--gray-200,#eaeaea);border-radius:var(--border-radius,8px);box-shadow:0 2px 4px #0000000d;overflow:hidden;position:relative;transition:all .2s ease}.day-event-card.user{background:linear-gradient(135deg,#28a74505,#28a7450d)}.day-event-card.user.going{background:linear-gradient(135deg,#ffb6c10d,#ff69b41a);border-left-color:#ff69b4}.day-event-card.friend{background:linear-gradient(135deg,#ffc10705,#ffc1070d)}.day-event-card:hover{transform:translateY(-1px)}.event-status-badge{background:var(--gray-200,#e9ecef);border-radius:12px;color:var(--gray-700,#495057);font-weight:500;font-weight:var(--font-weight-medium,500);padding:.25rem .75rem;position:absolute;right:1rem;top:1rem}.day-event-card.friend .event-status-badge{background:#fff3cd;color:#856404}.event-content{padding:1.5rem 5rem 1.5rem 1.5rem}.event-name-clickable{border-bottom:2px solid #0000;color:var(--gray-900,#212529);font-size:1.4rem;font-weight:700;line-height:1.3;margin:0 0 .75rem;transition:color .2s ease}.event-name-clickable:hover{border-bottom-color:#4a6cf7;border-bottom-color:var(--primary-color,#4a6cf7);color:#4a6cf7;color:var(--primary-color,#4a6cf7)}.user-status-compact{align-items:center;background:#28a7451a;border:1px solid #28a74533;border-radius:20px;display:inline-flex;font-size:.85rem;font-weight:500;font-weight:var(--font-weight-medium,500);gap:.5rem;margin-bottom:.75rem;padding:.5rem .75rem}.day-event-card.user.going .user-status-compact{background:#ffb6c133;border:1px solid #ff69b44d;color:#e91e63}.day-event-card.user .user-status-compact{color:#28a745}.user-icon{font-size:1rem}.status-text{font-size:.8rem}.friend-going{align-items:center;background:#ffc1071a;border:1px solid #ffc10733;border-radius:8px;display:flex;gap:.5rem;margin-bottom:1rem;padding:.75rem}.friend-going strong{color:#f57f17;font-weight:600}.friend-icon{font-size:1.1rem}.day-event-card.user .event-status-badge{background:#d4edda;color:#155724}.day-event-card.user.going .event-status-badge{background:#fce4ec;color:#ad1457}.user-icon{font-size:1.1rem}.event-meta{display:flex;flex-direction:column;gap:.5rem}.event-location-info{align-items:center;color:var(--gray-600,#6c757d);display:flex;font-size:.9rem;gap:.5rem}.day-event-item{display:none}.event-type-badge{background:#e9ecef;background:var(--gray-200,#e9ecef);border-radius:12px;color:#495057;color:var(--gray-700,#495057);font-size:.75rem;font-weight:500;font-weight:var(--font-weight-medium,500);padding:.25rem .5rem}.day-event-item.friend .event-type-badge{background:#fff3cd;color:#856404}.day-event-item.user .event-type-badge{background:#d4edda;color:#155724}.calendar-debug{background:#e9ecef;background:var(--gray-200,#e9ecef);border-top:1px solid #eaeaea;border-top:1px solid var(--gray-200,#eaeaea);color:#6c757d;color:var(--gray-600,#6c757d);font-size:.8rem;padding:.5rem 1rem;text-align:center}@media (max-width:768px){.calendar-day{min-height:70px;padding:8px}.friend-event-name{font-size:.7rem;padding:2px 4px}.calendar-legend{flex-direction:column;gap:.5rem;padding:.5rem}.calendar-header{padding:.75rem}.calendar-header h3{font-size:1rem}.calendar-nav-btn{font-size:.8rem;height:28px;width:28px}.today-btn{font-size:.8rem;padding:0 10px}.day-view-modal{margin:1rem;width:calc(100% - 2rem)}.modal-body,.modal-header{padding:1rem}.event-content{padding:1rem 4rem 1rem 1rem}.event-name-clickable{font-size:1.1rem}.friend-going,.user-going{font-size:.9rem;padding:.5rem}.event-status-badge{font-size:.7rem;padding:.2rem .5rem;right:.75rem;top:.75rem}}@media (max-width:480px){.calendar-day{min-height:60px;padding:6px}.day-number{font-size:.8rem;margin-bottom:6px}.friend-event-name{font-size:.65rem}.calendar-header{flex-direction:column;gap:.5rem;padding:.5rem;text-align:center}.weekday{font-size:.8rem;padding:8px 0}.event-dot{height:14px}}@media (max-width:768px){.dashboard-container.mobile-layout{padding-bottom:80px}.dashboard-header{background:#fff;box-shadow:0 2px 4px #0000001a;height:60px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-right{gap:.5rem}.profile-name{display:none}.compass-people-icon{display:inline-block;font-size:1.1rem}.mobile-content{margin-top:0 px;min-height:calc(100vh - 210px);padding:.5rem}.mobile-tab-content{display:flex;flex-direction:column;height:calc(100vh - 180px);overflow-y:auto;padding:25px 16px 10px;width:100%}.mobile-tab-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:0 0 8px 8px;box-shadow:0 1px 6px #667eea33;color:#fff;flex-shrink:0;margin:-16px -16px 16px;padding:10px 16px;position:-webkit-sticky;position:sticky;top:20px;z-index:20}.mobile-tab-header h3{align-items:center;color:#fff!important;display:flex;font-size:1rem;font-weight:600;gap:6px;margin:0}.mobile-tab-header i{font-size:.9rem;opacity:.9}.bottom-nav{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:linear-gradient(145deg,#fff,#f8fafc);border-top:1px solid #e2e8f0;bottom:0;box-shadow:0 -4px 20px #0000001a;display:flex;justify-content:space-around;left:0;padding:8px 16px 12px;position:fixed;right:0;z-index:1000}.bottom-nav.enhanced{animation:slideInUp .4s cubic-bezier(.4,0,.2,1)}.nav-item{align-items:center;background:none;border:none;border-radius:12px;color:#6b7280;cursor:pointer;display:flex;flex-direction:column;min-width:64px;padding:8px 12px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-item:hover{background:#667eea0d;transform:translateY(-2px)}.nav-item.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea66;color:#fff;transform:translateY(-3px)}.nav-icon-wrapper{align-items:center;display:flex;justify-content:center;margin-bottom:4px;position:relative}.nav-item i{font-size:1.2rem;transition:all .3s ease}.nav-item.active i{text-shadow:0 2px 4px #0003;transform:scale(1.1)}.nav-label{font-size:.75rem;font-weight:500;line-height:1;opacity:.8;text-align:center;transition:all .3s ease}.nav-item.active .nav-label{font-weight:600;opacity:1;text-shadow:0 1px 2px #0000001a}.active-indicator{background:#fff;border-radius:50%;box-shadow:0 0 8px #fff9;height:4px;left:50%;position:absolute;top:-2px;transform:translateX(-50%);width:4px}.chat-input-fixed-bottom{background:#fff;border:1px solid #e2e8f0;border-radius:24px;bottom:80px;box-shadow:0 4px 20px #00000026;left:16px;padding:8px;position:fixed!important;right:16px;z-index:999}.chat-input-fixed-bottom .input-wrapper{align-items:center;display:flex;gap:8px}.chat-input-fixed-bottom .message-input{background:#f8fafc;border:none;border-radius:18px;flex:1 1;font-size:1rem;outline:none;padding:12px 16px;transition:background-color .2s ease}.chat-input-fixed-bottom .message-input:focus{background:#fff;box-shadow:0 0 0 2px #667eea33}.chat-input-fixed-bottom .send-button{align-items:center;background:#e2e8f0;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;flex-shrink:0;height:44px;justify-content:center;transition:all .3s ease;width:44px}.chat-input-fixed-bottom .send-button.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #667eea66;color:#fff;transform:scale(1.05)}.chat-input-fixed-bottom .send-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.friend-list-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:0 0 12px 12px;box-shadow:0 2px 10px #667eea33;color:#fff!important;margin:-16px -16px 12px;padding:12px 16px;position:relative;z-index:10}.friend-list-header h2{align-items:center;color:#fff!important;display:flex;font-size:1.1rem;font-weight:600;gap:8px;margin:0}.friend-list-header .back-button{border-radius:6px;color:#fff!important;margin-right:8px;padding:6px;transition:background-color .2s ease}.friend-list-header .back-button:hover{background:#ffffff1a}.chat-header{display:none}.profile-menu{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 25px #00000026;min-width:220px;position:absolute;right:0;top:100%;z-index:200}.profile-menu .profile-header{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;gap:.75rem;padding:1rem}.profile-menu .profile-menu-image{border-radius:50%;height:48px;object-fit:cover;width:48px}.profile-menu .profile-user-info h3{color:#111827;font-size:1rem;margin:0 0 .25rem}.profile-menu .profile-user-info p{color:#6b7280;font-size:.875rem;margin:0}.profile-menu ul{list-style:none;margin:0;padding:0}.profile-menu li{align-items:center;border-bottom:1px solid #f3f4f6;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.875rem 1rem;transition:background-color .2s}.profile-menu li:last-child{border-bottom:none}.profile-menu li:hover{background:#f9fafb}.profile-menu li.logout-item{border-top:1px solid #f3f4f6;color:#dc2626}.profile-menu li.logout-item:hover{background:#fef2f2}.profile-menu li.language-item{justify-content:space-between}.profile-menu li.pending-request{color:#6b7280;font-style:italic}.language-select{background:#fff;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;margin-left:auto;min-width:80px;padding:.25rem .5rem}.mobile-layout .dashboard-main{display:none}.mobile-tab-content .pe-list{display:flex;flex:1 1;flex-direction:column;gap:1rem;overflow-y:auto;padding-right:8px}.mobile-tab-content .pe-item{background:#fff;border:1px solid #f3f4f6;border-radius:.75rem;box-shadow:0 2px 8px #0000001a;cursor:pointer;flex-shrink:0;padding:1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.mobile-tab-content .pe-item:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.mobile-tab-content .pe-item-grey{background:#f8fafc;opacity:.8}.mobile-tab-content .pe-item-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.mobile-tab-content .pe-item-title{color:#111827;flex:1 1;font-size:1.1rem;font-weight:600;line-height:1.4;margin:0}.mobile-tab-content .pe-title-grey{color:#6b7280}.mobile-tab-content .pe-button-group{display:flex;flex-shrink:0;gap:.5rem}.mobile-tab-content .pe-tag{border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;min-height:36px;padding:.5rem .75rem;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.mobile-tab-content .pe-tag:hover:not(.pe-tag-disabled){box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.mobile-tab-content .pe-tag-going{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.mobile-tab-content .pe-tag-interested-yellow{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.mobile-tab-content .pe-tag-cancel{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.mobile-tab-content .pe-tag-past{background:linear-gradient(135deg,#94a3b8,#64748b);color:#fff}.mobile-tab-content .pe-tag-cancelled{background:linear-gradient(135deg,#f87171,#ef4444);color:#fff}.mobile-tab-content .pe-tag-delete{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef44444d;color:#fff}.mobile-tab-content .pe-tag-delete:hover{box-shadow:0 4px 12px #ef444466;transform:translateY(-1px)}.mobile-tab-content .pe-tag-disabled{cursor:not-allowed;opacity:.6}.mobile-tab-content .pe-tag-updating{opacity:.7;pointer-events:none}.mobile-tab-content .pe-item-date{color:#6b7280;font-size:.9rem;margin-bottom:.5rem}.mobile-tab-content .pe-date-grey{color:#9ca3af}.mobile-tab-content .pe-item-location{align-items:center;color:#6b7280;display:flex;font-size:.85rem;gap:.25rem}.mobile-tab-content .pe-location-grey{color:#9ca3af}.mobile-tab-content .pe-no-data{color:#6b7280;padding:3rem 1rem;text-align:center}.mobile-tab-content .pe-no-data i{color:#d1d5db;font-size:3rem;margin-bottom:1rem}.mobile-tab-content .pe-no-data p{font-size:1rem;margin-bottom:1.5rem}.mobile-tab-content .pe-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.5rem;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.mobile-tab-content .pe-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.mobile-tab-content .friend-list-container{background:#fff;border-radius:.75rem;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;height:100%;overflow:hidden}.mobile-tab-content .friend-list-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:0 0 8px 8px;box-shadow:0 1px 6px #667eea33;color:#fff!important;flex-shrink:0;margin:-16px -16px 16px;padding:10px 16px;position:-webkit-sticky;position:sticky;top:20px;z-index:20}.mobile-tab-content .friend-list-header h2{align-items:center;color:#fff!important;display:flex;font-size:1rem;font-weight:600;gap:6px;margin:0}.mobile-tab-content .friend-list-content{flex:1 1;overflow-y:auto;padding:1rem}.mobile-tab-content .friend-item{align-items:center;border:1px solid #e2e8f0;border-radius:12px;display:flex;gap:12px;margin-bottom:8px;padding:12px 16px;transition:all .3s ease}.mobile-tab-content .friend-item:hover{background:#f8fafc;box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.mobile-tab-content .friend-item.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff}.mobile-tab-content .friend-avatar{border-radius:50%;height:40px;object-fit:cover;width:40px}.mobile-tab-content .friend-info{flex:1 1}.mobile-tab-content .friend-info h4{font-size:1rem;font-weight:500;margin:0}.mobile-tab-content .calendar-view{background:#fff;border-radius:.75rem;box-shadow:0 2px 8px #0000001a;display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:1rem}.mobile-tab-content .calendar-container{flex:1 1;overflow-y:auto}.mobile-tab-content .calendar-legend{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:1rem;padding:1rem}.mobile-tab-content .calendar-legend h4{color:#374151;font-size:.9rem;font-weight:600;margin:0 0 .75rem}.mobile-tab-content .legend-items{display:flex;flex-wrap:wrap;gap:1rem}.mobile-tab-content .legend-item{align-items:center;color:#6b7280;display:flex;font-size:.8rem;gap:.5rem}.mobile-tab-content .legend-dot{border-radius:50%;flex-shrink:0;height:12px;width:12px}.mobile-tab-content .legend-dot.interested{background:linear-gradient(135deg,#f59e0b,#d97706)}.mobile-tab-content .legend-dot.going{background:linear-gradient(135deg,#10b981,#059669)}.mobile-tab-content .legend-dot.friends{background:linear-gradient(135deg,#667eea,#764ba2)}.mobile-tab-content .legend-dot.public{background:linear-gradient(135deg,#6b7280,#4b5563)}.mobile-tab-content .loading-container{align-items:center;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:3rem 1rem}.mobile-tab-content .loading-spinner-small{animation:spin 1s linear infinite;border:2px solid #f3f4f6;border-radius:50%;border-top-color:#667eea;height:32px;margin-bottom:1rem;width:32px}.mobile-tab-content .loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f4f6;border-radius:50%;border-top-color:#667eea;height:40px;margin-bottom:1rem;width:40px}.mobile-tab-content .error-container{align-items:center;color:#ef4444;display:flex;flex-direction:column;justify-content:center;padding:3rem 1rem}.mobile-tab-content .error-message{margin:1rem 0;text-align:center}.mobile-tab-content .no-data-container{color:#6b7280;padding:3rem 1rem;text-align:center}.mobile-tab-content .no-data-container i{color:#d1d5db;font-size:3rem;margin-bottom:1rem}.mobile-tab-content .no-data{color:#6b7280;font-size:1rem;margin-bottom:1.5rem}.mobile-tab-content .btn-primary,.mobile-tab-content .btn-secondary{border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;min-height:44px;padding:.75rem 1rem;transition:all .3s ease}.mobile-tab-content .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea4d;color:#fff}.mobile-tab-content .btn-primary:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.mobile-tab-content .btn-secondary{background:#f3f4f6;color:#374151}.mobile-tab-content .btn-secondary:hover{background:#e5e7eb}.mobile-tab-content .btn-link{background:none;border:none;color:#667eea;cursor:pointer;padding:.5rem;text-decoration:underline}.mobile-tab-content .show-more-container{border-top:1px solid #e2e8f0;margin-top:1rem;padding:1rem;text-align:center}.mobile-tab-content .chat-messages{background:#fff;margin-bottom:100px;max-height:calc(100vh - 250px);min-height:calc(100vh - 250px);overflow-y:auto;padding:1rem}.mobile-tab-content .message{align-items:flex-start;display:flex;gap:8px;margin-bottom:1rem}.mobile-tab-content .message.sent{flex-direction:row-reverse}.mobile-tab-content .message-avatar{border-radius:50%;height:32px;object-fit:cover;width:32px}.mobile-tab-content .message-content{max-width:70%}.mobile-tab-content .message-bubble{background:#f1f5f9;border-radius:18px;margin-bottom:4px;padding:12px 16px}.mobile-tab-content .message.sent .message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.mobile-tab-content .message-time{color:#6b7280;font-size:.75rem;text-align:right}.mobile-tab-content .message.sent .message-time{text-align:left}.mobile-tab-content .no-messages{color:#6b7280;padding:3rem 1rem;text-align:center}.mobile-tab-content .no-messages i{color:#d1d5db;font-size:3rem;margin-bottom:1rem}}@keyframes slideInUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:480px){.mobile-tab-header{padding:10px 14px;top:20px}.mobile-tab-header h3{font-size:.95rem}.mobile-tab-header .back-button{font-size:.8rem!important;height:24px!important;min-width:28px!important;padding:4px 6px!important}.bottom-nav{padding:6px 12px 10px}.nav-item{min-width:60px;padding:6px 8px}.nav-label{font-size:.7rem}.chat-input-fixed-bottom{bottom:75px;left:12px;right:12px}.mobile-tab-content .pe-button-group{flex-direction:column;gap:.25rem}.mobile-tab-content .pe-tag{font-size:.8rem;padding:.4rem .6rem}.mobile-tab-content .chat-messages{max-height:calc(100vh - 220px);min-height:calc(100vh - 220px)}.mobile-content{margin-top:0 px;padding:.25rem}.mobile-tab-content{height:calc(100vh - 160px);padding:20px 12px 12px}.dashboard-container.mobile-layout{padding-bottom:75px}}@media (min-width:769px){.bottom-nav,.mobile-content{display:none}.compass-people-icon{font-size:1rem}.profile-menu{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 25px #0000001a;min-width:250px;position:absolute;right:0;top:100%;z-index:200}.profile-menu-item{align-items:center;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.875rem 1.25rem;transition:background-color .2s}.profile-menu-item:hover{background:#f9fafb}.language-item{justify-content:space-between}.language-select{background:#fff;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;margin-left:auto;min-width:100px;padding:.25rem .5rem}.logout-item{border-top:1px solid #f3f4f6;color:#dc2626}.logout-item:hover{background:#fef2f2}}.logo{color:#667eea!important}.tour-guide-button{border-radius:.375rem;padding:.5rem;position:relative;transition:background-color .2s}.tour-guide-button:hover{background:#f3f4f6}.home-button{align-items:center;border-radius:.375rem;cursor:pointer;display:flex;justify-content:center;padding:.5rem;position:relative;transition:background-color .2s}.home-button:hover{background:#f3f4f6}.compass-people-icon{display:inline-block;line-height:1}.tooltip-container{position:relative}.tooltip-container .tooltip{background:#000c;border-radius:6px;bottom:-35px;color:#fff;font-size:.75rem;left:50%;opacity:0;padding:6px 10px;pointer-events:none;position:absolute;transform:translateX(-50%);transition:all .3s ease;visibility:hidden;white-space:nowrap;z-index:1000}.tooltip-container .tooltip:before{border-bottom:4px solid #000c;border-left:4px solid #0000;border-right:4px solid #0000;content:"";left:50%;position:absolute;top:-4px;transform:translateX(-50%)}.tooltip-container:hover .tooltip{bottom:-40px;opacity:1;visibility:visible}@media (min-width:769px){.chat-input-container{padding:8px 12px}.chat-input-form .input-wrapper{min-height:40px}.message-input{min-height:36px;padding:8px 12px}.send-button{height:36px;width:36px}}.back-button{backdrop-filter:blur(10px)!important;-webkit-backdrop-filter:blur(10px)!important;background:linear-gradient(135deg,#fffffff2,#f8fafcf2)!important;border:2.5px solid #667eea!important;border-radius:50%!important;box-shadow:0 4px 15px #667eea40!important;color:#667eea!important;display:flex!important;font-size:1.4rem!important;font-weight:600!important;height:50px!important;margin:0 12px 0 0!important;min-height:50px!important;min-width:50px!important;padding:0!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;width:50px!important;z-index:15!important}.back-button:before{background:#0000;border-radius:50%;bottom:-10px;content:"";left:-10px;position:absolute;right:-10px;top:-10px;z-index:-1}.back-button:hover{background:linear-gradient(135deg,#667eea,#764ba2)!important;border-color:#667eea!important;box-shadow:0 6px 20px #667eea66!important;color:#fff!important;transform:translateY(-2px) scale(1.05)!important}.back-button:active{box-shadow:0 3px 12px #667eea4d!important;transform:translateY(0) scale(1.02)!important}.chat-header .back-button,.friend-list-header .back-button,.mobile-tab-header .back-button{background:#fff3!important;border:2px solid #fffc!important;color:#fff!important;height:44px!important;width:44px!important}.chat-header .back-button:hover,.friend-list-header .back-button:hover,.mobile-tab-header .back-button:hover{background:#ffffff4d!important;border-color:#fff!important;transform:translateY(-1px) scale(1.05)!important}.pe-item-header{gap:12px!important;justify-content:space-between!important;margin-bottom:8px!important;min-height:36px!important}.pe-item-header,.pe-item-title{align-items:flex-start!important;display:flex!important}.pe-item-title{flex:1 1!important;line-height:1.3!important;margin:0!important;padding-right:8px!important;padding-top:2px!important}.pe-button-group{align-items:flex-start!important;flex-shrink:0!important;margin-top:0!important;padding-top:0!important}.pe-tag{align-items:center!important;border:none!important;border-radius:16px!important;box-sizing:border-box!important;cursor:pointer!important;display:flex!important;font-size:12px!important;font-weight:500!important;justify-content:center!important;min-height:32px!important;min-width:60px!important;padding:6px 12px!important;transition:all .2s ease!important;white-space:nowrap!important}@media (max-width:768px){.mobile-tab-content .pe-item-header{align-items:flex-start!important;display:flex!important;gap:12px!important;justify-content:space-between!important;margin-bottom:12px!important;min-height:32px!important}.mobile-tab-content .pe-button-group{align-items:flex-start!important;display:flex!important;flex-shrink:0!important;flex-wrap:nowrap!important;gap:6px!important;justify-content:flex-end!important}.mobile-tab-content .pe-tag{border-radius:16px!important;font-size:11px!important;height:32px!important;min-height:32px!important;min-width:55px!important;padding:6px 10px!important}.mobile-tab-content .pe-item-title{flex:1 1!important;font-size:1rem!important;line-height:1.3!important;margin:0!important;padding-right:8px!important;padding-top:1px!important}}.dashboard-container{background-color:#f8fafc!important;min-height:100vh!important;overflow-x:hidden!important;position:relative!important}.dashboard-header{background:#fff!important;box-shadow:0 2px 4px #0000001a!important;height:70px!important;left:0!important;min-height:70px!important;position:-webkit-sticky!important;position:sticky!important;right:0!important;top:0!important;width:100%!important;z-index:100!important}.dashboard-content{margin-top:0!important;padding-top:0!important;position:relative!important;z-index:10!important}@media (max-width:768px){.mobile-content{margin-top:15px!important;max-height:calc(100vh - 155px)!important;min-height:calc(100vh - 155px)!important;overflow:hidden!important;padding:.5rem!important}.mobile-content,.mobile-tab-content{position:relative!important;z-index:10!important}.mobile-tab-content{-webkit-overflow-scrolling:touch!important;display:flex!important;flex-direction:column!important;height:calc(100vh - 175px)!important;max-height:calc(100vh - 175px)!important;overflow-x:hidden!important;overflow-y:auto!important;padding:25px 16px 20px!important;width:100%!important}.mobile-tab-header{background:linear-gradient(135deg,#667eea,#764ba2)!important;border-radius:0 0 12px 12px!important;box-shadow:0 2px 10px #667eea33!important;color:#fff!important;flex-shrink:0!important;margin:-16px -16px 20px!important;padding:12px 16px!important;position:-webkit-sticky!important;position:sticky!important;top:0!important;width:calc(100% + 32px)!important;z-index:25!important}.mobile-tab-header h3{align-items:center!important;color:#fff!important;display:flex!important;font-size:1.1rem!important;font-weight:600!important;gap:8px!important;margin:0!important}.bottom-nav{background:linear-gradient(145deg,#fff,#f8fafc)!important;border-top:1px solid #e2e8f0!important;bottom:0!important;box-shadow:0 -4px 20px #0000001a!important;height:80px!important;left:0!important;min-height:80px!important;position:fixed!important;right:0!important;width:100%!important;z-index:1000!important}.dashboard-container.mobile-layout{padding-bottom:80px!important}.friend-list-container{background:#fff!important;border-radius:12px!important;display:flex!important;flex-direction:column!important;height:100%!important;max-height:100%!important;overflow:hidden!important;position:relative!important;z-index:15!important}.friend-list-header{background:linear-gradient(135deg,#667eea,#764ba2)!important;border-radius:0 0 12px 12px!important;box-shadow:0 2px 8px #667eea33!important;color:#fff!important;flex-shrink:0!important;padding:12px 16px!important;position:-webkit-sticky!important;position:sticky!important;top:0!important;z-index:20!important}.friend-list-content{flex:1 1!important;overflow-y:auto!important;padding:16px!important;position:relative!important;z-index:15!important}.chat-input-fixed-bottom{background:#fff!important;border:1px solid #e2e8f0!important;border-radius:25px!important;bottom:85px!important;box-shadow:0 4px 20px #00000026!important;left:16px!important;padding:8px!important;position:fixed!important;right:16px!important;z-index:999!important}}.pe-tag-interested-yellow{background:linear-gradient(135deg,#f59e0b,#d97706)!important;box-shadow:0 2px 8px #f59e0b4d!important;color:#fff!important}.pe-tag-going{background:linear-gradient(135deg,#10b981,#059669)!important;box-shadow:0 2px 8px #10b9814d!important;color:#fff!important}.pe-tag-cancel{background:linear-gradient(135deg,#6b7280,#4b5563)!important;box-shadow:0 2px 8px #6b72804d!important;color:#fff!important}.pe-tag-delete{background:linear-gradient(135deg,#ef4444,#dc2626)!important;box-shadow:0 2px 8px #ef44444d!important;color:#fff!important}.pe-tag-past{background:linear-gradient(135deg,#94a3b8,#64748b)!important;box-shadow:0 2px 8px #94a3b84d!important;color:#fff!important}.pe-tag-cancelled{background:linear-gradient(135deg,#f87171,#ef4444)!important;box-shadow:0 2px 8px #f871714d!important;color:#fff!important}.pe-tag:hover:not(.pe-tag-disabled){box-shadow:0 4px 12px #0003!important;transform:translateY(-1px)!important}.pe-tag-disabled{cursor:not-allowed!important;opacity:.6!important;transform:none!important}.pe-tag-updating{opacity:.7!important;pointer-events:none!important}.back-button,button.back-button{background:linear-gradient(135deg,#fffffff2,#f8fafcf2)!important;border:2.5px solid #667eea!important;border-radius:50%!important;color:#667eea!important;cursor:pointer!important;font-size:1.4rem!important;height:50px!important;justify-content:center!important;margin-right:12px!important;width:50px!important}.back-button,.pe-button-group,button.back-button{align-items:center!important;display:flex!important}.pe-button-group{flex-direction:row!important;flex-wrap:nowrap!important;gap:8px!important;justify-content:flex-end!important}.pe-tag{height:32px!important;line-height:1!important;vertical-align:top!important}@media (max-width:768px){.mobile-tab-content{height:calc(100vh - 175px)!important;overflow-y:auto!important}.mobile-tab-header{z-index:25!important}.dashboard-header,.mobile-tab-header{position:-webkit-sticky!important;position:sticky!important;top:0!important}.dashboard-header{z-index:100!important}.dashboard-content{padding-top:0!important}.dashboard-content,.mobile-content{margin-top:0!important;position:relative!important;z-index:1!important}.mobile-content{max-height:calc(100vh - 160px)!important;min-height:calc(100vh - 160px)!important;padding:.5rem!important}.mobile-tab-content{display:flex!important;flex-direction:column!important;height:calc(100vh - 180px)!important;max-height:calc(100vh - 180px)!important;overflow-y:auto!important;padding:10px 16px 16px!important;position:relative!important;width:100%!important;z-index:1!important}.dashboard-header{background:#fff!important;box-shadow:0 2px 4px #0000001a!important;height:70px!important;left:0!important;position:fixed!important;right:0!important;top:0!important;width:100vw!important;z-index:1000!important}.mobile-tab-content .friend-list-container{height:calc(100vh - 260px)!important;margin-top:0!important;max-height:calc(100vh - 260px)!important}.mobile-tab-content .friend-list-header{border-radius:12px 12px 0 0!important;margin:0!important;position:relative!important;top:0!important;z-index:10!important}.mobile-tab-content .friend-list-content{height:calc(100% - 50px)!important;overflow-y:auto!important;padding:16px!important}}.back-button{align-items:center!important;display:inline-flex!important;justify-content:center!important;position:relative!important}.back-button:after{content:"‹"!important;font-size:2rem!important;font-weight:700!important;left:50%!important;line-height:1!important;position:absolute!important;top:50%!important;transform:translate(-50%,-50%)!important;z-index:10!important}.back-button:after,.back-button:empty:before{color:inherit!important;display:block!important}.back-button:empty:before{content:"◀"!important;font-size:1.2rem!important}.back-button *{display:none!important}.chat-header .back-button:after,.friend-list-header .back-button:after,.mobile-tab-header .back-button:after{color:#fff!important;font-size:1.8rem!important}.back-button{cursor:pointer!important;pointer-events:all!important;user-select:none!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important}@media (max-width:768px){.bottom-nav{background:linear-gradient(145deg,#fff,#f8fafc)!important;border-top:1px solid #e2e8f0!important;bottom:0!important;box-shadow:0 -4px 20px #0000001a!important;height:80px!important;left:0!important;position:fixed!important;right:0!important;width:100vw!important;z-index:999!important}.dashboard-container.mobile-layout{box-sizing:border-box!important;min-height:100vh!important;padding-bottom:80px!important;padding-top:70px!important}}*{box-sizing:border-box!important;outline:none!important}.bottom-nav,.dashboard-container,.dashboard-content,.dashboard-header,.friend-list-container,.friend-list-content,.friend-list-header,.mobile-content,.mobile-tab-content,.mobile-tab-header,.nav-item,.pe-button-group,.pe-item,.pe-item-header{border:none!important;outline:none!important}@media (max-width:768px){.mobile-tab-content .pe-button-group{flex-shrink:0!important;flex-wrap:nowrap!important;gap:8px!important;height:auto!important;justify-content:flex-end!important;margin:0!important;padding:0!important;width:auto!important}.mobile-tab-content .pe-button-group,.mobile-tab-content .pe-item-header{align-items:center!important;display:flex!important;flex-direction:row!important}.mobile-tab-content .pe-item-header{gap:12px!important;justify-content:space-between!important;margin-bottom:12px!important;min-height:36px!important;width:100%!important}.mobile-tab-content .pe-item-title{display:block!important;flex:1 1!important;font-size:1rem!important;line-height:1.3!important;margin:0!important;padding:0!important;text-align:left!important}.mobile-tab-content .pe-tag{align-items:center!important;border-radius:16px!important;display:inline-flex!important;flex-shrink:0!important;font-size:12px!important;height:32px!important;justify-content:center!important;margin:0!important;min-height:32px!important;min-width:60px!important;padding:6px 12px!important;white-space:nowrap!important}}@media (max-width:480px){.mobile-tab-content .pe-button-group{gap:6px!important}.mobile-tab-content .pe-tag{font-size:11px!important;height:30px!important;min-height:30px!important;min-width:55px!important;padding:5px 10px!important}}.notification-container{display:inline-block;position:relative}.notification-icon{align-items:center;background:#f1f5f9;border-radius:50%;color:#475569;cursor:pointer;display:flex;height:40px;justify-content:center;position:relative;transition:.2s;width:40px}.notification-icon:hover{background:#e2e8f0;color:#334155}.notification-icon i{font-size:18px}.notification-badge{background:#ef4444;font-size:11px;font-weight:600;height:18px;min-width:18px;right:-2px;top:-2px}.notification-dropdown{animation:dropdownFade .2s ease;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 10px 40px #00000026;max-height:500px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:360px;z-index:1000}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.notification-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:16px 20px}.notification-header h3{color:#1e293b}.notification-loading{color:#64748b;font-size:12px}.notification-content{max-height:400px;overflow-y:auto}.notification-item{border-bottom:1px solid #f1f5f9;padding:14px 20px}.notification-item:last-child{border-bottom:none}.friend-request{grid-column-gap:12px;align-items:center;column-gap:12px;display:grid;grid-template-columns:64px 1fr}.avatar-column{display:flex;justify-content:center}.avatar-img{border:2px solid #e2e8f0;border-radius:50%;height:56px;object-fit:cover;width:56px}.detail-column{min-width:0}.notification-message{color:#1e293b;font-size:14px;line-height:1.3;margin-bottom:4px}.notification-time{color:#64748b;font-size:12px;margin-bottom:8px}.notification-actions button{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px;transition:.15s}.btn-accept{background:#10b981}.btn-accept:hover{background:#059669}.btn-decline{background:#6b7280}.btn-decline:hover{background:#4b5563}.notification-processing{align-items:center;color:#64748b;display:flex;gap:6px}.notification-status .status-tag{border-radius:4px;font-size:11px;font-weight:600;padding:4px 8px;text-transform:uppercase}.status-tag.accepted{background:#dcfce7;color:#166534}.status-tag.declined{background:#fef2f2;color:#991b1b}.notification-empty{color:#64748b;padding:40px 20px;text-align:center}.notification-empty i{font-size:32px;margin-bottom:12px;opacity:.5}.notification-content::-webkit-scrollbar{width:6px}.notification-content::-webkit-scrollbar-track{background:#f1f5f9}.notification-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.notification-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width:480px){.notification-dropdown{width:300px}}.fa-regular,.fa-solid{font-family:Font Awesome\ 5 Free,FontAwesome!important;font-weight:900!important}.notification-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:12px 16px}.notification-header h3{font-size:16px;font-weight:600;margin:0}.refresh-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:4px;transition:background-color .2s}.refresh-btn:hover{background-color:#f0f0f0}.notification-status{margin-top:8px}.status-tag{border:1px solid;border-radius:16px;display:inline-block;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase;transition:all .2s ease}.status-tag.accepted{background-color:#d4edda;border-color:#c3e6cb;color:#155724}.status-tag.declined{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24}.status-tag.pending{background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.status-tag.faded{background-color:#f5f5f5;border-color:#ddd;color:#999;opacity:.6}.notification-item.old-declined{background-color:#fafafa;border-left:3px solid #ddd;margin-bottom:8px;opacity:.8}.request-indicator{color:#666;font-size:11px;font-weight:400;margin-left:5px}.notification-info{margin-top:4px}.notification-info small{color:#888;font-size:11px;font-style:italic}.notification-item.recent-response .status-tag{animation:statusPulse .5s ease-in-out}@keyframes statusPulse{0%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.notification-actions{display:flex;gap:8px;margin-top:8px}.btn-accept,.btn-decline{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s ease}.btn-accept{background-color:#28a745;color:#fff}.btn-accept:hover{background-color:#218838;transform:translateY(-1px)}.btn-decline{background-color:#dc3545;color:#fff}.btn-decline:hover{background-color:#c82333;transform:translateY(-1px)}.notification-processing{color:#6c757d;font-size:12px;font-style:italic;margin-top:8px}.notification-processing i{color:#007bff;margin-right:5px}.notification-item+.notification-item.old-declined{border-top:1px solid #eee;padding-top:12px}.notification-item:not(.old-declined){background-color:#fff;border-left:3px solid #007bff}.notification-badge{background-color:#dc3545;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;color:#fff;font-size:12px;font-weight:700;height:20px;position:absolute;right:-8px;top:-8px;width:20px}.notification-badge,.tour-guide-button{align-items:center;display:flex;justify-content:center}.tour-guide-button{background-color:#f0f8ff;border-radius:50%;cursor:pointer;height:40px;margin-right:15px;transition:all .3s ease;width:40px}.tour-guide-button:hover{background-color:#e6f3ff;transform:translateY(-2px)}.tour-guide-button .fas{color:#1976d2;font-size:16px}.tour-guide-button .tour-icon{font-size:18px;margin-left:2px}.dashboard-card .card-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px 12px 0 0;box-shadow:0 4px 15px #667eea33;color:#fff;overflow:hidden;padding:20px;position:relative}.dashboard-card .card-header:before{animation:shimmer 3s ease-in-out infinite;background:linear-gradient(45deg,#ffffff1a,#0000 50%,#ffffff1a);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.dashboard-card .card-header h2{font-size:1.1rem;font-weight:600;margin:0;position:relative;text-shadow:0 2px 4px #0003;z-index:1}.dashboard-card .card-header h2 i{font-size:1rem;margin-right:8px}.dashboard-card .card-body{max-height:400px;overflow-y:auto;padding:0}.dashboard-card .card-body::-webkit-scrollbar{width:6px}.dashboard-card .card-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.dashboard-card .card-body::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:3px}.dashboard-card .card-body::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}.pe-list{display:flex;flex-direction:column;gap:12px;padding:16px}.pe-item{background:#fff;border:1px solid #e1e5e9;border-radius:8px;box-shadow:0 1px 3px #0000000d;cursor:pointer;padding:16px;transition:all .2s ease}.pe-item:hover{border-color:#4a6cf7;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.pe-item-grey{background:#f8f9fa;border-color:#dee2e6;opacity:.75}.pe-item-grey:hover{border-color:#dee2e6;box-shadow:0 1px 3px #0000000d;transform:none}.pe-item-cancelled{background:#f8f9fa}.pe-date-cancelled,.pe-item-cancelled .pe-item-date,.pe-item-cancelled .pe-item-location,.pe-item-cancelled .pe-item-title,.pe-location-cancelled,.pe-title-cancelled{color:#9e9e9e!important}.pe-item-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px}.pe-item-title{color:#2c3e50;flex:1 1;font-size:1rem;font-weight:600;line-height:1.3;margin:0}.pe-title-grey{color:#9e9e9e}.pe-item-date{align-items:center;color:#6c757d;display:flex;font-size:.875rem;gap:4px;margin-top:4px}.pe-date-grey{color:#9e9e9e}.pe-item-location{align-items:center;color:#6c757d;display:flex;font-size:.8rem;gap:4px;margin-top:4px}.pe-location-grey{color:#9e9e9e}.pe-item-location i{font-size:.75rem;width:12px}.pe-button-group{align-items:center;display:flex;flex-shrink:0;gap:6px}.pe-tag{border:none;border-radius:16px;cursor:pointer;font-size:.75rem;font-weight:500;min-width:60px;overflow:hidden;padding:6px 12px;position:relative;text-align:center;transition:all .2s ease;white-space:nowrap}.pe-tag:focus{box-shadow:0 0 0 3px #4a6cf733;outline:none}.pe-tag-cancel{background:#ec4899;box-shadow:0 2px 4px #ec489933;color:#fff}.pe-tag-cancel:hover:not(.pe-tag-disabled){background:#db2777;box-shadow:0 4px 8px #db27774d;transform:scale(1.05)}.pe-tag-interested{background:#ffa726;box-shadow:0 2px 4px #ffa72633;color:#fff}.pe-tag-interested:hover:not(.pe-tag-disabled){background:#ff9800;box-shadow:0 4px 8px #ff98004d;transform:scale(1.05)}.pe-tag-interested-yellow{background:#f59e0b;box-shadow:0 2px 4px #f59e0b33;color:#fff}.pe-tag-interested-yellow:hover:not(.pe-tag-disabled){background:#d97706;box-shadow:0 4px 8px #d977064d;transform:scale(1.05)}.pe-tag-going{background:#4caf50;box-shadow:0 2px 4px #4caf5033;color:#fff}.pe-tag-going:hover:not(.pe-tag-disabled){background:#45a049;box-shadow:0 4px 8px #45a0494d;transform:scale(1.05)}.pe-tag-cancelled{background:#9ca3af}.pe-tag-cancelled,.pe-tag-past{color:#fff;cursor:not-allowed;opacity:.8}.pe-tag-past{background:#9e9e9e}.pe-tag-disabled{cursor:not-allowed;opacity:.6;pointer-events:none}.pe-tag-disabled:hover{background:#9e9e9e;box-shadow:none;transform:none}.pe-tag-updating{animation:pulse 1s infinite;pointer-events:none}.pe-tag:after{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.pe-tag:active:after{height:300px;width:300px}.pe-no-data{align-items:center;background:#fafbfc;border:2px dashed #dee2e6;border-radius:8px;color:#6c757d;display:flex;flex-direction:column;justify-content:center;min-height:250px;padding:40px 20px;text-align:center}.pe-no-data i{animation:gentle-bounce 2s ease-in-out infinite;color:#dee2e6;display:block;font-size:3rem;margin-bottom:16px}@keyframes gentle-bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.pe-no-data p{color:#6c757d;font-size:1rem;line-height:1.4;margin:0 0 20px}.pe-btn{background:#4a6cf7;border:none;border-radius:6px;box-shadow:0 2px 4px #4a6cf733;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:12px 24px;transition:all .2s ease}.pe-btn:hover{background:#3a5bd7;box-shadow:0 4px 8px #4a6cf74d;transform:translateY(-1px)}.pe-btn:active{box-shadow:0 2px 4px #4a6cf733;transform:translateY(0)}.event-card{background-color:#fff;border:1px solid #eaeaea;border-radius:8px;box-shadow:0 2px 4px #0000000d;cursor:pointer;height:100%;overflow:hidden;transition:all .3s ease}.event-card:hover{box-shadow:0 10px 20px #0000001a;transform:translateY(-5px)}.event-image{height:220px;overflow:hidden;position:relative}.event-image img{height:100%;object-fit:cover;transition:transform .5s ease;width:100%}.event-card:hover .event-image img{transform:scale(1.1)}.save-button{align-items:center;background-color:#ffffffe6;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:10px;top:10px;transition:all .3s ease;width:36px;z-index:1}.save-button:hover{background-color:#fff;box-shadow:0 3px 8px #0000001a;transform:scale(1.1)}.save-button.saved-interested{color:#ffa726}.save-button.saved-going{color:#4caf50}.event-info{padding:1.25rem}.event-info h3{color:#343a40;font-size:1.1rem;line-height:1.4;margin-bottom:.75rem}.event-date,.event-location{align-items:center;color:#6c757d;display:flex;font-size:.85rem;margin-bottom:.5rem}.event-date i,.event-location i{color:#4a6cf7;font-size:.9rem;margin-right:8px;width:16px}.event-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#6c757d;display:-webkit-box;font-size:.85rem;line-height:1.5;margin-top:.75rem;overflow:hidden}.saved-events-list{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:1fr}.no-data-container{align-items:center;color:#6c757d;display:flex;flex-direction:column;height:100%;justify-content:center;min-height:350px;padding:4rem 1.5rem;text-align:center}.no-data-container i{color:#ced4da;display:block;font-size:4rem;margin-bottom:1.5rem}.no-data{color:#6c757d;font-size:1.1rem;margin-bottom:1.25rem}.no-data-container .btn{font-size:.9rem;padding:.5rem 1.25rem}.pe-item.loading{opacity:.7;pointer-events:none}.pe-item.loading:after{align-items:center;background:#fffc;bottom:0;content:"";display:flex;justify-content:center;left:0;position:absolute;right:0;top:0}@media (max-width:768px){.pe-item{padding:12px}.pe-item-header{align-items:flex-start;flex-direction:column;gap:8px}.pe-button-group{align-self:flex-start;gap:4px}.pe-tag{font-size:.7rem;min-width:55px;padding:4px 10px}.pe-item-title{font-size:.95rem}.pe-item-date,.pe-item-location{font-size:.8rem}.pe-no-data{min-height:200px;padding:30px 15px}.pe-no-data i{font-size:2.5rem;margin-bottom:12px}.pe-no-data p{font-size:.9rem}}@media (max-width:480px){.pe-item{padding:10px}.pe-button-group{flex-wrap:wrap;gap:3px}.pe-tag{font-size:.65rem;min-width:50px;padding:3px 8px}.pe-item-title{font-size:.9rem;line-height:1.2}.pe-item-date,.pe-item-location{font-size:.75rem}.pe-no-data{min-height:180px;padding:20px 10px}}@media (prefers-color-scheme:dark){.pe-item{background:#2d3748;border-color:#4a5568}.pe-item,.pe-item-title{color:#f7fafc}.pe-title-grey{color:#a0aec0}.pe-item-date,.pe-item-location{color:#cbd5e0}.pe-date-grey,.pe-location-grey{color:#a0aec0}.pe-item-grey{background:#1a202c;border-color:#2d3748}.pe-no-data{background:#2d3748;border-color:#4a5568;color:#cbd5e0}}.calendar-view{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;width:100%}.calendar-header{align-items:center;background:#4361ee;color:#fff;display:flex;justify-content:space-between;padding:1rem}.calendar-header h3{font-weight:600;margin:0}.calendar-nav{display:flex;gap:.5rem}.calendar-nav-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:30px;justify-content:center;transition:all .2s;width:30px}.calendar-nav-btn:hover{background:#ffffff4d}.today-btn{border-radius:15px;font-size:.85rem;padding:0 12px;width:auto}.calendar-weekdays{background:#f8f9fa;display:grid;grid-template-columns:repeat(7,1fr)}.weekday{color:#495057;font-weight:500;padding:12px 0;text-align:center}.calendar-days{display:grid;grid-auto-rows:minmax(110px,auto);grid-template-columns:repeat(7,1fr)}.calendar-day{border-bottom:1px solid #eaeaea;border-right:1px solid #eaeaea;cursor:pointer;min-height:110px;padding:12px;position:relative;transition:background-color .2s}.calendar-day:hover{background:#f8f9fa}.calendar-day.today{background:#4361ee0d}.calendar-day.today .day-number{align-items:center;background:#4a6cf7;border-radius:50%;color:#fff;display:flex;height:30px;justify-content:center;width:30px}.day-number{color:#495057;font-weight:500;margin-bottom:10px}.event-dots{display:flex;flex-direction:column;gap:5px}.event-dot{background:#4361ee1a;border-radius:3px;cursor:pointer;height:18px;position:relative;width:100%}.event-dot:before{background:#4a6cf7;border-radius:3px 0 0 3px;bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.event-dot.user-event{background:#28a7451a}.event-dot.user-event:before{background:#28a745}.event-dot.user-event.going{background:#d63df41f}.event-dot.user-event.going:before{background:#d63df4}.friends-events{display:flex;flex-direction:column;gap:3px;margin-top:8px}.friend-event-name{background:#ffc1071a;border:1px solid #ffc1074d;border-radius:3px;color:#f57f17;cursor:pointer;font-size:.75rem;overflow:hidden;padding:3px 6px;position:relative;text-overflow:ellipsis;transition:all .2s;white-space:nowrap}.friend-event-name:before{background:#ffc107;border-radius:3px 0 0 3px;bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.friend-event-name:hover{background:#ffc10733;transform:translateY(-1px)}.calendar-legend{background-color:#fafafa;border-top:1px solid #eaeaea;display:flex;font-size:.75rem;gap:1rem;justify-content:center;padding:.5rem 1rem}.legend-item{color:#6c757d;font-weight:500;gap:.3rem}.legend-item .event-dot{border-radius:2px;height:8px;min-width:8px;position:relative;width:8px}.legend-item .event-dot:before{width:2px}.friend-event-sample{background-color:#ffc1071a;border-radius:2px;font-size:.65rem;font-weight:500;padding:1px 4px}.friend-event-sample:before{background-color:#ffc107;border-radius:2px 0 0 2px;width:2px}.legend-item{color:#495057;gap:.5rem}.friend-event-sample{background:#ffc1071a;border:1px solid #ffc1074d;border-radius:3px;color:#f57f17;font-size:.75rem;padding:2px 6px;position:relative}.friend-event-sample:before{background:#ffc107;border-radius:3px 0 0 3px;bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.modal-overlay{background:#0009}.day-view-modal,.event-modal{background:#fff;border-radius:8px;box-shadow:0 20px 40px #00000026;max-height:80vh;max-width:500px;overflow-y:auto;width:90%}.day-view-modal{max-width:600px}.modal-header{background:#f8f9fa;border-bottom:1px solid #e9ecef;padding:1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:5}.modal-header h3{color:#495057;margin:0}.close-btn{border-radius:50%;color:#6c757d;font-size:1.5rem;height:32px;width:32px}.modal-body{padding:1.5rem}.no-events{color:#6c757d;padding:2rem;text-align:center}.day-events-list{display:flex;flex-direction:column;gap:1rem}.day-event-card{border-left:4px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:1rem;padding:1rem;transition:all .2s}.day-event-card.user{background:#28a7450d;border-left-color:#28a745}.day-event-card.user.going{background:#d63df41a;border-left-color:#d63df4}.day-event-card.friend{background:#ffc1070d;border-left-color:#ffc107}.day-event-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.event-status-badge{align-self:flex-start;background:#e9ecef;border-radius:6px;color:#495057;font-size:.75rem;padding:4px 8px}.event-content{flex:1 1;min-width:0}.event-name-clickable{color:#212529;cursor:pointer;font-size:1rem;font-weight:600;margin:0 0 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-going,.user-status-compact{color:#495057;font-size:.85rem;margin-bottom:4px}.event-meta{font-size:.8rem}.event-location-info{color:#6c757d}@media (max-width:768px){.calendar-day{min-height:70px;padding:8px}.calendar-legend{flex-direction:row;flex-wrap:wrap;gap:.75rem;justify-content:center;padding:.4rem .5rem}.day-view-modal{margin:1rem;width:calc(100% - 2rem)}.day-event-card{align-items:flex-start;flex-direction:column;gap:.5rem}}.friend-list-container{background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000000a;display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.chat-header,.friend-list-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px 12px 0 0;box-shadow:0 4px 15px #667eea33;flex:0 0 auto;overflow:hidden;padding:20px 22px;position:relative}.chat-header h2,.chat-header-details h3,.friend-list-header h2{align-items:center;color:#000;display:flex;font-size:1.1rem;font-weight:600;gap:8px;letter-spacing:.2px;margin:0}.chat-header:before,.friend-list-header:before{animation:shimmer 5s linear infinite;background:linear-gradient(60deg,#ffffff2e 15%,#0000 45%,#ffffff2e 85%);content:"";inset:0;mix-blend-mode:overlay;position:absolute}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.friend-list-content{display:flex;flex:1 1 auto;flex-direction:column;min-height:0;overflow:hidden}.friend-list-content .friend-list,.friend-list-content>.error-container,.friend-list-content>.loading-container,.friend-list-content>.no-data-container{flex:1 1 auto;overflow-y:auto;padding:8px 0}.friend-list{padding:0}.friend-list-content .friend-list::-webkit-scrollbar,.friend-list-content>.error-container::-webkit-scrollbar,.friend-list-content>.loading-container::-webkit-scrollbar,.friend-list-content>.no-data-container::-webkit-scrollbar{width:6px}.friend-list-content .friend-list::-webkit-scrollbar-thumb,.friend-list-content>.error-container::-webkit-scrollbar-thumb,.friend-list-content>.loading-container::-webkit-scrollbar-thumb,.friend-list-content>.no-data-container::-webkit-scrollbar-thumb{background:linear-gradient(#667eea,#764ba2);border-radius:3px}.friend-item{align-items:center;border-radius:10px;cursor:pointer;display:flex;gap:14px;margin:6px 14px;padding:10px 14px;transition:background .25s,box-shadow .25s,transform .25s}.friend-item:hover{background:#f5f7ff;box-shadow:0 4px 10px #667eea26;transform:translateY(-1px)}.friend-item.active{background:#eef2ff;box-shadow:inset 0 0 0 2px #667eea}.friend-avatar{background:#edf0f7;border-radius:50%;flex-shrink:0;height:44px;object-fit:cover;width:44px}.friend-info h4{color:#2c3e50;font-size:.9rem;font-weight:600;margin:0}.friend-actions svg{color:#9aa0aa;font-size:1rem}.friend-item.active .friend-actions svg,.friend-item:hover .friend-actions svg{color:#667eea}.chat-container{display:flex;flex-direction:column;height:100%;min-height:0}.chat-header-info{align-items:center;display:flex;gap:10px}.chat-header-avatar{border-radius:50%;display:none!important;height:36px;object-fit:cover;width:36px}.chat-header-details h3{color:#000;font-size:.95rem;font-weight:700}.chat-messages{display:flex;flex:1 1 auto;flex-direction:column;gap:12px;min-height:0;padding:14px 18px}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}.no-messages{align-items:center;color:#9aa0aa;display:flex;flex-direction:column;gap:10px;margin:auto}.no-messages i{font-size:2rem;margin-bottom:10px}.message{align-items:flex-end;display:flex;gap:8px}.message.sent{flex-direction:row-reverse}.message-avatar{border-radius:50%;height:24px;object-fit:cover;width:24px}.message-content{max-width:70%}.message-bubble{border-radius:16px;font-size:.85rem;line-height:1.1;padding:6px 10px}.message-bubble p{margin:0}.message.sent .message-bubble{background:#007bff;color:#fff}.message.received .message-bubble{background:#f3f4f6;color:#333}.message-time{color:#9ca3af;font-size:.65rem;margin-top:2px;text-align:right}.chat-input-container{background:#fff;border-top:1px solid #e0e0e0;flex:0 0 auto;padding:8px 16px}.input-wrapper{background:#f3f4f6;border-radius:18px;display:flex;width:100%}.message-input{flex:1 1;font-size:.88rem;line-height:1.2;outline:none}.message-input,.send-button{background:#0000;border:none;padding:6px 13px}.send-button{color:#9aa0aa;cursor:pointer;font-size:1.05rem;transition:color .2s}.send-button.active{color:#007bff}.send-button:disabled{cursor:not-allowed;opacity:.5}.icon-spin{animation:spin 1s linear infinite}.friend-list-bottom-nav{background:#fff;border-top:1px solid #e8e8e8;display:flex;flex:0 0 44px}.nav-button{background:none;border:none;color:#9aa0aa;flex:1 1;font-size:1.1rem;padding:8px 0;position:relative;transition:color .25s}.nav-button svg{display:block;margin:0 auto}.nav-button.active,.nav-button:hover{color:#667eea}.nav-button.active:after{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px 2px 0 0;bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);width:32px}.nav-button span{-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;width:1px}.error-container,.loading-container,.no-data-container{align-items:center;color:#9aa0aa;display:flex;flex-direction:column;gap:10px;padding:40px 20px;text-align:center}.error-container{color:#dc3545}.loading-spinner-small{animation:spin 1s linear infinite;border:2px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:22px;width:22px}@media(max-width:768px){.friend-item{gap:10px;margin:4px 10px;padding:8px 12px}.friend-avatar{height:40px;width:40px}.chat-header{padding:16px 18px}.nav-button{font-size:1rem;padding:6px 0}.friend-list-bottom-nav{flex:0 0 40px}}:root{--primary:#e67e22;--primary-light:#f39c12;--primary-dark:#d35400;--secondary:#3498db;--secondary-light:#5dade2;--secondary-dark:#2980b9;--accent:#e74c3c;--dark-bg:#2c3e50;--darker-bg:#1a2a38;--light-bg:#f5f7fa;--lighter-bg:#fff;--text-light:#fff;--text-dark:#2c3e50;--text-muted:#7f8c8d;--border-light:#ecf0f1;--success:#27ae60;--warning:#f39c12;--danger:#e74c3c;--info:#3498db}body{background-color:#f5f7fa;background-color:var(--light-bg);color:#2c3e50;color:var(--text-dark);font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;line-height:1.5;padding:0}.dashboard-wrapper{display:flex;flex-direction:column;max-height:100vh;min-height:100vh;overflow:hidden}.dashboard-content{display:flex;flex:1 1;overflow:hidden}.admin-header{background:linear-gradient(135deg,#2c3e50,#1a2a38);background:linear-gradient(135deg,var(--dark-bg) 0,var(--darker-bg) 100%);box-shadow:0 2px 10px #0000001a;color:#fff;color:var(--text-light);padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.admin-header-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 2rem}.admin-branding{gap:.75rem}.admin-branding,.admin-logo{align-items:center;display:flex}.admin-logo{color:#e67e22;color:var(--primary);font-size:1.8rem;font-weight:700;letter-spacing:.5px;text-decoration:none}.admin-logo span{background:linear-gradient(90deg,#e67e22,#f39c12);background:linear-gradient(90deg,var(--primary),var(--primary-light));background-clip:text;-webkit-background-clip:text;color:#0000;transition:all .3s ease}.admin-logo:hover span{background:linear-gradient(90deg,#f39c12,#e67e22);background:linear-gradient(90deg,var(--primary-light),var(--primary));background-clip:text;-webkit-background-clip:text}.admin-badge{animation:pulse 2s infinite;background:#e74c3c;background:var(--accent);border-radius:20px;box-shadow:0 2px 5px #e74c3c4d;color:#fff;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:.3rem .6rem;text-transform:uppercase;transition:all .3s ease}.admin-search{flex:1 1;margin:0 1.5rem;max-width:600px;position:relative}.admin-search form{align-items:center;display:flex}.admin-search-input{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff1a;border:none;border-radius:30px;box-shadow:0 2px 10px #0000001a;color:#fff;font-size:.95rem;padding:.8rem 1.2rem .8rem 3rem;transition:all .3s ease;width:100%}.admin-search-input::placeholder{color:#fff9}.admin-search-input:focus{background:#ffffff26;box-shadow:0 2px 15px #00000026;outline:none}.admin-search-icon{color:#fff9;font-size:1rem;left:1.2rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.admin-search-button{background:#3498db;background:var(--secondary);border:none;border-radius:30px;box-shadow:0 2px 5px #3498db4d;color:#fff;cursor:pointer;font-weight:500;letter-spacing:.5px;margin-left:.5rem;padding:.8rem 1.5rem;transition:all .3s ease}.admin-search-button:hover{background:#2980b9;background:var(--secondary-dark);box-shadow:0 4px 8px #3498db66;transform:translateY(-2px)}.admin-search-button:active{transform:translateY(0)}.admin-user-section{align-items:center;display:flex;gap:1rem}.admin-user{align-items:center;background:#ffffff1a;border-radius:30px;cursor:pointer;display:flex;gap:.75rem;padding:.4rem .8rem;transition:all .3s ease}.admin-user:hover{background:#ffffff26}.admin-avatar{border:2px solid #ffffff4d;border-radius:50%;height:35px;overflow:hidden;transition:all .3s ease;width:35px}.admin-avatar img{height:100%;object-fit:cover;width:100%}.admin-user:hover .admin-avatar{border-color:#e67e22;border-color:var(--primary)}.admin-name{font-size:.95rem;font-weight:500}.admin-role{color:#ffffffb3;font-size:.75rem}.admin-logout{align-items:center;background:#e74c3c26;border:none;border-radius:30px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.7rem 1.2rem;transition:all .3s ease}.admin-logout:hover{background:#e74c3c4d;transform:translateY(-2px)}.admin-logout:active{transform:translateY(0)}.admin-logout-icon{font-size:1rem}.admin-sidebar{background:linear-gradient(180deg,#2c3e50,#1a2a38);background:linear-gradient(180deg,var(--dark-bg) 0,var(--darker-bg) 100%);box-shadow:2px 0 10px #0000001a;color:#fff;color:var(--text-light);flex-shrink:0;overflow-y:auto;padding:1.5rem 0;transition:all .3s ease;width:280px}.admin-nav{padding:0 1.5rem}.admin-nav h3{border-bottom:1px solid #ffffff1a;color:#ffffffb3;font-size:1.1rem;letter-spacing:1px;margin-bottom:1.5rem;padding-bottom:.75rem;text-transform:uppercase}.admin-nav ul{list-style:none;margin:0;padding:0}.admin-nav li{margin-bottom:.25rem}.admin-nav a{align-items:center;border-radius:8px;color:#fffc;display:flex;font-weight:500;padding:.8rem 1rem;text-decoration:none;transition:all .2s ease}.admin-nav a.active,.admin-nav a:hover{background:#ffffff1a;color:#fff;transform:translateX(3px)}.admin-nav i{color:#e67e22;color:var(--primary);font-size:1.1rem;margin-right:.8rem;text-align:center;width:20px}.admin-main{background-color:#f5f7fa;background-color:var(--light-bg);flex:1 1;overflow-y:auto;padding:1.5rem}.admin-welcome{background:linear-gradient(135deg,#fff,#f5f7fa);background:linear-gradient(135deg,var(--lighter-bg) 0,var(--light-bg) 100%);border-left:4px solid #e67e22;border-left:4px solid var(--primary);border-radius:12px;box-shadow:0 4px 15px #0000000d;margin-bottom:1.5rem;overflow:hidden;padding:2rem;position:relative;text-align:center}.admin-welcome:before{background:linear-gradient(45deg,#e67e220d,#3498db0d);bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:0}.admin-welcome h2{color:#2c3e50;color:var(--text-dark);font-size:1.8rem;margin-bottom:.5rem;position:relative;z-index:1}.admin-welcome p{color:#7f8c8d;color:var(--text-muted);margin:0 auto;max-width:600px;position:relative;z-index:1}.stats-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:1.5rem}.stat-card{background:linear-gradient(135deg,#fff,#f5f7fa);background:linear-gradient(135deg,var(--lighter-bg) 0,var(--light-bg) 100%);border-radius:12px;border-top:4px solid #3498db;border-top:4px solid var(--secondary);box-shadow:0 4px 15px #0000000d;overflow:hidden;padding:1.5rem;position:relative;text-align:center;transition:all .3s ease}.stat-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-5px)}.stat-card:before{background:radial-gradient(circle,#3498db1a 0,#3498db00 70%);border-radius:0 0 0 100%;content:"";height:80px;position:absolute;right:0;top:0;width:80px}.stat-card h3{color:#7f8c8d;color:var(--text-muted);font-size:1rem;margin-bottom:.75rem;margin-top:0}.stat-value{background:linear-gradient(90deg,#3498db,#2980b9);background:linear-gradient(90deg,var(--secondary),var(--secondary-dark));background-clip:text;-webkit-background-clip:text;color:#2c3e50;color:var(--text-dark);color:#0000;font-size:2.5rem;font-weight:700;margin-bottom:1rem}.stat-card a{background:#3498db1a;border-radius:30px;color:#3498db;color:var(--secondary);display:inline-block;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease}.stat-card a:hover{background:#3498db33;transform:translateY(-2px)}.admin-panels{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:1.5rem}.admin-panel{background:#fff;background:var(--lighter-bg);border-radius:12px;box-shadow:0 4px 15px #0000000d;padding:1.5rem}.admin-panel h3{align-items:center;border-bottom:1px solid #ecf0f1;border-bottom:1px solid var(--border-light);color:#2c3e50;color:var(--text-dark);display:flex;font-size:1.2rem;justify-content:space-between;margin-bottom:1.2rem;margin-top:0;padding-bottom:.8rem}.count-badge{background:#e74c3c;background:var(--accent);border-radius:20px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .5rem}.pending-events{border-left:4px solid #e74c3c;border-left:4px solid var(--accent)}.pending-list{list-style:none;margin:0;padding:0}.pending-item{background:#f5f7fa;background:var(--light-bg);border-left:3px solid #f39c12;border-left:3px solid var(--warning);border-radius:8px;display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem;padding:1.2rem;transition:all .3s ease}.pending-item:hover{box-shadow:0 5px 15px #0000000d;transform:translateY(-3px)}.pending-info h4{color:#2c3e50;color:var(--text-dark);font-size:1.1rem;margin:0 0 .5rem}.pending-info p{color:#7f8c8d;color:var(--text-muted);font-size:.9rem;margin:.25rem 0}.pending-actions{display:flex;flex-wrap:wrap;gap:.5rem}.pending-actions button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.6rem 1.2rem;transition:all .3s ease}.approve-btn{background:#27ae60;background:var(--success);color:#fff}.approve-btn:hover{background:#2ecc71;transform:translateY(-2px)}.reject-btn{background:#e74c3c;background:var(--danger);color:#fff}.reject-btn:hover{background:#c0392b;transform:translateY(-2px)}.view-btn{background:#3498db;background:var(--secondary);color:#fff}.view-btn:hover{background:#2980b9;background:var(--secondary-dark);transform:translateY(-2px)}.user-list{list-style:none;margin:0;padding:0}.user-item{align-items:center;background:#f5f7fa;background:var(--light-bg);border-radius:8px;display:flex;gap:1rem;margin-bottom:1rem;padding:1.2rem;transition:all .3s ease}.user-item:hover{box-shadow:0 5px 15px #0000000d;transform:translateY(-3px)}.user-avatar{align-items:center;background:#3498db;background:var(--secondary);border:3px solid #ecf0f1;border:3px solid var(--border-light);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.5rem;font-weight:600;height:50px;justify-content:center;overflow:hidden;width:50px}.user-avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#3498db,#2980b9);background:linear-gradient(135deg,var(--secondary) 0,var(--secondary-dark) 100%);color:#fff;display:flex;font-size:1.5rem;font-weight:600;height:100%;justify-content:center;width:100%}.user-info{flex:1 1}.user-info h4{color:#2c3e50;color:var(--text-dark);font-size:1.1rem;margin:0 0 .3rem}.user-info p{color:#7f8c8d;color:var(--text-muted);font-size:.85rem;margin:.1rem 0}.user-actions{display:flex;gap:.5rem}.user-actions button{background:#3498db;background:var(--secondary);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.6rem 1.2rem;transition:all .3s ease}.user-actions button:hover{background:#2980b9;background:var(--secondary-dark);transform:translateY(-2px)}.quick-actions{background:#fff;background:var(--lighter-bg);border-radius:12px;border-top:4px solid #e67e22;border-top:4px solid var(--primary);box-shadow:0 4px 15px #0000000d;margin-bottom:1.5rem;padding:1.5rem}.quick-actions h3{border-bottom:1px solid #ecf0f1;border-bottom:1px solid var(--border-light);color:#2c3e50;color:var(--text-dark);font-size:1.2rem;margin-bottom:1.2rem;margin-top:0;padding-bottom:.8rem}.action-buttons{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.action-buttons button{align-items:center;background:#3498db;background:var(--secondary);border:none;border-radius:8px;box-shadow:0 2px 5px #0000001a;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;justify-content:center;padding:1rem 1.2rem;transition:all .3s ease}.action-buttons button:hover{background:#2980b9;background:var(--secondary-dark);box-shadow:0 5px 15px #0000001a;transform:translateY(-3px)}.action-buttons button:active{transform:translateY(-1px)}.action-buttons button:first-child{background:linear-gradient(135deg,#e67e22,#f39c12);background:linear-gradient(135deg,var(--primary) 0,var(--primary-light) 100%)}.action-buttons button:first-child:hover{background:linear-gradient(135deg,#f39c12,#e67e22);background:linear-gradient(135deg,var(--primary-light) 0,var(--primary) 100%)}.action-buttons button:nth-child(2){background:linear-gradient(135deg,#e74c3c,#ed6663);background:linear-gradient(135deg,var(--accent) 0,#ed6663 100%)}.action-buttons button:nth-child(2):hover{background:linear-gradient(135deg,#ed6663,#e74c3c);background:linear-gradient(135deg,#ed6663 0,var(--accent) 100%)}.action-buttons button:nth-child(3){background:linear-gradient(135deg,#3498db,#5dade2);background:linear-gradient(135deg,var(--info) 0,#5dade2 100%)}.action-buttons button:nth-child(3):hover{background:linear-gradient(135deg,#5dade2,#3498db);background:linear-gradient(135deg,#5dade2 0,var(--info) 100%)}.action-buttons button:nth-child(4){background:linear-gradient(135deg,#f39c12,#f5b041);background:linear-gradient(135deg,var(--warning) 0,#f5b041 100%)}.action-buttons button:nth-child(4):hover{background:linear-gradient(135deg,#f5b041,#f39c12);background:linear-gradient(135deg,#f5b041 0,var(--warning) 100%)}.action-buttons button:nth-child(5){background:linear-gradient(135deg,#27ae60,#58d68d);background:linear-gradient(135deg,var(--success) 0,#58d68d 100%)}.action-buttons button:nth-child(5):hover{background:linear-gradient(135deg,#58d68d,#27ae60);background:linear-gradient(135deg,#58d68d 0,var(--success) 100%)}.action-buttons button:nth-child(6){background:linear-gradient(135deg,#9b59b6,#af7ac5)}.action-buttons button:nth-child(6):hover{background:linear-gradient(135deg,#af7ac5,#9b59b6)}.dashboard-footer{background:#2c3e50;background:var(--dark-bg);color:#fff;color:var(--text-light);font-size:.9rem;padding:1.2rem;text-align:center}.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100px;padding:2rem}.loading-spinner{border:3px solid #3498db1a;border-top-color:#3498db;border-top:3px solid var(--secondary);margin-bottom:1rem}.empty-state{color:#7f8c8d;color:var(--text-muted);padding:2rem;text-align:center}.empty-state-icon{color:#ddd;font-size:3rem;margin-bottom:1rem}@media (max-width:1200px){.admin-panels{grid-template-columns:1fr}}@media (max-width:992px){.admin-header-container{flex-direction:column;gap:1rem;padding:1rem}.admin-search{margin:.5rem 0;max-width:100%;width:100%}.admin-user-section{justify-content:space-between;width:100%}.dashboard-content{flex-direction:column}.admin-sidebar{order:2;padding:1rem 0;width:100%}.admin-main{order:1}.stats-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.admin-header-container{flex-wrap:wrap}.admin-branding{flex:1 1}.admin-search{margin:.5rem 0 0;max-width:100%;order:3}.admin-user-section{flex:1 1;justify-content:flex-end}.action-buttons,.stats-cards{grid-template-columns:1fr}.pending-item{flex-direction:column}.pending-actions{width:100%}}@media (max-width:576px){.admin-search form{flex-direction:column;gap:.5rem}.admin-search-button{margin-left:0;width:100%}.admin-user-section{align-items:stretch;flex-direction:column;gap:.5rem}.admin-logout,.admin-user{justify-content:center}.user-item{flex-direction:column;text-align:center}.user-avatar{margin:0 auto}.user-actions{justify-content:center;width:100%}}.modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.create-tour-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:#333;font-size:24px;font-weight:600;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:background .2s;width:30px}.close-btn:hover{background:#f5f5f5}.tour-form{padding:20px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr;margin-bottom:20px}.form-row:has(.form-group:nth-child(2)){grid-template-columns:1fr 1fr}.form-row:has(.form-group:nth-child(3)){grid-template-columns:1fr 1fr 1fr}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input,.form-group textarea{border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;line-height:1.4;padding:10px 12px;transition:border-color .3s ease;width:100%}.form-group input[type=datetime-local],.form-group input[type=number],.form-group input[type=text]{color:#333;height:auto;min-height:36px}.form-group input[type=datetime-local]{color:#333!important}.form-group input[type=datetime-local]::-webkit-datetime-edit,.form-group input[type=datetime-local]::-webkit-datetime-edit-text{color:#333}.form-group input[type=datetime-local]::-webkit-datetime-edit-day-field,.form-group input[type=datetime-local]::-webkit-datetime-edit-hour-field,.form-group input[type=datetime-local]::-webkit-datetime-edit-minute-field,.form-group input[type=datetime-local]::-webkit-datetime-edit-month-field,.form-group input[type=datetime-local]::-webkit-datetime-edit-year-field{color:#333}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.form-group input.error,.form-group textarea.error{border-color:#f44336}.error-text{color:#f44336;display:block;font-size:12px;margin-top:4px}.meeting-point-input{display:flex;gap:10px}.meeting-point-input input{flex:1 1}.select-location-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 16px;transition:background .2s;white-space:nowrap}.select-location-btn:hover{background:#5a67d8}.location-coords{color:#4caf50;display:block;font-size:12px;font-weight:500;margin-top:4px}.form-actions{border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;margin-top:30px;padding-top:20px}.cancel-btn{background:#757575;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .2s}.cancel-btn:hover{background:#616161;transform:translateY(-1px)}.submit-btn{transition:all .2s}.submit-btn:hover:not(:disabled){box-shadow:0 4px 12px #4caf504d}.submit-btn:disabled{background:#bbb}.location-modal{background:#fff;border-radius:12px;display:flex;flex-direction:column;height:600px;max-width:800px;width:90%}.location-modal .modal-header{border-bottom:1px solid #e0e0e0;padding:20px}.location-modal .modal-header h3{color:#333;font-size:20px;font-weight:600;margin:0 0 5px}.location-modal .modal-header p{color:#666;font-size:14px;margin:0}.location-map{border-radius:0;flex:1 1}.duration-display{background:#f8f9fa;border-left:3px solid #4caf50;border-radius:4px;color:#4caf50;display:block;font-size:12px;font-weight:500;margin-top:4px;padding:4px 8px}.loading-address{color:#667eea;font-size:14px;font-style:italic}.location-actions{border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;padding:20px}.confirm-btn{background:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .2s}.confirm-btn:hover:not(:disabled){background:#45a049;transform:translateY(-1px)}.confirm-btn:disabled{background:#bbb;cursor:not-allowed}@media (max-width:768px){.modal-overlay{padding:10px}.create-tour-modal{max-height:95vh}.modal-header{padding:15px}.modal-header h2{font-size:20px}.tour-form{padding:15px}.form-row:has(.form-group:nth-child(2)),.form-row:has(.form-group:nth-child(3)){grid-template-columns:1fr}.meeting-point-input{flex-direction:column}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.location-modal{height:80vh;width:95%}.location-actions{flex-direction:column-reverse}.location-actions button{width:100%}}.submission-status{background:linear-gradient(135deg,#4caf50,#45a049);border-radius:8px;box-shadow:0 2px 10px #4caf504d;color:#fff;margin-bottom:20px;padding:12px 20px}.submission-progress{align-items:center;display:flex;gap:12px}.progress-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.submit-btn{background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:8px;box-shadow:0 2px 8px #4caf504d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;min-width:150px;padding:12px 24px;transition:all .3s ease}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#45a049,#4caf50);box-shadow:0 4px 12px #4caf5066;transform:translateY(-1px)}.submit-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.submit-btn.submitting{background:linear-gradient(135deg,#4caf50,#45a049);cursor:wait;pointer-events:none;position:relative}.submit-btn.submitting:before{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;content:"";height:16px;left:12px;position:absolute;top:50%;transform:translateY(-50%);width:16px}.tour-form button:disabled,.tour-form input:disabled,.tour-form textarea:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed;opacity:.7}.tour-form input:disabled::placeholder,.tour-form textarea:disabled::placeholder{color:#ccc}.modal-overlay .create-tour-modal.submitting{pointer-events:none}.modal-overlay .create-tour-modal.submitting .modal-header,.modal-overlay .create-tour-modal.submitting .tour-form{opacity:.8}.tour-card{border:2px solid #0000;border-radius:12px;box-shadow:0 4px 15px #0000001a;box-sizing:border-box;margin-bottom:25px;max-width:100%;overflow:hidden;position:relative}.tour-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-4px)}.tour-card.live{background:linear-gradient(135deg,#fff,#f8fff8);border-color:#4caf50}.tour-card.scheduled.needs-action{animation:subtle-pulse 3s ease-in-out infinite;background:linear-gradient(135deg,#fff,#f0f8ff);border-color:#2196f3}.tour-card.ended{background:linear-gradient(135deg,#fff,#f5f5f5);opacity:.85;padding:12px}.tour-card.cancelled{background:linear-gradient(135deg,#fff,#fff5f5);border-color:#f44336}@keyframes subtle-pulse{0%,to{box-shadow:0 4px 15px #0000001a}50%{box-shadow:0 4px 16px #2196f333}}.tour-title{align-items:center;display:flex;flex-direction:column;gap:8px;width:100%}.tour-title h3{word-wrap:break-word;color:#2c3e50!important;display:block!important;font-size:18px!important;font-weight:600!important;-webkit-hyphens:auto;hyphens:auto;line-height:1.3;margin:0 0 8px;opacity:1!important;overflow-wrap:anywhere;text-align:center;visibility:visible!important;width:100%}.start-datetime{color:#666;font-size:14px;font-weight:500;margin-top:4px}.live-start-time{background:#4caf501a;border-left:3px solid #4caf50;border-radius:6px;color:#4caf50;font-size:14px;font-weight:600;margin:10px 0 8px;padding:8px 12px;text-align:center}.status-container{align-items:flex-end;display:flex;flex-direction:column;gap:6px}.tour-status{border-radius:20px;box-shadow:0 2px 4px #0000001a;color:#fff;flex-shrink:0;font-size:11px;font-weight:700;padding:4px 12px;white-space:nowrap}.tour-status.live{animation:pulse-status 2s infinite;background:#4caf50}.tour-status.scheduled{background:#2196f3}.tour-status.completed{background:#9e9e9e}.tour-status.cancelled{background:#f44336}.tour-status.paused{background:#ff9800}.tour-status.draft{background:#757575}.attention-badge{border-radius:12px;font-size:.7rem;font-weight:700;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.attention-badge.full{animation:attention-blink 2s ease-in-out infinite;background:#ff9800;color:#fff}.attention-badge.action{animation:attention-pulse 2s ease-in-out infinite;background:#2196f3;color:#fff}@keyframes attention-blink{0%,to{opacity:1}50%{opacity:.7}}@keyframes attention-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes pulse-status{0%,to{opacity:1}50%{opacity:.7}}.tour-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;margin:0 0 15px;overflow:hidden}.tour-details{display:flex;flex-direction:column;gap:8px}.detail-row{display:flex;gap:20px}.detail-icon{flex-shrink:0;text-align:center}.detail-text{color:#333;font-weight:500}.full-indicator{background:#ff9800;border-radius:8px;color:#fff;font-size:.7rem;font-weight:600;margin-left:6px;padding:2px 6px}.tour-meta{border-top:1px solid #f0f0f0;margin-top:12px;padding-top:12px}.meta-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.meta-row:last-child{margin-bottom:0}.tour-meta small{color:#999;font-size:12px}.meta-row.live small,.tour-meta.active small{color:#4caf50;font-weight:600}.meta-row.ended small{color:#9e9e9e}.meta-row.cancelled small{color:#f44336}.token-status.inactive{color:#f44336;font-weight:600}.token-usage{color:#2196f3}.tour-card-footer{border-top:1px solid #f0f0f0;margin-top:20px;padding-top:20px}.tour-card-actions{align-items:center;display:flex;justify-content:space-between;margin-top:10px}.tour-meta-item{color:#555;font-size:.85rem;font-weight:500}.tour-btn{align-items:center;background:#fff;border:1px solid #ddd;border-radius:8px;color:#555;cursor:pointer;display:flex;font-size:13px;font-weight:600;height:42px;justify-content:center;line-height:1;min-height:42px;overflow:hidden;padding:10px 12px;text-align:center;text-overflow:ellipsis;transition:all .2s ease;white-space:nowrap}.tour-btn:hover:not(:disabled){background:#f5f5f5;border-color:#ccc;box-shadow:0 4px 12px #0003;transform:translateY(-1px)}.tour-btn:active{transform:translateY(0)}.tour-btn:disabled{background:#e0e0e0!important;color:#9e9e9e!important;cursor:not-allowed;opacity:.6;transform:none}.tour-btn:disabled:hover{box-shadow:none;transform:none}.tour-btn.primary{background:#2196f3;border-color:#2196f3;color:#fff}.tour-btn.primary:hover:not(:disabled){background:#1976d2;border-color:#1976d2}.tour-btn.danger{background:#f44336;border-color:#f44336;color:#fff}.tour-btn.danger:hover:not(:disabled){background:#d32f2f;border-color:#d32f2f}.share-btn{background:#667eea;border-color:#667eea;color:#fff}.share-btn:hover:not(:disabled){background:#5a67d8;border-color:#5a67d8}.start-btn{background:#4caf50;border-color:#4caf50;color:#fff}.start-btn:hover:not(:disabled){background:#45a049;border-color:#45a049}.view-map-btn{background:#2196f3;border-color:#2196f3}.view-map-btn:hover:not(:disabled){background:#1976d2;border-color:#1976d2}.end-btn{background:#ff5722;border-color:#ff5722;color:#fff}.end-btn:hover:not(:disabled){background:#e64a19;border-color:#e64a19}.delete-btn{background:#757575;border-color:#757575;color:#fff}.delete-btn:hover:not(:disabled){background:#616161;border-color:#616161}.view-stats-btn{background:#9c27b0;border-color:#9c27b0;color:#fff}.view-stats-btn:hover:not(:disabled){background:#7b1fa2;border-color:#7b1fa2}.resume-btn{background:#ff9800;border-color:#ff9800;color:#fff}.resume-btn:hover:not(:disabled){background:#f57c00;border-color:#f57c00}.edit-btn{background:#607d8b;border-color:#607d8b;color:#fff}.edit-btn:hover:not(:disabled){background:#455a64;border-color:#455a64}.tour-completion-stats{background:#f8f9fa;border-radius:6px;margin-top:10px;padding:8px 12px;text-align:center}.tour-completion-stats small{color:#4caf50;font-size:12px;font-weight:600}.tour-cancellation-info{background:#ffebee;border-radius:6px;margin-top:10px;padding:8px 12px;text-align:center}.tour-cancellation-info small{color:#f44336;font-size:12px;font-weight:600}.live-indicator{background:linear-gradient(90deg,#4caf50,#45a049);border-radius:20px;bottom:-12px;box-shadow:0 4px 12px #4caf504d;color:#fff;font-size:12px;justify-content:center;left:50%;min-width:120px;padding:8px 16px;position:absolute;transform:translateX(-50%);white-space:nowrap;z-index:10}.live-indicator.enhanced{align-items:center;background:linear-gradient(135deg,#4caf50,#45a049);border-radius:8px;box-shadow:0 2px 8px #4caf504d;color:#fff;display:flex;font-weight:600;justify-content:space-between;margin-top:16px;padding:12px 16px;position:static;transform:none}.live-indicator.active{background:linear-gradient(90deg,#4caf50,#45a049)}.live-indicator.pending{background:linear-gradient(90deg,#ff9800,#f57c00)}.live-indicator.ended{background:linear-gradient(90deg,#757575,#616161)}.pulse-dot{animation:pulse-dot 1.5s infinite;background:#fff}@keyframes pulse-dot{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.live-actions{display:flex;gap:8px}.quick-action{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;padding:6px 10px;transition:all .2s ease}.quick-action:hover{background:#ffffff4d;transform:scale(1.05)}.scheduled-indicator{background:#e3f2fd;border:1px solid #bbdefb;border-radius:6px;color:#1976d2;font-size:12px;font-weight:600;margin-top:10px;padding:8px 16px;text-align:center}.scheduled-indicator.enhanced{align-items:center;background:linear-gradient(135deg,#2196f3,#1976d2);border-radius:8px;box-shadow:0 2px 8px #2196f34d;color:#fff;display:flex;font-weight:500;justify-content:space-between;margin-top:16px;padding:12px 16px}.start-prompt{margin-left:16px}.quick-start-btn{background:#ffffffe6;border:none;border-radius:6px;color:#2196f3;cursor:pointer;font-weight:600;padding:8px 16px;transition:all .2s ease}.quick-start-btn:hover{background:#fff;transform:scale(1.05)}.full-tour-indicator{animation:full-tour-pulse 3s ease-in-out infinite;background:linear-gradient(135deg,#ff9800,#f57c00);border-radius:8px;box-shadow:0 2px 8px #ff98004d;color:#fff;font-weight:600;margin-top:16px;padding:12px 16px;text-align:center}@keyframes full-tour-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.token-warning{align-items:center;background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;color:#856404;display:flex;font-size:.9rem;justify-content:space-between;margin-top:16px;padding:12px 16px}.reactivate-btn{background:#ffc107;border:none;border-radius:6px;color:#856404;cursor:pointer;font-size:.8rem;font-weight:600;padding:6px 12px;transition:all .2s ease}.reactivate-btn:hover{background:#e0a800;transform:scale(1.05)}.tour-completion-enhanced{padding:16px 0}.completion-stats{background:#f8f9fa;border-radius:6px;color:#555;font-size:14px;font-weight:600;margin-bottom:12px;padding:8px 12px;text-align:center}.completion-details{margin-bottom:16px}.completion-detail{align-items:center;color:#666;display:flex;font-size:13px;gap:8px;margin-bottom:8px}.completion-detail:last-child{margin-bottom:0}.completion-detail .detail-icon{flex-shrink:0;font-size:14px;text-align:center;width:16px}.completion-detail .detail-text{font-weight:500}.reactivate-tour-btn{align-items:center;background:#757575;border:1px solid #757575;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;justify-content:center;padding:12px 16px;transition:all .2s ease;width:100%}.reactivate-tour-btn:hover{background:#616161;border-color:#616161;box-shadow:0 2px 8px #7575754d;transform:translateY(-1px)}.tour-card.ended .live-subtext,.tour-card.ended .owner-actions,.tour-card.ended .primary-live-map-btn,.tour-card.ended .tour-card-footer,.tour-card.ended .tour-info{display:none!important}@media (max-width:768px){.tour-card{margin-bottom:30px;max-width:100%;overflow-x:hidden;padding:15px}.tour-card.ended{padding:10px}.tour-card-actions{gap:8px;grid-template-columns:1fr}.tour-btn{font-size:12px;height:40px;min-height:40px;padding:8px 10px}.tour-title{align-items:flex-start;flex-direction:column;gap:10px}.tour-status{align-self:flex-start}.detail-row{flex-direction:column;gap:8px}.live-indicator{bottom:-10px;font-size:11px;min-width:100px;padding:6px 12px}.pulse-dot{height:6px;width:6px}}@media (max-width:480px){.tour-title h3{font-size:16px}.tour-btn{font-size:11px;height:36px;min-height:36px}.tour-card{margin-bottom:25px;padding:12px}.live-indicator{bottom:-8px;font-size:10px;min-width:80px;padding:4px 10px}}.tour-guide-dashboard{background-color:#f8f9fa;height:100vh;margin:0 auto;max-width:1200px;min-height:100vh;overflow-x:hidden;overflow-y:auto;padding:30px 20px 20px;scrollbar-color:#667eea #f1f1f1;scrollbar-width:thin}.tour-guide-loading{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;gap:20px;justify-content:center;min-height:100vh}.loading-spinner{border:4px solid #ffffff4d}.dashboard-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-sizing:border-box;color:#fff;display:flex;flex-wrap:nowrap!important;gap:8px;justify-content:space-between;margin-bottom:30px;min-height:50px;min-width:0;padding:8px 15px;position:relative;width:100%}.app-name{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#4caf50!important;display:flex!important;flex:1 1;font-size:22px;font-weight:800;letter-spacing:.5px;min-height:50px;overflow:hidden;padding:0 12px;text-align:center;text-overflow:ellipsis;text-shadow:none;text-transform:uppercase;white-space:nowrap;z-index:10}.app-name,.create-tour-btn,.dashboard-back-btn{align-items:center;justify-content:center;line-height:1.2}.create-tour-btn,.dashboard-back-btn{display:flex;min-height:44px;padding-bottom:0;padding-top:0}@media (max-width:480px){.dashboard-header{gap:6px;min-height:50px;padding:10px 12px}}@media (min-width:481px) and (max-width:768px){.dashboard-header{gap:8px;min-height:55px;padding:12px 15px}}@media (min-width:769px) and (max-width:1024px){.dashboard-header{gap:10px;min-height:65px;padding:15px 20px}}@media (min-width:1025px){.dashboard-header{gap:15px;min-height:80px;padding:20px 30px}}.dashboard-header .dashboard-back-btn{align-items:center;background:#fff;border:2px solid #fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;color:#667eea;cursor:pointer;display:flex;flex-grow:0;flex-shrink:0;font-weight:700;justify-content:center;overflow:hidden;position:static;text-decoration:none;transition:all .3s ease;white-space:nowrap}@media (max-width:480px){.dashboard-header .dashboard-back-btn{flex-basis:50px;font-size:11px;gap:2px;max-width:50px;min-width:50px;padding:6px 8px}}@media (min-width:481px) and (max-width:768px){.dashboard-header .dashboard-back-btn{flex-basis:60px;font-size:12px;gap:3px;max-width:60px;min-width:60px;padding:7px 10px}}@media (min-width:769px) and (max-width:1024px){.dashboard-header .dashboard-back-btn{flex-basis:70px;font-size:13px;gap:4px;max-width:70px;min-width:70px;padding:8px 12px}}@media (min-width:1025px){.dashboard-header .dashboard-back-btn{flex-basis:80px;font-size:14px;gap:6px;max-width:80px;min-width:80px;padding:10px 16px}}.dashboard-header .dashboard-back-btn:hover{background:#f0f8ff;box-shadow:0 4px 16px #0003;color:#5a67d8;transform:translateY(-2px)}.dashboard-header .dashboard-back-btn:active{transform:translateY(0)}.dashboard-header .header-content{display:none!important}.dashboard-header .header-content h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4caf50,#2e7d32);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:2.2rem;font-weight:700;font-weight:800;letter-spacing:1px;margin:0;text-overflow:ellipsis;text-shadow:0 2px 10px #0000004d;text-shadow:none;text-transform:uppercase}.dashboard-header .header-content h1,.dashboard-header .header-content p{word-wrap:break-word;line-height:1.1;max-width:100%;overflow:hidden;white-space:nowrap}.dashboard-header .header-content p{color:#ffffffe6;margin:2px 0 0;text-overflow:ellipsis}@media (max-width:480px){.dashboard-header .header-content h1{font-size:1.2rem}.dashboard-header .header-content p{font-size:.7rem}}@media (min-width:481px) and (max-width:768px){.dashboard-header .header-content h1{font-size:1.5rem}.dashboard-header .header-content p{font-size:.75rem}}@media (min-width:769px) and (max-width:1024px){.dashboard-header .header-content h1{font-size:1.8rem}.dashboard-header .header-content p{font-size:.85rem}}@media (min-width:1025px){.dashboard-header .header-content h1{font-size:2.2rem}.dashboard-header .header-content p{font-size:1rem}}.token-health-indicator{display:none!important}.dashboard-header .create-tour-btn{align-items:center;background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:10px;box-shadow:0 4px 15px #4caf504d;color:#fff;cursor:pointer;display:flex;flex-grow:0;flex-shrink:0;font-size:16px!important;font-weight:600;justify-content:center;line-height:1.15;overflow-wrap:anywhere;padding:8px 20px;position:static;text-align:center;transition:all .3s ease;white-space:normal;word-break:break-word}@media (max-width:480px){.dashboard-header .create-tour-btn{flex-basis:70px;font-size:10px;max-width:70px;min-width:70px;padding:6px 8px}}@media (min-width:481px) and (max-width:768px){.dashboard-header .create-tour-btn{flex-basis:85px;font-size:11px;max-width:85px;min-width:85px;padding:7px 10px}}@media (min-width:769px) and (max-width:1024px){.dashboard-header .create-tour-btn{flex-basis:110px;font-size:12px;max-width:110px;min-width:110px;padding:8px 12px}}@media (min-width:1025px){.dashboard-header .create-tour-btn{flex-basis:140px;font-size:16px!important;max-width:140px;min-width:140px;padding:12px 20px}}.dashboard-header .create-tour-btn:hover:not(:disabled){box-shadow:0 6px 20px #4caf5066;transform:translateY(-2px)}.dashboard-header .create-tour-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.action-alert{background:linear-gradient(135deg,#ff9800,#f57c00);border-radius:12px;box-shadow:0 4px 16px #ff98004d;color:#fff;justify-content:space-between;margin-bottom:30px;margin-top:10px;padding:16px 20px}.action-alert,.alert-content{align-items:center;display:flex}.alert-content{gap:12px}.alert-icon{font-size:1.5rem}.alert-text{font-size:1rem;font-weight:600}.alert-action{background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:all .2s ease}.alert-action:hover{background:#ffffff4d;transform:scale(1.05)}.tours-container{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr;margin-bottom:30px;margin-top:20px}@media (min-width:768px){.tours-container{gap:20px;grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.tours-container{gap:24px;grid-template-columns:repeat(3,1fr)}}@media (min-width:1400px){.tours-container{gap:28px;grid-template-columns:repeat(4,1fr)}}.section-header{border-bottom:2px solid #e0e0e0;margin-bottom:25px;padding-bottom:15px}.section-header h2{align-items:center;color:#333;display:flex;font-size:1.5em;font-weight:600;gap:10px;margin:0 0 8px}.section-icon{font-size:1.2em}.section-stats{color:#666;font-size:.9em;font-weight:500;margin-left:auto}.section-quick-stats{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.quick-stat{border-radius:8px;color:#fff;font-size:.75rem;font-weight:600;padding:4px 8px}.quick-stat.live{background:#4caf50}.quick-stat.action{animation:quick-stat-blink 2s ease-in-out infinite;background:#ff9800}.quick-stat.completed{background:#9e9e9e}@keyframes quick-stat-blink{0%,to{opacity:1}50%{opacity:.7}}.tours-grid{grid-gap:20px;display:grid;gap:20px}.joined-tour-card{background:#fff;border:2px solid #0000;border-radius:15px;box-shadow:0 2px 8px #0000001a;cursor:pointer;margin-bottom:16px;padding:20px;transition:all .3s ease}.joined-tour-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.joined-tour-card.live{background:linear-gradient(135deg,#fff,#f8fff8);border-color:#4caf50}.joined-tour-card.scheduled{background:linear-gradient(135deg,#fff,#f0f8ff);border-color:#2196f3}.joined-tour-card.ended{background:linear-gradient(135deg,#fff,#f5f5f5);opacity:.8}.tour-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.tour-card-header h3{color:#333;flex:1 1;font-size:1.2em;font-weight:600;margin:0 10px 0 0}.status-badge{border-radius:16px;color:#fff;font-size:.8em;padding:6px 12px;white-space:nowrap}.status-badge.active{background:#4caf50}.status-badge.scheduled{background:#2196f3}.status-badge.ended{background:#9e9e9e}.tour-card-content{margin-bottom:15px}.tour-guide{color:#666;font-size:.9em;margin:0 0 8px}.meeting-point{color:#555;font-size:.9em;margin:0 0 10px}.tour-meta{color:#777;display:flex;font-size:.85em;gap:15px;margin-bottom:8px}.live-info small{color:#4caf50;font-weight:600}.ended-info small{color:#9e9e9e}.tour-card-actions{text-align:center}.join-action-btn{background:linear-gradient(135deg,#2196f3,#1976d2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9em;font-weight:600;padding:12px 20px;transition:all .3s ease;width:100%}.join-action-btn:hover{box-shadow:0 4px 12px #2196f34d;transform:translateY(-1px)}.join-action-btn.live{background:linear-gradient(135deg,#4caf50,#45a049)}.join-action-btn.ended{background:#e0e0e0;color:#666}.no-tours{align-items:center;display:flex;justify-content:center;min-height:300px}.no-tours-content{color:#333;text-align:center}.empty-icon{color:#999;font-size:4em;margin-bottom:20px;opacity:.7}.no-tours-content h3{color:#333;font-size:1.5em;margin:0 0 10px}.no-tours-content p{color:#666;font-size:1em;margin:0 0 25px}.browse-tours-btn,.create-first-tour-btn{background:linear-gradient(135deg,#ff9800,#f57c00);border:none;border-radius:12px;box-shadow:0 4px 15px #ff98004d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:15px 25px;transition:all .3s ease}.browse-tours-btn:hover,.create-first-tour-btn:hover{box-shadow:0 6px 20px #ff980066;transform:translateY(-2px)}.dashboard-tips{background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000001a;margin-top:32px;padding:24px}.dashboard-tips h3{color:#333;font-size:1.3rem;font-weight:700;margin:0 0 20px}.tips-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.tip{align-items:flex-start;border-left:4px solid #ddd;border-radius:12px;display:flex;gap:12px;padding:16px}.tip.urgent{background:#fff3e0;border-left-color:#ff9800}.tip.info{background:#e3f2fd;border-left-color:#2196f3}.tip.warning{background:#fff8e1;border-left-color:#ffc107}.tip.general{background:#f3e5f5;border-left-color:#9c27b0}.tip-icon{font-size:1.5rem;margin-top:2px}.tip-content strong{color:#333;display:block;font-size:1rem;font-weight:600;margin-bottom:4px}.tip-content p{color:#666;font-size:.9rem;line-height:1.4;margin:0}@media (max-width:1200px){.tour-groups-container{gap:20px;grid-template-columns:1fr}}.tour-card{background:#fff;border:1px solid #0000000d;border-radius:20px;box-shadow:0 4px 20px #00000014;padding:20px;transition:all .3s ease}.tour-card:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-2px)}.tour-card-header{margin-bottom:16px}.tour-title h3{color:#1a1a1a;font-size:24px;font-weight:700;line-height:1.2;margin:0 0 12px}.tour-status{border-radius:8px;display:inline-block;font-size:14px;font-weight:600;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.tour-info{margin-bottom:20px}.tour-description{color:#666;font-size:14px;line-height:1.4;margin:0 0 16px}.detail-item{align-items:center;color:#555;font-size:14px;gap:8px;margin-bottom:8px}.detail-icon{width:20px}.detail-icon,.primary-live-map-btn{display:flex;font-size:16px;justify-content:center}.primary-live-map-btn{align-items:center;background:#4caf50;border:0;border-radius:16px;color:#fff;cursor:pointer;font-weight:700;gap:8px;margin-bottom:12px;padding:16px 20px;transition:all .3s ease;width:100%}.primary-live-map-btn:hover{background:#45a049;transform:translateY(-1px)}.live-subtext{color:#888;font-size:14px;margin-bottom:16px;text-align:center}.owner-actions-with-status{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:8px;justify-content:center;padding-top:8px}.owner-actions{gap:12px}.owner-actions,.status-only-area{display:flex;justify-content:center}.status-only-area{padding-top:8px}.icon-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;font-size:18px;height:48px;justify-content:center;transition:all .2s ease;width:48px}.icon-btn:hover{background:#f9fafb;transform:translateY(-1px)}.icon-btn.danger{border-color:#fecaca;color:#dc2626}.icon-btn.danger:hover{background:#fef2f2}.join-card{align-items:center;background:#fff;border:1px solid #0000000d;border-radius:15px;box-shadow:0 2px 8px #0000001a;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center;padding:20px;width:100%}.join-card,.tour-card{margin:0}.join-card h3{color:#1a1a1a;font-size:24px;font-weight:700;margin:0 0 20px;text-align:center}.qr-illustration{font-size:64px;line-height:1;margin:16px 0 24px;opacity:.8;text-align:center}.join-row{display:flex;gap:12px;margin-top:16px}.join-row input{background:#f9fafb;border:2px solid #e5e7eb;border-radius:16px;flex:1 1;font-size:16px;height:52px;padding:0 16px;transition:border-color .2s ease}.join-row input:focus{background:#fff;border-color:#4caf50;outline:none}.join-row button{background:#4caf50;border:0;border-radius:16px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;height:52px;min-width:80px;padding:0 24px;transition:all .2s ease;white-space:nowrap}.join-row button:hover{background:#45a049;transform:translateY(-1px)}.scan-btn{background:#f9fafb;border:2px solid #e5e7eb;border-radius:16px;color:#555;cursor:pointer;font-size:16px;font-weight:600;height:52px;margin-bottom:16px;transition:all .2s ease;width:100%}.scan-btn:hover{background:#fff;border-color:#4caf50;color:#4caf50;transform:translateY(-1px)}@media (max-width:480px){.join-row{flex-direction:column;gap:12px}.join-row button{width:100%}}.advertisement-bar{align-items:center;background:linear-gradient(135deg,#2196f3,#1976d2);bottom:0;color:#fff;display:flex;gap:16px;justify-content:center;left:0;padding:12px 20px;position:fixed;width:100%;z-index:100}.advertisement-bar p{font-size:14px;font-weight:600;margin:0}.tvent-btn{background:#fff;border:none;border-radius:8px;color:#1976d2;cursor:pointer;font-size:16px;font-weight:700;padding:12px 24px;transition:all .3s ease}.tvent-btn:hover{background:#f0f0f0;transform:translateY(-1px)}.tour-guide-dashboard{padding-bottom:72px}.section-title{border-bottom:2px solid #e0e0e0;color:#333;font-size:20px;font-weight:700;margin:24px 0 16px;padding-bottom:8px}@media (max-width:768px){.tour-guide-dashboard{padding:16px 16px 72px}.tour-card{padding:16px}.tour-title h3{font-size:20px}.primary-live-map-btn{font-size:15px;padding:14px 16px}.icon-btn{font-size:16px;height:44px;width:44px}.action-alert{flex-direction:column;gap:12px;text-align:center}.app-name{font-size:18px}.tvent-ad-banner{font-size:12px;padding:10px 12px}}@media (max-width:480px){.tour-guide-dashboard{padding:12px 12px 72px}.tour-card{padding:16px}.tour-title h3{font-size:18px}.join-card{padding:20px}.join-card h3{font-size:20px}.qr-illustration{font-size:48px}.app-name{font-size:16px}.tvent-ad-banner{font-size:11px;padding:8px 10px}}.dashboard-header{gap:6px;min-height:44px;padding:6px 10px}@media (min-width:481px) and (max-width:768px){.dashboard-header{min-height:50px;padding:8px 12px}}@media (min-width:769px) and (max-width:1024px){.dashboard-header{min-height:56px;padding:10px 16px}}@media (min-width:1025px){.dashboard-header{min-height:60px;padding:12px 18px}}.app-name{font-size:18px;padding:2px 8px}.tour-guide-dashboard{padding-top:16px}.tours-container{margin-top:48px}.tours-container>.tour-card:first-child,.tours-container>:first-child{margin-top:8px;scroll-margin-top:72px}.tour-card{margin-top:max(8px,8px);margin-top:max(8px,var(--tour-card-top,8px))}.join-card{margin-top:0}.tours-container{margin-bottom:0}.section-title{margin:16px 0 8px;padding-bottom:4px}.section-title+.tours-container{margin-top:0}.share-tour-page{background:linear-gradient(135deg,#667eea,#764ba2);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;max-height:100vh;min-height:100vh;overflow-y:auto;padding:20px}.share-tour-page::-webkit-scrollbar{width:8px}.share-tour-page::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.share-tour-page::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.share-tour-page::-webkit-scrollbar-thumb:hover{background:#ffffff80}.back-btn{align-items:center;background:#ffffff1a;border:2px solid #ffffff4d;border-radius:10px;display:flex;font-size:1rem;font-weight:600;justify-content:center;transition:all .3s ease}.back-btn:hover{background:#fff3;border-color:#ffffff80;color:#fff}.share-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:30px}@media (max-width:768px){.share-content{gap:20px;grid-template-columns:1fr}}.tour-preview{background:#fff;border-radius:16px;box-shadow:0 10px 30px #0003;height:-webkit-fit-content;height:-moz-fit-content;height:fit-content;padding:25px}.tour-info-card h2{color:#2c3e50;font-size:1.8rem;font-weight:700;margin:0 0 15px}.tour-description{color:#7f8c8d;line-height:1.6;margin-bottom:25px}.tour-details-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:25px;margin-top:16px}.detail-item{display:flex;flex-direction:column;gap:5px}.detail-label{color:#95a5a6;font-size:.9rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.detail-value{color:#2c3e50;font-size:1.1rem;font-weight:600}.tour-status{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.status-badge{border-radius:20px;font-size:.9rem;font-weight:600;letter-spacing:.5px;padding:8px 16px;text-transform:uppercase}.status-badge.started{background:#e3f2fd;color:#2196f3}.status-badge.live{background:#e8f5e8;color:#27ae60}.status-badge.completed{background:#f0f0f0;color:#7f8c8d}.status-badge.active{background:#e8f5e8;color:#27ae60}.status-badge.scheduled{background:#e3f2fd;color:#2196f3}.participants-count{background:#f8f9fa;border-radius:12px;color:#6c757d;font-size:.85rem;padding:5px 12px}.sharing-options{display:flex;flex-direction:column;gap:25px}.link-sharing-section,.qr-code-section,.tour-management{background:#fff;border-radius:16px;box-shadow:0 10px 30px #0003;padding:25px}.link-sharing-section h3,.qr-code-section h3,.tour-management h3{color:#2c3e50;font-size:1.4rem;font-weight:700;margin:0 0 10px}.link-sharing-section p,.qr-code-section p{color:#7f8c8d;line-height:1.5;margin-bottom:20px}.qr-code-container{align-items:center;display:flex;justify-content:center;margin-bottom:20px}.qr-code-container svg{height:auto;max-width:180px}@media (max-width:768px){.qr-code-container svg{max-width:100%}}.qr-code{border-radius:8px;box-shadow:0 4px 15px #0000001a}.qr-placeholder{align-items:center;background:#f8f9fa;border-radius:8px;color:#6c757d;display:flex;flex-direction:column;gap:10px;padding:50px}.qr-actions{display:flex;justify-content:center}.download-btn{background:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.download-btn:hover:not(:disabled){background:#2980b9}.download-btn:disabled{background:#bdc3c7;cursor:not-allowed;transform:none}.url-container{margin-bottom:20px}.url-display{align-items:center;display:flex;gap:10px}.url-input{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;color:#495057;flex:1 1;font-size:.9rem;padding:12px 16px}.copy-btn{background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:12px 20px;transition:all .3s ease;white-space:nowrap}.copy-btn:hover{background:#218838}.copy-btn.success{background:#20c997}.share-actions{display:flex;flex-wrap:wrap;gap:12px}.share-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:.9rem;font-weight:600;min-width:120px;padding:12px 16px;text-align:center;transition:all .3s ease}.share-btn.primary{background:#6c63ff;color:#fff}.share-btn.primary:hover{background:#5a52ff}.share-btn.line{background:#00c300;color:#fff}.share-btn.line:hover{background:#00a300}.share-btn.email{background:#dc3545;color:#fff}.share-btn.email:hover{background:#c82333}.management-actions{display:flex;flex-direction:column;gap:12px}.edit-tour-btn,.start-tour-btn,.view-map-btn{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;padding:12px 20px;transition:all .3s ease}.start-tour-btn{background:#28a745;color:#fff}.start-tour-btn:hover{background:#218838}.view-map-btn{background:#17a2b8;color:#fff}.view-map-btn:hover{background:#138496}.edit-tour-btn{background:#ffc107;color:#212529}.edit-tour-btn:hover{background:#e0a800}.copy-notification{animation:slideIn .3s ease;background:#28a745;border-radius:8px;bottom:20px;box-shadow:0 4px 15px #0003;color:#fff;padding:12px 20px;position:fixed;right:20px}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.loading-spinner{border:3px solid #ffffff4d;border-top-color:#fff;margin:0 auto}.loading-spinner.small{border-width:2px;height:20px;width:20px}.error,.loading{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:50vh;text-align:center}.error button{background:#fff;border:none;border-radius:8px;color:#667eea;cursor:pointer;font-weight:600;margin-top:20px;padding:12px 24px;transition:all .3s ease}.error button:hover{box-shadow:0 4px 15px #0003}.header-area{display:none;position:static!important;top:auto!important}.tour-preview .card-header{grid-gap:12px;align-items:center;background:#fff;border-bottom:1px solid #eef2f7;border-top-left-radius:14px;border-top-right-radius:14px;display:grid;gap:12px;grid-template-columns:auto 1fr auto;padding:12px 16px;position:static!important}.tour-preview .card-header .share-title{color:#2c3e50;font-size:clamp(1.1rem,2.2vw,1.35rem);font-weight:700;justify-self:center;line-height:1.2;margin:0}.tour-preview .card-header .back-btn,.tour-preview .card-header .close-btn{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #00000014;border-radius:10px;cursor:pointer;font-size:.95rem;line-height:1;padding:6px 10px}.tour-preview .card-header .back-btn:hover,.tour-preview .card-header .close-btn:hover{background:#0000000a}.tour-preview .card-header,.tour-preview .card-header *{float:none!important;position:static!important;top:auto!important}.tour-preview .card-header .close-btn{opacity:0!important;pointer-events:none!important;-webkit-user-select:none!important;user-select:none!important;visibility:hidden!important}.tour-guide-map-container{background:#f5f5f5;display:flex;flex-direction:column;height:100vh}.background-warning{animation:slideDown .3s ease;background:#ff9800;color:#fff;font-weight:600;padding:10px 20px;text-align:center}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.map-content{display:flex;flex:1 1;overflow:hidden}.center-me-control{bottom:120px;position:absolute;right:20px;z-index:10}.center-me-btn{background:#2196f3;border:none;border-radius:50%;box-shadow:0 4px 15px #0003;color:#fff;cursor:pointer;font-size:20px;height:50px;transition:.2s;width:50px}.center-me-btn:hover:not(:disabled){background:#1976d2;transform:translateY(-2px)}.center-me-btn:disabled{background:#f5f5f5;color:#ccc;cursor:not-allowed;opacity:.6}.tour-map-loading{align-items:center;background:#f5f5f5;display:flex;flex-direction:column;height:100vh;justify-content:center}.loading-spinner{margin-bottom:15px}@media (max-width:768px){.map-content{flex-direction:column}.map-container{height:60%}.center-me-control{bottom:120px;pointer-events:auto;position:absolute;right:20px;z-index:100}.center-me-btn{align-items:center;background:#fff;border:none;border-radius:50%;box-shadow:0 4px 15px #0003;color:#333;cursor:pointer;display:flex;font-size:20px;height:50px;justify-content:center;pointer-events:auto;transition:all .3s ease;width:50px}.center-me-btn:hover:not(:disabled){background:#2196f3;box-shadow:0 6px 20px #0000004d;color:#fff;transform:translateY(-2px)}.center-me-btn:active:not(:disabled){transform:translateY(0)}}@media (max-width:480px){.center-me-control{bottom:100px;right:15px}.center-me-btn{font-size:18px;height:45px;width:45px}}@media (max-width:768px){.chat-section.mobile-fullscreen{background:#fff!important;border-left:none!important;border-top-left-radius:12px!important;border-top-right-radius:12px!important;bottom:0!important;box-shadow:0 -4px 12px #00000026!important;height:calc(100vh - 120px)!important;left:0!important;position:fixed!important;right:0!important;top:120px!important;width:100%!important;z-index:8000!important}.chat-section.mobile-fullscreen .chat-header{background:#f8f9fa!important;border-bottom:1px solid #e0e0e0!important;border-top-left-radius:12px!important;border-top-right-radius:12px!important;flex-shrink:0!important;padding:15px!important}.chat-section.mobile-fullscreen .chat-messages{flex:1 1!important;min-height:0!important;overflow-y:auto!important;padding:10px 0!important}.chat-section.mobile-fullscreen form{background:#fff!important;border-top:1px solid #e0e0e0!important;flex-shrink:0!important;padding:10px 12px!important}.participant-panel-fullscreen{background:#fff!important;border-top-left-radius:12px!important;border-top-right-radius:12px!important;bottom:0!important;box-shadow:0 -4px 12px #00000026!important;left:0!important;position:fixed!important;right:0!important;top:120px!important;z-index:8000!important}.participant-panel-fullscreen .map-sidebar{border-left:none!important;border-top:none!important;border-top-left-radius:12px!important;border-top-right-radius:12px!important;height:100%!important;width:100%!important}.chat-section.mobile-fullscreen .close-chat,.participant-panel-fullscreen .close-btn{border-radius:50%!important;font-size:32px!important;height:48px!important;line-height:1!important;padding:8px!important;transition:all .2s ease!important;width:48px!important}.chat-section.mobile-fullscreen .close-chat:hover,.participant-panel-fullscreen .close-btn:hover{background-color:#f0f0f0!important}.chat-section.mobile-fullscreen .close-chat:active,.participant-panel-fullscreen .close-btn:active{background-color:#e0e0e0!important;transform:scale(.95)!important}.map-header{background:#fff!important;border-bottom:1px solid #e0e0e0!important;left:0!important;position:fixed!important;right:0!important;top:0!important;z-index:10000!important}.map-content{height:calc(100vh - 120px)!important;margin-top:120px!important}.map-container{height:100%!important;position:relative;z-index:1}}@media (min-width:769px){.participant-panel-overlay{align-items:flex-start!important;background-color:#0000004d!important;bottom:0!important;display:flex!important;justify-content:flex-end!important;left:0!important;padding-right:20px!important;padding-top:100px!important;position:fixed!important;right:0!important;top:0!important;z-index:9000!important}.participant-panel-desktop{background-color:#fff!important;border:1px solid #e0e0e0!important;border-radius:8px!important;box-shadow:0 4px 20px #00000026!important;display:flex!important;flex-direction:column!important;flex-shrink:0!important;height:calc(100vh - 140px)!important;max-height:700px!important;max-width:350px!important;min-width:350px!important;overflow:hidden!important;width:350px!important}.participant-panel-desktop .map-sidebar{border-left:none!important;border-radius:8px!important;max-width:100%!important;min-width:100%!important;width:100%!important}.map-header{background:#fff!important;border-bottom:1px solid #e0e0e0!important;left:0!important;position:fixed!important;right:0!important;top:0!important;z-index:10000!important}.map-content{height:calc(100vh - 80px)!important;margin-top:80px!important}}@media (max-width:480px){.chat-section.mobile-fullscreen .close-chat,.participant-panel-fullscreen .close-btn{font-size:28px!important;height:44px!important;width:44px!important}.chat-section.mobile-fullscreen{height:calc(100vh - 100px)!important;top:100px!important}.participant-panel-fullscreen{top:100px!important}.map-content{height:calc(100vh - 100px)!important;margin-top:100px!important}}.map-header{background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 10px #0000001a;left:0;min-height:60px;padding:15px 20px;position:fixed;right:0;top:0;z-index:10000}.map-header-top{align-items:center;display:flex;gap:0;min-height:50px;width:100%}.map-header-left{flex-grow:0;flex-shrink:0;width:120px}.map-header-title{flex:1 1;margin-left:20px;margin-right:20px;min-width:0}.map-header-right{align-items:center;display:flex;flex-shrink:0;flex-wrap:nowrap;gap:12px}.back-btn{align-items:center!important;background:#2196f3!important;border:2px solid #1976d2!important;border-radius:6px!important;cursor:pointer!important;display:flex!important;font-size:14px!important;font-weight:600!important;gap:6px!important;height:40px!important;justify-content:center!important;margin:0!important;outline:none!important;padding:10px 16px!important;position:relative!important;text-decoration:none!important;transition:background-color .2s ease,border-color .2s ease!important;white-space:nowrap!important;width:100px!important}.back-btn,.back-btn:hover{box-shadow:0 2px 4px #2196f34d!important;color:#fff!important;transform:none!important}.back-btn:hover{background:#1976d2!important;border-color:#1565c0!important}.back-btn:active{background:#1565c0!important;border-color:#0d47a1!important;box-shadow:0 2px 4px #2196f34d!important;color:#fff!important;transform:none!important}.map-header h1{color:#2c3e50!important;font-size:18px!important;font-weight:700!important;line-height:1.2!important;margin:0!important;overflow:hidden!important;padding:0!important;text-align:left!important;text-overflow:ellipsis!important;white-space:nowrap!important;width:100%!important}.broadcast-btn{background:linear-gradient(135deg,#ff9800,#f57c00)!important;border:none!important;border-radius:8px!important;box-shadow:0 2px 4px #ff98004d!important;color:#fff!important;cursor:pointer!important;flex-shrink:0!important;font-size:14px!important;font-weight:600!important;padding:10px 16px!important;transition:all .3s ease!important;white-space:nowrap!important}.broadcast-btn:hover{background:linear-gradient(135deg,#f57c00,#ef6c00)!important;box-shadow:0 4px 8px #ff980066!important;transform:translateY(-2px)!important}.chat-toggle{background:linear-gradient(135deg,#4caf50,#45a049)!important;border:none!important;border-radius:8px!important;box-shadow:0 2px 4px #4caf504d!important;color:#fff!important;cursor:pointer!important;flex-shrink:0!important;font-size:14px!important;font-weight:600!important;padding:10px 16px!important;position:relative!important;transition:all .3s ease!important;white-space:nowrap!important}.chat-toggle:hover{background:linear-gradient(135deg,#45a049,#388e3c)!important;box-shadow:0 4px 8px #4caf5066!important;transform:translateY(-2px)!important}.chat-toggle.active{background:linear-gradient(135deg,#2e7d32,#1b5e20)!important;box-shadow:0 2px 4px #2e7d3266!important}.message-count{align-items:center!important;background:#ff5722!important;border:2px solid #fff!important;border-radius:50%!important;box-shadow:0 2px 4px #0003!important;color:#fff!important;display:flex!important;font-size:11px!important;font-weight:700!important;height:22px!important;justify-content:center!important;position:absolute!important;right:-8px!important;top:-8px!important;width:22px!important}.participant-btn{background:linear-gradient(135deg,#2196f3,#1976d2)!important;border:none!important;border-radius:8px!important;box-shadow:0 2px 4px #2196f34d!important;color:#fff!important;cursor:pointer!important;flex-shrink:0!important;font-size:14px!important;font-weight:600!important;padding:10px 16px!important;transition:all .3s ease!important;white-space:nowrap!important}.participant-btn:hover{background:linear-gradient(135deg,#1976d2,#1565c0)!important;box-shadow:0 4px 8px #2196f366!important;transform:translateY(-2px)!important}.participant-count{background:linear-gradient(135deg,#e3f2fd,#bbdefb)!important;border:1px solid #2196f3!important;border-radius:20px!important;box-shadow:0 1px 3px #2196f31a!important;color:#1976d2!important;cursor:default!important}.guide-status,.participant-count{flex-shrink:0!important;font-size:14px!important;font-weight:600!important;padding:8px 14px!important;white-space:nowrap!important}.guide-status{border:1px solid #0000!important;border-radius:20px!important;box-shadow:0 1px 3px #0000001a!important}.guide-status.active{background:linear-gradient(135deg,#e8f5e8,#c8e6c9)!important;border-color:#4caf50!important;color:#2e7d32!important}.guide-status.inactive{background:linear-gradient(135deg,#ffebee,#ffcdd2)!important;border-color:#f44336!important;color:#c62828!important}@media (max-width:768px){.map-header{min-height:auto!important;padding:15px!important}.map-header-top{align-items:stretch!important;flex-direction:column!important;gap:12px!important}.mobile-header-row{align-items:center!important;display:flex!important;gap:15px!important;width:100%!important}.map-header-left{flex-shrink:0!important;width:auto!important}.map-header-title{flex:1 1!important;margin:0!important;min-width:0!important}.map-header-right{flex-wrap:wrap!important;gap:8px!important;justify-content:flex-start!important;width:100%!important}.back-btn{border-radius:5px!important;font-size:13px!important;height:36px!important;padding:8px 12px!important;width:80px!important}.map-header h1{font-size:16px!important;line-height:1.3!important;overflow:visible!important;text-overflow:clip!important;white-space:normal!important}.broadcast-btn,.chat-toggle,.guide-status,.participant-btn,.participant-count{border-radius:6px!important;font-size:12px!important;padding:8px 12px!important}}@media (max-width:480px){.map-header{padding:12px!important}.back-btn{font-size:12px!important;height:32px!important;width:70px!important}.map-header h1{font-size:15px!important}}@keyframes emergency-pulse{0%{box-shadow:0 0 0 0 #ff4444b3}70%{box-shadow:0 0 0 10px #f440}to{box-shadow:0 0 0 0 #f440}}@keyframes emergency-pulse-text{0%,to{opacity:1}50%{opacity:.8}}@keyframes emergency-glow{0%,to{box-shadow:0 0 5px #ff444480}50%{box-shadow:0 0 15px #f44c}}@keyframes pulse-green{0%{box-shadow:0 0 0 0 #4caf50b3}70%{box-shadow:0 0 0 8px #4caf5000}to{box-shadow:0 0 0 0 #4caf5000}}@keyframes pulse-orange{0%{box-shadow:0 0 0 0 #ff9800b3}70%{box-shadow:0 0 0 8px #ff980000}to{box-shadow:0 0 0 0 #ff980000}}.guide-marker{position:relative;transform:translate(-50%,-100%);z-index:100}.guide-marker-inner{box-shadow:0 2px 10px #0000004d;font-size:18px;height:40px;transition:all .3s ease;width:40px}.guide-marker-label{background:#fff;border:1px solid #ddd;box-shadow:0 2px 8px #0003;color:#000;min-width:100px;text-align:center;top:45px}.tourist-marker{cursor:pointer;position:relative;transform:translate(-50%,-100%);transition:all .3s ease;z-index:50}.tourist-marker:hover .tourist-marker-inner{transform:scale(1.1)}.tourist-marker-inner{align-items:center;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #0003;display:flex;font-size:14px;height:32px;justify-content:center;transition:all .3s ease;width:32px}.tourist-marker-inner.active{animation:pulse-green 2s infinite;background:#4caf50}.tourist-marker-inner.slow{animation:pulse-orange 2s infinite;background:#ff9800}.tourist-marker-inner.inactive{animation:none;background:#757575;opacity:.7}.tourist-marker-label{background:#fff;border:1px solid #ddd;border-radius:3px;box-shadow:0 1px 4px #0003;color:#000;font-size:10px;font-weight:600;left:50%;min-width:80px;padding:2px 6px;position:absolute;text-align:center;top:35px;transform:translateX(-50%);white-space:nowrap}.tourist-marker.emergency{z-index:200!important}.tourist-marker.emergency .tourist-marker-inner{animation:emergency-pulse 1s infinite!important;background-color:#f44!important;border:3px solid #fff!important;box-shadow:0 0 0 0 #ff4444b3!important;font-size:18px!important;height:40px!important;width:40px!important}.tourist-marker.emergency .tourist-marker-label{animation:emergency-pulse-text 1.5s infinite;background:#ff4444f2!important;border:2px solid #fff!important;color:#fff!important;font-size:12px!important;font-weight:700!important;min-width:120px!important;padding:4px 8px!important;top:45px!important}.emergency-alert-banner{animation:emergency-pulse-text 1.5s infinite;background-color:#f44;border-bottom:2px solid #d32f2f;color:#fff;font-size:14px;font-weight:700;left:0;padding:8px 16px;position:fixed;right:0;text-align:center;top:0;z-index:9999}.emergency-controls{animation:emergency-glow 2s infinite;background-color:#ff4444e6;border-radius:8px;box-shadow:0 4px 12px #0000004d;color:#fff;max-width:300px;padding:12px;position:absolute;right:10px;top:10px;z-index:1000}.emergency-controls button{background-color:#fff;border:none;border-radius:4px;color:#f44;cursor:pointer;font-size:12px;font-weight:700;padding:6px 12px;transition:all .2s ease}.emergency-controls button:hover{background-color:#f5f5f5;transform:scale(1.05)}.participant-item.emergency{animation:emergency-pulse 2s infinite;background-color:#ff44441a!important;border:2px solid #f44!important}.participant-item.emergency .participant-nickname{color:#d32f2f!important;font-weight:700!important}.participant-item.emergency .participant-real-name{color:#d32f2f!important}.participant-item.emergency .distance,.participant-item.emergency .last-update{color:#d32f2f!important;font-weight:600!important}.emergency-badge{animation:emergency-pulse-text 1.5s infinite;background-color:#f44!important;border-radius:12px!important;color:#fff!important;font-size:12px!important;font-weight:700!important;margin-left:8px!important;padding:2px 8px!important}.participant-count .emergency-count{animation:emergency-pulse-text 1.5s infinite;color:#f44;font-weight:700;margin-left:8px}.participant-avatar-emergency{position:relative}.participant-avatar-emergency:after{align-items:center;animation:emergency-pulse 1s infinite;background-color:#f44;border:2px solid #fff;border-radius:50%;content:"🚨";display:flex;font-size:10px;height:16px;justify-content:center;position:absolute;right:-4px;top:-4px;width:16px;z-index:10}.status-indicator{display:inline-block;height:8px;width:8px}.status-indicator.active{background-color:#4caf50}.status-indicator.slow{background-color:#ff9800}.status-indicator.inactive{background-color:#757575}.status-indicator.emergency{animation:emergency-pulse 1s infinite;background-color:#f44;height:12px;width:12px}@media (max-width:768px){.emergency-alert-banner{font-size:13px;padding:6px 12px}.emergency-controls{max-width:250px;padding:8px;right:5px;top:5px}.emergency-controls button{font-size:11px;padding:4px 8px}.tourist-marker.emergency .tourist-marker-inner{font-size:16px!important;height:36px!important;width:36px!important}.tourist-marker.emergency .tourist-marker-label{font-size:11px!important;min-width:100px!important;padding:3px 6px!important}}@media (prefers-color-scheme:dark){.emergency-alert-banner{background-color:#d32f2f;border-bottom-color:#b71c1c}.emergency-controls{background-color:#d32f2fe6}.tourist-marker.emergency .tourist-marker-label{background:#d32f2ff2!important}.participant-item.emergency{background-color:#d32f2f26!important;border-color:#d32f2f!important}}@media (prefers-reduced-motion:reduce){.emergency-alert-banner,.emergency-badge,.emergency-glow,.emergency-pulse,.emergency-pulse-text,.participant-count .emergency-count,.pulse-green,.pulse-orange,.tourist-marker.emergency .tourist-marker-inner,.tourist-marker.emergency .tourist-marker-label{animation:none!important}.tourist-marker.emergency .tourist-marker-inner{box-shadow:0 0 8px #f44c!important}.emergency-controls{box-shadow:0 4px 12px #0000004d,inset 0 0 0 2px #f44!important}.tourist-marker-inner.active{animation:none;background:#4caf50;box-shadow:0 0 8px #4caf50cc}.tourist-marker-inner.slow{animation:none;background:#ff9800;box-shadow:0 0 8px #ff9800cc}}@media (prefers-contrast:high){.tourist-marker.emergency .tourist-marker-inner{background-color:red!important;border:4px solid #fff!important}.tourist-marker.emergency .tourist-marker-label{background:red!important;border:3px solid #fff!important}.emergency-alert-banner{background-color:red;border-bottom:3px solid #fff}.participant-item.emergency{background-color:#f003!important;border:3px solid red!important}.tourist-marker-inner.active{background:#0a0!important;border:3px solid #fff!important}.tourist-marker-inner.slow{background:#f60!important;border:3px solid #fff!important}.tourist-marker-inner.inactive{background:#333!important;border:3px solid #fff!important}}.map-sidebar{background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;flex-shrink:0;max-width:320px;min-width:320px;overflow-y:auto;width:320px}.participants-panel{flex:1 1;padding:20px}.participants-panel h3{color:#333;font-size:18px;margin:0 0 15px}.participants-list{gap:10px}.participant-item{align-items:center;background:#f8f9fa;border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:12px;transition:all .2s}.participant-item:hover{background:#e3f2fd;transform:translateX(2px)}.participant-item.selected{background:#e3f2fd;border-color:#2196f3}.participant-item.active{border-left:4px solid #4caf50}.participant-item.slow{border-left:4px solid #ff9800}.participant-item.inactive{border-left:4px solid #757575;opacity:.7}.participant-info{align-items:center;display:flex;flex:1 1;gap:10px}.participant-avatar-small{border:2px solid #fff;border-radius:50%;box-shadow:0 1px 4px #0003;height:36px;object-fit:cover;width:36px}.participant-nickname{color:#333;font-size:14px;font-weight:600}.participant-real-name{color:#666;font-size:12px}.participant-status{align-items:flex-end;display:flex;flex-direction:column;gap:4px}.status-indicator{border:2px solid #fff;border-radius:50%;box-shadow:0 1px 3px #0003;height:12px;width:12px}.status-indicator.active{animation:pulse-small 2s infinite;background:#4caf50}.status-indicator.slow{background:#ff9800}.status-indicator.inactive{background:#757575}@keyframes pulse-small{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.distance{color:#666;font-size:11px;font-weight:600}.last-update{color:#999;font-size:10px}.no-location{color:#f44336;font-size:11px;font-weight:600}.status-legend{background:#f8f9fa;border-top:1px solid #e0e0e0;padding:15px 20px}.status-legend h4{color:#333;font-size:14px;margin:0 0 10px}.legend-item{align-items:center;color:#666;display:flex;font-size:12px;gap:8px;margin-bottom:6px}@media (max-width:768px){.map-sidebar{border-left:none;border-top:1px solid #e0e0e0;height:40%;max-width:100%!important;min-width:100%!important;width:100%!important}}@media (min-width:769px){.map-sidebar{flex-shrink:0!important;max-width:320px!important;min-width:320px!important;width:320px!important}}.chat-section{background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;height:100%;width:350px}.chat-header{justify-content:space-between}.chat-header,.close-chat{align-items:center;display:flex}.close-chat{background:none;border:none;color:#666;cursor:pointer;font-size:20px;height:24px;justify-content:center;padding:0;transition:color .2s;width:24px}.close-chat:hover{color:#333}.chat-messages{max-height:calc(100vh - 200px);padding:20px}.chat-message{background:#f8f9fa;border-left:3px solid #667eea;border-radius:8px;padding:12px}.chat-message .message-content{color:#333;font-size:14px;line-height:1.4;margin-bottom:4px}.chat-message .message-time{color:#999;font-size:11px}.broadcast-message-container{background:#fff3e0;border:2px solid #ff9800;border-radius:8px;margin-bottom:15px;padding:12px}.broadcast-message-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.broadcast-label{color:#f57c00;font-size:12px;font-weight:600}.broadcast-delete-button{background-color:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;font-weight:600;padding:4px 8px;text-transform:uppercase;transition:background-color .2s}.broadcast-delete-button:hover{background-color:#d32f2f}.broadcast-delete-button:active{background-color:#b71c1c}.broadcast-message-content{color:#333;font-size:14px;font-weight:600;line-height:1.4;margin-bottom:4px}.broadcast-message-time{color:#666;font-size:11px}.chat-input-form{background:#fff;border-top:1px solid #e0e0e0;display:flex;gap:10px;padding:15px 20px}.chat-input-form input{border:1px solid #e0e0e0;border-radius:6px;flex:1 1;font-size:14px;outline:none;padding:10px 12px;transition:border-color .2s}.chat-input-form input:focus{border-color:#667eea}.chat-input-form button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:background .2s}.chat-input-form button:hover:not(:disabled){background:#5a67d8}.chat-input-form button:disabled{background:#bbb;cursor:not-allowed}@media (max-width:768px){.chat-section{border-left:none;border-top:1px solid #e0e0e0;height:50%;width:100%}}.participant-details-modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.participant-details-content{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-width:400px;padding:25px;width:90%}.participant-details-content h3{color:#333;margin:0 0 15px}.participant-details-content p{color:#666;margin:8px 0}.status-text{border-radius:3px;font-size:12px;font-weight:600;padding:2px 6px;text-transform:uppercase}.status-text.active{background:#e8f5e8;color:#4caf50}.status-text.slow{background:#fff3e0;color:#ff9800}.status-text.inactive{background:#f5f5f5;color:#757575}.participant-details-content button{background:#2196f3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;margin-top:15px;padding:10px 20px}.join-tour-page{align-items:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;max-height:100vh;min-height:100vh;overflow-y:auto;padding:20px}.join-tour-page::-webkit-scrollbar{width:8px}.join-tour-page::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.join-tour-page::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.join-tour-page::-webkit-scrollbar-thumb:hover{background:#ffffff80}.join-tour-page.error,.join-tour-page.loading{align-items:center;background:#f8f9fa}.error-container,.loading-container{margin:0 auto;text-align:center;width:100%}.loading-spinner{margin:0 auto 20px}.error-icon{margin-bottom:20px}.error-container h2{color:#f44336;font-size:24px;margin-bottom:15px}.error-container p{color:#666;line-height:1.5;margin-bottom:30px}.error-actions{gap:15px}.error-actions button{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:12px 24px;transition:transform .2s}.error-actions button:first-child{background:#667eea;color:#fff}.error-actions button:last-child{background:#757575;color:#fff}.error-actions button:hover{transform:translateY(-2px)}.join-tour-container{background:#fff;border-radius:16px;box-shadow:0 8px 25px #00000026;margin:20px auto;max-width:500px;padding:30px;position:relative;width:100%}.tour-header{margin-bottom:30px;text-align:center}.tour-status-badge{margin-bottom:15px}.status{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;letter-spacing:.5px;padding:6px 16px;text-transform:uppercase}.status.active{background:#ff5722;color:#fff}.status.scheduled{background:#667eea;color:#fff}.status.ended{background:#757575;color:#fff}.tour-header h1{color:#333;font-size:28px;font-weight:700;line-height:1.3;margin:0 0 10px}.tour-guide-info{color:#666;font-size:16px}.tour-guide-info strong{color:#333}.tour-details-card{background:#f8f9fa;border-radius:12px;margin-bottom:25px;padding:25px}.tour-description h3{color:#333;font-size:18px;margin:0 0 10px}.tour-description p{color:#666;line-height:1.6;margin-bottom:20px}.tour-info-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr}.info-item{align-items:flex-start;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;gap:12px;padding:12px}.meeting-point-item{border-left:4px solid #667eea}.info-icon{color:#667eea;font-size:16px;margin-top:2px;text-align:center;width:20px}.info-content{flex:1 1}.info-label{color:#666;display:block;font-size:12px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.info-value{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:6px}.distance{background:#667eea1a;border-radius:4px;color:#667eea;display:block;font-size:12px;font-weight:500;margin-top:4px;padding:4px 8px;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.distance.near{background:#4caf501a;color:#4caf50;font-weight:600}.location-warning{background:#ff98001a;border-radius:4px;color:#ff9800;display:block;font-size:11px;font-weight:500;margin-top:4px;padding:4px 8px;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.tour-full-badge{background:#f44336;border-radius:12px;color:#fff;display:inline-block;font-size:10px;font-weight:600;margin-top:4px;padding:2px 8px;text-transform:uppercase}.tour-live-info{border-top:1px solid #e0e0e0;margin-top:20px;padding-top:15px}.live-indicator{align-items:center;color:#ff5722;display:flex;font-size:14px;font-weight:600;gap:8px}.pulse-dot{animation:pulse 2s infinite;background:#ff5722;border-radius:50%;height:8px;width:8px}@keyframes pulse{0%{box-shadow:0 0 0 0 #ff5722b3;transform:scale(.95)}70%{box-shadow:0 0 0 10px #ff572200;transform:scale(1)}to{box-shadow:0 0 0 0 #ff572200;transform:scale(.95)}}.tour-guidelines{background:#f8f9fa;border-radius:12px;margin-bottom:25px;padding:20px}.tour-guidelines h3{color:#333;font-size:16px;font-weight:600;margin:0 0 15px}.tour-guidelines ul{color:#666;line-height:1.6;margin:0;padding-left:20px}.tour-guidelines li{margin-bottom:8px}.tour-guidelines li strong{color:#ff9800}.join-actions,.login-prompt{text-align:center}.login-prompt p{color:#666;font-size:16px;margin-bottom:20px}.login-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 28px;transition:transform .2s}.login-btn:hover{transform:translateY(-2px)}.join-controls{align-items:center;display:flex;flex-direction:column;gap:15px}.tour-full{background:#f443361a;border:1px solid #f4433633;border-radius:8px;color:#f44336;padding:20px;text-align:center}.tour-full p{margin:0 0 8px}.tour-full p:last-child{margin-bottom:0}.join-tour-btn{align-items:center;background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:8px;box-shadow:0 4px 15px #4caf504d;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:600;gap:10px;justify-content:center;min-width:200px;padding:16px 32px;transition:all .3s ease}.join-tour-btn:hover:not(:disabled){box-shadow:0 6px 20px #4caf5066;transform:translateY(-2px)}.join-tour-btn:disabled{background:#bbb;box-shadow:none;cursor:not-allowed}.join-tour-btn .loading-spinner.small{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;height:16px;width:16px}.tour-ended{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;color:#666;padding:20px;text-align:center}.tour-ended p{font-size:16px;margin:0 0 15px}.tour-ended button{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:transform .2s}.tour-ended button:hover{transform:translateY(-2px)}.error-message{background:#f443361a;border:1px solid #f4433633;border-radius:8px;color:#f44336;font-size:14px;margin-top:15px;padding:12px 16px;text-align:center}.debug-user-info{background:#fff;border:1px solid #ccc;border-radius:4px;font-size:12px;max-width:200px;padding:10px;position:fixed;right:10px;top:10px;z-index:9999}@media (max-width:768px){.join-tour-page{max-height:none;min-height:100vh;padding:10px}.join-tour-container{margin:10px auto;padding:20px}.tour-header h1{font-size:24px}.error-actions{flex-direction:column}.error-actions button{width:100%}.join-tour-btn{font-size:16px;padding:14px 24px;width:100%}.tour-guidelines{padding:15px}.tour-details-card{padding:20px}}.tour-participant-page{background:#f5f5f5;display:flex;flex-direction:column;height:100vh;overflow:hidden}.tour-participant-page.error,.tour-participant-page.loading{align-items:center;justify-content:center}.tour-participant-page.error{text-align:center}.tour-participant-page.error h2{color:#f44336;margin-bottom:20px}.tour-participant-page.error button{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin:5px;padding:12px 24px;transition:transform .2s}.tour-participant-page.error button:hover{transform:translateY(-2px)}.error-container,.loading-container{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 15px #0000001a;display:flex;flex-direction:column;margin:20px;max-width:400px;padding:40px}.loading-spinner{border:3px solid #f3f3f3;height:40px;margin-bottom:20px;width:40px}.error-actions{margin-top:20px}.tour-participant-container{background:#f5f5f5;display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-content{display:flex;flex:1 1;overflow:hidden}.participant-header{background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 1px 3px #00000014;min-height:60px;padding:10px 20px;position:relative;z-index:100}.header-content,.participant-header{align-items:center;display:flex;justify-content:space-between}.header-content{flex:1 1}.header-content h1{color:#333;font-size:18px;font-weight:700;line-height:1.2;margin:0}.tour-info{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.tour-info span{color:#666;font-size:13px;white-space:nowrap}.tour-info strong{color:#333}.emergency-indicator{animation:emergency-blink 1s infinite;background-color:#f44;border-radius:10px;color:#fff;font-size:11px;font-weight:700;padding:3px 8px}@keyframes emergency-blink{0%,50%{opacity:1}51%,to{opacity:.7}}.header-menu{margin-left:15px}.header-menu,.menu-toggle{align-items:center;display:flex;position:relative}.menu-toggle{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;height:36px;justify-content:center;min-width:36px;padding:6px 10px;transition:all .2s;z-index:1000}.menu-toggle:hover{background:#5a67d8;transform:scale(1.05)}.dropdown-menu{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 15px #00000026;isolation:isolate;margin-top:5px;min-width:280px;padding:12px;pointer-events:auto!important;position:absolute;right:0;top:100%;z-index:1000}.menu-section{border-bottom:1px solid #f0f0f0;margin-bottom:12px;padding-bottom:12px;position:relative;z-index:1001}.menu-section:last-of-type{border-bottom:none;margin-bottom:8px}.menu-section h4{color:#333;font-size:14px;font-weight:600;margin:0 0 8px}.status-item{align-items:center;color:#666;display:flex;font-size:12px;justify-content:space-between;margin-bottom:6px}.status-item.emergency{color:#f44;font-weight:600}.menu-actions{display:flex;flex-direction:column;gap:6px;position:relative;z-index:1001}.menu-action{-webkit-tap-highlight-color:transparent;align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:13px;font-weight:600;justify-content:center;min-height:36px;padding:8px 12px;pointer-events:auto!important;position:relative!important;text-align:left;touch-action:manipulation;transition:all .2s;-webkit-user-select:none;user-select:none;z-index:1001!important}.menu-action.emergency{background:#fff3e0;border:1px solid #ffcc02;color:#f57c00}.menu-action.emergency:hover{background:#ff5722;color:#fff;transform:translateY(-1px)}.menu-action.leave{background:#f5f5f5;border:1px solid #e0e0e0;color:#757575}.menu-action.leave:hover{background:#757575;color:#fff;transform:translateY(-1px)}.menu-overlay{background:#0000;bottom:0;cursor:default;left:0;position:fixed;right:0;top:0;z-index:999}.menu-actions .emergency-button{justify-content:center!important;padding:12px 16px!important;position:relative!important;text-align:center!important;z-index:1002!important}@media (min-width:769px){.participant-header{min-height:65px;padding:12px 20px}.header-content h1{font-size:19px}.tour-info{gap:20px}.menu-toggle{font-size:17px;height:38px;min-width:38px;padding:7px 11px}}@media (max-width:768px){.dropdown-menu{min-width:260px;padding:10px;right:5px}.menu-action{font-size:14px;min-height:44px;padding:10px 12px}.menu-actions{gap:8px}.header-menu{position:static}.dropdown-menu{left:10px;max-width:calc(100vw - 20px);min-width:0;min-width:auto;position:fixed;right:10px;top:70px}}.map-section{display:flex;flex:1 1;flex-direction:column;position:relative}.map-container{border:none;flex:1 1;position:relative}.floating-map-controls{bottom:120px;display:flex;flex-direction:column;gap:10px;position:absolute;right:20px;z-index:10}.floating-btn{align-items:center;background:#fff;border:none;border-radius:50%;box-shadow:0 4px 15px #0003;color:#333;cursor:pointer;display:flex;font-size:20px;height:50px;justify-content:center;transition:all .3s ease;width:50px}.floating-btn:hover:not(:disabled){background:#667eea;box-shadow:0 6px 20px #0000004d;color:#fff;transform:translateY(-2px)}.floating-btn:disabled{background:#f5f5f5;color:#ccc;cursor:not-allowed;opacity:.6}.location-btn{background:#2196f3;color:#fff}.location-btn:hover{background:#1976d2}.guide-btn{background:#ff5722;color:#fff}.guide-btn:hover:not(:disabled){background:#d84315}.tourist-view-guide-marker{cursor:pointer;position:relative}.guide-marker-inner{align-items:center;animation:pulse-guide 2s infinite;background:#ff5722;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #0000004d;display:flex;font-size:16px;height:32px;justify-content:center;width:32px}@keyframes pulse-guide{0%{box-shadow:0 0 0 0 #ff5722b3}70%{box-shadow:0 0 0 10px #ff572200}to{box-shadow:0 0 0 0 #ff572200}}.guide-marker-label{background:#000c;border-radius:4px;color:#fff;font-size:12px;font-weight:600;left:50%;padding:4px 8px;position:absolute;top:35px;transform:translateX(-50%);white-space:nowrap}.tourist-self-marker{cursor:pointer;position:relative}.self-marker-inner{align-items:center;animation:pulse-self 2s infinite;background:#2196f3;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #0000004d;display:flex;font-size:14px;height:28px;justify-content:center;width:28px}@keyframes pulse-self{0%{box-shadow:0 0 0 0 #2196f3b3}70%{box-shadow:0 0 0 8px #2196f300}to{box-shadow:0 0 0 0 #2196f300}}.self-marker-label{background:#000c;border-radius:4px;color:#fff;font-size:12px;font-weight:600;left:50%;padding:4px 8px;position:absolute;top:31px;transform:translateX(-50%);white-space:nowrap}.other-tourist-marker{cursor:pointer;position:relative}.other-marker-inner{align-items:center;background:#9c27b0;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #0000004d;color:#fff;display:flex;font-size:12px;height:24px;justify-content:center;width:24px}.other-marker-label{background:#000c;border-radius:4px;color:#fff;font-size:11px;font-weight:600;left:50%;padding:2px 6px;position:absolute;top:27px;transform:translateX(-50%);white-space:nowrap}.chat-panel{background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;position:relative;width:350px}.chat-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:15px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.chat-header h3{color:#333;font-size:16px;font-weight:600;margin:0}.chat-messages{background:#fff;flex:1 1;overflow-y:auto;padding:15px 20px}.no-messages{color:#666;font-style:italic;padding:40px 20px;text-align:center}.messages-list{display:flex;flex-direction:column;gap:12px}.message{background:#f8f9fa;border-left:3px solid #667eea;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:10px 12px}.broadcast-message{background:#fff3e0;border:2px solid #ff9800;border-radius:8px;margin-bottom:15px;padding:12px;position:-webkit-sticky;position:sticky;top:0;z-index:20}.broadcast-header{align-items:center;color:#f57c00;display:flex;font-size:12px;font-weight:600;justify-content:space-between;margin-bottom:8px}.broadcast-content{color:#333;font-size:14px;font-weight:600;margin-bottom:4px}.broadcast-time{color:#666;font-size:11px}.message-sender{color:#667eea;font-size:12px;font-weight:600;margin-bottom:4px}.message-content{color:#333;font-size:14px;line-height:1.4;margin-bottom:4px}.message-time{color:#999;font-size:11px}.chat-input{background:#fff;border-top:1px solid #e0e0e0;bottom:0;padding:15px 20px;position:-webkit-sticky;position:sticky;z-index:10}.message-form{display:flex;gap:10px}.message-form input{border:1px solid #e0e0e0;border-radius:8px;flex:1 1;font-size:14px;outline:none;padding:10px 12px;transition:border-color .2s}.message-form input:focus{border-color:#667eea}.message-form button{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:background .2s}.message-form button:hover:not(:disabled){background:#5a67d8}.message-form button:disabled{background:#bbb;cursor:not-allowed}.mobile-bottom-nav{background:#fff;border-top:1px solid #e0e0e0;display:none;gap:10px;padding:10px}.nav-btn{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:12px 8px;text-align:center;transition:all .2s}.nav-btn.active{background:#667eea;border-color:#667eea;color:#fff}.nav-btn:hover{background:#f0f0f0}.nav-btn.active:hover{background:#5a67d8}.participants-mobile-panel{background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;position:relative;width:100%}.participants-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:15px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.participants-header h3{color:#333;font-size:16px;font-weight:600;margin:0}.participants-content{background:#fff;flex:1 1;overflow-y:auto}.participants-list{display:flex;flex-direction:column;gap:12px}@media (max-width:768px){.main-content{position:relative}.map-section{bottom:0;left:0;position:absolute;right:0;top:0;z-index:1}.map-section.active{z-index:2}.chat-panel{bottom:0;left:0;position:absolute;right:0;top:0;transform:translateY(100%);transition:transform .3s ease;width:100%;z-index:1}.chat-panel.active{transform:translateY(0);z-index:2}.participants-mobile-panel{bottom:0;left:0;position:absolute;right:0;top:0;transform:translateY(100%);transition:transform .3s ease;width:100%;z-index:1}.participants-mobile-panel.active{transform:translateY(0);z-index:2}.mobile-bottom-nav{display:flex}.participant-header{min-height:auto;padding:8px 15px;z-index:300}.header-content{width:100%}.header-content h1{font-size:16px;line-height:1.2;margin:0 0 4px}.header-menu{align-self:flex-start;margin-top:0}.menu-toggle{border-radius:4px;font-size:16px;padding:6px 10px}.tour-info{flex-direction:row;flex-wrap:wrap;gap:12px;justify-content:flex-start;width:100%}.tour-info span{font-size:12px}.emergency-indicator{background-color:#f44;border-radius:8px;color:#fff;font-size:11px;font-weight:700;padding:2px 6px}.dropdown-menu{min-width:200px;position:absolute;right:0;top:100%;z-index:310}.floating-map-controls{bottom:110px;gap:8px;right:15px}.floating-btn{font-size:18px;height:45px;width:45px}.chat-header,.chat-input{padding:12px 15px}.chat-messages{padding:8px 15px}.message{padding:8px 10px}.message-form input{font-size:13px;padding:8px 10px}.message-form button{font-size:13px;padding:8px 12px}.participants-header{padding:12px 15px}.participants-content{padding:8px 0}.participants-list{gap:10px;padding:0 15px}}@media (max-width:480px){.floating-map-controls{bottom:100px;right:10px}.floating-btn{font-size:16px;height:40px;width:40px}.dropdown-menu{min-width:180px;padding:12px}.menu-action{font-size:13px;padding:8px 10px}.nav-btn{font-size:12px;padding:10px 6px}.participants-header{padding:10px 12px}.participants-list{gap:8px;padding:0 12px}}.emergency-button{-webkit-tap-highlight-color:rgba(255,255,255,.1);align-items:center;border:none;border-radius:8px;box-shadow:0 2px 8px #00000026;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;min-height:44px;overflow:hidden;padding:12px 16px;pointer-events:auto!important;position:relative;touch-action:manipulation;transition:all .3s ease;-webkit-user-select:none;user-select:none;width:100%;z-index:1001!important}.emergency-button:hover:not(:disabled){box-shadow:0 4px 12px #0003;transform:translateY(-1px);z-index:1002!important}.emergency-button:active:not(:disabled){box-shadow:0 2px 6px #00000026;transform:translateY(0)}.emergency-button:disabled{cursor:not-allowed;opacity:.6;pointer-events:none}.emergency-button.menu-action{margin-bottom:0;pointer-events:auto!important;position:relative!important;text-align:center!important;z-index:1001!important}.emergency-button .emergency-icon{align-items:center;display:flex;font-size:16px;justify-content:center;min-width:20px;pointer-events:none}.emergency-button .emergency-text{font-size:14px;font-weight:600;pointer-events:none;white-space:nowrap}.emergency-button.active{animation:emergency-resolved-pulse 2s ease-in-out infinite;background-color:#4caf50!important}.emergency-button:not(.active){background-color:#f44336!important}.emergency-button:not(.active):hover:not(:disabled){background-color:#d32f2f!important}.emergency-button.active:hover:not(:disabled){background-color:#388e3c!important}.emergency-button:not(.active){animation:emergency-alert-pulse 3s ease-in-out infinite}@keyframes emergency-alert-pulse{0%,to{box-shadow:0 2px 8px #00000026}50%{box-shadow:0 2px 8px #f4433666,0 0 0 2px #f4433633}}@keyframes emergency-resolved-pulse{0%,to{box-shadow:0 2px 8px #00000026}50%{box-shadow:0 2px 8px #4caf5066,0 0 0 2px #4caf5033}}.emergency-button:focus{box-shadow:0 0 0 3px #ffffff80,0 2px 8px #00000026;outline:none;z-index:1002!important}.emergency-button.loading{color:#0000;pointer-events:none;position:relative}.emergency-button.loading:after{animation:emergency-button-spin 1s linear infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;content:"";height:16px;left:50%;margin:-8px 0 0 -8px;position:absolute;top:50%;width:16px}@keyframes emergency-button-spin{to{transform:rotate(1turn)}}@media (max-width:768px){.emergency-button{font-size:15px;min-height:48px;padding:14px 18px}.emergency-button .emergency-icon{font-size:18px;min-width:22px}.emergency-button .emergency-text{font-size:15px}.emergency-button.menu-action{-webkit-tap-highlight-color:rgba(255,255,255,.1);touch-action:manipulation}}@media (prefers-contrast:high){.emergency-button{border:2px solid #fff}.emergency-button:not(.active){background-color:#c00!important}.emergency-button.active{background-color:#060!important}}@media (prefers-reduced-motion:reduce){.emergency-button,.emergency-button:after{animation:none!important;transition:none!important}}.qr-scanner-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.scanner-container{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:500px;overflow:hidden;width:100%}.scanner-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;position:relative;text-align:center}.back-btn{background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;left:20px;padding:8px 12px;position:absolute;top:50%;transform:translateY(-50%);transition:background-color .3s ease}.back-btn:hover{background:#ffffff4d}.scanner-header h1{font-size:24px;font-weight:600;margin:0 0 8px}.scanner-header p{font-size:14px;margin:0;opacity:.9}.scanner-content{padding:20px}.scanner-wrapper{margin-bottom:20px}#qr-scanner{background:#f8f9fa;border-radius:12px;overflow:hidden;width:100%}#qr-scanner video{border-radius:12px;height:auto!important;width:100%!important}#qr-scanner button{background:#667eea!important;border:none!important;border-radius:8px!important;color:#fff!important;cursor:pointer!important;margin:5px!important;padding:8px 16px!important}#qr-scanner button:hover{background:#5a67d8!important}.scanner-instructions{background:#f8f9fa;border-radius:12px;margin-top:15px;padding:15px;text-align:center}.scanner-instructions p{color:#666;font-size:14px;margin:5px 0}.scan-result{padding:30px 20px;text-align:center}.result-icon{font-size:48px;margin-bottom:15px}.scan-result h3{color:#4caf50;font-size:20px;margin:0 0 10px}.scan-result p{color:#666;margin:0 0 15px}.scanned-data{background:#e8f5e8;border-radius:8px;color:#2e7d32;font-size:14px;line-height:1.4;padding:15px;text-align:center;white-space:pre-line;word-break:break-word}.scan-result .loading-spinner{margin-top:15px}.scan-error{padding:30px 20px;text-align:center}.error-icon{font-size:48px;margin-bottom:15px}.scan-error h3{color:#f44336;font-size:20px;margin:0 0 10px}.scan-error p{color:#666;margin:0 0 20px}.error-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.manual-btn,.retry-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .3s ease}.manual-btn:hover,.retry-btn:hover{background:#5a67d8}.manual-btn{background:#6c757d}.manual-btn:hover{background:#5a6268}.scanner-tips{background:#f8f9fa;border-top:1px solid #e9ecef;padding:20px}.scanner-tips h3{color:#333;font-size:16px;margin:0 0 15px}.scanner-tips ul{margin:0 0 20px;padding-left:20px}.scanner-tips li{color:#666;font-size:14px;margin-bottom:5px}.manual-option{text-align:center}.manual-input-btn{background:#0000;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .3s ease}.manual-input-btn:hover{background:#667eea;color:#fff}@media (max-width:768px){.qr-scanner-page{padding:10px}.scanner-container{margin:0}.scanner-header{padding:15px}.scanner-header h1{font-size:20px}.scanner-content,.scanner-tips{padding:15px}.error-actions{align-items:center;flex-direction:column}.manual-btn,.retry-btn{min-width:120px}}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;display:inline-block;height:20px;margin-right:8px;width:20px}.camera-container{margin:20px 0;position:relative}.camera-container,.scanner-overlay{align-items:center;display:flex;justify-content:center}.scanner-overlay{bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0}.scanner-frame{border:2px solid #fff;border-radius:12px;box-shadow:0 0 0 9999px #00000080,inset 0 0 0 2px #007bff;height:250px;position:relative;width:250px}.scanner-frame:after,.scanner-frame:before{border:3px solid #007bff;content:"";height:20px;position:absolute;width:20px}.scanner-frame:before{border-bottom:none;border-right:none;left:-3px;top:-3px}.scanner-frame:after{border-left:none;border-top:none;bottom:-3px;right:-3px}.camera-controls{display:flex;justify-content:center;margin:15px 0}.camera-toggle-btn{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .2s}.camera-toggle-btn:hover{background:#0056b3}.camera-error{background:#f8f9fa;border-radius:12px;margin:20px 0;padding:40px 20px;text-align:center}.camera-error .error-icon{font-size:48px;margin-bottom:15px}.camera-error h3{color:#dc3545;margin-bottom:10px}.camera-error p{color:#6c757d;line-height:1.5;margin-bottom:20px}.scanner-wrapper{align-items:center;display:flex;flex-direction:column}@media (max-width:768px){.scanner-frame{height:200px;width:200px}.camera-container{margin:10px 0}.camera-toggle-btn{font-size:12px;padding:8px 16px}}.change-password-container{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;min-height:100vh;overflow-y:auto;padding:20px;position:relative}.change-password-header{align-items:center;display:flex;flex-shrink:0;gap:20px;margin-bottom:30px}.back-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;padding:12px;transition:all .3s ease;width:48px}.back-button:hover{background:#ffffff4d;box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.back-button i{font-size:1.2rem}.page-title{color:#fff;font-size:2rem;font-weight:600;margin:0;text-shadow:0 2px 4px #0000001a}.change-password-content{align-items:flex-start;display:flex;flex:1 1;justify-content:center;overflow-y:auto;padding-bottom:20px}.password-form-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border-radius:16px;box-shadow:0 10px 30px #0000001a;margin:auto;max-width:500px;padding:40px;position:relative;width:100%}.social-login-notice{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-left:4px solid #4a6cf7;border-radius:12px;color:#495057;font-size:14px;margin-bottom:30px;padding:20px}.social-login-notice p{font-weight:500;line-height:1.6;margin:0}.social-login-notice .setup-note{color:#6c757d;font-style:italic;font-weight:400;margin-top:12px}.change-password-container .password-form-container .password-form .form-group{display:flex!important;flex-direction:column!important;gap:2px!important;height:auto!important;margin-bottom:8px!important;max-height:none!important;min-height:0!important;overflow:visible!important;padding:0!important;position:relative!important}.change-password-container .password-form-container .password-form .form-group label{color:#333!important;font-size:.95rem!important;font-weight:600!important;height:auto!important;line-height:1.2!important;margin-bottom:4px!important;padding:0!important}.change-password-container .password-form-container .password-form .form-group .error-message{color:#e74c3c!important;display:block!important;font-size:.7rem!important;font-weight:500!important;height:auto!important;line-height:1.1!important;margin-bottom:0!important;margin-top:2px!important;max-height:20px!important;min-height:0!important;overflow:hidden!important;padding:0!important}.change-password-container .password-form-container .password-form .form-group .password-hint{color:#6c757d!important;font-size:.65rem!important;font-style:italic!important;height:auto!important;line-height:1.1!important;margin-bottom:0!important;margin-top:2px!important;max-height:16px!important;min-height:0!important;overflow:hidden!important;padding:0!important}.change-password-container .password-form-container .password-form .form-group .password-input-wrapper{align-items:center!important;display:flex!important;height:40px!important;margin:0!important;padding:0!important;position:relative!important;width:100%!important}.change-password-container .password-form-container .password-form .form-group .password-input-wrapper input,.change-password-container .password-form-container .password-form .form-group .password-input-wrapper input.error{background-color:#f8f9fa!important;border:2px solid #e1e5e9!important;border-radius:8px!important;box-sizing:border-box!important;font-size:.95rem!important;height:40px!important;line-height:1.2!important;margin:0!important;padding:8px 45px 8px 12px!important;transition:all .3s ease!important;width:100%!important}.change-password-container .password-form-container .password-form .form-group .password-input-wrapper input:focus{background-color:#fff!important;border-color:#4a6cf7!important;box-shadow:0 0 0 3px #4a6cf71a!important;outline:none!important}.change-password-container .password-form-container .password-form .form-group .password-input-wrapper input.error{background-color:#fdf2f2!important;border-color:#e74c3c!important}.change-password-container .password-form-container .password-form .form-group .password-input-wrapper input.error:focus{border-color:#e74c3c!important;box-shadow:0 0 0 3px #e74c3c1a!important}.password-toggle{align-items:center;background:none;border:none;border-radius:6px;color:#6c757d;cursor:pointer;display:flex;justify-content:center;padding:8px;position:absolute;right:12px;transition:all .2s ease;z-index:2}.password-toggle:hover{background-color:#4a6cf71a;color:#4a6cf7}.password-toggle:focus{color:#4a6cf7;outline:none}.password-toggle i{font-size:1rem}.error-message{color:#e74c3c;display:block;font-size:.75rem;font-weight:500;height:12px;line-height:1.1;margin-top:1px;overflow:hidden}.error-message:before{content:"⚠️";font-size:.65rem;margin-right:3px}.password-hint{color:#6c757d;font-size:.7rem;font-style:italic;height:12px;line-height:1.1;margin-top:1px;overflow:hidden}.change-password-container .password-form-container .password-form .form-actions{align-items:stretch!important;border-top:1px solid #e9ecef!important;box-sizing:border-box!important;clear:both!important;display:flex!important;flex-direction:row!important;gap:16px!important;justify-content:space-between!important;margin-top:24px!important;padding-top:20px!important;position:relative!important;width:100%!important}.change-password-container .password-form-container .password-form .form-actions .cancel-button,.change-password-container .password-form-container .password-form .form-actions .save-button{align-items:center!important;border:none!important;border-radius:12px!important;box-sizing:border-box!important;cursor:pointer!important;display:inline-flex!important;flex:1 1 50%!important;float:none!important;font-size:1rem!important;font-weight:600!important;gap:8px!important;height:48px!important;justify-content:center!important;margin:0!important;padding:14px 24px!important;position:static!important;text-align:center!important;transition:all .3s ease!important;vertical-align:top!important;width:calc(50% - 8px)!important}.cancel-button{background-color:#f8f9fa;border:2px solid #e1e5e9;color:#6c757d}.cancel-button:hover:not(:disabled){background-color:#e9ecef;border-color:#adb5bd;color:#495057;transform:translateY(-1px)}.save-button{background:linear-gradient(135deg,#4a6cf7,#667eea);box-shadow:0 4px 12px #4a6cf74d;color:#fff}.save-button:hover:not(:disabled){box-shadow:0 6px 16px #4a6cf766;transform:translateY(-1px)}.cancel-button:disabled,.save-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.save-button .fas.fa-spinner{animation:spin 1s linear infinite;margin-right:8px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (prefers-color-scheme:dark){.change-password-container{background:linear-gradient(135deg,#2d3748,#4a5568)}.password-form-container{background:#1a202c;color:#e2e8f0}.social-login-notice{background:linear-gradient(135deg,#2d3748,#4a5568);border-color:#4a5568;color:#e2e8f0}.social-login-notice .setup-note{color:#cbd5e0}.form-group label{color:#e2e8f0}.password-input-wrapper input{background-color:#2d3748;border-color:#4a5568;color:#e2e8f0}.password-input-wrapper input:focus{background-color:#374151;border-color:#667eea}.password-toggle{color:#a0aec0}.password-toggle:hover{background-color:#667eea1a;color:#667eea}.password-hint{color:#a0aec0}.cancel-button{background-color:#2d3748;border-color:#4a5568;color:#a0aec0}.cancel-button:hover:not(:disabled){background-color:#374151;color:#e2e8f0}}@media (max-width:768px){.change-password-container{min-height:100vh;padding:15px}.change-password-header{gap:15px;margin-bottom:25px}.back-button{height:42px;padding:10px;width:42px}.back-button i{font-size:1.1rem}.page-title{font-size:1.5rem}.password-form-container{border-radius:12px;padding:30px 20px}.form-group{min-height:80px}.form-actions{flex-direction:row;gap:12px;margin-top:25px}.cancel-button,.save-button{flex:1 1;max-width:none;min-width:100px}.social-login-notice{margin-bottom:25px;padding:16px}}@media (max-width:480px){.change-password-container{padding:10px}.change-password-header{gap:12px;margin-bottom:20px}.back-button{height:38px;padding:8px;width:38px}.back-button i{font-size:1rem}.page-title{font-size:1.3rem}.password-form-container{border-radius:10px;padding:25px 15px}.password-input-wrapper input{font-size:.95rem;padding:12px 45px 12px 14px}.form-group{gap:6px;min-height:75px}.form-group label{font-size:.9rem}.error-message,.password-hint{font-size:.75rem}.form-actions{flex-direction:row;gap:10px}.cancel-button,.save-button{flex:1 1;font-size:.95rem;min-width:80px;padding:12px 16px}.social-login-notice{font-size:13px;padding:14px}}@media (max-width:360px){.change-password-container{padding:8px}.password-form-container{padding:20px 12px}.form-actions{gap:10px}}@media (max-width:768px) and (orientation:landscape){.change-password-container{min-height:100vh;padding:10px 15px}.change-password-header{margin-bottom:15px}.password-form-container{padding:25px 20px}.form-group{min-height:70px}}body div#root div.change-password-container div.change-password-content div.password-form-container form.password-form div.form-group{align-items:normal!important;background:#0000!important;border:none!important;box-sizing:border-box!important;display:block!important;flex:none!important;flex-direction:row!important;flex-wrap:nowrap!important;height:auto!important;justify-content:normal!important;margin:0 0 6px!important;max-height:70px!important;min-height:0!important;overflow:visible!important;padding:0!important;position:static!important;width:100%!important}body div#root div.change-password-container div.change-password-content div.password-form-container form.password-form div.form-group label{align-items:normal!important;color:#333!important;display:block!important;flex:none!important;font-size:.9rem!important;font-weight:600!important;height:auto!important;justify-content:normal!important;line-height:1.1!important;margin:0 0 2px!important;max-height:20px!important;min-height:0!important;padding:0!important;width:100%!important}body div#root div.change-password-container div.change-password-content div.password-form-container form.password-form div.form-group div.password-input-wrapper{align-items:normal!important;background:#0000!important;border:none!important;display:block!important;flex:none!important;height:36px!important;justify-content:normal!important;margin:0!important;max-height:36px!important;min-height:36px!important;overflow:visible!important;padding:0!important;position:relative!important;width:100%!important}body div#root div.change-password-container div.change-password-content div.password-form-container form.password-form div.form-group div.password-input-wrapper input{align-items:normal!important;background-color:#f8f9fa!important;border:2px solid #e1e5e9!important;border-radius:6px!important;box-sizing:border-box!important;display:block!important;flex:none!important;font-size:.9rem!important;height:36px!important;justify-content:normal!important;line-height:1.1!important;margin:0!important;max-height:36px!important;min-height:36px!important;padding:6px 40px 6px 10px!important;width:100%!important}body div#root div.change-password-container div.change-password-content div.password-form-container form.password-form div.form-group div.password-input-wrapper input.error{background-color:#fdf2f2!important;border-color:#e74c3c!important}body div#root div.change-password-container div.change-password-content div.password-form-container form.password-form div.form-group span.error-message{color:#e74c3c!important;font-size:.7rem!important;max-height:14px!important}body div#root div.change-password-container div.change-password-content div.password-form-container form.password-form div.form-group small.password-hint,body div#root div.change-password-container div.change-password-content div.password-form-container form.password-form div.form-group span.error-message{align-items:normal!important;background:#0000!important;border:none!important;display:block!important;flex:none!important;height:auto!important;justify-content:normal!important;line-height:1!important;margin:1px 0 0!important;min-height:0!important;overflow:hidden!important;padding:0!important;width:100%!important}body div#root div.change-password-container div.change-password-content div.password-form-container form.password-form div.form-group small.password-hint{color:#6c757d!important;font-size:.65rem!important;max-height:12px!important}body div#root div.change-password-container div.change-password-content div.password-form-container form.password-form div.form-actions{align-items:center!important;border-top:1px solid #e9ecef!important;clear:both!important;display:flex!important;flex-direction:row!important;gap:16px!important;height:auto!important;justify-content:space-between!important;margin:16px 0 0!important;max-height:60px!important;min-height:48px!important;overflow:hidden!important;padding:16px 0 0!important;position:relative!important;width:100%!important}body div#root div.change-password-container div.change-password-content div.password-form-container form.password-form div.form-actions button{border-radius:8px!important;box-sizing:border-box!important;display:inline-block!important;flex:1 1 auto!important;float:none!important;font-size:.9rem!important;font-weight:600!important;height:44px!important;margin:0!important;max-height:44px!important;min-height:44px!important;padding:10px 16px!important;position:static!important;vertical-align:top!important;width:calc(50% - 8px)!important}body{background-color:#fff;color:#333;font-family:Arial,sans-serif;height:100%;margin:0;overflow:hidden}#root,body,html{height:100%;margin:0;padding:0}#root>div{display:flex;flex-direction:column;height:100%}header{background:#35495e;color:#5a5353;flex:0 0 auto;padding:10px 0;text-align:center}main{flex:1 1 auto;overflow:hidden}.container{margin:auto;overflow:hidden;padding:20px;width:80%}.button{background:#35495e;border:none;color:#fff;cursor:pointer;display:inline-block;padding:10px 20px;transition:background .3s ease}.button:hover{background:#3a6073}.gm-style-iw button{display:none!important}
/*# sourceMappingURL=main.c287e468.css.map*/