@charset "UTF-8";.toast-container[data-v-896c945c]{position:fixed;bottom:30px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast-item[data-v-896c945c]{pointer-events:auto;display:flex;align-items:center;gap:12px;padding:12px 24px;border-radius:50px;font-weight:700;font-size:1rem;box-shadow:0 5px 15px #0003;cursor:pointer;min-width:200px;justify-content:center}.toast-item[data-v-896c945c]{background:linear-gradient(135deg,#4caf50,#2e7d32);color:#fff}.toast-item.error[data-v-896c945c]{background:linear-gradient(135deg,#d32f2f,#b71c1c);color:#fff}.toast-item.point[data-v-896c945c]{background:linear-gradient(135deg,gold,orange);color:#000;border:2px solid #fff}.spinning[data-v-896c945c]{animation:spin-896c945c 2s infinite linear;display:inline-block}@keyframes spin-896c945c{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.toast-enter-from[data-v-896c945c],.toast-leave-to[data-v-896c945c]{opacity:0;transform:translateY(30px) scale(.9)}.toast-enter-active[data-v-896c945c],.toast-leave-active[data-v-896c945c]{transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.toast-leave-active[data-v-896c945c]{position:absolute}:root{--white: #ffffff;--black: #081723;--primary: #00c3cd;--primary-dark: #018187;--secondary: #0a1e2d;--tertiary: #ff7d00;--secondary-dark: #04121e;--success: #00c387;--gray: #d5d5d5;--gray-light: #f2f2f2;--gray-lighter: #f8f8f8;--gray-dark: #a2a2a2;--swiper-navigation-color: var(--white);--link-color: var(--primary);--link-hover-color: var(--primary);--text-dark: var(--white);--text-light: var(--white);--button-bg-color: var(--primary);--button-text-color: var(--secondary);--button-border-color: var(--primary);--button-bg-color-hover: transparent;--button-text-color-hover: var(--primary);--button-border-color-hover: var(--primary);--button-bg-color-active: transparent;--button-text-color-active: var(--primary);--button-border-color-active: var(--primary)}body{font-family:univia-pro,Arial,sans-serif;margin:0;padding:0;color:var(--text-light);background:var(--secondary)}h1,h2,h3{color:var(--primary);margin-top:0}ul{padding:0;list-style:none}.loading-state{color:var(--text-light);font-style:italic;padding:40px}.btn{display:inline-flex;flex-direction:column;justify-content:center;align-items:center;padding:12px 20px;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s;text-decoration:none;width:100%}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.btn:active{transform:scale(.98)}.btn.guest-btn{background:#fff;color:#2c3e50;border:1px solid #ddd}.btn.oauth-btn,.btn.login-btn,.btn.confirm-btn{background:var(--primary);color:#fff}.btn.confirm-btn:disabled{background:#ccc;cursor:not-allowed;transform:none}.btn.logout-btn{width:auto;padding:5px 12px;font-size:.8rem;background:#fff3;color:#fff}.btn.logout-btn:hover{background:#ffffff4d;transform:none}.card,.status-card,.challenge-card{background:var(--secondary);border-radius:12px;padding:20px;box-shadow:0 4px 6px #0000001a;margin-bottom:20px}.status-card{color:#fff}.status-card.registered{background:linear-gradient(135deg,var(--primary),var(--primary-dark))}.status-card.demo{background:var(--secondary-dark)}.status-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.challenge-card{border:1px solid #eee;cursor:pointer;transition:all .2s}.challenge-card:hover{transform:translateY(-3px)}.challenge-card.locked{opacity:.5;cursor:not-allowed}.challenge-card .progress-bg{height:10px;background:#eee;border-radius:5px;overflow:hidden;margin-top:10px}.challenge-card .progress-bg .progress-fill{height:100%;background:var(--tertiary);transition:width .6s ease}.challenge-card .progress-bg .progress-fill.fill-green{background:var(--success)}.info-text{font-size:.8rem;margin-bottom:15px}.spot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;padding-top:20px}.spot-test-card{background:var(--primary);border-radius:8px;padding:15px;text-align:center;cursor:pointer;transition:transform .1s,background .2s;border:1px solid var(--primary);-webkit-user-select:none;user-select:none}.spot-test-card:hover{background:transparent;border-color:var(--primary);color:var(--primary)}.spot-test-card:hover h4{color:var(--primary)}.spot-test-card:active{background:transparent;border-color:var(--primary);color:var(--primary)}.spot-test-card:active h4{color:var(--primary)}.spot-test-card h4{margin:0;font-size:.9rem;color:var(--text-light)}.points-area{margin-top:15px;background:#ffffff1a;padding:10px 15px;border-radius:8px;display:flex;flex-direction:column;align-items:center}.points-area .label{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;opacity:.8}.points-area .value{font-size:2.5rem;font-weight:800;line-height:1;margin-top:5px}.install-banner{position:fixed;bottom:20px;left:50%;transform:translate(-50%);width:90%;max-width:400px;background:#222;border:1px solid #444;border-radius:12px;padding:12px 20px;box-shadow:0 10px 25px #00000080;z-index:10000;animation:slideUp .5s ease-out}.install-banner .install-content{display:flex;align-items:center;justify-content:space-between;color:var(--white);font-weight:700}.install-banner .btn-group{display:flex;align-items:center;gap:10px}.install-banner .install-btn{background:var(--primary);color:var(--secondary);border:none;padding:6px 14px;border-radius:6px;font-weight:700;cursor:pointer;font-size:.9rem}.install-banner .install-btn:hover{opacity:.9}.install-banner .close-btn{background:transparent;border:none;color:#888;font-size:1.2rem;cursor:pointer;padding:0 5px}.install-banner .close-btn:hover{color:var(--white)}@keyframes slideUp{0%{transform:translate(-50%,100px);opacity:0}to{transform:translate(-50%);opacity:1}}.landing-page{padding:40px 20px;text-align:center;max-width:400px;margin:0 auto}.landing-page .logo-area{margin-bottom:40px}.landing-page .logo-area h1{font-size:2.5rem;margin-bottom:10px}.landing-page .logo-area .subtitle{color:var(--text-light);font-size:1.1rem}.landing-page .divider{margin:20px 0;color:var(--text-light);font-size:.8rem;letter-spacing:1px}.landing-page .form-area h3{margin-bottom:10px}.landing-page .form-area p{margin-bottom:5px;color:var(--text-light)}.landing-page .form-area input{width:100%;padding:12px;font-size:1.1rem;border:2px solid var(--primary);color:var(--primary);border-radius:8px;background:transparent;margin-top:10px;text-align:center;box-sizing:border-box}.landing-page .form-area input:focus{border-color:var(--primary);outline:none}.landing-page .form-area .btn-row{display:flex;flex-direction:column;justify-content:space-between;align-items:center;margin-top:20px;gap:10px}.landing-page .form-area .btn-text{background:none;border:none;color:var(--primary);cursor:pointer;text-decoration:underline}.landing-page .actions .small{font-size:.75rem;font-weight:400;opacity:.8;margin-top:4px}.dashboard{padding-bottom:60px}.dashboard .welcome-card{margin-bottom:30px}.dashboard .welcome-card .welcome-img{width:100%;max-height:200px;object-fit:cover;border-radius:12px;margin-bottom:10px}.dashboard .welcome-card .welcome-text{font-size:1.1rem;color:#666}.dashboard .empty-state{text-align:center;padding:30px;color:#666;background:#fff;border-radius:12px;border:1px dashed #ccc}.challenge-detail{text-align:left;padding-bottom:50px}.challenge-detail .back-btn{margin-bottom:20px;background:#ddd;color:#2c3e50;border:none;padding:8px 15px;border-radius:5px;cursor:pointer}.challenge-detail .back-btn:hover{background:#ccc}.challenge-detail .success-banner{background:gold;color:#333;padding:15px;border-radius:12px;margin-bottom:20px;border:2px solid #b8860b;text-align:center;animation:popIn .5s ease}.challenge-detail .description{color:#666;line-height:1.6;margin-bottom:20px}.challenge-detail .progress-info{margin:20px 0;font-weight:700}.challenge-detail .progress-info .progress-bar-bg{height:10px;background:#eee;border-radius:5px;overflow:hidden;margin-top:5px}.challenge-detail .progress-info .progress-bar-bg .progress-bar-fill{height:100%;background:#2e7d32;transition:width .5s ease}.challenge-detail .spot-list{list-style:none;padding:0;margin-top:20px}.challenge-detail .spot-list li{border:1px solid var(--primary);padding:15px;border-radius:8px;margin-bottom:10px;background:transparent;transition:background .3s}.challenge-detail .spot-list li.done{background:var(--success);border-color:var(--success)}.challenge-detail .spot-list li.done .spot-row .checkin-btn{background:var(--secondary)}.challenge-detail .spot-list li .spot-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.challenge-detail .spot-list li .spot-row .spot-name{font-size:1rem}.challenge-detail .spot-list li .spot-row .checkin-btn{font-size:.8rem;padding:6px 12px;background:transparent;color:var(--text-light);border-radius:4px;cursor:pointer;border:1px solid var(--primary);font-weight:700}.challenge-detail .spot-list li .spot-row .checkin-btn:hover{background:var(--primary)}.challenge-detail .error{text-align:center;margin-top:50px;color:#d32f2f}@keyframes popIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.scan-page{text-align:center;padding:40px 20px;min-height:60vh;display:flex;flex-direction:column;justify-content:center;align-items:center}.scan-page .pulse-icon{font-size:4rem;margin-bottom:20px;animation:pulse 1.5s infinite ease-in-out}.scan-page h2{margin-bottom:10px;color:var(--primary)}.scan-page p{color:var(--text-light);margin-bottom:30px}.scan-page .auth-required{width:100%;max-width:350px}.scan-page .auth-required .icon{font-size:3rem;margin-bottom:10px}.scan-page .auth-required .actions{display:flex;flex-direction:column;gap:15px}.scan-page .auth-required .divider{font-size:.8rem;opacity:.5;margin:5px 0}.scan-page .auth-required .login-box{display:flex;gap:10px}.scan-page .auth-required .login-box input{flex:1;padding:10px;border-radius:8px;border:1px solid var(--primary);background:transparent;color:var(--primary)}.scan-page .auth-required .login-box input:focus{outline:none;box-shadow:0 0 5px var(--primary)}.scan-page .auth-required .login-box button{white-space:nowrap}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}to{transform:scale(1);opacity:1}}
