:root[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f6f6f8;--bg-tertiary: #ececf0;--text-primary: #1b1b1f;--text-secondary: #3a3a44;--text-tertiary: #5a5a66;--accent-primary: #ff9ec7;--accent-secondary: #ffb8d9;--accent-hover: #ff7ab8;--accent-light: rgba(255, 158, 199, .14);--border-color: rgba(0, 0, 0, .12);--shadow-color: rgba(0, 0, 0, .1);--success-color: #a8e6cf;--error-color: #ffaaa5;--warning-color: #ffd3a5;--info-color: #a5d8ff;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--shadow-sm: 0 2px 4px var(--shadow-color);--shadow-md: 0 4px 12px var(--shadow-color);--shadow-lg: 0 6px 20px var(--shadow-color);--shadow-xl: 0 10px 30px var(--shadow-color);--auth-overlay-from: rgba(255, 255, 255, .62);--auth-overlay-to: rgba(0, 0, 0, .06);--bg-rain-strong: rgba(255, 122, 184, .22);--bg-rain-soft: rgba(255, 122, 184, .12);--bg-stars-small: rgba(26, 26, 40, .22);--bg-stars-medium: rgba(26, 26, 40, .3);--bg-stars-large: rgba(26, 26, 40, .38);--bg-stars-glow: rgba(26, 26, 40, .14);--sakura-petal-color: var(--accent-primary)}:root[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #3f3f3f;--text-primary: #f0f0f0;--text-secondary: #c4c4c4;--text-tertiary: #9a9a9a;--accent-primary: #ff9ec7;--accent-secondary: #ffb8d9;--accent-hover: #ff7ab8;--accent-light: rgba(255, 158, 199, .1);--border-color: #4a4a4a;--shadow-color: rgba(255, 158, 199, .2);--success-color: #a8e6cf;--error-color: #ffaaa5;--warning-color: #ffd3a5;--info-color: #a5d8ff;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--shadow-sm: 0 2px 4px var(--shadow-color);--shadow-md: 0 4px 12px var(--shadow-color);--shadow-lg: 0 6px 20px var(--shadow-color);--shadow-xl: 0 10px 30px var(--shadow-color);--auth-overlay-from: rgba(0, 0, 0, .42);--auth-overlay-to: rgba(0, 0, 0, .58);--bg-rain-strong: rgba(255, 158, 199, .18);--bg-rain-soft: rgba(255, 158, 199, .08);--bg-stars-small: rgba(255, 255, 255, .14);--bg-stars-medium: rgba(255, 255, 255, .2);--bg-stars-large: rgba(255, 255, 255, .26);--bg-stars-glow: rgba(255, 255, 255, .12);--sakura-petal-color: var(--accent-primary)}:root[data-theme=dark] .theme-cat-light{display:none}:root[data-theme=dark] .theme-cat-dark{display:inline-block!important}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;font-family:Julee,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:16px;line-height:1.5;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color var(--transition-normal),color var(--transition-normal);overflow-x:hidden}*{-ms-overflow-style:none;scrollbar-width:none}*::-webkit-scrollbar{width:0;height:0}.app-loader{position:fixed;left:0;right:0;bottom:0;top:var(--app-loader-top, 0px);height:calc(100vh - var(--app-loader-top, 0px));z-index:90;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.app-loader.is-hidden{display:none}input,textarea,select,button,*{text-transform:none!important}#app{display:flex;flex-direction:column;min-height:100vh;position:relative}#app:before,#app:after{content:none;display:none}#app>*{position:relative;z-index:1}#header{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));border-bottom:2px solid var(--border-color);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:100}#menu-toggle,.mobile-drawer-backdrop{display:none}#header.quiz-mode{background:transparent;border-bottom:none;box-shadow:none;position:absolute;width:100%}#header.quiz-mode #navbar{justify-content:center;padding:var(--spacing-md);max-width:100%}#header.quiz-mode .nav-actions{margin:0}#header.quiz-mode .nav-brand,#header.quiz-mode .nav-menu,#header.quiz-mode .nav-center,#header.quiz-mode .nav-actions button:not(.theme-toggle){display:none!important}#header.quiz-mode .theme-toggle{margin-top:60px;padding:5px}#header.quiz-mode .theme-toggle svg{width:100%;height:100%;transform:scale(1.2)}#navbar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);max-width:100%;margin:0;width:100%}.nav-brand{flex-shrink:0}.nav-brand h1{font-size:1.8rem;color:var(--accent-primary);text-shadow:2px 2px 4px rgba(255,158,199,.3);margin:0}.nav-brand-link{text-decoration:none;color:inherit;display:inline-flex;align-items:center}.nav-menu{display:none}.nav-center{display:none;gap:var(--spacing-md);flex:1;justify-content:center;align-items:center;margin:0 var(--spacing-xl)}.nav-link{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--text-primary);text-decoration:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);transition:all var(--transition-fast);font-weight:500;white-space:nowrap;position:relative;cursor:pointer}.nav-link:hover{background-color:var(--bg-tertiary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.nav-dropdown{position:relative}.nav-menu a{color:var(--text-primary);text-decoration:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);transition:all var(--transition-fast);font-weight:500;white-space:nowrap;position:relative}.nav-menu a:hover{background-color:var(--bg-tertiary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.dropdown-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(-6px);background:var(--bg-secondary);border:2px solid var(--accent-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:200px;z-index:1000;overflow:hidden;display:block;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,transform .18s ease,visibility 0s linear .18s;will-change:transform,opacity;overflow-x:hidden}.dropdown-menu,.dropdown-menu-right{scrollbar-width:none}.dropdown-menu::-webkit-scrollbar,.dropdown-menu-right::-webkit-scrollbar{width:0;height:0}.dropdown-menu.open{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%) translateY(0);transition:opacity .18s ease,transform .18s ease,visibility 0s}.dropdown-menu-right{left:auto;right:0;transform:translateY(-6px)}.dropdown-menu-right.open{transform:translateY(0)}.dropdown-item{display:flex;align-items:center;gap:0;justify-content:center;padding:var(--spacing-md) var(--spacing-lg);color:var(--text-primary);text-decoration:none;transition:all .2s ease;border-bottom:1px solid var(--bg-tertiary);text-align:center}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background:var(--accent-light);color:var(--accent-primary)}.dropdown-icon{font-size:1.3rem}.nav-actions{display:flex;gap:var(--spacing-sm);align-items:center;flex-shrink:0}.theme-toggle{background:var(--bg-secondary);border:2px solid var(--accent-primary);border-radius:50%;width:44px;height:44px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:all .3s ease;padding:4px;overflow:visible}.theme-toggle:hover{transform:scale(1.05);background:var(--accent-light)}.settings-btn{background:transparent;border:none;width:auto;height:auto;cursor:pointer;position:relative;display:inline-flex;align-items:center;justify-content:center;transition:all .3s ease;color:var(--accent-primary);opacity:.7;padding:var(--spacing-sm)}.settings-btn:hover{opacity:1}.settings-btn svg{width:20px;height:20px;display:block}.notif-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 6px;border-radius:9999px;background:var(--accent-primary);color:#fff;font-weight:800;font-size:.75rem;display:inline-flex;align-items:center;justify-content:center;border:2px solid var(--bg-secondary)}.dropdown-menu[data-dropdown-menu=notifications]{min-width:300px;max-width:min(420px,92vw);width:min(350px,92vw);border-radius:var(--radius-lg)}.notif-panel{padding:0;display:flex;flex-direction:column;gap:0}.notif-tabs{display:flex;gap:0;border:none;border-radius:0;overflow:visible;background:transparent;margin-bottom:0}.notif-tab{flex:1 1 0;min-width:0;border:none;background:transparent;color:var(--text-primary);font-weight:800;padding:8px 10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:none;border-radius:0;border-bottom:2px solid transparent}.notif-tab+.notif-tab{border-left:none}.notif-tab.is-active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.notif-tab.is-active[data-notif-tab=active]{border-right:1px solid var(--bg-tertiary)}.notif-tab.is-active[data-notif-tab=read]{border-left:1px solid var(--bg-tertiary)}.notif-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 8px;border-radius:0;border:none;background:transparent;color:var(--text-primary);font-size:.8rem}.notif-tab.is-active .notif-tab-count{background:transparent;color:var(--accent-primary)}.notif-items-area{flex:1;min-height:0;display:flex;flex-direction:column}.notif-items-scroll{position:relative;display:block}.notif-items-list{display:flex;flex-direction:column;gap:0;--notif-visible-items: 4;--notif-item-row-height: 44px;overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable;padding-right:0;height:calc(var(--notif-visible-items) * var(--notif-item-row-height));position:relative;scrollbar-width:none}.dropdown-item.notif-empty{flex:1;height:auto;display:flex;align-items:center;justify-content:center}.notif-items-list::-webkit-scrollbar{width:0;height:0}.notif-list.is-hidden{display:none}.dropdown-item.notif-row{justify-content:flex-start;gap:10px;text-align:left;height:var(--notif-item-row-height);box-sizing:border-box;align-items:center;padding:8px 10px;border-radius:0;background:transparent}.dropdown-item.notif-row+.dropdown-item.notif-row{border-top:1px solid var(--bg-tertiary)}.dropdown-item.notif-row{border-bottom:none}.dropdown-item.notif-row.is-unread{position:relative}.dropdown-item.notif-row.is-unread:before{content:"";width:8px;height:8px;border-radius:9999px;background:var(--accent-primary);box-shadow:0 0 10px #ff9ec759;flex:0 0 auto}.dropdown-item.notif-row.is-read{opacity:.85}.notif-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:800;color:var(--text-primary)}.notif-action{padding:6px 10px}.notif-divider{height:1px;background:var(--bg-tertiary);margin:8px 0}.dropdown-item.notif-empty{border-bottom:none;justify-content:center;padding:18px 12px;height:var(--notif-item-row-height)}.notif-footer{display:flex;justify-content:flex-end;align-items:center;padding:6px 10px;border-top:1px solid var(--bg-tertiary)}.notif-footer.is-hidden{visibility:hidden;pointer-events:none}.notif-mark-all{font-weight:800;font-size:.85rem;padding:8px 0;white-space:nowrap;background:transparent!important;border:none!important;border-radius:0!important;box-shadow:none!important;outline:none;color:var(--text-primary);cursor:pointer;margin:0;transition:none}.dropdown-menu[data-dropdown-menu=notifications] .dropdown-item{transition:none}.dropdown-menu[data-dropdown-menu=notifications] .dropdown-item:hover{background:transparent;color:var(--text-primary)}.dropdown-menu[data-dropdown-menu=notifications] .btn-primary,.dropdown-menu[data-dropdown-menu=notifications] .btn-secondary,.dropdown-menu[data-dropdown-menu=notifications] .btn-danger{transition:none}.dropdown-menu[data-dropdown-menu=notifications] .btn-primary:hover,.dropdown-menu[data-dropdown-menu=notifications] .btn-secondary:hover,.dropdown-menu[data-dropdown-menu=notifications] .btn-danger:hover{transform:none;box-shadow:none}.notif-mark-all:hover:not(:disabled){color:var(--accent-primary)}.notif-mark-all:disabled{opacity:.6;cursor:not-allowed}.notif-scroll-fade{position:absolute;left:2px;right:2px;bottom:2px;height:34px;border-radius:0 0 14px 14px;background:linear-gradient(180deg,rgba(0,0,0,0),var(--bg-secondary));pointer-events:none;opacity:0;transition:opacity .16s ease;z-index:4}.notif-scroll-arrow{position:absolute;left:50%;bottom:8px;transform:translate(-50%) translateY(-2px);opacity:0;transition:opacity .16s ease,transform .16s ease;color:var(--text-tertiary);pointer-events:none;font-size:18px;line-height:1;z-index:5}.notif-items-scroll.is-scrollable:not(.is-at-bottom) .notif-scroll-arrow{opacity:1;transform:translate(-50%) translateY(0)}.notif-items-scroll.is-scrollable:not(.is-at-bottom) .notif-scroll-fade{opacity:1}.notif-items-scroll.is-scrollable.is-at-bottom .notif-scroll-arrow{top:8px;bottom:auto;opacity:1;transform:translate(-50%) translateY(0)}.notif-items-scroll.is-scrollable.is-at-bottom .notif-scroll-fade{top:2px;bottom:auto;border-radius:14px 14px 0 0;background:linear-gradient(0deg,rgba(0,0,0,0),var(--bg-secondary));opacity:1}.logout-btn{background:var(--accent-primary);color:#fff;border:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);cursor:pointer;font-weight:600;transition:all .3s ease;white-space:nowrap}.logout-btn:hover{background:var(--bg-tertiary);color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.theme-toggle.blinking .cat-eyes{animation:catBlink .4s ease-in-out}@keyframes catBlink{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.1;transform:scaleY(.1)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.theme-icon{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:visible}.theme-icon svg{width:100%;height:100%;display:block;overflow:visible}.cat-eyes{transform-origin:center;transition:transform .1s ease}#main-content{flex:1;padding:var(--spacing-xl);max-width:1200px;margin:0 auto;width:100%}#main-content.quiz-page{padding:0;max-width:100%;min-height:100vh;position:relative}#main-content.quiz-page:before{content:none;display:none}body.auth-mode #header{background:transparent;border-bottom:none;box-shadow:none;position:fixed;top:0;left:0;width:100%;pointer-events:none}body.auth-mode,body.quiz-mode{height:100vh;overflow:hidden}body.auth-mode #main-content,body.quiz-mode #main-content{height:100vh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}body.auth-mode #navbar{justify-content:center;padding:0;height:min(180px,22vh);align-items:center}body.quiz-mode #navbar{padding:0;height:min(180px,22vh);align-items:center}body.auth-mode #theme-toggle,body.quiz-mode #theme-toggle{width:62px;height:62px;padding:6px}body.auth-mode .nav-brand,body.auth-mode .nav-menu,body.auth-mode .nav-center,body.auth-mode #logout-btn,body.auth-mode #settings-btn,body.auth-mode #settings-dropdown{display:none!important}body.auth-mode #theme-toggle{pointer-events:auto;margin:0}button,.btn{font-family:inherit;font-size:1rem;padding:var(--spacing-md) var(--spacing-lg);border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));color:var(--text-primary);font-weight:500;box-shadow:var(--shadow-sm)}button:hover,.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}button:disabled,.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;font-weight:600}.btn-primary:hover{background:linear-gradient(135deg,var(--accent-hover),var(--accent-primary))}.btn-back{background:transparent;color:var(--accent-primary);border:2px solid var(--accent-primary);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-full);font-size:1rem;font-weight:600;min-height:44px;display:inline-flex;align-items:center;justify-content:center;line-height:1;cursor:pointer;transition:all var(--transition-fast);font-family:inherit;box-shadow:none}.btn-back:hover{background:var(--accent-primary);color:#fff;box-shadow:var(--shadow-sm)}.page-header{--page-header-side: 132px;display:grid;grid-template-columns:var(--page-header-side) 1fr var(--page-header-side);gap:12px;align-items:center;margin:var(--spacing-md) 0 var(--spacing-lg)}.page-header-left{display:flex;align-items:center;justify-content:flex-start}.page-header-right{display:flex;align-items:center;justify-content:flex-end}.page-header-text{text-align:center;min-width:0}.page-title{margin:0;color:var(--accent-primary);font-size:clamp(1.6rem,2.8vw,2.2rem);text-shadow:2px 2px 4px rgba(255,158,199,.25);line-height:1.1}.page-subtitle{margin:2px 0 0;opacity:.9;color:var(--text-secondary);font-size:1.05rem}@media (max-width: 520px){.page-header{--page-header-side: 112px}}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);color:var(--text-primary);font-weight:600}input,textarea,select{width:100%;padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--border-color);border-radius:var(--radius-lg);background-color:var(--bg-primary);color:var(--text-primary);font-family:inherit;font-size:1rem;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 4px #ff9ec733;transform:translateY(-1px)}.auth-container,.quiz-container{display:flex;justify-content:center;align-items:center;min-height:80vh;position:relative;padding-top:120px;z-index:1}.auth-card,.quiz-card{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:450px;width:100%;border:2px solid var(--border-color);position:relative;z-index:10;margin:0 var(--spacing-lg)}.auth-card h1,.quiz-card h1{text-align:center;margin-bottom:var(--spacing-md);color:var(--accent-primary);font-size:2rem;text-shadow:2px 2px 4px rgba(255,158,199,.2)}.auth-subtitle,.quiz-subtitle{text-align:center;color:var(--text-primary);margin-bottom:var(--spacing-xl);font-size:1.3rem;font-weight:700}.auth-title-pink{color:var(--accent-primary)}.auth-form,.quiz-form{margin-top:var(--spacing-lg)}.btn-quiz{width:60%;margin:var(--spacing-lg) auto 0;display:block;font-size:1rem;padding:var(--spacing-md) var(--spacing-lg)}.btn-google.btn-quiz{width:100%;margin-top:0;margin-bottom:var(--spacing-lg);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);background:#fff;color:#444;padding:var(--spacing-md) var(--spacing-lg)}.btn-google.btn-quiz:hover{background:#f8f8f8}.sakura-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:0}.sakura-petal{position:absolute;top:-10%;width:15px;height:15px;background:var(--sakura-petal-color);border-radius:50% 0;animation:fall linear infinite;transform-origin:center;will-change:transform}@keyframes fall{0%{transform:translateY(0) rotate(0) translate(0)}25%{transform:translateY(25vh) rotate(90deg) translate(calc(var(--sakura-drift, 0px) * .6))}50%{transform:translateY(50vh) rotate(180deg) translate(calc(var(--sakura-drift, 0px) * -1))}75%{transform:translateY(75vh) rotate(270deg) translate(calc(var(--sakura-drift, 0px) * .6))}to{transform:translateY(100vh) rotate(360deg) translate(0);opacity:0}}@media (prefers-reduced-motion: reduce){.sakura-container{display:none}}.auth-footer{text-align:center;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.auth-footer-split{display:flex;justify-content:space-between;align-items:center}.link{color:var(--accent-primary);text-decoration:none}.link:hover{text-decoration:underline}.error-message{color:var(--error-color);font-size:.9rem;margin:var(--spacing-sm) 0;text-align:center}.question-group{margin-bottom:var(--spacing-lg)}.question-group label{font-weight:600;margin-bottom:var(--spacing-sm);display:block}.home-container{text-align:center}.home-hero{margin-bottom:var(--spacing-xl)}.home-hero h1{font-size:3rem;color:var(--accent-primary);margin-bottom:var(--spacing-sm)}.home-subtitle{font-size:1.5rem;color:var(--text-secondary)}.home-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-xl)}.home-card{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);cursor:pointer;transition:all var(--transition-normal);border:2px solid var(--border-color)}.home-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-xl);border-color:var(--accent-primary)}.card-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.home-card h3{margin-bottom:var(--spacing-sm);color:var(--accent-primary)}.home-card p{color:var(--text-secondary)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:var(--bg-primary);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:90%;max-height:90%;overflow:auto;position:relative}.category-modal{max-width:600px;text-align:center}.category-modal h2{font-size:2rem;color:var(--accent-primary);margin-bottom:var(--spacing-sm)}.modal-subtitle{color:var(--text-secondary);margin-bottom:var(--spacing-xl);font-size:1.1rem}.category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.category-card{background:var(--bg-secondary);border:2px solid transparent;border-radius:var(--radius-lg);padding:var(--spacing-xl);cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.category-card:hover{border-color:var(--accent-primary);transform:translateY(-5px);box-shadow:var(--shadow-lg);background:var(--bg-tertiary)}.category-icon{font-size:3rem}.category-name{font-size:1.2rem;font-weight:600;color:var(--text-primary)}.modal-close{width:100%}.birthday-modal{text-align:center;max-width:600px}.birthday-content{position:relative;z-index:2}.birthday-modal h1{font-size:2.5rem;color:var(--accent-primary);margin-bottom:var(--spacing-lg)}.birthday-message{font-size:1.2rem;line-height:1.8;margin-bottom:var(--spacing-xl);color:var(--text-primary)}.fireworks-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:1}.firework{position:absolute;width:4px;height:4px}.firework-particle{position:absolute;width:4px;height:4px;border-radius:50%;animation:explode 1.5s ease-out forwards}@keyframes explode{0%{transform:translate(0);opacity:1}to{transform:translate(var(--tx),var(--ty));opacity:0}}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:50vh}.loading-container.is-page-loading{position:fixed;left:0;right:0;bottom:0;top:var(--app-loader-top, 0px);height:calc(100vh - var(--app-loader-top, 0px));min-height:0;width:100%;z-index:5}.loading-spinner{width:50px;height:50px;border:4px solid var(--bg-tertiary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{margin-top:var(--spacing-md);color:var(--text-secondary)}.workspace-choice-container{display:flex;justify-content:center;align-items:flex-start;padding:0 16px 48px}.space-cards{max-width:820px;margin:0 auto}.space-card{text-align:left;cursor:default}.space-card:hover{transform:none;box-shadow:var(--shadow-md);border-color:var(--border-color)}.space-header-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}.space-pane{border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#00000029;padding:12px 14px;display:grid;gap:10px;justify-items:center;text-align:center}.space-pane-header{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;justify-self:stretch;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.06)}.space-pane-body{display:grid;gap:8px;justify-items:center;text-align:center}.space-pane-body .space-field{justify-content:center}.space-label{color:var(--accent-primary);font-weight:800}.space-action-btn{padding:4px 10px;min-height:30px;box-shadow:none}.space-btn-sm{padding:2px 10px;min-height:26px;font-size:.82rem;border-radius:9999px;width:fit-content;display:inline-flex;align-items:center;justify-content:center;box-shadow:none}.space-btn-sm:hover{transform:none;box-shadow:none}.space-outline-btn{background:transparent;border:2px solid rgba(255,158,199,.55);color:var(--accent-primary);font-weight:800}.space-outline-btn:hover{border-color:#ff9ec7d9;background:#ff9ec70f}.space-info{margin-top:2px}.space-field{display:inline-flex;align-items:center;gap:2px;flex-wrap:nowrap}.space-name-inline-input{width:auto;padding:2px 4px;border-radius:9999px;border:1px solid transparent;background:transparent;box-shadow:none;color:var(--text-primary);font-weight:800}.space-name-inline-input:focus{outline:none}.space-name-inline-input.is-editing{border-color:transparent;background:#00000014;font-weight:700}.space-name-inline-input.is-editing:focus{border-color:transparent}.space-name-edit{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.space-name-edit input{max-width:320px}.space-token-inline{display:inline-flex;align-items:center;justify-content:center;gap:8px;flex-wrap:nowrap;width:100%}.space-add-member-footer{display:flex;justify-content:center;margin-top:12px}.space-members-block{border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#00000029;padding:12px}.space-card,.space-card *{transition:none!important}.space-card:hover{transform:none!important}.space-card button:hover,.space-card button:active,.space-card button:focus,.space-card input:focus,.space-card textarea:focus,.space-card select:focus{transform:none!important;box-shadow:none!important}.space-token-toggle{background:transparent;border:none;color:var(--text-primary);padding:0 6px;border-radius:10px;font-size:.68rem;line-height:1;height:18px;min-width:24px;opacity:.75;flex:0 0 auto;box-shadow:none}.space-token-toggle:hover{opacity:1;background:transparent;box-shadow:none;color:var(--text-primary)}.space-token-toggle.is-on{opacity:.92;color:var(--text-primary)}.space-token-toggle:focus-visible{outline:1px solid rgba(255,255,255,.2);outline-offset:2px}.space-token-input{width:auto;flex:1 1 auto;min-width:0;max-width:100%;padding:0 2px;border:none;background:transparent;box-shadow:none;color:var(--text-primary);font-weight:800;text-align:center;line-height:1;height:22px}.space-card button:hover,.space-card button:active,.space-card button:focus{transform:none;box-shadow:none}.space-card input:focus,.space-card textarea:focus,.space-card select:focus{transform:none}@media (max-width: 520px){.space-field{flex-wrap:wrap}}.space-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:10px}.space-members{margin-top:10px}.space-members-list{display:flex;flex-direction:column;gap:10px}.space-divider{margin-top:14px;padding-top:14px;border-top:1px solid var(--border-color)}.space-owner-actions{display:flex;flex-direction:column;align-items:center;gap:12px}.space-add-member-panel{width:100%}.space-add-member-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:center}.space-add-member-row input{max-width:320px}.space-add-member-hint{margin:10px 0 0;color:var(--text-secondary);word-break:break-word;text-align:center}@media (max-width: 420px){.space-header-grid{grid-template-columns:1fr}}@media (max-width: 540px){.space-token-input{text-align:left}}.workspace-choice-card{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:800px;width:100%;border:2px solid var(--border-color)}.profile-container{display:flex;justify-content:center;align-items:flex-start;padding:0 16px 48px}.profile-card{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:800px;width:100%;border:2px solid var(--border-color)}.profile-header{display:flex;gap:14px;align-items:center;justify-content:center;margin-bottom:18px;text-align:left}.profile-avatar-btn{cursor:pointer;padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none}.profile-avatar-btn:hover{border-color:#ff9ec7d9}.profile-avatar-btn:focus{outline:2px solid rgba(255,158,199,.45);outline-offset:3px}.profile-avatar{width:64px;height:64px;border-radius:20px;overflow:hidden;border:2px solid rgba(255,158,199,.55);background:#00000038;display:grid;place-items:center;color:var(--text-primary);font-weight:900;font-size:1.25rem;flex:0 0 auto}.profile-avatar img{width:100%;height:100%;object-fit:cover;display:block}.profile-header-text{min-width:0}.profile-name{font-weight:900;font-size:1.15rem;color:var(--text-primary)}.profile-email{color:var(--text-secondary);margin-top:2px;word-break:break-word}.profile-list{display:grid;gap:14px}.profile-item{border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#00000024;padding:14px}.profile-item-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.profile-item-meta{min-width:0}.profile-item-label{color:var(--accent-primary);font-weight:900}.profile-item-value{color:var(--text-secondary);margin-top:2px;word-break:break-word}.profile-edit-btn{min-height:38px;padding:10px 16px;border-radius:9999px;box-shadow:none;flex:0 0 auto}.profile-item-body{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.profile-form-grid{display:grid;gap:10px}.profile-form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.profile-form-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.profile-hint{margin:10px 0 0;color:var(--text-secondary);font-size:.95rem;opacity:.95}@media (max-width: 640px){.profile-header{flex-direction:column;text-align:center}.profile-item-top{flex-direction:column;align-items:center;text-align:center}.profile-form-row-2{grid-template-columns:1fr}.profile-form-actions{justify-content:center}}.profile2-wrap{display:flex;justify-content:center;width:100%;padding:0 16px 48px}.profile2-card{width:min(760px,96vw);margin-left:auto;margin-right:auto;border-radius:var(--radius-xl);border:2px solid var(--border-color);background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));box-shadow:var(--shadow-lg);padding:18px}.profile2-top{display:flex;align-items:center;justify-content:center;gap:18px;width:100%;padding-top:6px;padding-bottom:10px}.profile2-avatar{width:120px;height:120px;border-radius:9999px;border:3px solid rgba(255,158,199,.75);background:#00000038;color:var(--accent-primary);display:grid;place-items:center;cursor:pointer;padding:0;box-shadow:none}.profile2-avatar:hover{border-color:#ff9ec7e6}.profile2-avatar:focus{outline:2px solid rgba(255,158,199,.45);outline-offset:4px}.profile2-avatar img{width:100%;height:100%;object-fit:cover;display:block}.profile2-avatar-initials{font-weight:1000;font-size:3.1rem;line-height:1;color:#ffffffeb}.profile2-avatar-hint{font-weight:900;font-size:.78rem;line-height:1.15;text-transform:lowercase;text-align:center;color:#ff9ec7eb}.profile2-info{text-align:left;max-width:520px;min-width:0}.profile2-file{display:none}.profile2-row{display:flex;align-items:center;gap:10px}.profile2-inline{color:var(--text-primary);font-weight:800;overflow-wrap:anywhere;word-break:break-word}.profile2-line{display:flex;align-items:center;justify-content:space-between;gap:12px}.profile2-label{font-weight:900;color:var(--accent-primary);letter-spacing:.2px}.profile2-value{margin-top:6px;color:var(--text-secondary);font-weight:800;word-break:break-word}.profile2-link{background:transparent;border:none;color:var(--accent-hover);font-weight:900;cursor:pointer;padding:6px 8px;border-radius:9999px}.profile2-link:hover{background:#ff9ec71a}.profile2-divider{height:1px;background:#ffffff1a;margin:18px 0}.profile2-sections{display:grid;gap:14px}.profile2-section{border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#00000024;padding:14px}.profile2-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:10px;margin-bottom:12px;border-bottom:1px solid rgba(255,255,255,.08)}.profile2-section-title{font-weight:900;color:var(--accent-primary)}.profile2-section-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:9999px;border:1px solid rgba(255,255,255,.14);background:#00000024;color:var(--text-secondary);font-weight:800;font-size:.82rem;line-height:1;flex:0 0 auto}.profile2-section-badge.is-on{border-color:#ff9ec74d;color:#ff9ec7eb}.profile2-section-hint{margin:0 0 10px;color:var(--text-secondary);font-size:.95rem;opacity:.95}.profile2-actions-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.profile2-actions-grid.is-single{grid-template-columns:1fr}.profile2-btn{width:100%;min-height:42px;justify-content:center;border-radius:9999px;box-shadow:none}@media (max-width: 520px){.profile2-actions-grid{grid-template-columns:1fr}}.profile2-actions{display:flex;justify-content:center;gap:34px;flex-wrap:wrap;padding:4px 0}.profile2-action{background:transparent;border:none;color:var(--accent-hover);font-weight:900;cursor:pointer;padding:8px 10px;border-radius:9999px}.profile2-action:hover{background:#ff9ec71a}.profile2-action-danger{color:#ff7878f2}.profile2-action-danger:hover{background:#ff78781f}@media (max-width: 640px){.profile2-top{flex-direction:column;text-align:center}.profile2-info{text-align:center}.profile2-line{justify-content:center}.profile2-row{justify-content:center;flex-wrap:wrap}}.profile2-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:2000;display:grid;place-items:center;padding:18px}.profile2-modal{width:min(520px,96vw);background:var(--bg-secondary);border:2px solid rgba(255,158,199,.55);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.profile2-modal header{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;gap:12px}.profile2-modal header h2{width:100%;text-align:center}.profile2-modal header h2{margin:0;font-size:1.1rem;color:var(--text-primary)}.profile2-modal-body{padding:16px;display:grid;gap:10px}.profile2-modal-body label{font-weight:900;color:var(--text-secondary);font-size:.9rem}.profile2-modal-body input{width:100%}.profile2-two{display:grid;grid-template-columns:1fr 1fr;gap:10px}.profile2-modal-actions{display:flex;gap:10px;justify-content:flex-end;padding:14px 16px;border-top:1px solid rgba(255,255,255,.1)}.profile2-modal-hint{margin:0;color:var(--text-secondary);font-size:.95rem}@media (max-width: 520px){.profile2-two{grid-template-columns:1fr}}.workspace-choice-card h1{text-align:center;margin-bottom:var(--spacing-sm);color:var(--accent-primary)}.workspace-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:var(--spacing-xl);line-height:1.6}.choice-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg);margin-top:var(--spacing-xl)}.choice-option{background-color:var(--bg-primary);padding:var(--spacing-xl);border-radius:var(--radius-lg);text-align:center;border:2px solid var(--border-color);transition:all var(--transition-normal)}.choice-option:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:var(--shadow-md)}.option-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.choice-option h3{margin-bottom:var(--spacing-sm);color:var(--accent-primary)}.choice-option p{color:var(--text-secondary);margin-bottom:var(--spacing-lg);font-size:.9rem}.workspace-form{margin-top:10px;padding-top:0;border-top:none}.workspace-form-header{text-align:center;margin-bottom:14px}.workspace-form-title{margin:0;color:var(--accent-primary);font-weight:900;letter-spacing:.2px;font-size:clamp(1.2rem,2.2vw,1.55rem)}.workspace-form-header .workspace-form-title{margin-bottom:6px}.workspace-form-divider{display:none}.workspace-form form{max-width:620px;margin:0 auto}.workspace-form .form-group{max-width:620px;margin-left:auto;margin-right:auto}.workspace-form input{max-width:620px;margin-left:auto;margin-right:auto;display:block}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg);justify-content:space-between}.form-actions button{flex:1;min-width:140px}.workspace-form .form-actions{max-width:620px;margin-left:auto;margin-right:auto;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap;margin-top:12px}.workspace-form .form-actions button{flex:0 0 auto;width:min(260px,100%);min-height:44px;padding:10px 16px}@media (max-width: 520px){.form-actions{flex-direction:column}.form-actions button{width:100%}.workspace-form .form-actions{flex-direction:row;flex-wrap:nowrap;gap:10px}.workspace-form .form-actions button{flex:1 1 0;width:auto;min-width:0}}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--border-color)}.btn-danger{background:transparent;border:2px solid var(--error-color);color:var(--error-color);font-weight:700}.btn-danger:hover{background:#ff40811f}@media (max-width: 768px){.choice-buttons{grid-template-columns:1fr}.workspace-choice-card{padding:var(--spacing-lg)}}.do-container{max-width:1400px;margin:0 auto}.do-header{text-align:center;margin-bottom:var(--spacing-xl)}.do-header h1{font-size:2.5rem;color:var(--accent-primary);margin-bottom:var(--spacing-sm)}.do-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);border-bottom:2px solid var(--border-color);overflow-x:auto}.tab-btn{padding:var(--spacing-md) var(--spacing-lg);background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;color:var(--text-secondary);transition:all var(--transition-fast);white-space:nowrap}.tab-btn:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.tab-btn.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.search-section{margin-bottom:var(--spacing-xl)}.search-bar{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.search-bar input{flex:1}.search-results,.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-lg)}.media-card{background-color:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.media-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.media-card img{width:100%;height:270px;object-fit:cover}.media-card-info{padding:var(--spacing-md)}.media-card-info h3{font-size:1rem;margin-bottom:var(--spacing-xs);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical}.media-year{color:var(--text-tertiary);font-size:.875rem;margin-bottom:var(--spacing-xs)}.media-rating,.my-rating{color:var(--warning-color);font-weight:700;margin-bottom:var(--spacing-sm)}.btn-add{width:100%;font-size:.875rem;padding:var(--spacing-xs) var(--spacing-sm)}.media-card.watched{opacity:.7}.watched-badge{background-color:var(--success-color);color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem;display:inline-block;margin-bottom:var(--spacing-xs)}.comment-preview{font-size:.875rem;color:var(--text-secondary);font-style:italic;margin-top:var(--spacing-xs)}.no-results,.empty-list{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary)}.media-modal{max-width:900px;width:90%}.modal-close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:var(--bg-tertiary);border:none;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-fast)}.modal-close:hover{background-color:var(--error-color);color:#fff}.media-detail-content{display:grid;grid-template-columns:300px 1fr;gap:var(--spacing-xl)}.media-detail-poster img{width:100%;border-radius:var(--radius-md)}.media-detail-info h2{color:var(--accent-primary);margin-bottom:var(--spacing-md)}.media-overview{line-height:1.6;margin-bottom:var(--spacing-md);color:var(--text-secondary)}.media-meta{color:var(--text-tertiary);font-size:.875rem;margin-bottom:var(--spacing-lg)}.media-form{margin-top:var(--spacing-lg)}.rating-input{display:flex;align-items:center;gap:var(--spacing-md)}.rating-input input[type=range]{flex:1}.rating-input span{font-size:1.5rem;font-weight:700;color:var(--accent-primary);min-width:40px}.checkbox-group label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.checkbox-group input[type=checkbox]{width:auto;cursor:pointer}.modal-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.btn-delete{background-color:var(--error-color);color:#fff}.btn-delete:hover{background-color:#c62828}.puzzle-container{max-width:1200px;margin:0 auto}.puzzle-header h1{font-size:2.5rem;color:var(--accent-primary);margin-bottom:var(--spacing-sm)}.games-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:var(--spacing-xl)}.game-card{background-color:var(--bg-secondary);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);text-align:center}.game-card-single{max-width:600px;margin:0 auto}.game-card h2{color:var(--accent-primary);margin-bottom:var(--spacing-sm)}.game-card>p{color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.roulette-container{position:relative;margin:var(--spacing-xl) auto;width:400px;height:400px}.roulette-pointer{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:2rem;color:var(--accent-primary);z-index:10}.dice-options{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.dice-container{margin:var(--spacing-xl) auto;perspective:1000px}.dice{width:150px;height:150px;margin:0 auto;background-color:#fff;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-xl);transition:transform var(--transition-normal)}.dice.rolling{animation:diceRoll .1s infinite}@keyframes diceRoll{0%,to{transform:rotateX(0) rotateY(0)}25%{transform:rotateX(180deg) rotateY(90deg)}50%{transform:rotateX(360deg) rotateY(180deg)}75%{transform:rotateX(540deg) rotateY(270deg)}}.dice-face{font-size:4rem;font-weight:700;color:var(--accent-primary)}.btn-large{font-size:1.2rem;padding:var(--spacing-md) var(--spacing-xl);margin-top:var(--spacing-lg)}.game-result{margin-top:var(--spacing-xl);min-height:80px}.winner-announcement{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;padding:var(--spacing-lg);border-radius:var(--radius-lg);animation:slideUp .5s ease}.winner-announcement h3{margin-bottom:var(--spacing-sm);font-size:1.2rem}.winner-text{font-size:2rem;font-weight:700;margin:0}.music-container{max-width:800px;margin:0 auto}.music-header{text-align:center;margin-bottom:var(--spacing-xl)}.music-header h1{font-size:2.5rem;color:var(--accent-primary);margin-bottom:var(--spacing-sm)}.moments-container{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}.moments-hero{text-align:center;margin-bottom:var(--spacing-xl)}.moments-hero h1{font-size:2.5rem;color:var(--accent-primary);margin-bottom:var(--spacing-sm)}.moments-subtitle{font-size:1.2rem;color:var(--text-secondary)}.moments-content{display:grid;gap:var(--spacing-lg)}.moments-placeholder{background-color:var(--bg-secondary);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);text-align:center;min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center}.moments-placeholder p{font-size:1.3rem;color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.coming-soon-card{background-color:var(--bg-secondary);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);text-align:center;margin-bottom:var(--spacing-xl)}.coming-soon-icon{font-size:5rem;margin-bottom:var(--spacing-lg)}.coming-soon-card h2{color:var(--accent-primary);margin-bottom:var(--spacing-md)}.feature-list{list-style:none;padding:0;margin:var(--spacing-lg) 0;text-align:left;max-width:400px;margin-left:auto;margin-right:auto}.feature-list li{padding:var(--spacing-sm);margin-bottom:var(--spacing-xs);background-color:var(--bg-tertiary);border-radius:var(--radius-sm)}.quick-links{text-align:center}.quick-links h3{margin-bottom:var(--spacing-md);color:var(--text-secondary)}.spotify-link{display:inline-flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-xl);background-color:#1db954;color:#fff;text-decoration:none;border-radius:var(--radius-full);font-weight:700;transition:transform var(--transition-fast)}.spotify-link:hover{transform:scale(1.05)}.spotify-icon{font-size:1.5rem}.alert-modal,.confirm-modal,.loading-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999;animation:fadeIn .3s ease}.alert-modal-content,.confirm-modal-content{background:var(--bg-secondary);padding:2.5rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:400px;width:90%;text-align:center;animation:slideUp .3s ease;border:3px solid var(--accent-primary)}.alert-icon,.confirm-icon{font-size:4rem;margin-bottom:1rem}.alert-message,.confirm-message{font-size:1.2rem;color:var(--text-primary);margin-bottom:2rem;line-height:1.6}.confirm-warning{margin-top:-1.2rem;margin-bottom:1.1rem;color:var(--text-secondary);font-size:.95rem;line-height:1.35}.confirm-input{width:100%;max-width:320px;padding:.7rem .9rem;border-radius:var(--radius-lg);border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);margin:0 auto 1.2rem;outline:none;text-align:center}.confirm-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 4px #ff69b42e}.alert-btn{min-width:120px;padding:.875rem 2rem}.confirm-actions{display:flex;gap:1rem;justify-content:center}.confirm-actions button{min-width:120px}.space-invite-status{margin:.25rem auto 1rem;color:var(--text-secondary);font-size:.95rem}.space-btn-loading{position:relative;padding-left:2.2rem}.space-btn-loading:before{content:"";position:absolute;left:.9rem;top:50%;width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.35);border-top-color:#fffffff2;transform:translateY(-50%);animation:spin .9s linear infinite}@keyframes spin{0%{transform:translateY(-50%) rotate(0)}to{transform:translateY(-50%) rotate(360deg)}}.alert-modal-content.success{border-color:var(--accent-primary)}.alert-modal-content.error{border-color:var(--error-color)}.alert-modal-content.warning{border-color:#ff9800}.alert-modal-content.workspace{border-color:var(--accent-primary)}.alert-modal-content.info{border-color:#2196f3}.loading-modal-content{background:var(--bg-secondary);padding:2rem;border-radius:var(--radius-xl);text-align:center;border:3px solid var(--accent-primary)}.loading-modal-content p{margin-top:1rem;color:var(--text-primary);font-size:1.1rem}.watch-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999;animation:fadeIn .3s ease}.watch-modal-content{background:var(--bg-secondary);padding:1.75rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:720px;width:min(92vw,720px);border:3px solid var(--accent-primary);animation:slideUp .3s ease;max-height:88vh;display:flex;flex-direction:column}.watch-modal-header{flex:0 0 auto}.watch-modal-body{flex:1 1 auto;overflow:auto;padding-right:2px;scrollbar-width:none}#mail-compose-modal .watch-modal-body,#mail-compose-modal .watch-modal-content{overflow:visible}#mail-unlock-modal .watch-modal-content{max-width:480px;width:min(92vw,480px);padding:1rem;text-align:center}#mail-unlock-modal .watch-title{margin-bottom:.75rem}#mail-unlock-modal .watch-field{margin-top:.85rem}#mail-unlock-modal .watch-field label{text-align:center}#mail-unlock-modal .watch-modal-body{padding-right:0}#mail-unlock-modal input.input{display:block;margin:.25rem auto 0;max-width:420px;width:100%;text-align:center}#mail-unlock-modal .watch-actions{margin-top:.9rem;justify-content:center}#mail-unlock-modal .watch-actions-right{width:100%;justify-content:center}.watch-modal-body::-webkit-scrollbar{width:0;height:0}.watch-title{margin:0 0 1rem;color:var(--text-primary);font-size:1.5rem}.watch-field{margin-top:1rem}.watch-field label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-weight:700}.watch-field input[readonly]{opacity:.85}.watch-members{display:flex;flex-direction:column;justify-content:flex-start;gap:10px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:14px;padding:10px;min-height:64px}.watch-members.is-inline{flex-direction:row;flex-wrap:wrap}.watch-members.is-inline .watch-member{flex:1 1 160px}.game-status-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:14px;padding:10px}.game-status-option{border:2px solid var(--border-color);border-radius:12px;padding:12px 10px;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));color:var(--text-primary);font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;text-align:center;min-height:54px;-webkit-user-select:none;user-select:none}.game-status-option:hover{border-color:var(--accent-primary)}.game-status-option.is-selected{border-color:var(--accent-primary);box-shadow:0 10px 24px #ff9ec724;color:var(--accent-primary)}@media (max-width: 520px){.game-status-row{grid-template-columns:1fr}}.watch-members.is-sparse{justify-content:center;min-height:86px}.watch-member{display:flex;align-items:center;gap:10px;color:var(--text-primary);padding:10px 12px;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));border:2px solid var(--border-color);border-radius:12px;box-sizing:border-box}.watch-member input[type=checkbox]{width:18px;height:18px}.watch-member-name{font-weight:700}.watch-pill{font-size:.75rem;padding:2px 10px;border-radius:9999px;border:2px solid var(--accent-primary);color:var(--accent-primary)}.watch-review-preview{margin-left:auto;color:var(--text-tertiary);font-size:.9rem;max-width:48%;text-align:right}.watch-hint{color:var(--text-tertiary);font-size:.95rem}.watch-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:1.25rem}.watch-actions-right{display:inline-flex;gap:10px}.watch-hero{display:grid;grid-template-columns:120px 1fr;gap:14px;align-items:start;margin-bottom:8px}.watch-poster{width:120px;height:180px;border-radius:14px;object-fit:cover;background:var(--bg-tertiary);border:2px solid var(--border-color)}.watch-hero textarea[readonly],.watch-hero input[readonly]{background:var(--bg-primary);color:var(--text-secondary)}.watch-readonly{width:100%;background:var(--bg-primary);color:var(--text-secondary);border:2px solid var(--border-color);border-radius:12px;padding:10px 12px;line-height:1.4;-webkit-user-select:none;user-select:none;cursor:default;pointer-events:none}.watch-readonly.watch-scroll{pointer-events:auto}.watch-scrollbox{position:relative;border-radius:12px}.watch-scroll{max-height:112px;overflow:auto;padding-bottom:24px;scrollbar-width:none}.watch-scroll::-webkit-scrollbar{width:0;height:0}.watch-scroll-cue{position:absolute;right:10px;bottom:6px;opacity:0;transform:translateY(-2px);transition:opacity .16s ease,transform .16s ease;color:var(--text-tertiary);pointer-events:none;font-size:18px;line-height:1}.watch-scrollbox.has-more .watch-scroll-cue{opacity:1;transform:translateY(0)}.watch-scrollbox.has-more:after{content:"";position:absolute;left:2px;right:2px;bottom:2px;height:34px;border-radius:0 0 12px 12px;background:linear-gradient(180deg,rgba(0,0,0,0),var(--bg-primary));pointer-events:none}.watch-season-row{display:flex;gap:10px;align-items:center}.watch-season-dropdown{position:relative;flex:1}.watch-season-btn{width:100%;padding:12px 14px;border-radius:14px;border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;position:relative;display:grid;grid-template-columns:1.1em 1fr 1.1em;align-items:center;gap:10px;line-height:1.2}.watch-season-btn:before{content:"";display:block;width:1.1em;height:1em}.watch-season-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;justify-self:center;text-align:center}.watch-season-caret{justify-self:end;color:var(--text-tertiary);font-size:16px;line-height:1;pointer-events:none}.watch-season-dropdown.is-open .watch-season-btn{border-color:var(--accent-primary);box-shadow:0 10px 24px #ff9ec72e}.watch-season-menu{position:absolute;left:0;right:0;top:calc(100% + 8px);background:var(--bg-primary);border:2px solid var(--border-color);border-radius:14px;box-shadow:var(--shadow-lg);padding:6px;display:none;max-height:240px;overflow:auto;z-index:10000;scrollbar-width:none}.watch-season-menu::-webkit-scrollbar{width:0;height:0}.watch-season-dropdown.is-open .watch-season-menu{display:block}.watch-season-option{width:100%;text-align:left;border:none;background:transparent;color:var(--text-primary);padding:10px 12px;border-radius:12px;cursor:pointer}.watch-season-option:hover{background:var(--accent-light);color:var(--accent-primary)}.watch-chronology{display:flex;flex-direction:column;gap:8px}.watch-chrono-item{display:grid;grid-template-columns:44px 1fr 120px;gap:10px;align-items:center;padding:10px;border-radius:14px;border:2px solid var(--border-color);background:#0000001f}.watch-chrono-item.is-current{border-color:var(--accent-primary);box-shadow:0 10px 24px #ff9ec71f}.watch-chrono-poster{width:44px;height:62px;border-radius:10px;object-fit:cover;background:#ffffff0f}.watch-chrono-poster.is-placeholder{display:block}.watch-chrono-info{min-width:0}.watch-chrono-title{color:var(--text-primary);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.watch-chrono-meta{margin-top:2px;color:var(--text-tertiary);font-size:.9rem}.watch-chrono-action{display:flex;align-items:center;justify-content:center;width:120px}.watch-chrono-status{display:inline-flex;align-items:center;justify-content:center;width:100%;font-weight:700;font-size:.95rem;color:var(--text-tertiary)}.watch-chrono-add{width:100%;justify-content:center;text-align:center}.watch-chrono-status.is-added{color:var(--text-secondary)}.watch-chrono-status.is-watched{color:var(--accent-primary)}.watch-season-option.is-selected{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));border:1px solid var(--accent-primary)}.watch-season-actions{display:inline-flex;gap:8px;flex-wrap:wrap}.watch-episodes{max-height:300px;overflow:auto;padding:10px 10px 28px;border-radius:14px;border:2px solid var(--border-color);background:var(--bg-primary);display:grid;gap:8px;scrollbar-width:none}.watch-season-row+.watch-scrollbox{margin-top:10px}.watch-episodes::-webkit-scrollbar{width:0;height:0}.watch-episode{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:2px solid var(--border-color);background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary))}.watch-episode input[type=checkbox]{width:18px;height:18px}.watch-episode-title{color:var(--text-primary);font-weight:700}.status-pill{padding:2px 10px;border-radius:9999px;border:2px solid var(--border-color);color:var(--text-tertiary);font-weight:800;font-size:.75rem}.status-pill.is-watched{border-color:var(--accent-primary);color:var(--accent-primary)}.status-pill.is-watching{border-color:#ff9800;color:#ff9800}@media (max-width: 720px){.watch-hero{grid-template-columns:92px 1fr}.watch-poster{width:92px;height:138px}.watch-actions{flex-wrap:wrap;justify-content:flex-end}.watch-hint{width:100%;text-align:left}}.star-rating{display:flex;gap:.25rem;justify-content:center;margin:1rem 0}.star{font-size:2rem;cursor:pointer;color:var(--border-color);transition:all .2s ease;-webkit-user-select:none;user-select:none}.star:hover,.star.active{color:gold;transform:scale(1.2)}.star.half{position:relative}.star.half:before{content:"⭐";position:absolute;width:50%;overflow:hidden;color:gold}.rating-value{font-size:1.5rem;font-weight:700;color:var(--accent-primary);margin-left:1rem}@media (max-width: 768px){#navbar{flex-wrap:nowrap;padding:var(--spacing-sm) var(--spacing-md);display:grid;grid-template-columns:44px 1fr auto;grid-template-areas:"left brand actions";align-items:center;gap:var(--spacing-sm)}#menu-toggle{grid-area:left}.nav-brand{grid-area:brand}.nav-actions{grid-area:actions}body.auth-mode #navbar{display:flex;justify-content:center;align-items:center}body.auth-mode .nav-actions{justify-self:auto}.nav-brand{justify-self:center}.nav-brand h1{font-size:1.25rem;text-align:center}.nav-center{display:none!important}.nav-actions{justify-self:end;display:inline-flex;align-items:center;gap:10px}.dropdown-menu-right[data-dropdown-menu=notifications]{position:fixed;left:calc(10px + env(safe-area-inset-left));right:calc(10px + env(safe-area-inset-right));top:calc(var(--header-h, 56px) + var(--spacing-sm) + env(safe-area-inset-top));width:auto;min-width:0;max-width:none;height:auto;max-height:calc((var(--vh, 1vh) * 100) - var(--header-h, 56px) - env(safe-area-inset-top) - env(safe-area-inset-bottom) - (var(--spacing-sm) * 2));transform:translateY(-6px)}.dropdown-menu-right[data-dropdown-menu=notifications].open{transform:translateY(0)}#settings-dropdown{display:none!important}#main-content{padding:var(--spacing-md)}.page-header{--page-header-side: 92px;margin:6px 0 10px;gap:10px}.page-title{font-size:1.55rem;line-height:1.1}.page-subtitle{font-size:.95rem;line-height:1.2}.btn-back{padding:8px 12px;min-height:36px;font-size:.95rem}.home-hero h1{font-size:2rem}.home-subtitle{font-size:1.2rem}.home-cards{grid-template-columns:1fr;gap:var(--spacing-md)}.auth-card,.quiz-card{padding:var(--spacing-lg);border-radius:var(--radius-md)}.auth-card h1,.quiz-card h1{font-size:1.5rem}.birthday-modal h1{font-size:1.8rem}.birthday-message{font-size:1rem}button,.btn{padding:var(--spacing-md) var(--spacing-lg)}#footer{padding:var(--spacing-md)}}@media (max-width: 480px){html,body{font-size:14px}body.auth-mode input,body.auth-mode textarea,body.auth-mode select,body.quiz-mode input,body.quiz-mode textarea,body.quiz-mode select{font-size:16px}.home-hero h1{font-size:1.8rem}.auth-card,.quiz-card{padding:var(--spacing-md)}.modal-content{padding:var(--spacing-lg);max-width:95%}}@media (max-width: 768px){.nav-brand{display:flex;align-items:center;gap:var(--spacing-md)}#menu-toggle{display:block;font-size:1.5rem;background:transparent;border:none;cursor:pointer;color:var(--text-primary);padding:var(--spacing-xs);width:44px;height:44px;border-radius:12px}#menu-toggle:hover{background:#ff9ec71a}}@media (min-width: 769px){#menu-toggle{display:none}.nav-center{display:flex!important}}@media (max-width: 768px){.mobile-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;z-index:9998;display:none;align-items:stretch;justify-content:flex-start}.mobile-drawer-backdrop.is-open{display:flex}.mobile-drawer{width:min(86vw,320px);height:100%;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));border-right:3px solid var(--accent-primary);box-shadow:var(--shadow-xl);padding:18px 14px 14px;transform:translate(-102%);transition:transform .22s ease;display:flex;flex-direction:column;gap:14px}.mobile-drawer-backdrop.is-open .mobile-drawer{transform:translate(0)}.mobile-drawer-user{width:min(92%,288px);margin-left:auto;margin-right:auto;display:flex;align-items:center;gap:14px;border-radius:18px;border:2px solid rgba(255,158,199,.55);background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));box-shadow:var(--shadow-lg);padding:14px;cursor:pointer;text-align:left}.mobile-drawer-user:active{transform:scale(.99)}.mobile-drawer-user-avatar{width:64px;height:64px;border-radius:9999px;border:3px solid rgba(255,158,199,.75);background:#00000038;overflow:hidden;display:grid;place-items:center;flex:0 0 auto;color:#ffffffeb;font-weight:1000;font-size:1.4rem;line-height:1}.mobile-drawer-user-avatar img{width:100%;height:100%;object-fit:cover;display:block}.mobile-drawer-user-meta{min-width:0;flex:1}.mobile-drawer-user-name{font-weight:1000;color:var(--text-primary);font-size:1.05rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-drawer-user-email{color:var(--text-secondary);font-weight:800;margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-drawer-links{display:flex;flex-direction:column;gap:0;padding-top:2px;align-items:center}.mobile-drawer-navlink{width:min(92%,288px);margin-left:auto;margin-right:auto;justify-content:center;text-align:center;background:#00000024;border:2px solid rgba(255,158,199,.35);margin-bottom:12px}.mobile-drawer-navlink[data-drawer-toggle]{margin-bottom:12px}.mobile-drawer-navlink[data-drawer-toggle][aria-expanded=true]{margin-bottom:0}.mobile-drawer-dropdown{width:min(92%,288px);background:var(--bg-secondary);border:0;border-radius:var(--radius-lg);box-shadow:none;overflow:hidden;opacity:0;transform:translateY(-6px);transition:max-height .24s ease,opacity .18s ease,transform .18s ease,margin .18s ease;margin:0;pointer-events:none}.mobile-drawer-dropdown.is-open{opacity:1;transform:translateY(0);margin:10px auto 12px;border:2px solid var(--accent-primary);box-shadow:var(--shadow-lg);pointer-events:auto}.mobile-drawer-dropdown .dropdown-item{width:100%;cursor:pointer;justify-content:center;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;border:none;border-radius:0;box-shadow:none;margin:0;transform:none;border-bottom:1px solid var(--bg-tertiary)}.mobile-drawer-dropdown .dropdown-item:hover{transform:none}.mobile-drawer-dropdown .dropdown-item:after{content:none}.mobile-drawer-dropdown .dropdown-item:last-child{border-bottom:none}.mobile-drawer-navlink:active,.mobile-drawer-logout:active{transform:scale(.99)}.mobile-drawer-footer{margin-top:auto;padding-top:8px;border-top:1px solid rgba(255,255,255,.1)}.mobile-drawer-logout{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--text-primary);font-weight:800;padding:10px 8px;text-align:center;cursor:pointer;border-radius:10px}.mobile-drawer-logout:hover{background:#ff9ec71a}body.has-mobile-drawer{overflow:hidden}}@media (max-width: 768px){input,textarea,select,button{min-height:44px}.home-card{padding:var(--spacing-lg)}.card-icon{font-size:2.5rem}}a{transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}a:active{transform:scale(.98)}button,.btn{position:relative;overflow:hidden}button:hover,.btn:hover{transform:translateY(-2px)}button:active,.btn:active{transform:translateY(0)}button:after,.btn:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background-color:#ffffff80;transform:translate(-50%,-50%);transition:width .6s,height .6s}button:active:after,.btn:active:after{width:300px;height:300px}input:focus,textarea:focus,select:focus{box-shadow:0 0 0 3px #ff6b9d33}.home-card{transform-origin:center}.home-card:active{transform:translateY(-2px) scale(.98)}.nav-menu a{position:relative}.nav-menu a:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background-color:var(--accent-primary);transform:translate(-50%);transition:width var(--transition-normal)}.nav-menu a:hover:after{width:80%}.theme-toggle{transition:transform var(--transition-normal);position:relative}.theme-toggle:hover{transform:scale(1.05)}.theme-toggle:active{transform:scale(.96)}@keyframes catBlink{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.3;transform:scaleY(.1)}}.modal{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}button[disabled],.btn[disabled]{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:.7}}html{scroll-behavior:smooth}::selection{background-color:var(--accent-primary);color:#fff}*:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}#main-content{animation:pageTransition .3s ease}@keyframes pageTransition{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.error-message{animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}@keyframes successPulse{0%{box-shadow:0 0 #4caf50b3}70%{box-shadow:0 0 0 10px #4caf5000}to{box-shadow:0 0 #4caf5000}}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--bg-tertiary);color:var(--text-primary);font-size:.875rem;white-space:nowrap;border-radius:var(--radius-sm);opacity:0;pointer-events:none;transition:opacity var(--transition-normal);margin-bottom:5px}[data-tooltip]:hover:after{opacity:1}.home-simple{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:10px;padding:28px var(--spacing-md)}.home-title{margin:0;font-size:clamp(1.6rem,2.6vw,2.4rem);text-align:center;color:var(--text-primary)}.home-name{color:var(--accent-primary);text-shadow:2px 2px 4px rgba(255,158,199,.25)}.home-text{margin:0;text-align:center;color:var(--text-secondary);font-size:1.05rem;max-width:680px}.home-since-row{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:14px;border:1px solid rgba(255,158,199,.35);background:#0000002e;box-shadow:0 0 0 1px #ff9ec714 inset;margin-top:4px}.home-since-counter{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.95rem;letter-spacing:.08em;color:var(--text-primary);white-space:nowrap;-webkit-user-select:none;user-select:none}.home-heart{color:#ff2b6a;font-size:1.1rem;line-height:1}.home-mail{width:100%;max-width:740px;margin-top:16px;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:2px solid var(--border-color);padding:var(--spacing-lg);display:flex;flex-direction:column}.home-mail-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}@media (max-width: 768px){.home-mail-header{flex-direction:column;align-items:stretch;justify-content:flex-start;gap:10px}.home-mail-title{text-align:center}.home-mail-actions{width:100%;justify-content:center;flex-wrap:nowrap}.home-mail-action-btn{min-width:0;flex:1 1 0;padding-left:14px;padding-right:14px}}.home-mail-actions{display:inline-flex;align-items:center;gap:10px}.home-mail-action-btn{min-width:160px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;line-height:1;white-space:nowrap}.home-mail-title{margin:0;font-size:1.15rem;color:var(--text-primary)}.home-mail-tabs{display:flex;gap:0;border:none;border-radius:0;overflow:visible;background:transparent;margin:4px calc(-1 * var(--spacing-lg)) 10px}.home-mail-tab{flex:1 1 0;min-width:0;border:none;background:transparent;color:var(--text-primary);font-weight:800;padding:8px 10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-bottom:2px solid transparent;transition:none;border-radius:0}.home-mail-tab:hover{background:transparent;color:var(--text-primary);transform:none;box-shadow:none}.home-mail-tab.is-active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.home-mail-tab.is-active[data-mail-tab=open]{border-right:1px solid var(--bg-tertiary)}.home-mail-tab.is-active[data-mail-tab=read]{border-left:1px solid var(--bg-tertiary)}.home-mail-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 8px;background:transparent;color:var(--text-primary);font-size:.8rem;border-radius:0}.home-mail-tab.is-active .home-mail-tab-count{color:var(--accent-primary)}.home-mail-items-area{display:flex;flex-direction:column;flex:1 1 auto;min-height:0}.home-mail-items-scroll{position:relative;display:flex;flex-direction:column;flex:1 1 auto;min-height:0}.home-mail-scroll-fade{position:absolute;left:2px;right:2px;bottom:2px;height:34px;border-radius:0 0 12px 12px;background:linear-gradient(180deg,rgba(0,0,0,0),var(--bg-secondary));pointer-events:none;opacity:0;transition:opacity .16s ease;z-index:4}.home-mail-scroll-arrow{position:absolute;left:50%;bottom:8px;transform:translate(-50%) translateY(-2px);opacity:0;transition:opacity .16s ease,transform .16s ease;color:var(--text-tertiary);pointer-events:none;font-size:18px;line-height:1;z-index:5}.home-mail-items-scroll.is-scrollable:not(.is-at-bottom) .home-mail-scroll-arrow{opacity:1;transform:translate(-50%) translateY(0)}.home-mail-items-scroll.is-scrollable:not(.is-at-bottom) .home-mail-scroll-fade{opacity:1}.home-mail-items-scroll.is-scrollable.is-at-bottom .home-mail-scroll-arrow{top:8px;bottom:auto;opacity:1;transform:translate(-50%) translateY(0)}.home-mail-items-scroll.is-scrollable.is-at-bottom .home-mail-scroll-fade{top:2px;bottom:auto;border-radius:12px 12px 0 0;background:linear-gradient(0deg,rgba(0,0,0,0),var(--bg-secondary));opacity:1}.home-inbox-list{display:flex;flex-direction:column;--mail-item-gap: 10px;gap:var(--mail-item-gap);--mail-visible-items: 4;--mail-item-row-height: 74px;height:calc((var(--mail-visible-items) * var(--mail-item-row-height)) + ((var(--mail-visible-items) - 1) * var(--mail-item-gap)));overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable;padding-right:0;scrollbar-width:none}@media (max-width: 768px){.home-mail{--home-gutter: 10px;max-width:none;width:calc(100vw - (2 * var(--home-gutter)) - env(safe-area-inset-left) - env(safe-area-inset-right));margin-left:calc(50% - 50vw + var(--home-gutter) + env(safe-area-inset-left));margin-right:calc(50% - 50vw + var(--home-gutter) + env(safe-area-inset-right));height:min(clamp(420px,calc((var(--vh, 1vh) * 100) - 220px),900px),calc(var(--home-mail-max-h, 9999px) - env(safe-area-inset-bottom)));max-height:calc(var(--home-mail-max-h, 9999px) - env(safe-area-inset-bottom))}.home-inbox-list{height:auto;flex:1 1 auto;min-height:0}}.home-inbox-list::-webkit-scrollbar{width:0;height:0}.home-mail-empty{flex:1;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);text-align:center;padding:12px 6px}.home-mail-item{width:100%;text-align:left;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#0000002e;padding:10px 12px;cursor:pointer;color:inherit;box-sizing:border-box;height:var(--mail-item-row-height);overflow:hidden;flex:0 0 var(--mail-item-row-height);display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.home-mail-left{min-width:0;display:flex;flex-direction:column;gap:6px}.home-mail-item:hover{border-color:#ff9ec759}.home-mail-item.is-unread{border-color:#ff9ec78c;box-shadow:0 0 0 1px #ff9ec71a inset}.home-mail-label{color:var(--text-secondary);font-weight:800;margin-right:6px}.home-mail-from{font-weight:700;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-mail-when{color:var(--text-secondary);font-size:.9rem;white-space:nowrap;line-height:1;align-self:center}.home-mail-subject{margin-top:0;color:var(--text-primary);font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-mail-lock{width:100%;max-width:460px;margin:0 auto;display:flex;flex-direction:column;align-items:stretch;gap:10px;padding:6px 2px}.home-mail-lock-title{font-weight:900;font-size:1.22rem;color:var(--text-primary)}.home-mail-lock-legend{color:var(--text-secondary);opacity:.95}.home-mail-lock-row{display:flex;align-items:center;justify-content:center;gap:10px;width:100%}.home-mail-lock-input{flex:0 1 240px;min-width:0;min-height:44px;max-width:240px;text-align:center}.home-mail-lock-input::placeholder{text-align:center}.home-mail-lock-btn{flex:0 0 auto;min-height:44px;min-width:140px;white-space:nowrap}@media (max-width: 768px){.home-mail-lock-row{flex-direction:column;align-items:center;justify-content:flex-start}.home-mail-lock-input{flex:0 0 auto;width:75%;max-width:380px}.home-mail-lock-btn{width:60%;max-width:340px;min-width:0}}.home-mail-lock-hint{min-height:18px;font-size:.95rem;color:var(--text-secondary)}.home-mail-lock-hint.is-error{color:#ff5b87}.home-mail-lock-hint.is-timeout{color:var(--text-secondary);opacity:.95}.mylist-page{max-width:1100px;margin:0 auto;padding:0 16px 48px}.mylist-header{margin-bottom:18px}.mylist-landing-results{max-width:580px;margin-left:auto;margin-right:auto;gap:10px}.mylist-title{margin:0}.mylist-tabs{display:flex;gap:10px;padding:8px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:14px}.mylist-tab{flex:1 1 0;min-width:0;text-align:center;padding:10px 14px;border-radius:9999px;border:2px solid var(--border-color);background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));color:var(--text-secondary);font-weight:700}.mylist-tab:hover{border-color:var(--accent-primary);color:var(--text-primary)}.mylist-tab.is-active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border-color:transparent}.mylist-search{display:flex;gap:12px;align-items:center;margin-bottom:10px}.mylist-search-field{position:relative;flex:1}.mylist-search-dropdown{position:absolute;top:calc(100% + 2px);left:0;right:0;z-index:40;max-height:420px;overflow:auto;padding:8px;border-radius:16px;border:2px solid var(--border-color);background:linear-gradient(135deg,#1e1e1ef5,#161616f5);box-shadow:0 20px 40px #0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.mylist-search-dropdown .result-item{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary))}.mylist-search input{width:100%;padding-right:44px}.mylist-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:9999px;border:2px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);font-size:18px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0}.mylist-search-clear:hover,.mylist-search-clear:active{transform:translateY(-50%)}.mylist-search-clear:hover{border-color:var(--accent-primary);color:var(--text-primary);background:var(--bg-secondary)}.mylist-search button{white-space:nowrap;padding-left:18px;padding-right:18px}.mylist-results{margin-top:10px;display:grid;gap:12px}#mylist-results:empty{display:none;margin-top:0}.result-item{display:grid;grid-template-columns:64px 1fr auto;gap:12px;align-items:center;padding:12px;border-radius:16px;border:2px solid var(--border-color);background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));box-shadow:var(--shadow-sm);transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}.result-item.is-landing{grid-template-columns:1fr auto;padding-top:8px;padding-bottom:8px}.result-item.is-landing .result-info{min-width:0}.mylist-landing-inline{display:flex;align-items:center;gap:12px;min-width:0}.mylist-landing-title{margin:0;font-size:.98rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:clamp(86px,12vw,140px);flex:0 0 auto}.result-item:hover{transform:translateY(-1px);border-color:var(--accent-primary);box-shadow:0 16px 34px #00000073}.result-poster{width:64px;height:96px;border-radius:12px;object-fit:cover;background:var(--bg-tertiary)}.result-info h3{margin:0;font-size:1.05rem;color:var(--text-primary);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.mylist-landing-counts{margin-top:0;display:flex;gap:10px;flex-wrap:nowrap;align-items:center;min-width:0;flex:1 1 auto;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.mylist-landing-counts::-webkit-scrollbar{width:0;height:0}.mylist-count-pill{display:inline-flex;gap:6px;align-items:center;white-space:nowrap;line-height:1.2}.mylist-landing-counts .status-pill{padding:2px 7px;font-size:.68rem}.result-item.is-landing .btn-primary{padding:7px 14px;border-radius:9999px}.mylist-count-label{color:inherit;font-weight:900}.result-meta{margin-top:4px;display:flex;gap:10px;flex-wrap:wrap;color:var(--text-tertiary);font-size:.9rem}.platform-pill{padding:2px 10px;border-radius:9999px;border:2px solid var(--border-color);color:var(--text-secondary);font-weight:800;font-size:.75rem;background:var(--bg-tertiary)}.platform-chips{display:inline-flex;gap:6px;flex-wrap:wrap;align-items:center}.platform-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);padding:2px 10px;border-radius:999px;font-size:.75rem;font-weight:800;line-height:1.4;cursor:pointer;-webkit-user-select:none;user-select:none}.platform-chip:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.platform-chip.is-selected{border-color:var(--accent-primary);color:var(--accent-primary);background:#ff69b41a}.result-overview{margin-top:6px;color:var(--text-secondary);font-size:.92rem;line-height:1.35}.result-overview:not(.result-note){display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.result-overview.result-note{color:var(--text-tertiary);font-size:.9rem}.mylist-edit-modal .confirm-modal-content{max-width:720px;width:min(92vw,720px);text-align:left}.mylist-edit-hero{display:grid;grid-template-columns:96px 1fr;gap:12px;align-items:start;margin-bottom:14px}.mylist-edit-poster{width:96px;height:140px;border-radius:14px;object-fit:cover;background:var(--bg-tertiary);border:2px solid var(--border-color)}.mylist-edit-title{font-weight:800;color:var(--text-primary);font-size:1.1rem;margin-bottom:6px}.mylist-edit-overview{color:var(--text-secondary);line-height:1.35;font-size:.95rem}.mylist-edit-status{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:10px 0 14px}.mylist-status-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);padding:8px 12px;border-radius:999px;font-weight:800;cursor:pointer;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}.mylist-status-chip:hover{border-color:var(--accent-primary);transform:translateY(-1px)}.mylist-status-chip.is-active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-color:transparent;box-shadow:0 14px 30px #00000059;color:#fff}.mylist-edit-fields{display:grid;gap:12px;margin-bottom:14px}.mylist-edit-label{display:grid;gap:6px;color:var(--text-secondary);font-weight:700}.inline-actions{display:flex;gap:10px;justify-content:flex-end;align-items:center}.icon-btn{width:44px;height:44px;border-radius:999px;border:2px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.05rem}.icon-btn svg{display:block}.icon-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.icon-btn.danger:hover{border-color:var(--error-color);color:var(--error-color)}.mylist-chronology{margin-top:10px}.mylist-section{margin-top:22px}.mylist-section h2{margin:0 0 10px;font-size:1.2rem;color:var(--text-primary);text-align:center}.mylist-empty{color:var(--text-tertiary);text-align:center;padding:22px 0}.genre-group{margin-top:14px}.genre-group:first-child{margin-top:6px}.genre-title{margin:14px 0 10px;color:var(--text-primary);font-size:1.05rem;text-align:center}.genre-group:first-child .genre-title{margin-top:0}@media (max-width: 560px){.mylist-page.has-back{--mylist-gutter: 10px;max-width:none;width:calc(100vw - (2 * var(--mylist-gutter)) - env(safe-area-inset-left) - env(safe-area-inset-right));margin-left:calc(50% - 50vw + var(--mylist-gutter) + env(safe-area-inset-left));margin-right:calc(50% - 50vw + var(--mylist-gutter) + env(safe-area-inset-right));padding-left:0;padding-right:0}.mylist-page.has-back .mylist-header.page-header{--mylist-header-side: 92px;grid-template-columns:var(--mylist-header-side) 1fr var(--mylist-header-side);margin:6px 0 10px;gap:10px}.mylist-page.has-back .mylist-header .page-header-right{display:flex;visibility:hidden}.mylist-page.has-back .mylist-title{white-space:normal;word-break:break-word}.mylist-scroll-state{position:fixed;left:calc(var(--mylist-gutter, 10px) + env(safe-area-inset-left));right:calc(var(--mylist-gutter, 10px) + env(safe-area-inset-right));bottom:calc(var(--mylist-gutter, 10px) + env(safe-area-inset-bottom));height:44px;pointer-events:none;z-index:60}.mylist-scroll-fade{position:absolute;left:2px;right:2px;bottom:2px;height:34px;border-radius:14px;background:linear-gradient(180deg,#0000,#0000008c);opacity:0;transition:opacity .16s ease}.mylist-scroll-arrow{position:absolute;left:50%;bottom:8px;transform:translate(-50%) translateY(-2px);opacity:0;transition:opacity .16s ease,transform .16s ease;color:var(--text-tertiary);font-size:18px;line-height:1}.mylist-scroll-state.is-scrollable:not(.is-at-bottom) .mylist-scroll-arrow{opacity:1;transform:translate(-50%) translateY(0)}.mylist-scroll-state.is-scrollable:not(.is-at-bottom) .mylist-scroll-fade{opacity:1}.mylist-scroll-state.is-scrollable.is-at-bottom .mylist-scroll-arrow{top:8px;bottom:auto;opacity:1;transform:translate(-50%) translateY(0)}.mylist-scroll-state.is-scrollable.is-at-bottom .mylist-scroll-fade{top:2px;bottom:auto;background:linear-gradient(0deg,#0000,#0000008c);opacity:1}.mylist-tabs{padding:6px;gap:8px;border-radius:16px;margin-bottom:12px}.mylist-tab{padding:10px 12px}.mylist-search{margin-bottom:8px}.result-item{padding:10px}.result-action{justify-self:stretch;width:100%}.inline-actions{width:100%;justify-content:space-between}.inline-actions>button{flex:1 1 0;min-width:0}.result-item{grid-template-columns:56px 1fr;grid-template-areas:"poster info" "action action";align-items:start}.result-poster{grid-area:poster;width:56px;height:84px}.result-info{grid-area:info}.result-action{grid-area:action;justify-self:stretch;width:100%;display:flex;flex-wrap:wrap;gap:10px}.result-action{justify-self:stretch}.result-action>.inline-actions{flex:1 1 100%;min-width:0}.result-action>button{flex:1 1 calc(50% - 5px);min-width:0}.result-action>button:only-child{flex-basis:100%}}.puzzle-container{max-width:1100px;margin:0 auto}@media (max-width: 560px){.puzzle-container{--puzzle-gutter: 10px;max-width:none;width:calc(100vw - (2 * var(--puzzle-gutter)) - env(safe-area-inset-left) - env(safe-area-inset-right));margin-left:calc(50% - 50vw + var(--puzzle-gutter) + env(safe-area-inset-left));margin-right:calc(50% - 50vw + var(--puzzle-gutter) + env(safe-area-inset-right))}}.puzzle-header{text-align:center;margin-bottom:var(--spacing-xl)}.puzzle-header h1{color:var(--accent-primary);font-size:2.2rem;margin-bottom:var(--spacing-sm);text-shadow:2px 2px 4px rgba(255,158,199,.3)}.puzzle-header p{color:var(--text-secondary);font-size:1.1rem}.games-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-xl);align-items:stretch}.game-card{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border:2px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:var(--shadow-lg);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.game-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.game-card-single{max-width:760px;margin:0 auto}.game-card h2{color:var(--accent-primary);font-size:1.6rem;margin-bottom:var(--spacing-sm)}.game-card>p{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.game-result{margin-top:var(--spacing-lg);padding:var(--spacing-lg);background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-color);min-height:70px;display:flex;align-items:center;justify-content:center;text-align:center}.winner-text{font-size:1.4rem;color:var(--accent-primary);font-weight:700}.puzzle-view-tabs{display:flex;gap:0;border:none;border-radius:0;overflow:visible;background:transparent;margin:4px 0 var(--spacing-lg)}.puzzle-view-tab{flex:1 1 0;min-width:0;border:none;background:transparent;color:var(--text-primary);font-weight:800;padding:10px 12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-bottom:2px solid transparent;transition:none;border-radius:0}.puzzle-view-tab:hover{background:transparent;color:var(--text-primary);transform:none;box-shadow:none}.puzzle-view-tab.is-active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.puzzle-view-tab.is-active[data-roulette-view-tab=roulette],.puzzle-view-tab.is-active[data-dice-view-tab=dice]{border-right:1px solid var(--bg-tertiary)}.puzzle-view-tab.is-active[data-roulette-view-tab=list],.puzzle-view-tab.is-active[data-dice-view-tab=list]{border-left:1px solid var(--bg-tertiary)}@media (min-width: 561px){.puzzle-view-tabs{display:none}}.moments-page{max-width:1100px;margin:0 auto;padding:0 16px 48px}.moments-header{margin:0 0 var(--spacing-lg)}.moments-toolbar{display:flex;justify-content:center;margin:10px 0 14px}.moments-toolbar-inner{width:min(920px,100%);display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:nowrap;overflow-x:auto;padding:2px 2px 6px}.moments-actions-left,.moments-actions-right{display:flex;gap:10px;flex-wrap:nowrap;align-items:center}.moments-toolbar-btn{width:160px;justify-content:center;white-space:nowrap}.moments-toolbar-btn-danger{border-color:#ff52528c!important}@media (max-width: 520px){.moments-toolbar-btn{width:150px}}@media (max-width: 768px){.moments-page{padding-left:0;padding-right:0;padding-bottom:40px}.moments-header{margin-bottom:10px}.moments-toolbar{margin:8px 0 12px}.moments-toolbar-inner{width:100%;flex-wrap:wrap;justify-content:center;overflow-x:visible;padding:0;gap:10px}.moments-actions-left,.moments-actions-right{width:100%;justify-content:center;flex-wrap:wrap;gap:10px}.moments-toolbar-btn{width:auto;min-width:0;flex:1 1 calc(50% - 10px);max-width:100%}}@media (max-width: 380px){.moments-toolbar-btn{flex-basis:100%}}.moments-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.moments-grid.is-empty{display:flex;align-items:center;justify-content:center;text-align:center;min-height:320px}.moments-empty{opacity:.9;padding:18px 14px}.moments-empty-title{font-size:1.05rem;margin-bottom:6px}.moments-empty-sub{opacity:.9}@media (min-width: 720px){.moments-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1024px){.moments-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.moment-tile{position:relative;border-radius:14px;overflow:hidden;background:#00000040;border:1px solid rgba(255,255,255,.12);cursor:pointer;min-height:170px}.moment-tile:focus{outline:2px solid rgba(255,255,255,.35);outline-offset:2px}.moment-select-indicator{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:10px;display:grid;place-items:center;background:#0000008c;border:2px solid rgba(255,255,255,.3);color:#ffffffeb;opacity:0;transform:scale(.96);transition:opacity .12s ease,transform .12s ease;pointer-events:none}.moment-tile.is-multi-select .moment-select-indicator{opacity:.9}.moment-tile.is-selected{outline:3px solid rgba(255,158,199,.75);outline-offset:2px}.moment-tile.is-selected .moment-select-indicator{opacity:1;transform:scale(1);background:#ff9ec740;border-color:#ff9ec7cc}.moment-reorder-controls{position:absolute;left:10px;right:10px;bottom:10px;display:none;gap:8px;justify-content:flex-end;z-index:3}.moment-tile.is-reordering .moment-reorder-controls{display:flex}.moment-reorder-btn{width:44px;min-width:44px;padding:6px 0;justify-content:center}.moment-tile.is-reordering{cursor:default}.moment-tile.is-reordering .moment-overlay{pointer-events:none}.moment-photo{width:100%;height:100%;object-fit:cover;display:block}.moment-overlay{position:absolute;left:0;right:0;bottom:0;padding:10px 10px 9px;background:linear-gradient(to top,#000000bf,#0000)}.moment-caption{font-size:.9rem;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.moment-date{font-size:.78rem;opacity:.85;margin-top:3px}.moment-album{padding:16px;display:grid;align-content:center;justify-items:center;text-align:center;height:100%;gap:10px}.moment-album .album-icon{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;background:var(--accent-light);border:2px solid var(--border-color);font-size:30px}.moment-album .album-title{font-weight:900;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.moment-album .album-meta{color:var(--text-secondary);font-size:.9rem}.moments-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:2000;display:grid;place-items:center;padding:18px}.moments-modal{width:min(520px,96vw);background:var(--bg-secondary);border:2px solid var(--accent-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.moments-modal header{padding:14px 16px;border-bottom:1px solid var(--bg-tertiary);display:flex;align-items:center;justify-content:space-between;gap:12px}.moments-modal header h2{margin:0;font-size:1.1rem;color:var(--text-primary)}.moments-modal .moments-modal-body{padding:16px;display:grid;gap:12px}.moments-modal label{font-weight:800;color:var(--text-secondary);font-size:.9rem}.moments-modal input[type=text],.moments-modal input[type=date],.moments-modal select{width:100%;padding:10px 12px;border-radius:12px;border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary)}.moments-modal .moments-modal-actions{display:flex;gap:10px;justify-content:flex-end;padding:14px 16px;border-top:1px solid var(--bg-tertiary)}.moments-photo-preview{width:100%;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.1);background:#00000040}.moments-photo-preview img{width:100%;height:auto;display:block}
