:root{--color-bg-primary: transparent;--color-bg-secondary: rgba(22, 33, 62, .4);--color-bg-card: rgba(255, 255, 255, .05);--color-bg-card-hover: rgba(255, 255, 255, .1);--color-accent: #4ECDC4;--color-accent-secondary: #44A08D;--color-danger: #FF6B6B;--color-warning: #FFE66D;--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-success: linear-gradient(135deg, #11998e 0%, #38ef7d 100%);--gradient-danger: linear-gradient(135deg, #FF6B6B 0%, #FF8E53 100%);--color-text: #ffffff;--color-text-secondary: rgba(255, 255, 255, .7);--color-text-muted: rgba(255, 255, 255, .5);--color-text-disabled: rgba(255, 255, 255, .3);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--transition-fast: .1s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--safe-area-top: env(safe-area-inset-top);--safe-area-bottom: env(safe-area-inset-bottom)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;background:transparent}body:before{content:"";position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;background:url(/images/starry_bg.png) center/cover no-repeat;z-index:-999;pointer-events:none}.app-container{min-height:100%;display:flex;flex-direction:column;padding-bottom:calc(80px + var(--safe-area-bottom))}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;color:#fff;font-size:18px}.page-title{font-size:28px;font-weight:700;color:var(--color-text);padding:var(--spacing-lg) var(--spacing-md)}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--spacing-md);margin:0 var(--spacing-md) var(--spacing-md)}.card-title{font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-md)}.btn{border:none;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-normal);display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.btn-primary{background:var(--gradient-danger);color:var(--color-text)}.btn-primary:hover{opacity:.9;transform:scale(1.02)}.btn-primary:disabled{background:rgba(255,255,255,.1);color:var(--color-text-disabled);cursor:not-allowed;transform:none}.btn-secondary{background:var(--color-bg-card);color:var(--color-text)}.btn-secondary:hover{background:var(--color-bg-card-hover)}.input{background:var(--color-bg-card);border:none;border-radius:var(--radius-md);padding:var(--spacing-md);color:var(--color-text);font-size:16px;width:100%;outline:none;transition:background var(--transition-normal)}.input::placeholder{color:var(--color-text-muted)}.input:focus{background:var(--color-bg-card-hover)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:rgba(26,26,46,.95);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:var(--spacing-sm) 0;padding-bottom:calc(var(--spacing-sm) + var(--safe-area-bottom));display:flex;justify-content:space-around;border-top:1px solid rgba(255,255,255,.1);z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--color-text-muted);text-decoration:none;padding:var(--spacing-xs) var(--spacing-md);transition:color var(--transition-normal);background:none;border:none;cursor:pointer}.nav-item.active{color:var(--color-accent)}.nav-item span{font-size:10px}.accounting-page{display:flex;flex-direction:column;height:100%}.sub-tab-bar{display:flex;gap:4px;padding:calc(12px + var(--safe-area-top)) 16px 0;background:transparent;position:sticky;top:0;z-index:10}.sub-tab-item{flex:1;padding:10px 0;border:none;background:transparent;color:var(--color-text-muted);font-size:15px;font-weight:500;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-normal);position:relative}.sub-tab-item.active{color:var(--color-accent);font-weight:700;background:rgba(78,205,196,.1)}.sub-tab-item.active:after{content:"";position:absolute;bottom:0;left:30%;right:30%;height:3px;background:var(--color-accent);border-radius:2px}.sub-tab-item:not(.active):hover{color:var(--color-text-secondary);background:rgba(255,255,255,.05)}.fab{position:fixed;bottom:calc(90px + var(--safe-area-bottom));left:50%;transform:translate(-50%);width:56px;height:56px;border-radius:50%;background:var(--gradient-danger);border:none;box-shadow:0 4px 20px rgba(255,107,107,.4);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text);transition:all var(--transition-normal);z-index:101}.fab:hover{transform:translate(-50%) scale(1.1)}.fab:active{transform:translate(-50%) scale(.95)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-end;justify-content:center}.modal-content{background:var(--color-bg-primary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:500px;max-height:95vh;overflow-y:auto;padding-bottom:var(--safe-area-bottom);animation:slideUp .3s ease}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:2px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--color-text-muted);text-align:center}.empty-state svg{width:48px;height:48px;margin-bottom:var(--spacing-md);opacity:.3}.empty-state p{font-size:14px}.empty-hint{font-size:12px!important;margin-top:4px}@keyframes tap{0%,to{transform:scale(1)}50%{transform:scale(.95)}}.tap-effect:active{animation:tap .1s ease}@media(min-width:768px){.app-container{max-width:500px;margin:0 auto}.bottom-nav{max-width:500px;left:50%;transform:translate(-50%);border-radius:var(--radius-lg) var(--radius-lg) 0 0}}.bento-grid{display:flex;flex-direction:column;gap:10px;padding:12px;width:100%;max-width:600px;margin:0 auto}.bento-card{background:rgba(40,42,45,.6);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:14px;overflow:hidden;position:relative;display:flex;flex-direction:column;box-shadow:0 4px 16px rgba(0,0,0,.1)}.bento-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.05),rgba(255,255,255,0));z-index:1}.bento-card-large,.bento-card-square{width:100%}.bento-card-title{font-size:.75rem;font-weight:700;color:rgba(255,255,255,.6);letter-spacing:.5px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;z-index:2}.bento-card-content{flex:1;display:flex;flex-direction:column;z-index:2;position:relative;height:100%}@keyframes slideDown{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}.notif-list-page{min-height:100vh;background:var(--color-bg-base)}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;z-index:10;background:var(--color-bg-base)}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:60vh;color:#666}.notif-items{padding:8px 0}.notif-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;cursor:pointer;transition:background .2s;border-bottom:1px solid rgba(255,255,255,.04)}.notif-item:hover{background:rgba(255,255,255,.04)}.notif-item.unread{background:rgba(124,108,240,.06)}.notif-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-content{flex:1;min-width:0}.notif-title{font-size:14px;font-weight:600;color:var(--color-text-primary);line-height:1.4}.notif-msg{font-size:12px;color:#888;margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-time{font-size:11px;color:#666;margin-top:4px}.notif-dot{width:8px;height:8px;border-radius:50%;background:#7c6cf0;flex-shrink:0;margin-top:6px}.notif-badge{position:absolute;top:-4px;right:-4px;background:#f5222d;color:#fff;border-radius:10px;min-width:16px;height:16px;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700;padding:0 4px}.ev-card-badge-pending{font-size:.7rem;color:#fff;background:#7c6cf0;padding:1px 6px;border-radius:8px;margin-left:auto;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.ev-card-user-status{margin-top:6px;display:flex;justify-content:flex-end}.ev-status-tag{font-size:.7rem;padding:2px 8px;border-radius:10px;font-weight:600;letter-spacing:.5px}.ev-status-creator{background:rgba(124,108,240,.2);color:#7c6cf0}.ev-status-joined{background:rgba(82,196,26,.2);color:#52c41a}.ev-status-pending{background:rgba(250,173,20,.2);color:#faad14}.ev-status-rejected{background:rgba(245,34,45,.2);color:#f5222d}.ev-status-none{background:rgba(255,255,255,.06);color:#888}.bento-card-horizontal{width:100%}button,a,[role=button],.clickable{-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:44px;min-width:44px}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:24px}.error-boundary-card{text-align:center;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:32px 24px;max-width:300px}.error-boundary-icon{font-size:48px;display:block;margin-bottom:12px}.error-boundary-card h3{color:#fff;font-size:18px;margin-bottom:8px}.error-boundary-card p{color:#999;font-size:13px;margin-bottom:16px}.error-boundary-card button{background:linear-gradient(135deg,#7c6cf0,#a78bfa);color:#fff;border:none;border-radius:12px;padding:10px 24px;font-size:14px;font-weight:600;cursor:pointer}.app-container>div{animation:pageFadeIn .2s ease}@keyframes pageFadeIn{0%{opacity:0}to{opacity:1}}.legal-doc-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:16px}.legal-doc-panel{background:var(--color-bg-base, #1a1a2e);border-radius:20px;width:100%;max-width:480px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.legal-doc-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.legal-doc-header h2{font-size:1.1rem;font-weight:700;color:var(--color-text-primary, #fff);margin:0}.legal-doc-close{background:rgba(255,255,255,.1);border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary, #aaa);cursor:pointer;transition:background .2s}.legal-doc-close:hover{background:rgba(255,255,255,.2)}.legal-doc-body{flex:1;overflow-y:auto;padding:20px;color:var(--color-text-secondary, #ccc);font-size:.88rem;line-height:1.8}.legal-doc-body h3{color:var(--color-text-primary, #fff);font-size:.95rem;font-weight:600;margin:20px 0 8px}.legal-doc-body h3:first-child{margin-top:0}.legal-doc-body p{margin:6px 0}.legal-doc-body ul{padding-left:20px;margin:6px 0}.legal-doc-body li{margin:4px 0}.legal-doc-body .legal-update-date{font-size:.8rem;color:var(--color-text-muted, #888);margin-bottom:16px}.consent-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.92);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);z-index:3000;display:flex;align-items:center;justify-content:center;padding:24px}.consent-panel{background:var(--color-bg-base, #1a1a2e);border-radius:24px;width:100%;max-width:400px;padding:32px 24px;border:1px solid rgba(255,255,255,.1);text-align:center}.consent-icon{font-size:48px;margin-bottom:16px}.consent-title{font-size:1.2rem;font-weight:700;color:var(--color-text-primary, #fff);margin-bottom:12px}.consent-desc{font-size:.85rem;color:var(--color-text-secondary, #aaa);line-height:1.6;margin-bottom:20px}.consent-summary{background:rgba(255,255,255,.05);border-radius:14px;padding:16px;text-align:left;margin-bottom:20px;border:1px solid rgba(255,255,255,.06)}.consent-summary-item{display:flex;align-items:flex-start;gap:8px;margin-bottom:10px;font-size:.82rem;color:var(--color-text-secondary, #ccc);line-height:1.4}.consent-summary-item:last-child{margin-bottom:0}.consent-summary-item .icon{flex-shrink:0;margin-top:1px}.consent-links{display:flex;justify-content:center;gap:16px;margin-bottom:24px}.consent-links button{background:none;border:none;color:var(--color-accent, #4ecdc4);font-size:.82rem;cursor:pointer;text-decoration:underline;padding:0}.consent-btn-agree{width:100%;padding:14px;border:none;border-radius:14px;background:linear-gradient(135deg,#4ecdc4,#44b8ac);color:#fff;font-size:1rem;font-weight:700;cursor:pointer;margin-bottom:10px;transition:opacity .2s}.consent-btn-agree:hover{opacity:.9}.consent-btn-disagree{width:100%;padding:12px;border:none;border-radius:14px;background:transparent;color:var(--color-text-muted, #888);font-size:.85rem;cursor:pointer}.perm-list{display:flex;flex-direction:column;gap:12px;margin-top:8px}.perm-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background:rgba(255,255,255,.04);border-radius:12px;border:1px solid rgba(255,255,255,.06)}.perm-icon{width:36px;height:36px;border-radius:10px;background:rgba(78,205,196,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#4ecdc4}.perm-info{flex:1}.perm-name{font-size:.9rem;font-weight:600;color:var(--color-text-primary, #fff);margin-bottom:2px}.perm-desc{font-size:.78rem;color:var(--color-text-muted, #888);line-height:1.4}.delete-confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);z-index:2500;display:flex;align-items:center;justify-content:center;padding:24px}.delete-confirm-panel{background:var(--color-bg-base, #1a1a2e);border-radius:20px;width:100%;max-width:360px;padding:28px 24px;border:1px solid rgba(255,82,82,.3);text-align:center}.delete-confirm-panel h3{color:#ff5252;font-size:1.1rem;margin:0 0 12px}.delete-confirm-panel p{color:var(--color-text-secondary);font-size:.85rem;line-height:1.5;margin-bottom:16px}.delete-confirm-panel input{width:100%;padding:12px;border:1px solid rgba(255,82,82,.3);border-radius:12px;background:rgba(255,255,255,.05);color:var(--color-text-primary);font-size:.9rem;margin-bottom:16px;box-sizing:border-box}.delete-confirm-panel input:focus{outline:none;border-color:#ff5252}.delete-confirm-btns{display:flex;gap:10px}.delete-confirm-btns button{flex:1;padding:12px;border:none;border-radius:12px;font-size:.9rem;font-weight:600;cursor:pointer}.delete-confirm-btns .btn-cancel{background:rgba(255,255,255,.08);color:var(--color-text-secondary)}.delete-confirm-btns .btn-danger{background:#ff5252;color:#fff}.delete-confirm-btns .btn-danger:disabled{opacity:.5;cursor:not-allowed}.auth-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.auth-modal{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;padding:40px;max-width:400px;width:90%;position:relative;animation:slideUp .3s ease;box-shadow:0 20px 60px rgba(0,0,0,.4)}.auth-close{position:absolute;top:20px;right:20px;background:rgba(255,255,255,.2);border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .3s}.auth-close:hover{background:rgba(255,255,255,.3);transform:rotate(90deg)}.auth-header{text-align:center;color:#fff;margin-bottom:30px}.auth-header h2{font-size:28px;margin:0 0 8px;font-weight:600}.auth-header p{margin:0;opacity:.9;font-size:14px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#fff;font-size:14px;font-weight:500}.form-group input{padding:12px 16px;border-radius:12px;border:2px solid rgba(255,255,255,.2);background:rgba(255,255,255,.15);color:#fff;font-size:15px;transition:all .3s}.form-group input::placeholder{color:rgba(255,255,255,.6)}.form-group input:focus{outline:none;border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.2)}.auth-error{background:rgba(255,59,48,.2);border:1px solid rgba(255,59,48,.4);color:#fff;padding:12px;border-radius:8px;font-size:14px;text-align:center}.auth-submit{background:#fff;color:#667eea;border:none;padding:14px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;margin-top:10px}.auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.2)}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-switch{text-align:center;color:#fff;font-size:14px;margin-top:10px}.auth-switch button{background:none;border:none;color:#fff;font-weight:600;cursor:pointer;margin-left:4px;text-decoration:underline;font-size:14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-agree-row{display:flex;align-items:flex-start;gap:8px;color:rgba(255,255,255,.9);font-size:13px;cursor:pointer;line-height:1.4}.auth-agree-row input[type=checkbox]{margin-top:2px;width:16px;height:16px;accent-color:#4ecdc4;flex-shrink:0}.auth-link{background:none;border:none;color:#fff;font-weight:600;cursor:pointer;padding:0;font-size:13px;text-decoration:underline}.auth-remember-row{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.9);font-size:13px;cursor:pointer}.auth-remember-row input[type=checkbox]{width:16px;height:16px;accent-color:#4ecdc4;flex-shrink:0}.static-page-container{min-height:100vh;background-color:var(--app-bg, #0f1015);color:var(--app-text, #fff);display:flex;flex-direction:column}.static-page-header{padding:16px 20px;background:var(--nav-bg, #1a1b23);border-bottom:1px solid rgba(255,255,255,.05);position:sticky;top:0;z-index:10}.static-page-header h1{margin:0;font-size:18px;font-weight:600;color:#fff}.static-page-content{flex:1;padding:20px;max-width:800px;margin:0 auto;width:100%;box-sizing:border-box}.static-page-content .legal-content{height:auto;max-height:none;overflow-y:visible;padding-right:0}.delete-guide-content h2{font-size:24px;margin-bottom:16px;color:#fff}.delete-guide-content>p{color:#aaa;line-height:1.6;margin-bottom:24px}.guide-steps{background:rgba(255,255,255,.05);border-radius:12px;padding:20px;margin-bottom:24px}.step-item{display:flex;align-items:flex-start;margin-bottom:16px;gap:12px}.step-item:last-child{margin-bottom:0}.step-num{background:var(--accent-light, #7c6cf0);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.step-text{color:#ddd;line-height:1.5;padding-top:2px}.step-text strong{color:#fff}.guide-note{border-left:3px solid #ff9800;background:rgba(255,152,0,.1);padding:16px;border-radius:0 8px 8px 0}.guide-note strong{color:#ff9800;display:block;margin-bottom:8px}.guide-note ul{margin:0;padding-left:20px;color:#bbb}.guide-note li{margin-bottom:6px;line-height:1.4}.guide-note li:last-child{margin-bottom:0}.app-updater-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:updaterFadeIn .3s ease;padding:24px}@keyframes updaterFadeIn{0%{opacity:0}to{opacity:1}}@keyframes updaterSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.app-updater-modal{background:linear-gradient(145deg,#1e1e3a,#16162b);border:1px solid rgba(124,108,240,.2);border-radius:24px;padding:32px 28px;width:100%;max-width:340px;text-align:center;animation:updaterSlideUp .4s ease;box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 40px rgba(124,108,240,.1)}.app-updater-icon{font-size:48px;margin-bottom:12px;animation:updaterBounce 1s ease infinite alternate}@keyframes updaterBounce{0%{transform:translateY(0)}to{transform:translateY(-6px)}}.app-updater-title{font-size:20px;font-weight:700;color:#fff;margin:0 0 6px}.app-updater-version{font-size:14px;color:#a78bfa;font-weight:600;margin:0 0 18px}.app-updater-changelog{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:14px 16px;text-align:left;margin-bottom:22px}.app-updater-changelog-title{font-size:12px;color:#888;margin:0 0 8px}.app-updater-changelog-content{font-size:13px;color:#ccc;line-height:1.7;margin:0;white-space:pre-wrap;font-family:inherit}.app-updater-actions{display:flex;flex-direction:column;gap:10px}.app-updater-btn{width:100%;padding:13px;border:none;border-radius:14px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.app-updater-btn.primary{background:linear-gradient(135deg,#7c6cf0,#a78bfa);color:#fff;box-shadow:0 4px 16px rgba(124,108,240,.3)}.app-updater-btn.primary:active{transform:scale(.97)}.app-updater-btn.primary:disabled{opacity:.6;cursor:not-allowed}.app-updater-btn.secondary{background:rgba(255,255,255,.06);color:#888;border:1px solid rgba(255,255,255,.08)}.app-updater-btn.secondary:active{background:rgba(255,255,255,.1)}.toast-container{position:fixed;top:calc(12px + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);z-index:99999;display:flex;flex-direction:column;gap:8px;pointer-events:none;width:90%;max-width:360px}.toast-item{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:14px;font-size:14px;font-weight:500;pointer-events:auto;animation:toastSlideIn .3s ease,toastFadeOut .3s ease 2.7s forwards;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 8px 24px rgba(0,0,0,.3)}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes toastFadeOut{0%{opacity:1}to{opacity:0;transform:translateY(-10px)}}.toast-success{background:rgba(82,196,26,.15);border:1px solid rgba(82,196,26,.3);color:#95de64}.toast-error{background:rgba(255,77,79,.15);border:1px solid rgba(255,77,79,.3);color:#ff7875}.toast-warning{background:rgba(250,173,20,.15);border:1px solid rgba(250,173,20,.3);color:#ffc53d}.toast-info{background:rgba(24,144,255,.15);border:1px solid rgba(24,144,255,.3);color:#69c0ff}.toast-icon{font-size:16px;flex-shrink:0}.toast-msg{flex:1;line-height:1.4}.network-offline-bar{position:fixed;top:0;left:0;right:0;padding:8px 16px;padding-top:calc(8px + env(safe-area-inset-top,0px));background:rgba(255,77,79,.9);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:13px;font-weight:600;text-align:center;z-index:100000;animation:offlineSlide .3s ease}@keyframes offlineSlide{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.tagwall-page{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(180deg,#1a1119,#231520,#1a1119);background-attachment:fixed;position:relative;overflow-x:hidden}.tagwall-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.03;background:repeating-linear-gradient(90deg,transparent 0,transparent 50px,rgba(255,107,223,.1) 50px,rgba(255,107,223,.1) 52px),repeating-linear-gradient(0deg,transparent 0,transparent 25px,rgba(57,255,20,.06) 25px,rgba(57,255,20,.06) 27px)}.tagwall-header{display:flex;align-items:center;gap:12px;padding:calc(16px + env(safe-area-inset-top,0px)) 16px 8px;position:relative;z-index:2}.tagwall-back-btn{background:none;border:none;color:#ff6bdf;cursor:pointer;padding:6px}.tagwall-header-text h2{font-size:20px;color:#ff6bdf;margin:0;text-shadow:0 0 20px rgba(255,107,223,.4),0 0 40px rgba(255,107,223,.15)}.tagwall-header-sub{font-size:12px;color:rgba(255,107,223,.4);margin:2px 0 0}.tagwall-body{flex:1;padding:8px 16px 100px;display:flex;flex-direction:column;gap:14px;position:relative;z-index:1}.tagwall-card{border-radius:18px;padding:18px;background:rgba(255,107,223,.04);border:1px solid rgba(255,107,223,.1);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:relative;overflow:hidden}.tagwall-card:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,107,223,.04) 0%,transparent 70%);pointer-events:none}.tagwall-card-header{display:flex;align-items:center;gap:8px;margin-bottom:14px}.tagwall-card-icon{font-size:18px}.tagwall-card-title{font-size:15px;font-weight:600;color:#f0d0e8;flex:1}.tagwall-card-badge{padding:3px 10px;border-radius:12px;background:rgba(255,107,223,.12);border:1px solid rgba(255,107,223,.2);color:#ff6bdf;font-size:11px;font-weight:500}.tagwall-cloud{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;padding:8px 0}.tagwall-sticker{display:inline-flex;align-items:center;gap:4px;padding:8px 16px;border-radius:20px;font-weight:600;cursor:default;transform:rotate(var(--tilt, 0deg)) scale(var(--scale, 1));transition:all .3s cubic-bezier(.34,1.56,.64,1);animation:stickerPop .4s cubic-bezier(.34,1.56,.64,1) backwards;position:relative;letter-spacing:.5px}@keyframes stickerPop{0%{opacity:0;transform:rotate(var(--tilt, 0deg)) scale(0)}to{opacity:1;transform:rotate(var(--tilt, 0deg)) scale(var(--scale, 1))}}.tagwall-sticker:hover{transform:rotate(0) scale(1.15)!important;z-index:2}.tagwall-sticker-count{font-size:10px;opacity:.7;margin-left:2px}.tagwall-cloud-empty{text-align:center;padding:24px 16px}.tagwall-cloud-empty-icon{font-size:36px;display:block;margin-bottom:10px}.tagwall-cloud-empty p{color:#f0d0e8;font-size:14px;margin:0}.tagwall-cloud-empty-hint{color:rgba(255,107,223,.4)!important;font-size:12px!important;margin-top:4px!important}.tagwall-compose-card{border-color:rgba(57,255,20,.08);background:rgba(57,255,20,.03)}.tagwall-compose-card:before{background:radial-gradient(circle,rgba(57,255,20,.03) 0%,transparent 70%)}.tagwall-friend-btn{display:block;width:100%;padding:12px 16px;border-radius:12px;border:1px dashed rgba(57,255,20,.2);background:rgba(57,255,20,.04);color:rgba(57,255,20,.6);font-size:14px;cursor:pointer;text-align:left;transition:all .3s}.tagwall-friend-btn:hover{border-color:rgba(57,255,20,.4);background:rgba(57,255,20,.08)}.tagwall-friend-selected{color:#39ff14;font-weight:500}.tagwall-friend-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;padding:10px;border-radius:12px;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.04);max-height:160px;overflow-y:auto}.tagwall-friend-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);color:#d0c0d8;font-size:13px;cursor:pointer;transition:all .3s}.tagwall-friend-chip img{width:22px;height:22px;border-radius:50%;object-fit:cover}.tagwall-friend-chip .avatar-letter{width:22px;height:22px;border-radius:50%;background:rgba(255,107,223,.15);display:flex;align-items:center;justify-content:center;font-size:11px;color:#ff6bdf}.tagwall-friend-chip:hover{border-color:rgba(255,107,223,.3);background:rgba(255,107,223,.06)}.tagwall-friend-chip.selected{border-color:#39ff14;background:rgba(57,255,20,.1);color:#39ff14}.tagwall-input-row{display:flex;gap:8px;margin-top:10px}.tagwall-input{flex:1;padding:10px 14px;border-radius:12px;border:1px solid rgba(57,255,20,.15);background:rgba(0,0,0,.2);color:#e8d5f0;font-size:14px;outline:none}.tagwall-input::placeholder{color:rgba(57,255,20,.25)}.tagwall-input:focus{border-color:#39ff14;box-shadow:0 0 12px rgba(57,255,20,.15)}.tagwall-send-btn{width:44px;height:44px;border-radius:12px;border:none;background:linear-gradient(135deg,#39ff14,#0c6);color:#0a0a0a;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;box-shadow:0 4px 12px rgba(57,255,20,.2)}.tagwall-send-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(57,255,20,.3)}.tagwall-send-btn:disabled{opacity:.3;cursor:not-allowed}.tagwall-hint{margin-top:12px;font-size:11px;color:rgba(200,180,220,.35);text-align:center}.tagwall-sticker.public{outline:2px solid rgba(57,255,20,.3);outline-offset:2px}.tagwall-public-badge{font-size:10px;margin-right:2px}.tagwall-public-hint{margin-top:12px;font-size:11px;color:rgba(57,255,20,.35);text-align:center}.tagwall-float-zone{position:relative;min-height:200px;flex:1;overflow:hidden;border-radius:18px;background:rgba(255,107,223,.02);border:1px dashed rgba(255,107,223,.06)}.tagwall-float-zone-title{position:absolute;top:12px;left:16px;font-size:12px;color:rgba(255,107,223,.35);z-index:1}.tagwall-float-tag{position:absolute;font-size:13px;font-weight:500;opacity:.35;padding:4px 12px;border-radius:14px;border:1px solid;white-space:nowrap;pointer-events:none;animation:tagFloat linear infinite;display:flex;align-items:center;gap:6px}.tagwall-float-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover;flex-shrink:0}.tagwall-float-avatar-letter{width:20px;height:20px;border-radius:50%;background:rgba(255,107,223,.2);display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0}@keyframes tagFloat{0%{transform:translate(0) rotate(0);opacity:.15}15%{opacity:.3}25%{transform:translate(10px,-12px) rotate(3deg)}50%{transform:translate(-8px,-20px) rotate(-2deg);opacity:.25}75%{transform:translate(12px,-8px) rotate(4deg)}85%{opacity:.3}to{transform:translate(0) rotate(0);opacity:.15}}.tagwall-float-deco{position:absolute;pointer-events:none;opacity:.12;font-size:18px}.deco-1{top:15%;right:12%;animation:decoFloat 5s ease-in-out infinite}.deco-2{bottom:20%;left:10%;animation:decoFloat 6s ease-in-out infinite reverse}.deco-3{bottom:35%;right:25%;animation:decoFloat 7s ease-in-out infinite}@keyframes decoFloat{0%,to{transform:translateY(0) rotate(0);opacity:.1}50%{transform:translateY(-10px) rotate(15deg);opacity:.18}}.tagwall-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:rgba(255,107,223,.5);font-size:14px;position:relative;z-index:1}.tagwall-loading-orb{width:40px;height:40px;border-radius:50%;background:radial-gradient(circle,rgba(255,107,223,.3) 0%,transparent 70%);animation:orbPulse 2s ease-in-out infinite}@keyframes orbPulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.3);opacity:1}}.tagwall-empty{text-align:center;padding:16px;color:rgba(200,180,220,.4);font-size:13px}.tagwall-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);padding:10px 24px;border-radius:30px;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;font-size:14px;z-index:100;animation:toastIn .3s ease;white-space:nowrap}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.report-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}.report-modal{background:var(--color-bg-card, #1e1e2e);border-radius:16px;padding:24px;width:100%;max-width:400px;box-shadow:0 16px 48px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.1);animation:slideUp .25s ease}.report-modal h3{margin:0 0 16px;font-size:18px;font-weight:700;color:var(--color-text-primary, #fff)}.report-modal textarea{width:100%;min-height:100px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.05);color:var(--color-text-primary, #fff);padding:12px;font-size:14px;resize:vertical;outline:none;transition:border-color .2s;box-sizing:border-box}.report-modal textarea:focus{border-color:rgba(255,255,255,.3)}.report-images{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.report-image-preview{width:72px;height:72px;border-radius:8px;overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.1)}.report-image-preview img{width:100%;height:100%;object-fit:cover}.report-image-preview .remove-btn{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.7);color:#fff;border:none;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.report-add-image{width:72px;height:72px;border-radius:8px;border:1px dashed rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:rgba(255,255,255,.4);transition:all .2s}.report-add-image:hover{border-color:rgba(255,255,255,.4);color:rgba(255,255,255,.6)}.report-actions{display:flex;gap:10px;margin-top:20px}.report-actions button{flex:1;padding:10px;border-radius:10px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.report-actions .cancel-btn{background:rgba(255,255,255,.08);color:var(--color-text-muted, #999)}.report-actions .cancel-btn:hover{background:rgba(255,255,255,.12)}.report-actions .submit-btn{background:#e53935;color:#fff}.report-actions .submit-btn:hover{background:#c62828}.report-actions .submit-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.bottle-page{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(180deg,#0a1628,#0d2137,#0a1a2e 60%,#061220);background-attachment:fixed;position:relative;overflow-x:hidden}.bottle-page:before,.bottle-page:after{content:"";position:absolute;border-radius:50%;pointer-events:none;opacity:.25}.bottle-page:before{width:8px;height:8px;left:20%;bottom:-10px;background:rgba(0,210,255,.5);box-shadow:0 0 6px rgba(0,210,255,.4);animation:bubbleUp 6s ease-in infinite}.bottle-page:after{width:5px;height:5px;left:70%;bottom:-10px;background:rgba(0,210,255,.4);box-shadow:0 0 4px rgba(0,210,255,.3);animation:bubbleUp 8s ease-in infinite 2s}@keyframes bubbleUp{0%{transform:translateY(0) scale(1);opacity:.3}50%{opacity:.5}to{transform:translateY(-100vh) scale(.5);opacity:0}}.bottle-header{display:flex;align-items:center;gap:8px;padding:calc(16px + env(safe-area-inset-top,0px)) 16px 12px;position:relative;z-index:1}.bottle-header h2{font-size:20px;color:#7dd3fc;margin:0;text-shadow:0 0 12px rgba(56,189,248,.3)}.bottle-body{flex:1;overflow-y:auto;padding:0 12px 80px;position:relative;z-index:1}.bottle-action-row{display:flex;gap:10px;margin-bottom:16px}.bottle-action-card{flex:1;padding:20px 14px;border-radius:16px;border:1px solid rgba(56,189,248,.15);background:rgba(56,189,248,.06);display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:all .3s}.bottle-action-card:hover:not(.disabled){border-color:rgba(56,189,248,.35);transform:translateY(-2px);box-shadow:0 8px 24px rgba(56,189,248,.12)}.bottle-action-card.disabled{opacity:.4;cursor:not-allowed}.bottle-action-icon{font-size:32px;filter:drop-shadow(0 0 8px rgba(56,189,248,.4))}.bottle-action-label{font-size:15px;font-weight:600;color:#7dd3fc}.bottle-action-quota{font-size:11px;color:rgba(125,211,252,.4)}.bottle-throw-area{padding:14px;border-radius:14px;background:rgba(56,189,248,.04);border:1px solid rgba(56,189,248,.12);margin-bottom:16px;animation:fadeSlideUp .3s ease}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.bottle-throw-input{width:100%;padding:12px;border-radius:12px;border:1px solid rgba(56,189,248,.15);background:rgba(0,0,0,.2);color:#e0f2fe;font-size:14px;outline:none;box-sizing:border-box;margin-bottom:10px}.bottle-throw-input::placeholder{color:rgba(125,211,252,.3)}.bottle-throw-input:focus{border-color:#38bdf8}.bottle-throw-btn{width:100%;padding:10px;border-radius:12px;border:none;background:linear-gradient(135deg,#0284c7,#0ea5e9);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.bottle-throw-btn:hover:not(:disabled){box-shadow:0 4px 16px rgba(14,165,233,.3)}.bottle-throw-btn:disabled{opacity:.4;cursor:not-allowed}.bottle-section-title{font-size:13px;color:rgba(125,211,252,.5);margin-bottom:10px;text-transform:uppercase;letter-spacing:1px}.bottle-item{display:flex;align-items:center;gap:12px;padding:14px;border-radius:14px;background:rgba(56,189,248,.04);border:1px solid rgba(56,189,248,.08);cursor:pointer;transition:all .3s}.bottle-item:hover{border-color:rgba(56,189,248,.2);background:rgba(56,189,248,.08)}.bottle-item-icon{font-size:24px;flex-shrink:0}.bottle-item-text{font-size:14px;color:#e0f2fe;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bottle-item-meta{font-size:11px;color:rgba(125,211,252,.4);margin-top:4px}.bottle-item-status{font-size:11px;padding:3px 8px;border-radius:10px;flex-shrink:0}.bottle-status-floating{background:rgba(56,189,248,.1);color:#7dd3fc}.bottle-status-chatting{background:rgba(52,211,153,.1);color:#6ee7b7}.bottle-status-revealed{background:rgba(251,191,36,.1);color:#fbbf24}.bottle-status-closed{background:rgba(148,163,184,.1);color:#94a3b8}.bottle-empty{text-align:center;padding:24px;color:rgba(125,211,252,.3);font-size:14px}.bottle-chat-page{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(180deg,#0a1628,#0d2137,#0a1628);background-attachment:fixed}.bottle-original{margin:0 12px 8px;padding:12px 14px;border-radius:12px;background:rgba(56,189,248,.06);border:1px solid rgba(56,189,248,.1)}.bottle-original-label{font-size:11px;color:rgba(125,211,252,.5);margin-bottom:6px}.bottle-original-text{font-size:14px;color:#bae6fd;line-height:1.5}.bottle-reveal-bar{margin:0 12px 8px;text-align:center}.bottle-revealed-info{padding:10px;border-radius:10px;background:rgba(52,211,153,.08);color:#6ee7b7;font-size:13px}.bottle-peer-name{margin-left:6px;font-weight:600}.bottle-waiting{padding:10px;font-size:13px;color:rgba(251,191,36,.7)}.bottle-reveal-btn{display:inline-flex;align-items:center;gap:4px;padding:8px 20px;border-radius:20px;border:1px solid rgba(56,189,248,.3);background:rgba(56,189,248,.1);color:#7dd3fc;font-size:13px;cursor:pointer;transition:all .3s}.bottle-reveal-btn:hover{background:rgba(56,189,248,.2);box-shadow:0 0 16px rgba(56,189,248,.15)}.bottle-messages{flex:1;overflow-y:auto;padding:8px 12px}.bottle-msg{display:flex;gap:8px;margin-bottom:12px;align-items:flex-end}.bottle-msg-avatar{width:28px;height:28px;border-radius:50%;background:rgba(56,189,248,.15);display:flex;align-items:center;justify-content:center;font-size:11px;color:#7dd3fc;flex-shrink:0;overflow:hidden}.bottle-msg-bubble{max-width:70%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.5;word-break:break-word}.bottle-msg.theirs .bottle-msg-bubble{background:rgba(56,189,248,.08);color:#bae6fd;border-bottom-left-radius:4px}.bottle-msg.mine .bottle-msg-bubble{background:linear-gradient(135deg,#0284c7,#0ea5e9);color:#fff;border-bottom-right-radius:4px}.bottle-input-bar{display:flex;gap:8px;padding:10px 12px;border-top:1px solid rgba(56,189,248,.08)}.bottle-chat-input{flex:1;padding:10px 14px;border-radius:20px;border:1px solid rgba(56,189,248,.15);background:rgba(0,0,0,.2);color:#e0f2fe;font-size:14px;outline:none}.bottle-chat-input::placeholder{color:rgba(125,211,252,.3)}.bottle-chat-input:focus{border-color:#38bdf8}.bottle-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);padding:10px 24px;border-radius:20px;background:rgba(0,0,0,.85);color:#fff;font-size:14px;z-index:100;animation:fadeSlideUp .3s ease}.mbti-entry-card{background:rgba(255,255,255,.05)!important;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1)!important;position:relative;overflow:hidden}.mbti-entry-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.02;background:repeating-linear-gradient(0deg,transparent 0,transparent 20px,rgba(191,90,242,.3) 20px,rgba(191,90,242,.3) 21px),repeating-linear-gradient(90deg,transparent 0,transparent 20px,rgba(191,90,242,.3) 20px,rgba(191,90,242,.3) 21px)}.mbti-entry-card:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;pointer-events:none;background:radial-gradient(ellipse at 70% 30%,rgba(191,90,242,.08) 0%,transparent 50%)}.mbti-entry-top{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:1}.mbti-entry-label{font-size:12px;color:rgba(191,90,242,.5);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.mbti-entry-title{font-size:18px;font-weight:700;color:#e8d5f5;display:flex;align-items:center;gap:8px}.mbti-entry-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid rgba(191,90,242,.3);box-shadow:0 0 16px rgba(191,90,242,.2)}.mbti-entry-desc{font-size:13px;color:rgba(196,163,217,.7);margin-top:10px;line-height:1.5;position:relative;z-index:1}.mbti-progress-area{margin-top:16px;position:relative;z-index:1}.mbti-progress-info{display:flex;justify-content:space-between;font-size:11px;color:rgba(191,90,242,.6);margin-bottom:6px}.mbti-progress-bar{height:5px;background:rgba(191,90,242,.1);border-radius:3px;overflow:hidden}.mbti-progress-fill{height:100%;background:linear-gradient(90deg,#bf5af2,#ff375f);border-radius:3px;transition:width .5s ease;box-shadow:0 0 8px rgba(191,90,242,.4)}.mbti-cta-btn{width:100%;padding:12px;border-radius:14px;border:none;color:#fff;font-size:15px;font-weight:600;cursor:pointer;display:flex;justify-content:center;align-items:center;gap:8px;margin-top:16px;transition:all .3s;position:relative;z-index:1;overflow:hidden}.mbti-cta-btn.primary{background:linear-gradient(135deg,#bf5af2,#ff375f);box-shadow:0 4px 16px rgba(191,90,242,.3)}.mbti-cta-btn.primary:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:16px;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);animation:btnShimmer 2.5s ease-in-out infinite}.mbti-cta-btn.secondary{background:rgba(191,90,242,.1);border:1px solid rgba(191,90,242,.15)}.mbti-cta-btn:hover{transform:translateY(-1px)}.mbti-cta-btn.primary:hover{box-shadow:0 6px 24px rgba(191,90,242,.4)}.tarot-page{display:flex;flex-direction:column;min-height:100vh;background:transparent;position:relative;overflow-x:hidden}.tarot-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse at 50% 30%,rgba(138,43,226,.06) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(75,0,130,.04) 0%,transparent 40%)}@keyframes twinkle{0%{opacity:.7}to{opacity:1}}.tarot-page-header{display:flex;align-items:center;gap:8px;padding:16px 16px 8px;position:relative;z-index:1}.tarot-page-header h2{font-size:20px;color:#e8d5f5;margin:0;text-shadow:0 0 20px rgba(138,43,226,.3)}.tarot-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.tarot-loading-orb{width:60px;height:60px;border-radius:50%;background:radial-gradient(circle,rgba(186,85,211,.6) 0%,rgba(138,43,226,.2) 60%,transparent 70%);animation:orbPulse 2s ease-in-out infinite;box-shadow:0 0 40px rgba(138,43,226,.4)}@keyframes orbPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.2);opacity:1}}.tarot-loading p{color:#a78bba;font-size:14px}.tarot-input-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 20px 20px;position:relative;z-index:1}.tarot-orbit-container{position:relative;width:300px;height:300px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.tarot-crystal-ball{width:110px;height:130px;position:relative;display:flex;align-items:center;justify-content:center;z-index:2}.crystal-halo{position:absolute;border-radius:50%;border:1px solid transparent;pointer-events:none}.crystal-halo-1{width:130px;height:130px;top:-10px;left:50%;transform:translate(-50%);background:radial-gradient(circle,transparent 55%,rgba(168,85,247,.06) 70%,transparent 80%);border-image:linear-gradient(135deg,rgba(168,85,247,.3),rgba(236,72,153,.15),rgba(168,85,247,.05)) 1;animation:haloBreath1 4s ease-in-out infinite}.crystal-halo-2{width:160px;height:160px;top:-25px;left:50%;transform:translate(-50%);border:1px solid rgba(139,92,246,.12);animation:haloBreath2 5s ease-in-out infinite}.crystal-halo-3{width:190px;height:190px;top:-40px;left:50%;transform:translate(-50%);border:1px solid rgba(139,92,246,.05);animation:haloBreath3 6s ease-in-out infinite}@keyframes haloBreath1{0%,to{transform:translate(-50%) scale(1);opacity:.6}50%{transform:translate(-50%) scale(1.08);opacity:1}}@keyframes haloBreath2{0%,to{transform:translate(-50%) scale(1);opacity:.4}50%{transform:translate(-50%) scale(1.06);opacity:.7}}@keyframes haloBreath3{0%,to{transform:translate(-50%) scale(1);opacity:.2}50%{transform:translate(-50%) scale(1.04);opacity:.4}}.crystal-orb{width:100px;height:100px;border-radius:50%;position:relative;overflow:hidden;background:radial-gradient(ellipse 60% 40% at 35% 25%,rgba(255,255,255,.15) 0%,transparent 60%),radial-gradient(ellipse 80% 50% at 50% 80%,rgba(20,0,50,.5) 0%,transparent 60%),radial-gradient(circle at 50% 50%,rgba(120,50,200,.25),rgba(80,20,160,.15) 40%,rgba(30,10,80,.4),rgba(15,5,45,.8));box-shadow:0 0 30px rgba(168,85,247,.25),0 0 60px rgba(139,92,246,.12),inset 0 -10px 30px rgba(60,20,130,.4),inset 0 5px 15px rgba(200,150,255,.08),inset 0 -3px 8px rgba(168,85,247,.2);border:1px solid rgba(200,150,255,.12)}.crystal-nebula{position:absolute;top:10%;right:10%;bottom:10%;left:10%;border-radius:50%;background:conic-gradient(from 0deg,rgba(168,85,247,0),rgba(168,85,247,.15),rgba(236,72,153,.1),rgba(59,130,246,.08),rgba(168,85,247,.12) 240deg,rgba(139,92,246,0) 360deg);animation:nebulaSwirl 8s linear infinite;filter:blur(6px)}.crystal-nebula-2{animation:nebulaSwirl 12s linear infinite reverse;background:conic-gradient(from 90deg,rgba(236,72,153,0),rgba(59,130,246,.1),rgba(168,85,247,.15),rgba(236,72,153,.08),rgba(59,130,246,0) 360deg);filter:blur(8px)}@keyframes nebulaSwirl{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.crystal-stars{position:absolute;top:15%;right:15%;bottom:15%;left:15%;border-radius:50%;background:radial-gradient(1px 1px at 20% 30%,rgba(255,255,255,.8) 0%,transparent 100%),radial-gradient(1px 1px at 65% 45%,rgba(255,255,255,.7) 0%,transparent 100%),radial-gradient(1px 1px at 40% 70%,rgba(255,255,255,.9) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 75% 25%,rgba(200,150,255,.8) 0%,transparent 100%),radial-gradient(1px 1px at 30% 55%,rgba(255,255,255,.6) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 55% 80%,rgba(236,72,153,.7) 0%,transparent 100%),radial-gradient(1px 1px at 80% 65%,rgba(255,255,255,.8) 0%,transparent 100%),radial-gradient(1px 1px at 15% 75%,rgba(139,92,246,.9) 0%,transparent 100%);animation:starsShimmer 3s ease-in-out infinite alternate}@keyframes starsShimmer{0%{opacity:.5;transform:rotate(0)}to{opacity:1;transform:rotate(10deg)}}.crystal-highlight{position:absolute;width:55%;height:35%;top:8%;left:15%;border-radius:50%;background:linear-gradient(180deg,rgba(255,255,255,.22) 0%,rgba(255,255,255,.05) 60%,transparent 100%);pointer-events:none}.crystal-highlight-2{position:absolute;width:12px;height:8px;top:22%;left:60%;border-radius:50%;background:rgba(255,255,255,.25);filter:blur(2px);pointer-events:none}.crystal-core{position:absolute;width:20px;height:20px;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.5) 0%,rgba(200,150,255,.3) 30%,rgba(168,85,247,.2) 60%,transparent 100%);animation:corePulse 2.5s ease-in-out infinite}@keyframes corePulse{0%,to{transform:translate(-50%,-50%) scale(.8);opacity:.4}50%{transform:translate(-50%,-50%) scale(1.5);opacity:.9}}.crystal-base{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:60px;height:18px;background:linear-gradient(180deg,rgba(100,60,160,.4),rgba(60,30,100,.6),rgba(40,15,70,.8));border-radius:0 0 30px 30px/0 0 18px 18px;border:1px solid rgba(168,85,247,.15);border-top:none;box-shadow:0 4px 12px rgba(0,0,0,.3),inset 0 -2px 6px rgba(168,85,247,.1)}.crystal-base-glow{position:absolute;bottom:-5px;left:50%;transform:translate(-50%);width:80px;height:10px;background:radial-gradient(ellipse,rgba(168,85,247,.2) 0%,transparent 70%);filter:blur(4px);animation:baseGlow 3s ease-in-out infinite}@keyframes baseGlow{0%,to{opacity:.5}50%{opacity:1}}.tarot-crystal-ball.activated .crystal-orb{box-shadow:0 0 40px rgba(168,85,247,.4),0 0 80px rgba(139,92,246,.2),0 0 120px rgba(236,72,153,.08),inset 0 -10px 30px rgba(60,20,130,.4),inset 0 5px 15px rgba(200,150,255,.1)}.tarot-crystal-ball.activated .crystal-core{animation:coreActivated 1.2s ease-out forwards}@keyframes coreActivated{0%{transform:translate(-50%,-50%) scale(1);opacity:.6}50%{transform:translate(-50%,-50%) scale(3);opacity:1}to{transform:translate(-50%,-50%) scale(2);opacity:.8}}.tarot-crystal-ball.activated .crystal-halo-1{animation:haloActivated 1.5s ease-out forwards}@keyframes haloActivated{0%{transform:translate(-50%) scale(1);opacity:.6}40%{transform:translate(-50%) scale(1.5);opacity:1}to{transform:translate(-50%) scale(1.2);opacity:.3}}.tarot-orbit-ring{position:absolute;top:0;right:0;bottom:0;left:0;animation:orbitSpin 20s linear infinite}@keyframes orbitSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tarot-orbit-ring.paused{animation-play-state:paused}.tarot-orbit-card{position:absolute;width:54px;height:70px;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;transition:all .4s cubic-bezier(.34,1.56,.64,1);background:linear-gradient(135deg,rgba(168,85,247,.08),rgba(59,130,246,.04));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(168,85,247,.2);box-shadow:0 2px 12px rgba(168,85,247,.1),inset 0 1px rgba(255,255,255,.06)}.tarot-orbit-card-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;animation:orbitCounterSpin 20s linear infinite}@keyframes orbitCounterSpin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.tarot-orbit-ring.paused .tarot-orbit-card-inner{animation-play-state:paused}.tarot-orbit-card:hover{border-color:rgba(168,85,247,.5);transform:scale(1.12);box-shadow:0 4px 20px rgba(168,85,247,.25),inset 0 1px rgba(255,255,255,.1)}.tarot-orbit-card.active{border-color:rgba(236,72,153,.6);background:linear-gradient(135deg,rgba(168,85,247,.2),rgba(236,72,153,.1));transform:scale(1.18);box-shadow:0 0 20px rgba(168,85,247,.35),0 0 40px rgba(236,72,153,.15),inset 0 1px rgba(255,255,255,.1)}.tarot-orbit-card:nth-child(1){top:0;left:50%;transform:translate(-50%)}.tarot-orbit-card:nth-child(2){top:18%;right:0;transform:translate(0)}.tarot-orbit-card:nth-child(3){bottom:18%;right:0;transform:translate(0)}.tarot-orbit-card:nth-child(4){bottom:0;left:50%;transform:translate(-50%)}.tarot-orbit-card:nth-child(5){bottom:18%;left:0;transform:translate(0)}.tarot-orbit-card:nth-child(6){top:18%;left:0;transform:translate(0)}.tarot-orbit-card.active:nth-child(1){transform:translate(-50%) scale(1.18)}.tarot-orbit-card.active:nth-child(2){transform:translate(0) scale(1.18)}.tarot-orbit-card.active:nth-child(3){transform:translate(0) scale(1.18)}.tarot-orbit-card.active:nth-child(4){transform:translate(-50%) scale(1.18)}.tarot-orbit-card.active:nth-child(5){transform:translate(0) scale(1.18)}.tarot-orbit-card.active:nth-child(6){transform:translate(0) scale(1.18)}.tarot-orbit-icon{font-size:20px}.tarot-orbit-label{font-size:10px;color:#c4a3d9;font-weight:500}.tarot-orbit-card.active .tarot-orbit-label{color:#f0e6ff}.tarot-custom-area{width:100%;max-width:320px;display:flex;flex-direction:column;align-items:center;gap:12px}.tarot-custom-toggle{background:none;border:none;color:rgba(196,163,217,.6);font-size:12px;cursor:pointer;padding:4px;transition:color .3s}.tarot-custom-toggle:hover{color:#c4a3d9}.tarot-custom-input{width:100%;padding:12px 16px;border-radius:16px;border:1px solid rgba(138,43,226,.2);background:rgba(138,43,226,.06);color:#e8d5f5;font-size:14px;outline:none;box-sizing:border-box;transition:border-color .3s;text-align:center}.tarot-custom-input::placeholder{color:rgba(196,163,217,.35)}.tarot-custom-input:focus{border-color:#ba55d3}.tarot-generate-btn{padding:14px 56px;border:none;border-radius:28px;background:linear-gradient(135deg,#8b5cf6,#a855f7,#d946ef);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 24px rgba(139,92,246,.3);position:relative;overflow:hidden}.tarot-generate-btn:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:30px;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.15) 50%,transparent 70%);animation:btnShimmer 2s ease-in-out infinite}@keyframes btnShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.tarot-generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 30px rgba(139,92,246,.5)}.tarot-generate-btn:disabled{opacity:.4;cursor:not-allowed}.tarot-generate-btn:disabled:before{display:none}.tarot-limit-hint{color:rgba(196,163,217,.4);font-size:12px;text-align:center;margin:0}.tarot-flip-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;position:relative;z-index:1}.tarot-flip-card{width:180px;height:270px;perspective:800px;position:relative;transform-style:preserve-3d}.tarot-flip-card.flipping{animation:cardFlip 1.5s ease-in-out forwards}@keyframes cardFlip{0%{transform:rotateY(0) scale(1)}40%{transform:rotateY(90deg) scale(1.05)}60%{transform:rotateY(270deg) scale(1.05)}to{transform:rotateY(360deg) scale(1)}}.tarot-flip-front,.tarot-flip-back{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;backface-visibility:hidden}.tarot-card-back{width:100%;height:100%;border-radius:16px;background:linear-gradient(135deg,#2a1a4e,#4a2d7a);border:2px solid rgba(186,85,211,.3);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.tarot-card-back-pattern{position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:12px;border:1px solid rgba(186,85,211,.2);background:repeating-conic-gradient(rgba(186,85,211,.05) 0% 25%,transparent 0% 50%) 0 0 / 20px 20px}.tarot-card-back-symbol{font-size:48px;position:relative;z-index:1;animation:orbPulse 2s ease-in-out infinite}.tarot-flip-text{color:#c4a3d9;font-size:14px;animation:fadeInOut 1.5s ease-in-out infinite}@keyframes fadeInOut{0%,to{opacity:.4}50%{opacity:1}}.tarot-result{flex:1;overflow-y:auto;padding:0 16px 80px;position:relative;z-index:1;animation:resultFadeIn .6s ease}@keyframes resultFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tarot-result-card{background:rgba(138,43,226,.08);border:1px solid rgba(186,85,211,.15);border-radius:20px;overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.tarot-result-image{width:100%;aspect-ratio:1/1;overflow:hidden}.tarot-result-image img{width:100%;height:100%;object-fit:cover}.tarot-result-info{padding:20px}.tarot-card-name{font-size:24px;font-weight:700;color:#e8d5f5;text-align:center;margin-bottom:4px;text-shadow:0 0 20px rgba(186,85,211,.3)}.tarot-card-keyword{font-size:13px;color:#a78bba;text-align:center;margin-bottom:12px}.tarot-stars{display:flex;justify-content:center;gap:4px;margin-bottom:16px}.tarot-star{font-size:22px;color:rgba(186,85,211,.2);transition:color .3s}.tarot-star.active{color:#fbbf24;text-shadow:0 0 8px rgba(251,191,36,.4)}.tarot-reading{font-size:14px;line-height:1.7;color:#d4bce8;margin-bottom:16px;text-align:justify;padding:16px;border-radius:12px;background:rgba(138,43,226,.06);border-left:3px solid rgba(186,85,211,.3)}.tarot-advice{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:12px;background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(217,70,239,.1));color:#e8d5f5;font-size:14px;font-weight:500}.tarot-advice-icon{font-size:18px}.tarot-result-hint{text-align:center;color:rgba(196,163,217,.4);font-size:12px;margin-top:16px;padding-bottom:20px}.tarot-share-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:12px;padding:12px;border:none;border-radius:14px;background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(217,70,239,.15));border:1px solid rgba(186,85,211,.2);color:#e8d5f5;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.tarot-share-btn:hover{background:linear-gradient(135deg,rgba(139,92,246,.25),rgba(217,70,239,.25));box-shadow:0 4px 20px rgba(139,92,246,.2)}.tarot-share-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;animation:resultFadeIn .3s ease}.tarot-share-modal{width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:16px;position:relative}.tarot-share-close{position:absolute;top:-40px;right:0;background:rgba(255,255,255,.1);border:none;color:#fff;padding:8px;border-radius:50%;cursor:pointer;z-index:2}.tarot-share-card{width:100%;border-radius:20px;overflow:hidden;position:relative}.tarot-share-card-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(170deg,#0f0826,#1a103a,#2d1654 60%,#1a0e33)}.tarot-share-card-content{position:relative;z-index:1;padding:24px 20px 20px}.tarot-share-logo{display:flex;align-items:center;gap:6px;margin-bottom:16px}.tarot-share-logo-icon{font-size:18px}.tarot-share-logo-text{font-size:16px;font-weight:700;background:linear-gradient(135deg,#c084fc,#e879f9);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.tarot-share-date{margin-left:auto;font-size:11px;color:rgba(196,163,217,.5)}.tarot-share-image{width:100%;aspect-ratio:1/1;border-radius:14px;overflow:hidden;margin-bottom:16px;box-shadow:0 8px 32px rgba(139,92,246,.3)}.tarot-share-image img{width:100%;height:100%;object-fit:cover}.tarot-share-title{font-size:22px;font-weight:700;color:#f0e6ff;text-align:center;margin-bottom:6px;text-shadow:0 0 16px rgba(186,85,211,.4)}.tarot-share-stars{display:flex;justify-content:center;gap:4px;margin-bottom:14px}.tarot-share-stars span{font-size:18px;color:rgba(186,85,211,.2)}.tarot-share-stars span.active{color:#fbbf24;text-shadow:0 0 6px rgba(251,191,36,.4)}.tarot-share-reading{font-size:13px;line-height:1.8;color:#d4bce8;text-align:justify;padding:12px 14px;border-radius:10px;background:rgba(139,92,246,.08);border-left:3px solid rgba(186,85,211,.3);margin-bottom:10px}.tarot-share-advice{font-size:13px;color:#e8d5f5;padding:10px 14px;border-radius:10px;background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(217,70,239,.08));margin-bottom:16px}.tarot-share-footer{border-top:1px solid rgba(186,85,211,.12);padding-top:14px}.tarot-share-brand{display:flex;flex-direction:column;align-items:center;gap:4px}.tarot-share-brand-name{font-size:15px;font-weight:700;color:#c084fc}.tarot-share-slogan{font-size:11px;color:rgba(196,163,217,.4);letter-spacing:1px}.tarot-share-download{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border:none;border-radius:16px;background:linear-gradient(135deg,#8b5cf6,#a855f7,#d946ef);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 24px rgba(139,92,246,.3)}.tarot-share-download:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 30px rgba(139,92,246,.5)}.tarot-share-download:disabled{opacity:.6;cursor:not-allowed}.rant-page{display:flex;flex-direction:column;min-height:100vh;background:transparent;position:relative;overflow-x:hidden}.rant-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.05;background:repeating-linear-gradient(90deg,transparent 0,transparent 60px,rgba(255,255,255,.08) 60px,rgba(255,255,255,.08) 62px),repeating-linear-gradient(0deg,transparent 0,transparent 28px,rgba(255,255,255,.05) 28px,rgba(255,255,255,.05) 30px)}.rant-header{display:flex;align-items:center;gap:8px;padding:calc(14px + env(safe-area-inset-top,0px)) 16px 10px;position:relative;z-index:1}.rant-header .back-btn{background:none;border:none;color:#e8c9a0;cursor:pointer;padding:4px 8px}.rant-header h2{font-size:20px;color:#fbbf24;margin:0;flex:1;text-shadow:0 0 12px rgba(251,191,36,.4),0 0 30px rgba(251,191,36,.2);animation:neonFlicker 4s ease-in-out infinite}@keyframes neonFlicker{0%,to{opacity:1}93%{opacity:.85}95%{opacity:1}97%{opacity:.9}}.rant-compose-btn{padding:6px 14px;border-radius:16px;border:none;background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .3s}.rant-compose-btn:hover:not(:disabled){box-shadow:0 4px 16px rgba(245,158,11,.3)}.rant-compose-btn:disabled{opacity:.4;cursor:not-allowed}.rant-scope-tabs{display:flex;gap:6px;padding:0 16px 8px;position:relative;z-index:1}.rant-scope-tab{display:flex;align-items:center;gap:4px;padding:6px 14px;border-radius:16px;border:1px solid rgba(251,191,36,.1);background:rgba(251,191,36,.04);color:rgba(251,191,36,.5);font-size:12px;cursor:pointer;transition:all .3s}.rant-scope-tab.active{background:rgba(251,191,36,.12);border-color:rgba(251,191,36,.3);color:#fbbf24}.rant-list{flex:1;overflow-y:auto;padding:0 12px 80px;display:flex;flex-direction:column;gap:10px;position:relative;z-index:1}.rant-loading,.rant-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:rgba(251,191,36,.3);font-size:14px;position:relative;z-index:1}.rant-empty-icon{font-size:40px;margin-bottom:12px}.rant-item{background:rgba(40,30,30,.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(251,191,36,.1);border-radius:14px;padding:14px;position:relative;transition:all .3s}.rant-item:hover{border-color:rgba(251,191,36,.15);background:rgba(255,248,220,.08)}.rant-king{border-color:rgba(251,191,36,.3)!important;background:rgba(251,191,36,.08)!important;box-shadow:0 0 20px rgba(251,191,36,.08)}.rant-king-badge{font-size:11px;color:#fbbf24;margin-bottom:8px;font-weight:600;text-shadow:0 0 8px rgba(251,191,36,.3)}.rant-avatar{width:32px;height:32px;border-radius:50%;background:rgba(251,191,36,.12);display:flex;align-items:center;justify-content:center;font-size:14px;color:#fbbf24;overflow:hidden;flex-shrink:0}.rant-author{font-size:13px;font-weight:600;color:#e8c9a0}.rant-time{font-size:11px;color:rgba(232,201,160,.4)}.rant-self-delete-btn,.rant-delete-btn{background:none;border:none;color:rgba(255,200,200,.3);cursor:pointer;padding:4px;transition:color .3s}.rant-self-delete-btn:hover,.rant-delete-btn:hover{color:#ef4444}.rant-content{font-size:14px;line-height:1.6;color:#e8d5c0;margin-bottom:10px;word-break:break-word}.rant-waterfall{display:flex;gap:8px;padding:0 10px;box-sizing:border-box;width:100%;overflow-y:auto;flex:1}.rant-waterfall-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.rant-wf-card{background:rgba(30,20,20,.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:visible;width:100%;box-sizing:border-box}.rant-wf-card.rant-king{border-color:rgba(250,173,20,.3);background:rgba(250,173,20,.05)}.rant-king-badge{font-size:10px;color:#faad14;font-weight:600;padding:4px 8px;text-align:center;background:rgba(250,173,20,.08)}.rant-wf-img-wrap{position:relative;width:100%;overflow:hidden;border-radius:11px 11px 0 0;cursor:pointer}.rant-wf-img-wrap img{width:100%;aspect-ratio:3 / 4;object-fit:cover;display:block}.rant-wf-body{padding:8px 10px}.rant-wf-text{font-size:13px;color:#e8e0f0;margin:0 0 6px;line-height:1.5;word-break:break-word;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.rant-wf-user{display:flex;align-items:center;gap:5px;margin-bottom:6px;overflow:hidden}.rant-wf-avatar{width:20px;height:20px;border-radius:50%;flex-shrink:0;overflow:hidden}.rant-wf-avatar img{width:100%;height:100%;object-fit:cover}.rant-wf-avatar span{width:20px;height:20px;border-radius:50%;background:rgba(251,191,36,.15);display:flex;align-items:center;justify-content:center;font-size:10px;color:#fbbf24}.rant-wf-name{font-size:11px;color:#ccc;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.rant-wf-time{font-size:10px;color:#666;flex-shrink:0}.rant-wf-actions{display:flex;align-items:center;justify-content:space-between;gap:4px}.rant-wf-right-actions{display:flex;gap:4px;flex-shrink:0}.rant-actions{display:flex;align-items:center;justify-content:space-between}.rant-reactions-display{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.rant-react-add{padding:3px 10px;border-radius:14px;border:1px solid rgba(251,191,36,.1);background:rgba(251,191,36,.04);color:rgba(251,191,36,.5);font-size:11px;cursor:pointer;transition:all .3s}.rant-react-add:hover{border-color:rgba(251,191,36,.3);color:#fbbf24}.rant-react-btn{display:inline-flex;align-items:center;gap:2px;padding:1px 5px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.03);color:rgba(255,255,255,.6);font-size:11px;cursor:pointer;transition:all .3s}.rant-react-btn span{font-size:10px}.rant-react-btn.active{border-color:rgba(251,191,36,.3);background:rgba(251,191,36,.1)}.rant-react-btn:hover{border-color:rgba(251,191,36,.2)}.rant-report-btn{background:none;border:none;color:rgba(255,255,255,.15);cursor:pointer;padding:4px;transition:color .3s}.rant-report-btn:hover{color:#ef4444}.rant-reactions-display{position:relative}.rant-reaction-overlay{position:absolute;left:0;bottom:calc(100% + 8px);z-index:20}.rant-reaction-picker{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;padding:6px;border-radius:10px;background:rgba(0,0,0,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);animation:fadeSlideUp .2s ease;width:max-content}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.rant-reaction-item{width:auto;height:auto;border-radius:6px;border:none;background:transparent;font-size:18px;padding:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.rant-reaction-item:hover{background:rgba(255,255,255,.1);transform:scale(1.15)}.rant-reaction-item.active{background:rgba(251,191,36,.15)}.scroll-to-top-btn{position:fixed;bottom:calc(90px + env(safe-area-inset-bottom,0px));right:16px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:rgba(255,255,255,.7);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:50;transition:all .3s;box-shadow:0 4px 16px rgba(0,0,0,.3);animation:fadeSlideUp .3s ease}.scroll-to-top-btn:hover{background:rgba(0,0,0,.8);color:#fff;transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,.4)}.rant-compose-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center;animation:fadeSlideUp .3s ease}.rant-compose-modal{width:100%;max-width:500px;background:#231812;border-radius:20px 20px 0 0;padding:20px;max-height:90vh;overflow-y:auto;border:1px solid rgba(251,191,36,.1);border-bottom:none}.rant-compose-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.rant-compose-header h3{color:#fbbf24;font-size:18px;margin:0}.rant-compose-header button{background:none;border:none;color:rgba(251,191,36,.5);cursor:pointer}.rant-compose-modal textarea{width:100%;padding:12px;border-radius:12px;border:1px solid rgba(251,191,36,.15);background:rgba(0,0,0,.2);color:#e8d5c0;font-size:14px;outline:none;resize:none;box-sizing:border-box}.rant-compose-modal textarea::placeholder{color:rgba(251,191,36,.25)}.rant-compose-modal textarea:focus{border-color:#fbbf24}.rant-compose-images{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.rant-compose-img-preview{width:64px;height:64px;position:relative;border-radius:8px;overflow:hidden}.rant-compose-img-preview img{width:100%;height:100%;object-fit:cover}.rant-compose-img-preview button{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.7);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.rant-compose-add-img{width:64px;height:64px;border-radius:8px;border:1px dashed rgba(251,191,36,.2);background:rgba(251,191,36,.04);display:flex;align-items:center;justify-content:center;cursor:pointer;color:rgba(251,191,36,.4);transition:all .3s}.rant-compose-add-img:hover{border-color:rgba(251,191,36,.4);color:#fbbf24}.rant-visibility-picker{display:flex;align-items:center;gap:10px;margin-top:12px}.rant-visibility-label{font-size:12px;color:rgba(232,201,160,.5);flex-shrink:0}.rant-visibility-options{display:flex;gap:6px}.rant-vis-opt{display:flex;align-items:center;gap:4px;padding:4px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:transparent;color:rgba(232,201,160,.5);font-size:12px;cursor:pointer;transition:all .3s}.rant-vis-opt.active{border-color:rgba(251,191,36,.3);background:rgba(251,191,36,.1);color:#fbbf24}.rant-anon-section{margin-top:12px}.rant-anon-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:#e8c9a0;cursor:pointer}.rant-anon-toggle.disabled{opacity:.4;pointer-events:none}.rant-anon-hint{font-size:10px;color:rgba(232,201,160,.3)}.rant-toggle-track{width:36px;height:20px;border-radius:10px;background:rgba(255,255,255,.1);position:relative;transition:background .3s;margin-left:auto}.rant-toggle-track.on{background:rgba(251,191,36,.4)}.rant-toggle-track.disabled{opacity:.3}.rant-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .3s}.rant-anon-name-row{display:flex;align-items:center;gap:8px;margin-top:8px}.rant-anon-icon{font-size:18px}.rant-anon-input{flex:1;padding:6px 10px;border-radius:8px;border:1px solid rgba(251,191,36,.15);background:rgba(0,0,0,.2);color:#e8c9a0;font-size:13px;outline:none}.rant-anon-input::placeholder{color:rgba(251,191,36,.2)}.rant-anon-refresh{display:flex;align-items:center;gap:3px;padding:4px 10px;border-radius:8px;border:1px solid rgba(251,191,36,.15);background:transparent;color:rgba(251,191,36,.6);font-size:11px;cursor:pointer}.rant-compose-footer{display:flex;justify-content:space-between;align-items:center;margin-top:14px}.rant-remaining{font-size:11px;color:rgba(232,201,160,.3)}.rant-submit-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;border-radius:14px;border:none;background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.rant-submit-btn:hover:not(:disabled){box-shadow:0 4px 16px rgba(245,158,11,.3)}.rant-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;padding:20px;cursor:pointer}.rant-preview-overlay img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}.rant-report-modal h3{color:#ef4444;font-size:16px;margin:0 0 12px}.rant-report-reasons{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.rant-report-reason{padding:6px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:transparent;color:#ddd;font-size:13px;cursor:pointer}.rant-report-reason.active{border-color:#ef4444;background:rgba(239,68,68,.1);color:#ef4444}.rant-report-actions{display:flex;justify-content:flex-end;gap:8px}.rant-report-actions button{padding:8px 16px;border-radius:12px;border:none;font-size:13px;cursor:pointer}.rant-report-actions button:first-child{background:rgba(255,255,255,.06);color:#ddd}.rant-report-actions button.confirm{background:#ef4444;color:#fff}.rest-page{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(180deg,#1a140e,#211810,#1a140e);background-attachment:fixed;position:relative;overflow-x:hidden}.rest-header{display:flex;align-items:center;gap:8px;padding:calc(14px + env(safe-area-inset-top,0px)) 16px 10px;position:relative;z-index:1}.rest-header .back-btn{background:none;border:none;color:#e8c9a0;cursor:pointer;padding:4px 8px}.rest-header h2{font-size:20px;color:#f97316;margin:0;flex:1;text-shadow:0 0 10px rgba(249,115,22,.3)}.rest-compose-btn{padding:6px 14px;border-radius:16px;border:none;background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .3s}.rest-compose-btn:hover{box-shadow:0 4px 16px rgba(249,115,22,.3);transform:translateY(-1px)}.rest-location-prompt{display:flex;align-items:center;gap:8px;margin:0 12px 8px;padding:8px 12px;border-radius:10px;background:rgba(249,115,22,.06);border:1px solid rgba(249,115,22,.12);font-size:12px;color:rgba(249,115,22,.7);position:relative;z-index:1}.rest-location-prompt button{padding:3px 8px;border-radius:8px;border:1px solid rgba(249,115,22,.2);background:transparent;color:#f97316;font-size:11px;cursor:pointer}.rest-location-dismiss{margin-left:auto;border:none!important;opacity:.5}.rest-list{flex:1;overflow-y:auto;padding:0 12px 80px;display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}.rest-item{border-radius:16px;overflow:hidden;border:1px solid rgba(249,115,22,.08);background:rgba(249,115,22,.04);transition:all .3s}.rest-item:hover{border-color:rgba(249,115,22,.15);box-shadow:0 4px 16px rgba(249,115,22,.06)}.rest-item-top{position:relative}.rest-item-images{display:flex;overflow-x:auto;gap:0;scrollbar-width:none}.rest-item-images::-webkit-scrollbar{display:none}.rest-item-images img{width:100%;max-width:200px;height:160px;object-fit:cover;cursor:pointer;flex-shrink:0}.rest-item-images img:only-child{max-width:100%}.rest-item-info{padding:14px}.rest-item-name{font-size:16px;font-weight:700;color:#fde68a;margin-bottom:4px}.rest-item-addr{display:flex;align-items:center;gap:4px;font-size:12px;color:rgba(253,230,138,.5);margin-bottom:8px}.rest-item-dist{padding:2px 8px;border-radius:8px;background:rgba(249,115,22,.12);color:#f97316;font-size:11px;font-weight:500;margin-left:4px}.rest-item-comment{font-size:13px;color:#e8c9a0;line-height:1.5;margin-bottom:8px}.rest-item-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.rest-tag{padding:2px 8px;border-radius:10px;font-size:11px;background:rgba(249,115,22,.1);color:#fb923c;border:1px solid rgba(249,115,22,.15)}.rest-stars{display:flex;gap:2px;align-items:center}.rest-star{color:rgba(253,230,138,.2);cursor:default;transition:color .2s}.rest-star.filled{color:#fbbf24;fill:#fbbf24}.rest-item-footer{display:flex;align-items:center;justify-content:space-between;padding:0 14px 12px}.rest-item-meta{display:flex;align-items:center;gap:6px}.rest-item-avatar{width:22px;height:22px;border-radius:50%;background:rgba(249,115,22,.15);display:flex;align-items:center;justify-content:center;font-size:10px;color:#f97316;overflow:hidden}.rest-item-avatar img{width:100%;height:100%;object-fit:cover}.rest-item-author{font-size:12px;color:rgba(232,201,160,.6)}.rest-item-time{font-size:11px;color:rgba(232,201,160,.3)}.rest-item-actions{display:flex;gap:8px;align-items:center}.rest-item-actions button{background:none;border:none;color:rgba(255,255,255,.2);cursor:pointer;padding:4px;transition:color .3s}.rest-item-actions button:hover{color:#f97316}.rest-nav-btn{display:flex;align-items:center;gap:3px;padding:4px 10px;border-radius:12px;border:1px solid rgba(249,115,22,.2);background:rgba(249,115,22,.06);color:#f97316;font-size:11px;cursor:pointer;transition:all .3s}.rest-nav-btn:hover{background:rgba(249,115,22,.15);box-shadow:0 0 12px rgba(249,115,22,.1)}.rest-rate-area{display:flex;align-items:center;gap:8px;padding:10px 14px;background:rgba(251,191,36,.04);border-top:1px solid rgba(251,191,36,.08)}.rest-rate-area .rest-star{cursor:pointer}.rest-rate-area .rest-star:hover{color:#fbbf24}.rest-rate-submit{padding:4px 12px;border-radius:10px;border:none;background:#fbbf24;color:#1a140e;font-size:12px;font-weight:600;cursor:pointer;margin-left:auto}.rest-compose-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center}.rest-compose-modal{width:100%;max-width:500px;background:#211810;border-radius:20px 20px 0 0;padding:20px;max-height:90vh;overflow-y:auto;border:1px solid rgba(249,115,22,.12);border-bottom:none;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.rest-compose-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.rest-compose-header h3{color:#f97316;font-size:18px;margin:0}.rest-compose-header button{background:none;border:none;color:rgba(249,115,22,.5);cursor:pointer}.rest-compose-field{margin-bottom:12px}.rest-compose-label{font-size:12px;color:rgba(232,201,160,.6);margin-bottom:6px}.rest-compose-input{width:100%;padding:10px 14px;border-radius:10px;border:1px solid rgba(249,115,22,.15);background:rgba(0,0,0,.2);color:#e8c9a0;font-size:14px;outline:none;box-sizing:border-box}.rest-compose-input::placeholder{color:rgba(249,115,22,.2)}.rest-compose-input:focus{border-color:#f97316}.rest-compose-textarea{width:100%;padding:10px 14px;border-radius:10px;border:1px solid rgba(249,115,22,.15);background:rgba(0,0,0,.2);color:#e8c9a0;font-size:14px;outline:none;resize:none;box-sizing:border-box}.rest-compose-textarea::placeholder{color:rgba(249,115,22,.2)}.rest-compose-textarea:focus{border-color:#f97316}.rest-poi-tips{margin-top:4px;border-radius:10px;background:rgba(0,0,0,.4);border:1px solid rgba(249,115,22,.1);max-height:200px;overflow-y:auto}.rest-poi-tip{display:block;width:100%;text-align:left;padding:8px 12px;border:none;background:transparent;color:#e8c9a0;font-size:13px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.03)}.rest-poi-tip:hover{background:rgba(249,115,22,.08)}.rest-poi-tip-addr{font-size:11px;color:rgba(232,201,160,.4);margin-top:2px}.rest-tags-picker{display:flex;flex-wrap:wrap;gap:6px}.rest-tag-option{padding:5px 12px;border-radius:14px;border:1px solid rgba(249,115,22,.15);background:transparent;color:rgba(249,115,22,.6);font-size:12px;cursor:pointer;transition:all .3s}.rest-tag-option.selected{border-color:#f97316;background:rgba(249,115,22,.15);color:#f97316}.rest-compose-images{display:flex;gap:8px;flex-wrap:wrap}.rest-compose-img-preview{width:64px;height:64px;position:relative;border-radius:8px;overflow:hidden}.rest-compose-img-preview img{width:100%;height:100%;object-fit:cover}.rest-compose-img-preview button{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.7);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.rest-compose-add-img{width:64px;height:64px;border-radius:8px;border:1px dashed rgba(249,115,22,.2);background:rgba(249,115,22,.04);display:flex;align-items:center;justify-content:center;cursor:pointer;color:rgba(249,115,22,.4)}.rest-compose-add-img:hover{border-color:rgba(249,115,22,.4);color:#f97316}.rest-compose-footer{margin-top:14px}.rest-submit-btn{width:100%;padding:12px;border-radius:14px;border:none;background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s}.rest-submit-btn:hover:not(:disabled){box-shadow:0 4px 16px rgba(249,115,22,.3)}.rest-submit-btn:disabled{opacity:.4;cursor:not-allowed}.rest-stamp{position:absolute;bottom:12px;right:12px;z-index:2;display:flex;flex-direction:column;align-items:center;width:42px;height:48px;justify-content:center;border-radius:4px;border:3px solid;transform:rotate(-10deg);font-weight:900;opacity:.9;box-shadow:2px 2px 8px rgba(0,0,0,.1);font-family:STKaiti,KaiTi,serif}.rest-stamp-emoji{font-size:16px;line-height:1.1;margin-bottom:2px}.rest-stamp-label{font-size:11px;line-height:1;letter-spacing:2px;font-weight:700;transform:scaleY(1.1)}.rest-item{position:relative}.rest-card-imgs{margin:6px 0;border-radius:8px;overflow:hidden}.rest-card-imgs img{width:100%;aspect-ratio:16 / 9;object-fit:cover;display:block}.rest-card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.rest-price-tag{font-size:10px;color:#f59e0b;background:rgba(245,158,11,.1);padding:1px 6px;border-radius:6px;flex-shrink:0}.rest-queue-mini{font-size:12px;flex-shrink:0}.rest-dish-mini{font-size:10px;color:#f97316;background:rgba(249,115,22,.08);padding:1px 6px;border-radius:6px}.rest-price-options{display:flex;gap:6px}.rest-price-option{flex:1;padding:6px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#999;font-size:11px;cursor:pointer;text-align:center;transition:all .2s}.rest-price-option.active{background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.4);color:#f59e0b}.rest-detail-hero{padding:16px;position:relative}.rest-detail-name{font-size:22px;color:#fff;margin:0 0 6px;padding-right:56px}.rest-detail-address{display:flex;align-items:center;gap:4px;font-size:13px;color:#999;margin-bottom:10px}.rest-detail-meta{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}.rest-detail-rating{display:flex;align-items:center;gap:6px;font-size:13px;color:#ccc}.rest-detail-price{font-size:12px;color:#f59e0b;background:rgba(245,158,11,.1);padding:2px 8px;border-radius:8px}.rest-detail-queue{margin-bottom:10px}.rest-detail-queue-label{font-size:12px;color:#999}.rest-queue-tag{font-size:13px;font-weight:600}.rest-queue-tag small{font-size:10px;color:#666;font-weight:400;margin-left:4px}.rest-queue-btns{display:flex;gap:6px;margin-top:6px}.rest-queue-btn{flex:1;padding:5px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#ccc;font-size:11px;cursor:pointer;transition:all .2s}.rest-queue-btn:active{transform:scale(.95)}.rest-detail-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.rest-detail-comment{font-size:13px;color:#e8c9a0;font-style:italic;margin-bottom:12px;line-height:1.5}.rest-detail-actions{display:flex;gap:8px}.rest-save-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:8px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#ccc;font-size:12px;cursor:pointer;transition:all .2s}.rest-save-btn.active-must{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.4);color:#ef4444}.rest-save-btn.active-avoid{background:rgba(107,114,128,.15);border-color:rgba(107,114,128,.4);color:#6b7280}.rest-detail-card{margin:0 16px 12px;padding:12px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:14px}.rest-detail-card h4{color:#f97316;font-size:14px;margin:0 0 10px}.rest-dish-cloud{display:flex;flex-wrap:wrap;gap:6px}.rest-dish-tag{color:#f97316;background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.15);padding:3px 10px;border-radius:14px;font-size:12px}.rest-dish-tag.small{font-size:10px;padding:1px 6px}.rest-dish-tag small{color:#666;margin-left:2px}.rest-review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.rest-write-review-btn{padding:5px 12px;border-radius:12px;border:none;background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;font-size:12px;font-weight:600;cursor:pointer}.rest-review-form{margin-bottom:12px;padding:10px;background:rgba(255,255,255,.03);border-radius:10px;border:1px solid rgba(255,255,255,.06)}.rest-review-stars{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;color:#ccc}.rest-review-input{width:100%;box-sizing:border-box;padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#e8e0f0;font-size:13px;resize:vertical;margin-bottom:8px}.rest-review-dishes{margin-bottom:8px}.rest-review-dish-input{display:flex;gap:6px}.rest-review-dish-input input{flex:1;padding:6px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#e8e0f0;font-size:12px}.rest-review-dish-input button{padding:6px 12px;border-radius:8px;border:none;background:rgba(249,115,22,.2);color:#f97316;font-size:14px;cursor:pointer}.rest-review-dish-input button:disabled{opacity:.3}.rest-review-dish-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.rest-review-dish-tags button{background:none;border:none;color:#666;cursor:pointer;padding:0 2px;font-size:12px}.rest-review-images{display:flex;gap:6px;margin-bottom:8px}.rest-review-img-wrap{position:relative;width:60px;height:60px}.rest-review-img-wrap img{width:100%;height:100%;object-fit:cover;border-radius:8px}.rest-review-img-remove{position:absolute;top:-4px;right:-4px;width:18px;height:18px;border-radius:50%;border:none;background:rgba(239,68,68,.9);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}.rest-review-img-add{width:60px;height:60px;border-radius:8px;border:1px dashed rgba(255,255,255,.15);background:none;color:#666;display:flex;align-items:center;justify-content:center;cursor:pointer}.rest-review-submit{width:100%;padding:8px;border-radius:10px;border:none;background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;font-size:13px;font-weight:600;cursor:pointer}.rest-review-submit:disabled{opacity:.4;cursor:not-allowed}.rest-review-list{display:flex;flex-direction:column;gap:10px}.rest-review-item{padding:10px;background:rgba(255,255,255,.02);border-radius:10px;border:1px solid rgba(255,255,255,.04)}.rest-review-item-header{display:flex;align-items:center;gap:6px;margin-bottom:6px}.rest-review-avatar{width:24px;height:24px;border-radius:50%;overflow:hidden;flex-shrink:0}.rest-review-avatar img{width:100%;height:100%;object-fit:cover}.rest-review-avatar span{width:24px;height:24px;border-radius:50%;background:rgba(249,115,22,.15);display:flex;align-items:center;justify-content:center;font-size:11px;color:#f97316}.rest-review-meta{flex:1;min-width:0}.rest-review-name{font-size:12px;color:#ccc;font-weight:600}.rest-review-time{font-size:10px;color:#666;flex-shrink:0}.rest-review-delete{background:none;border:none;color:#555;cursor:pointer;padding:2px}.rest-review-content{font-size:13px;color:#e8e0f0;margin:0 0 6px;line-height:1.5;word-break:break-word}.rest-review-imgs{display:flex;gap:4px;margin-top:6px}.rest-review-imgs img{width:72px;height:72px;object-fit:cover;border-radius:6px;cursor:pointer}.rest-detail-loading,.rest-detail-empty{text-align:center;padding:20px;color:#666;font-size:13px}.rest-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;cursor:pointer}.rest-preview-overlay img{max-width:90%;max-height:90vh;object-fit:contain;border-radius:8px}.plaza-glow-ootd{background:radial-gradient(circle,rgba(255,105,180,.25),transparent 70%)}.plaza-float-8{animation-delay:1.4s}.ootd-page{min-height:100vh;background:transparent;display:flex;flex-direction:column;overflow-x:hidden;box-sizing:border-box;width:100%;max-width:480px;margin:0 auto;position:relative}.ootd-header{display:flex;align-items:center;gap:10px;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0px));position:sticky;top:0;background:rgba(30,20,30,.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:10;box-sizing:border-box;width:100%}.ootd-header h2{flex:1;font-size:17px;font-weight:700;color:#fff;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ootd-back-btn{background:rgba(255,255,255,.08);border:none;border-radius:10px;color:#fff;padding:8px;cursor:pointer;flex-shrink:0}.ootd-publish-btn{background:linear-gradient(135deg,#ff69b4,#ff1493);color:#fff;border:none;border-radius:12px;padding:7px 16px;font-size:13px;font-weight:600;cursor:pointer;flex-shrink:0}.ootd-publish-btn:disabled{opacity:.4}.ootd-menu-btn{background:rgba(255,255,255,.08);border:none;border-radius:10px;color:#fff;padding:8px;cursor:pointer;flex-shrink:0}.ootd-tabs{display:flex;gap:8px;padding:0 16px 10px;box-sizing:border-box;width:100%}.ootd-tab{flex:1;padding:9px;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:rgba(255,255,255,.04);color:#888;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}.ootd-tab.active{background:linear-gradient(135deg,rgba(255,105,180,.2),rgba(255,20,147,.15));border-color:rgba(255,105,180,.4);color:#ff69b4}.ootd-post-status{padding:6px 16px;text-align:center;font-size:12px;color:#999;box-sizing:border-box}.ootd-post-status strong{color:#ff69b4;font-size:14px}.ootd-top-section{padding:0 16px 12px;box-sizing:border-box;width:100%}.ootd-top-section h4{color:#fff;font-size:14px;margin:0 0 8px;display:flex;align-items:center;gap:6px}.ootd-top-scroll{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:4px}.ootd-top-scroll::-webkit-scrollbar{display:none}.ootd-top-item{flex-shrink:0;width:80px;border-radius:12px;overflow:hidden;background:rgba(255,255,255,.05);cursor:pointer;position:relative;transition:transform .2s}.ootd-top-item:active{transform:scale(.95)}.ootd-top-item img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block}.ootd-top-crown{position:absolute;top:3px;left:3px;font-size:16px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.ootd-top-info{padding:4px 6px;display:flex;flex-direction:column;gap:1px}.ootd-top-name{color:#fff;font-size:10px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ootd-top-liang{color:#ff69b4;font-size:10px}.ootd-waterfall{display:flex;gap:8px;padding:0 10px;box-sizing:border-box;width:100%}.ootd-waterfall-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.ootd-card{background:rgba(30,20,30,.4);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.06);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .2s;width:100%;box-sizing:border-box}.ootd-card:active{transform:scale(.97)}.ootd-card-img-wrap{position:relative;width:100%;overflow:hidden}.ootd-card-img-wrap img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block}.ootd-card-weather{position:absolute;top:6px;left:6px;background:rgba(0,0,0,.5);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:2px 6px;border-radius:6px;font-size:10px;color:#fff;max-width:calc(100% - 12px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ootd-card-body{padding:8px 10px;overflow:hidden}.ootd-card-user{display:flex;align-items:center;gap:5px;margin-bottom:4px;overflow:hidden}.ootd-card-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover;flex-shrink:0}.ootd-card-avatar-placeholder{width:20px;height:20px;border-radius:50%;background:rgba(255,105,180,.2);display:flex;align-items:center;justify-content:center;font-size:10px;color:#ff69b4;flex-shrink:0}.ootd-card-name{font-size:11px;color:#ccc;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.ootd-card-text{font-size:12px;color:#999;margin:0 0 4px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.ootd-card-stats{display:flex;gap:10px;font-size:11px;color:#777}.ootd-card-stats span{display:flex;align-items:center;gap:3px}.ootd-compose-body{padding:12px 16px;flex:1;box-sizing:border-box;width:100%;overflow-x:hidden}.ootd-compose-weather{background:rgba(255,105,180,.1);border:1px solid rgba(255,105,180,.2);border-radius:10px;padding:6px 10px;font-size:12px;color:#ff69b4;margin-bottom:12px;text-align:center;word-break:break-word}.ootd-compose-images{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:12px;width:100%;box-sizing:border-box}.ootd-compose-img-item{position:relative;border-radius:10px;overflow:hidden}.ootd-compose-img-item img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block}.ootd-compose-cover-badge{position:absolute;top:3px;left:3px;background:linear-gradient(135deg,#ff69b4,#ff1493);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:5px}.ootd-compose-img-remove{position:absolute;top:3px;right:3px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center}.ootd-compose-add-img{aspect-ratio:3/4;border:2px dashed rgba(255,255,255,.15);border-radius:10px;background:rgba(255,255,255,.03);color:#888;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:11px;cursor:pointer}.ootd-compose-text{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;padding:10px;font-size:14px;resize:none;margin-bottom:12px;font-family:inherit;box-sizing:border-box;word-break:break-word}.ootd-compose-text::placeholder{color:#666}.ootd-compose-visibility{display:flex;align-items:center;gap:8px;color:#999;font-size:12px;margin-bottom:10px;flex-wrap:wrap}.ootd-vis-btn{display:flex;align-items:center;gap:4px;padding:5px 12px;border:1px solid rgba(255,255,255,.1);border-radius:10px;background:rgba(255,255,255,.04);color:#999;font-size:12px;cursor:pointer;transition:all .2s}.ootd-vis-btn.active{background:rgba(255,105,180,.15);border-color:rgba(255,105,180,.4);color:#ff69b4}.ootd-compose-tip{color:#666;font-size:11px;text-align:center}.ootd-detail-page{padding-bottom:140px}.ootd-detail-user{display:flex;align-items:center;gap:8px;flex:1;font-size:14px;font-weight:600;color:#fff;min-width:0;overflow:hidden}.ootd-detail-user span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ootd-detail-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;flex-shrink:0}.ootd-detail-avatar-ph{width:30px;height:30px;border-radius:50%;background:rgba(255,105,180,.2);display:flex;align-items:center;justify-content:center;color:#ff69b4;font-weight:700;font-size:13px;flex-shrink:0}.ootd-detail-menu{position:absolute;top:calc(50px + env(safe-area-inset-top,0px));right:16px;background:rgba(40,40,40,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:4px;z-index:20;min-width:140px}.ootd-detail-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;background:none;border:none;color:#fff;font-size:13px;cursor:pointer;border-radius:8px}.ootd-detail-menu button:active{background:rgba(255,255,255,.08)}.ootd-detail-gallery{position:relative;width:100%;background:#000;overflow:hidden}.ootd-detail-gallery>img{width:100%;aspect-ratio:3/4;object-fit:contain;display:block}.ootd-gallery-prev,.ootd-gallery-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.5);border:none;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer}.ootd-gallery-prev{left:8px}.ootd-gallery-next{right:8px}.ootd-gallery-dots{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:flex;gap:5px}.ootd-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.3);transition:all .2s}.ootd-dot.active{background:#ff69b4;width:14px;border-radius:3px}.ootd-reactions{display:flex;gap:8px;padding:12px 16px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;box-sizing:border-box}.ootd-reactions::-webkit-scrollbar{display:none}.ootd-react-btn{flex-shrink:0;padding:6px 14px;border:1px solid rgba(255,255,255,.1);border-radius:20px;background:rgba(255,255,255,.04);color:#ccc;font-size:14px;cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .2s}.ootd-react-btn span{font-size:12px;color:#999}.ootd-react-btn.active{background:rgba(255,105,180,.15);border-color:rgba(255,105,180,.4);color:#ff69b4}.ootd-react-btn.active span{color:#ff69b4}.ootd-detail-content{padding:0 16px 12px;box-sizing:border-box;width:100%}.ootd-detail-weather{display:inline-block;background:rgba(255,105,180,.1);padding:2px 8px;border-radius:6px;font-size:11px;color:#ff69b4;margin-bottom:6px}.ootd-detail-content p{color:#ddd;font-size:14px;line-height:1.6;margin:0 0 6px;word-break:break-word;white-space:pre-wrap}.ootd-detail-time{color:#666;font-size:11px}.ootd-comments{padding:12px 16px 0;border-top:1px solid rgba(255,255,255,.06);box-sizing:border-box;width:100%}.ootd-comments h4{color:#fff;font-size:14px;margin:0 0 10px}.ootd-comment{margin-bottom:14px}.ootd-comment-header{display:flex;align-items:center;gap:8px;margin-bottom:3px}.ootd-comment-header img{width:26px;height:26px;border-radius:50%;object-fit:cover;flex-shrink:0}.ootd-comment-avatar-ph{width:26px;height:26px;border-radius:50%;background:rgba(255,105,180,.15);display:flex;align-items:center;justify-content:center;font-size:11px;color:#ff69b4;flex-shrink:0}.ootd-comment-name{font-size:12px;font-weight:600;color:#ccc}.ootd-comment-time{font-size:10px;color:#666;margin-left:auto;flex-shrink:0}.ootd-comment-text{color:#bbb;font-size:13px;line-height:1.5;margin:0 0 3px;padding-left:34px;word-break:break-word;white-space:pre-wrap}.ootd-reply-btn{background:none;border:none;color:#888;font-size:11px;cursor:pointer;padding-left:34px}.ootd-comment-reply{margin-left:34px;padding-left:10px;border-left:2px solid rgba(255,105,180,.15);margin-top:6px}.ootd-comment-input{position:fixed;bottom:60px;left:50%;transform:translate(-50%);width:100%;max-width:480px;background:rgba(25,25,25,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.08);padding:8px 12px;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));z-index:30;box-sizing:border-box}.ootd-reply-hint{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:#ff69b4;padding:3px 0 5px}.ootd-reply-hint button{background:none;border:none;color:#888;font-size:13px;cursor:pointer}.ootd-comment-bar{display:flex;gap:8px;align-items:center}.ootd-comment-bar input{flex:1;min-width:0;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:8px 14px;color:#fff;font-size:13px;box-sizing:border-box}.ootd-comment-bar input::placeholder{color:#666}.ootd-comment-bar button{background:linear-gradient(135deg,#ff69b4,#ff1493);border:none;border-radius:50%;width:36px;height:36px;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.ootd-comment-bar button:disabled{opacity:.3}.ootd-fab{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));right:max(16px,calc(50% - 224px));width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#ff69b4,#ff1493);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px rgba(255,20,147,.4);z-index:10;transition:transform .2s}.ootd-fab:active{transform:scale(.9)}.ootd-loading{text-align:center;color:#888;font-size:13px;padding:20px}.ootd-empty{text-align:center;color:#666;font-size:13px;padding:40px 16px}.plaza-view{min-height:100vh;background:transparent;padding:16px 16px 100px}.plaza-header{text-align:center;margin-bottom:20px}.plaza-title{font-size:22px;font-weight:800;background:linear-gradient(135deg,#7c6cf0,#a78bfa,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0}.plaza-subtitle{font-size:12px;color:#888;margin-top:4px}.plaza-float-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 16px 20px;width:100%;box-sizing:border-box}.plaza-float-card{position:relative;background:rgba(255,255,255,.05);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:18px 14px;cursor:pointer;overflow:hidden;display:flex;flex-direction:column;align-items:center;text-align:center;transition:transform .2s cubic-bezier(.34,1.56,.64,1);box-shadow:0 10px 30px -10px rgba(0,0,0,.5)}.plaza-float-card:active{transform:scale(.95)!important}.plaza-float-glow{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,rgba(255,255,255,.1) 0%,transparent 60%);opacity:.5;pointer-events:none;z-index:0}.plaza-float-icon{font-size:30px;margin-bottom:6px;position:relative;z-index:1}.plaza-float-name{font-size:14px;font-weight:700;color:var(--color-text-primary);margin-bottom:2px;position:relative;z-index:1}.plaza-float-desc{font-size:11px;color:#888;line-height:1.4;position:relative;z-index:1}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.plaza-float-1{animation:float 8s ease-in-out infinite}.plaza-float-2{animation:float 9s ease-in-out infinite 1s}.plaza-float-3{animation:float 10s ease-in-out infinite .5s}.plaza-float-4{animation:float 7s ease-in-out infinite 1.5s}.plaza-float-5{animation:float 10s ease-in-out infinite .5s}.plaza-float-6{animation:float 7s ease-in-out infinite 1.5s}.plaza-float-7{grid-column:1 / -1;animation:float 8s ease-in-out infinite 2s}.plaza-glow-chemistry{background:radial-gradient(circle at 30% 20%,rgba(124,108,240,.2),transparent 70%)}.plaza-glow-tags{background:radial-gradient(circle at 70% 30%,rgba(244,114,182,.15),transparent 70%)}.plaza-glow-dilemma{background:radial-gradient(circle at 20% 80%,rgba(236,72,153,.15),rgba(124,108,240,.1),transparent 70%)}.plaza-glow-bottle{background:radial-gradient(circle at 80% 70%,rgba(6,182,212,.2),transparent 70%)}.plaza-glow-tarot{background:radial-gradient(circle at 50% 50%,rgba(139,92,246,.25),rgba(217,70,239,.1),transparent 70%)}.plaza-float-particles{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0}.plaza-float-particles span{position:absolute;width:2px;height:2px;background:#fff;border-radius:50%;animation:twinkle 3s infinite ease-in-out}.plaza-float-particles span:nth-child(1){top:20%;left:30%;animation-delay:0s}.plaza-float-particles span:nth-child(2){top:60%;left:80%;animation-delay:1s}.plaza-float-particles span:nth-child(3){top:80%;left:20%;animation-delay:.5s}.plaza-float-particles span:nth-child(4){top:40%;left:60%;animation-delay:2s}.plaza-float-particles span:nth-child(5){top:10%;left:70%;animation-delay:1.5s}@keyframes twinkle{0%,to{opacity:.2;transform:scale(1)}50%{opacity:.8;transform:scale(1.5)}}.plaza-card-badge{position:absolute;top:10px;right:10px;background:#f5222d;color:#fff;font-size:10px;padding:2px 6px;border-radius:8px;font-weight:700}.plaza-card-hint{position:absolute;bottom:10px;right:12px;font-size:10px;color:rgba(255,255,255,.4)}.dilemma-page{min-height:100vh;background:transparent;display:flex;flex-direction:column}.dilemma-header{display:flex;align-items:center;padding:16px;padding-top:calc(16px + env(safe-area-inset-top,0px));gap:12px}.dilemma-header h2{font-size:18px;font-weight:700;margin:0;flex:1}.dilemma-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;gap:24px}.dilemma-question{font-size:14px;color:#aaa;text-align:center;margin-bottom:8px}.dilemma-vs{display:flex;flex-direction:column;gap:16px;width:100%;max-width:360px}.dilemma-option{background:rgba(255,255,255,.05);border:2px solid rgba(255,255,255,.1);border-radius:16px;padding:24px 20px;text-align:center;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.dilemma-option:active{transform:scale(.97)}.dilemma-option.selected-a{border-color:#7c6cf0;background:rgba(124,108,240,.15)}.dilemma-option.selected-b{border-color:#f472b6;background:rgba(244,114,182,.15)}.dilemma-option-text{font-size:16px;font-weight:600;color:var(--color-text-primary);line-height:1.4}.dilemma-option-pct{margin-top:8px;font-size:24px;font-weight:800}.dilemma-option-bar{position:absolute;bottom:0;left:0;height:4px;border-radius:0 2px 0 0;transition:width .6s ease}.dilemma-vs-badge{text-align:center;font-size:20px;font-weight:900;color:#666;letter-spacing:4px}.dilemma-stats{text-align:center;color:#888;font-size:12px}.dilemma-streak{display:flex;align-items:center;justify-content:center;gap:6px;color:#faad14;font-size:13px;font-weight:600}.coming-soon-page{min-height:100vh;background:transparent;display:flex;flex-direction:column}.coming-soon-header{display:flex;align-items:center;padding:16px;padding-top:calc(16px + env(safe-area-inset-top,0px));gap:12px}.coming-soon-header h2{font-size:18px;font-weight:700;margin:0}.coming-soon-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#666}.coming-soon-body .icon{font-size:64px}.chem-section{margin-top:20px}.chem-section-title{font-size:14px;font-weight:700;color:var(--color-text-primary);margin-bottom:12px}.chem-friend-list{display:flex;flex-direction:column;gap:8px}.chem-friend-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:rgba(255,255,255,.04);border-radius:12px}.chem-friend-avatar{width:32px;height:32px;border-radius:50%;background:rgba(124,108,240,.2);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#7c6cf0;overflow:hidden;flex-shrink:0}.chem-friend-avatar img{width:100%;height:100%;object-fit:cover}.chem-friend-name{font-size:13px;font-weight:500;flex:1}.chem-friend-choice{font-size:11px;padding:3px 8px;border-radius:8px;background:rgba(255,255,255,.06);color:#888}.chem-friend-choice.same{background:rgba(82,196,26,.15);color:#52c41a}.chem-friend-choice.diff{background:rgba(245,34,45,.1);color:#f5222d}.chem-score-list{display:flex;flex-direction:column;gap:8px}.chem-score-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:rgba(255,255,255,.04);border-radius:12px}.chem-rank{font-size:16px;width:24px;text-align:center}.chem-score-value{font-size:16px;font-weight:800;color:#7c6cf0;margin-left:auto}.chem-score-games{font-size:11px;color:#888}.tag-cloud{display:flex;flex-wrap:wrap;gap:8px}.tag-item{padding:6px 14px;border-radius:20px;font-weight:600;transition:transform .2s;cursor:default}.tag-item:hover{transform:scale(1.05)}.tag-count{font-size:.75em;opacity:.7;margin-left:4px}.tag-empty{text-align:center;padding:30px;color:#666;font-size:13px}.tag-friend-select{width:100%;padding:12px 16px;background:rgba(255,255,255,.05);border:1px dashed rgba(255,255,255,.15);border-radius:12px;color:var(--color-text-primary);font-size:14px;cursor:pointer;text-align:left}.tag-friend-picker{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;max-height:200px;overflow-y:auto}.tag-friend-option{display:flex;align-items:center;gap:8px;padding:8px 12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;color:var(--color-text-primary);font-size:13px;cursor:pointer}.tag-friend-option.selected{border-color:#7c6cf0;background:rgba(124,108,240,.15)}.tag-input-area{display:flex;gap:8px;margin-top:12px}.tag-input{flex:1;padding:10px 14px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:12px;color:var(--color-text-primary);font-size:14px;outline:none}.tag-input:focus{border-color:#7c6cf0}.tag-send-btn{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#7c6cf0,#a78bfa);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.tag-send-btn:disabled{opacity:.4;cursor:not-allowed}.tag-hint{font-size:11px;color:#666;margin-top:10px;text-align:center}.tag-toast{position:fixed;top:20px;left:50%;transform:translate(-50%);background:rgba(30,30,45,.95);backdrop-filter:blur(12px);padding:10px 20px;border-radius:12px;color:#fff;font-size:13px;z-index:9999;box-shadow:0 8px 24px rgba(0,0,0,.4)}.bottle-chat-page{display:flex;flex-direction:column;height:100vh;background:transparent}.bottle-original{margin:0 16px;padding:16px;background:rgba(124,108,240,.08);border:1px solid rgba(124,108,240,.15);border-radius:14px}.bottle-original-label{font-size:11px;color:#7c6cf0;margin-bottom:6px}.bottle-original-text{font-size:14px;color:var(--color-text-primary);line-height:1.5}.bottle-reveal-bar{margin:10px 16px;text-align:center}.bottle-reveal-btn{padding:8px 20px;background:linear-gradient(135deg,#06b6d4,#7c6cf0);border:none;border-radius:20px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.bottle-waiting{font-size:12px;color:#faad14}.bottle-revealed-info{font-size:13px;color:#52c41a;font-weight:600}.bottle-peer-name{margin-left:8px;color:#7c6cf0}.bottle-messages{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:10px}.bottle-msg{display:flex;gap:8px;align-items:flex-end}.bottle-msg.mine{flex-direction:row-reverse}.bottle-msg-avatar{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:12px;color:#888;flex-shrink:0;overflow:hidden}.bottle-msg-avatar img{width:100%;height:100%;object-fit:cover}.bottle-msg-bubble{max-width:70%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.4}.bottle-msg.theirs .bottle-msg-bubble{background:rgba(255,255,255,.06);color:var(--color-text-primary);border-bottom-left-radius:4px}.bottle-msg.mine .bottle-msg-bubble{background:linear-gradient(135deg,#7c6cf0,#a78bfa);color:#fff;border-bottom-right-radius:4px}.bottle-input-bar{display:flex;gap:8px;padding:12px 16px;border-top:1px solid rgba(255,255,255,.06)}.bottle-chat-input{flex:1;padding:10px 14px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:20px;color:var(--color-text-primary);font-size:14px;outline:none}.bottle-chat-input:focus{border-color:#7c6cf0}.bottle-pick-btn{width:100%;padding:14px;background:linear-gradient(135deg,#06b6d4,#7c6cf0);border:none;border-radius:14px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:transform .2s}.bottle-pick-btn:active{transform:scale(.97)}.bottle-pick-btn:disabled{opacity:.4;cursor:not-allowed}.bottle-list{display:flex;flex-direction:column;gap:8px}.bottle-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:rgba(255,255,255,.04);border-radius:12px;cursor:pointer;transition:background .2s}.bottle-item:hover{background:rgba(255,255,255,.06)}.bottle-item-icon{font-size:24px}.bottle-item-content{flex:1;min-width:0}.bottle-item-text{font-size:13px;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bottle-item-meta{font-size:11px;color:#666;margin-top:3px}.bottle-item-status{font-size:11px;padding:3px 8px;border-radius:8px;font-weight:600;flex-shrink:0}.bottle-status-floating{background:rgba(6,182,212,.15);color:#06b6d4}.bottle-status-picked{background:rgba(124,108,240,.15);color:#7c6cf0}.bottle-status-revealed{background:rgba(82,196,26,.15);color:#52c41a}.rant-page,.rest-page{min-height:100vh;background:var(--color-bg-base);display:flex;flex-direction:column}.rant-header,.rest-header{display:flex;align-items:center;padding:16px;padding-top:calc(16px + env(safe-area-inset-top,0px));gap:12px}.rant-header h2,.rest-header h2{font-size:18px;font-weight:700;margin:0;flex:1}.rant-compose-btn,.rest-compose-btn{padding:6px 14px;background:linear-gradient(135deg,#7c6cf0,#a78bfa);border:none;border-radius:16px;color:#fff;font-size:12px;font-weight:600;cursor:pointer}.rant-compose-btn:disabled,.rest-compose-btn:disabled{opacity:.4;cursor:not-allowed}.rant-loading,.rant-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#666;gap:12px;font-size:14px}.rant-list,.rest-list{padding:0 16px 100px;display:flex;flex-direction:column;gap:12px}.rant-item{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:14px;position:relative;overflow:visible}.rant-item.rant-king{border-color:rgba(250,173,20,.3);background:rgba(250,173,20,.05)}.rant-king-badge{font-size:11px;color:#faad14;font-weight:600;margin-bottom:8px}.rant-item-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.rant-avatar{width:36px;height:36px;border-radius:50%;background:rgba(124,108,240,.15);display:flex;align-items:center;justify-content:center;font-size:14px;color:#7c6cf0;font-weight:600;overflow:hidden;flex-shrink:0}.rant-avatar img{width:100%;height:100%;object-fit:cover}.rant-meta{flex:1}.rant-author{font-size:13px;font-weight:600;color:var(--color-text-primary)}.rant-time{font-size:11px;color:#666;margin-top:1px}.rant-content{font-size:14px;color:var(--color-text-primary);line-height:1.6;white-space:pre-wrap;word-break:break-word}.rant-images{display:flex;gap:8px;margin-top:10px;overflow-x:auto}.rant-images img{width:100px;height:100px;object-fit:cover;border-radius:10px;cursor:pointer;flex-shrink:0}.rant-actions{display:flex;gap:8px;margin-top:10px;align-items:center}.rant-react-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;color:#888;font-size:13px;cursor:pointer;transition:all .2s}.rant-react-btn.active{border-color:rgba(124,108,240,.3);background:rgba(124,108,240,.1);color:#a78bfa}.rant-react-btn span{font-size:12px}.rant-report-btn{margin-left:auto;background:none;border:none;color:#555;cursor:pointer;padding:4px 6px;opacity:.5}.rant-delete-btn{background:none;border:none;color:#f5222d;cursor:pointer;padding:4px 6px;opacity:.7}.rant-compose-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.rant-compose-modal{background:rgba(26,26,46,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:20px 20px 0 0;padding:24px 20px 30px;width:100%;max-width:480px;max-height:85vh;overflow-y:auto;animation:slideUp .3s ease}.rant-compose-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.rant-compose-header h3{font-size:16px;font-weight:700;margin:0}.rant-compose-header button{background:none;border:none;color:#888;cursor:pointer}.rant-compose-modal textarea{width:100%;padding:12px 14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:12px;color:var(--color-text-primary);font-size:14px;resize:none;outline:none;box-sizing:border-box}.rant-compose-modal textarea:focus{border-color:#7c6cf0}.rant-compose-images{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.rant-compose-img-preview{position:relative;width:70px;height:70px}.rant-compose-img-preview img{width:100%;height:100%;object-fit:cover;border-radius:10px}.rant-compose-img-preview button{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:#f5222d;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.rant-compose-add-img{width:70px;height:70px;border:1px dashed rgba(255,255,255,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666}.rant-scope-tabs{display:flex;gap:0;padding:0 16px;margin-bottom:12px;border-bottom:1px solid rgba(255,255,255,.06)}.rant-scope-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:10px 0;background:none;border:none;border-bottom:2px solid transparent;color:#666;font-size:14px;font-weight:500;cursor:pointer;transition:all .25s}.rant-scope-tab.active{color:#a78bfa;border-bottom-color:#7c6cf0;font-weight:600}.rant-visibility-picker{display:flex;align-items:center;gap:10px;margin-top:14px;margin-bottom:2px}.rant-visibility-label{font-size:12px;color:#888;flex-shrink:0}.rant-visibility-options{display:flex;gap:6px;flex:1}.rant-vis-opt{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#888;font-size:12px;cursor:pointer;transition:all .2s}.rant-vis-opt.active{background:rgba(124,108,240,.12);border-color:rgba(124,108,240,.4);color:#a78bfa;font-weight:600}.rant-anon-toggle.disabled{opacity:.45;cursor:not-allowed}.rant-anon-hint{font-size:11px;color:#f5222d;opacity:.8}.rant-toggle-track.disabled{opacity:.4}.rant-anon-toggle{display:flex;align-items:center;gap:8px;margin-top:14px;font-size:13px;color:#aaa;cursor:pointer}.rant-anon-toggle input[type=checkbox]{display:none}.rant-toggle-track{width:36px;height:20px;background:rgba(255,255,255,.1);border-radius:10px;position:relative;transition:background .2s;margin-left:auto}.rant-toggle-track.on{background:#7c6cf0}.rant-toggle-thumb{width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .2s}.rant-toggle-track.on .rant-toggle-thumb{transform:translate(16px)}.rant-submit-btn{width:100%;padding:12px;background:linear-gradient(135deg,#7c6cf0,#a78bfa);border:none;border-radius:12px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;margin-top:14px;display:flex;align-items:center;justify-content:center;gap:6px}.rant-submit-btn:disabled{opacity:.4;cursor:not-allowed}.rant-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:2000;cursor:pointer}.rant-preview-overlay img{max-width:90%;max-height:90vh;object-fit:contain;border-radius:8px}.rant-report-modal{padding:24px 20px}.rant-report-modal h3{font-size:16px;font-weight:700;margin:0 0 16px}.rant-report-reasons{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.rant-report-reason{padding:6px 14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;color:#aaa;font-size:13px;cursor:pointer}.rant-report-reason.active{border-color:#f5222d;color:#f5222d;background:rgba(245,34,45,.1)}.rant-report-actions{display:flex;gap:10px;justify-content:flex-end}.rant-report-actions button{padding:8px 18px;border-radius:10px;font-size:13px;cursor:pointer;border:none;background:rgba(255,255,255,.06);color:#aaa}.rant-report-actions button.confirm{background:linear-gradient(135deg,#f5222d,#ff6b6b);color:#fff}.rant-report-actions button.confirm:disabled{opacity:.4}.rest-item{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:14px}.rest-item-top{margin-bottom:8px}.rest-name-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.rest-name{font-size:15px;font-weight:700;color:var(--color-text-primary)}.rest-tag{font-size:10px;padding:2px 8px;background:rgba(124,108,240,.1);border-radius:10px;color:#a78bfa}.rest-address{font-size:12px;color:#888;margin-top:4px;display:flex;align-items:center;gap:4px}.rest-comment{font-size:13px;color:var(--color-text-primary);line-height:1.5;margin-bottom:8px;opacity:.85}.rest-bottom{margin-top:10px;display:flex;flex-direction:column;gap:8px}.rest-author{display:flex;align-items:center;gap:6px;font-size:12px;color:#888}.rest-rating-row{display:flex;align-items:center;gap:6px}.rest-stars{display:flex;gap:2px}.rest-star{color:#444;cursor:default}.rest-star.filled{color:#faad14;fill:#faad14}.rest-rating-text{font-size:11px;color:#888}.rest-actions-row{display:flex;gap:8px;align-items:center}.rest-rate-btn,.rest-nav-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;color:#888;font-size:12px;cursor:pointer}.rest-nav-btn{color:#06b6d4;border-color:rgba(6,182,212,.2)}.rest-compose-modal{max-height:90vh}.rest-form-group{margin-bottom:14px}.rest-form-group label{font-size:13px;font-weight:600;color:#aaa;display:block;margin-bottom:6px}.rest-form-group input{width:100%;padding:10px 14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--color-text-primary);font-size:14px;outline:none;box-sizing:border-box}.rest-form-group input:focus,.rest-form-group textarea:focus{border-color:#7c6cf0}.rest-form-group textarea{width:100%;padding:10px 14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--color-text-primary);font-size:14px;resize:none;outline:none;box-sizing:border-box}.rest-tag-options{display:flex;flex-wrap:wrap;gap:6px}.rest-tag-option{padding:4px 10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;color:#aaa;font-size:12px;cursor:pointer}.rest-tag-option.active{border-color:#7c6cf0;color:#a78bfa;background:rgba(124,108,240,.1)}.rest-rating-picker{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 0}.rest-rating-picker .rest-stars{gap:8px}.rest-rating-picker .rest-star{cursor:pointer!important;transition:transform .1s}.rest-rating-picker .rest-star:hover{transform:scale(1.2)}.rest-rating-label{font-size:14px;color:#faad14;font-weight:600}.plaza-glow-rant{background:radial-gradient(circle at 50% 40%,rgba(255,107,107,.2),rgba(250,173,20,.1),transparent 70%)}.plaza-glow-restaurant{background:radial-gradient(circle at 40% 60%,rgba(255,169,64,.2),rgba(82,196,26,.1),transparent 70%)}.rest-search-group{position:relative}.rest-search-input-wrapper{position:relative;display:flex;align-items:center}.rest-search-icon{position:absolute;left:12px;color:#666;pointer-events:none}.rest-search-input-wrapper input{padding-left:36px!important}.rest-search-loading{position:absolute;right:12px;font-size:11px;color:#7c6cf0}.rest-search-tips{position:absolute;top:100%;left:0;right:0;background:#1e1e3a;border:1px solid rgba(124,108,240,.2);border-radius:12px;margin-top:4px;max-height:250px;overflow-y:auto;z-index:100;box-shadow:0 8px 24px rgba(0,0,0,.4)}.rest-search-tip{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(255,255,255,.04)}.rest-search-tip:last-child{border-bottom:none}.rest-search-tip:hover{background:rgba(124,108,240,.1)}.rest-search-tip svg{color:#7c6cf0;flex-shrink:0}.rest-tip-name{font-size:13px;font-weight:600;color:var(--color-text-primary)}.rest-tip-addr{font-size:11px;color:#888;margin-top:2px}.rest-selected-location{display:flex;align-items:center;gap:4px;font-size:11px;color:#52c41a;margin-top:6px;padding:4px 8px;background:rgba(82,196,26,.08);border-radius:8px}.rant-self-delete-btn{background:none;border:none;color:#999;cursor:pointer;padding:4px;border-radius:6px;transition:all .2s;margin-left:auto}.rant-self-delete-btn:hover{color:#ff4d4f;background:rgba(255,77,79,.1)}.rant-anon-section{display:flex;flex-direction:column;gap:8px;margin:8px 0}.rant-anon-name-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:rgba(124,108,240,.06);border-radius:10px}.rant-anon-preview{font-size:13px;color:#bbb;flex:1}.rant-anon-refresh{display:flex;align-items:center;gap:4px;background:none;border:1px solid rgba(124,108,240,.3);color:#7c6cf0;font-size:12px;padding:4px 10px;border-radius:8px;cursor:pointer;transition:all .2s;white-space:nowrap}.rant-anon-refresh:hover{background:rgba(124,108,240,.1)}.rant-compose-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.rant-remaining{font-size:12px;color:#888}.rest-location-prompt{display:flex;align-items:center;gap:8px;padding:10px 14px;background:rgba(124,108,240,.08);border:1px solid rgba(124,108,240,.2);border-radius:12px;margin:8px 0;font-size:13px;color:#bbb}.rest-location-prompt span:first-child{flex:1}.rest-location-prompt button{background:rgba(124,108,240,.15);border:none;color:#7c6cf0;font-size:12px;padding:4px 12px;border-radius:8px;cursor:pointer;transition:background .2s}.rest-location-prompt button:hover{background:rgba(124,108,240,.25)}.rest-location-dismiss{background:none!important;color:#666!important;padding:4px 6px!important;font-size:14px!important}.rest-distance-tag{font-size:11px;color:#52c41a;background:rgba(82,196,26,.1);padding:2px 8px;border-radius:10px;white-space:nowrap}.rest-avatar-sm{width:24px!important;height:24px!important}.rant-empty-icon{font-size:48px}.rant-reactions-display{display:flex;flex-wrap:wrap;gap:8px;align-items:center;position:relative;flex:1}.rant-reaction-overlay{position:absolute;top:auto;left:0;right:auto;bottom:calc(100% + 8px);background:transparent;display:block;backdrop-filter:none;z-index:50;pointer-events:auto}.rant-reaction-overlay.flip-down{bottom:auto;top:calc(100% + 8px)}.rant-reaction-picker{background:rgba(30,30,45,.95);backdrop-filter:blur(12px);border:1px solid rgba(124,108,240,.3);border-radius:10px;padding:6px;display:grid;grid-template-columns:repeat(5,1fr);gap:4px;box-shadow:0 10px 30px rgba(0,0,0,.5);animation:zoomIn .2s cubic-bezier(.34,1.56,.64,1);width:max-content}.rant-reaction-item{background:none;border:none;font-size:18px;cursor:pointer;padding:3px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:transform .1s,background .2s}.rant-reaction-item:hover{background:rgba(255,255,255,.1);transform:scale(1.2)}.rant-reaction-item.active{background:rgba(124,108,240,.2);transform:scale(1.1)}.rant-react-add{display:flex;align-items:center;justify-content:center;padding:4px 10px;background:rgba(255,255,255,.05);border:1px dashed rgba(255,255,255,.2);border-radius:16px;color:#888;font-size:13px;cursor:pointer;transition:all .2s}.rant-react-add:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.4);color:#fff}@keyframes zoomIn{0%{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.mute-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99998;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center}.mute-panel{background:var(--color-bg-card, #1c1c2e);border-radius:20px;padding:24px;width:320px;max-width:90vw;animation:muteIn .25s ease}@keyframes muteIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.mute-user-info{display:flex;align-items:center;gap:12px;margin-bottom:20px}.mute-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;color:#fff}.mute-avatar img{width:100%;height:100%;object-fit:cover}.mute-username{font-size:16px;font-weight:600;color:#fff}.mute-section{margin-bottom:16px}.mute-label{font-size:13px;color:#888;margin-bottom:8px}.mute-presets{display:flex;flex-wrap:wrap;gap:8px}.mute-preset{padding:6px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#ccc;font-size:13px;cursor:pointer;transition:all .2s}.mute-preset:hover{border-color:rgba(255,255,255,.2)}.mute-preset.active{background:rgba(191,90,242,.2);border-color:#bf5af2;color:#bf5af2}.mute-result{padding:10px 14px;border-radius:10px;font-size:13px;background:rgba(255,255,255,.04);color:#ddd;margin-bottom:14px;text-align:center}.mute-actions{display:flex;gap:10px;margin-bottom:12px}.mute-btn{flex:1;padding:10px;border:none;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;transition:opacity .2s}.mute-btn:disabled{opacity:.5}.mute-btn.mute{background:linear-gradient(135deg,#ff4757,#ff6b81);color:#fff}.mute-btn.unmute{background:rgba(78,205,196,.15);color:#4ecdc4;border:1px solid rgba(78,205,196,.3)}.mute-close{width:100%;padding:10px;border:none;border-radius:10px;background:rgba(255,255,255,.06);color:#888;font-size:14px;cursor:pointer;transition:all .2s}.mute-close:hover{background:rgba(255,255,255,.1);color:#fff}.events-view{padding-bottom:80px}.events-header{display:flex;justify-content:space-between;align-items:center;padding:16px}.events-header-actions{display:flex;gap:8px}.ev-btn{display:inline-flex;align-items:center;gap:4px;padding:10px 18px;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.ev-btn-primary{background:linear-gradient(135deg,#4ecdc4,#44b8ac);color:#fff;box-shadow:0 2px 8px rgba(78,205,196,.3)}.ev-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(78,205,196,.4)}.ev-btn-primary:disabled{opacity:.6;transform:none}.ev-btn-ghost{background:rgba(255,255,255,.1);color:var(--color-text-secondary);border:1px solid rgba(255,255,255,.15)}.ev-btn-ghost:hover{background:rgba(255,255,255,.15)}.ev-btn-danger{background:#e53e3e;color:#fff}.ev-btn-sm{padding:6px 12px;font-size:.8rem}.ev-loading{text-align:center;padding:60px 20px;color:var(--color-text-muted)}.ev-empty{text-align:center;padding:80px 20px;color:var(--color-text-muted)}.ev-empty-icon{font-size:3rem;margin-bottom:16px}.ev-empty-hint{font-size:.85rem;opacity:.6}.ev-list{padding:0 16px}.ev-section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-text-muted);padding:12px 0 8px}.ev-card{display:flex;gap:14px;padding:14px;background:var(--color-card);border-radius:14px;margin-bottom:10px;cursor:pointer;transition:all .2s;border:1px solid rgba(255,255,255,.06)}.ev-card:hover{transform:translate(4px);border-color:rgba(78,205,196,.3)}.ev-card-past{opacity:.55}.ev-card-left{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:50px}.ev-card-icon{font-size:1.5rem}.ev-card-date{display:flex;flex-direction:column;align-items:center}.ev-card-month{font-size:.7rem;color:var(--color-text-muted)}.ev-card-day{font-size:1.3rem;font-weight:800;color:var(--color-accent)}.ev-card-body{flex:1;min-width:0}.ev-card-title{font-size:1rem;font-weight:700;color:var(--color-text-primary);margin-bottom:4px}.ev-card-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.78rem;color:var(--color-text-muted);margin-bottom:6px}.ev-card-meta span{display:flex;align-items:center;gap:3px}.ev-card-stats{display:flex;gap:12px;font-size:.78rem;color:var(--color-text-muted)}.ev-card-stats span{display:flex;align-items:center;gap:3px}.ev-card-badge-creator{background:rgba(78,205,196,.2);color:#4ecdc4;padding:1px 8px;border-radius:8px;font-size:.72rem;font-weight:600}.ev-editor{padding:16px}.ev-editor h2{margin-bottom:20px}.ev-form-group{margin-bottom:16px}.ev-form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:6px}.ev-form-row{display:flex;gap:12px}.ev-form-row .ev-form-group{flex:1}.ev-input{width:100%;padding:10px 14px;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:var(--color-card);color:var(--color-text-primary);font-size:.92rem;transition:border .2s;box-sizing:border-box}.ev-input:focus{outline:none;border-color:var(--color-accent)}.ev-textarea{resize:vertical;min-height:60px}.ev-select{padding:10px 14px;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:var(--color-card);color:var(--color-text-primary);font-size:.92rem}.ev-category-pills{display:flex;gap:8px;flex-wrap:wrap}.ev-pill{padding:6px 16px;border:1px solid rgba(255,255,255,.12);border-radius:20px;background:transparent;color:var(--color-text-muted);font-size:.85rem;cursor:pointer;transition:all .2s}.ev-pill.active{background:rgba(78,205,196,.2);color:#4ecdc4;border-color:rgba(78,205,196,.4)}.ev-friend-select{display:flex;flex-wrap:wrap;gap:8px}.ev-friend-chip{padding:6px 14px;border:1px solid rgba(255,255,255,.12);border-radius:20px;background:transparent;color:var(--color-text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s}.ev-friend-chip.selected{background:rgba(78,205,196,.2);color:#4ecdc4;border-color:rgba(78,205,196,.4)}.ev-form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.ev-detail{padding:0 16px 16px}.ev-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.ev-detail-header h2{font-size:1.3rem}.ev-detail-actions{display:flex;gap:6px}.ev-sub-tabs{display:flex;gap:0;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08);overflow-x:auto}.ev-sub-tab{flex-shrink:0;padding:10px 16px;border:none;background:transparent;color:var(--color-text-muted);font-size:.88rem;font-weight:500;cursor:pointer;position:relative;transition:color .2s;display:flex;align-items:center;gap:4px}.ev-sub-tab.active{color:var(--color-accent);font-weight:700}.ev-sub-tab.active:after{content:"";position:absolute;bottom:-1px;left:20%;right:20%;height:3px;background:var(--color-accent);border-radius:2px}.ev-badge{background:rgba(78,205,196,.2);color:#4ecdc4;font-size:.72rem;padding:1px 6px;border-radius:8px;font-weight:600}.ev-info-row{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:.92rem;color:var(--color-text-secondary)}.ev-info-desc{padding:12px;background:var(--color-card);border-radius:10px;color:var(--color-text-secondary);margin:12px 0;font-size:.9rem;line-height:1.6}.ev-split-result{display:flex;align-items:center;gap:10px;padding:12px;background:rgba(78,205,196,.1);border-radius:10px;color:#4ecdc4;font-weight:600;margin:12px 0}.ev-members-section{margin-top:20px}.ev-members-section h3{display:flex;align-items:center;gap:6px;font-size:.95rem;margin-bottom:12px}.ev-member-item{display:flex;align-items:center;gap:12px;padding:8px 0}.ev-member-item .fm-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;overflow:hidden;background:linear-gradient(135deg,#4ecdc4,#44b8ac);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem}.ev-member-item .fm-avatar img{width:100%;height:100%;object-fit:cover}.ev-chat{display:flex;flex-direction:column;height:calc(100vh - 360px)}.ev-chat-messages{flex:1;overflow-y:auto;padding:8px 0}.ev-chat-empty{text-align:center;color:var(--color-text-muted);padding:40px 0;font-size:.9rem}.ev-chat-msg-wrapper{display:flex;gap:10px;margin-bottom:12px;align-items:flex-end}.ev-chat-msg-wrapper.mine{flex-direction:row-reverse}.ev-chat-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;margin-bottom:2px;background:linear-gradient(135deg,#4ecdc4,#44b8ac);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem}.ev-chat-avatar img{width:100%;height:100%;object-fit:cover}.ev-chat-msg{display:flex;flex-direction:column;padding:10px 14px;background:var(--color-card);border-radius:16px 16px 16px 4px;max-width:75%;margin-bottom:0}.ev-chat-msg-wrapper.mine .ev-chat-msg{background:linear-gradient(135deg,#4ecdc4,#44b8ac);color:#fff;border-bottom-left-radius:16px;border-bottom-right-radius:4px}.ev-chat-msg-wrapper.mine .ev-chat-text{color:#fff}.ev-chat-msg-wrapper.mine .ev-chat-time,.ev-chat-msg-wrapper.mine .ev-chat-sender{color:rgba(255,255,255,.8)}.ev-chat-sender{font-size:.75rem;font-weight:600;color:var(--color-text-muted);margin-bottom:2px}.ev-chat-text{font-size:.95rem;color:var(--color-text-primary);word-break:break-word}.ev-chat-time{font-size:.7rem;color:var(--color-text-muted);text-align:right;margin-top:4px}.ev-chat-input-bar{display:flex;gap:8px;padding:12px 0;position:relative}.ev-chat-input-bar .ev-input{flex:1}.ev-emoji-panel{display:flex;flex-wrap:wrap;gap:8px;padding:12px;background:var(--color-card);border:1px solid rgba(255,255,255,.1);border-radius:12px;position:absolute;bottom:100%;left:0;margin-bottom:8px;z-index:10;box-shadow:0 -4px 12px rgba(0,0,0,.2);width:260px}.ev-emoji-btn{font-size:1.5rem;padding:6px;border-radius:8px;background:transparent;border:none;cursor:pointer;transition:background .2s}.ev-emoji-btn:hover{background:rgba(255,255,255,.1)}.ev-emoji-panel-rich{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:var(--color-card);border:1px solid rgba(255,255,255,.1);border-radius:12px;z-index:10;box-shadow:0 -4px 12px rgba(0,0,0,.2);width:320px;display:flex;flex-direction:column;overflow:hidden}.ev-emoji-tabs{display:flex;overflow-x:auto;background:rgba(0,0,0,.2);padding:6px 8px;gap:4px;scrollbar-width:thin}.ev-emoji-tabs::-webkit-scrollbar{height:4px}.ev-emoji-tabs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:4px}.ev-emoji-tab{background:transparent;border:none;color:var(--color-text-muted);font-size:.8rem;padding:6px 10px;border-radius:16px;cursor:pointer;white-space:nowrap;transition:all .2s}.ev-emoji-tab:hover{background:rgba(255,255,255,.1)}.ev-emoji-tab.active{background:var(--color-accent);color:#fff;font-weight:600}.ev-emoji-content-scroll{display:flex;flex-wrap:wrap;gap:8px;padding:12px;max-height:200px;overflow-y:auto}.ev-emoji-content-scroll::-webkit-scrollbar{width:6px}.ev-emoji-content-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:10px}.ev-photos{padding:0}.ev-photo-upload{display:flex;gap:8px;margin-bottom:16px}.ev-photo-upload .ev-input{flex:1}.ev-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.ev-photo-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden}.ev-photo-item img{width:100%;height:100%;object-fit:cover}.ev-photo-by{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.6);color:#fff;font-size:.7rem;padding:2px 6px;text-align:center}.ev-fp-add{display:flex;gap:8px;margin-bottom:16px}.ev-fp-add .ev-input{flex:1}.ev-fp-list{display:flex;flex-direction:column;gap:8px}.ev-fp-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--color-card);border-radius:12px}.ev-fp-icon{font-size:1.4rem}.ev-fp-info{display:flex;flex-direction:column}.ev-fp-name{font-size:.95rem;font-weight:600;color:var(--color-text-primary)}.ev-fp-by{font-size:.78rem;color:var(--color-text-muted)}.ev-split{padding:16px 0}.ev-split h3{margin-bottom:8px}.ev-split-hint{font-size:.85rem;color:var(--color-text-muted);margin-bottom:16px}.ev-split-form{display:flex;gap:8px}.ev-split-form .ev-input{flex:1}.ev-split-done{padding:16px;background:rgba(78,205,196,.1);border-radius:12px;color:#4ecdc4;font-weight:600}.ev-split-done p{margin:4px 0}.friend-manager{padding:0 16px}.fm-add-section{margin-bottom:24px}.fm-add-section h3{margin-bottom:10px}.fm-add-row{display:flex;gap:8px}.fm-add-row .fm-input{flex:1;padding:10px 14px;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:var(--color-card);color:var(--color-text-primary);font-size:.92rem}.fm-add-row .fm-input:focus{outline:none;border-color:var(--color-accent)}.fm-section{margin-bottom:20px}.fm-section h3{margin-bottom:10px;color:var(--color-text-secondary);font-size:.9rem}.fm-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:12px}.fm-card{background:var(--color-card);border-radius:16px;padding:16px;display:flex;align-items:center;gap:14px;box-shadow:0 4px 12px rgba(0,0,0,.1);transition:all .3s ease;border:1px solid rgba(255,255,255,.05)}.fm-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,.15);border-color:rgba(78,205,196,.3)}.fm-card .fm-avatar{width:48px;height:48px;border-radius:50%;flex-shrink:0;overflow:hidden;background:linear-gradient(135deg,#4ecdc4,#44b8ac);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.2rem}.fm-card .fm-avatar img{width:100%;height:100%;object-fit:cover}.fm-card .fm-info{flex:1;min-width:0;display:flex;flex-direction:column}.fm-card .fm-name{font-size:1rem;font-weight:700;margin-bottom:4px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-text-primary)}.fm-card .fm-meta{font-size:.8rem;color:var(--color-text-muted)}.ev-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.ev-modal{background:var(--color-card, #1e1e2d);border:1px solid rgba(255,255,255,.1);border-radius:16px;width:100%;max-width:400px;box-shadow:0 20px 60px rgba(0,0,0,.5);animation:modalSlideIn .25s ease;overflow:hidden}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.ev-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.ev-modal-header h3{margin:0;font-size:1rem;font-weight:700;color:var(--color-text-primary)}.ev-modal-body{padding:20px}.ev-modal-body .ev-textarea{width:100%;padding:12px 14px;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:rgba(255,255,255,.05);color:var(--color-text-primary);font-size:.92rem;resize:vertical;min-height:80px;box-sizing:border-box;transition:border .2s}.ev-modal-body .ev-textarea:focus{outline:none;border-color:var(--color-accent, #4ecdc4)}.ev-modal-body .ev-textarea::placeholder{color:var(--color-text-muted, #666)}.ev-modal-footer{display:flex;gap:10px;padding:16px 20px;border-top:1px solid rgba(255,255,255,.08);justify-content:flex-end}.ev-btn-secondary{background:rgba(255,255,255,.08);color:var(--color-text-secondary);border:1px solid rgba(255,255,255,.12)}.ev-btn-secondary:hover{background:rgba(255,255,255,.12)}.ev-location-wrapper{position:relative}.ev-location-suggestions{position:absolute;top:100%;left:0;right:0;z-index:20;background:var(--color-card, #1e1e2d);border:1px solid rgba(255,255,255,.12);border-top:none;border-radius:0 0 10px 10px;max-height:240px;overflow-y:auto;box-shadow:0 8px 24px rgba(0,0,0,.3)}.ev-location-item{display:flex;flex-direction:column;gap:2px;padding:10px 14px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s}.ev-location-item:last-child{border-bottom:none}.ev-location-item:hover{background:rgba(78,205,196,.1)}.ev-location-item-name{font-size:.9rem;font-weight:600;color:var(--color-text-primary)}.ev-location-item-addr{font-size:.78rem;color:var(--color-text-muted)}.ev-navigate-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:rgba(78,205,196,.15);color:#4ecdc4;border:1px solid rgba(78,205,196,.3);border-radius:8px;font-size:.78rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s;margin-left:8px}.ev-navigate-btn:hover{background:rgba(78,205,196,.25);transform:translateY(-1px)}.anon-tags-card{display:flex;flex-direction:column;gap:12px;background:linear-gradient(135deg,rgba(167,139,250,.12),rgba(40,42,45,.85))!important;border:1px solid rgba(167,139,250,.2)!important}.anon-tags-header{display:flex;align-items:center;justify-content:space-between}.anon-tags-title{font-size:15px;font-weight:700;color:var(--color-text-primary)}.anon-tags-hint{font-size:11px;color:#888}.anon-tags-cloud{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;padding:8px 0}.anon-tag-item{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:20px;font-weight:600;transition:all .2s ease;user-select:none;will-change:transform,opacity}.anon-tag-item:hover{transform:scale(1.05)}.anon-tag-text{line-height:1}.anon-tag-count{opacity:.7;font-weight:800}.anon-tag-eye{display:flex;align-items:center;opacity:.5;margin-left:2px}.anon-tag-hidden{filter:grayscale(1);opacity:.4;background:rgba(255,255,255,.05);border:1px dashed rgba(255,255,255,.2);color:#fff}.anon-tag-s:not(.anon-tag-hidden){font-size:11px;padding:4px 10px;background:rgba(124,108,240,.15);color:#a78bfa;transform:rotate(-1deg)}.anon-tag-m:not(.anon-tag-hidden){font-size:13px;padding:6px 14px;background:rgba(244,114,182,.15);color:#f472b6;font-style:italic;transform:rotate(1.5deg);box-shadow:0 2px 8px rgba(244,114,182,.15)}.anon-tag-l:not(.anon-tag-hidden){font-size:15px;padding:8px 16px;background:rgba(6,182,212,.15);color:#06b6d4;border:1px solid rgba(6,182,212,.3);transform:rotate(-2deg);font-weight:700;box-shadow:0 2px 12px rgba(6,182,212,.2)}.anon-tag-xl:not(.anon-tag-hidden){font-size:18px;padding:10px 20px;background:linear-gradient(135deg,rgba(82,196,26,.2),rgba(6,182,212,.2));color:#52c41a;border:1px solid rgba(82,196,26,.3);font-weight:800;animation:tagPulse 2s ease-in-out infinite;box-shadow:0 4px 16px rgba(82,196,26,.2)}@keyframes tagPulse{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.03) rotate(.5deg)}}.anon-tag-s:not(.anon-tag-hidden):nth-child(3n+1){color:#fb923c;background:rgba(251,146,60,.12)}.anon-tag-s:not(.anon-tag-hidden):nth-child(3n+2){color:#fbbf24;background:rgba(251,191,36,.12)}.tarot-fortune-bento{position:relative;overflow:hidden;min-height:100px;transition:box-shadow .3s}.tarot-fortune-bento.clickable{cursor:pointer}.tarot-fortune-bento.clickable:hover{box-shadow:0 0 20px rgba(139,92,246,.15)}.tarot-fortune-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(135deg,rgba(139,92,246,.08),rgba(217,70,239,.06));border-radius:inherit}.tarot-fortune-content{position:relative;z-index:1;padding:16px}.tarot-fortune-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.tarot-fortune-emoji{font-size:20px}.tarot-fortune-title{font-size:14px;font-weight:600;color:var(--color-text, #e8d5f5)}.tarot-fortune-expand-hint{margin-left:auto;font-size:12px;color:rgba(139,92,246,.6);transition:color .3s}.tarot-fortune-bento.clickable:hover .tarot-fortune-expand-hint{color:rgba(186,85,211,.9)}.tarot-fortune-card-row{display:flex;gap:12px;align-items:flex-start}.tarot-fortune-thumb{width:60px;height:90px;border-radius:8px;overflow:hidden;flex-shrink:0;box-shadow:0 2px 12px rgba(139,92,246,.2)}.tarot-fortune-thumb img{width:100%;height:100%;object-fit:cover}.tarot-fortune-details{flex:1;min-width:0}.tarot-fortune-name{font-size:16px;font-weight:700;color:var(--color-text, #e8d5f5);margin-bottom:4px}.tarot-fortune-stars{display:flex;gap:2px;margin-bottom:6px}.tarot-fortune-stars span{font-size:14px;color:rgba(255,255,255,.15)}.tarot-fortune-stars span.active{color:#fbbf24}.tarot-fortune-advice{font-size:12px;color:var(--color-text-secondary, #a78bba);line-height:1.4}.tarot-history-wall{padding:16px;animation:tarotWallIn .3s ease}@keyframes tarotWallIn{0%{opacity:0;max-height:0}to{opacity:1;max-height:600px}}.tarot-history-title{font-size:15px;font-weight:600;color:var(--color-text, #e8d5f5);margin-bottom:12px}.tarot-history-loading,.tarot-history-empty{text-align:center;padding:20px 0;color:var(--color-text-secondary, #a78bba);font-size:13px}.tarot-history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.tarot-history-item{background:rgba(139,92,246,.06);border:1px solid rgba(139,92,246,.1);border-radius:12px;overflow:hidden;transition:transform .2s,box-shadow .2s}.tarot-history-item:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(139,92,246,.15)}.tarot-history-img{width:100%;aspect-ratio:2/3;overflow:hidden}.tarot-history-img img{width:100%;height:100%;object-fit:cover}.tarot-history-info{padding:8px 10px}.tarot-history-name{font-size:13px;font-weight:600;color:var(--color-text, #e8d5f5);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tarot-history-stars{display:flex;gap:1px;margin-bottom:2px}.tarot-history-stars span{font-size:11px;color:rgba(255,255,255,.12)}.tarot-history-stars span.active{color:#fbbf24}.tarot-history-date{font-size:11px;color:var(--color-text-secondary, #a78bba)}.profile-fullscreen-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;background:#000;overflow-y:auto}.profile-rest-card{padding:0!important;overflow:hidden;background:#252020}.profile-rest-header{padding:14px;background:linear-gradient(to bottom,rgba(40,30,30,.9),transparent)}.profile-rest-title{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#fca5a5}.profile-rest-list{padding:0 12px 12px;display:flex;flex-direction:column;gap:8px}.profile-rest-item{display:flex;gap:10px;align-items:center;background:rgba(255,255,255,.05);padding:10px 12px;border-radius:10px;cursor:pointer;transition:background .2s}.profile-rest-item:active{background:rgba(255,255,255,.1)}.profile-rest-emoji{font-size:24px;flex-shrink:0;width:36px;text-align:center}.profile-rest-info{flex:1;min-width:0}.profile-rest-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-rest-tags{display:flex;gap:4px;margin-top:4px}.profile-rest-tag{font-size:9px;color:#ffc1cc;background:rgba(255,193,204,.15);padding:2px 4px;border-radius:4px;white-space:nowrap}.profile-rest-more{text-align:center;font-size:11px;color:#777;margin-top:4px}.profile-ootd-card{padding:16px!important;overflow:hidden}.profile-ootd-bg-default{background:linear-gradient(135deg,rgba(40,42,45,.8),rgba(20,20,22,.9))}.profile-ootd-bg-spring{background:linear-gradient(135deg,rgba(82,196,26,.15),rgba(40,42,45,.8))}.profile-ootd-bg-summer{background:linear-gradient(135deg,rgba(239,68,68,.15),rgba(40,42,45,.8))}.profile-ootd-bg-autumn{background:linear-gradient(135deg,rgba(217,119,6,.15),rgba(40,42,45,.8))}.profile-ootd-bg-winter{background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(40,42,45,.8))}.profile-ootd-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.profile-ootd-title{font-size:13px;font-weight:700;color:rgba(255,255,255,.8)}.profile-ootd-actions{display:flex;align-items:center;gap:6px}.profile-ootd-weather{font-size:10px;color:#ff69b4;background:rgba(255,105,180,.1);padding:2px 6px;border-radius:4px}.profile-ootd-edit-btn{display:flex;align-items:center;gap:3px;font-size:10px;color:#a78bfa;background:rgba(167,139,250,.1);border:1px solid rgba(167,139,250,.2);padding:2px 8px;border-radius:6px;cursor:pointer;transition:all .2s}.profile-ootd-edit-btn:hover{background:rgba(167,139,250,.2)}.profile-ootd-scroll{display:flex;gap:12px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:4px}.profile-ootd-scroll::-webkit-scrollbar{display:none}.profile-ootd-item{min-width:100px;width:100px;cursor:pointer;flex-shrink:0;position:relative;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.05);transition:transform .2s}.profile-ootd-item:active{transform:scale(.95)}.profile-ootd-item img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block}.profile-ootd-pin{position:absolute;top:4px;left:4px;font-size:12px;z-index:2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.8))}.profile-ootd-date{position:absolute;bottom:0;left:0;right:0;padding:16px 6px 6px;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:#fff;font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-ootd-more{min-width:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:rgba(255,255,255,.3);font-size:12px;writing-mode:vertical-rl;letter-spacing:4px}.profile-lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;animation:profile-fade-in .2s ease}@keyframes profile-fade-in{0%{opacity:0}to{opacity:1}}.profile-lightbox-content{position:relative;max-width:90vw;max-height:85vh;display:flex;flex-direction:column;align-items:center}.profile-lightbox-close{position:fixed;top:16px;right:16px;background:rgba(255,255,255,.1);border:none;color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;backdrop-filter:blur(8px)}.profile-lightbox-image{max-width:100%;max-height:75vh;object-fit:contain;border-radius:8px}.profile-lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:none;color:#fff;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(4px)}.profile-lightbox-prev{left:-54px}.profile-lightbox-next{right:-54px}.profile-lightbox-dots{display:flex;gap:6px;margin-top:12px}.profile-lightbox-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;transition:all .2s}.profile-lightbox-dot.active{background:#fff;transform:scale(1.3)}.profile-lightbox-caption{margin-top:12px;color:rgba(255,255,255,.6);font-size:12px;text-align:center;display:flex;flex-direction:column;gap:4px}.profile-lightbox-text{color:rgba(255,255,255,.8);font-size:13px}.profile-edit-panel{background:#1a1a1e;border-radius:16px 16px 0 0;position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;max-height:80vh;overflow-y:auto;animation:profile-slide-up .3s ease}@keyframes profile-slide-up{0%{transform:translate(-50%,100%)}to{transform:translate(-50%)}}.profile-edit-header{padding:16px;display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:600;color:#fff;border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;background:#1a1a1e;z-index:1}.profile-edit-save{display:flex;align-items:center;gap:4px;background:#8b5cf6;color:#fff;border:none;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer}.profile-edit-save:disabled{opacity:.5}.profile-edit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:8px}.profile-edit-item{position:relative;aspect-ratio:3/4;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:border-color .2s}.profile-edit-item img{width:100%;height:100%;object-fit:cover}.profile-edit-item.selected{border-color:#8b5cf6}.profile-edit-check{position:absolute;top:6px;right:6px;width:22px;height:22px;background:#8b5cf6;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700}.bento-edit-toolbar{display:flex;justify-content:flex-end;margin-bottom:12px;gap:8px}.bento-edit-btn{display:flex;align-items:center;gap:4px;font-size:12px;padding:6px 12px;border-radius:8px;border:none;cursor:pointer;font-weight:600;transition:all .2s}.bento-edit-btn-primary{background:#8b5cf6;color:#fff}.bento-edit-btn-secondary{background:rgba(255,255,255,.08);color:rgba(255,255,255,.6)}.bento-card-edit-wrapper{position:relative}.bento-card-edit-controls{position:absolute;top:8px;right:8px;display:flex;gap:4px;z-index:10}.bento-card-move-btn{width:28px;height:28px;border-radius:50%;background:rgba(139,92,246,.8);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;backdrop-filter:blur(4px);transition:background .2s}.bento-card-move-btn:hover{background:#8b5cf6}.bento-card-move-btn:disabled{opacity:.3;cursor:default}.bento-card-edit-label{font-size:11px;color:rgba(255,255,255,.7);background:rgba(0,0,0,.5);padding:3px 8px;border-radius:6px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);white-space:nowrap}.fb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);display:flex;align-items:flex-end;justify-content:center}.fb-panel{background:var(--color-bg-card, #1c1c2e);border-radius:20px 20px 0 0;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;animation:fbSlideUp .3s ease}@keyframes fbSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.fb-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.06)}.fb-header h2{font-size:18px;font-weight:600;color:#fff;margin:0}.fb-close{background:none;border:none;color:#888;cursor:pointer;padding:4px}.fb-close:hover{color:#fff}.fb-body{flex:1;overflow-y:auto;padding:16px 20px}.fb-form{margin-bottom:20px}.fb-textarea{width:100%;min-height:100px;resize:vertical;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px;color:#fff;font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}.fb-textarea:focus{border-color:var(--accent, #BF5AF2)}.fb-textarea::placeholder{color:#666}.fb-char-count{text-align:right;font-size:12px;color:#666;margin-top:4px}.fb-char-count.over{color:#ff4757}.fb-images{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.fb-img-preview{width:72px;height:72px;border-radius:10px;overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.1)}.fb-img-preview img{width:100%;height:100%;object-fit:cover}.fb-img-remove{position:absolute;top:2px;right:2px;background:rgba(0,0,0,.7);border:none;color:#fff;width:18px;height:18px;border-radius:50%;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center}.fb-img-add{width:72px;height:72px;border-radius:10px;border:1px dashed rgba(255,255,255,.2);background:none;color:#666;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.fb-img-add:hover{border-color:var(--accent, #BF5AF2);color:var(--accent, #BF5AF2)}.fb-actions{display:flex;gap:10px;margin-top:14px}.fb-submit{flex:1;padding:12px;border:none;border-radius:12px;background:linear-gradient(135deg,#bf5af2,#ff375f);color:#fff;font-weight:600;font-size:15px;cursor:pointer;transition:opacity .2s}.fb-submit:disabled{opacity:.5;cursor:not-allowed}.fb-divider{font-size:13px;color:#888;margin:20px 0 12px;display:flex;align-items:center;gap:8px}.fb-divider:after{content:"";flex:1;height:1px;background:rgba(255,255,255,.06)}.fb-list{display:flex;flex-direction:column;gap:10px}.fb-card{background:rgba(255,255,255,.04);border-radius:12px;padding:14px;cursor:pointer;transition:background .2s;border:1px solid rgba(255,255,255,.04)}.fb-card:hover{background:rgba(255,255,255,.07)}.fb-card-content{color:#ddd;font-size:14px;line-height:1.5}.fb-card-meta{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:12px;color:#666}.fb-status{padding:2px 8px;border-radius:6px;font-size:11px;font-weight:500}.fb-status.pending{background:rgba(255,165,0,.15);color:orange}.fb-status.replied{background:rgba(78,205,196,.15);color:#4ecdc4}.fb-status.closed{background:rgba(136,136,136,.15);color:#888}.fb-card-images{display:flex;gap:6px;margin-top:8px}.fb-card-thumb{width:48px;height:48px;border-radius:8px;object-fit:cover;border:1px solid rgba(255,255,255,.06)}.fb-detail{padding:0}.fb-detail-back{background:none;border:none;color:var(--accent, #BF5AF2);cursor:pointer;font-size:14px;display:flex;align-items:center;gap:4px;padding:0;margin-bottom:12px}.fb-detail-content{background:rgba(255,255,255,.04);border-radius:12px;padding:14px;margin-bottom:12px}.fb-detail-content p{color:#ddd;font-size:14px;line-height:1.6;margin:0}.fb-detail-imgs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.fb-detail-img{max-width:160px;max-height:160px;border-radius:10px;object-fit:cover;cursor:pointer}.fb-replies{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.fb-reply{padding:10px 12px;border-radius:10px;font-size:13px;line-height:1.5}.fb-reply.admin{background:rgba(78,205,196,.08);border-left:3px solid #4ecdc4}.fb-reply.user{background:rgba(255,255,255,.04);border-left:3px solid #666}.fb-reply-header{font-size:12px;color:#888;margin-bottom:4px}.fb-reply-content{color:#ddd}.fb-reply-form{display:flex;gap:8px}.fb-reply-input{flex:1;padding:10px 14px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#fff;font-size:14px;outline:none;font-family:inherit}.fb-reply-input:focus{border-color:var(--accent, #BF5AF2)}.fb-reply-btn{padding:10px 18px;border:none;border-radius:10px;background:var(--accent, #BF5AF2);color:#fff;font-weight:600;cursor:pointer;white-space:nowrap}.fb-reply-btn:disabled{opacity:.5}.fb-admin-user{display:flex;align-items:center;gap:8px;margin-bottom:6px}.fb-admin-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.1)}.fb-admin-name{font-size:13px;color:#aaa;font-weight:500}.fb-empty{text-align:center;color:#666;padding:40px 0;font-size:14px}.fb-img-zoom-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;cursor:pointer}.fb-img-zoom-overlay img{max-width:90vw;max-height:90vh;border-radius:8px}.preferences-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:480px;height:85vh;background:var(--color-bg-base);border-radius:var(--border-radius-xl);display:flex;flex-direction:column;padding:0;overflow:hidden;z-index:1000;box-shadow:0 10px 40px rgba(0,0,0,.3)}.preferences-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--color-border);background:var(--color-bg-subtle)}.preferences-modal .preferences-body{flex:1;overflow-y:auto;padding:20px}.preferences-modal .settings-section{margin-bottom:24px}.preferences-modal .section-title{font-size:14px;font-weight:600;color:var(--color-text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.preferences-modal .settings-card{background:var(--color-bg-subtle);border-radius:var(--border-radius-lg);border:1px solid var(--color-border);overflow:hidden}.preferences-modal .settings-item{display:flex;align-items:center;padding:16px;width:100%;background:none;border:none;border-bottom:1px solid var(--color-border);text-align:left;color:var(--color-text-primary);transition:background-color .2s;cursor:pointer}.preferences-modal .settings-item:last-child{border-bottom:none}.preferences-modal .settings-item:not(.static):not(.toggle-item):hover{background-color:rgba(255,255,255,.03)}.preferences-modal .settings-item.static{cursor:default}.preferences-modal .item-content{flex:1;margin-left:12px;display:flex;flex-direction:column}.preferences-modal .item-title{font-size:16px;font-weight:500;margin-bottom:4px}.preferences-modal .item-desc{font-size:13px;color:var(--color-text-secondary)}.preferences-modal .item-arrow{color:var(--color-text-tertiary)}.preferences-modal .danger-item:hover{background-color:rgba(239,68,68,.1)!important}.preferences-modal .danger-text,.preferences-modal .danger-icon{color:var(--color-danger)}.settings-view{padding-bottom:var(--spacing-lg)}.settings-section{margin-bottom:var(--spacing-lg)}.section-title{font-size:12px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;padding:0 var(--spacing-md);margin-bottom:var(--spacing-sm)}.settings-card{margin:0 var(--spacing-md);background:var(--color-bg-card);border-radius:var(--radius-lg);overflow:hidden}.settings-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md);background:none;border:none;border-bottom:1px solid rgba(255,255,255,.05);color:var(--color-text);text-align:left;cursor:pointer;transition:background var(--transition-normal)}.settings-item:last-child{border-bottom:none}.settings-item:hover:not(.static):not(.toggle-item){background:var(--color-bg-card-hover)}.settings-item.static,.settings-item.toggle-item{cursor:default}.item-content{flex:1;display:flex;flex-direction:column;gap:2px}.item-title{font-size:14px;color:var(--color-text)}.item-desc{font-size:12px;color:var(--color-text-muted)}.item-value{font-size:14px;color:var(--color-text-secondary)}.item-arrow{color:var(--color-text-muted)}.toggle-switch{position:relative;width:48px;height:28px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.1);border-radius:28px;transition:.3s}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}.toggle-switch input:checked+.toggle-slider{background:var(--color-accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.settings-tip{margin:var(--spacing-xl) var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-card);border-radius:var(--radius-md);text-align:center}.settings-tip p{font-size:12px;color:var(--color-text-muted);margin:var(--spacing-xs) 0}.budget-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.budget-modal{background:var(--color-bg-secondary);border-radius:var(--radius-xl);padding:var(--spacing-lg);width:100%;max-width:320px}.budget-modal h3{font-size:18px;font-weight:600;text-align:center;margin-bottom:var(--spacing-lg)}.budget-input-section{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--color-bg-card);padding:var(--spacing-md);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md)}.budget-input-section .currency{font-size:24px;color:var(--color-text-secondary)}.budget-input{flex:1;background:none;border:none;color:var(--color-text);font-size:24px;font-weight:600;outline:none}.budget-input::placeholder{color:var(--color-text-muted)}.budget-presets{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.preset-btn{flex:1;padding:var(--spacing-sm);background:var(--color-bg-card);border:1px solid transparent;border-radius:var(--radius-md);color:var(--color-text);font-size:12px;cursor:pointer;transition:all var(--transition-normal)}.preset-btn:hover,.preset-btn.active{border-color:var(--color-accent);background:rgba(78,205,196,.1)}.budget-modal-actions{display:flex;gap:var(--spacing-sm)}.cancel-btn,.save-btn{flex:1;padding:var(--spacing-md);border:none;border-radius:var(--radius-lg);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-normal)}.cancel-btn{background:var(--color-bg-card);color:var(--color-text)}.save-btn{background:var(--gradient-accent);color:#fff}.cancel-btn:hover{background:var(--color-bg-card-hover)}.save-btn:hover{opacity:.9}
