.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);background:transparent;position:relative}.login-card{width:100%;max-width:420px;background:#1a1a1ab3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);padding:var(--spacing-2xl);box-shadow:var(--shadow-xl),0 0 40px #9333ea1a;border:1px solid rgba(255,255,255,.1);position:relative;overflow:hidden}.login-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(147,51,234,.15),transparent 70%);opacity:.5;pointer-events:none}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-title{font-size:2rem;font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-sm);letter-spacing:-.02em}.login-subtitle{color:var(--color-text-muted);font-size:.875rem;font-weight:400}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column}.forgot-password-link{background:none;border:none;color:var(--color-text-muted);font-size:.85rem;cursor:pointer;text-align:center;padding:4px;transition:color .2s}.forgot-password-link:hover{color:var(--color-text);text-decoration:underline}.back-to-login{background:none;border:none;color:var(--color-text-muted);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;padding:4px;transition:color .2s}.back-to-login:hover{color:var(--color-text)}.success-message{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#22c55e;padding:12px 16px;border-radius:var(--radius-sm);font-size:.85rem;line-height:1.5}@media (max-width: 480px){.login-card{padding:var(--spacing-xl)}.login-title{font-size:1.75rem}}.tool-navigation{position:fixed;bottom:max(24px,env(safe-area-inset-bottom,24px));right:max(24px,env(safe-area-inset-right,24px));z-index:1000}.tool-nav-trigger{width:60px;height:60px;border-radius:18px;background:linear-gradient(145deg,#26262af2,#16161afa);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .35s cubic-bezier(.34,1.56,.64,1);box-shadow:0 8px 32px #0006,0 0 0 1px #ffffff08,inset 0 1px #ffffff14;position:relative;overflow:hidden}.tool-nav-trigger:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:18px;background:linear-gradient(135deg,#a78bfa,#8b5cf6 50%,transparent 80%);opacity:.12;transition:opacity .3s ease}.tool-nav-trigger:hover{transform:scale(1.06) translateY(-2px);box-shadow:0 12px 40px #00000080,0 0 24px #a78bfa26}.tool-nav-trigger:hover:before{opacity:.2}.tool-nav-trigger.open{border-radius:50%;background:linear-gradient(145deg,#ef4444e6,#dc2626f2)}.tool-nav-trigger.open:before{opacity:0}.hamburger-icon{width:22px;height:16px;display:flex;flex-direction:column;justify-content:space-between;position:relative}.hamburger-line{display:block;width:100%;height:2.5px;background:linear-gradient(90deg,#fffffff2,#fffc);border-radius:2px;transition:all .35s cubic-bezier(.68,-.6,.32,1.6);transform-origin:center;box-shadow:0 0 6px #a78bfa4d}.hamburger-line:nth-child(1){width:100%}.hamburger-line:nth-child(2){width:70%;margin-left:auto}.hamburger-line:nth-child(3){width:85%}.tool-nav-trigger:hover .hamburger-line{width:100%;box-shadow:0 0 10px #a78bfa80}.tool-nav-trigger.open .hamburger-line{background:#fff;box-shadow:none}.tool-nav-trigger.open .hamburger-line:nth-child(1){width:100%;transform:translateY(6.75px) rotate(45deg)}.tool-nav-trigger.open .hamburger-line:nth-child(2){opacity:0;transform:scaleX(0)}.tool-nav-trigger.open .hamburger-line:nth-child(3){width:100%;transform:translateY(-6.75px) rotate(-45deg)}.tool-nav-panel{position:absolute;bottom:80px;right:0;width:clamp(320px,34vw,520px);max-width:calc(100vw - 48px);background:linear-gradient(160deg,#1a1a1afa,#101010fc);border-radius:24px;border:1px solid rgba(255,255,255,.08);box-shadow:0 24px 80px #0009,0 0 0 1px #ffffff0d,inset 0 1px #ffffff1a;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);opacity:0;visibility:hidden;transform:translateY(20px) scale(.95);transform-origin:bottom right;transition:all .35s cubic-bezier(.34,1.56,.64,1);overflow:hidden}@media (max-width: 768px){.tool-nav-panel{width:calc(100vw - 32px);max-width:460px;bottom:72px}}.tool-nav-panel.open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.tool-nav-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:120px;background:radial-gradient(ellipse at top,rgba(147,51,234,.15),transparent);pointer-events:none}.tool-nav-header{padding:20px 24px 12px;display:flex;align-items:baseline;gap:8px;position:relative}.tool-nav-title{font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,#fff,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.tool-nav-subtitle{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em}.tool-nav-grid{padding:8px 0 16px;display:flex;gap:12px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-x;scrollbar-width:none;-ms-overflow-style:none}.tool-nav-grid::-webkit-scrollbar{display:none}.tool-nav-spacer{flex:0 0 15px;min-width:15px;pointer-events:none}.tool-nav-item{display:flex;flex-direction:column;align-items:center;padding:20px 16px 16px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:16px;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;flex:0 0 auto;min-width:120px;max-width:140px}.tool-nav-item:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center top,var(--tool-color),transparent 70%);opacity:0;transition:opacity .3s ease}.tool-nav-item:hover{background:#ffffff0f;border-color:#ffffff1f;transform:translateY(-4px)}.tool-nav-item:hover:before{opacity:.15}.tool-nav-item.active{background:#ffffff14;border-color:var(--tool-color);box-shadow:0 0 20px rgba(var(--tool-color-rgb),.2),inset 0 0 20px rgba(var(--tool-color-rgb),.05)}.tool-nav-item.active:before{opacity:.2}.tool-nav-icon-wrapper{position:relative;width:56px;height:56px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.tool-nav-icon-bg{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;background:linear-gradient(135deg,var(--tool-color),transparent);opacity:.15;transition:all .3s ease}.tool-nav-item:hover .tool-nav-icon-bg{opacity:.25;transform:scale(1.1)}.tool-nav-item.active .tool-nav-icon-bg{opacity:.3}.tool-nav-icon{position:relative;color:var(--tool-color);transition:all .3s ease;filter:drop-shadow(0 0 8px var(--tool-color))}.tool-nav-item:hover .tool-nav-icon{transform:scale(1.1)}.tool-nav-name{font-size:.875rem;font-weight:600;color:var(--color-text);position:relative;transition:color .3s ease}.tool-nav-item.active .tool-nav-name{color:var(--tool-color)}.tool-nav-active-indicator{position:absolute;bottom:8px;left:50%;transform:translate(-50%);width:20px;height:3px;background:var(--tool-color);border-radius:2px;box-shadow:0 0 8px var(--tool-color)}.tool-nav-footer{padding:12px 24px;border-top:1px solid rgba(255,255,255,.06);font-size:.75rem;color:var(--color-text-muted);text-align:center}.tool-nav-footer strong{color:var(--color-text-secondary)}.tool-nav-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:all .3s ease;z-index:-1}.tool-nav-backdrop.open{opacity:1;visibility:visible}@media (max-width: 480px){.tool-navigation{bottom:max(16px,env(safe-area-inset-bottom,16px));right:max(16px,env(safe-area-inset-right,16px))}.tool-nav-trigger{width:54px;height:54px;border-radius:16px}.hamburger-icon{width:20px;height:14px}.hamburger-line{height:2px}.tool-nav-trigger.open .hamburger-line:nth-child(1){transform:translateY(6px) rotate(45deg)}.tool-nav-trigger.open .hamburger-line:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.tool-nav-panel{width:calc(100vw - 32px);bottom:70px;right:0}.tool-nav-grid{padding:8px 0 16px;gap:10px}.tool-nav-spacer{flex:0 0 12px;min-width:12px}.tool-nav-item{padding:14px 12px 12px;min-width:100px;max-width:120px}.tool-nav-icon-wrapper{width:44px;height:44px;margin-bottom:8px}.tool-nav-icon{width:26px;height:26px}.tool-nav-name{font-size:.8125rem}}.tool-nav-panel.open .tool-nav-item{animation:slideIn .4s ease backwards}.tool-nav-panel.open .tool-nav-item:nth-child(1){animation-delay:.05s}.tool-nav-panel.open .tool-nav-item:nth-child(2){animation-delay:.1s}.tool-nav-panel.open .tool-nav-item:nth-child(3){animation-delay:.15s}.tool-nav-panel.open .tool-nav-item:nth-child(4){animation-delay:.2s}.tool-nav-panel.open .tool-nav-item:nth-child(5){animation-delay:.25s}.tool-nav-panel.open .tool-nav-item:nth-child(6){animation-delay:.3s}.tool-nav-panel.open .tool-nav-item:nth-child(7){animation-delay:.35s}.tool-nav-panel.open .tool-nav-item:nth-child(8){animation-delay:.4s}@keyframes slideIn{0%{opacity:0;transform:translate(-20px) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}.app-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;padding-top:max(16px,env(safe-area-inset-top));background:#0000004d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;z-index:50;margin-bottom:1rem}.app-header-left{display:flex;align-items:center;gap:12px}.app-header-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.app-header-title{font-size:1.4rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.app-header-right{display:flex;align-items:center;gap:8px}.app-header-chat-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.1);color:var(--color-text-muted);width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;position:relative}.app-header-chat-btn:hover{background:#ffffff1f;color:var(--color-text)}.app-header-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--color-danger);color:#fff;font-size:.625rem;font-weight:600;display:flex;align-items:center;justify-content:center}.app-header-settings-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.1);color:var(--color-text-muted);width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.app-header-settings-btn:hover{background:#ffffff1f;color:var(--color-text)}.app-header-logout-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.1);color:var(--color-text-muted);padding:8px 12px;border-radius:var(--radius-sm);font-size:.8rem;display:flex;align-items:center;gap:6px;transition:all .2s;cursor:pointer}.app-header-logout-btn:hover{background:#ffffff1f;color:var(--color-text)}@media (max-width: 768px){.app-header-logout-btn span{display:none}}.dash-subtitle{font-size:.875rem;color:var(--color-text-muted);margin-top:.25rem}.dash-container{display:flex;flex-direction:column;gap:1.25rem}.dash-stats-row{display:flex;gap:.65rem}.dash-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.85rem .5rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;color:var(--color-text)}.dash-stat:hover{background:#ffffff0f;border-color:#ffffff1f;transform:translateY(-2px)}.dash-stat-icon{opacity:.7}.dash-stat-icon--coins{color:#a855f7}.dash-stat-icon--streak{color:#f59e0b}.dash-stat-icon--messages{color:#3b82f6}.dash-stat-value{font-size:1.5rem;font-weight:700;line-height:1;letter-spacing:-.02em}.dash-stat-label{font-size:.72rem;color:var(--color-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.dash-grid{display:grid;grid-template-columns:1fr;gap:.75rem}@media (min-width: 640px){.dash-grid{grid-template-columns:repeat(2,1fr)}.dash-widget--today{grid-column:1 / -1}}@media (min-width: 1024px){.dash-grid{grid-template-columns:repeat(3,1fr)}.dash-widget--today{grid-column:1 / -1}}.dash-widget{background:#1a1a1a99;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-md);padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.75rem;transition:all .22s ease;text-align:left;width:100%;color:var(--color-text)}.dash-widget--clickable{cursor:pointer}.dash-widget--clickable:hover{background:#1a1a1acc;border-color:#ffffff1f;transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.dash-widget-header{display:flex;align-items:center;gap:.5rem}.dash-widget-title{font-size:.88rem;font-weight:700;margin:0;flex:1}.dash-widget-icon{opacity:.8}.dash-widget-icon--coins{color:#a855f7}.dash-widget-icon--fitness{color:#34e85e}.dash-widget-icon--dinner{color:#f97316}.dash-widget-icon--movies{color:#e50914}.dash-widget-arrow{color:var(--color-text-muted);opacity:.5;transition:opacity .15s ease}.dash-widget--clickable:hover .dash-widget-arrow{opacity:1}.dash-today-sections{display:flex;flex-direction:column;gap:.5rem}.dash-today-item{display:flex;align-items:center;gap:.7rem;padding:.65rem .75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);cursor:pointer;transition:all .15s ease;color:var(--color-text);width:100%;text-align:left}.dash-today-item:hover{background:#ffffff0f;border-color:#ffffff1f}.dash-today-item-icon{opacity:.7}.dash-today-item-icon--fitness{color:#34e85e}.dash-today-item-icon--dinner{color:#f97316}.dash-today-item-content{flex:1;min-width:0}.dash-today-item-label{font-size:.72rem;color:var(--color-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.03em}.dash-today-item-value{font-size:.9rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-today-item-arrow{color:var(--color-text-muted);opacity:.4;flex-shrink:0}.dash-today-empty{color:var(--color-text-muted);font-size:.85rem;padding:.5rem 0}@media (min-width: 640px){.dash-today-sections{flex-direction:row}.dash-today-item{flex:1}}.dash-coins-body{display:flex;align-items:baseline;gap:.75rem}.dash-coins-balance{display:flex;align-items:baseline;gap:.35rem}.dash-coins-amount{font-size:1.75rem;font-weight:800;line-height:1;letter-spacing:-.03em}.dash-coins-unit{font-size:.82rem;color:var(--color-text-muted);font-weight:500}.dash-coins-pending{display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;color:var(--color-warning);background:#f59e0b1a;padding:.2rem .5rem;border-radius:var(--radius-full)}.dash-coins-recent{display:flex;flex-direction:column;gap:.3rem;border-top:1px solid rgba(255,255,255,.06);padding-top:.6rem}.dash-coins-activity{display:flex;justify-content:space-between;align-items:center;font-size:.78rem}.dash-coins-activity-cat{color:var(--color-text-secondary)}.dash-coins-activity-status{font-weight:600;font-size:.72rem}.dash-coins-activity-status--confirmed{color:var(--color-success)}.dash-coins-activity-status--pending{color:var(--color-warning)}.dash-coins-activity-status--rejected{color:var(--color-danger)}.dash-fitness-stats{display:flex;gap:1rem}.dash-fitness-stat{display:flex;align-items:center;gap:.35rem}.dash-fitness-stat-icon{color:var(--color-text-muted);opacity:.6}.dash-fitness-stat-value{font-size:1.1rem;font-weight:700}.dash-fitness-stat-label{font-size:.72rem;color:var(--color-text-muted)}.dash-fitness-last{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;font-size:.78rem;border-top:1px solid rgba(255,255,255,.06);padding-top:.6rem}.dash-fitness-last-label{color:var(--color-text-muted)}.dash-fitness-last-name{font-weight:600;color:var(--color-text-secondary)}.dash-fitness-last-ago{color:var(--color-text-muted);margin-left:auto}.dash-dinner-body{display:flex;flex-direction:column}.dash-dinner-today-label{font-size:.72rem;color:var(--color-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.2rem}.dash-dinner-today-meal{font-size:1.05rem;font-weight:700}.dash-dinner-empty{color:var(--color-text-muted);font-size:.85rem}.dash-movies-body{display:flex;flex-direction:column;gap:.5rem}.dash-movies-stats{display:flex;gap:1.25rem}.dash-movies-stat{display:flex;align-items:baseline;gap:.3rem}.dash-movies-stat-value{font-size:1.25rem;font-weight:700}.dash-movies-stat-label{font-size:.75rem;color:var(--color-text-muted)}.dash-movies-recent{font-size:.78rem;color:var(--color-text-muted);border-top:1px solid rgba(255,255,255,.06);padding-top:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-release{background:#1a1a1a99;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-md);overflow:hidden}.dash-release-header{display:flex;align-items:center;gap:.45rem;width:100%;padding:.75rem 1rem;cursor:pointer;color:var(--color-text);background:transparent;border:none;transition:background .15s ease}.dash-release-header:hover{background:#ffffff08}.dash-release-icon{color:#a78bfa;opacity:.85;flex-shrink:0}.dash-release-title{font-size:.82rem;font-weight:700;flex:1;text-align:left}.dash-release-version{font-size:.7rem;color:var(--color-text-muted);font-weight:500;font-variant-numeric:tabular-nums}.dash-release-chevron{color:var(--color-text-muted);opacity:.5;flex-shrink:0;transition:transform .25s ease}.dash-release-chevron--open{transform:rotate(180deg)}.dash-release-body{padding:0 1rem .75rem}.dash-release-body:not(.dash-release-body--open) .dash-release-group+.dash-release-group{display:none}.dash-release-group{padding-top:.35rem}.dash-release-group+.dash-release-group{margin-top:.65rem;padding-top:.65rem;border-top:1px solid rgba(255,255,255,.05)}.dash-release-group-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}.dash-release-group-version{font-size:.72rem;font-weight:700;color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.dash-release-group-date{font-size:.68rem;color:var(--color-text-muted);font-variant-numeric:tabular-nums}.dash-release-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}.dash-release-entry{display:flex;align-items:flex-start;gap:.45rem;font-size:.78rem;line-height:1.4}.dash-release-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:.12rem .4rem;border-radius:var(--radius-full);flex-shrink:0;margin-top:.1rem;line-height:1.3}.dash-release-badge--feature{background:#a855f726;color:#c084fc}.dash-release-badge--app{background:#3b82f626;color:#60a5fa}.dash-release-badge--bugfix{background:#ef444426;color:#f87171}.dash-release-badge--improvement{background:#22c55e26;color:#4ade80}.dash-release-text{color:var(--color-text-secondary)}.admin-pending-banner{display:flex;align-items:center;gap:.5rem;padding:.6rem .9rem;background:#a855f714;border:1px solid rgba(168,85,247,.2);border-radius:var(--radius-md);color:#c084fc;font-size:.82rem;font-weight:600}.dash-widget--admin{border-color:#a855f726}.dash-widget-icon--admin{color:#a855f7}.admin-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.4rem;height:1.4rem;padding:0 .4rem;border-radius:var(--radius-full);background:#a855f726;color:#c084fc;font-size:.72rem;font-weight:700}.admin-pending-list{display:flex;flex-direction:column;gap:.5rem;max-height:280px;overflow-y:auto}.admin-pending-item{display:flex;align-items:center;gap:.6rem;padding:.55rem .65rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);transition:background .15s ease}.admin-pending-item:hover{background:#ffffff0d}.admin-pending-item-info{flex:1;min-width:0}.admin-pending-item-category{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-pending-item-meta{font-size:.72rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-pending-item-actions{display:flex;gap:.3rem;flex-shrink:0}.admin-action-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:var(--radius);border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text-muted);cursor:pointer;transition:all .15s ease}.admin-action-btn:hover{border-color:#ffffff26}.admin-action-btn--confirm:hover{color:var(--color-success);background:#34e85e1a;border-color:#34e85e40}.admin-action-btn--reject:hover{color:var(--color-warning);background:#f59e0b1a;border-color:#f59e0b40}.admin-action-btn--delete:hover{color:var(--color-danger);background:#ef44441a;border-color:#ef444440}.admin-coins-body{display:flex;flex-direction:column;gap:.75rem}.admin-user-selector{width:100%}.admin-select{width:100%;padding:.5rem 1.8rem .5rem .7rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);color:var(--color-text);font-size:.85rem;font-weight:500;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:border-color .15s ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center}.admin-select:focus{outline:none;border-color:#a855f766}.admin-coins-balance{display:flex;align-items:baseline;gap:.35rem}.admin-coins-amount{font-size:1.5rem;font-weight:800;line-height:1;letter-spacing:-.02em}.admin-coins-label{font-size:.78rem;color:var(--color-text-muted);font-weight:500}.admin-redeem{display:flex;flex-direction:column;gap:.5rem;border-top:1px solid rgba(255,255,255,.06);padding-top:.65rem}.admin-redeem-controls{display:flex;align-items:center;gap:.5rem;justify-content:center}.admin-redeem-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:var(--radius);border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--color-text);font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s ease}.admin-redeem-btn:hover:not(:disabled){background:#ffffff14;border-color:#ffffff2e}.admin-redeem-btn:disabled{opacity:.3;cursor:not-allowed}.admin-redeem-value{font-size:1.1rem;font-weight:700;min-width:3rem;text-align:center}.admin-redeem-submit{width:100%;padding:.55rem;background:#a855f71f;border:1px solid rgba(168,85,247,.25);border-radius:var(--radius);color:#c084fc;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s ease}.admin-redeem-submit:hover:not(:disabled){background:#a855f733;border-color:#a855f766}.admin-redeem-submit:disabled{opacity:.35;cursor:not-allowed}.admin-activities-list{display:flex;flex-direction:column;gap:.4rem;max-height:300px;overflow-y:auto}.admin-activities-empty{font-size:.82rem;color:var(--color-text-muted);padding:.5rem 0}.admin-activity-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.45rem .6rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius)}.admin-activity-info{display:flex;flex-direction:column;min-width:0}.admin-activity-category{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-activity-meta{font-size:.7rem;color:var(--color-text-muted)}.admin-activity-right{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.admin-activity-status{font-size:.7rem;font-weight:600;padding:.1rem .4rem;border-radius:var(--radius-full)}.admin-activity-status--confirmed{color:var(--color-success);background:#34e85e1a}.admin-activity-status--pending{color:#f59e0b;background:#f59e0b1a}.admin-activity-status--rejected{color:var(--color-danger);background:#ef44441a}.admin-activity-date{font-size:.65rem;color:var(--color-text-muted);margin-top:.15rem}.food-icon-picker{position:relative;width:100%}.icon-picker-trigger{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md);background:#ffffff08;border:2px solid rgba(255,255,255,.1);border-radius:var(--radius);cursor:pointer;transition:all .2s ease;color:var(--color-text)}.icon-picker-trigger:hover{background:#ffffff0f;border-color:#fff3}.icon-picker-trigger.open{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e926}.selected-icon-name{font-size:.9375rem;font-weight:500;color:var(--color-text-secondary)}.icon-picker-dropdown{margin-top:var(--spacing-sm);background:#141414fa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);box-shadow:0 8px 32px #0000004d,0 0 0 1px #ffffff0d;overflow:hidden;animation:dropdownSlide .2s ease}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.icon-search-wrapper{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.06);background:#0003}.search-icon{color:var(--color-text-muted);flex-shrink:0}.icon-search-input{flex:1;background:transparent;border:none;outline:none;font-size:.9375rem;color:var(--color-text)}.icon-search-input::placeholder{color:var(--color-text-muted)}.clear-search{display:flex;align-items:center;justify-content:center;padding:4px;background:#ffffff1a;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all .2s ease}.clear-search:hover{background:#ef444433;color:var(--color-danger)}.icon-results-info{padding:var(--spacing-sm) var(--spacing-md);font-size:.75rem;color:var(--color-text-muted);border-bottom:1px solid rgba(255,255,255,.03)}.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:var(--spacing-sm);padding:var(--spacing-md)}.icon-grid-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background:#ffffff05;border:2px solid transparent;border-radius:var(--radius);cursor:pointer;transition:all .2s ease}.icon-grid-item:hover{background:#ffffff0f;border-color:#0ea5e94d;transform:scale(1.02)}.icon-grid-item.selected{background:#0ea5e926;border-color:#0ea5e9;box-shadow:0 0 12px #0ea5e933}.icon-grid-label{font-size:.6875rem;color:var(--color-text-muted);text-align:center;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon-grid-item:hover .icon-grid-label,.icon-grid-item.selected .icon-grid-label{color:var(--color-text)}.no-results{padding:var(--spacing-xl);text-align:center;color:var(--color-text-muted);font-size:.875rem}.food-icon-picker.small .icon-picker-trigger{padding:var(--spacing-sm);gap:var(--spacing-sm)}.food-icon-picker.small .selected-icon-name{font-size:.8125rem}.food-icon-picker.small .icon-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}.food-icon-picker.small .icon-grid-item{padding:6px}.food-icon-picker.small .icon-grid-label{font-size:.625rem}@media (max-width: 768px){.icon-grid{grid-template-columns:repeat(auto-fill,minmax(75px,1fr))}.icon-grid-item{padding:var(--spacing-xs)}}.admin-page{min-height:100vh;padding-bottom:100px}.admin-container{display:flex;flex-direction:column;gap:1.25rem}.admin-tab-bar{display:flex;gap:4px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-md);padding:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.admin-tab-bar::-webkit-scrollbar{display:none}.admin-tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 14px;border:none;border-radius:calc(var(--radius-md) - 2px);background:transparent;color:var(--color-text-muted);font-size:.82rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-width:0}.admin-tab-btn:hover{color:var(--color-text);background:#ffffff0d}.admin-tab-btn.active{color:#fff;background:#0ea5e933;box-shadow:0 1px 4px #0ea5e926}.admin-sections{display:flex;flex-direction:column;gap:1rem}.admin-card{max-width:720px}.admin-card:hover{transform:none}.admin-section-header{display:flex;align-items:center;gap:10px;color:var(--color-text);margin-bottom:1rem}.admin-section-header h2{font-size:1.05rem;font-weight:600;margin:0;flex:1}.admin-count{background:#ffffff14;color:var(--color-text-muted);font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);min-width:22px;text-align:center}.admin-form{display:flex;flex-direction:column;gap:.85rem}.admin-form--inline .admin-form-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem}.admin-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}@media (max-width: 540px){.admin-form-grid{grid-template-columns:1fr}}.admin-field{display:flex;flex-direction:column;gap:5px}.admin-label{font-size:.78rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.admin-form-submit{align-self:flex-start;display:flex;align-items:center;gap:6px}.admin-hint{color:var(--color-text-muted);font-size:.82rem;margin:0 0 .5rem;line-height:1.5}.admin-user-list{display:flex;flex-direction:column;gap:6px}.admin-user-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:#ffffff06;border:1px solid rgba(255,255,255,.05);border-radius:var(--radius);transition:all .15s ease}.admin-user-row:hover{background:#ffffff0d;border-color:#ffffff1a}.admin-user-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.admin-user-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#0ea5e940,#0ea5e914);color:#0ea5e9;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}.admin-user-details{min-width:0}.admin-user-name{font-weight:600;font-size:.92rem;color:var(--color-text);line-height:1.3}.admin-user-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:3px}.admin-badge{font-size:.65rem;font-weight:700;padding:1px 7px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;line-height:1.6}.admin-badge--admin{background:#a855f733;color:#c084fc}.admin-badge--user{background:#ffffff14;color:var(--color-text-muted)}.admin-badge--fsk-0{background:#ffffffd9;color:#000}.admin-badge--fsk-6{background:#f5c518d9;color:#000}.admin-badge--fsk-12{background:#22c55ed9;color:#fff}.admin-badge--fsk-16{background:#3b82f6d9;color:#fff}.admin-badge--fsk-18{background:#ef4444d9;color:#fff}.admin-user-date{font-size:.7rem;color:var(--color-text-muted);opacity:.7}.admin-user-controls{display:flex;align-items:center;gap:4px;flex-shrink:0}.admin-fsk-select{width:76px;font-size:.72rem;padding:5px 6px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;transition:border-color .15s}.admin-fsk-select:focus{border-color:#0ea5e9;outline:none}.admin-icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all .15s ease}.admin-icon-btn:hover{background:#ffffff1a;border-color:#ffffff26;color:var(--color-text)}.admin-icon-btn--active{background:#2ecc7126;border-color:#2ecc714d;color:#2ecc71}.admin-icon-btn--active:hover{background:#2ecc7140;border-color:#2ecc7180}.admin-icon-btn--danger:hover{background:#ef444426;border-color:#ef44444d;color:#ef4444}.admin-user-edit{width:100%;display:flex;flex-direction:column;gap:10px}.admin-user-edit-fields{display:grid;grid-template-columns:1fr auto;gap:8px}.admin-user-edit-fields select{width:120px}.admin-user-edit-actions{display:flex;gap:6px}.admin-meal-list{display:flex;flex-direction:column;gap:6px}.admin-meal-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#ffffff06;border:1px solid rgba(255,255,255,.05);border-radius:var(--radius);transition:all .15s ease}.admin-meal-row:hover{background:#ffffff0d;border-color:#ffffff1a}.admin-meal-icon{flex-shrink:0}.admin-meal-info{flex:1;min-width:0}.admin-meal-name{font-weight:600;font-size:.92rem;color:var(--color-text)}.admin-meal-actions{display:flex;gap:4px;flex-shrink:0}.admin-meal-edit{display:flex;flex-direction:column;gap:8px;width:100%}.admin-meal-edit-actions{display:flex;gap:6px}.admin-smtp-test{display:flex;flex-direction:column;gap:10px}.admin-smtp-test-row{display:flex;gap:8px;align-items:center}.admin-smtp-test-row .input{flex:1}.admin-smtp-test-row .btn{display:flex;align-items:center;gap:6px;white-space:nowrap}.admin-smtp-result{padding:10px 14px;border-radius:var(--radius-sm);font-size:.82rem;line-height:1.4}.admin-smtp-result--ok{background:#22c55e1a;border:1px solid rgba(34,197,94,.25);color:#22c55e}.admin-smtp-result--err{background:#ef44441a;border:1px solid rgba(239,68,68,.25);color:#ef4444}.admin-btn--saved{background:#22c55e!important;border-color:#22c55e!important}.admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.admin-modal{background:var(--color-bg);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #00000080;max-width:420px;width:100%;overflow:hidden}.admin-modal-header{display:flex;align-items:center;gap:10px;padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.08);color:var(--color-text)}.admin-modal-header h3{margin:0;font-size:1.05rem;font-weight:600;flex:1}.admin-modal-close{background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .15s ease}.admin-modal-close:hover{background:#ffffff1a;color:var(--color-text)}.admin-modal-body{padding:20px;display:flex;flex-direction:column;gap:12px}.admin-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid rgba(255,255,255,.08)}.admin-modal-footer .btn{display:flex;align-items:center;gap:6px}.admin-group-list{display:flex;flex-direction:column;gap:10px}.admin-group-card{padding:14px 16px;background:#ffffff06;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);transition:all .15s ease}.admin-group-card:hover{border-color:#ffffff1a}.admin-group-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.admin-group-name{font-weight:700;font-size:1rem;color:var(--color-text)}.admin-group-actions{display:flex;gap:4px;flex-shrink:0}.admin-group-edit-row{display:flex;align-items:center;gap:8px;width:100%}.admin-group-edit-row .input{flex:1}.admin-group-members{display:flex;flex-direction:column;gap:8px}.admin-group-members-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-muted)}.admin-group-member-chips{display:flex;flex-wrap:wrap;gap:6px}.admin-member-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px 3px 3px;background:#0ea5e91a;border:1px solid rgba(14,165,233,.2);border-radius:var(--radius-full);font-size:.78rem;font-weight:500;color:var(--color-text)}.admin-member-chip-avatar{width:22px;height:22px;border-radius:50%;background:#0ea5e940;color:#0ea5e9;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.7rem}.admin-group-member-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.admin-member-select-list{display:flex;flex-direction:column;gap:4px;max-height:340px;overflow-y:auto}.admin-member-select-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#ffffff06;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);cursor:pointer;transition:all .15s ease;text-align:left;color:var(--color-text);width:100%}.admin-member-select-item:hover{background:#ffffff0f;border-color:#ffffff1f}.admin-member-select-item.selected{background:#0ea5e914;border-color:#0ea5e940}.admin-member-select-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#0ea5e940,#0ea5e914);color:#0ea5e9;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.admin-member-select-info{flex:1;min-width:0;display:flex;flex-direction:column}.admin-member-select-name{font-weight:600;font-size:.9rem}.admin-member-select-hint{font-size:.72rem;color:var(--color-text-muted);opacity:.7}.admin-member-select-check{width:24px;height:24px;border-radius:6px;border:2px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease}.admin-member-select-check.checked{background:#0ea5e9;border-color:#0ea5e9;color:#fff}.admin-app-overview{display:flex;flex-direction:column;gap:4px}.admin-app-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:var(--radius)}.admin-app-info{display:flex;align-items:center;gap:10px}.admin-app-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:#ffffff0a}.admin-app-name{font-weight:600;font-size:.88rem;color:var(--color-text)}.admin-app-type{font-size:.7rem;font-weight:700;padding:2px 10px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em}.admin-app-type--privat{background:#6366f126;color:#818cf8}.admin-app-type--gruppe{background:#f9731626;color:#fb923c}.admin-app-type--global{background:#34e85e26;color:#34e85e}.admin-badge--group{background:#f9731633;color:#fb923c}.admin-fitness{display:flex;flex-direction:column}.admin-fitness-tabs{display:flex;gap:4px;margin-top:.75rem}.admin-fitness-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);background:transparent;color:var(--color-text-muted);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s ease}.admin-fitness-tab:hover{background:#ffffff0d;color:var(--color-text)}.admin-fitness-tab.active{background:#0ea5e926;border-color:#0ea5e94d;color:#0ea5e9}.admin-exercise-type{font-size:.7rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}@media (max-width: 640px){.admin-tab-btn span{display:none}.admin-tab-btn{padding:10px 16px}.admin-user-row{flex-direction:column;align-items:flex-start;gap:10px}.admin-user-controls{width:100%;flex-wrap:wrap}.admin-fsk-select{flex:0 0 auto}.admin-user-edit-fields{grid-template-columns:1fr}.admin-user-edit-fields select{width:100%}.admin-meal-row{flex-wrap:wrap}.admin-meal-actions{width:100%;justify-content:flex-end}.admin-smtp-test-row{flex-direction:column}.admin-smtp-test-row .btn{width:100%;justify-content:center}}@media (max-width: 400px){.admin-form--inline .admin-form-fields{grid-template-columns:1fr}}.touch-turn-wheel-container{position:relative;display:flex;justify-content:center;align-items:center;padding:var(--spacing-md);margin:var(--spacing-sm) 0}.touch-turn-wheel{position:relative;width:280px;height:280px;cursor:grab;user-select:none;-webkit-user-select:none;touch-action:none}.touch-turn-wheel:active{cursor:grabbing}.wheel-ring{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;background:#1a1a1acc;border:2px solid rgba(255,255,255,.1);box-shadow:inset 0 0 20px #00000080,0 0 30px #0000004d;z-index:1}.wheel-grip{position:absolute;top:50%;left:50%;width:3px;height:16px;background:#fffc;transform-origin:center center;margin-left:-1.5px;margin-top:-8px;border-radius:1.5px;box-shadow:0 0 4px #fff9,inset 0 0 2px #ffffff4d;z-index:5;transition:background .2s ease,box-shadow .2s ease}.wheel-grip.active{background:var(--color-primary);box-shadow:0 0 6px var(--color-primary),0 0 12px #9333ea66,inset 0 0 2px #ffffff4d}.wheel-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:180px;height:180px;border-radius:50%;background:#1a1a1ae6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.wheel-value{font-size:3rem;font-weight:700;color:var(--color-text);line-height:1;margin-bottom:var(--spacing-xs);z-index:11;position:relative}.wheel-label{font-size:.875rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;z-index:11;position:relative}.wheel-center-clickable{cursor:pointer;transition:all .3s ease}.wheel-center-clickable:hover{background:#9333ea33;box-shadow:0 0 30px #9333ea4d}.wheel-center-clickable:active{transform:translate(-50%,-50%) scale(.95)}.wheel-go{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);color:var(--color-primary);font-size:1.5rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;pointer-events:none}.wheel-go svg{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.wheel-seconds{font-size:1.5rem;font-weight:600;color:var(--color-text-secondary);line-height:1;margin-top:var(--spacing-xs);z-index:11;position:relative}.wheel-coins{font-size:.875rem;font-weight:600;color:var(--color-secondary);margin-top:var(--spacing-sm);z-index:11;position:relative;padding:4px 12px;background:#10b98126;border-radius:20px;border:1px solid rgba(16,185,129,.3)}@media (max-width: 768px){.touch-turn-wheel{width:240px;height:240px}.wheel-center{width:150px;height:150px}.wheel-value{font-size:2.5rem}.wheel-grip{margin-top:-5px;height:12px;width:2.5px}}@media (max-width: 480px){.touch-turn-wheel{width:200px;height:200px}.wheel-center{width:130px;height:130px}.wheel-value{font-size:2rem}.wheel-grip{margin-top:-4px;height:10px;width:2px}}.growth-coins-page{min-height:100vh;padding-bottom:100px}.page-title h1{margin:0}.growth-coins-layout{display:grid;grid-template-columns:1fr;gap:var(--spacing-xl)}@media (min-width: 1024px){.growth-coins-layout{grid-template-columns:2fr 1fr}}.growth-coins-main,.growth-coins-sidebar{display:flex;flex-direction:column;gap:var(--spacing-lg)}.balance-display{text-align:center;padding:var(--spacing-lg)}.balance-label{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.balance-value{font-size:2.5rem;font-weight:600;color:var(--color-text);letter-spacing:-.02em}.category-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-lg)}.category-btn{padding:var(--spacing-lg);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-md);background:#1a1a1a66;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);transition:all .3s ease;cursor:pointer;min-height:110px;position:relative;overflow:hidden}.category-btn:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at center,rgba(147,51,234,.1),transparent);opacity:0;transition:opacity .3s ease}.category-btn:hover{border-color:#9333ea4d;background:#1a1a1a99;transform:translateY(-3px);box-shadow:0 8px 20px #00000080,0 0 20px #9333ea1a}.category-btn:hover:before{opacity:1}.category-btn.active{border-color:var(--color-primary);background:#9333ea26;box-shadow:0 0 20px #9333ea33}.category-btn.active:before{opacity:1}.category-icon{color:var(--color-text-secondary);transition:all .3s ease;position:relative;z-index:1}.category-btn:hover .category-icon,.category-btn.active .category-icon{color:var(--color-primary)}.category-label{font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);text-align:center;position:relative;z-index:1}.category-btn.active .category-label{color:var(--color-text)}.time-wheel-section{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-md) 0}.time-display{text-align:center}.time-value{font-size:2.5rem;font-weight:600;color:var(--color-text);line-height:1;letter-spacing:-.02em}.time-label{font-size:.875rem;color:var(--color-text-muted);margin-top:var(--spacing-sm);font-weight:500}.coins-preview{font-size:1rem;color:var(--color-secondary);font-weight:500;margin-top:var(--spacing-sm)}.activities-list{display:flex;flex-direction:column;gap:var(--spacing-md);max-height:600px;overflow-y:auto}.activity-item{padding:var(--spacing-md);background:#1116;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:var(--radius);border:1px solid rgba(255,255,255,.05);transition:all .3s ease}.activity-item:hover{background:#1a1a1a99;border-color:#ffffff1a}.activity-item.activity-redemption{border-left:3px solid #f472b6}.activity-item.activity-redemption .activity-category{color:#f472b6}.activity-category{font-weight:500;color:var(--color-text);font-size:.875rem}.activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.activity-meta{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:.25rem}.activity-date{font-size:.75rem;color:var(--color-text-muted)}@media (max-width: 768px){.balance-value,.time-value{font-size:2rem}.category-selector{grid-template-columns:repeat(2,1fr)}}.messages-container{display:flex;height:100vh;height:100dvh;background:var(--color-bg);overflow:hidden}.messages-loading{display:flex;justify-content:center;align-items:center;height:100vh;height:100dvh}.messages-sidebar{width:340px;min-width:340px;background:#111111f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;position:relative;z-index:10}.sidebar-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);padding-top:calc(env(safe-area-inset-top,0px) + var(--spacing-lg));border-bottom:1px solid rgba(255,255,255,.06);background:#1a1a1acc}.sidebar-header h1{flex:1;font-size:1.25rem;font-weight:600;color:var(--color-text);letter-spacing:-.02em}.back-btn,.new-chat-btn{width:40px;height:40px;border-radius:var(--radius);background:#ffffff0d;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s ease}.back-btn:hover,.new-chat-btn:hover{background:#9333ea33;color:var(--color-primary-light)}.conversations-list{flex:1;overflow-y:auto;padding:var(--spacing-sm)}.no-conversations{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:var(--spacing-xl);text-align:center;color:var(--color-text-muted)}.no-conversations svg{opacity:.3;margin-bottom:var(--spacing-lg)}.no-conversations p{margin-bottom:var(--spacing-lg)}.conversation-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md);border-radius:var(--radius-md);background:transparent;text-align:left;transition:all .2s ease;margin-bottom:2px;cursor:pointer;position:relative}.conversation-item:hover{background:#ffffff0d}.conversation-item.active{background:#9333ea26;border:1px solid rgba(147,51,234,.3)}.conv-delete-btn{position:absolute;right:var(--spacing-sm);top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:var(--radius);background:transparent;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s ease}.conversation-item:hover .conv-delete-btn{opacity:1}.conv-delete-btn:hover{background:#ef444433;color:#ef4444}.conv-avatar,.chat-avatar,.user-avatar{width:48px;height:48px;min-width:48px;border-radius:50%;background:linear-gradient(135deg,#9333ea4d,#3b82f64d);display:flex;align-items:center;justify-content:center;color:var(--color-text);position:relative}.chat-avatar{width:40px;height:40px;min-width:40px}.user-avatar{width:44px;height:44px;min-width:44px}.online-dot{position:absolute;bottom:2px;right:2px;width:12px;height:12px;border-radius:50%;background:#22c55e;border:2px solid var(--color-bg-secondary);animation:pulse-green 2s infinite}@keyframes pulse-green{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 4px #22c55e00}}.conv-info{flex:1;min-width:0}.conv-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.conv-name{font-weight:500;color:var(--color-text);font-size:.9375rem}.conv-time{font-size:.75rem;color:var(--color-text-muted)}.conv-preview{display:flex;align-items:center;gap:var(--spacing-sm)}.preview-text{flex:1;font-size:.8125rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-empty{font-size:.8125rem;color:var(--color-text-disabled);font-style:italic}.unread-badge{min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--color-primary);color:#fff;font-size:.6875rem;font-weight:600;display:flex;align-items:center;justify-content:center}.new-chat-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.search-box{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);margin:var(--spacing-md);background:#ffffff0d;border-radius:var(--radius);border:1px solid rgba(255,255,255,.08)}.search-box svg{color:var(--color-text-muted)}.search-box input{flex:1;background:transparent;border:none;color:var(--color-text);font-size:.9375rem}.search-box input::placeholder{color:var(--color-text-disabled)}.users-list{flex:1;overflow-y:auto;padding:0 var(--spacing-sm)}.no-users{text-align:center;padding:var(--spacing-xl);color:var(--color-text-muted)}.user-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md);border-radius:var(--radius);background:transparent;text-align:left;transition:all .2s ease}.user-item:hover{background:#ffffff0d}.user-name{flex:1;font-weight:500;color:var(--color-text)}.chevron{color:var(--color-text-muted);transition:transform .2s ease}.user-item:hover .chevron{transform:translate(4px);color:var(--color-primary-light)}.cancel-new-chat{margin:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius);background:#ffffff0d;color:var(--color-text-secondary);font-weight:500;transition:all .2s ease}.cancel-new-chat:hover{background:#ffffff1a}.chat-area{flex:1;display:flex;flex-direction:column;background:var(--color-bg);min-width:0}.no-chat-selected{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-xl);color:var(--color-text-muted)}.no-chat-selected svg{opacity:.2;margin-bottom:var(--spacing-lg);color:var(--color-primary)}.no-chat-selected h2{font-size:1.25rem;color:var(--color-text);margin-bottom:var(--spacing-sm)}.chat-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);padding-top:calc(env(safe-area-inset-top,0px) + var(--spacing-md));background:#111111f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06)}.chat-header-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.chat-header-text h2{font-size:1rem;font-weight:600;color:var(--color-text);margin-bottom:2px}.online-status{font-size:.75rem;color:var(--color-text-muted)}.messages-list{flex:1;overflow-y:auto;padding:var(--spacing-lg);display:flex;flex-direction:column;gap:4px}.no-messages{flex:1;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.message{display:flex;align-items:flex-end;gap:var(--spacing-sm);max-width:80%}.message.own{align-self:flex-end;flex-direction:row-reverse}.message.other{align-self:flex-start}.message-avatar{width:32px;height:32px;min-width:32px;border-radius:50%;background:linear-gradient(135deg,#9333ea4d,#3b82f64d);display:flex;align-items:center;justify-content:center;color:var(--color-text);margin-bottom:20px}.message-avatar-placeholder{width:32px;min-width:32px}.message-content{display:flex;flex-direction:column;gap:4px}.message.own .message-content{align-items:flex-end}.message-bubble{padding:var(--spacing-sm) var(--spacing-md);border-radius:18px;max-width:100%;word-wrap:break-word}.message.own .message-bubble{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;border-bottom-right-radius:6px}.message.other .message-bubble{background:#ffffff14;color:var(--color-text);border-bottom-left-radius:6px}.message.last-in-group.own .message-bubble{border-bottom-right-radius:18px}.message.last-in-group.other .message-bubble{border-bottom-left-radius:18px}.message-bubble p{margin:0;font-size:.9375rem;line-height:1.4}.message-time{font-size:.6875rem;color:var(--color-text-disabled);padding:0 4px}.typing-indicator{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-muted);font-size:.8125rem}.typing-dots{display:flex;gap:4px}.typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--color-text-muted);animation:typing-bounce 1.4s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.message-input{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);padding-bottom:calc(env(safe-area-inset-bottom,0px) + var(--spacing-md));background:#111111f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.06)}.message-input input{flex:1;padding:var(--spacing-md) var(--spacing-lg);border-radius:24px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--color-text);font-size:.9375rem;transition:all .2s ease}.message-input input:focus{border-color:var(--color-primary);background:#9333ea1a;outline:none}.message-input input::placeholder{color:var(--color-text-disabled)}.send-btn{width:48px;height:48px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.send-btn:hover:not(:disabled){background:var(--color-primary-light);transform:scale(1.05)}.send-btn:disabled{background:#ffffff1a;color:var(--color-text-disabled);cursor:not-allowed}.mobile-only{display:none}@media (max-width: 768px){.messages-sidebar{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;min-width:100%;z-index:100}.messages-sidebar.hidden-mobile{display:none}.chat-area{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100}.chat-area.hidden-mobile{display:none}.mobile-only{display:flex}.message{max-width:85%}.no-chat-selected{display:none}}.messages-list::-webkit-scrollbar{width:6px}.messages-list::-webkit-scrollbar-track{background:transparent}.messages-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.messages-list::-webkit-scrollbar-thumb:hover{background:#fff3}.dinner-planner{min-height:100vh;padding-bottom:100px}.page-title{padding:var(--spacing-md) var(--spacing-lg);padding-top:0}.page-title h1,.page-title p{margin:0}.week-view{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}@media (max-width: 1200px){.week-view{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){.week-view{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}}.day-card{background:#1a1a1a99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.05);overflow:hidden;transition:all .3s ease;min-height:140px;display:flex;flex-direction:column;cursor:pointer;position:relative}.day-card:hover{border-color:#ffffff1a}.day-card:active{transform:scale(.98)}.day-card.today{border-color:#f9731666;background:#f9731614}.day-card.today:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#f97316,#fb923c)}.day-card.selected{border-color:#f97316;background:#f973161f;box-shadow:0 0 20px #f9731633;transform:scale(1.02)}.day-card.drag-over{border-color:#f9731699;background:#f9731626;transform:scale(1.02);box-shadow:0 0 20px #f9731633}.day-card.locked{opacity:.85;cursor:default}.day-header{padding:var(--spacing-sm) var(--spacing-md);background:#0003;border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xs)}.day-header-main{display:flex;align-items:baseline;gap:var(--spacing-xs)}.day-name{font-weight:700;font-size:.9375rem;color:var(--color-text)}.day-date{font-size:.75rem;color:var(--color-text-muted)}.today-badge{background:linear-gradient(135deg,#f97316,#fb923c);color:#fff;font-size:.625rem;font-weight:600;padding:2px 6px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.day-content{flex:1;padding:var(--spacing-sm);display:flex;flex-direction:column;align-items:center}.empty-day{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-md);opacity:.6;transition:all .2s ease}.day-card:hover .empty-day,.day-card.selected .empty-day{opacity:1}.empty-icon{color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.empty-day span{font-size:.6875rem;color:var(--color-text-muted)}.meal-entry{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-xs);width:100%;height:100%;padding-top:var(--spacing-xs)}.meal-entry-icon{flex-shrink:0}.meal-name{font-weight:600;font-size:.8125rem;color:var(--color-text);word-break:break-word;line-height:1.2}.meal-status{margin-top:2px}.status-badge{display:inline-flex;align-items:center;gap:3px;font-size:.5625rem;padding:2px 6px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em}.status-badge.pending{background:#f59e0b26;color:var(--color-warning)}.status-badge.confirmed{background:#10b98126;color:var(--color-success)}.meal-actions{display:flex;gap:4px;justify-content:space-between;width:100%;margin-top:auto;padding-top:8px}.action-btn{width:24px;height:24px;border-radius:var(--radius-sm);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.action-btn.confirm{background:#10b98133;color:var(--color-success)}.action-btn.confirm:hover{background:var(--color-success);color:#fff}.action-btn.clear{background:#ef444433;color:var(--color-danger)}.action-btn.clear:hover{background:var(--color-danger);color:#fff}.meal-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:fadeIn .2s ease}.meal-picker-strip{background:#141414fa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid rgba(249,115,22,.3);overflow:hidden;box-shadow:0 24px 80px #0009,0 0 40px #f9731626;animation:scaleUp .25s cubic-bezier(.34,1.56,.64,1);max-width:95vw;width:100%;max-width:600px}@keyframes scaleUp{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.meal-picker-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.06);background:#f9731614}.meal-picker-title{font-size:.875rem;color:var(--color-text-secondary)}.meal-picker-title strong{color:#f97316}.close-picker{width:32px;height:32px;border-radius:var(--radius);background:#ffffff0d;border:none;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.close-picker:hover{background:#ef444433;color:var(--color-danger)}.meal-picker-container{position:relative;display:flex;align-items:center}.scroll-btn{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:#1a1a1ae6;border:1px solid rgba(255,255,255,.1);color:var(--color-text);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:all .2s ease;box-shadow:0 4px 12px #0000004d}.scroll-btn:hover{background:#f9731633;border-color:#f97316}.scroll-btn.scroll-left{left:var(--spacing-sm)}.scroll-btn.scroll-right{right:var(--spacing-sm)}@media (max-width: 768px){.scroll-btn{display:none}}.meal-picker-scroll{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);padding-left:var(--spacing-xl);padding-right:var(--spacing-xl);overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.meal-picker-scroll::-webkit-scrollbar{display:none}.meal-picker-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;flex-shrink:0;min-width:100px;scroll-snap-align:start}.meal-picker-item:hover{background:#f973161a;border-color:#f973164d;transform:scale(1.05)}.meal-picker-item:active{transform:scale(.98)}.meal-picker-item span{font-size:.75rem;font-weight:500;color:var(--color-text);text-align:center;white-space:nowrap}.meal-picker-item.custom-meal-btn{border-style:dashed;border-color:#9333ea66}.meal-picker-item.custom-meal-btn:hover{background:#9333ea1a;border-color:#9333ea99}.custom-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;color:#9333ea;border:2px dashed rgba(147,51,234,.4);border-radius:var(--radius)}.custom-meal-input-strip{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid rgba(255,255,255,.06);background:#9333ea0d;animation:fadeIn .2s ease}.custom-meal-input-strip .input{flex:1}.custom-meal-input-strip .btn{flex-shrink:0}.meals-section{background:#1a1a1a99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.05);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}@media (max-width: 768px){.meals-section{display:none}}.section-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-lg);color:var(--color-text)}.section-title svg{color:#f97316}.drag-hint-desktop{margin-left:auto;font-size:.75rem;font-weight:400;color:var(--color-text-muted);opacity:.6}@media (max-width: 768px){.drag-hint-desktop{display:none}}.meals-palette{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--spacing-md)}.meal-card{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);cursor:grab;transition:all .3s ease;position:relative;user-select:none;-webkit-user-select:none}.meal-card:hover{background:#ffffff14;border-color:#f973164d;transform:translateY(-4px);box-shadow:0 8px 24px #0000004d}.meal-card:active,.meal-card.dragging{cursor:grabbing;transform:scale(1.05);box-shadow:0 12px 32px #f973164d;border-color:#f97316;z-index:100}.meal-drag-handle{position:absolute;top:4px;right:4px;color:var(--color-text-muted);opacity:.3;transition:opacity .2s ease}.meal-card:hover .meal-drag-handle{opacity:.7}.meal-card-name{font-size:.8125rem;font-weight:500;color:var(--color-text);text-align:center;margin-top:var(--spacing-sm);line-height:1.3}.meal-icon svg{width:100%;height:100%}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.day-card.drag-over .empty-day{animation:pulse .8s ease-in-out infinite}@media (hover: none){.meal-card{padding:var(--spacing-lg)}.action-btn{width:32px;height:32px}}@media (max-width: 768px){.day-card{min-height:120px}.day-content{padding:var(--spacing-xs)}.meal-entry-icon{width:40px!important;height:40px!important}.meal-name{font-size:.75rem}.meal-picker-item{min-width:90px;padding:var(--spacing-sm)}.meal-picker-item .meal-icon{width:48px!important;height:48px!important}.custom-icon{width:48px;height:48px}}.bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1100;display:flex;align-items:flex-end;justify-content:center;animation:bottomSheetFadeIn .2s ease}.bottom-sheet{background:#1a1a1a;border-radius:20px 20px 0 0;width:100%;max-width:500px;max-height:92vh;max-height:92dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;will-change:transform;padding:0 20px 28px;padding-bottom:max(28px,env(safe-area-inset-bottom));animation:bottomSheetSlideUp .3s cubic-bezier(.16,1,.3,1);border:1px solid rgba(255,255,255,.08);border-bottom:none}.bottom-sheet-handle{width:100%;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;touch-action:none;cursor:grab}.bottom-sheet-handle:after{content:"";width:36px;height:4px;background:#ffffff4d;border-radius:2.5px}@keyframes bottomSheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes bottomSheetFadeIn{0%{opacity:0}to{opacity:1}}@media (min-width: 768px){.bottom-sheet-overlay{align-items:center;padding:40px 20px}.bottom-sheet{border-radius:16px;max-height:88vh;border-bottom:1px solid rgba(255,255,255,.08);animation:bottomSheetFadeScale .3s cubic-bezier(.16,1,.3,1);box-shadow:0 24px 80px #00000080}.bottom-sheet-handle{display:none}@keyframes bottomSheetFadeScale{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}}.movies-page{min-height:100vh;padding:0;position:relative}.movies-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;padding-top:max(16px,env(safe-area-inset-top));background:#0000004d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;z-index:50}.movies-header-left{display:flex;align-items:center;gap:12px}.movies-header-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#e50914,#b20710);display:flex;align-items:center;justify-content:center;color:#fff}.movies-title{font-size:1.4rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.movies-header-right{display:flex;align-items:center;gap:8px}.movies-backfill-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.1);color:var(--color-text-muted);width:34px;height:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.movies-backfill-btn:hover{background:#e5091426;border-color:#e509144d;color:#e50914}.movies-backfill-btn:active{transform:scale(.95)}.movies-logout-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.1);color:var(--color-text-muted);padding:8px 12px;border-radius:var(--radius-sm);font-size:.8rem;display:flex;align-items:center;gap:6px;transition:all .2s}.movies-logout-btn:hover{background:#ffffff1f;color:var(--color-text)}.movies-content{max-width:1200px;margin:0 auto;padding:20px 16px 120px}.movies-search-section{margin-bottom:24px}.movies-search-bar{display:flex;align-items:center;gap:10px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:10px 16px;transition:all .2s}.movies-search-bar:focus-within{border-color:#e50914;background:#e509140f;box-shadow:0 0 0 3px #e509141a}.movies-search-bar svg{color:var(--color-text-muted);flex-shrink:0}.movies-search-input{flex:1;background:transparent;border:none;color:var(--color-text);font-size:.95rem;outline:none}.movies-search-input::placeholder{color:var(--color-text-disabled)}.movies-search-clear{background:#ffffff1a;border:none;color:var(--color-text-muted);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .2s}.movies-search-clear:hover{background:#fff3;color:var(--color-text)}.movies-search-results{margin-top:12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);overflow:hidden;max-height:400px;overflow-y:auto}.movies-search-result-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.05);cursor:pointer;transition:all .15s;background:transparent;width:100%;text-align:left;color:var(--color-text)}.movies-search-result-item:hover{background:#e5091414}.movies-search-result-item:last-child{border-bottom:none}.movies-search-result-poster{width:40px;height:60px;border-radius:6px;object-fit:cover;flex-shrink:0;background:#ffffff0d}.movies-search-result-poster-placeholder{width:40px;height:60px;border-radius:6px;flex-shrink:0;background:#ffffff0d;display:flex;align-items:center;justify-content:center;color:var(--color-text-disabled)}.movies-search-result-info{flex:1;min-width:0}.movies-search-result-title{font-weight:600;font-size:.9rem;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.movies-search-result-year{font-size:.8rem;color:var(--color-text-muted);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.movies-search-result-actions{display:flex;gap:6px;flex-shrink:0}.movies-search-result-btn{border:none;color:#fff;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .2s}.movies-search-result-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.movies-search-result-add{background:linear-gradient(135deg,#e50914,#b20710)}.movies-search-result-add:hover:not(:disabled){transform:scale(1.1);box-shadow:0 0 12px #e5091466}.movies-search-result-add.added{background:var(--color-success);pointer-events:none}.movies-search-result-watched-btn{background:linear-gradient(135deg,#22c55e,#16a34a)}.movies-search-result-watched-btn:hover:not(:disabled){transform:scale(1.1);box-shadow:0 0 12px #22c55e66}.movies-search-result-watched-btn.done{background:var(--color-success);pointer-events:none;opacity:.6}.movies-search-loading{padding:20px;text-align:center;color:var(--color-text-muted);font-size:.85rem}.movies-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.movies-section-title{font-size:1.1rem;font-weight:600;color:var(--color-text);display:flex;align-items:center;gap:8px}.movies-count-badge{background:#e5091433;color:#e50914;font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:var(--radius-full)}.movies-spin-btn{background:linear-gradient(135deg,#e50914,#b20710);border:none;color:#fff;padding:10px 20px;border-radius:var(--radius);font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:8px;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #e509144d}.movies-spin-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #e5091466}.movies-spin-btn:active{transform:translateY(0)}.movies-spin-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.movies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}@media (min-width: 640px){.movies-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}.movie-card{position:relative;border-radius:var(--radius);overflow:hidden;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);transition:all .3s ease;cursor:default}.movie-card:hover{transform:translateY(-4px);border-color:#e509144d;box-shadow:0 8px 24px #0006}.movie-card-poster-wrapper{position:relative;aspect-ratio:2/3;overflow:hidden}.movie-card-poster{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.movie-card:hover .movie-card-poster{transform:scale(1.05)}.movie-card-poster-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e509141a,#b207100d);color:var(--color-text-disabled)}.movie-card-detail-btn-wrap{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:2;opacity:0;pointer-events:none;transition:opacity .2s ease}.movie-card-detail-btn-wrap.active,.movie-card:hover .movie-card-detail-btn-wrap{opacity:1;pointer-events:none}.movie-card-detail-btn-wrap.active .movie-card-detail-btn,.movie-card:hover .movie-card-detail-btn-wrap .movie-card-detail-btn{pointer-events:auto}.movie-card-detail-btn{width:48px;height:48px;border-radius:50%;border:2px solid rgba(255,255,255,.25);background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;box-shadow:0 4px 16px #0006}.movie-card-detail-btn:hover{background:#e50914b3;border-color:#e50914cc;transform:scale(1.1);box-shadow:0 4px 24px #e509144d}.movie-card-detail-btn:active{transform:scale(.95)}.fsk-badge{display:inline-flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:800;padding:2px 5px;border-radius:3px;letter-spacing:.02em;line-height:1;white-space:nowrap;text-transform:uppercase}.fsk-badge-sm{font-size:.55rem;padding:1px 4px}.fsk-unknown{background:#ffffff26;color:var(--color-text-muted)}.movie-card-badges-left{position:absolute;bottom:8px;left:8px;z-index:2}.movie-card-actions-top{position:absolute;top:8px;right:8px;display:flex;flex-direction:column;gap:4px;z-index:4}.movie-card-action-btn{background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:all .2s}.movie-card:hover .movie-card-action-btn{opacity:1}.movie-card-delete{color:#ef4444}.movie-card-delete:hover{background:#ef44444d;transform:scale(1.1)}.movie-card-watched-btn{color:#22c55e}.movie-card-watched-btn:hover{background:#22c55e4d;transform:scale(1.1)}.movie-card-info{padding:10px 10px 12px}.movie-card-title{font-size:.82rem;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.movie-card-meta{display:flex;align-items:center;justify-content:space-between;font-size:.72rem;color:var(--color-text-muted)}.movie-card-added-by{display:flex;align-items:center;gap:3px}.movies-empty-state{text-align:center;padding:60px 20px;color:var(--color-text-muted)}.movies-empty-icon{width:64px;height:64px;margin:0 auto 16px;background:#e509141a;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#e50914}.movies-empty-title{font-size:1.1rem;font-weight:600;color:var(--color-text);margin-bottom:8px}.movies-empty-text{font-size:.85rem;max-width:300px;margin:0 auto}.movies-wheel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.movies-wheel-title{font-size:1.6rem;font-weight:700;color:var(--color-text);margin-bottom:30px;text-align:center}.movies-wheel-title span{color:#e50914}.movies-wheel-container{position:relative;width:200px;height:300px;overflow:hidden;border-radius:var(--radius-md);border:3px solid rgba(229,9,20,.5);box-shadow:0 0 40px #e5091433,inset 0 0 30px #00000080;background:#111}.movies-wheel-strip{position:absolute;left:0;width:100%;transition:none}.movies-wheel-strip.spinning{transition:transform 4s cubic-bezier(.17,.67,.12,.99)}.movies-wheel-strip-item{width:200px;height:300px;flex-shrink:0}.movies-wheel-strip-item img{width:100%;height:100%;object-fit:cover}.movies-wheel-strip-item .movies-card-poster-placeholder{width:100%;height:100%}.movies-wheel-indicator{position:absolute;top:50%;transform:translateY(-50%);z-index:5}.movies-wheel-indicator-left{left:-20px;color:#e50914;filter:drop-shadow(0 0 6px rgba(229,9,20,.5))}.movies-wheel-indicator-right{right:-20px;color:#e50914;filter:drop-shadow(0 0 6px rgba(229,9,20,.5))}.movies-wheel-mask-top,.movies-wheel-mask-bottom{position:absolute;left:0;right:0;height:60px;z-index:3;pointer-events:none}.movies-wheel-mask-top{top:0;background:linear-gradient(to bottom,#111 0%,transparent 100%)}.movies-wheel-mask-bottom{bottom:0;background:linear-gradient(to top,#111 0%,transparent 100%)}.movies-wheel-selection-line{position:absolute;left:0;right:0;top:0;bottom:0;border:2px solid rgba(229,9,20,.6);border-radius:var(--radius-md);z-index:4;pointer-events:none;box-shadow:inset 0 0 20px #e509141a}.wheel-fsk-filter{margin-bottom:20px;text-align:center}.wheel-fsk-label{display:block;font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.wheel-fsk-buttons{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}.wheel-fsk-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;border-radius:10px;border:2px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--color-text-muted);font-size:.7rem;font-weight:700;cursor:pointer;transition:all .2s;min-width:52px;-webkit-tap-highlight-color:transparent}.wheel-fsk-btn:hover:not(:disabled){border-color:#ffffff40;background:#ffffff14}.wheel-fsk-btn.active{border-color:transparent;transform:scale(1.05);box-shadow:0 2px 12px #0000004d}.wheel-fsk-btn:disabled{opacity:.5;cursor:not-allowed}.wheel-fsk-count{font-size:.6rem;font-weight:600;opacity:.7}.wheel-provider-filter{margin-bottom:16px;text-align:center}.wheel-provider-label{display:block;font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.wheel-provider-buttons{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.wheel-provider-btn{width:58px;border-radius:12px;border:2px solid rgba(255,255,255,.12);background:#ffffff0d;color:var(--color-text-muted);padding:6px 5px 4px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:4px;-webkit-tap-highlight-color:transparent}.wheel-provider-btn img{width:42px;height:42px;border-radius:9px;object-fit:cover}.wheel-provider-fallback{width:42px;height:42px;border-radius:9px;font-size:.55rem;line-height:1.1;display:flex;align-items:center;justify-content:center;text-align:center;background:#ffffff1a;padding:3px}.wheel-provider-count{font-size:.62rem;font-weight:700;opacity:.75}.wheel-provider-btn:hover:not(:disabled){border-color:#ffffff4d;transform:translateY(-1px)}.wheel-provider-btn.active{border-color:#e50914a6;background:#e5091429;box-shadow:0 4px 16px #e5091438}.wheel-provider-btn:disabled{opacity:.55;cursor:not-allowed}.wheel-provider-hint{margin-top:8px;font-size:.68rem;line-height:1.35;color:var(--color-text-muted)}.wheel-provider-hint-error{color:#ef4444}.wheel-fsk-warning{color:var(--color-text-muted);font-size:.85rem;text-align:center;padding:30px 20px;background:#ffffff08;border-radius:var(--radius);border:1px dashed rgba(255,255,255,.1)}.movies-wheel-go-btn{margin-top:30px;background:linear-gradient(135deg,#e50914,#b20710);border:none;color:#fff;padding:14px 40px;border-radius:var(--radius-full);font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 20px #e5091466;letter-spacing:.05em}.movies-wheel-go-btn:hover{transform:scale(1.05);box-shadow:0 6px 30px #e5091480}.movies-wheel-go-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.movies-wheel-close-btn{position:absolute;top:20px;right:20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:var(--color-text-muted);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:10}.movies-wheel-close-btn:hover{background:#fff3;color:var(--color-text)}.movies-wheel-result{text-align:center;animation:fadeInUp .5s ease}.movies-wheel-result-label{font-size:1rem;color:var(--color-text-muted);margin-bottom:20px}.movies-wheel-result-card{display:inline-block;border-radius:var(--radius-md);overflow:hidden;border:3px solid #e50914;box-shadow:0 0 40px #e509144d;animation:pulse-glow 2s ease-in-out infinite}.movies-wheel-result-poster{width:200px;height:300px;object-fit:cover}.movies-wheel-result-title{font-size:1.4rem;font-weight:700;color:var(--color-text);margin-top:20px}.movies-wheel-result-year{font-size:.9rem;color:var(--color-text-muted);margin-top:4px}.movies-wheel-result-actions{display:flex;gap:12px;margin-top:24px;justify-content:center}.movies-wheel-confirm-btn{background:linear-gradient(135deg,#e50914,#b20710);border:none;color:#fff;padding:12px 28px;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.movies-wheel-confirm-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px #e5091466}.movies-wheel-respin-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:var(--color-text);padding:12px 28px;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.movies-wheel-respin-btn:hover{background:#ffffff26}.movies-tabs{display:flex;gap:4px;margin-bottom:20px;background:#ffffff0a;border-radius:var(--radius);padding:4px;border:1px solid rgba(255,255,255,.06);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.movies-tabs::-webkit-scrollbar{display:none}.movies-tab{flex:1 0 0;min-width:0;padding:10px;border-radius:calc(var(--radius) - 4px);font-size:.8rem;font-weight:600;color:var(--color-text-muted);background:transparent;border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap}.movies-tab:hover{color:var(--color-text);background:#ffffff0a}.movies-tab.active{background:#e5091426;color:#e50914}.movies-tab-badge{font-size:.65rem;background:#e5091433;color:#e50914;padding:1px 5px;border-radius:var(--radius-full)}.movies-tab svg{flex-shrink:0}@media (max-width: 400px){.movies-tab{font-size:.72rem;padding:9px 6px;gap:3px}.movies-tab svg{width:13px;height:13px}.movies-tab-badge{font-size:.58rem;padding:0 4px}}.movie-card-corner-ribbon{position:absolute;top:8px;width:94px;height:22px;display:flex;align-items:center;justify-content:center;z-index:3;pointer-events:none;border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 12px #00000059;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.movie-card-corner-ribbon span{font-size:.52rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#fff}.movie-card-corner-ribbon-left{left:-28px;transform:rotate(-45deg)}.movie-card-corner-ribbon-right{right:-28px;transform:rotate(45deg)}.movie-card-corner-ribbon-watched{background:linear-gradient(135deg,#10b981f2,#059669eb)}.movie-card-corner-ribbon-rated{background:linear-gradient(135deg,#f5c518f2,#d97706f2)}.movie-card-ratings{margin-top:8px;display:flex;flex-direction:column;gap:4px}.movie-card-rating-row{display:flex;align-items:center;gap:8px;padding:0;background:none;border:none;width:100%;text-align:left;color:inherit;font:inherit;cursor:default}.movie-card-rating-row.family-row{cursor:pointer;border-radius:6px;padding:3px 0;transition:opacity .15s;-webkit-tap-highlight-color:transparent}.movie-card-rating-row.family-row:hover{opacity:.8}.movie-card-rating-row.family-row:active{opacity:.6}.movie-card-rating-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;width:38px;flex-shrink:0;color:var(--color-text-muted)}.tmdb-row .movie-card-rating-label{color:#0d9488}.family-row .movie-card-rating-label{color:#f5c518}.movie-card-rating-bar-wrap{flex:1;display:flex;align-items:center;gap:6px;min-width:0}.movie-card-rating-bar{flex:1;height:4px;background:#ffffff0f;border-radius:2px;overflow:hidden}.movie-card-rating-bar-fill{height:100%;border-radius:2px;transition:width .3s ease}.movie-card-rating-bar-fill.family-fill{background:linear-gradient(90deg,#f5c518,#ffda44)}.movie-card-rating-val{font-size:.7rem;font-weight:700;min-width:20px;text-align:right;flex-shrink:0}.movie-card-rating-val.family-val{color:#f5c518}.movie-card-rating-na{font-size:.65rem;color:var(--color-text-disabled)}.movie-card-rating-cta{display:flex;align-items:center;gap:3px;color:var(--color-text-muted);font-size:.65rem}.rating-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1100;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.rating-sheet{background:#1a1a1a;border-radius:20px 20px 0 0;width:100%;max-width:500px;max-height:85vh;overflow-y:auto;padding:12px 20px 28px;padding-bottom:max(28px,env(safe-area-inset-bottom));animation:slideUp .3s cubic-bezier(.16,1,.3,1);border:1px solid rgba(255,255,255,.08);border-bottom:none;will-change:transform;-webkit-overflow-scrolling:touch}.rating-sheet-movie{display:flex;gap:14px;align-items:center;margin-bottom:20px}.rating-sheet-poster{width:56px;height:84px;border-radius:8px;object-fit:cover;flex-shrink:0;box-shadow:0 4px 12px #0006}.rating-sheet-movie-info{flex:1;min-width:0}.rating-sheet-movie-title{font-size:1.05rem;font-weight:700;color:var(--color-text);margin-bottom:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.rating-sheet-movie-year{font-size:.8rem;color:var(--color-text-muted);margin-bottom:6px}.rating-sheet-avg{display:flex;align-items:center;gap:4px}.rating-sheet-avg-val{font-size:.9rem;font-weight:700;color:#f5c518}.rating-sheet-avg-count{font-size:.75rem;color:var(--color-text-muted)}.rating-sheet-section{margin-bottom:20px}.rating-sheet-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.rating-sheet-numbers{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.rating-num-btn{aspect-ratio:1;border-radius:12px;border:2px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--color-text-muted);font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.rating-num-btn.filled{background:#f5c51814;border-color:#f5c51840;color:#f5c518b3}.rating-num-btn.active{background:linear-gradient(135deg,#f5c518,#e5b516);border-color:#f5c518;color:#000;transform:scale(1.05);box-shadow:0 0 20px #f5c5184d}.rating-num-btn:active{transform:scale(.95)}.rating-sheet-chosen{display:flex;align-items:center;justify-content:center;gap:2px;margin-top:12px;padding:8px;background:#f5c5180f;border-radius:10px}.rating-sheet-chosen span{font-size:.8rem;font-weight:700;color:#f5c518;margin-left:6px}.rating-sheet-users{display:flex;flex-direction:column;gap:10px}.rating-sheet-user-row{display:flex;flex-direction:column;gap:4px;padding:8px 10px;background:#ffffff08;border-radius:10px;border:1px solid rgba(255,255,255,.04)}.rating-sheet-user-row.is-me{background:#f5c5180d;border-color:#f5c5181f}.rating-sheet-user-name{display:flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:var(--color-text)}.rating-sheet-me-tag{font-size:.6rem;font-weight:700;background:#f5c51833;color:#f5c518;padding:1px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em}.rating-sheet-user-score{display:flex;align-items:center;gap:10px}.rating-sheet-bar{flex:1;height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden}.rating-sheet-bar-fill{height:100%;background:linear-gradient(90deg,#f5c518,#ffda44);border-radius:3px;transition:width .4s ease}.rating-sheet-user-val{font-size:.85rem;font-weight:700;color:#f5c518;min-width:20px;text-align:right}.rating-sheet-close{width:100%;padding:14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:12px;color:var(--color-text);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.rating-sheet-close:hover{background:#ffffff1a}.rating-sheet-close:active{transform:scale(.98)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.detail-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1100;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.detail-sheet{background:#1a1a1a;border-radius:20px 20px 0 0;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;padding:12px 20px 28px;padding-bottom:max(28px,env(safe-area-inset-bottom));animation:slideUp .3s cubic-bezier(.16,1,.3,1);border:1px solid rgba(255,255,255,.08);border-bottom:none;-webkit-overflow-scrolling:touch;will-change:transform}.detail-sheet-header{display:flex;gap:16px;margin-bottom:20px}.detail-sheet-poster{width:100px;height:150px;border-radius:10px;object-fit:cover;flex-shrink:0;box-shadow:0 4px 16px #00000080}.detail-sheet-header-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}.detail-sheet-title{font-size:1.15rem;font-weight:700;color:var(--color-text);margin:0 0 6px;line-height:1.3}.detail-sheet-meta{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--color-text-muted);margin-bottom:8px;flex-wrap:wrap}.detail-sheet-genres{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.detail-sheet-genre{font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:10px;background:#ffffff0f;color:var(--color-text-muted);border:1px solid rgba(255,255,255,.06)}.detail-sheet-tmdb-rating{display:flex;align-items:center;gap:4px;font-size:.9rem;font-weight:700;color:#f5c518}.detail-sheet-tmdb-label{font-size:.6rem;font-weight:700;color:var(--color-text-muted);margin-left:2px}.detail-sheet-loading{display:flex;align-items:center;justify-content:center;padding:40px}.detail-sheet-section{margin-bottom:22px}.detail-sheet-section-label{font-size:.72rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.detail-sheet-overview{font-size:.88rem;line-height:1.6;color:#fffc;margin:0}.detail-sheet-trailer{position:relative;width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;background:#000}.detail-sheet-trailer iframe{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:none}.detail-sheet-trailer-tabs{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.detail-sheet-trailer-tab{padding:5px 10px;border-radius:8px;font-size:.7rem;font-weight:600;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);color:var(--color-text-muted);cursor:pointer;transition:all .15s}.detail-sheet-trailer-tab.active{background:#e5091426;border-color:#e509144d;color:#e50914}.detail-sheet-cast{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.detail-sheet-cast::-webkit-scrollbar{display:none}.detail-sheet-cast-item{flex-shrink:0;width:72px;text-align:center}.detail-sheet-cast-photo{width:56px;height:56px;border-radius:50%;object-fit:cover;margin:0 auto 6px;display:block;border:2px solid rgba(255,255,255,.08);background:#ffffff0a}.detail-sheet-cast-placeholder{display:flex;align-items:center;justify-content:center;color:var(--color-text-disabled)}.detail-sheet-cast-name{font-size:.65rem;font-weight:600;color:var(--color-text);line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.detail-sheet-cast-character{font-size:.58rem;color:var(--color-text-muted);margin-top:2px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.detail-sheet-providers-group{margin-bottom:12px}.detail-sheet-providers-group:last-child{margin-bottom:0}.detail-sheet-providers-type{font-size:.68rem;font-weight:600;color:var(--color-text-muted);margin-bottom:8px}.detail-sheet-providers{display:flex;gap:8px;flex-wrap:wrap}.detail-sheet-provider{width:44px;height:44px;border-radius:10px;overflow:hidden;background:#ffffff0f;border:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;transition:transform .15s}.detail-sheet-provider:hover{transform:scale(1.08)}.detail-sheet-provider img{width:100%;height:100%;object-fit:cover}.detail-sheet-provider-name{font-size:.5rem;color:var(--color-text-muted);text-align:center;padding:2px;word-break:break-all}.detail-sheet-justwatch{display:inline-block;margin-top:10px;font-size:.6rem;color:var(--color-text-disabled);text-decoration:none}.detail-sheet-justwatch:hover{color:var(--color-text-muted)}@media (min-width: 768px){.detail-sheet-overlay{align-items:center;padding:40px 20px}.detail-sheet{border-radius:16px;width:90vw;max-width:960px;max-height:88vh;padding:24px 32px 32px;border-bottom:1px solid rgba(255,255,255,.08);animation:detailFadeScale .3s cubic-bezier(.16,1,.3,1);box-shadow:0 24px 80px #00000080}@keyframes detailFadeScale{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.detail-sheet-header{gap:24px;margin-bottom:28px}.detail-sheet-poster{width:180px;height:270px;border-radius:12px;box-shadow:0 8px 32px #0009}.detail-sheet-title{font-size:1.5rem;margin-bottom:8px}.detail-sheet-meta{font-size:.88rem;margin-bottom:10px}.detail-sheet-genres{gap:6px;margin-bottom:12px}.detail-sheet-genre{font-size:.72rem;padding:3px 10px}.detail-sheet-tmdb-rating{font-size:1rem;gap:6px}.detail-sheet-tmdb-label{font-size:.65rem}.detail-sheet-content{display:grid;grid-template-columns:1fr 1fr;gap:20px 32px}.detail-sheet-content .detail-sheet-section--overview{grid-column:1 / -1}.detail-sheet-content .detail-sheet-section--trailer{grid-column:span 1}.detail-sheet-trailer{max-height:280px}.detail-sheet-section-label{font-size:.78rem;margin-bottom:12px}.detail-sheet-overview{font-size:.95rem;line-height:1.7}.detail-sheet-cast{flex-wrap:wrap}.detail-sheet-cast-item{width:88px}.detail-sheet-cast-photo{width:68px;height:68px;margin-bottom:8px}.detail-sheet-cast-name{font-size:.72rem}.detail-sheet-cast-character{font-size:.64rem}.detail-sheet-provider{width:52px;height:52px;border-radius:12px}.detail-sheet-providers-type{font-size:.74rem}.detail-sheet-justwatch{font-size:.65rem}.rating-sheet-close{max-width:300px;margin:8px auto 0}}@media (min-width: 1200px){.detail-sheet{max-width:1100px;padding:28px 40px 36px}.detail-sheet-poster{width:200px;height:300px}.detail-sheet-title{font-size:1.65rem}.detail-sheet-content{gap:24px 40px}.detail-sheet-trailer{max-height:320px}}.movies-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#fff;padding:12px 20px;border-radius:14px;font-size:.85rem;font-weight:600;z-index:1200;display:flex;align-items:center;gap:10px;max-width:calc(100vw - 40px);animation:toastIn .4s cubic-bezier(.16,1,.3,1),toastOut .35s ease 2.8s forwards;box-shadow:0 8px 32px #00000059;border:1px solid rgba(255,255,255,.12)}.movies-toast-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;flex-shrink:0;background:#fff3}.movies-toast-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.movies-toast-added{background:#10b981eb}.movies-toast-added .movies-toast-icon{background:#ffffff40}.movies-toast-removed{background:#ef7344eb}.movies-toast-removed .movies-toast-icon{background:#ffffff40}.movies-toast-watched{background:#14b8a6eb}.movies-toast-watched .movies-toast-icon{background:#ffffff40}.movies-toast-rated{background:#b49b14eb}.movies-toast-rated .movies-toast-icon{background:#ffffff40}.movies-toast-info{background:#3b82f6eb}.movies-toast-info .movies-toast-icon{background:#ffffff40}.movies-toast-error{background:#dc2626eb}.movies-toast-error .movies-toast-icon{background:#ffffff40}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(24px) scale(.92)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translate(-50%) translateY(0) scale(1)}to{opacity:0;transform:translate(-50%) translateY(-12px) scale(.95)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes pulse-glow{0%,to{box-shadow:0 0 40px #e509144d}50%{box-shadow:0 0 60px #e5091480}}.movies-loading{display:flex;align-items:center;justify-content:center;padding:40px}.movies-spinner{width:32px;height:32px;border:3px solid rgba(229,9,20,.2);border-top-color:#e50914;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 480px){.movies-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}.movies-header{padding:12px 14px;padding-top:max(12px,env(safe-area-inset-top))}.movies-title{font-size:1.15rem}.movies-content{padding:14px 10px 100px}.movies-section-header{flex-direction:column;align-items:flex-start;gap:10px}.movies-spin-btn{width:100%;justify-content:center}.movies-wheel-container,.movies-wheel-strip-item,.movies-wheel-result-poster{width:160px;height:240px}.movies-wheel-result-actions{flex-direction:column}}.discover-section{margin-bottom:28px}.discover-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;flex-wrap:wrap}.discover-section-title{display:flex;align-items:center;gap:8px;font-size:1.1rem;font-weight:700;color:var(--color-text)}.discover-section-desc{font-size:.82rem;color:var(--color-text-muted);margin:0 0 16px;line-height:1.4}.discover-tipp-hero{position:relative;border-radius:16px;overflow:hidden;margin-bottom:28px;border:1px solid rgba(255,255,255,.08)}.discover-tipp-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#f59e0b26,#ef444426,#a855f71f);z-index:0}.discover-tipp-hero-content{position:relative;z-index:1;display:flex;align-items:center;gap:14px;padding:18px 20px}.discover-tipp-hero-icon{color:#f59e0b;flex-shrink:0;filter:drop-shadow(0 0 8px rgba(245,158,11,.4))}.discover-tipp-hero-text{flex:1;min-width:0}.discover-tipp-hero-title{font-size:1rem;font-weight:700;color:var(--color-text);margin:0 0 2px}.discover-tipp-hero-desc{font-size:.75rem;color:var(--color-text-muted);margin:0;line-height:1.3}.discover-tipp-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;border-radius:var(--radius-full);border:none;cursor:pointer;font-size:.8rem;font-weight:700;background:linear-gradient(135deg,#f59e0b,#ef4444,#a855f7);background-size:200% 200%;animation:tippGradient 4s ease infinite;color:#fff;transition:all .25s;box-shadow:0 4px 20px #f59e0b59;flex-shrink:0;white-space:nowrap}@keyframes tippGradient{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.discover-tipp-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #f59e0b80}.discover-tipp-btn:disabled{opacity:.7;cursor:not-allowed}@keyframes spinLoader{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin-animation{animation:spinLoader 1s linear infinite}.discover-tipp-loading{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:10px;padding:24px 20px;color:var(--color-text-muted);font-size:.82rem}.discover-tipp-sort-bar{position:relative;z-index:1;display:flex;align-items:center;gap:6px;padding:0 20px 12px;color:var(--color-text-muted)}.discover-tipp-results{position:relative;z-index:1;display:flex;gap:12px;overflow-x:auto;padding:0 20px 16px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.discover-tipp-results::-webkit-scrollbar{height:4px}.discover-tipp-results::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:var(--radius-full)}@media (max-width: 480px){.discover-tipp-hero-content{flex-wrap:wrap;gap:10px;padding:14px 16px}.discover-tipp-hero-icon{width:22px;height:22px}.discover-tipp-hero-title{font-size:.92rem}.discover-tipp-btn{width:100%;justify-content:center;padding:10px 16px}.discover-tipp-results{padding:0 16px 14px}.discover-tipp-sort-bar{padding:0 16px 10px}}.discover-movie-card{flex:0 0 140px;scroll-snap-align:start;border-radius:var(--radius);background:#ffffff0a;border:1px solid rgba(255,255,255,.06);overflow:hidden;transition:all .2s;position:relative}.discover-movie-card:hover{border-color:#ffffff1f;transform:translateY(-2px)}.discover-movie-card.in-list,.discover-movie-card.is-watched{opacity:.7}.discover-movie-poster-wrap{position:relative;width:100%;aspect-ratio:2 / 3}.discover-movie-poster{width:100%;height:100%;object-fit:cover;display:block}.discover-movie-poster-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#ffffff0a;color:var(--color-text-muted)}.discover-movie-tmdb-badge{position:absolute;top:6px;left:6px;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#14b8a6;font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:var(--radius-full)}.discover-movie-status-badge{position:absolute;bottom:6px;left:6px;right:6px;display:flex;align-items:center;justify-content:center;gap:4px;font-size:.6rem;font-weight:600;padding:3px 6px;border-radius:var(--radius-full);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.discover-movie-status-badge.wishlist{background:#e50914d9;color:#fff}.discover-movie-status-badge.watched{background:#10b981d9;color:#fff}.discover-movie-info{padding:8px}.discover-movie-title{font-size:.78rem;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.discover-movie-year{font-size:.7rem;color:var(--color-text-muted);margin-top:2px}.discover-movie-actions{display:flex;border-top:1px solid rgba(255,255,255,.06)}.discover-movie-action-btn{flex:1;padding:7px 0;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:.75rem}.discover-add-wishlist{background:#e509141a;color:#e50914;border-right:1px solid rgba(255,255,255,.06)}.discover-add-wishlist:hover:not(:disabled){background:#e5091440}.discover-add-watched{background:#10b9811a;color:#10b981}.discover-add-watched:hover:not(:disabled){background:#10b98140}.discover-movie-action-btn:disabled{opacity:.5;cursor:not-allowed}.discover-genre-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.discover-genre-chip{padding:6px 14px;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:var(--color-text-muted);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.discover-genre-chip:hover{background:#ffffff14;color:var(--color-text);border-color:#fff3}.discover-genre-chip.active{background:#e5091426;color:#e50914;border-color:#e509144d;font-weight:600}.discover-sort-bar{display:flex;align-items:center;gap:8px;margin-bottom:16px}.discover-sort-label{display:flex;align-items:center;gap:4px;font-size:.78rem;color:var(--color-text-muted);font-weight:500}.discover-sort-btn{padding:5px 12px;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--color-text-muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s}.discover-sort-btn:hover{background:#ffffff14}.discover-sort-btn.active{background:#e5091426;color:#e50914;border-color:#e509144d;font-weight:600}.discover-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}.discover-grid .discover-movie-card{flex:none}.discover-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px 0;color:var(--color-text-muted);font-size:.85rem}.discover-empty-hint{text-align:center;padding:24px 16px;color:var(--color-text-muted);font-size:.85rem;background:#ffffff05;border-radius:var(--radius);border:1px dashed rgba(255,255,255,.08)}.discover-load-more{display:flex;align-items:center;justify-content:center;gap:8px;padding:24px 0;color:var(--color-text-muted);font-size:.8rem;min-height:60px}@media (max-width: 480px){.discover-movie-card{flex:0 0 120px}.discover-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.discover-genre-chips{gap:6px}.discover-genre-chip{padding:5px 10px;font-size:.75rem}.discover-section-header{flex-direction:column;align-items:flex-start}}.fitness-subtitle{font-size:.875rem;color:var(--color-text-light);margin-top:.25rem}.fitness-container{display:flex;flex-direction:column;gap:1.25rem}.fitness-tabs{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.fitness-tab{display:flex;align-items:center;justify-content:center;gap:.4rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;color:var(--color-text);padding:.6rem .8rem;cursor:pointer}.fitness-tab.active{border-color:#22c55eb3;color:#22c55e;background:#22c55e14;box-shadow:0 0 12px #22c55e1f}.fitness-container .btn-primary{background:linear-gradient(160deg,#34e85ef2,#22cc4eeb);border:1px solid rgba(52,232,94,.8);color:#ecfdf5}.fitness-container .btn-primary:hover{background:linear-gradient(160deg,#34e85e,#22cc4e);border-color:#34e85e;box-shadow:0 4px 16px #34e85e4d}.fitness-container .btn-outline{border-color:#22c55e4d;color:#22c55ee6}.fitness-container .btn-outline:hover{background:#22c55e14;border-color:#22c55e80;color:#22c55e}.fitness-streak-bar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.6rem 0;margin-bottom:.75rem;font-size:.88rem;color:var(--color-text-muted)}.fitness-streak-bar strong{color:var(--color-text)}.fitness-streak-bar svg{color:#f59e0b}.fitness-streak-sep{opacity:.4}.fitness-plan-list,.fitness-workout-list,.fitness-feed-list,.fitness-badge-list{display:flex;flex-direction:column;gap:.5rem}.fitness-plan-item,.fitness-workout-item,.fitness-feed-item,.fitness-badge-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);transition:all .2s ease}.fitness-workout-actions{display:flex;gap:.5rem;align-items:center}.fitness-plan-day,.fitness-workout-name,.fitness-badge-name{font-weight:600}.fitness-plan-workout,.fitness-workout-meta,.fitness-feed-meta,.fitness-badge-desc,.fitness-badge-date{font-size:.875rem;color:var(--color-text-muted)}.fitness-plan-actions{display:flex;align-items:center;gap:.4rem}.fitness-plan-today{border-color:#22c55e73;background:#22c55e0f}.fitness-plan-date{font-size:.8rem;font-weight:400;color:var(--color-text-muted);margin-left:.25rem}.fitness-plan-today-badge{display:inline-block;font-size:.68rem;font-weight:700;color:#22c55e;background:#22c55e24;padding:.1rem .4rem;border-radius:6px;margin-left:.4rem;vertical-align:middle}.fitness-start-btn{background:linear-gradient(160deg,#34e85ef2,#22cc4eeb);border-color:#34e85eeb;color:#ecfdf5}.fitness-start-btn:hover{background:linear-gradient(160deg,#34e85e,#22cc4ef5);border-color:#34e85e}.fitness-workout-detail{margin-top:1rem}.fitness-exercise-tiles{margin-top:.75rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.6rem}.fitness-exercise-tile{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:.6rem;text-align:center}.fitness-ex-icon{font-size:.75rem;color:#22c55e;margin-bottom:.3rem}.fitness-ex-name{font-size:.875rem}.fitness-ex-meta{color:var(--color-text-muted);font-size:.75rem}.fitness-player{display:flex;flex-direction:column;gap:1rem}.fitness-modal-title-wrap{display:flex;flex-direction:column;gap:.2rem}.fitness-modal-meta{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;font-size:.82rem;color:var(--color-text-muted)}.fitness-coverflow{position:relative;height:330px;width:100%;overflow:visible;padding:0 18px;display:flex;align-items:center;justify-content:center;perspective:800px}.fitness-coverflow-card{position:absolute;width:min(560px,92%);display:flex;align-items:center;gap:.75rem;background:#16161af5;border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:.8rem .9rem;opacity:.38;filter:blur(1px);transition:transform .35s ease,opacity .3s ease,filter .3s ease,border-color .3s ease}.fitness-coverflow-card.near{opacity:.85;filter:blur(.2px)}.fitness-workout-icons{margin-top:.45rem;display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.fitness-workout-icon-chip{display:inline-flex}.fitness-workout-icon-chip>div{width:30px!important;height:30px!important;border-radius:10px!important}.fitness-workout-icon-more{font-size:.75rem;color:var(--color-text-muted);padding:.18rem .4rem;border:1px solid rgba(255,255,255,.12);border-radius:999px}.fitness-coverflow-card.current{opacity:1;filter:none;border-color:#22c55e99;box-shadow:0 0 0 2px #22c55e3d,0 0 34px #22c55e57;transform:translateY(0) scale(1.03);z-index:3}.fitness-coverflow-card.running{animation:fitnessCardPulse 1.1s ease-in-out infinite}.fitness-coverflow-card.running-cooldown{animation:fitnessCardPulseCooldown 1.1s ease-in-out infinite}.fitness-coverflow-card.running-prepare{animation:fitnessCardPulsePrepare 1.1s ease-in-out infinite}.fitness-coverflow-text{display:flex;flex-direction:column;gap:.15rem}.fitness-coverflow-name{font-size:.95rem;font-weight:700}.fitness-coverflow-meta{font-size:.78rem;color:var(--color-text-muted)}.fitness-coverflow-status{margin-left:auto;width:24px;height:24px;min-width:24px;border-radius:50%;border:2px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;color:transparent}.fitness-coverflow-status.current{border-color:#22c55ecc}.fitness-coverflow-status.done{background:#22c55e;border-color:#22c55e;color:#052e16}.fitness-timer{background:#22c55e14;border:1px solid rgba(34,197,94,.28);border-radius:14px;padding:1rem;display:flex;flex-direction:column;gap:.5rem;align-items:center}.fitness-timer.tappable{cursor:pointer}.fitness-timer-wrap{position:relative}.fitness-timer-wrap.confirm-active{min-height:182px}.fitness-timer.blurred{filter:blur(2.3px);opacity:.55}.fitness-timer-confirm{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:.35rem;z-index:5}.fitness-timer-confirm-btn{min-height:58px;min-width:min(360px,calc(100% - 18px));border:1px solid rgba(52,232,94,.78);background:linear-gradient(160deg,#34e85efa,#22cc4ef2);color:#f0fdf4;font-size:1rem;font-weight:800;border-radius:14px;padding:.8rem 1rem;box-shadow:0 12px 30px #34e85e57;cursor:pointer}.fitness-cooldown{background:#fbbf2414;border-color:#fbbf2459}.fitness-prepare{background:#3b82f614;border-color:#3b82f659}.fitness-current-exercise{font-size:1.22rem;font-weight:700;line-height:1.15}.fitness-current-row{display:flex;align-items:center;gap:.65rem;justify-content:center}.fitness-timer-label{color:var(--color-text-muted);font-size:.875rem}.fitness-timer-value{font-size:2.5rem;font-weight:800;line-height:1}.fitness-timer-note{font-size:.875rem;color:var(--color-text-muted)}.fitness-touch-controls{display:flex;gap:.75rem}.fitness-touch-btn{border:1px solid transparent;border-radius:16px;min-height:72px;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-size:1rem;font-weight:700;cursor:pointer;touch-action:manipulation}.fitness-touch-btn:disabled{opacity:.5;cursor:not-allowed}.fitness-touch-btn.primary{background:linear-gradient(160deg,#22c55e47,#22c55e1f);border-color:#22c55e99;color:#ecfdf5}.fitness-touch-btn.secondary{background:#ffffff0d;border-color:#ffffff2e;color:var(--color-text);width:100%}.fitness-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1500;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;animation:builderFadeIn .2s ease}.fitness-sheet{background:#1a1a1a;border-radius:20px 20px 0 0;width:100%;max-width:560px;max-height:92vh;max-height:92dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;will-change:transform;padding:12px 20px 28px;padding-bottom:max(28px,env(safe-area-inset-bottom));animation:builderSlideUp .3s cubic-bezier(.16,1,.3,1);border:1px solid rgba(255,255,255,.08);border-bottom:none}.fitness-sheet-training{max-width:860px}.fitness-sheet-title{font-size:1.1rem;font-weight:700;margin:0 0 .25rem}.fitness-sheet-subtitle{margin:0 0 .7rem;font-size:.88rem;color:var(--color-text-muted)}.fitness-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.fitness-week-picker-list{display:flex;flex-direction:column;gap:.55rem}.fitness-week-picker-item{width:100%;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:#ffffff0d;color:var(--color-text);padding:.7rem .85rem;display:flex;align-items:center;justify-content:space-between;gap:.7rem;cursor:pointer;transition:all .2s ease}.fitness-week-picker-item:hover{border-color:#22c55e66;background:#22c55e0f}.fitness-week-picker-clear{border-color:#ffffff0f;color:var(--color-text-muted)}.fitness-week-picker-clear:hover{border-color:#ef444459;background:#ef44440f}.fitness-container .input:focus,.fitness-container select:focus{border-color:#22c55e99;box-shadow:0 0 0 3px #22c55e1a}.fitness-week-picker-item-main{text-align:left}.fitness-week-picker-name{font-weight:700;font-size:.95rem}.fitness-week-picker-meta{margin-top:.15rem;font-size:.8rem;color:var(--color-text-muted)}@keyframes fitnessCardPulse{0%{border-color:#22c55e8c;box-shadow:0 0 0 2px #22c55e33,0 0 18px #22c55e2e}50%{border-color:#22c55ef2;box-shadow:0 0 0 2px #22c55e6b,0 0 34px #22c55e57}to{border-color:#22c55e8c;box-shadow:0 0 0 2px #22c55e33,0 0 18px #22c55e2e}}@keyframes fitnessCardPulsePrepare{0%{border-color:#3b82f68c;box-shadow:0 0 0 2px #3b82f633,0 0 18px #3b82f62e}50%{border-color:#3b82f6f2;box-shadow:0 0 0 2px #3b82f66b,0 0 34px #3b82f657}to{border-color:#3b82f68c;box-shadow:0 0 0 2px #3b82f633,0 0 18px #3b82f62e}}@keyframes fitnessCardPulseCooldown{0%{border-color:#fbbf2494;box-shadow:0 0 0 2px #fbbf243d,0 0 16px #fbbf2433}50%{border-color:#fbbf24f2;box-shadow:0 0 0 2px #fbbf246b,0 0 30px #fbbf2457}to{border-color:#fbbf2494;box-shadow:0 0 0 2px #fbbf243d,0 0 16px #fbbf2433}}.fitness-feed-item,.fitness-badge-item{flex-direction:column;align-items:flex-start}.fitness-feed-head{font-size:.95rem}.fitness-health-row{display:flex;flex-wrap:wrap;gap:.7rem;font-size:.8125rem;color:var(--color-text-muted)}.fitness-empty-inline{color:var(--color-text-muted);font-size:.9rem}.fitness-training-header{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;margin-bottom:.5rem}.fitness-create-btn{background:linear-gradient(160deg,#34e85ef2,#22cc4eeb);border-color:#34e85ecc;color:#ecfdf5;gap:.35rem;white-space:nowrap}.fitness-create-btn:hover{background:linear-gradient(160deg,#34e85e,#22cc4e);box-shadow:0 4px 16px #34e85e4d}.fitness-workout-item-body{display:flex;align-items:center;justify-content:space-between;gap:.75rem;width:100%}.fitness-workout-author{opacity:.7}.fitness-workout-edit-btn,.fitness-workout-del-btn{padding:.3rem .4rem;min-width:0}.fitness-delete-confirm{display:flex;gap:.3rem}.fitness-owner-btn{background:none;border:none;border-bottom:1px dashed rgba(34,197,94,.5);color:var(--color-text-muted);font-size:inherit;padding:0;cursor:pointer;transition:color .12s ease,border-color .12s ease}.fitness-owner-btn:hover{color:#22c55e;border-color:#22c55e}.fitness-owner-picker{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.35rem}.fitness-owner-picker-item{padding:.2rem .5rem;font-size:.72rem;font-weight:600;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff08;color:var(--color-text-muted);cursor:pointer;display:inline-flex;align-items:center;gap:.3rem;transition:all .12s ease}.fitness-owner-picker-item:hover{border-color:#22c55e80;color:var(--color-text);background:#22c55e0f}.fitness-owner-picker-item.current{border-color:#22c55e80;color:#22c55e;background:#22c55e14}.fitness-builder-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1500;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;animation:builderFadeIn .2s ease}@keyframes builderFadeIn{0%{opacity:0}to{opacity:1}}@keyframes builderSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.builder-sheet-handle{width:36px;height:4px;background:#ffffff4d;border-radius:2px;margin:0 auto;padding:0;flex-shrink:0}.builder-sheet-handle-area{padding:14px 0 10px;cursor:grab;flex-shrink:0;touch-action:none}.fitness-builder-sheet{max-width:600px}.fitness-builder-header{margin:0 0 .85rem}.fitness-builder-header .card-title{margin:0;font-size:1.1rem}.fitness-builder-body{display:flex;flex-direction:column;gap:1.2rem}.fitness-builder-section{display:flex;flex-direction:column}.fitness-builder-form{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1rem}.fitness-builder-row{display:flex;gap:.6rem}.fitness-builder-section-title{font-size:.95rem;font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:.5rem;margin:0 0 .6rem}.fitness-builder-count{font-size:.78rem;font-weight:500;color:var(--color-text-muted)}.fitness-builder-exercises-section{flex:1;display:flex;flex-direction:column;min-height:0}.fitness-builder-exercises-header{display:flex;align-items:center;justify-content:space-between}.fitness-builder-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding:2rem 1rem;color:var(--color-text-muted);background:#ffffff05;border:1px dashed rgba(255,255,255,.1);border-radius:14px;text-align:center;font-size:.875rem}.fitness-builder-exercise-list{display:flex;flex-direction:column;gap:.4rem}.fitness-builder-exercise-card{display:flex;align-items:center;gap:.6rem;padding:.55rem .65rem;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:12px;transition:border-color .15s ease,background .15s ease}.fitness-builder-exercise-card:hover{border-color:#22c55e4d;background:#22c55e08}.fitness-builder-exercise-pos{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:6px;background:#22c55e1f;color:#22c55e;font-size:.72rem;font-weight:700;flex-shrink:0}.fitness-builder-exercise-info{flex:1;min-width:0}.fitness-builder-exercise-name{font-size:.85rem;font-weight:600;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fitness-builder-exercise-controls{display:flex;align-items:center;gap:.2rem;margin-top:.2rem}.fitness-builder-adj-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.12);border-radius:7px;background:#ffffff0a;color:var(--color-text);cursor:pointer;transition:all .12s ease}.fitness-builder-adj-btn:hover:not(:disabled){border-color:#22c55e80;background:#22c55e14}.fitness-builder-adj-btn:disabled{opacity:.3;cursor:not-allowed}.fitness-builder-exercise-value{min-width:52px;text-align:center;font-size:.78rem;font-weight:700;font-variant-numeric:tabular-nums}.fitness-builder-mode-btn{padding:.15rem .4rem;font-size:.68rem;font-weight:600;border:1px solid rgba(255,255,255,.12);border-radius:6px;background:#ffffff0a;color:var(--color-text-muted);cursor:pointer;margin-left:.15rem;transition:all .12s ease}.fitness-builder-mode-btn:hover{border-color:#22c55e66;color:#22c55e}.fitness-builder-exercise-actions{display:flex;gap:.2rem;flex-shrink:0}.fitness-builder-action-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.08);border-radius:7px;background:transparent;color:var(--color-text-muted);cursor:pointer;transition:all .12s ease}.fitness-builder-action-btn:hover:not(:disabled){border-color:#fff3;color:var(--color-text)}.fitness-builder-action-btn:disabled{opacity:.25;cursor:not-allowed}.fitness-builder-action-btn.danger:hover{border-color:#ef444480;color:#ef4444;background:#ef44440f}.fitness-builder-pool-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.fitness-builder-create-exercise-btn{gap:.3rem;white-space:nowrap;font-size:.72rem}.fitness-create-exercise-btn{gap:.35rem;white-space:nowrap}.fitness-builder-search{position:relative;margin-bottom:.5rem}.fitness-builder-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.fitness-builder-type-filters{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.6rem}.fitness-builder-filter-btn{padding:.25rem .55rem;font-size:.72rem;font-weight:600;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff08;color:var(--color-text-muted);cursor:pointer;transition:all .12s ease}.fitness-builder-filter-btn:hover{border-color:#fff3;color:var(--color-text)}.fitness-builder-filter-btn.active{border-color:#22c55e99;color:#22c55e;background:#22c55e14}.fitness-builder-exercise-pool{display:flex;flex-direction:column;gap:.3rem}.fitness-builder-pool-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .6rem;border:1px solid rgba(255,255,255,.06);border-radius:10px;background:#ffffff05;color:var(--color-text);cursor:pointer;transition:all .14s ease;width:100%;text-align:left}.fitness-builder-pool-item:hover{border-color:#22c55e66;background:#22c55e0d}.fitness-builder-pool-item:hover .fitness-builder-pool-add{opacity:1;color:#22c55e}.fitness-builder-pool-item.added{border-color:#22c55e33}.fitness-builder-pool-name{flex:1;font-size:.82rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fitness-builder-pool-badge{font-size:.68rem;font-weight:700;color:#22c55e;background:#22c55e1f;padding:.1rem .35rem;border-radius:5px}.fitness-builder-pool-add{opacity:.3;flex-shrink:0;transition:opacity .12s ease}.fitness-builder-footer{display:flex;align-items:center;justify-content:flex-end;gap:.6rem;margin-top:1rem;padding-top:.85rem;padding-bottom:max(.4rem,env(safe-area-inset-bottom));border-top:1px solid rgba(255,255,255,.06)}.fitness-builder-save-btn{background:linear-gradient(160deg,#34e85ef2,#22cc4eeb);border-color:#34e85ecc;color:#ecfdf5;font-weight:700;padding:.5rem 1.2rem}.fitness-builder-save-btn:hover:not(:disabled){box-shadow:0 4px 20px #34e85e59}.fitness-builder-save-btn:disabled{opacity:.45;cursor:not-allowed}.exercise-creator-sheet{max-width:520px}.exercise-creator{display:flex;flex-direction:column;gap:1.1rem}.exercise-creator-header{display:flex;align-items:flex-start;gap:.7rem;margin-bottom:.2rem}.exercise-creator-header-icon{color:#22c55e;flex-shrink:0;margin-top:.15rem}.exercise-creator-title{font-size:1.15rem;font-weight:800;margin:0;line-height:1.2}.exercise-creator-subtitle{font-size:.82rem;color:var(--color-text-muted);margin:.15rem 0 0}.exercise-creator-error{padding:.55rem .75rem;border-radius:10px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;font-size:.82rem}.exercise-creator-field{display:flex;flex-direction:column;gap:.45rem}.exercise-creator-label{font-size:.82rem;font-weight:700;color:var(--color-text)}.exercise-creator-optional{font-weight:400;color:var(--color-text-muted)}.exercise-creator-input{font-size:.95rem}.exercise-creator-types{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.exercise-creator-type-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;padding:.65rem .7rem;border:1.5px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff08;color:var(--color-text);cursor:pointer;transition:all .18s ease;text-align:left}.exercise-creator-type-card:hover{border-color:color-mix(in srgb,var(--type-color) 50%,transparent);background:color-mix(in srgb,var(--type-color) 6%,transparent)}.exercise-creator-type-card.selected{border-color:color-mix(in srgb,var(--type-color) 70%,transparent);background:color-mix(in srgb,var(--type-color) 10%,transparent);box-shadow:0 0 20px color-mix(in srgb,var(--type-color) 15%,transparent)}.exercise-creator-type-emoji{font-size:1.25rem;line-height:1}.exercise-creator-type-name{font-size:.85rem;font-weight:700}.exercise-creator-type-desc{font-size:.68rem;color:var(--color-text-muted);line-height:1.25}.exercise-creator-type-check{position:absolute;top:.45rem;right:.45rem;width:20px;height:20px;border-radius:50%;background:var(--type-color);color:#fff;display:flex;align-items:center;justify-content:center;animation:ecCheckPop .25s cubic-bezier(.34,1.56,.64,1)}@keyframes ecCheckPop{0%{transform:scale(0)}to{transform:scale(1)}}.exercise-creator-icon-preview{display:flex;align-items:center;gap:.6rem;padding:.5rem .7rem;background:#22c55e0f;border:1px solid rgba(34,197,94,.2);border-radius:12px}.exercise-creator-icon-preview-text{font-size:.78rem;font-weight:600;color:#22c55e}.exercise-creator-icon-search{position:relative}.exercise-creator-icon-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.exercise-creator-icon-categories{display:flex;flex-wrap:wrap;gap:.3rem}.exercise-creator-cat-btn{padding:.2rem .5rem;font-size:.7rem;font-weight:600;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff08;color:var(--color-text-muted);cursor:pointer;transition:all .12s ease}.exercise-creator-cat-btn:hover{border-color:#fff3;color:var(--color-text)}.exercise-creator-cat-btn.active{border-color:color-mix(in srgb,var(--cat-color) 60%,transparent);color:var(--cat-color);background:color-mix(in srgb,var(--cat-color) 8%,transparent)}.exercise-creator-icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:.35rem;max-height:220px;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.exercise-creator-icon-btn{display:flex;align-items:center;justify-content:center;padding:.35rem;border:1.5px solid rgba(255,255,255,.06);border-radius:12px;background:#ffffff05;color:var(--color-text);cursor:pointer;transition:all .14s ease;aspect-ratio:1}.exercise-creator-icon-btn:hover{border-color:#22c55e59;background:#22c55e0a}.exercise-creator-icon-btn.selected{border-color:#22c55e99;background:#22c55e14;box-shadow:0 0 12px #22c55e1f}.exercise-creator-icon-empty{grid-column:1 / -1;text-align:center;padding:1rem;color:var(--color-text-muted);font-size:.82rem}.exercise-creator-footer{display:flex;align-items:center;justify-content:flex-end;gap:.6rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.06)}.exercise-creator-save{font-weight:700;padding:.5rem 1.2rem}.exercise-creator-save:disabled{opacity:.4;cursor:not-allowed}.exercise-creator-success{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;padding:2.5rem 1rem;text-align:center}.exercise-creator-success-icon{width:56px;height:56px;border-radius:50%;background:linear-gradient(160deg,#34e85ef2,#22cc4eeb);color:#f0fdf4;display:flex;align-items:center;justify-content:center;animation:ecSuccessPop .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 8px 32px #22c55e59}@keyframes ecSuccessPop{0%{transform:scale(0);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.exercise-creator-success-title{font-size:1.1rem;font-weight:800;margin:0}.exercise-creator-success-text{font-size:.85rem;color:var(--color-text-muted);margin:0}@media (max-width: 768px){.logout-label{display:none}}@media (max-width: 900px){.fitness-coverflow{height:290px}.fitness-coverflow-card{width:min(500px,88%)}.fitness-touch-controls{grid-template-columns:1fr}.fitness-builder-row{flex-direction:column}.fitness-builder-row .form-group{width:100%!important}.fitness-workout-item-body{flex-direction:column;align-items:flex-start}.fitness-workout-actions{width:100%;justify-content:flex-end}}@media (min-width: 768px){.fitness-sheet-overlay,.fitness-builder-overlay{align-items:center;padding:40px 20px}.fitness-sheet,.fitness-builder-sheet{border-radius:16px;max-height:88vh;border-bottom:1px solid rgba(255,255,255,.08);animation:builderFadeScale .3s cubic-bezier(.16,1,.3,1);box-shadow:0 24px 80px #00000080}.fitness-sheet{padding:24px 28px 28px}.fitness-sheet-training{max-width:860px}.fitness-builder-sheet{max-width:640px}@keyframes builderFadeScale{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.fitness-builder-header .card-title,.fitness-sheet-title{font-size:1.25rem}.fitness-builder-row{flex-direction:row}}.shopping-page{min-height:100vh;padding-bottom:100px}.shopping-container{padding:0 var(--spacing-md)}.shopping-loading{display:flex;justify-content:center;align-items:center;min-height:40vh}.shopping-tabs-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:var(--spacing-lg)}.shopping-tabs-wrapper::-webkit-scrollbar{display:none}.shopping-tabs{display:flex;gap:var(--spacing-sm);min-width:max-content;padding:var(--spacing-xs) 0}.shopping-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:var(--color-text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.shopping-tab:hover{background:#ffffff14;color:var(--color-text)}.shopping-tab.active{background:#ec489926;border-color:#ec489966;color:#ec4899}.shopping-tab-delete{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:none;background:#ffffff1a;color:var(--color-text-muted);cursor:pointer;padding:0;transition:all .15s}.shopping-tab-delete:hover{background:#ef44444d;color:#ef4444}.shopping-tab-add{border-style:dashed;border-color:#ffffff1f;color:var(--color-text-muted);padding:8px 12px}.shopping-tab-add:hover{border-color:#ec489966;color:#ec4899}.shopping-tab-new-form{display:flex;align-items:center;gap:4px}.shopping-tab-input{width:120px;padding:6px 12px;border-radius:var(--radius-full);border:1px solid rgba(236,72,153,.4);background:#ec489914;color:var(--color-text);font-size:.875rem;outline:none}.shopping-tab-input:focus{border-color:#ec4899}.shopping-tab-confirm,.shopping-tab-cancel{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:none;cursor:pointer;padding:0;transition:all .15s}.shopping-tab-confirm{background:#10b98133;color:#10b981}.shopping-tab-confirm:hover{background:#10b98166}.shopping-tab-cancel{background:#ffffff14;color:var(--color-text-muted)}.shopping-tab-cancel:hover{background:#ef444433;color:#ef4444}.shopping-section-header{display:flex;align-items:baseline;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.shopping-section-header h2{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0}.shopping-count{font-size:.8rem;color:var(--color-text-muted)}.shopping-list-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);min-height:80px;margin-bottom:var(--spacing-lg);overflow:hidden}.shopping-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-md);color:var(--color-text-muted);text-align:center;gap:var(--spacing-sm)}.shopping-empty p{margin:0;font-size:.9rem}.shopping-empty-hint{font-size:.78rem!important;opacity:.6}.shopping-list-card{position:relative;transition:transform .25s cubic-bezier(.22,1,.36,1),opacity .2s;user-select:none;-webkit-user-select:none;touch-action:none;min-width:0}.shopping-list-card--placeholder{opacity:.12!important}.shopping-list-card--placeholder .shopping-card{border-style:dashed!important;border-color:#ec489933!important}.shopping-list-card--ghost{box-shadow:0 20px 60px #00000080,0 0 0 1px #ec489940;transform:scale(1.06);border-radius:var(--radius);overflow:hidden}.shopping-list-card--ghost .shopping-card{border-color:#ec489966!important;background:#1a1a1af7!important;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.shopping-pool-card{user-select:none;-webkit-user-select:none;touch-action:pan-y;transition:opacity .2s;min-width:0}.shopping-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:100%;min-width:0;aspect-ratio:1;padding:var(--spacing-sm);border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);background:#1a1a1ab3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;color:var(--color-text)}.shopping-card:hover{border-color:#ffffff1f;background:#2a2a2acc}.shopping-card:active{transform:scale(.95)}.shopping-card.in-list{border-color:#ec489959;background:#ec48991a}.shopping-card.in-list .shopping-card-icon{color:#ec4899}.shopping-card-check{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:#ec4899;color:#fff;display:flex;align-items:center;justify-content:center}.shopping-card-icon{color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0;width:48px;height:48px}.shopping-card-image{width:44px;height:44px;object-fit:contain;image-rendering:-webkit-optimize-contrast;-webkit-touch-callout:none;-webkit-user-select:none;pointer-events:none;-webkit-user-drag:none}.shopping-card-fallback{font-size:1.8rem;line-height:1}.shopping-card-name{font-size:.8rem;font-weight:500;color:var(--color-text);text-align:center;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shopping-card-added-by{font-size:.55rem;color:var(--color-text-muted);opacity:.7;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shopping-card-new{border-style:dashed;border-color:#ffffff1a;background:transparent}.shopping-card-new:hover{border-color:#ec489966;color:#ec4899}.shopping-card-new .shopping-card-icon,.shopping-card-new .shopping-card-name{color:var(--color-text-muted)}.shopping-flying-item{z-index:9999;pointer-events:none;animation:flyToList .45s cubic-bezier(.22,1,.36,1) forwards}.shopping-flying-item .shopping-card{border-color:#ec489980;background:#ec489926;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}@keyframes flyToList{0%{transform:translate(0) scale(1);opacity:1}60%{opacity:.9}to{transform:translate(var(--fly-dx),var(--fly-dy)) scale(.7);opacity:0}}.shopping-divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-xl) 0 var(--spacing-md);color:var(--color-text-muted);font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.shopping-divider:before,.shopping-divider:after{content:"";flex:1;height:1px;background:#ffffff14}.shopping-catalog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);overflow:hidden}.shopping-search-row{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.shopping-search-input{flex:1;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:var(--color-text);font-size:.9rem;outline:none}.shopping-search-input:focus{border-color:#ec489999;background:#ec489914}.shopping-search-count{min-width:36px;text-align:center;font-size:.75rem;color:var(--color-text-muted);padding:6px 8px;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.1);background:#ffffff0a}.shopping-no-list{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-md);color:var(--color-text-muted);text-align:center;gap:var(--spacing-md);min-height:50vh}.shopping-no-list p{margin:0;font-size:1rem}.shopping-no-list .btn{display:flex;align-items:center;gap:var(--spacing-sm)}.shopping-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.shopping-modal{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.08);padding:var(--spacing-lg);width:100%;max-width:360px;display:flex;flex-direction:column;gap:var(--spacing-md)}.shopping-modal h3{margin:0;font-size:1.1rem;color:var(--color-text)}.shopping-modal-field{display:flex;flex-direction:column;gap:6px}.shopping-modal-field label{font-size:.8rem;color:var(--color-text-muted);font-weight:500}.shopping-modal-field input{padding:10px 14px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--color-text);font-size:.95rem;outline:none;transition:border-color .2s}.shopping-modal-field input:focus{border-color:#ec4899}.shopping-icon-picker{display:flex;gap:var(--spacing-sm)}.shopping-icon-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--color-text-muted);cursor:pointer;transition:all .2s;flex:1}.shopping-icon-option span{font-size:.7rem}.shopping-icon-option:hover{background:#ffffff14}.shopping-icon-option.selected{border-color:#ec489980;background:#ec48991f;color:#ec4899}.shopping-icon-search{padding:8px 12px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--color-text);font-size:.85rem;outline:none;margin-bottom:6px;transition:border-color .2s}.shopping-icon-search:focus{border-color:#ec489980}.shopping-icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:6px;max-height:200px;overflow-y:auto;padding:4px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.06);background:#00000026}.shopping-icon-grid-item{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;border-radius:var(--radius-sm);border:2px solid transparent;background:#ffffff0a;cursor:pointer;padding:6px;transition:all .15s}.shopping-icon-grid-item:hover{background:#ffffff1a}.shopping-icon-grid-item.selected{border-color:#ec4899;background:#ec489926}.shopping-icon-grid-item img{width:28px;height:28px;object-fit:contain}.shopping-item-modal{max-width:400px}.shopping-item-delete-btn{margin-right:auto;padding:8px 12px!important;background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#ef4444;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;transition:all .15s}.shopping-item-delete-btn:hover{background:#ef444440;border-color:#ef444480}.shopping-modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-sm)}.shopping-modal-actions .btn{padding:8px 20px;font-size:.875rem}.shopping-bring-container{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.shopping-bring-toggle{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-full);border:1px solid transparent;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.shopping-bring-toggle.inactive{color:#ef4444;background:#ef44441f;border-color:#ef444466}.shopping-bring-toggle.active{color:#10b981;background:#10b9811f;border-color:#10b98166}.shopping-bring-toggle:disabled{opacity:.6;cursor:not-allowed}.shopping-bring-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-full);border:1px solid rgba(234,179,8,.4);background:#eab3081f;color:#eab308;font-size:.8rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s;flex-shrink:0}.shopping-bring-btn:hover:not(:disabled){background:#eab30833;border-color:#eab30899}.shopping-bring-btn:disabled{opacity:.6;cursor:wait}.shopping-bring-sync-btn{display:inline-flex;align-items:center;padding:6px 12px;border-radius:var(--radius-full);border:1px solid rgba(59,130,246,.4);background:#3b82f61f;color:#60a5fa;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.shopping-bring-sync-btn:hover:not(:disabled){background:#3b82f633;border-color:#3b82f6a6}.shopping-bring-sync-btn:disabled{opacity:.6;cursor:not-allowed}.shopping-bring-icon{font-size:1rem}.shopping-bring-badge{display:flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:#eab3084d;font-size:.65rem;font-weight:600}.shopping-bring-spinner{width:14px;height:14px;border:2px solid rgba(234,179,8,.2);border-top-color:#eab308;border-radius:50%;animation:spin .6s linear infinite}.shopping-bring-progress{display:flex;flex-direction:column;gap:2px;padding:4px 8px;background:#eab30814;border-radius:var(--radius-sm);border:1px solid rgba(234,179,8,.15);min-width:120px}.shopping-bring-stage{font-size:.7rem;color:#eab308;font-weight:500}.shopping-bring-count{font-size:.7rem;color:var(--color-text-muted)}.shopping-bring-current{font-size:.65rem;color:var(--color-text-muted);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (min-width: 768px){.shopping-list-grid,.shopping-catalog-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.todo-page{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.todo-tabs{display:flex;position:relative;padding:0 20px;flex-shrink:0;background:#ffffff05;border-bottom:1px solid rgba(255,255,255,.06)}.todo-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 0;background:none;color:var(--color-text-muted);font-size:.88rem;font-weight:600;letter-spacing:.01em;transition:color .3s;position:relative;z-index:1;-webkit-tap-highlight-color:transparent}.todo-tab.active{color:#22d3ee}.todo-tab-badge{background:#06b6d42e;color:#22d3ee;font-size:.68rem;font-weight:700;padding:2px 7px;border-radius:10px;min-width:20px;text-align:center;transition:all .3s}.todo-tab.active .todo-tab-badge{background:#06b6d44d}.todo-tab-indicator{position:absolute;bottom:-1px;left:20px;width:calc((100% - 40px)/2);height:2px;background:linear-gradient(90deg,#06b6d4,#22d3ee);border-radius:2px 2px 0 0;transition:transform .35s cubic-bezier(.32,.72,0,1);will-change:transform;box-shadow:0 0 16px #06b6d480}.todo-panel-header{display:none}.todo-swipe{flex:1;min-height:0;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:none;-ms-overflow-style:none}.todo-swipe::-webkit-scrollbar{display:none}.todo-track{display:flex;width:200%;height:100%}.todo-panel{width:50%;height:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;scroll-snap-align:start;scrollbar-width:none}.todo-panel::-webkit-scrollbar{display:none}.todo-list{max-width:480px;margin:0 auto;padding:0 16px calc(100px + env(safe-area-inset-bottom,0px))}.todo-add{position:sticky;top:0;z-index:10;padding:14px 0 20px}.todo-add-inner{display:flex;gap:10px;align-items:center}.todo-add-input{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:12px 16px;color:var(--color-text);font-size:.9rem;transition:all .25s;min-height:48px}.todo-add-input:focus{border-color:#06b6d473;background:#ffffff12;box-shadow:0 0 0 3px #06b6d41a,0 4px 20px #06b6d40f}.todo-add-input::placeholder{color:var(--color-text-disabled)}.todo-add-btn{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;box-shadow:0 4px 16px #06b6d44d}.todo-add-btn:disabled{opacity:.2;box-shadow:none;pointer-events:none}.todo-add-btn:active{transform:scale(.9);box-shadow:0 2px 8px #06b6d433}.todo-sections{display:flex;flex-direction:column;gap:4px}.todo-section{margin-bottom:4px}.todo-section-header{display:flex;align-items:center;gap:10px;padding:16px 4px 10px}.todo-section-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#22d3ee;white-space:nowrap}.todo-section-count{font-size:.6rem;font-weight:600;color:var(--color-text-disabled);background:#06b6d414;padding:2px 7px;border-radius:8px}.todo-section-line{flex:1;height:1px;background:linear-gradient(90deg,#06b6d433,#ffffff08)}.todo-section-items{display:flex;flex-direction:column;gap:8px}.todo-item{display:flex;align-items:center;gap:6px;padding:12px 12px 12px 6px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:16px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .15s,border-color .15s,opacity .2s,transform .2s;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative}.todo-item:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(6,182,212,.08) 50%,transparent);border-radius:16px 16px 0 0;opacity:0;transition:opacity .2s}.todo-item:active{background:#ffffff12}.todo-item:active:before{opacity:1}.todo-grip{color:var(--color-text-disabled);padding:8px 4px;flex-shrink:0;touch-action:none;cursor:grab;background:none;display:flex;align-items:center;opacity:.35;transition:opacity .15s}.todo-grip:active{opacity:1;color:var(--color-text-muted)}.todo-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px;padding:0 6px}.todo-text{font-size:.9rem;color:var(--color-text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.todo-meta{display:flex;flex-wrap:wrap;align-items:center;gap:4px}.todo-item--has-notes:after{content:"";position:absolute;top:6px;right:6px;width:5px;height:5px;border-radius:50%;background:#06b6d466}.todo-tag{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:6px;background:color-mix(in srgb,var(--tc) 15%,transparent);color:var(--tc);line-height:1.5}.todo-up{color:var(--color-text-disabled);padding:8px;flex-shrink:0;border-radius:10px;background:none;transition:all .15s;display:flex;align-items:center}.todo-up:active{color:#22d3ee;background:#06b6d41f;transform:translateY(-2px) scale(.92)}.todo-check{color:#ffffff2e;padding:6px;flex-shrink:0;border-radius:50%;background:none;transition:all .15s;display:flex;align-items:center}.todo-check:active{color:var(--color-success);transform:scale(.88)}.todo-item--completing{animation:todoComplete .45s cubic-bezier(.32,.72,0,1) forwards}.todo-item--completing .todo-check{color:var(--color-success);animation:checkPop .35s cubic-bezier(.34,1.56,.64,1)}.todo-item--completing .todo-text{text-decoration:line-through;text-decoration-color:var(--color-text-muted);color:var(--color-text-muted)}@keyframes todoComplete{0%{opacity:1;transform:scale(1) translate(0)}40%{opacity:1;transform:scale(1.015) translate(0)}to{opacity:0;transform:scale(.97) translate(24px)}}@keyframes checkPop{0%{transform:scale(1)}50%{transform:scale(1.35)}to{transform:scale(1)}}.todo-item--placeholder{opacity:.1!important;border-style:dashed!important;border-color:#06b6d426!important}.todo-item--ghost{box-shadow:0 20px 60px #00000080,0 0 0 1px #06b6d440;transform:scale(1.04);border-color:#06b6d44d!important;background:#1a1a1af7!important;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:16px}.todo-done{margin-top:24px;padding-top:4px}.todo-done-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:12px 4px;background:none;color:var(--color-text-muted);font-size:.78rem;font-weight:500;-webkit-tap-highlight-color:transparent;transition:color .15s}.todo-done-toggle:active{color:var(--color-text-secondary)}.todo-done-chevron{margin-left:auto;transition:transform .3s cubic-bezier(.32,.72,0,1)}.todo-done-chevron.open{transform:rotate(180deg)}.todo-done-list{display:flex;flex-direction:column;gap:6px;animation:fadeSlideIn .3s ease;padding-top:4px}.todo-item--done{opacity:.4;cursor:default;padding:10px 12px 10px 14px}.todo-item--done .todo-text{text-decoration:line-through;text-decoration-color:#ffffff26;color:var(--color-text-muted);font-size:.85rem}.todo-check--done{color:var(--color-success)!important;opacity:.6}.todo-delete-sm{color:var(--color-text-disabled);padding:8px;background:none;border-radius:10px;display:flex;align-items:center;flex-shrink:0;transition:all .15s}.todo-delete-sm:active{color:var(--color-danger);background:#ef44441a}.todo-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px 40px;text-align:center}.todo-empty-icon{color:#22d3ee;opacity:.15;margin-bottom:20px}.todo-empty p{color:var(--color-text-secondary);font-size:1rem;font-weight:500;margin-bottom:6px}.todo-empty span{color:var(--color-text-muted);font-size:.82rem}.todo-modal{max-height:85vh;max-height:85dvh}.todo-modal-section{margin-bottom:24px}.todo-modal-input{width:100%;background:none;border:none;border-bottom:1.5px solid rgba(255,255,255,.08);color:var(--color-text);font-size:1.15rem;font-weight:500;padding:6px 0 12px;transition:border-color .2s}.todo-modal-input:focus{outline:none;border-color:#06b6d480}.todo-modal-input::placeholder{color:var(--color-text-disabled)}.todo-modal-label{display:flex;align-items:center;gap:6px;color:var(--color-text-muted);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}.todo-modal-pills{display:flex;flex-wrap:wrap;gap:7px}.todo-pill{padding:7px 14px;border-radius:20px;font-size:.78rem;font-weight:500;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:var(--color-text-secondary);transition:all .2s;-webkit-tap-highlight-color:transparent}.todo-pill:active{transform:scale(.95)}.todo-pill.active{background:#06b6d426;border-color:#06b6d466;color:#22d3ee;font-weight:600}.todo-pill--tag.active{background:color-mix(in srgb,var(--tc) 15%,transparent);border-color:color-mix(in srgb,var(--tc) 35%,transparent);color:var(--tc)}.todo-pill-wrap{position:relative;display:inline-flex}.todo-tag-del-btn{position:absolute;top:-5px;right:-5px;width:16px;height:16px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.12);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;opacity:.45;transition:opacity .15s,background .15s,color .15s;z-index:1;padding:0}.todo-tag-del-btn:active{background:#ef444433;color:var(--color-danger)}.todo-tag-del-confirm{position:absolute;top:-6px;right:-6px;display:flex;gap:2px;z-index:2}.todo-tag-del-yes,.todo-tag-del-no{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0;transition:transform .15s}.todo-tag-del-yes{background:var(--color-danger);color:#fff}.todo-tag-del-no{background:#ffffff1a;color:var(--color-text-muted);border:1px solid rgba(255,255,255,.1)}.todo-tag-del-yes:active,.todo-tag-del-no:active{transform:scale(.88)}.todo-pill--add{display:flex;align-items:center;gap:5px;border-style:dashed;border-color:#ffffff1f;color:var(--color-text-muted);font-size:.75rem}.todo-pill--add:active{border-color:#06b6d466;color:#22d3ee;background:#06b6d414}.todo-new-tag{width:100%;display:flex;flex-direction:column;gap:10px;padding:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:14px;animation:fadeSlideIn .2s ease}.todo-new-tag-input{width:100%;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:9px 12px;color:var(--color-text);font-size:.85rem;transition:border-color .2s}.todo-new-tag-input:focus{outline:none;border-color:#06b6d466}.todo-new-tag-input::placeholder{color:var(--color-text-disabled)}.todo-new-tag-colors{display:flex;gap:6px;flex-wrap:wrap}.todo-color-dot{width:22px;height:22px;border-radius:50%;border:2px solid transparent;transition:border-color .15s,transform .15s;padding:0}.todo-color-dot.active{border-color:#fff;transform:scale(1.15);box-shadow:0 0 8px #fff3}.todo-color-dot:active{transform:scale(.9)}.todo-new-tag-actions{display:flex;gap:8px}.todo-new-tag-save{padding:7px 16px;border-radius:10px;background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff;font-size:.78rem;font-weight:600;transition:all .15s}.todo-new-tag-save:disabled{opacity:.3;pointer-events:none}.todo-new-tag-save:active{transform:scale(.95)}.todo-new-tag-cancel{padding:7px 16px;border-radius:10px;background:#ffffff0f;color:var(--color-text-secondary);font-size:.78rem;font-weight:500}.todo-new-tag-cancel:active{transform:scale(.95)}.todo-modal-textarea{width:100%;background:#ffffff09;border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:12px 14px;color:var(--color-text);font-size:.85rem;resize:vertical;min-height:72px;font-family:inherit;line-height:1.5;transition:border-color .2s}.todo-modal-textarea:focus{outline:none;border-color:#06b6d459}.todo-modal-textarea::placeholder{color:var(--color-text-disabled)}.todo-modal-footer{border-top:1px solid rgba(255,255,255,.06);padding-top:16px;margin-top:4px}.todo-modal-del{display:flex;align-items:center;gap:6px;background:none;color:var(--color-text-muted);font-size:.82rem;padding:8px 0;transition:color .15s}.todo-modal-del:active{color:var(--color-danger)}.todo-modal-confirm{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--color-text-secondary)}.todo-modal-yes{background:var(--color-danger);color:#fff;padding:7px 16px;border-radius:10px;font-size:.78rem;font-weight:600}.todo-modal-yes:active{transform:scale(.95)}.todo-modal-no{background:#ffffff0f;color:var(--color-text-secondary);padding:7px 16px;border-radius:10px;font-size:.78rem;font-weight:500}.todo-modal-no:active{transform:scale(.95)}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media (min-width: 768px){.todo-tabs{display:none}.todo-panel-header{display:flex;align-items:center;gap:10px;padding:6px 4px 2px}.todo-panel-title{font-size:1.15rem;font-weight:700;color:var(--color-text);letter-spacing:-.01em}.todo-panel-badge{background:#06b6d426;color:#22d3ee;font-size:.7rem;font-weight:700;padding:2px 9px;border-radius:10px}.todo-swipe{overflow-x:hidden;scroll-snap-type:none}.todo-track{width:100%!important;gap:0}.todo-panel{width:50%!important;scroll-snap-align:none;border-right:1px solid rgba(255,255,255,.04)}.todo-panel:last-child{border-right:none}.todo-list{max-width:100%;padding-left:28px;padding-right:28px}.todo-item:hover{background:#ffffff0f;border-color:#ffffff17}.todo-item:hover:before{opacity:1}.todo-up:hover{color:#22d3ee;background:#06b6d414}.todo-check:hover{color:var(--color-success)}.todo-delete-sm:hover{color:var(--color-danger);background:#ef444414}.todo-done-toggle:hover{color:var(--color-text-secondary)}.todo-pill:hover{background:#ffffff12;border-color:#ffffff1f}.todo-grip{opacity:0;transition:opacity .2s}.todo-item:hover .todo-grip{opacity:.5}}.todo-tag-del-btn{opacity:0}.todo-pill-wrap:hover .todo-tag-del-btn{opacity:1}} @media (min-width: 1200px){.todo-swipe{max-width:1000px;margin:0 auto;width:100%}}.user-settings-page{min-height:100vh}.settings-card{max-width:640px}.settings-card:hover{transform:none}.settings-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.settings-section-header{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text)}.settings-section-header h2{font-size:1.1rem;font-weight:600;margin:0}.settings-hint{color:var(--color-text-muted);font-size:.85rem;margin:0;line-height:1.5}.email-form{display:flex;gap:var(--spacing-sm);align-items:center}.email-form .input{flex:1}.email-form .btn{display:flex;align-items:center;gap:6px;white-space:nowrap;padding:10px 16px}.btn-success-flash{background:#22c55e!important;border-color:#22c55e!important}.saved-indicator{display:flex;align-items:center;gap:4px;color:#22c55e;font-size:.8rem;font-weight:500;margin-left:auto;animation:fadeInOut 1.5s ease}@keyframes fadeInOut{0%{opacity:0}20%{opacity:1}80%{opacity:1}to{opacity:0}}.btn-enable-all{display:flex;align-items:center;gap:6px;padding:8px 14px;font-size:.8rem;font-weight:500;border-radius:var(--radius-sm);border:1px solid rgba(124,58,237,.4);background:#7c3aed1a;color:#a78bfa;cursor:pointer;transition:all .2s;align-self:flex-start}.btn-enable-all:hover:not(:disabled){background:#7c3aed33;border-color:#7c3aed99}.btn-enable-all:disabled{opacity:.5;cursor:default}.btn-enable-all.all-active{border-color:#22c55e66;background:#22c55e1a;color:#4ade80}.feature-toggle-list{display:flex;flex-direction:column;gap:0}.feature-toggle-header{display:flex;align-items:center;padding:0 16px 8px;gap:var(--spacing-md)}.feature-toggle-header-label{flex:1;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.feature-toggle-header-col{width:52px;text-align:center;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);flex-shrink:0}.feature-toggle-row{display:flex;align-items:center;gap:var(--spacing-md);padding:10px 16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);transition:background .2s;margin-bottom:6px}.feature-toggle-row:hover{background:#ffffff14}.feature-toggle-info{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0}.feature-toggle-col{width:52px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.feature-toggle-na{color:var(--color-text-muted);font-size:.85rem;opacity:.4}.app-toggle-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--app-color) 20%,transparent);color:var(--app-color);flex-shrink:0}.app-toggle-name{flex:1;font-size:.9rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-toggle-switch{width:40px;height:22px;border-radius:11px;background:#ffffff1a;border:none;padding:0;position:relative;transition:background .2s;flex-shrink:0;cursor:pointer}.app-toggle-switch:hover{background:#ffffff2e}.app-toggle-switch.on{background:#7c3aed}.app-toggle-switch.on:hover{background:#6d28d9}.app-toggle-knob{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #0000004d}.app-toggle-switch.on .app-toggle-knob{transform:translate(18px)}@media (max-width: 480px){.email-form{flex-direction:column}.email-form .btn{width:100%;justify-content:center}}.container{max-width:1400px;margin:0 auto;padding:var(--spacing-lg);padding-top:var(--spacing-xs);padding-left:max(var(--spacing-lg),env(safe-area-inset-left,var(--spacing-lg)));padding-right:max(var(--spacing-lg),env(safe-area-inset-right,var(--spacing-lg)));padding-bottom:max(var(--spacing-lg),env(safe-area-inset-bottom,var(--spacing-lg)))}@media (min-width: 768px){.container{padding:var(--spacing-xl);padding-top:var(--spacing-sm);padding-left:max(var(--spacing-xl),env(safe-area-inset-left,var(--spacing-xl)));padding-right:max(var(--spacing-xl),env(safe-area-inset-right,var(--spacing-xl)));padding-bottom:max(var(--spacing-xl),env(safe-area-inset-bottom,var(--spacing-xl)))}}.card{background:#1a1a1a99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--radius-md);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-lg);border:1px solid rgba(255,255,255,.05);transition:all .3s ease;position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(147,51,234,.3),transparent);opacity:0;transition:opacity .3s ease}.card:hover{box-shadow:var(--shadow-lg);border-color:#ffffff1a;background:#1a1a1abf;transform:translateY(-2px)}.card:hover:before{opacity:1}@media (min-width: 768px){.card{padding:var(--spacing-xl)}}.btn{padding:.625rem 1.25rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);min-height:40px;cursor:pointer;font-family:inherit}.btn-primary{background:var(--color-surface-light);color:var(--color-text);border:1px solid var(--color-border)}.btn-primary:hover{background:var(--color-surface-hover);border-color:var(--color-border-light)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--color-primary);color:#fff;border:none}.btn-secondary:hover{background:var(--color-primary-light)}.btn-danger{background:var(--color-danger);color:#fff;border:none}.btn-danger:hover{background:#dc2626;opacity:.9}.btn-outline{background:transparent;border:1px solid var(--color-border-light);color:var(--color-text-secondary)}.btn-outline:hover{background:var(--color-surface);border-color:var(--color-border-light);color:var(--color-text)}.btn-full{width:100%;margin-top:var(--spacing-lg)}.btn-icon{width:44px;height:44px;padding:0;border-radius:var(--radius);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:relative}.btn-icon:hover{background:#9333ea26;border-color:#9333ea4d;color:var(--color-primary-light);transform:translateY(-2px)}.btn-icon .badge-count{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--color-danger);color:#fff;font-size:.6875rem;font-weight:600;display:flex;align-items:center;justify-content:center}.input,select{width:100%;padding:.625rem .875rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.875rem;transition:all .2s ease;min-height:40px;background:var(--color-surface);color:var(--color-text)}.input:focus,select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #9333ea1a}.input-error{border-color:var(--color-danger)}.input-error:focus{box-shadow:0 0 0 3px #ef44441a}.label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--color-text-secondary);font-size:.875rem}.error-message{color:var(--color-danger);font-size:.8125rem;margin-top:var(--spacing-sm)}.success-message{color:var(--color-success);font-size:.8125rem;margin-top:var(--spacing-sm)}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:500;line-height:1}.badge-success{background:#10b98126;color:var(--color-success)}.badge-warning{background:#f59e0b26;color:var(--color-warning)}.badge-danger{background:#ef444426;color:var(--color-danger)}.badge-primary{background:#9333ea26;color:var(--color-primary-light)}.badge-redeemed{background:#ec489926;color:#f472b6}.header{background:transparent;border-bottom:none;padding:var(--spacing-lg);padding-top:var(--spacing-lg);box-shadow:none;margin:0;width:100%;padding-left:max(var(--spacing-lg),env(safe-area-inset-left,0px));padding-right:max(var(--spacing-lg),env(safe-area-inset-right,0px))}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.header-title{font-size:1.5rem;font-weight:600;color:var(--color-text);letter-spacing:-.02em}.header-actions{display:flex;gap:var(--spacing-md);align-items:center}.grid{display:grid;gap:var(--spacing-lg)}.grid-2{grid-template-columns:1fr}@media (min-width: 768px){.grid-2{grid-template-columns:repeat(2,1fr)}}.grid-3{grid-template-columns:1fr}@media (min-width: 768px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.grid-3{grid-template-columns:repeat(3,1fr)}}.empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg);color:var(--color-text-muted)}.empty-state-icon{color:var(--color-text-muted);margin-bottom:var(--spacing-md);opacity:.5}.empty-state p{color:var(--color-text-secondary);font-size:.875rem}.loading{display:flex;justify-content:center;align-items:center;padding:var(--spacing-xl)}.spinner{width:1.5rem;height:1.5rem;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dev-switcher{position:fixed;top:0;left:0;right:0;z-index:99999;display:flex;align-items:center;gap:6px;padding:4px 8px;background:#eab3081f;border-bottom:1px solid rgba(234,179,8,.25);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);font-size:.72rem}.dev-switcher-label{font-weight:700;color:#eab308;letter-spacing:.08em;flex-shrink:0}.dev-switcher-users{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none}.dev-switcher-users::-webkit-scrollbar{display:none}.dev-switcher-btn{display:flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.06);background:#ffffff0a;color:var(--color-text-muted);cursor:pointer;white-space:nowrap;font-size:.72rem;transition:all .15s}.dev-switcher-btn:hover{background:#ffffff1a;color:var(--color-text)}.dev-switcher-btn.active{background:#eab30833;border-color:#eab30866;color:#eab308}.dev-switcher-role{font-size:.6rem;opacity:.6;text-transform:uppercase;letter-spacing:.04em}.email-prompt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100000;display:flex;align-items:center;justify-content:center;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:var(--spacing-lg);animation:emailFadeIn .25s ease}@keyframes emailFadeIn{0%{opacity:0}to{opacity:1}}.email-prompt-modal{position:relative;width:100%;max-width:400px;background:#1e1e1ef2;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:var(--spacing-2xl) var(--spacing-xl);box-shadow:0 24px 48px #0006,0 0 40px #9333ea14;text-align:center;animation:emailSlideUp .3s ease}@keyframes emailSlideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.email-prompt-close{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:color .2s,background .2s}.email-prompt-close:hover{color:var(--color-text);background:#ffffff14}.email-prompt-icon{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;background:#9333ea26;color:#a855f7;margin-bottom:var(--spacing-lg)}.email-prompt-title{font-size:1.25rem;font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-sm)}.email-prompt-text{font-size:.875rem;color:var(--color-text-secondary);line-height:1.5;margin-bottom:var(--spacing-xl)}.email-prompt-form{display:flex;flex-direction:column;gap:var(--spacing-sm)}.email-prompt-form .btn-full{margin-top:var(--spacing-sm)}.email-prompt-skip{background:none;border:none;color:var(--color-text-muted);font-size:.85rem;cursor:pointer;padding:8px;transition:color .2s}.email-prompt-skip:hover{color:var(--color-text);text-decoration:underline}.update-banner{position:fixed;bottom:0;left:0;right:0;z-index:99999;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;padding-bottom:max(14px,env(safe-area-inset-bottom,14px));background:#9333eaeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;animation:updateSlideUp .35s ease;-webkit-tap-highlight-color:transparent}.update-banner:active{background:#7e22cef2}@keyframes updateSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ptr-indicator{position:fixed;top:0;left:0;right:0;display:flex;justify-content:center;z-index:99998;pointer-events:none;padding-top:env(safe-area-inset-top,0px)}.ptr-spinner{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--color-primary-light);transition:transform .05s linear}.ptr-spinner.ptr-spinning{animation:ptr-spin .7s linear infinite}@keyframes ptr-spin{to{transform:rotate(360deg)}}.no-group-banner{display:flex;align-items:center;gap:10px;margin:0 var(--spacing-md);padding:12px 16px;background:#f9731614;border:1px solid rgba(249,115,22,.2);border-radius:var(--radius);color:#fb923c;font-size:.85rem;font-weight:500;line-height:1.4}*{margin:0;padding:0;box-sizing:border-box}html{height:100%;margin:0;padding:0;background:#2a003c;background-attachment:fixed;background-size:100% 100%}:root{--color-primary: #9333ea;--color-primary-light: #a855f7;--color-primary-dark: #7e22ce;--color-secondary: #10b981;--color-secondary-light: #34d399;--color-accent-purple: #9333ea;--color-accent-blue: #3b82f6;--color-accent-orange: #f97316;--color-accent-red: #ef4444;--color-accent-pink: #ec4899;--color-success: #10b981;--color-danger: #ef4444;--color-warning: #f59e0b;--color-bg: #0a0a0a;--color-bg-secondary: #111111;--color-surface: #1a1a1a;--color-surface-hover: #242424;--color-surface-light: #2a2a2a;--color-text: #ffffff;--color-text-secondary: #d1d5db;--color-text-muted: #9ca3af;--color-text-disabled: #6b7280;--color-border: #2a2a2a;--color-border-light: #3a3a3a;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .5);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .6);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .7);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .8);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .9);--radius-sm: 8px;--radius: 12px;--radius-md: 16px;--radius-lg: 20px;--radius-full: 9999px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-text);line-height:1.6;overflow-x:hidden;min-height:100vh;min-height:100dvh;min-height:-webkit-fill-available;height:100%;font-size:14px;position:relative;margin:0;padding:0;background:linear-gradient(to top,#2a003c,#29003a,#270039,#260037,#250036,#230133,#220130,#20012d,#1d0128,#1b0123,#18001f,#14001a,#18001f,#1b0123,#1d0128,#20012d,#220130,#230133,#250036,#260037,#270039,#29003a,#2a003c);background-attachment:fixed;background-size:100% 100%}@media all and (display-mode: standalone){body{overscroll-behavior-y:none}}#root{min-height:100vh;min-height:100dvh;min-height:-webkit-fill-available;width:100%;position:relative;z-index:1;margin:0;padding:0;background:transparent}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .2s ease}input,select,textarea{font-family:inherit;outline:none}a{text-decoration:none;color:inherit}button,a{-webkit-tap-highlight-color:transparent}.no-select{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-surface-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}
