@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;700&display=swap";:root{--primary:#0ea5e9;--primary-glow:#0ea5e94d;--secondary:#10b981;--bg-dark:#f8fafc;--bg-light:#fff;--text-main:#0f172a;--text-muted:#64748b;--glass-bg:#fff6;--glass-border:#0f172a14;--font-main:"Outfit", system-ui, -apple-system, sans-serif;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-main);background-color:var(--bg-dark);color:var(--text-main);min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:inherit;transition:var(--transition);text-decoration:none}ul{list-style:none}button{cursor:pointer;transition:var(--transition);background:0 0;border:none;font-family:inherit}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}body:before{content:"";z-index:-1;pointer-events:none;background:radial-gradient(circle,#0ea5e926 0%,#0000 70%);width:70%;height:70%;position:fixed;top:-10%;right:-10%}body:after{content:"";z-index:-1;pointer-events:none;background:radial-gradient(circle,#10b9811a 0%,#0000 70%);width:50%;height:50%;position:fixed;bottom:-10%;left:-10%}.header{background-color:var(--glass-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--glass-border);z-index:1000;align-items:center;width:100%;height:80px;padding:0 40px;display:flex;position:sticky;top:0;overflow:hidden}.header-banner-bg{z-index:-1;opacity:.9;filter:blur(2px)brightness(.95);background-position:50%;background-size:cover;transition:opacity .5s;position:absolute;inset:0;transform:scale(1.03)}.header-container{justify-content:space-between;align-items:center;gap:20px;width:100%;max-width:1400px;margin:0 auto;display:flex}.header-left{flex-shrink:0}.logo{letter-spacing:-.5px;background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 8px #00000040);transition:var(--transition);-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:700}.logo:hover{filter:brightness(1.2);transform:scale(1.05)}.header-center{flex:1;max-width:600px;margin:0 20px}.ticker-container{border:1px solid var(--glass-border);background:#0f172a0a;border-radius:8px;align-items:center;width:100%;height:40px;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #00000008}.ticker-text{white-space:nowrap;color:var(--primary);text-shadow:0 0 10px var(--primary-glow);will-change:transform;padding-left:100%;font-family:Courier New,Courier,monospace;font-size:16px;font-weight:600;animation:20s linear infinite ticker-scroll;display:inline-block;position:relative}@keyframes ticker-scroll{0%{transform:translate(0)}to{transform:translate(-100%)}}.header-right{flex-shrink:0;align-items:center;gap:32px;display:flex}.shop-link-container{align-items:center;display:flex}.shop-link{background:#0ea5e90d;border:1px solid #0000;border-radius:12px;align-items:center;gap:10px;padding:8px 16px;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.shop-icon{width:22px;height:22px;color:var(--primary);filter:drop-shadow(0 2px 4px #0006);transition:transform .3s}.shop-text{color:var(--primary);letter-spacing:1.2px;text-shadow:0 1px 3px #0006;transition:var(--transition);font-size:14px;font-weight:800}.shop-link:hover{border-color:var(--glass-border);background:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0ea5e91a}.shop-link:hover .shop-icon{transform:scale(1.1)rotate(-5deg)}.shop-link:hover .shop-text{letter-spacing:2px}.user-info-container{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.points-display{border:1px solid var(--glass-border);color:var(--text-main);white-space:nowrap;background:#fff;border-radius:9px;align-items:center;padding:6px 14px;font-size:13px;font-weight:700;display:flex;box-shadow:0 2px 8px #0000000a}.points-value{color:var(--primary);margin-left:6px;font-size:16px;font-weight:800}.auth-links{color:var(--text-muted);white-space:nowrap;align-items:center;gap:8px;padding-right:4px;font-size:12px;font-weight:600;display:flex}.admin-link,.auth-link{color:var(--primary);transition:var(--transition);white-space:nowrap;text-decoration:none}.admin-link{color:var(--primary);font-weight:800}.admin-link:hover,.auth-link:hover{color:var(--primary);text-decoration:underline}.admin-link,.auth-link,.auth-link-button{text-shadow:0 1px 4px #0006}.auth-link-button{color:var(--primary);cursor:pointer;transition:var(--transition);background:0 0;border:none;padding:0;font-size:12px;font-weight:600}.auth-link-button:hover{color:var(--primary);text-decoration:underline}.divider{color:var(--glass-border);font-size:10px}.ticker-text.hijacked{justify-content:center;width:100%;padding-left:0;animation:none;display:flex;position:relative;left:0;transform:none}.ticker-text.exiting{animation:.8s cubic-bezier(.4,0,.2,1) forwards ticker-exit}@keyframes ticker-exit{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-100%)}}.system-message{color:#ef4444;letter-spacing:1px;text-shadow:0 0 12px #ef44444d;font-weight:800}@media (width<=900px){.header-center{max-width:400px}}@media (width<=768px){.header{height:auto;padding:15px 20px 0}.header-container{flex-direction:column;gap:10px}.header-center{width:100%;max-width:100%}}.ad-banner-container{text-align:center;max-width:1200px;margin:0 auto 10px}.ad-label{color:var(--text-muted);opacity:.4;text-transform:uppercase;letter-spacing:.5px;margin:0;font-size:9px;font-weight:700;position:absolute;top:6px;left:14px}.pseudo-ad{background:var(--glass-bg);border:1px dashed var(--glass-border);width:100%;height:80px;color:var(--text-main);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex;position:relative;box-shadow:inset 0 2px 10px #00000005}.ad-text{letter-spacing:2px;font-weight:800;color:var(--primary)!important;opacity:1!important}@media (width<=1200px){.ad-banner-container{padding:0 40px}}.game-carousel-section{width:100%;padding:60px 40px;position:relative;overflow:hidden}.carousel-wrapper{max-width:1200px;margin:0 auto;position:relative}.carousel-container{width:100%;height:480px;position:relative}.carousel-slide{opacity:0;visibility:hidden;width:100%;height:100%;transition:opacity .6s ease-in-out,transform .6s ease-in-out;position:absolute;top:0;left:0;transform:translate(20px)}.carousel-slide.active{opacity:1;visibility:visible;transform:translate(0)}.game-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:24px;width:100%;height:100%;display:flex;overflow:hidden;box-shadow:0 15px 40px #0000000d}.card-left{border-right:1px solid var(--glass-border);flex:0 0 280px;height:100%;overflow:hidden}.cover-img{object-fit:cover;width:100%;height:100%;transition:transform .5s}.game-card:hover .cover-img{transform:scale(1.05)}.card-middle{border-right:1px solid var(--glass-border);background:#000;flex:1;height:100%;position:relative}.screenshot-container{width:100%;height:100%;position:relative}.screenshot-img{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity 1s ease-in-out;position:absolute;top:0;left:0}.screenshot-img.visible{opacity:1}.card-right{background:#fff3;flex-direction:column;flex:0 0 320px;justify-content:center;padding:32px;display:flex}.game-title{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:20px;font-size:28px;font-weight:800;line-height:1.2}.overview-label{color:var(--primary);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;font-size:12px;font-weight:700}.description-body{color:var(--text-main);opacity:.8;margin-bottom:32px;font-size:14px;line-height:1.7}.card-actions{flex-direction:column;gap:12px;display:flex}.btn-detail,.btn-play{transition:var(--transition);border-radius:12px;padding:12px 24px;font-size:14px;font-weight:600}.btn-detail{border:1px solid var(--primary);color:var(--primary)}.btn-detail:hover{background:var(--primary);color:#fff}.btn-play{background:var(--primary);color:#fff;box-shadow:0 4px 15px var(--primary-glow)}.btn-play:hover{filter:brightness(1.1);box-shadow:0 8px 25px var(--primary-glow);transform:translateY(-2px)}.carousel-nav{border:1px solid var(--glass-border);width:50px;height:50px;color:var(--text-main);cursor:pointer;z-index:10;transition:var(--transition);background:#fff;border-radius:25px;justify-content:center;align-items:center;font-size:20px;display:flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 4px 15px #0000000d}.carousel-nav:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.carousel-nav.prev{left:-25px}.carousel-nav.next{right:-25px}.carousel-dots{justify-content:center;gap:12px;margin-top:30px;display:flex}.dot{background:var(--text-muted);opacity:.3;cursor:pointer;height:10px;transition:var(--transition);border-radius:5px;flex:none;width:10px!important}.dot.active{background:var(--primary);opacity:1;width:30px}@media (width<=1024px){.game-carousel-section{padding:30px 15px}.carousel-container{height:380px}.game-card{border-radius:16px;flex-direction:row;height:100%}.card-left{border-right:1px solid var(--glass-border);border-bottom:none;flex:0 0 140px}.card-middle{display:none}.card-right{background:0 0;border-bottom:none;flex:1;padding:20px}.game-title{margin-bottom:12px;font-size:20px}.overview-label{letter-spacing:1px;margin-bottom:4px;font-size:9px}.description-body{-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;margin-bottom:15px;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.card-actions{flex-direction:row;gap:8px}.btn-detail,.btn-play{white-space:nowrap;text-align:center;flex:1;padding:10px 12px;font-size:12px}.carousel-nav{display:none}}@media (width<=480px){.carousel-container{height:320px}.card-left{flex:0 0 110px}.card-right{padding:15px}.game-title{font-size:18px}}.game-list-section{max-width:1280px;margin:0 auto;padding:40px}.list-header-container{margin-bottom:40px}.list-title-bar{background:linear-gradient(90deg, var(--primary) 0%, #0ea5e900 100%);border-left:6px solid #0284c7;border-radius:0 40px 40px 0;width:60%;padding:10px 40px;position:relative;overflow:hidden}.list-title{color:#fff;letter-spacing:2px;margin:0;font-size:20px;font-weight:700}.game-grid{grid-template-columns:repeat(3,1fr);gap:32px;display:grid}.game-item{cursor:pointer;flex-direction:column;gap:12px;display:flex}.game-cover-wrapper{aspect-ratio:16/9;border:1px solid var(--glass-border);background:#000;border-radius:16px;width:100%;position:relative;overflow:hidden;box-shadow:0 4px 20px #0000000d}.game-cover{object-fit:cover;width:100%;height:100%;transition:transform .5s}.cover-overlay{opacity:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0ea5e94d;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .3s;display:flex;position:absolute;top:0;left:0}.play-icon{color:#fff;font-size:40px;transition:transform .3s cubic-bezier(.175,.885,.32,1.275);transform:scale(.5)}.game-item:hover .game-cover{transform:scale(1.1)}.game-item:hover .cover-overlay{opacity:1}.game-item:hover .play-icon{transform:scale(1)}.game-item-title{color:var(--text-main);margin:0;padding-left:4px;font-size:16px;font-weight:700}.view-all-wrapper{border:1px solid #fff3;justify-content:center;align-items:center;display:flex;background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%)!important}.view-all-content{color:#fff;text-align:center;z-index:1;flex-direction:column;align-items:center;gap:12px;display:flex}.plus-icon{opacity:.9;font-size:40px;font-weight:300;line-height:1}.view-all-text{letter-spacing:1px;opacity:.9;font-size:14px;font-weight:700}.view-all-title{opacity:.8;letter-spacing:1px;color:var(--primary)!important}@media (width<=900px){.game-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.game-grid{grid-template-columns:1fr}.list-title-bar{width:90%}}.home-page{width:100%;padding-top:0}.hero{text-align:center;flex-direction:column;align-items:center;gap:24px;max-width:1280px;margin:0 auto;padding:100px 40px;animation:1s ease-out fadeIn;display:flex}.hero-title{letter-spacing:-2px;max-width:800px;color:var(--text-main);font-size:72px;font-weight:700;line-height:1.1}.accent{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--text-muted);max-width:600px;margin-bottom:12px;font-size:20px;font-weight:500}.hero-actions{gap:20px;display:flex}.btn{cursor:pointer;border-radius:14px;align-items:center;gap:8px;padding:16px 36px;font-size:16px;font-weight:600;display:flex;box-shadow:0 4px 15px #0000000d}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, #0ea5e9 100%);color:#fff;border:none}.btn-primary:hover{filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 8px 25px #0ea5e933}.btn-secondary{color:var(--text-main);border:1px solid var(--glass-border);background:#fff}.btn-secondary:hover{background:#f8fafc;transform:translateY(-2px);box-shadow:0 8px 25px #0000000d}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.hero-title{font-size:48px}.hero{padding:60px 20px}.hero-actions{flex-direction:column;gap:12px;width:100%}.btn{justify-content:center;width:100%}}.verify-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);text-align:center;border-radius:24px;width:100%;max-width:480px;padding:60px 40px;animation:.6s cubic-bezier(.2,.8,.2,1) slideInSignUp;box-shadow:0 10px 40px #0000000d}.verify-title{color:var(--text-main);margin-bottom:12px;font-size:28px;font-weight:800}.verify-description{color:var(--text-muted);margin-bottom:40px;font-size:15px;line-height:1.6}.masked-email{color:var(--primary);background:#0ea5e90d;border-radius:8px;margin-top:8px;padding:4px 12px;font-weight:600;display:inline-block}.code-input-container{justify-content:center;gap:12px;margin-bottom:30px;display:flex}.code-input-box{border:2px solid var(--glass-border);text-align:center;width:45px;height:60px;color:var(--text-main);background:#fff;border-radius:12px;outline:none;font-size:24px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1)}.code-input-box:focus{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 0 15px #0ea5e926}.verify-error{color:#ef4444;background:#ef44440d;border:1px solid #ef44441a;border-radius:8px;margin-bottom:20px;padding:10px;font-size:14px;animation:.4s shake}.verify-info{border-top:1px solid var(--glass-border);margin-top:20px;padding-top:30px}.timer-text{color:var(--text-muted);margin-bottom:16px;font-size:14px}.time-highlight{color:var(--primary);font-family:monospace;font-size:16px;font-weight:700}.resend-link{color:var(--primary);cursor:pointer;opacity:.8;background:0 0;border:none;font-size:14px;font-weight:600;text-decoration:underline;transition:opacity .2s}.resend-link:hover{opacity:1}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes slideInSignUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width<=480px){.code-input-box{width:38px;height:50px;font-size:20px}}.signup-page{background:radial-gradient(circle at 0 0,#0ea5e90d 0%,#0000 40%),radial-gradient(circle at 100% 100%,#10b9810d 0%,#0000 40%);justify-content:center;align-items:center;min-height:calc(100vh - 100px);padding:60px 20px;display:flex}.signup-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:24px;width:100%;max-width:480px;padding:48px;animation:.6s cubic-bezier(.2,.8,.2,1) slideUp;box-shadow:0 20px 50px #0000000d}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.signup-title{color:var(--text-main);text-align:center;margin-bottom:12px;font-size:32px;font-weight:800}.signup-subtitle{color:var(--text-muted);text-align:center;margin-bottom:40px;font-size:15px}.signup-form{flex-direction:column;gap:24px;display:flex}.form-group input[type=email],.form-group input[type=password]{border:1.5px solid var(--glass-border);width:100%;color:var(--text-main);background:#fff;border-radius:12px;padding:14px 18px;font-size:16px;transition:all .3s}.form-group input:focus{border-color:var(--primary);outline:none;transform:translateY(-1px);box-shadow:0 0 0 4px #0ea5e91a}.password-input-wrapper input{padding-right:50px!important}.input-error{background-color:#ef444405!important;border-color:#ef4444!important}.localized-error{color:#ef4444;margin-top:4px;padding-left:4px;font-size:12px;font-weight:600;animation:.3s ease-out fadeInError}@keyframes fadeInError{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.checkbox-group{margin-top:8px}.checkbox-wrapper{cursor:pointer;align-items:center;gap:12px;display:flex}.checkbox-wrapper input[type=checkbox]{cursor:pointer;width:20px;height:20px;accent-color:var(--primary)}.checkbox-wrapper label{color:var(--text-muted);cursor:pointer;font-size:14px}.terms-link{color:var(--primary);cursor:pointer;font-weight:600;text-decoration:underline}.signup-button{cursor:pointer;border:none;border-radius:14px;width:100%;margin-top:12px;padding:18px;font-size:16px;font-weight:700;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.signup-button.active{background:linear-gradient(135deg, var(--primary) 0%, #0ea5e9 100%);color:#fff;box-shadow:0 10px 25px #0ea5e94d}.signup-button.active:hover{filter:brightness(1.1);transform:translateY(-3px);box-shadow:0 15px 35px #0ea5e966}.signup-button.inactive{color:#fff6;filter:grayscale(.5);cursor:default;background:#450a0a}.signup-button.inactive:hover{background:#7f1d1d}.error-bullet{color:#fff;background:#ef4444;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;font-weight:900;display:flex}.signup-footer{text-align:center;color:var(--text-muted);margin-top:32px;font-size:14px}.login-link{color:var(--primary);cursor:pointer;font-weight:700}.login-link:hover{text-decoration:underline}@media (width<=480px){.signup-card{padding:32px 20px}.signup-title{font-size:28px}}.terms-page{background:radial-gradient(circle at 10% 20%,#0ea5e908 0%,#0000 40%);justify-content:center;align-items:flex-start;min-height:calc(100vh - 100px);padding:80px 20px;display:flex}.terms-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:24px;width:100%;max-width:800px;padding:60px;animation:.6s cubic-bezier(.2,.8,.2,1) slideUp;box-shadow:0 10px 40px #0000000d}.terms-title{color:var(--text-main);text-align:center;margin-bottom:8px;font-size:32px;font-weight:800}.terms-date{color:var(--text-muted);text-align:center;margin-bottom:60px;font-size:14px}.terms-section{margin-bottom:40px}.terms-section h2{color:var(--primary);border-bottom:1.5px solid #0ea5e933;margin-bottom:16px;padding-bottom:8px;font-size:18px;font-weight:700;display:inline-block}.terms-section p{color:var(--text-main);opacity:.9;font-size:15px;line-height:1.8}.terms-section ul{margin-top:12px;padding-left:20px}.terms-section li{color:var(--text-main);opacity:.9;margin-bottom:8px;font-size:15px;line-height:1.8;list-style:square}.terms-footer{justify-content:center;margin-top:60px;display:flex}.back-button{color:var(--text-main);border:1px solid var(--glass-border);cursor:pointer;background:#fff;border-radius:12px;padding:14px 40px;font-weight:600;transition:all .3s}.back-button:hover{background:#f8fafc;transform:translateY(-2px);box-shadow:0 4px 15px #0000000d}@media (width<=600px){.terms-container{padding:32px 20px}}.mypage-layout{background:0 0;flex-direction:column;min-height:calc(100vh - 80px);animation:.8s ease-out fadeInLayout;display:flex}@keyframes fadeInLayout{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mypage-menu{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);z-index:10;padding:0;position:sticky;top:0}.menu-container{justify-content:space-between;width:100%;max-width:1280px;margin:0 auto;display:flex}.menu-tab{height:64px;color:var(--text-sub);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:0;transition:all .3s;display:flex;position:relative;overflow:hidden}.tab-text{z-index:2;letter-spacing:.01em;margin-top:2px;font-size:12px;font-weight:700;position:relative}.tab-icon-bg{z-index:1;opacity:.12;color:var(--text-sub);transition:all .4s cubic-bezier(.4,0,.2,1);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.tab-icon-bg svg{width:32px;height:32px}.menu-tab:hover,.menu-tab.active{color:var(--text-main)}.menu-tab.active .tab-icon-bg{opacity:.35;color:var(--primary);filter:drop-shadow(0 0 8px #0ea5e966);transform:translate(-50%,-50%)scale(1.1)}.tab-indicator{background:var(--primary);border-radius:3px 3px 0 0;width:90%;height:3px;animation:.3s ease-out slideIndicator;position:absolute;bottom:0;left:5%;box-shadow:0 -4px 10px #0ea5e980}@keyframes slideIndicator{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.mypage-body{gap:32px;width:100%;max-width:1280px;margin:32px auto;padding:0 40px;display:flex}.ad-sidebar{flex-direction:column;flex-shrink:0;gap:24px;width:320px;height:fit-content;display:flex;position:sticky;top:100px}.ad-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--glass-border);border-radius:20px;padding:24px;transition:transform .3s}.ad-card:hover{border-color:#0ea5e966;transform:translateY(-5px)}.ad-image-placeholder{background:linear-gradient(135deg,#0ea5e9 0%,#10b981 100%);border-radius:12px;justify-content:center;align-items:center;width:100%;height:140px;margin-bottom:16px;display:flex;position:relative;overflow:hidden}.ad-text{color:#fff;letter-spacing:.1em;opacity:.8;font-size:14px;font-weight:800}.ad-title{color:var(--text-main);margin-bottom:8px;font-size:16px;font-weight:700}.ad-desc{color:var(--text-sub);margin-bottom:16px;font-size:13px;line-height:1.5}.ad-button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;padding:10px;font-size:13px;font-weight:700;transition:all .3s}.ad-card-mini{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);background:#ffffff1a;border-radius:16px;justify-content:center;align-items:center;height:80px;padding:20px;display:flex}.ad-mini-text{color:var(--text-sub);letter-spacing:.2em;font-size:12px;font-weight:900}.content-area{flex-grow:1}.content-glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--glass-border);border-radius:28px;min-height:500px;padding:48px;box-shadow:0 10px 40px #0000000d}.content-title{color:var(--text-main);letter-spacing:-.02em;margin-bottom:32px;font-size:32px;font-weight:800}.content-placeholder{flex-direction:column;gap:16px;display:flex}.content-placeholder p{color:var(--text-sub);margin-bottom:24px;font-size:16px}.skeleton-line{background:#ffffff1a;border-radius:7px;width:100%;height:14px;position:relative;overflow:hidden}.skeleton-line:after{content:"";background:linear-gradient(90deg,#0000,#ffffff1a,#0000);width:100%;height:100%;animation:2s infinite shine;position:absolute;top:0;left:-100%}.skeleton-line.short{width:30%}.skeleton-line.medium{width:60%}@keyframes shine{to{left:100%}}.mobile-ad-banner{display:none!important}@media (width<=900px){.mypage-body{flex-direction:column;padding-top:0}.ad-sidebar{display:none!important}.mobile-ad-banner{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:8px;align-items:center;height:64px;margin:0 0 12px;padding:0 16px;animation:.5s cubic-bezier(.4,0,.2,1) fadeInAd;display:flex;overflow:hidden;box-shadow:0 4px 24px #00000026;display:flex!important}.ad-banner-mini-image{background:#0ea5e90d;border-radius:6px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;position:relative;overflow:hidden}.ad-mini-badge{text-align:center;width:200%;color:var(--primary);pointer-events:none;background:#0ea5e91a;font-size:6px;font-weight:800;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-45deg)}.ad-mini-text{color:var(--primary);text-align:center;text-transform:uppercase;font-size:8px;font-weight:800;line-height:1.1}.ad-banner-info{flex:1;justify-content:space-between;align-items:center;margin-left:20px;display:flex}.ad-banner-title{color:var(--text-main);letter-spacing:.05em;white-space:nowrap;margin:0;font-size:13px;font-weight:800}.ad-banner-desc{color:var(--text-sub);text-align:right;opacity:.8;flex:1;margin:0 0 0 16px;font-size:10px;line-height:1.2}@keyframes fadeInAd{0%{opacity:0;filter:blur(10px)}to{opacity:1;filter:blur()}}.content-area{width:100%;padding:0}.content-glass-card{min-height:auto;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;box-shadow:none!important;background:0 0!important;border:none!important;border-radius:0!important;padding:12px 0!important}.accordion-section{border:none!important;border-bottom:1px solid var(--glass-border)!important;box-shadow:none!important;background:0 0!important;border-radius:0!important;margin-bottom:0!important}.accordion-section.open{background:#ffffff08!important}.accordion-header{padding:24px 0!important}.accordion-header h3{font-weight:800;font-size:17px!important}.accordion-icon{box-shadow:none!important;background:0 0!important}.accordion-content{padding:0 0 32px!important}.form-grid{grid-template-columns:1fr!important;gap:12px!important;width:100%!important}.form-item{width:100%!important}.form-item input,.form-item select{border-radius:8px!important;width:100%!important}.profile-info-layout{flex-direction:column!important;align-items:center!important;gap:24px!important;width:100%!important;padding:20px 0!important}.save-section-btn{width:100%!important}.security-modal-content{border-radius:24px!important;width:95%!important;padding:24px 20px!important}.modal-actions{flex-direction:column-reverse!important;gap:12px!important;margin-top:24px!important}.save-btn,.cancel-btn{width:100%!important;padding:14px!important;font-size:15px!important}}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;animation:.5s ease-out fadeIn;display:grid}.stat-card{border:1px solid var(--glass-border);background:#ffffff0d;border-radius:20px;flex-direction:column;gap:12px;padding:32px;transition:all .3s;display:flex}.stat-card:hover{background:#ffffff14;border-color:#0ea5e966;transform:translateY(-5px)}.stat-card.highlight-border{border-color:#f59e0b4d}.stat-label{color:var(--text-sub);font-size:14px;font-weight:600}.stat-value{color:var(--text-main);letter-spacing:-.02em;font-size:42px;font-weight:900}.stat-unit{color:var(--text-sub);font-size:18px;font-weight:600}.stat-value .highlight{color:var(--primary);text-shadow:0 0 20px #0ea5e980}.stat-trend{color:#10b981;font-size:13px;font-weight:600}.stat-trend.pending{color:#f59e0b}.news-summary-card{border:1px solid var(--glass-border);background:#ffffff08;border-radius:20px;grid-column:1/-1;padding:24px}.news-summary-card h3{color:var(--text-main);margin-bottom:20px;font-size:18px}.mini-news-list{flex-direction:column;gap:12px;list-style:none;display:flex}.mini-news-list li{color:var(--text-sub);gap:16px;font-size:14px;display:flex}.mini-news-list li span{color:var(--primary);opacity:.8;font-weight:800}.profile-container{flex-direction:column;gap:16px;display:flex}.profile-banner-area{border-radius:20px;width:100%;height:180px;margin-bottom:8px;position:relative;overflow:hidden}.profile-banner-default{background:linear-gradient(135deg,#0ea5e926 0%,#38bdf81a 40%,#0ea5e914 70%,#6366f11f 100%);border:1px dashed #0ea5e94d;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.profile-banner-img{object-fit:cover;width:100%;height:100%}.profile-banner-img.default-opacity{opacity:.6;filter:grayscale(.2)blur(1px)}.default-banner-option{background:#f1f5f9;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.default-banner-option img{opacity:.5}.banner-overlay-icons{opacity:0;z-index:10;flex-direction:column;gap:8px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;bottom:12px;right:12px}.profile-banner-area:hover .banner-overlay-icons{opacity:1;transform:translate(-4px)}.banner-icon-btn{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff26;border:1px solid #fff3;border-radius:12px;justify-content:center;align-items:center;gap:10px;min-width:40px;height:40px;padding:0 16px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 15px #0000001a}.banner-icon-btn .btn-icon{font-size:18px}.banner-icon-btn .btn-text{letter-spacing:.05em;opacity:0;width:0;font-size:11px;font-weight:800;transition:all .3s;overflow:hidden}.banner-overlay-icons:hover .btn-text,.banner-icon-btn:hover .btn-text{opacity:1;width:auto;margin-left:2px}.banner-icon-btn:hover{background:var(--primary);border-color:var(--primary);transform:scale(1.05);box-shadow:0 0 20px #0ea5e966}.banner-icon-btn:disabled{opacity:.5;cursor:not-allowed}.profile-title-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#f59e0b;background:#0009;border:1px solid #f59e0b4d;border-radius:8px;padding:6px 16px;font-size:13px;font-weight:700;position:absolute;bottom:12px;right:16px}.profile-icon-placeholder{background:linear-gradient(135deg,#0ea5e91a 0%,#6366f11a 100%);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.profile-icon-placeholder svg{color:#0ea5e966;width:60px;height:60px}.profile-info-layout{align-items:center;gap:40px;margin-bottom:24px;padding:16px 0;display:flex}.profile-icon-wrapper{border:2px solid #0ea5e94d;border-radius:24px;flex-shrink:0;width:140px;height:140px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 0 20px #0ea5e933}.profile-icon-wrapper:hover{border-color:var(--primary);transform:scale(1.02);box-shadow:0 0 30px #0ea5e966}.profile-icon-large{object-fit:cover;width:100%;height:100%}.icon-overlay{opacity:0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:5;background:linear-gradient(135deg,#ebf8ffd9 0%,#cfedffe6 100%);flex-direction:column;width:100%;height:100%;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:0;left:0}.profile-icon-wrapper:hover .icon-overlay{opacity:1}.overlay-btn{color:#1e293b;cursor:pointer;background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:8px;width:100%;text-decoration:none;transition:all .2s;display:flex}.overlay-btn .btn-icon{font-size:16px}.overlay-btn .btn-text{letter-spacing:.02em;font-size:11px;font-weight:800}.overlay-btn:hover{color:var(--primary);background:#0ea5e91a}.overlay-btn.top{border-bottom:1px solid #0ea5e926}.item-selector-modal{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;background:#0f172a99;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.item-selector-content{background:#fff;border-radius:32px;width:100%;max-width:500px;padding:32px;animation:.4s cubic-bezier(.16,1,.3,1) slideIn;box-shadow:0 40px 100px #0003}@keyframes slideIn{0%{opacity:0;transform:scale(.95)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h2{color:var(--text-main);margin:0;font-size:20px;font-weight:800}.close-modal-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:50%;width:32px;height:32px;font-size:16px}.icon-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:16px;max-height:400px;margin-bottom:24px;padding:4px;display:grid;overflow-y:auto}.selectable-icon{aspect-ratio:1;cursor:pointer;background:#f8fafc;border:3px solid #f1f5f9;border-radius:16px;flex-direction:column;transition:all .2s;display:flex;overflow:hidden}.selectable-icon:hover{border-color:#cbd5e1;transform:translateY(-4px)}.selectable-icon.active{border-color:var(--primary);box-shadow:0 4px 12px #0ea5e933}.selectable-icon img{object-fit:cover;width:100%;height:100%}.default-icon-option{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;display:flex}.modal-footer{gap:12px;display:flex}.modal-footer button{cursor:pointer;border-radius:12px;flex:1;padding:14px;font-size:14px;font-weight:700}.modal-footer .cancel-btn{color:#64748b;background:#f1f5f9}.modal-footer .save-btn{background:var(--primary);color:#fff;box-shadow:0 4px 12px #0ea5e94d}.modal-footer .save-btn:disabled{box-shadow:none;cursor:not-allowed;background:#cbd5e1}.profile-info-layout .form-grid{flex-grow:1;margin-bottom:0}@media (width<=600px){.profile-info-layout{text-align:center;flex-direction:column}}.accordion-section{border:1px solid var(--glass-border);background:#ffffff08;border-radius:16px;transition:all .4s cubic-bezier(.4,0,.2,1);overflow:hidden}.accordion-section.open{background:#ffffff0f;border-color:#0ea5e94d}.accordion-header{cursor:pointer;justify-content:space-between;align-items:center;padding:24px 32px;transition:background .3s;display:flex}.accordion-header:hover{background:#ffffff08}.accordion-header h3{color:var(--text-main);align-items:center;gap:12px;font-size:18px;font-weight:700;display:flex}.sub-tag{color:var(--text-sub);text-transform:uppercase;background:#ffffff1a;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500}.accordion-icon{color:var(--text-sub);background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;transition:all .3s;display:flex}.accordion-section.open .accordion-icon{background:var(--primary);color:#fff;transform:rotate(0)}.accordion-content{opacity:0;visibility:hidden;max-height:0;padding:0 32px;transition:all .4s cubic-bezier(.4,0,.2,1)}.accordion-section.open .accordion-content{opacity:1;visibility:visible;max-height:1000px;padding:8px 32px 32px}.form-grid{grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:24px;display:grid}.form-item{flex-direction:column;gap:8px;display:flex}.form-item.full{grid-column:1/-1}.form-item label{color:#64748b;margin-left:4px;font-size:13px;font-weight:700}.form-item input,.form-item select,.form-item textarea{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#1e293b;background:#ffffff80;border:1.5px solid #0ea5e914;border-radius:14px;padding:14px 18px;font-size:15px;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 2px 4px #00000005}.form-item input::placeholder{color:#94a3b8}.form-item input[readOnly]{color:#94a3b8;cursor:not-allowed;background:#f1f5f966;border-color:#cbd5e14d}.form-item input:focus,.form-item select:focus,.form-item textarea:focus{border-color:var(--primary);background:#fff;outline:none;transform:translateY(-1px);box-shadow:0 10px 25px #0ea5e91f,0 0 0 4px #0ea5e90d}.form-item textarea{resize:none;height:120px;line-height:1.7}.save-section-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:10px;align-self:flex-start;padding:12px 24px;font-size:14px;font-weight:700;transition:all .3s;box-shadow:0 4px 12px #0ea5e94d}.save-section-btn:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 6px 16px #0ea5e966}.save-section-btn:disabled{box-shadow:none;cursor:not-allowed;filter:none;background:#cbd5e1;transform:none}.security-card{background:#ffffff4d;border:1.5px solid #0ea5e91a;border-radius:20px;flex-direction:column;gap:20px;margin-top:16px;padding:24px;display:flex}.security-item{justify-content:space-between;align-items:flex-start;gap:24px;display:flex}.security-info{flex-grow:1}.security-info label{color:#64748b;margin-bottom:8px;font-size:13px;font-weight:700;display:block}.info-with-badge{align-items:center;gap:12px;margin-bottom:8px;display:flex}.current-value{color:#1e293b;font-size:16px;font-weight:600}.auth-badge{text-transform:uppercase;border-radius:100px;padding:4px 10px;font-size:10px;font-weight:800}.auth-badge.google{color:#4285f4;background:#f1f5f9;border:1px solid #4285f433}.security-note{color:#94a3b8;margin-top:4px;font-size:12px}.password-explanation{background:#0ea5e90a;border:1.5px solid #0ea5e91a;border-radius:16px;margin-top:12px;padding:16px 20px}.explanation-title{color:var(--primary);margin-bottom:8px;font-size:14px;font-weight:800}.password-explanation p{color:#475569;font-size:13px;line-height:1.6}.password-explanation ul{margin:10px 0 0 18px;padding:0}.password-explanation li{color:#64748b;margin-bottom:6px;font-size:12.5px;line-height:1.5}.security-btn-row{justify-content:flex-end;margin-top:20px;display:flex}.security-action-btn{cursor:pointer;color:#475569;white-space:nowrap;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;padding:10px 24px;font-size:13.5px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1)}.security-action-btn:hover{background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.security-action-btn.primary{background:var(--primary);color:#fff;border:none;box-shadow:0 4px 14px #0ea5e940}.security-action-btn.primary:hover{color:#fff;background:#0284c7;border:none;transform:translateY(-2px);box-shadow:0 6px 20px #0ea5e973}.divider{background:#0ea5e914;width:100%;height:1px;margin:10px 0}.security-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:3000;background:#0f172a66;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.security-modal-content{background:#fff;border-radius:28px;width:100%;max-width:440px;max-height:90vh;padding:32px;position:relative;overflow-y:auto;box-shadow:0 40px 100px #00000026}.save-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:12px 24px;font-size:14px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0ea5e933}.save-btn:hover:not(:disabled){background:#0284c7;transform:translateY(-2px);box-shadow:0 6px 16px #0ea5e94d}.save-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.security-modal-content h2{color:#1e293b;margin-bottom:12px;font-size:20px;font-weight:800}.modal-desc{color:#64748b;margin-bottom:24px;font-size:14px;line-height:1.5}.security-error-msg{color:#ef4444;background:#fef2f2;border-radius:8px;margin-top:16px;padding:8px 12px;font-size:13px;font-weight:600}.password-toggle-btn{color:#94a3b8;cursor:pointer;z-index:5;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex;position:absolute;right:8px}.point-history-container{padding:8px}.history-header{background:#fff6;border:1px solid #fff9;border-radius:20px;justify-content:space-between;align-items:center;margin-bottom:32px;padding:20px 24px;display:flex}.history-summary{flex-direction:column;gap:4px;display:flex}.summary-label{color:var(--text-sub);font-size:13px;font-weight:600}.summary-value{color:var(--text-main);letter-spacing:-.02em;font-size:28px;font-weight:800}.summary-value small{color:var(--text-sub);margin-left:2px;font-size:14px}.history-refresh-btn{border:1px solid var(--glass-border);color:var(--primary);cursor:pointer;background:#fff;border-radius:12px;padding:10px 18px;font-size:13px;font-weight:700;transition:all .2s;box-shadow:0 4px 12px #00000008}.history-refresh-btn:hover:not(:disabled){background:var(--primary);color:#fff;transform:translateY(-1px);box-shadow:0 6px 16px #0ea5e933}.history-refresh-btn:disabled{opacity:.6;cursor:not-allowed}.history-list-wrapper{min-height:400px}.history-items{flex-direction:column;gap:16px;display:flex}.history-item-card{background:#ffffff80;border:1px solid #fffc;border-radius:18px;padding:20px;transition:all .3s;animation:.4s ease-out backwards fadeInHistory}.history-item-card:hover{background:#ffffffe6;border-color:#0ea5e94d;transform:translate(4px);box-shadow:0 8px 24px #0000000a}@keyframes fadeInHistory{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.item-meta{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.item-date{color:var(--text-sub);font-family:inherit;font-size:13px;font-weight:500}.item-type-badge{text-transform:uppercase;border-radius:100px;padding:4px 10px;font-size:11px;font-weight:800}.item-type-badge.earn{color:#10b981;background:#10b9811a}.item-type-badge.spend{color:#ef4444;background:#ef44441a}.item-content{justify-content:space-between;align-items:center;display:flex}.item-reason{color:var(--text-main);font-size:16px;font-weight:700}.item-amount{font-size:18px;font-weight:800}.item-amount.positive{color:#059669}.item-amount.negative{color:#dc2626}.item-amount small{opacity:.7;font-size:12px}.history-empty,.history-loading{text-align:center;background:#ffffff4d;border:1px dashed #0000001a;border-radius:24px;flex-direction:column;justify-content:center;align-items:center;padding:100px 20px;display:flex}.empty-icon{filter:drop-shadow(0 4px 12px #0000001a);margin-bottom:20px;font-size:48px}.history-empty p,.history-loading p{color:var(--text-main);margin-bottom:8px;font-size:18px;font-weight:700}.empty-sub{color:var(--text-sub);font-size:14px}.spinner{border:3px solid #0ea5e91a;border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;margin-bottom:20px;animation:1s linear infinite spinHistory}@keyframes spinHistory{to{transform:rotate(360deg)}}@media (width<=640px){.security-item{flex-direction:column;gap:16px}.security-action-btn{width:100%}}.save-section-btn:active{transform:translateY(0)}.settings-container{flex-direction:column;gap:24px;animation:.4s ease-out fadeIn;display:flex}.danger-zone{background:#ef44440d;border:1px solid #ef444433;border-radius:16px;padding:32px}.danger-zone h3{color:#ef4444;align-items:center;gap:8px;margin-bottom:12px;font-size:20px;font-weight:800;display:flex}.danger-zone h3:before{content:"⚠️";font-size:22px}.danger-desc{color:var(--text-sub);margin-bottom:24px;font-size:14px;line-height:1.6}.delete-account-btn{color:#ef4444;cursor:pointer;background:#ef44441a;border:1px solid #ef444480;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1)}.delete-account-btn:hover{color:#fff;background:#ef4444;transform:translateY(-2px);box-shadow:0 4px 16px #ef444466}.delete-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background:#0f172ad9;justify-content:center;align-items:center;animation:.2s ease-out fadeInLayout;display:flex;position:fixed;inset:0}.delete-modal-content{background:#fff;border:1px solid #ef44444d;border-radius:24px;width:90%;max-width:500px;padding:40px;position:relative;box-shadow:0 24px 60px #00000080,inset 0 0 0 1px #ffffff0d}.delete-modal-content:before{content:"";background:linear-gradient(90deg,#ef4444,#f43f5e);border-radius:24px 24px 0 0;width:100%;height:6px;position:absolute;top:0;left:0}.delete-modal-content h2{color:#0f172a;margin-bottom:16px;font-size:24px;font-weight:800}.modal-warning{color:#991b1b;background:#fef2f2;border-left:4px solid #ef4444;border-radius:0 8px 8px 0;margin-bottom:24px;padding:16px;font-size:14.5px;line-height:1.6}.delete-verify-input{color:#0f172a;background:#f8fafc;border:1px solid #cbd5e1;border-radius:12px;width:100%;margin-top:12px;padding:14px;font-size:15px;transition:all .3s}.delete-verify-input:focus{background:#fff;border-color:#ef4444;outline:none;box-shadow:0 0 0 4px #ef444426}.delete-hint{color:#f43f5e;margin-top:4px;font-size:13px;font-weight:600;display:inline-block}.modal-actions{justify-content:flex-end;gap:16px;margin-top:32px;display:flex}.cancel-btn{color:#64748b;cursor:pointer;background:0 0;border:1px solid #cbd5e1;border-radius:10px;padding:12px 24px;font-weight:600;transition:all .2s}.cancel-btn:hover{color:#0f172a;background:#f1f5f9}.confirm-delete-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);border:none;border-radius:10px;padding:12px 24px;font-weight:700;transition:all .3s;box-shadow:0 4px 12px #ef44444d}.confirm-delete-btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 6px 16px #ef444466}.confirm-delete-btn:disabled{color:#ffffff80;cursor:not-allowed;box-shadow:none;background:#ef44444d;transform:none}.error-message{color:#fca5a5;background:#ef44441a;border-radius:8px;margin-top:16px;padding:12px 16px;font-size:14px;font-weight:600}.login-page{background:0 0;justify-content:center;align-items:center;padding:40px 20px;display:flex}.login-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border);border-radius:32px;width:100%;max-width:440px;padding:48px;animation:.8s cubic-bezier(.2,.8,.2,1) slideInLogin;box-shadow:0 20px 80px #00000014}@keyframes slideInLogin{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-title{color:var(--text-main);letter-spacing:-.02em;margin-bottom:8px;font-size:32px;font-weight:800}.login-subtitle{color:var(--text-sub);margin-bottom:40px;font-size:15px;line-height:1.6}.login-form{flex-direction:column;gap:24px;display:flex}.form-group label{color:var(--text-main);padding-left:4px;font-size:14px;font-weight:600}.form-group input{color:var(--text-main);background:#fff6;border:1.5px solid #0000;border-radius:16px;padding:16px 20px;font-size:16px;transition:all .3s}.form-group input::placeholder{color:#bebebe}.form-group input:focus{border-color:var(--primary);background:#fffc;outline:none;box-shadow:0 0 0 4px #0ea5e91a}.password-input-wrapper input{width:100%;padding-right:50px}.forgot-password-container{justify-content:flex-end;margin-top:-8px;display:flex}.forgot-password-link{color:var(--primary);font-size:13px;font-weight:500;text-decoration:none;transition:opacity .2s}.forgot-password-link:hover{opacity:.7}.error-container{background:#ef444414;border-left:3px solid #ef4444;border-radius:8px;padding:12px 16px}.error-message{color:#ef4444;align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.error-bullet{font-weight:800}.login-button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:16px;margin-top:8px;padding:18px;font-size:16px;font-weight:700;transition:all .3s;box-shadow:0 10px 20px #0ea5e933}.login-button:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 12px 24px #0ea5e94d}.login-button:active{transform:translateY(0)}.login-button.loading{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;color:var(--text-sub);margin-top:32px;font-size:14px}.social-login-divider{color:#94a3b8;align-items:center;margin:20px 0;font-size:.85rem;display:flex}.social-login-divider:before,.social-login-divider:after{content:"";background-color:#e2e8f0;flex:1;height:1px}.social-login-divider span{padding:0 12px}.google-login-container{justify-content:center;width:100%;margin-top:10px;display:flex}.google-login-container>div{width:100%!important}.signup-link{color:var(--primary);font-weight:600;text-decoration:none}.signup-link:hover{text-decoration:underline}.signup-confirm-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;background:#0f172a66;justify-content:center;align-items:center;animation:.3s ease-out fadeInModal;display:flex;position:fixed;inset:0}.signup-confirm-modal{text-align:center;background:#fff;border:1px solid #0000000d;border-radius:24px;width:95%;max-width:600px;padding:40px;box-shadow:0 20px 60px #00000026}.signup-confirm-modal h3{color:#0f172a;margin-bottom:16px;font-size:24px;font-weight:800}.signup-confirm-modal p{color:#64748b;margin-bottom:32px;font-size:15px;line-height:1.6}.confirm-modal-actions{justify-content:center;gap:16px;display:flex}.confirm-cancel-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:12px;flex:1;padding:14px 24px;font-weight:600;transition:all .2s}.confirm-cancel-btn:hover{color:#0f172a;background:#e2e8f0}.confirm-accept-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;flex:1;padding:14px 24px;font-weight:700;transition:all .3s;box-shadow:0 4px 12px #0ea5e94d}.confirm-accept-btn:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 6px 16px #0ea5e966}@keyframes fadeInModal{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.shop-container{max-width:1200px;margin:0 auto;padding:40px 24px;animation:.6s ease-out fadeIn}.shop-hero{border-radius:32px;height:380px;margin-bottom:56px;position:relative;overflow:hidden;box-shadow:0 24px 60px #0000001a}.hero-image{object-fit:cover;filter:brightness(.7);width:100%;height:100%}.hero-overlay{background:linear-gradient(90deg,#0f172acc 0%,#0000 60%);align-items:center;padding:64px;display:flex;position:absolute;inset:0}.hero-content{max-width:500px}.hero-badge{background:var(--primary);color:#fff;text-transform:uppercase;letter-spacing:.1em;border-radius:20px;margin-bottom:20px;padding:6px 14px;font-size:13px;font-weight:700;display:inline-block}.hero-content h1{color:#fff;margin-bottom:20px;font-size:44px;font-weight:800;line-height:1.1}.hero-content p{color:#fffc;margin-bottom:32px;font-size:17px}.hero-btn{color:var(--text-main);background:#fff;border-radius:14px;padding:16px 32px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-block}.hero-btn:hover{transform:scale(1.05);box-shadow:0 10px 25px #fff3}.section-title{color:var(--text-main);align-items:center;gap:12px;margin-bottom:32px;font-size:28px;font-weight:800;display:flex}.category-grid{grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:64px;display:grid}.category-card{cursor:pointer;border-radius:28px;flex-direction:column;justify-content:flex-end;height:280px;padding:32px;transition:all .4s cubic-bezier(.175,.885,.32,1.275);display:flex;position:relative;overflow:hidden;box-shadow:0 12px 30px #0000000d}.category-card:before{content:"";z-index:1;background:linear-gradient(#0000 40%,#00000080 100%);position:absolute;inset:0}.category-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #0000001a}.category-card.active{border:3px solid var(--primary);transform:translateY(-4px)scale(1.02);box-shadow:0 0 25px #0ea5e966}.category-card.active:after{content:"選択中";background:var(--primary);color:#fff;z-index:3;border-radius:8px;padding:4px 10px;font-size:11px;font-weight:800;position:absolute;top:12px;left:12px}.category-card.physical{background:#e0e7ff}.category-card.digital{background:#dcfce7}.category-card.game{background:#ffedd5}.category-icon-bg{opacity:.15;filter:grayscale();font-size:140px;transition:all .4s;position:absolute;top:-20px;right:-20px}.category-card:hover .category-icon-bg{opacity:.25;transform:scale(1.1)rotate(-10deg)}.category-card h3{color:#fff;z-index:2;text-shadow:0 2px 4px #0003;margin-bottom:8px;font-size:24px;font-weight:800;position:relative}.category-card p{color:#ffffffe6;z-index:2;font-size:14px;font-weight:500;position:relative}.items-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:24px;display:grid}.item-card{background:#fff;border:1px solid #0000000a;border-radius:24px;flex-direction:column;padding:16px;transition:all .3s;display:flex;position:relative}.item-card:hover{transform:translateY(-5px);box-shadow:0 12px 30px #00000014}.item-image-container{aspect-ratio:1;background:#f8fafc;border-radius:18px;justify-content:center;align-items:center;width:100%;margin-bottom:16px;padding:20px;display:flex;position:relative;overflow:hidden}.item-image{object-fit:contain;width:100%;height:100%;transition:transform .3s}.item-card:hover .item-image{transform:scale(1.1)}.rarity-tag{text-transform:uppercase;color:#fff;border-radius:20px;padding:4px 10px;font-size:10px;font-weight:800;position:absolute;top:8px;right:8px}.rarity-tag.COMMON{background:#94a3b8}.rarity-tag.RARE{background:#8b5cf6}.rarity-tag.EPIC{background:#ec4899}.rarity-tag.LEGENDARY{background:#f59e0b}.item-info{flex-grow:1}.item-name{color:var(--text-main);margin-bottom:4px;font-size:16px;font-weight:700}.item-price{color:var(--primary);align-items:center;gap:4px;font-size:15px;font-weight:800;display:flex}.item-price:after{content:"pt";opacity:.7;font-size:11px;font-weight:600}.shop-tabs{background:#0000000a;border-radius:16px;gap:12px;width:fit-content;margin-bottom:40px;padding:6px;display:flex}.tab-btn{color:var(--text-sub);cursor:pointer;border-radius:12px;padding:10px 24px;font-weight:700;transition:all .2s}.tab-btn.active{color:var(--primary);background:#fff;box-shadow:0 4px 12px #0000000d}.shop-filters-bar{flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:40px;margin-bottom:32px;display:flex}.sub-categories{scrollbar-width:none;-ms-overflow-style:none;gap:10px;padding:4px 0;display:flex;overflow-x:auto}.sub-categories::-webkit-scrollbar{display:none}.sub-chip{color:#64748b;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #0000000d;border-radius:50px;padding:8px 20px;font-size:13px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1)}.sub-chip:hover{border-color:var(--primary);color:var(--primary);background:#0ea5e905}.sub-chip.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 8px 20px #0ea5e940}.sort-select{color:var(--text-main);cursor:pointer;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") right 10px center/16px no-repeat;border:1px solid #0000000d;border-radius:14px;outline:none;padding:10px 40px 10px 16px;font-size:14px;font-weight:700;transition:all .2s}.sort-select:hover{border-color:var(--primary-light)}.sort-select:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0ea5e91a}.item-genre-label{color:var(--primary);text-transform:uppercase;letter-spacing:.1em;opacity:.8;margin-bottom:4px;font-size:10px;font-weight:800;display:block}.item-card.owned{opacity:.8;cursor:default}.owned-tag{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border-radius:20px;padding:4px 10px;font-size:10px;font-weight:800;position:absolute;top:8px;right:8px}.purchase-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0f172a99;justify-content:center;align-items:center;padding:20px;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.purchase-modal-content{background:#fff;border-radius:32px;width:100%;max-width:800px;animation:.4s cubic-bezier(.16,1,.3,1) slideUp;overflow:hidden;box-shadow:0 40px 100px #0003}.modal-body{grid-template-columns:1fr 1.2fr;display:grid}.preview-area{background:#f8fafc;border-right:1px solid #0000000d;flex-direction:column;justify-content:center;align-items:center;padding:48px;display:flex}.preview-label{color:#64748b;letter-spacing:.2em;margin-bottom:24px;font-size:12px;font-weight:800}.preview-profile-card{background:#fff;border-radius:24px;width:280px;position:relative;overflow:hidden;box-shadow:0 12px 40px #0000001a}.preview-banner{width:100%;height:100px}.preview-avatar-wrapper{border:4px solid #fff;border-radius:50%;width:80px;height:80px;margin:-40px auto 12px;position:relative;overflow:hidden}.preview-avatar{object-fit:cover;width:100%;height:100%}.preview-info{text-align:center;padding:0 20px 24px}.preview-name{color:var(--text-main);margin-bottom:4px;font-size:18px;font-weight:800}.preview-title{color:var(--primary);font-size:12px;font-weight:700}.preview-hint{color:#94a3b8;margin-top:24px;font-size:12px}.purchase-info{padding:48px;position:relative}.modal-close{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:all .2s;display:flex;position:absolute;top:24px;right:24px}.modal-close:hover{color:var(--text-main);background:#e2e8f0}.modal-rarity{letter-spacing:.1em;margin-bottom:12px;font-size:12px;font-weight:800;display:inline-block}.modal-rarity.COMMON{color:#94a3b8}.modal-rarity.RARE{color:#8b5cf6}.modal-rarity.EPIC{color:#ec4899}.modal-rarity.LEGENDARY{color:#f59e0b}.modal-item-name{color:var(--text-main);margin-bottom:8px;font-size:32px;font-weight:800}.modal-category{color:#64748b;margin-bottom:24px;font-size:14px;font-weight:600}.modal-description{color:#475569;margin-bottom:32px;font-size:15px;line-height:1.6}.purchase-financials{background:#f8fafc;border-radius:20px;margin-bottom:32px;padding:24px}.financial-row{color:#64748b;justify-content:space-between;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.financial-row span:last-child{color:var(--text-main)}.financial-row.price span:last-child{color:#ef4444}.financial-divider{background:#0000000d;height:1px;margin:12px 0}.financial-row.total{color:var(--text-main);margin-bottom:0}.financial-row.total span:last-child{color:var(--primary);font-size:18px;font-weight:800}.financial-row.total span.insufficient{color:#ef4444}.purchase-error{color:#ef4444;text-align:center;background:#fef2f2;border-radius:12px;margin-bottom:24px;padding:12px 16px;font-size:14px;font-weight:600}.modal-actions{gap:16px;display:flex}.modal-actions button{border-radius:14px;flex:1;padding:16px;font-size:15px;font-weight:700;transition:all .2s}.modal-actions .cancel-btn{color:#64748b;background:#f1f5f9}.modal-actions .buy-btn{background:var(--primary);color:#fff;box-shadow:0 8px 20px #0ea5e94d}.modal-actions .buy-btn:disabled{color:#94a3b8;box-shadow:none;cursor:not-allowed;background:#cbd5e1}@media (width<=768px){.modal-body{grid-template-columns:1fr}.preview-area{display:none}.purchase-info{padding:32px}.modal-item-name{font-size:24px}}.empty-state-container{text-align:center;background:#00000005;border:2px dashed #0000000d;border-radius:32px;grid-column:1/-1;padding:80px 40px;animation:.6s ease-out fadeIn}.empty-icon{margin-bottom:24px;font-size:64px;display:block}.empty-state-container h3{color:var(--text-main);margin-bottom:12px;font-size:28px;font-weight:800}.empty-state-container p{color:var(--text-sub);max-width:400px;margin:0 auto;font-size:16px;line-height:1.6}@media (width<=992px){.category-grid{grid-template-columns:1fr}.shop-hero{height:auto;padding-bottom:30px}.hero-overlay{padding:40px}.hero-content h1{font-size:32px}}@media (width<=768px){.shop-container{padding:24px 16px}.shop-hero{height:300px;margin-bottom:32px}.hero-content h1{font-size:28px}.hero-overlay{background:linear-gradient(#0000 0%,#0f172ae6 100%);align-items:flex-end;padding:24px}.category-grid{gap:12px;margin-bottom:40px}.category-card{border-radius:18px;flex-direction:row;justify-content:flex-start;align-items:center;height:90px;padding:16px 24px}.category-card p{display:none}.category-icon-bg{opacity:.1;font-size:70px;top:50%;right:20px;transform:translateY(-50%)}.category-card:hover .category-icon-bg{transform:translateY(-50%)scale(1.1)}.category-card h3{margin-bottom:0;font-size:18px}.category-card.active:after{font-size:10px;top:10px;left:auto;right:12px}.items-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.section-title{margin-bottom:20px;font-size:20px}}.forgot-password-layout{background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.forgot-password-card{-webkit-backdrop-filter:blur(12px);background:#ffffffb3;border:1px solid #fff6;border-radius:24px;width:100%;max-width:440px;padding:40px;animation:.5s ease-out cardAppear;box-shadow:0 20px 40px #0000000d}@keyframes cardAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.forgot-password-title{color:#1e293b;text-align:center;letter-spacing:-.02em;margin-bottom:12px;font-size:24px;font-weight:800}.forgot-password-desc{color:#64748b;text-align:center;margin-bottom:32px;font-size:14px;line-height:1.6}.forgot-password-form{flex-direction:column;gap:20px;display:flex}.form-group input:focus{border-color:#0ea5e9;outline:none;box-shadow:0 0 0 4px #0ea5e91a}.forgot-password-footer{text-align:center;margin-top:32px}.back-link{color:#64748b;font-size:14px;font-weight:600;text-decoration:none;transition:color .2s}.back-link:hover{color:#0ea5e9}.success-icon{text-align:center;margin-bottom:20px;font-size:48px}.success-message strong{color:#0ea5e9}.reset-password-layout{background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.reset-password-card{-webkit-backdrop-filter:blur(12px);background:#ffffffb3;border:1px solid #fff6;border-radius:24px;width:100%;max-width:440px;padding:40px;animation:.5s ease-out cardAppear;box-shadow:0 20px 40px #0000000d}.reset-password-title{color:#1e293b;text-align:center;letter-spacing:-.02em;margin-bottom:12px;font-size:24px;font-weight:800}.reset-password-desc{color:#64748b;text-align:center;margin-bottom:32px;font-size:14px;line-height:1.6}.reset-password-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#475569;margin-left:4px;font-size:13px;font-weight:700}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{background:#fff;border:1px solid #e2e8f0;border-radius:12px;width:100%;padding:14px 44px 14px 16px;font-size:15px;transition:all .2s}.password-input-wrapper input:focus{border-color:#0ea5e9;outline:none;box-shadow:0 0 0 4px #0ea5e91a}.form-group input{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px 16px;font-size:15px;transition:all .2s}.password-toggle-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex;position:absolute;right:8px}.password-toggle-btn:hover{color:#0ea5e9;background:#0ea5e91a}.submit-button{color:#fff;cursor:pointer;background:#0ea5e9;border:none;border-radius:12px;margin-top:10px;padding:16px;font-size:16px;font-weight:700;transition:all .2s cubic-bezier(.4,0,.2,1)}.submit-button:hover:not(:disabled){background:#0284c7;transform:translateY(-1px);box-shadow:0 4px 12px #0ea5e94d}.submit-button:disabled{opacity:.7;cursor:not-allowed}.success-icon-check{color:#10b981;text-align:center;margin-bottom:24px;font-size:56px;animation:.6s cubic-bezier(.68,-.55,.265,1.55) bounceIn}.error-icon{text-align:center;margin-bottom:24px;font-size:56px}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:.9;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.success-message{color:#334155;text-align:center;margin-bottom:32px;font-size:16px;line-height:1.7}.error-message-large{color:#64748b;text-align:center;margin-bottom:32px;font-size:15px;line-height:1.6}.action-button{text-align:center;color:#fff;background:#0ea5e9;border-radius:12px;width:100%;padding:14px;font-weight:700;text-decoration:none;transition:all .2s;display:block}.action-button:hover{background:#0284c7}.loading-spinner-small{border:3px solid #0ea5e91a;border-top-color:#0ea5e9;border-radius:50%;width:32px;height:32px;margin:0 auto;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-container{background:#fef2f2;border:1px solid #fee2e2;border-radius:10px;padding:10px 14px}.error-message{color:#ef4444;align-items:center;gap:8px;margin:0;font-size:13px;font-weight:600;display:flex}.error-bullet{color:#fff;background:#ef4444;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;display:flex}.admin-users-container{flex-direction:column;gap:24px;display:flex}.admin-users-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.search-wrapper{flex:1;max-width:400px;position:relative}.search-input{background:#fff;border:1px solid #0000000d;border-radius:12px;outline:none;width:100%;padding:12px 16px 12px 42px;font-size:14px;transition:all .2s}.search-input:focus{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a}.search-icon{color:#94a3b8;font-size:16px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.admin-table-wrapper{background:#fff;border:1px solid #00000008;border-radius:20px;overflow:hidden;box-shadow:0 4px 6px #00000003}.admin-table{border-collapse:collapse;text-align:left;width:100%}.admin-table th{color:#64748b;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;border-bottom:1px solid #0000000d;padding:16px 24px;font-size:12px;font-weight:700}.admin-table td{color:#1e293b;vertical-align:middle;border-bottom:1px solid #00000008;padding:16px 24px;font-size:14px}.user-info-cell{align-items:center;gap:12px;display:flex}.user-avatar-mini{object-fit:cover;background:#f1f5f9;border-radius:50%;width:36px;height:36px}.user-main-info{flex-direction:column;display:flex}.user-name-bold{font-weight:700}.user-email-sub{color:#94a3b8;font-size:12px}.role-badge{text-transform:uppercase;border-radius:6px;padding:4px 8px;font-size:11px;font-weight:800;display:inline-block}.role-badge.admin{color:#854d0e;background:#fef9c3}.role-badge.user{color:#64748b;background:#f1f5f9}.points-cell{color:#0ea5e9;font-weight:700}.edit-points-btn{color:#0ea5e9;cursor:pointer;background:#0ea5e90d;border:1px solid #0ea5e933;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:700;transition:all .2s}.edit-points-btn:hover{color:#fff;background:#0ea5e9}.admin-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a66;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.admin-modal-card{background:#fff;border-radius:24px;width:100%;max-width:480px;padding:32px;animation:.3s cubic-bezier(.4,0,.2,1) modalIn;box-shadow:0 20px 40px #00000026}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-title{margin-bottom:8px;font-size:20px;font-weight:800}.modal-subtitle{color:#64748b;margin-bottom:24px;font-size:14px}.form-group{margin-bottom:20px}.form-group label{color:#1e293b;margin-bottom:8px;font-size:13px;font-weight:700;display:block}.admin-input{border:1px solid #0000001a;border-radius:10px;outline:none;width:100%;padding:12px 14px;font-size:15px}.admin-input:focus{border-color:#0ea5e9}.modal-footer{justify-content:flex-end;gap:12px;margin-top:32px;display:flex}.cancel-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:12px;padding:12px 20px;font-weight:700}.submit-btn{color:#fff;cursor:pointer;background:#0ea5e9;border:none;border-radius:12px;padding:12px 24px;font-weight:700;box-shadow:0 4px 12px #0ea5e933}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.empty-state{text-align:center;color:#94a3b8;padding:80px 0}@media (width<=768px){.admin-users-header{flex-direction:column;align-items:flex-start}.search-wrapper{max-width:100%}.admin-table,.admin-table thead,.admin-table tbody,.admin-table th,.admin-table td,.admin-table tr{display:block}.admin-table thead tr{position:absolute;top:-9999px;left:-9999px}.admin-table-wrapper{box-shadow:none;background:0 0;border:none;overflow:visible}.admin-table tr{background:#fff;border:1px solid #00000008;border-radius:20px;margin-bottom:20px;padding:20px;box-shadow:0 4px 12px #00000005}.admin-table td{border:none;justify-content:space-between;align-items:center;padding:8px 0;display:flex;position:relative}.admin-table td:first-child{border-bottom:1px solid #0000000d;margin-bottom:12px;padding-bottom:16px;display:block}.user-info-cell{gap:16px}.user-avatar-mini{width:48px;height:48px}.user-name-bold{font-size:16px}.admin-table td:not(:first-child):not(:last-child):before{content:attr(data-label);color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:800}.role-badge{padding:2px 8px}.points-cell{font-size:16px}.admin-table td:last-child{margin-top:8px;padding-top:16px;display:block}.edit-points-btn{color:#fff;background:#0ea5e9;border:none;justify-content:center;align-items:center;width:100%;padding:12px;font-size:14px;display:flex}}.shop-management-container{flex-direction:column;gap:24px;display:flex}.admin-section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.category-filter{background:#fff;border:1px solid #0000000d;border-radius:14px;gap:8px;padding:6px;display:flex}.filter-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:10px;padding:8px 16px;font-size:13px;font-weight:700;transition:all .2s}.filter-btn:hover{background:#f1f5f9}.filter-btn.active{color:#fff;background:#0ea5e9;box-shadow:0 4px 10px #0ea5e933}.admin-items-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;display:grid}.admin-item-card{background:#fff;border:1px solid #00000008;border-radius:20px;transition:transform .2s;overflow:hidden;box-shadow:0 4px 6px #00000003}.admin-item-card:hover{transform:translateY(-4px);box-shadow:0 10px 20px #0000000a}.item-preview{background:#f8fafc;justify-content:center;align-items:center;height:180px;padding:20px;display:flex;position:relative}.item-preview img{object-fit:contain;max-width:100%;max-height:100%}.rarity-tag{color:#475569;background:#cbd5e1;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:800;position:absolute;top:12px;left:12px}.rarity-tag.RARE{color:#1e40af;background:#dbeafe}.rarity-tag.EPIC{color:#6b21a8;background:#f3e8ff}.rarity-tag.LEGENDARY{color:#92400e;background:#fef3c7}.item-details{flex-direction:column;padding:16px;display:flex}.item-name{color:#1e293b;margin:0 0 4px;font-size:16px;font-weight:800}.item-meta{color:#94a3b8;text-transform:uppercase;letter-spacing:.02em;margin:0 0 12px;font-size:11px;font-weight:700}.item-price{color:#0ea5e9;margin:0 0 16px;font-size:18px;font-weight:900}.edit-btn{color:#0ea5e9;cursor:pointer;background:#0ea5e90d;border:1px solid #0ea5e933;border-radius:10px;width:100%;padding:10px;font-weight:700;transition:all .2s}.edit-btn:hover{color:#fff;background:#0ea5e9}.admin-loading{text-align:center;color:#64748b;padding:80px 0;font-weight:700}@media (width<=768px){.admin-section-header{flex-direction:column;align-items:stretch}.category-filter{padding-bottom:2px;overflow-x:auto}}.admin-layout{background:#f8fafc;flex-direction:column;min-height:100vh;display:flex}.admin-navbar{-webkit-backdrop-filter:blur(16px);z-index:1000;background:#ffffffb3;border-bottom:1px solid #0000000d;justify-content:space-between;align-items:center;height:80px;padding:0 40px;display:flex;position:sticky;top:0}.nav-brand-section{align-items:center;gap:16px;display:flex}.brand{color:#1e293b;letter-spacing:-.01em;font-size:20px;font-weight:900;text-decoration:none}.brand small{color:#fff;text-transform:uppercase;vertical-align:middle;background:#0ea5e9;border-radius:4px;margin-left:6px;padding:2px 6px;font-size:10px}.admin-main-nav{align-items:center;gap:8px;height:100%;display:flex}.nav-item{color:#64748b;border-radius:12px;align-items:center;gap:8px;height:48px;padding:8px 16px;font-size:14px;font-weight:700;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.nav-item:hover{color:#0ea5e9;background:#0ea5e90d}.nav-item.active{color:#0ea5e9;background:#0ea5e91a;position:relative}.nav-item.active:after{content:"";background:#0ea5e9;border-radius:10px 10px 0 0;height:3px;position:absolute;bottom:-16px;left:16px;right:16px}.nav-actions{align-items:center;gap:12px;display:flex}.back-to-site{background:#fff;border:1px solid #0000000d;box-shadow:0 2px 4px #00000005}.admin-content-area{flex-direction:column;flex:1;display:flex}.admin-top-bar{display:none}.admin-dynamic-content{flex:1;padding:40px}.admin-page-content{max-width:1200px;margin:0 auto}.admin-page-content h2{color:#1e293b;letter-spacing:-.02em;margin-bottom:32px;font-size:32px;font-weight:800}.admin-stats-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:32px;display:grid}.stat-card{background:#fff;border:1px solid #00000008;border-radius:24px;padding:32px;transition:transform .2s;box-shadow:0 4px 20px #00000005}.stat-card:hover{transform:translateY(-4px)}.stat-card h3{color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px;font-size:14px;font-weight:700}.stat-value{color:#1e293b;font-size:40px;font-weight:900}.stat-value small{color:#94a3b8;margin-left:4px;font-size:16px}@media (width<=1024px){.admin-navbar{padding:0 20px}}@media (width<=768px){.admin-navbar{flex-direction:column;gap:16px;height:auto;padding:16px}.admin-main-nav{-webkit-overflow-scrolling:touch;justify-content:flex-start;width:100%;padding-bottom:8px;overflow-x:auto}.nav-item{white-space:nowrap;flex-shrink:0}.nav-item.active:after{bottom:-4px}.admin-dynamic-content{padding:20px}.admin-page-content h2{font-size:24px}}.app{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;padding-top:0}
