*{margin:0;padding:0;box-sizing:border-box}html{background:var(--bg-body)}body{font-family:Inter,sans-serif;color:var(--text-primary);background:var(--bg-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;min-height:100dvh;background:var(--bg-body);--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-bottom: var(--safe-area-bottom);--nav-clearance: calc(80px + var(--safe-area-bottom))}.login-container{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-header);padding:calc(20px + var(--safe-area-top)) 20px 20px}.login-theme-toggle{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:background .2s,color .2s}.login-theme-toggle:hover{color:var(--text-primary)}.login-card{background:var(--bg-card);border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:30px}.login-logo{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--color-primary);margin-bottom:16px;transition:transform .3s ease}.login-logo:hover{transform:scale(1.05)}.login-header p{color:var(--text-secondary);font-family:Inter,sans-serif;font-size:1rem;margin:0}.error-message{background:var(--color-error-bg);border:1px solid var(--color-error);color:var(--color-error);padding:12px;border-radius:10px;margin-bottom:20px;font-size:.9rem;text-align:center}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--text-primary);font-family:Inter,sans-serif;font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:10px;font-size:1rem;font-family:Inter,sans-serif;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;background:var(--bg-input);color:var(--text-primary)}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-group input::placeholder{color:var(--text-tertiary)}.remember-me{margin-bottom:20px}.remember-me label{display:flex;align-items:center;gap:10px;cursor:pointer;font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-secondary)}.remember-me input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.login-btn{width:100%;padding:14px;background:var(--color-primary);color:#fff;border:none;border-radius:12px;font-size:1rem;font-family:Plus Jakarta Sans,sans-serif;font-weight:600;cursor:pointer;box-shadow:var(--shadow-primary);transition:background .2s,transform .1s}.login-btn:hover:not(:disabled){background:var(--color-primary-dark)}.login-btn:active:not(:disabled){transform:scale(.98)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.forgot-link{display:block;width:100%;background:none;border:none;text-align:center;margin:16px 0;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.85rem;cursor:pointer;transition:color .2s;padding:0}.forgot-link:hover{color:var(--color-primary)}.reset-sent{text-align:center;padding:10px 0}.reset-sent-icon{width:56px;height:56px;margin:0 auto 16px;color:var(--color-primary)}.reset-sent-icon svg{width:100%;height:100%}.reset-sent p{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 6px}.reset-sent span{font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-secondary)}.back-link{display:block;text-align:center;margin-top:20px;color:var(--text-secondary);text-decoration:none;font-size:.9rem;transition:color .2s}.back-link:hover{color:var(--color-primary)}.login-divider{display:flex;align-items:center;gap:12px;margin:16px 0 20px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.login-divider span{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-tertiary);text-transform:lowercase}.google-btn{width:100%;padding:14px;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .2s,border-color .2s}.google-btn:hover:not(:disabled){background:var(--bg-body);border-color:var(--text-tertiary)}.google-btn:active:not(:disabled){transform:scale(.98)}.google-btn:disabled{opacity:.7;cursor:not-allowed}.apple-btn{width:100%;padding:14px;border-radius:12px;border:none;background:#000;color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;margin-top:10px;transition:background .2s}.apple-btn:hover:not(:disabled){background:#1a1a1a}.apple-btn:active:not(:disabled){transform:scale(.98)}.apple-btn:disabled{opacity:.7;cursor:not-allowed}.login-signup-wrapper{position:relative;margin-top:16px}.login-btn-outline{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary);box-shadow:none;margin-top:10px}.login-coming-soon{pointer-events:none;-webkit-user-select:none;user-select:none;overflow:hidden}.login-coming-soon-overlay{position:absolute;inset:0;z-index:3;border-radius:12px;background:#0000008c;display:flex;align-items:center;justify-content:center}[data-theme=light] .login-coming-soon-overlay{background:#fff9}.login-coming-soon-overlay span{font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:700;color:#fff;letter-spacing:.08em;text-transform:uppercase;padding:6px 18px;border:2px solid rgba(255,255,255,.4);border-radius:30px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}[data-theme=light] .login-coming-soon-overlay span{color:var(--text-primary);border-color:var(--border-color)}.portal-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:40px;width:100%;max-width:480px;box-shadow:var(--shadow-lg)}.portal-subtitle{color:var(--text-tertiary);font-family:Inter,sans-serif;font-size:.85rem;margin:4px 0 0}.portal-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.portal-option{background:var(--bg-input);border:1px solid var(--border-color);border-top:3px solid var(--color-primary);border-radius:16px;padding:24px 16px 20px;cursor:pointer;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s,transform .15s}[data-theme=dark] .portal-option{background:var(--bg-card-elevated)}.portal-option:hover{border-color:var(--color-primary);border-top-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.portal-option:active{transform:scale(.97);box-shadow:var(--shadow-sm)}.portal-option:last-child:nth-child(odd){grid-column:1 / -1;max-width:calc(50% - 8px);margin:0 auto;width:100%}.portal-option-icon{width:52px;height:52px;border-radius:50%;background:var(--color-primary);color:var(--text-on-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.portal-option-icon svg{width:24px;height:24px}.portal-option-label{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.78rem;color:var(--text-primary);letter-spacing:.02em;line-height:1.3}.portal-option-desc{font-family:Inter,sans-serif;font-size:.75rem;color:var(--text-secondary);line-height:1.4}.login-back-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:none;padding:0;margin-bottom:16px;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.85rem;cursor:pointer;transition:color .2s}.login-back-btn:hover{color:var(--color-primary)}.login-type-label{display:inline-block;margin-top:6px;padding:3px 10px;border-radius:20px;background:var(--color-primary-light);color:var(--color-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.03em}.login-loading{display:flex;align-items:center;justify-content:center}.loading-logo{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--color-primary)}.native-login{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-body);padding:60px 32px 40px;box-sizing:border-box}.native-login .login-theme-toggle{position:fixed;top:16px;right:16px;z-index:10}.native-login-back{position:fixed;top:20px;left:20px;display:inline-flex;align-items:center;gap:5px;background:none;border:none;padding:0;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.85rem;cursor:pointer;transition:color .2s;z-index:10}.native-login-back:hover{color:var(--color-primary)}.native-login-actions{width:100%;max-width:380px;display:flex;flex-direction:column;gap:12px}.native-login-btn:hover:not(:disabled){opacity:.9}.native-login-field input{width:100%;padding:14px 16px;border:1px solid var(--border-color);border-radius:12px;font-size:1rem;font-family:Inter,sans-serif;background:var(--bg-input);color:var(--text-primary);box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.native-login-field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.native-login-link{background:none;border:none;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.85rem;cursor:pointer;text-align:center;padding:4px 0;transition:color .2s}.native-login-link:hover{color:var(--color-primary)}.native-login-error{width:100%;max-width:380px;background:var(--color-error-bg);border:1px solid var(--color-error);color:var(--color-error);padding:12px;border-radius:12px;margin-bottom:16px;font-size:.9rem;text-align:center;box-sizing:border-box}.native-login-reset-sent{text-align:center;width:100%;max-width:380px}.native-login-success{width:100%;max-width:380px;background:var(--color-success-bg, rgba(34, 197, 94, .1));border:1px solid var(--color-success, #22c55e);color:var(--color-success, #22c55e);padding:12px;border-radius:12px;margin-bottom:16px;font-size:.9rem;text-align:center;box-sizing:border-box}.native-login{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-body);padding:calc(60px + var(--safe-area-top)) 32px calc(40px + var(--safe-area-bottom));box-sizing:border-box}.native-login .login-theme-toggle{position:fixed;top:calc(12px + var(--safe-area-top));right:16px;z-index:10}.native-login-brand{text-align:center;margin-bottom:48px}.native-login-logo{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--color-primary);margin-bottom:16px}.native-login-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.4rem;font-weight:700;color:var(--text-primary);margin:0 0 6px}.native-login-subtitle{font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-tertiary);margin:0}.native-login-actions{width:100%;max-width:340px;display:flex;flex-direction:column;gap:12px}.native-login-btn{width:100%;padding:16px;border-radius:14px;font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:transform .1s,opacity .2s;border:none;-webkit-tap-highlight-color:transparent}.native-login-btn:active:not(:disabled){transform:scale(.97)}.native-login-btn:disabled{opacity:.6;cursor:not-allowed}.native-login-btn-apple{background:#000;color:#fff}[data-theme=dark] .native-login-btn-apple{background:#fff;color:#000}.native-login-btn-google{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.native-login-btn-email{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.native-login-btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-primary)}.native-login-divider{display:flex;align-items:center;gap:12px;margin:4px 0}.native-login-divider:before,.native-login-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.native-login-divider span{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-tertiary)}.native-login-email-form{display:flex;flex-direction:column;gap:14px}.native-login-field label{display:block;margin-bottom:6px;color:var(--text-primary);font-family:Inter,sans-serif;font-weight:500;font-size:.85rem}.native-login-field input{width:100%;padding:14px 16px;border:1px solid var(--border-color);border-radius:12px;font-size:1rem;font-family:Inter,sans-serif;background:var(--bg-input);color:var(--text-primary);box-sizing:border-box;transition:border-color .2s}.native-login-field input:focus{outline:none;border-color:var(--color-primary)}.native-login-link{background:none;border:none;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.85rem;cursor:pointer;text-align:center;padding:4px 0}.native-login-error{width:100%;max-width:340px;background:var(--color-error-bg);border:1px solid var(--color-error);color:var(--color-error);padding:12px;border-radius:12px;margin-bottom:16px;font-size:.9rem;text-align:center;box-sizing:border-box}.native-login-reset-sent{text-align:center;width:100%;max-width:340px}.native-login-reset-sent p{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:16px 0 6px}.native-login-reset-sent span{font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-secondary);display:block;margin-bottom:24px}.native-login-loading,.native-login-splash{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-body);transition:opacity .6s ease-out}.native-login-loading{gap:24px}.native-login-splash-fadeout{opacity:0}.native-login-splash-inner{display:flex;flex-direction:column;align-items:center}.native-login-splash-logo{width:140px;height:140px;object-fit:cover;border-radius:50%;border:3px solid var(--color-primary);animation:splash-logo-fade 1s ease-out both}.native-login-splash-name{font-family:Plus Jakarta Sans,Inter,sans-serif;font-size:22px;font-weight:700;color:var(--text-primary);margin:0;padding-top:32px;height:70px;animation:splash-text-fade .8s ease-out 1.5s both;opacity:0}@keyframes splash-logo-fade{0%{opacity:0}to{opacity:1}}@keyframes splash-text-fade{0%{opacity:0}to{opacity:1}}.native-login-spinner{width:36px;height:36px;border:3px solid var(--color-primary-light);border-top-color:var(--color-primary);border-radius:50%;animation:app-spin .7s linear infinite}.native-login-mode-toggle{text-align:center;margin-top:8px}.native-login-mode-toggle .native-login-link{font-size:.9rem;color:var(--text-secondary)}.native-login-mode-toggle .native-login-link strong{color:var(--color-primary)}.native-login-verify-hint{text-align:center;font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin:0 0 16px}.native-login-success{width:100%;max-width:340px;background:var(--color-success-bg, rgba(34, 197, 94, .1));border:1px solid var(--color-success, #22c55e);color:var(--color-success, #22c55e);padding:12px;border-radius:12px;margin-bottom:16px;font-size:.9rem;text-align:center;box-sizing:border-box}.locked-feature-wrap{position:relative;min-height:100dvh;overflow:hidden}.locked-feature-bg{filter:blur(6px);opacity:.45;pointer-events:none;-webkit-user-select:none;user-select:none}.locked-feature-overlay{position:fixed;inset:0;z-index:900;display:flex;align-items:center;justify-content:center;background:var(--overlay-bg);padding:24px}.locked-feature-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;padding:44px 28px;text-align:center;max-width:360px;width:100%;box-shadow:var(--shadow-lg)}.locked-icon{width:72px;height:72px;border-radius:50%;background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--color-primary)}.locked-feature-card h2{margin:0 0 10px;font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:700;color:var(--text-primary)}.locked-feature-card p{margin:0 0 28px;font-size:.92rem;line-height:1.5;color:var(--text-secondary)}.locked-back-btn{position:fixed;top:calc(12px + env(safe-area-inset-top,20px));left:calc(16px + env(safe-area-inset-left,0px));z-index:901;width:44px;height:44px;border-radius:50%;border:none;background:var(--bg-card);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #00000026}.locked-back-btn:active{transform:scale(.93);opacity:.8}.locked-upgrade-btn{display:inline-block;width:100%;padding:15px 24px;border:none;border-radius:30px;background:var(--color-primary);color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:600;cursor:pointer;box-shadow:0 6px 20px rgba(var(--color-primary-rgb),.45);transition:transform .15s ease,opacity .15s ease;letter-spacing:.02em}.locked-upgrade-btn:active{transform:scale(.97);opacity:.9}:root,[data-theme=light]{--color-primary: #B8313D;--color-primary-dark: #962832;--color-primary-light: rgba(184, 49, 61, .1);--color-primary-rgb: 184, 49, 61;--bg-body: #f5f5f5;--bg-secondary: #f5f5f5;--bg-card: #ffffff;--bg-card-elevated: #ffffff;--bg-header: #333331;--header-bg: #333331;--bg-input: #f9f9f9;--bg-skeleton: linear-gradient(90deg, #e0e0e0 25%, #f0f0f0 50%, #e0e0e0 75%);--text-primary: #373737;--text-secondary: #666666;--text-tertiary: #999999;--text-on-primary: #ffffff;--text-on-header: #373737;--border-color: #e0e0e0;--border-light: #f0f0f0;--color-success: #2e7d32;--color-success-bg: #e8f5e9;--success-bg: #e8f5e9;--success-text: #2e7d32;--color-error: #d32f2f;--color-error-bg: #ffebee;--color-warning: #e65100;--color-warning-bg: #fff3e0;--warning-bg: #fff3e0;--warning-border: #ffcc80;--warning-text: #e65100;--color-info: #1976d2;--color-info-bg: #e3f2fd;--info-bg: #e3f2fd;--info-border: #90caf9;--info-text: #1565c0;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-card: 0 2px 8px rgba(0, 0, 0, .08);--shadow-primary: 0 6px 20px rgba(184, 49, 61, .4);--shadow-glow: 0 1px 3px rgba(0, 0, 0, .06), 0 4px 12px rgba(0, 0, 0, .04), 0 0 12px rgba(var(--color-primary-rgb), .06);--overlay-bg: rgba(0, 0, 0, .6);--time-morning: #fff8e1;--time-afternoon: #e3f2fd}[data-theme=dark]{--color-primary: #DA3F4F;--color-primary-dark: #B8313D;--color-primary-light: rgba(218, 63, 79, .15);--color-primary-rgb: 218, 63, 79;--bg-body: #111114;--bg-secondary: #111114;--bg-card: #1a1a1f;--bg-card-elevated: #222228;--bg-header: #1a1a1f;--header-bg: #1a1a1f;--bg-input: #16161b;--bg-skeleton: linear-gradient(90deg, #1a1a1f 25%, #222228 50%, #1a1a1f 75%);--text-primary: #f0f0f2;--text-secondary: #a0a0a8;--text-tertiary: #606068;--text-on-primary: #ffffff;--text-on-header: #ffffff;--border-color: rgba(255, 255, 255, .08);--border-light: rgba(255, 255, 255, .04);--color-success: #4caf50;--color-success-bg: rgba(76, 175, 80, .15);--success-bg: rgba(76, 175, 80, .15);--success-text: #4caf50;--color-error: #f44336;--color-error-bg: rgba(244, 67, 54, .15);--color-warning: #ff9800;--color-warning-bg: rgba(255, 152, 0, .15);--warning-bg: rgba(255, 152, 0, .15);--warning-border: rgba(255, 152, 0, .3);--warning-text: #ff9800;--color-info: #42a5f5;--color-info-bg: rgba(66, 165, 245, .15);--info-bg: rgba(66, 165, 245, .15);--info-border: rgba(66, 165, 245, .3);--info-text: #42a5f5;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-card: 0 2px 8px rgba(0, 0, 0, .3);--shadow-primary: 0 6px 20px rgba(218, 63, 79, .4);--shadow-glow: 0 1px 3px rgba(0, 0, 0, .3), 0 4px 12px rgba(0, 0, 0, .15), 0 0 12px rgba(var(--color-primary-rgb), .1);--overlay-bg: rgba(0, 0, 0, .8);--time-morning: rgba(255, 248, 225, .1);--time-afternoon: rgba(227, 242, 253, .1)}[data-accent=orange]{--color-primary: #FF8533;--color-primary-dark: #E06E1A;--color-primary-light: rgba(255, 133, 51, .1);--color-primary-rgb: 255, 133, 51;--shadow-primary: 0 6px 20px rgba(255, 133, 51, .4)}[data-accent=orange][data-theme=dark]{--color-primary-light: rgba(255, 133, 51, .15)}[data-accent=blue]{--color-primary: #1AADFF;--color-primary-dark: #0E8FD8;--color-primary-light: rgba(26, 173, 255, .1);--color-primary-rgb: 26, 173, 255;--shadow-primary: 0 6px 20px rgba(26, 173, 255, .4)}[data-accent=blue][data-theme=dark]{--color-primary-light: rgba(26, 173, 255, .15)}[data-accent=green]{--color-primary: #C1FF72;--color-primary-dark: #A3DB58;--color-primary-light: rgba(193, 255, 114, .1);--color-primary-rgb: 193, 255, 114;--shadow-primary: 0 6px 20px rgba(193, 255, 114, .4);--text-on-primary: #1a1a1f}[data-accent=green][data-theme=dark]{--color-primary-light: rgba(193, 255, 114, .15)}[data-accent=purple]{--color-primary: #CB6CE6;--color-primary-dark: #A852C4;--color-primary-light: rgba(203, 108, 230, .1);--color-primary-rgb: 203, 108, 230;--shadow-primary: 0 6px 20px rgba(203, 108, 230, .4)}[data-accent=purple][data-theme=dark]{--color-primary-light: rgba(203, 108, 230, .15)}[data-mono=true][data-theme=light]{--color-primary: #111111;--color-primary-dark: #000000;--color-primary-light: rgba(0, 0, 0, .06);--color-primary-rgb: 17, 17, 17;--bg-body: #f0f0f0;--bg-secondary: #f0f0f0;--bg-card: rgba(255, 255, 255, .55);--bg-card-elevated: rgba(255, 255, 255, .65);--bg-header: #1a1a1a;--header-bg: #1a1a1a;--bg-input: rgba(255, 255, 255, .5);--text-primary: #111111;--text-secondary: #444444;--text-tertiary: #888888;--text-on-primary: #ffffff;--text-on-header: #ffffff;--border-color: rgba(0, 0, 0, .12);--border-light: rgba(0, 0, 0, .06);--color-success: #222222;--color-success-bg: rgba(0, 0, 0, .06);--success-bg: rgba(0, 0, 0, .06);--success-text: #222222;--color-error: #333333;--color-error-bg: rgba(0, 0, 0, .06);--color-warning: #555555;--color-warning-bg: rgba(0, 0, 0, .04);--warning-bg: rgba(0, 0, 0, .04);--warning-border: rgba(0, 0, 0, .1);--warning-text: #555555;--color-info: #333333;--color-info-bg: rgba(0, 0, 0, .04);--info-bg: rgba(0, 0, 0, .04);--info-border: rgba(0, 0, 0, .1);--info-text: #333333;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--shadow-card: 0 2px 12px rgba(0, 0, 0, .06);--shadow-primary: 0 6px 20px rgba(0, 0, 0, .15);--shadow-glow: 0 1px 4px rgba(0, 0, 0, .06), 0 4px 16px rgba(0, 0, 0, .04);--time-morning: rgba(0, 0, 0, .03);--time-afternoon: rgba(0, 0, 0, .03)}[data-mono=true][data-theme=dark]{--color-primary: #f0f0f0;--color-primary-dark: #cccccc;--color-primary-light: rgba(255, 255, 255, .08);--color-primary-rgb: 240, 240, 240;--bg-body: #0a0a0a;--bg-secondary: #0a0a0a;--bg-card: rgba(255, 255, 255, .05);--bg-card-elevated: rgba(255, 255, 255, .08);--bg-header: rgba(255, 255, 255, .04);--header-bg: rgba(255, 255, 255, .04);--bg-input: rgba(255, 255, 255, .04);--text-primary: #f0f0f0;--text-secondary: #aaaaaa;--text-tertiary: #666666;--text-on-primary: #0a0a0a;--text-on-header: #f0f0f0;--border-color: rgba(255, 255, 255, .1);--border-light: rgba(255, 255, 255, .05);--color-success: #cccccc;--color-success-bg: rgba(255, 255, 255, .06);--success-bg: rgba(255, 255, 255, .06);--success-text: #cccccc;--color-error: #cccccc;--color-error-bg: rgba(255, 255, 255, .06);--color-warning: #999999;--color-warning-bg: rgba(255, 255, 255, .04);--warning-bg: rgba(255, 255, 255, .04);--warning-border: rgba(255, 255, 255, .1);--warning-text: #999999;--color-info: #cccccc;--color-info-bg: rgba(255, 255, 255, .04);--info-bg: rgba(255, 255, 255, .04);--info-border: rgba(255, 255, 255, .08);--info-text: #cccccc;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .5);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .6);--shadow-card: 0 2px 12px rgba(0, 0, 0, .4);--shadow-primary: 0 6px 20px rgba(255, 255, 255, .08);--shadow-glow: 0 1px 4px rgba(0, 0, 0, .4), 0 4px 16px rgba(0, 0, 0, .2);--time-morning: rgba(255, 255, 255, .03);--time-afternoon: rgba(255, 255, 255, .03)}[data-mono=true] .settings-section,[data-mono=true] .cb-card,[data-mono=true] .card,[data-mono=true] .dashboard-card,[data-mono=true] .stat-card,[data-mono=true] .workout-card,[data-mono=true] .nutrition-card,[data-mono=true] .buddy-card,[data-mono=true] .challenge-card,[data-mono=true] .leaderboard-card,[data-mono=true] .consistency-card,[data-mono=true] .profile-card,[data-mono=true] .session-card,[data-mono=true] .modal-content,[data-mono=true] .onboarding-card,[data-mono=true] .notif-panel,[data-mono=true] .login-card{-webkit-backdrop-filter:blur(20px) saturate(100%);backdrop-filter:blur(20px) saturate(100%)}[data-mono=true][data-theme=dark] .cb-photo-badge,[data-mono=true][data-theme=dark] .lb-your-position,[data-mono=true][data-theme=dark] .prf-btn-primary{color:var(--text-on-primary)}[data-mono=true][data-theme=dark] .notif-panel{background:#1e1e1ee0}[data-mono=true][data-theme=light] .notif-panel{background:#ffffffd9}[data-mono=true][data-theme=light] .login-card{background:#ffffffe0}[data-mono=true][data-theme=dark] .login-card{background:#1e1e1ee0}[data-mono=true][data-theme=dark] .nut-modal,[data-mono=true][data-theme=dark] .nut-search-panel{background:#141414f2}[data-mono=true][data-theme=light] .nut-modal,[data-mono=true][data-theme=light] .nut-search-panel{background:#ffffffeb}[data-mono=true][data-theme=dark] .nut-search-item{background:#ffffff14}[data-mono=true][data-theme=light] .nut-search-item{background:#0000000a}[data-mono=true] .cb-ring .ring-tick.remaining{stroke:#da3f4f}[data-mono=true][data-theme=light] .cb-ring .ring-tick.remaining{stroke:#b8313d}[data-mono=true][data-theme=dark] .cb-stat-fill,[data-mono=true][data-theme=dark] .cb-fill-near,[data-mono=true][data-theme=dark] .cb-fill-complete,[data-mono=true][data-theme=dark] .cb-mini-fill,[data-mono=true][data-theme=dark] .cb-nudge-ring-fill,[data-mono=true][data-theme=dark] .wk-stat-fill,[data-mono=true][data-theme=dark] .wk-tick-filled.wk-tick-work,[data-mono=true][data-theme=dark] .wk-tick-filled.wk-tick-rest,[data-mono=true][data-theme=dark] .cbc-arc-fill,[data-mono=true][data-theme=dark] .cbc-habit-ring-fill,[data-mono=true][data-theme=dark] .ch-ring-svg circle:last-child,[data-mono=true][data-theme=dark] .progress-ring-fill,[data-mono=true][data-theme=dark] .wc-hold-ring-fill{stroke:#f0f0f0!important}[data-mono=true][data-theme=dark] .cb-val-complete{color:#f0f0f0!important}[data-mono=true][data-theme=dark] .cbc-habit-ring-icon,[data-mono=true][data-theme=dark] .cbc-habit-glow-orb{color:#f0f0f0!important;--habit-color: #f0f0f0 !important}[data-mono=true][data-theme=light] .cb-stat-fill,[data-mono=true][data-theme=light] .cb-fill-near,[data-mono=true][data-theme=light] .cb-fill-complete,[data-mono=true][data-theme=light] .cb-mini-fill,[data-mono=true][data-theme=light] .cb-nudge-ring-fill,[data-mono=true][data-theme=light] .wk-stat-fill,[data-mono=true][data-theme=light] .wk-tick-filled.wk-tick-work,[data-mono=true][data-theme=light] .wk-tick-filled.wk-tick-rest,[data-mono=true][data-theme=light] .cbc-arc-fill,[data-mono=true][data-theme=light] .cbc-habit-ring-fill,[data-mono=true][data-theme=light] .ch-ring-svg circle:last-child,[data-mono=true][data-theme=light] .progress-ring-fill,[data-mono=true][data-theme=light] .wc-hold-ring-fill{stroke:#111!important}[data-mono=true][data-theme=light] .cb-val-complete{color:#111!important}[data-mono=true][data-theme=light] .cbc-habit-ring-icon,[data-mono=true][data-theme=light] .cbc-habit-glow-orb{color:#111!important;--habit-color: #111111 !important}[data-mono=true][data-theme=dark] .wk-stat-value,[data-mono=true][data-theme=dark] .cb-mini-ring span{color:#f0f0f0!important}[data-mono=true][data-theme=light] .wk-stat-value,[data-mono=true][data-theme=light] .cb-mini-ring span{color:#111!important}[data-mono=true] .cbc-ring-complete .cbc-arc-fill,[data-mono=true] .cb-stat-near,[data-mono=true] .cb-stat-complete{filter:none!important;animation:none!important}[data-mono=true][data-theme=dark] .nut-week-day.selected .nut-week-day-num,[data-mono=true][data-theme=dark] .nut-cal-day.selected{color:#0a0a0a!important}[data-mono=true][data-theme=dark] .nut-week-day.selected .nut-week-day-letter{color:#f0f0f0!important}[data-mono=true][data-theme=light] .nut-week-day.selected .nut-week-day-num,[data-mono=true][data-theme=light] .nut-cal-day.selected{color:#fff!important}[data-mono=true][data-theme=light] .nut-week-day.selected .nut-week-day-letter{color:#111!important}[data-theme-transitioning] *{transition:background-color .3s ease,border-color .3s ease,color .2s ease}.theme-toggle{width:44px;height:44px;border-radius:50%;border:1px solid #444;background:transparent;color:#999;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-tap-highlight-color:transparent}.theme-toggle:hover{border-color:var(--color-primary);color:var(--color-primary)}.theme-toggle svg{width:22px;height:22px;transition:transform .3s ease}.theme-toggle:active svg{transform:rotate(20deg)}.success-checkmark{width:80px;height:80px;margin:0 auto 20px}.success-checkmark .circle{fill:none;stroke:var(--color-success);stroke-width:3;stroke-dasharray:166;stroke-dashoffset:0}.success-checkmark .check{fill:none;stroke:var(--color-success);stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:50;stroke-dashoffset:0}.session-card.today-session{border-color:var(--color-primary);background:var(--color-primary-light)}.session-card.today-session .session-date{color:var(--color-primary)}.empty-state{text-align:center;padding:40px 20px}.empty-state-icon{width:120px;height:120px;margin:0 auto 20px;opacity:.6}.empty-state-icon svg{width:100%;height:100%;color:var(--text-tertiary)}.empty-state h4{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;color:var(--text-primary);margin:0 0 8px}.empty-state p{font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-tertiary);margin:0}.pull-refresh-indicator{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--bg-body);overflow:hidden;transition:height .1s ease-out;opacity:0}.pull-refresh-indicator.visible{opacity:1}.pull-refresh-indicator.refreshing{height:60px!important}.refresh-spinner{color:var(--color-primary);transition:transform .2s}.refresh-spinner.spinning{animation:pullRefreshSpin 1s linear infinite}.refresh-text{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-secondary)}@keyframes pullRefreshSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.cb-card-content h3,.cb-nudge-title-text,.cb-journey-title,.cb-coach-msg,.cb-celebration-title,.cb-weekly-celebration-card h4,.cb-metric-rings-title,.cb-target-picker h4,.prf-section-title,.prf-name,.bdg-title,.bdg-category-title,.bdy-title,.cbc-section-title,.cbm-title,.cbm-section-title,.cbm-banner-title,.cbm-setup-heading,.bldr-title,.bldr-section-title,.wk-section-header h2,.wk-hub-heading h2,.wk-hub-card-body h3,.wk-menu-heading h2,.wk-hero-bottom h3,.wk-prog-hero-bottom h3,.wk-muscle-hero-name,.wk-landing-card-body h3,.mg-sessions-header h2,.mg-session-info h3,.mg-overview-title-row h2,.mg-overview-section h3,.pg-overview-name,.pg-browse-name,.pg-dash-name,.pg-next-session h3,.pg-week-label,.nut-setup-intro h2,.nut-meal-card-title,.nut-add-picker-title,.nut-calc-results h3,.nut-modal-header h3,.nut-log-section h3,.pb-intro h2,.pb-trend-section h4,.pb-target-section-title,.pb-metrics-card h3,.pb-edit-header h3,.lb-title,.lb-optin-title,.ch-title,.ch-card-body h3,.ch-completed-heading,.welcome-section h2,.block-info-card h3,.daily-quote-label,.daily-quote-cta-title,.core-buddy-cta-title,.completed-section h3,.modal-header h3,.confirm-modal h3,.header-left h1,.view-header h2,.page-header h1,.acb-header h1,.acb-main h2,.tools-intro h2,.forms-intro h2,.form-header h2,.today-summary h3,.calendar-header h3,.availability-header h3,.client-section-header,.client-name-text h3,.circuit-intro h2,.circuit-status-info h3,.circuit-stats-card h3,.circuit-rules h4,.cb-header h1,.cb-class-info h2,.locked-feature-card h2{font-weight:800!important}.cb-timer-digit,.cb-timer-colon,.cb-ring-countdown,.bldr-timer-digit,.bldr-timer-colon,.bldr-countdown,.timer-digit,.timer-colon,.ring-timer-countdown{font-weight:900!important}@keyframes page-fade-in{0%{opacity:0}to{opacity:1}}#root>:first-child:not(#app-loader){animation:page-fade-in .5s ease-out}.cb-dashboard .pull-indicator{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-card);color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.85rem;gap:4px;overflow:hidden}.cb-dashboard .pull-spinner{font-size:1.2rem;transition:transform .2s}.cb-dashboard .pull-spinner.spinning{animation:spin .8s linear infinite}@keyframes colonBlink{0%,to{opacity:1}50%{opacity:.3}}.cb-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-body)}.cb-loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.cb-loading-inline{display:flex;align-items:center;justify-content:center;min-height:60vh}.cb-dashboard{min-height:100vh;background:var(--bg-body);padding-bottom:calc(80px + var(--safe-area-bottom))}.cb-main{max-width:600px;margin:0 auto;padding:0 16px calc(80px + var(--safe-area-bottom))}.cb-coach-msg{font-family:Plus Jakarta Sans,sans-serif;font-size:1.15rem;font-weight:600;color:var(--text-primary);text-align:center;margin:8px 0 20px}.cb-coach-msg strong{font-weight:800;color:var(--color-primary)}.cb-card-nudge{background:rgba(var(--color-primary-rgb),.06);border-color:rgba(var(--color-primary-rgb),.15)}[data-theme=dark] .cb-card-nudge{background:rgba(var(--color-primary-rgb),.08);border-color:rgba(var(--color-primary-rgb),.2)}.cb-nudge-title-text{font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0}.cb-nudge-ring{position:relative;width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.cb-nudge-ring svg{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg)}.cb-nudge-ring-track{fill:none;stroke:rgba(var(--color-primary-rgb),.2);stroke-width:10;stroke-linecap:round}.cb-nudge-ring-fill{fill:none;stroke:var(--color-primary);stroke-width:10;stroke-linecap:round;animation:ringFillIn 1.6s ease-out}.cb-nudge-ring-val{position:relative;z-index:1;font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:700;color:var(--color-primary)}.cb-nudge-label{font-family:Inter,sans-serif;font-size:.55rem;font-weight:700;color:var(--text-tertiary);letter-spacing:1.5px;text-transform:uppercase}.cb-nudge-cta{font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;color:var(--color-primary)}.cb-ring-container{display:flex;flex-direction:column;align-items:center;padding:28px 0 12px}.cb-ring{position:relative;width:260px;height:260px;display:flex;align-items:center;justify-content:center}.cb-ring-svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:scaleX(-1)}.cb-ring .ring-tick.remaining{stroke:var(--color-primary)}.cb-ring .ring-tick.elapsed{stroke:#fff}[data-theme=light] .cb-ring .ring-tick.elapsed{stroke:#2d2d2d}.cb-ring-center{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;width:130px;height:130px}.cb-ring-logo{position:relative;width:120px;height:120px;border-radius:50%;overflow:hidden;box-shadow:0 4px 16px #00000059;cursor:pointer;-webkit-tap-highlight-color:transparent}.cb-ring-logo img{width:100%;height:100%;object-fit:cover}.cb-photo-overlay{position:absolute;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;border-radius:50%}.cb-ring-logo:hover .cb-photo-overlay,.cb-ring-logo:active .cb-photo-overlay,.cb-photo-overlay.uploading{opacity:1}.cb-photo-spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.cb-photo-badge{position:absolute;bottom:2px;right:2px;width:30px;height:30px;border-radius:50%;background:var(--color-primary);color:#fff;border:2px solid var(--bg-body);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;box-shadow:0 2px 6px #0000004d;-webkit-tap-highlight-color:transparent}.cb-photo-badge:active{transform:scale(.9)}.cb-ring-countdown{display:flex;align-items:baseline;justify-content:center;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;margin-top:8px}.cb-timer-digit{font-size:1.3rem;color:var(--text-primary);min-width:2ch;text-align:center;letter-spacing:1px}.cb-timer-colon{font-size:1.1rem;color:var(--text-secondary);margin:0 1px;animation:colonBlink 1s ease-in-out infinite}.cb-timer-seconds{color:var(--color-primary)}.cb-ring-label{font-family:Inter,sans-serif;font-size:.65rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin-top:3px}@keyframes taglineFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.cb-ring-tagline{font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-secondary);text-align:center;margin-top:10px;line-height:1.5;max-width:320px;animation:taglineFadeIn .6s ease-out}.cb-ring-tagline strong{color:var(--color-primary);font-weight:500}.cb-stats-row{display:flex;justify-content:center;align-items:flex-end;gap:16px;padding:4px 0 16px}.cb-stat-item{display:flex;flex-direction:column;align-items:center;gap:6px}.cb-stat-ring{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.cb-stat-large .cb-stat-ring{width:100px;height:100px}.cb-stat-ring svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.cb-stat-track{fill:none;stroke:rgba(var(--color-primary-rgb),.1);stroke-width:12;stroke-linecap:round}.cb-stat-fill{fill:none;stroke:var(--color-primary);stroke-width:12;stroke-linecap:round;animation:ringFillIn 1.6s ease-out}.cb-stat-value{position:relative;z-index:1;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.85rem}.cb-stat-large .cb-stat-value{font-size:1rem}.cb-stat-label{font-family:Inter,sans-serif;font-size:.65rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.cb-stat-tappable{cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s}.cb-stat-tappable:active{transform:scale(.93)}@keyframes statRingHintPulse{0%{box-shadow:0 0 rgba(var(--color-primary-rgb),.4)}50%{box-shadow:0 0 0 10px rgba(var(--color-primary-rgb),0)}to{box-shadow:0 0 rgba(var(--color-primary-rgb),0)}}.cb-stat-hint{border-radius:50%;animation:statRingHintPulse 1.6s ease-out 3}.cb-target-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:cbOverlayFadeIn .2s ease-out}.cb-target-picker{background:var(--bg-card-elevated);border:1px solid var(--border-color);border-radius:20px;padding:28px 24px;width:100%;max-width:320px;text-align:center;animation:cbBadgeZoomIn .25s cubic-bezier(.175,.885,.32,1.275)}.cb-target-picker h4{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.cb-target-picker p{font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-tertiary);margin:0 0 20px}.cb-target-options{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.cb-target-option{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border-color);background:transparent;color:var(--text-secondary);font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.cb-target-option:hover{border-color:rgba(var(--color-primary-rgb),.4);color:var(--text-primary)}.cb-target-option.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.cb-features{display:flex;flex-direction:column;gap:16px;padding:0 0 20px}.cb-feature-card{position:relative;display:flex;align-items:center;gap:14px;padding:18px 16px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;cursor:pointer;text-align:left;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;overflow:hidden;-webkit-tap-highlight-color:transparent;font-family:inherit;box-shadow:var(--shadow-glow)}[data-theme=dark] .cb-feature-card{border:1px solid rgba(255,255,255,.06);background:var(--bg-card)}.cb-grid-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.cb-grid-row.cb-grid-single{grid-template-columns:1fr}.cb-grid-card{flex-direction:column;align-items:flex-start;gap:0;padding:16px 14px;min-height:110px}.cb-grid-card .cb-card-content{width:100%}.cb-grid-card .cb-card-content h3{font-size:.85rem;margin-bottom:8px}.cb-grid-arrow{position:absolute;top:14px;right:12px;color:var(--color-primary);opacity:.7}.cb-grid-card .cb-habit-dots{gap:5px}.cb-grid-card .cb-habit-dots-label{margin-left:0;margin-top:6px;display:block}.cb-grid-card .cb-pb-preview{gap:3px}.cb-grid-card .cb-pb-name{font-size:.68rem}.cb-grid-card .cb-pb-value{font-size:.65rem}.cb-grid-card .cb-progress-preview{flex-direction:column;align-items:flex-start;gap:4px}.cb-grid-card .cb-progress-preview span{font-size:.72rem}.cb-card-unified{display:flex;align-items:center;gap:14px;min-height:88px}.cb-unified-stat{font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;color:var(--color-primary);white-space:nowrap;flex-shrink:0}.cb-feature-card:hover{transform:translateY(-2px);box-shadow:0 2px 6px #00000014,0 8px 24px #0000001a;border-color:rgba(var(--color-primary-rgb),.15)}[data-theme=dark] .cb-feature-card:hover{border-color:#ffffff1f}.cb-feature-card:active{transform:scale(.97);transition:transform .1s ease}.cb-activity-history-link{display:block;width:100%;text-align:center;background:none;border:none;color:var(--color-primary);font-size:.82rem;font-weight:600;padding:6px 0;margin:-4px 0 8px;cursor:pointer;font-family:inherit}.cb-activity-history-link:hover{text-decoration:underline}.cb-progress-preview{display:flex;align-items:center;gap:6px;margin-top:3px}.cb-progress-icon{flex-shrink:0;color:var(--color-primary)}.cb-progress-preview span{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-tertiary)}.cb-pb-preview{display:flex;flex-direction:column;gap:4px;margin-top:4px}.cb-pb-entry{display:flex;align-items:center;justify-content:space-between;gap:8px}.cb-pb-name{font-family:Inter,sans-serif;font-size:.72rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.cb-pb-value{font-family:Plus Jakarta Sans,sans-serif;font-size:.68rem;font-weight:600;color:var(--color-primary);white-space:nowrap;flex-shrink:0}.cb-lb-preview{display:flex;align-items:center;gap:10px;margin-top:6px}.cb-lb-entry{display:flex;flex-direction:column;align-items:center;gap:2px}.cb-lb-avatar{width:32px;height:32px;border-radius:50%;border:2px solid #A8B4C0;background:#ffffff1a;display:flex;align-items:center;justify-content:center}.cb-lb-avatar span{font-family:Inter,sans-serif;font-size:.55rem;font-weight:700;color:var(--text-primary);letter-spacing:.5px}.cb-lb-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.cb-lb-rank{font-family:Plus Jakarta Sans,sans-serif;font-size:.55rem;font-weight:700}.cb-lb-me .cb-lb-avatar{box-shadow:0 0 6px #ffd70080}.cb-card-icon-wrap{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:12px}.cb-card-icon-challenge,.cb-card-icon-badges{background:transparent;border-radius:50%;overflow:hidden}.cb-card-badge-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.cb-habit-dots{display:flex;align-items:center;gap:6px;margin-top:4px}.cb-habit-dot{width:10px;height:10px;border-radius:50%;background:rgba(var(--color-primary-rgb),.15);border:1.5px solid rgba(var(--color-primary-rgb),.25);transition:background .3s,border-color .3s}.cb-habit-dot.done{background:var(--color-primary);border-color:var(--color-primary);box-shadow:0 0 4px rgba(var(--color-primary-rgb),.4)}.cb-habit-dots-label{font-family:Inter,sans-serif;font-size:.7rem;font-weight:600;color:var(--text-tertiary);margin-left:4px}.cb-card-icon{flex-shrink:0;width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.cb-card-icon svg{width:22px;height:22px}.cb-card-icon{background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary)}.cb-card-content{flex:1;min-width:0}.cb-card-content h3{font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.cb-card-content p{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-tertiary);margin:0}.cb-card-arrow{flex-shrink:0;color:var(--text-tertiary);opacity:.25}.cb-mini-rings{display:flex;gap:10px}.cb-mini-ring{position:relative;width:44px;height:44px;display:flex;align-items:center;justify-content:center}.cb-mini-ring svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.cb-mini-ring span{position:relative;z-index:1;font-family:Inter,sans-serif;font-size:.55rem;font-weight:700}.cb-mini-track{fill:none;stroke:rgba(var(--color-primary-rgb),.1);stroke-width:10;stroke-linecap:round}.cb-mini-fill{fill:none;stroke-width:10;stroke-linecap:round;animation:ringFillIn 1.6s ease-out}.cb-coming-soon{flex-shrink:0;font-family:Inter,sans-serif;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);padding:4px 10px;border:1px solid var(--border-color);border-radius:12px}.cb-card-locked{opacity:.4;filter:grayscale(1)}.cb-card-locked:hover{transform:none;box-shadow:none;border-color:var(--border-color)}.cb-dashboard .toast-notification{position:fixed;bottom:90px;left:50%;right:auto;transform:translate(-50%);padding:12px 20px;border-radius:12px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;color:#fff;z-index:9999;display:flex;align-items:center;gap:8px;box-shadow:0 8px 24px #0003;max-width:calc(100vw - 32px);text-align:center;word-break:break-word}.cb-dashboard .toast-notification.info{background:var(--bg-header)}.cb-dashboard .toast-notification.success{background:var(--color-success)}.cb-dashboard .toast-notification.error{background:var(--color-error)}.ripple-btn{position:relative;overflow:hidden}.ripple{position:absolute;border-radius:50%;background:rgba(var(--color-primary-rgb),.15);transform:scale(0);animation:rippleExpand .5s ease-out forwards;pointer-events:none}@keyframes rippleExpand{to{transform:scale(2.5);opacity:0}}@media(min-width:400px){.cb-ring{width:300px;height:300px}.cb-ring-center{width:150px;height:150px}.cb-ring-logo{width:140px;height:140px}.cb-stat-ring{width:90px;height:90px}.cb-stat-value{font-size:.95rem}.cb-stats-row{gap:24px}.cb-feature-card{padding:20px 18px}.cb-card-content h3{font-size:1rem}.cb-grid-row{gap:16px}.cb-grid-card{padding:18px 16px;min-height:120px}.cb-grid-card .cb-card-content h3{font-size:.9rem}}@media(min-width:500px){.cb-main{padding:0 24px}.cb-nudge-title-text{font-size:1rem}}.cb-journey-section{margin-top:24px}.cb-journey-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.95rem;color:var(--text-primary);margin:0 0 14px;padding-left:2px}.journey-compose{display:flex;gap:12px;padding:14px 16px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;margin-bottom:16px;box-shadow:var(--shadow-glow);position:relative;z-index:10}[data-theme=dark] .journey-compose{background:var(--bg-card);border-color:#ffffff0f}.journey-compose-avatar span{font-family:Inter,sans-serif;font-size:.7rem;font-weight:700;color:var(--color-primary)}.journey-post-btn{padding:8px 20px;border-radius:20px;border:none;background:var(--color-primary);color:#fff;font-family:Inter,sans-serif;font-weight:700;font-size:.8rem;cursor:pointer;transition:opacity .2s,transform .15s;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;min-width:70px}.journey-post-avatar span{font-family:Inter,sans-serif;font-size:.6rem;font-weight:700;color:var(--color-primary)}.journey-post-name{font-family:Inter,sans-serif;font-size:.85rem;font-weight:700;color:var(--text-primary)}.journey-comment-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden;flex-shrink:0;background:rgba(var(--color-primary-rgb, 161, 47, 58),.1);display:flex;align-items:center;justify-content:center}.journey-comment-avatar span{font-family:Inter,sans-serif;font-size:.5rem;font-weight:700;color:var(--color-primary)}.journey-comment-name{font-family:Inter,sans-serif;font-size:.72rem;font-weight:700;color:var(--text-primary)}.journey-comment-time{font-family:Inter,sans-serif;font-size:.62rem;color:var(--text-tertiary)}.journey-comment-actions-row{display:flex;align-items:center;gap:10px;margin-left:12px;margin-top:2px}.journey-comment-reply-btn{background:none;border:none;padding:0;font-family:Inter,sans-serif;font-size:.62rem;font-weight:600;color:var(--text-tertiary);cursor:pointer;-webkit-tap-highlight-color:transparent}.journey-comment-reply-btn:hover{color:var(--color-primary)}.journey-comment-delete-btn{background:none;border:none;padding:0;cursor:pointer;color:var(--text-tertiary);display:flex;align-items:center;opacity:0;transition:opacity .15s,color .15s;-webkit-tap-highlight-color:transparent}.journey-comment:hover .journey-comment-delete-btn{opacity:1}.journey-comment-delete-btn:hover{color:#e74c3c}.journey-comment-reply-tag{display:inline-flex;align-items:center;gap:3px;font-family:Inter,sans-serif;font-size:.68rem;color:var(--color-primary);margin-bottom:1px}.journey-comment-image{max-width:200px;max-height:150px;border-radius:8px;margin-top:6px;object-fit:cover}.journey-comment-replying{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;border-radius:10px;background:rgba(var(--color-primary-rgb, 161, 47, 58),.08);font-family:Inter,sans-serif;font-size:.72rem;color:var(--text-secondary)}.journey-comment-replying button{background:none;border:none;cursor:pointer;color:var(--text-tertiary);display:flex;align-items:center;padding:2px;-webkit-tap-highlight-color:transparent}.journey-comment-img-preview{position:relative;display:inline-block}.journey-comment-img-preview img{max-width:120px;max-height:80px;border-radius:8px;object-fit:cover}.journey-comment-img-preview button{position:absolute;top:-4px;right:-4px;width:20px;height:20px;border-radius:50%;background:#0009;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}.journey-comment-img-btn{background:none;border:none;padding:0;cursor:pointer;color:var(--text-tertiary);display:flex;align-items:center;flex-shrink:0;transition:color .15s;-webkit-tap-highlight-color:transparent}.journey-comment-img-btn:hover{color:var(--color-primary)}.journey-comment-input input{flex:1;border:1px solid rgba(150,150,150,.2);border-radius:22px;padding:10px 16px;font-family:Inter,sans-serif;font-size:.88rem;color:var(--text-primary);background:transparent;outline:none;transition:border-color .2s}.journey-comment-input button:last-child{width:32px;height:32px;border-radius:50%;border:none;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:opacity .2s,transform .15s;-webkit-tap-highlight-color:transparent}.journey-comment-input button:last-child:active{transform:scale(.9)}.journey-comment-input button:last-child:disabled{opacity:.4;cursor:default}.header-left-group{position:absolute;left:10px;display:flex;align-items:center;gap:2px;z-index:100}.header-icon-btn{background:none;border:none;color:var(--text-secondary, #aaa);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .2s}.header-icon-btn:hover{color:var(--text-primary, #fff)}.header-notif-wrap{position:relative;z-index:100}.header-notif-btn{position:relative;background:none;border:none;color:var(--text-secondary, #aaa);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .2s}.header-notif-btn:hover{color:var(--text-primary, #fff)}.header-notif-badge{position:absolute;top:0;right:-2px;min-width:16px;height:16px;background:#f44336;color:#fff;font-size:.6rem;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.notif-panel{position:absolute;top:40px;left:0;width:300px;max-height:400px;background:var(--bg-card, #1a1a2e);border:1px solid var(--border-color, #2a2a3e);border-radius:12px;box-shadow:0 8px 32px #0006;overflow:hidden;z-index:200}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border-color, #2a2a3e)}.notif-panel-title{font-size:.85rem;font-weight:600;color:var(--text-primary, #fff)}.notif-clear-btn{background:none;border:none;color:var(--color-primary, #A12F3A);font-size:.7rem;cursor:pointer;padding:2px 6px;border-radius:4px;transition:opacity .2s}.notif-clear-btn:hover{opacity:.7}.notif-panel-list{max-height:340px;overflow-y:auto}.notif-empty{padding:30px 14px;text-align:center;color:var(--text-tertiary, #666);font-size:.8rem}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border-color, rgba(255,255,255,.04))}.notif-item:hover{background:#ffffff0a}.notif-item.unread{background:rgba(var(--color-primary-rgb),.08)}.notif-item-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--bg-card-hover, #2a2a3e);display:flex;align-items:center;justify-content:center}.notif-item-avatar img{width:100%;height:100%;object-fit:cover}.notif-item-avatar span{font-size:.65rem;font-weight:600;color:var(--text-secondary, #aaa)}.notif-item-body{flex:1;min-width:0}.notif-item-text{font-size:.78rem;color:var(--text-secondary, #ccc);line-height:1.35;margin:0}.notif-item-text strong{color:var(--text-primary, #fff)}.notif-item-time{font-size:.65rem;color:var(--text-tertiary, #666);margin-top:2px;display:block}.mention-dropdown{position:absolute;left:0;right:0;top:100%;background:var(--bg-card, #1a1a2e);border:1px solid var(--border-color, #2a2a3e);border-radius:8px;box-shadow:0 4px 16px #0000004d;z-index:50;overflow:hidden}.mention-dropdown-up{top:auto;bottom:100%;margin-bottom:4px}.mention-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;color:var(--text-primary, #fff);font-size:.8rem;cursor:pointer;text-align:left;transition:background .15s}.mention-option:hover{background:#ffffff0f}.mention-option-avatar{width:24px;height:24px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--bg-card-hover, #2a2a3e);display:flex;align-items:center;justify-content:center}.mention-option-avatar img{width:100%;height:100%;object-fit:cover}.mention-option-avatar span{font-size:.55rem;font-weight:600;color:var(--text-secondary, #aaa)}.mention-highlight{color:var(--color-primary, #A12F3A);font-weight:600}[data-theme=light] .notif-panel{background:#fff;border-color:#e5e5e5;box-shadow:0 8px 32px #0000001f}[data-theme=light] .notif-item:hover{background:#00000008}[data-theme=light] .notif-item.unread{background:rgba(var(--color-primary-rgb),.06)}[data-theme=light] .mention-dropdown{background:#fff;border-color:#e5e5e5;box-shadow:0 4px 16px #0000001a}[data-theme=light] .mention-option:hover{background:#0000000a}.cb-card-locked{opacity:.55;position:relative}.cb-card-locked .cb-card-content h3,.cb-card-locked .cb-card-content p{color:var(--text-tertiary)}.cb-card-lock-icon{position:absolute;top:10px;right:10px;opacity:.5;color:var(--text-tertiary)}.cb-upgrade-teaser{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px;background:none;border:1px dashed var(--border-color);border-radius:8px;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.85rem;cursor:pointer;transition:color .2s,border-color .2s}.cb-upgrade-cta{display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;width:100%;padding:24px 20px;margin-top:4px;background:var(--color-primary);border:none;border-radius:14px;color:var(--text-on-primary);cursor:pointer;transition:transform .2s,box-shadow .2s}.cb-upgrade-cta:active{transform:scale(.98)}.cb-upgrade-cta-text{font-family:Inter,sans-serif;font-size:.9rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.cb-upgrade-cta-sub{font-family:Inter,sans-serif;font-size:.75rem;font-weight:300;opacity:.85;margin-top:4px}.cb-upgrade-cta-arrow{position:absolute;right:16px;top:50%;transform:translateY(-50%);opacity:.7}@keyframes celebrationFadeIn{0%{opacity:0}to{opacity:1}}@keyframes celebrationBadgeBounce{0%{transform:scale(0);opacity:0}50%{transform:scale(1.15)}70%{transform:scale(.95)}to{transform:scale(1);opacity:1}}@keyframes celebrationGlow{0%{transform:scale(.5);opacity:0}50%{opacity:.6}to{transform:scale(1.8);opacity:0}}@keyframes celebrationTextSlide{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes confettiBurst{0%{transform:translate(0) rotate(0) scale(1);opacity:1}to{transform:translate(calc(cos(var(--angle)) * var(--distance) + var(--drift)),calc(sin(var(--angle)) * var(--distance) + 80px)) rotate(720deg) scale(0);opacity:0}}.cb-celebration-overlay{position:fixed;inset:0;background:#000000d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:celebrationFadeIn .4s ease-out}.cb-confetti-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:0;height:0;pointer-events:none}.cb-confetti-piece{position:absolute;width:var(--size);height:var(--size);background:var(--color);border-radius:2px;animation:confettiBurst 1.4s cubic-bezier(.25,.46,.45,.94) var(--delay) both}.cb-confetti-piece:nth-child(odd){border-radius:50%}.cb-celebration-content{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 24px;z-index:1}.cb-celebration-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(255,215,0,.35) 0%,transparent 70%);animation:celebrationGlow 1.8s ease-out .2s both;pointer-events:none}.cb-celebration-badge-img{width:180px;height:180px;object-fit:contain;filter:drop-shadow(0 0 40px rgba(255,215,0,.4));animation:celebrationBadgeBounce .8s cubic-bezier(.175,.885,.32,1.275) .2s both}.cb-celebration-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.5rem;font-weight:800;color:gold;text-transform:uppercase;letter-spacing:2px;margin:8px 0 0;text-shadow:0 0 20px rgba(255,215,0,.4);animation:celebrationTextSlide .6s ease-out .6s both}.cb-celebration-name{font-family:Inter,sans-serif;font-size:1.1rem;font-weight:700;color:#fff;margin:0;animation:celebrationTextSlide .6s ease-out .75s both}.cb-celebration-desc{font-family:Inter,sans-serif;font-size:.85rem;color:#fff9;text-align:center;margin:0;max-width:280px;line-height:1.4;animation:celebrationTextSlide .6s ease-out .9s both}.cb-celebration-dismiss{background:none;border:none;font-family:Inter,sans-serif;font-size:.75rem;color:#ffffff4d;cursor:pointer;padding:12px 20px;margin-top:16px;animation:celebrationTextSlide .6s ease-out 1.2s both;-webkit-tap-highlight-color:transparent}@keyframes statNearPulse{0%,to{filter:drop-shadow(0 0 0 transparent)}50%{filter:drop-shadow(0 0 6px rgba(var(--color-primary-rgb),.5))}}.cb-stat-near{animation:statNearPulse 2s ease-in-out infinite}.cb-fill-near{stroke:var(--color-primary)!important;filter:brightness(1.2)}@keyframes statCompleteGlow{0%{filter:drop-shadow(0 0 0 transparent)}40%{filter:drop-shadow(0 0 10px rgba(var(--color-primary-rgb),.6))}to{filter:drop-shadow(0 0 4px rgba(var(--color-primary-rgb),.3))}}.cb-stat-complete{animation:statCompleteGlow 1s ease-out forwards}.cb-fill-complete{stroke:#4caf50!important}.cb-val-complete{color:#4caf50!important}.cb-spider-section{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:16px 12px 12px;margin-bottom:16px;box-shadow:var(--shadow-glow);display:flex;flex-direction:column;align-items:center}[data-theme=dark] .cb-spider-section{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 1px 3px #0003,0 4px 12px #00000026}.cb-spider-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin:0}.cb-spider-subtitle{font-family:Inter,sans-serif;font-size:.65rem;color:var(--text-tertiary);margin:2px 0 0}.cb-charts-cta{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:20px;border:none;background:var(--color-primary);color:var(--text-on-primary, #fff);font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.78rem;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent;margin-top:4px}.cb-charts-cta:active{transform:scale(.95)}@keyframes dotWarmPulse{0%,to{box-shadow:0 0 0 transparent}50%{box-shadow:0 0 6px rgba(var(--color-primary-rgb),var(--glow-intensity, .3))}}.cb-habit-dots .cb-habit-dot:not(.done){animation:dotWarmPulse 2.5s ease-in-out infinite;animation-delay:calc(var(--glow-intensity, 0) * .5s);border-color:rgba(var(--color-primary-rgb),calc(.25 + var(--glow-intensity, 0) * .4));background:rgba(var(--color-primary-rgb),calc(.15 + var(--glow-intensity, 0) * .15))}.cb-habits-all-done .cb-habit-dot.done{box-shadow:0 0 6px rgba(var(--color-primary-rgb),.5);animation:habitAllDonePop .4s ease-out}@keyframes habitAllDonePop{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.cb-lb-movement{font-family:Inter,sans-serif;font-size:.5rem;font-weight:700;margin-left:2px;display:inline-block;animation:rankMoveFadeIn .5s ease-out}.cb-lb-up{color:#4caf50}.cb-lb-down{color:#f44336}@keyframes rankMoveFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.cb-card-done{position:relative;border-color:#4caf5040!important}.cb-card-done:after{content:"";position:absolute;top:10px;right:10px;width:20px;height:20px;background:#4caf50;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:cardDoneCheck .4s cubic-bezier(.175,.885,.32,1.275);z-index:2;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='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:12px 12px}.cb-card-done .cb-card-arrow{display:none}@keyframes cardDoneCheck{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}[data-theme=dark] .cb-card-done{background:linear-gradient(135deg,var(--bg-card),rgba(76,175,80,.04));border-color:#4caf5026!important}[data-theme=light] .cb-card-done{background:linear-gradient(135deg,var(--bg-card),rgba(76,175,80,.04))}.cb-weekly-celebration{position:fixed;top:0;left:50%;transform:translate(-50%);z-index:2000;animation:weeklyCelebSlideDown .4s cubic-bezier(.175,.885,.32,1.275);padding:16px;padding-top:calc(var(--safe-area-top) + 16px);width:100%;max-width:360px}.cb-weekly-celebration-card{background:var(--bg-card-elevated, #1e1e30);border:1px solid rgba(var(--color-primary-rgb),.3);border-radius:16px;padding:20px;text-align:center;box-shadow:0 8px 32px #0006,0 0 40px rgba(var(--color-primary-rgb),.15)}.cb-weekly-celebration-icon{display:inline-block;animation:weeklyStarSpin .6s ease-out}@keyframes weeklyStarSpin{0%{transform:rotate(-180deg) scale(0)}to{transform:rotate(0) scale(1)}}.cb-weekly-celebration-card h4{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:var(--color-primary);margin:8px 0 4px}.cb-weekly-celebration-card p{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-tertiary);margin:0}@keyframes weeklyCelebSlideDown{0%{transform:translate(-50%) translateY(-100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.cb-milestone-hint{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;margin:0 auto 16px;background:rgba(var(--color-primary-rgb),.06);border:1px solid rgba(var(--color-primary-rgb),.15);border-radius:20px;max-width:fit-content}.cb-milestone-hint svg{flex-shrink:0;color:var(--color-primary)}.cb-milestone-hint span{font-family:Inter,sans-serif;font-size:.75rem;font-weight:600;color:var(--color-primary)}.cb-streak-flame{vertical-align:middle;margin-right:1px;animation:flameFlicker 1.5s ease-in-out infinite}@keyframes flameFlicker{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.8;transform:scaleY(1.1)}}.toast-notification.success{border-left:3px solid #4CAF50}.toast-notification.success svg{color:#4caf50}.cb-card-metrics{display:flex;align-items:center;gap:14px}.cb-card-metrics-ring{position:relative;width:48px;height:48px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.cb-card-metrics-ring svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.cb-metrics-ring-track{fill:none;stroke:#4caf501f;stroke-width:10;stroke-linecap:round}.cb-metrics-ring-fill{fill:none;stroke:#4caf50;stroke-width:10;stroke-linecap:round;animation:ringFillIn 1.6s ease-out}.cb-metrics-ring-val{position:relative;z-index:1;font-family:Plus Jakarta Sans,sans-serif;font-size:.6rem;font-weight:700;color:#4caf50}.cb-metric-rings-wrap{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 12px 10px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;margin-bottom:16px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s;width:100%;box-shadow:var(--shadow-glow)}.cb-metric-rings-wrap:active{transform:scale(.98)}[data-theme=dark] .cb-metric-rings-wrap{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 1px 3px #0003,0 4px 12px #00000026}.cb-metric-rings-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.cb-metric-rings-row{display:flex;flex-wrap:wrap;justify-content:center;gap:6px}.cb-metric-mini{display:flex;flex-direction:column;align-items:center;gap:2px;width:52px}.cb-metric-mini-ring{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center}.cb-metric-mini-ring svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.cb-metric-mini-track{fill:none;stroke:rgba(var(--color-primary-rgb, 184, 49, 61),.12);stroke-width:10;stroke-linecap:round}.cb-metric-mini-fill{fill:none;stroke:var(--color-primary);stroke-width:10;stroke-linecap:round;animation:ringFillIn 1.6s ease-out}.cb-metric-mini-label{font-family:Inter,sans-serif;font-size:.5rem;font-weight:600;color:var(--text-tertiary);text-align:center;white-space:nowrap}.cb-metric-rings-cta{font-family:Inter,sans-serif;font-size:.68rem;font-weight:500;color:var(--color-primary);margin-top:2px}.cb-nutrition-mini{width:64px}.cb-nutrition-ring{width:48px;height:48px}.cb-nutrition-track{stroke:rgba(var(--color-primary-rgb),.12)}.cb-nutrition-fill{stroke:var(--color-primary)}.cb-fab{position:fixed;bottom:calc(64px + var(--safe-area-bottom));right:max(18px,env(safe-area-inset-right,0px));width:54px;height:54px;border-radius:50%;border:2px solid rgba(255,255,255,.35);background:var(--color-primary);color:var(--text-on-primary, #fff);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #00000059,0 0 0 3px rgba(var(--color-primary-rgb, 184, 49, 61),.3);cursor:pointer;z-index:1000;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s ease,opacity .3s ease}.cb-fab:active{transform:scale(.92)}.cb-fab.cb-fab-hidden{opacity:0;pointer-events:none;transform:scale(.5)}.cb-fab svg{transition:transform .3s cubic-bezier(.4,0,.2,1)}.cb-fab.cb-fab-open{box-shadow:0 6px 20px #0006}.cb-fab-overlay{position:fixed;inset:0;z-index:999;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;animation:cbFabOverlayIn .2s ease}.cb-fab-sheet{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:480px;padding:20px 20px 32px;padding-bottom:calc(32px + var(--safe-area-bottom));animation:cbFabSheetIn .3s ease;border:1px solid var(--border-color);border-bottom:none;box-shadow:0 -8px 32px #0000004d}.cb-fab-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.cb-fab-header h3{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin:0;flex:1;text-align:center}.cb-fab-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.cb-fab-close:hover{background:var(--bg-hover)}.cb-fab-header:before{content:"";width:32px}.cb-fab-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.cb-fab-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border-radius:14px;border:1.5px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2);background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);cursor:pointer;transition:all .2s}@media(hover:hover){.cb-fab-item:hover{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.12)}}.cb-fab-item:active{transform:scale(.95)}.cb-fab-item-icon{width:44px;height:44px;border-radius:50%;background:rgba(var(--color-primary-rgb, 184, 49, 61),.08);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.cb-fab-item-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:500;color:var(--text-primary);text-align:center;line-height:1.2}.cb-fab-item-locked{position:relative;opacity:.5;border-color:var(--border-color);background:var(--bg-card)}.cb-fab-item-locked .cb-fab-item-icon{background:#8080801a;color:var(--text-tertiary)}.cb-fab-item-locked .cb-fab-item-label{color:var(--text-tertiary)}.cb-fab-item-lock{position:absolute;top:8px;right:8px;color:var(--text-tertiary)}.cb-fab-item:nth-child(1){animation:cbFabItemIn .3s .03s both}.cb-fab-item:nth-child(2){animation:cbFabItemIn .3s .06s both}.cb-fab-item:nth-child(3){animation:cbFabItemIn .3s .09s both}.cb-fab-item:nth-child(4){animation:cbFabItemIn .3s .12s both}.cb-fab-item:nth-child(5){animation:cbFabItemIn .3s .15s both}.cb-fab-item:nth-child(6){animation:cbFabItemIn .3s .18s both}@media(min-width:481px){.cb-fab-overlay{align-items:center}.cb-fab-sheet{border-radius:20px;border-bottom:1px solid var(--border-color);max-height:80vh}}[data-theme=dark] .cb-fab-sheet{background:#1e1e1e}[data-mono=true][data-theme=dark] .journey-post-btn{color:#111}[data-mono=true][data-theme=dark] .journey-btn-spinner{border-color:#0003;border-top-color:#111}.cb-section-locked-wrap{position:relative;overflow:hidden;border-radius:16px}.cb-section-locked-content{filter:blur(5px);opacity:.4;pointer-events:none;-webkit-user-select:none;user-select:none}.cb-section-locked-overlay{position:absolute;inset:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px;color:var(--text-primary)}.cb-section-locked-overlay>svg{opacity:.6}.cb-section-locked-overlay>span{font-size:.88rem;font-weight:600;text-align:center;color:var(--text-secondary)}.cb-section-locked-btn{margin-top:4px;padding:10px 28px;border:none;border-radius:24px;background:var(--color-primary);color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;box-shadow:0 4px 14px rgba(var(--color-primary-rgb),.4);transition:transform .15s ease}.cb-section-locked-btn:active{transform:scale(.95)}.client-header{background:transparent;padding:calc(16px + var(--safe-area-top)) 20px 16px}.header-content{max-width:600px;margin:0 auto;display:flex;align-items:center;justify-content:center;padding:0 10px;position:relative}.header-back-btn{position:absolute;left:10px;background:none;border:none;color:var(--text-secondary, #aaa);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .2s}.header-back-btn:hover{color:var(--color-primary)}.header-actions{position:absolute;right:10px;display:flex;align-items:center;gap:6px}.header-actions button{background:none;border:none;color:var(--text-secondary, #aaa);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .2s}.header-actions button:hover{color:var(--text-primary, #fff)}.header-logo{height:50px;width:50px;border-radius:50%;object-fit:cover}.block-bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background:var(--bg-card);border-top:1px solid var(--border-color);z-index:100;padding-bottom:var(--safe-area-bottom)}[data-mono=true][data-theme=light] .block-bottom-nav{background:#f0f0f0;border-top-color:#0000001a}[data-mono=true][data-theme=dark] .block-bottom-nav{background:#0a0a0a;border-top-color:#ffffff14}.block-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 0;background:none;border:none;cursor:pointer;color:var(--text-tertiary);transition:color .2s;-webkit-tap-highlight-color:transparent}.block-nav-tab span{font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:600;letter-spacing:.3px}.block-nav-tab svg{width:22px;height:22px}.block-nav-tab.active{color:var(--color-primary)}.block-nav-tab:not(.active):hover{color:var(--text-secondary)}.block-nav-tab.nav-locked{opacity:.4;pointer-events:none}.block-nav-tab.nav-locked .nav-lock-icon{position:absolute;top:2px;right:calc(50% - 18px);width:12px;height:12px;opacity:.6}.cb-locked-wrap{position:relative;pointer-events:none;-webkit-user-select:none;user-select:none}.cb-locked-wrap>*{opacity:.35;filter:grayscale(.6)}.cb-locked-wrap>.cb-locked-badge{opacity:1;filter:none}.cb-locked-wrap:after{content:"";position:absolute;inset:0;z-index:2;border-radius:14px}.cb-locked-badge{position:absolute;top:10px;right:10px;z-index:3;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#00000073;border-radius:50%;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}[data-theme=light] .cb-locked-badge{background:#0003}.cb-locked-badge svg{opacity:.9}.spider-chart-wrap{width:100%;display:flex;align-items:center;justify-content:center}.spider-loading{display:flex;align-items:center;justify-content:center;min-height:200px}.spider-spinner{width:28px;height:28px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.spider-empty{display:flex;align-items:center;justify-content:center;min-height:140px}.spider-empty p{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-tertiary);margin:0}.spider-chart-wrap .recharts-tooltip-wrapper{z-index:10}.st-overlay,.st-backdrop{position:fixed;inset:0;z-index:10000}.st-spotlight{position:fixed;border-radius:14px;box-shadow:0 0 0 9999px #000000b8;z-index:10001;pointer-events:none;transition:top .35s ease,left .35s ease,width .35s ease,height .35s ease,opacity .25s ease}.st-spotlight.st-transitioning{opacity:.4}.st-tooltip{position:fixed;width:290px;max-width:calc(100vw - 32px);background:var(--bg-card, #1e1e2e);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:20px;z-index:10002;transition:opacity .25s ease,transform .25s ease}.st-tooltip.st-transitioning{opacity:0;transform:translateY(6px)}@keyframes st-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.st-tooltip-below:before{content:"";position:absolute;top:-8px;left:28px;width:16px;height:16px;background:var(--bg-card, #1e1e2e);border-top:1px solid rgba(255,255,255,.12);border-left:1px solid rgba(255,255,255,.12);transform:rotate(45deg)}.st-tooltip-above:before{content:"";position:absolute;bottom:-8px;left:28px;width:16px;height:16px;background:var(--bg-card, #1e1e2e);border-bottom:1px solid rgba(255,255,255,.12);border-right:1px solid rgba(255,255,255,.12);transform:rotate(45deg)}.st-dots{display:flex;gap:6px;margin-bottom:14px}.st-dot{width:8px;height:8px;border-radius:50%;background:#ffffff26;transition:background .2s,transform .2s}.st-dot.active{background:var(--color-primary, #FF6B35);transform:scale(1.25)}.st-dot.done{background:var(--color-primary, #FF6B35);opacity:.45}.st-title{margin:0 0 6px;font-size:1.05rem;font-weight:700;color:var(--text-primary, #fff)}.st-body{margin:0 0 16px;font-size:.88rem;line-height:1.45;color:var(--text-secondary, rgba(255, 255, 255, .65))}.st-actions{display:flex;gap:10px}.st-btn{flex:1;padding:10px 0;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s}.st-btn:active{opacity:.8}.st-btn-next{background:var(--color-primary, #FF6B35);color:#fff}.st-btn-back{background:#ffffff14;color:var(--text-primary, #fff)}.st-skip{display:block;margin:14px auto 0;background:none;border:none;font-size:.78rem;color:var(--text-secondary, rgba(255, 255, 255, .45));cursor:pointer;text-decoration:underline;text-underline-offset:3px}.st-skip:hover{color:var(--text-primary, #fff)}.al-overlay{position:fixed;inset:0;background:#000000b3;z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:al-fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes al-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes al-slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.al-modal{background:#ffffffe0;-webkit-backdrop-filter:blur(40px) saturate(180%);backdrop-filter:blur(40px) saturate(180%);border-radius:20px 20px 0 0;width:100%;max-width:480px;max-height:85vh;overflow-y:auto;padding:20px 20px calc(32px + var(--safe-area-bottom));animation:al-slideUp .3s ease;border:1px solid var(--border-color);border-bottom:none;box-shadow:0 -8px 32px #0000004d}.al-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.al-header h3{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin:0;flex:1;text-align:center}.al-close,.al-back{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.al-close:hover,.al-back:hover{background:var(--bg-hover)}.al-header .al-close:first-child~h3{margin-left:-32px}.al-subtitle{text-align:center;color:var(--text-secondary);font-size:.9rem;margin:4px 0 16px}.al-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.al-type-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border-radius:14px;border:1.5px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2);background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);color:var(--text-primary);cursor:pointer;transition:all .2s;font-size:.82rem;font-weight:500}@media(hover:hover){.al-type-btn:hover{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.12)}}.al-type-icon{width:44px;height:44px;border-radius:50%;background:rgba(var(--color-primary-rgb, 184, 49, 61),.08);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.al-details{margin-top:16px}.al-label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px;margin-top:16px}.al-label:first-child{margin-top:0}.al-custom-name{width:100%;padding:10px 12px;border-radius:10px;border:1.5px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2);background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);color:var(--text-primary);font-size:.95rem;font-weight:600;font-family:inherit;outline:none;transition:border-color .2s;box-sizing:border-box}.al-custom-name:focus{border-color:var(--color-primary)}.al-custom-name::placeholder{font-weight:400;color:var(--text-tertiary)}.al-duration-presets{display:flex;gap:8px;flex-wrap:wrap}.al-duration-btn{padding:10px 18px;border-radius:10px;border:1.5px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2);background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);color:var(--text-primary);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:52px}.al-duration-btn.active{border-color:var(--color-primary);background:var(--color-primary);color:var(--text-on-primary, #fff)}.al-duration-btn:hover:not(.active){border-color:var(--color-primary)}.al-duration-custom{width:80px;padding:10px 12px;border-radius:10px;border:1.5px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2);background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);color:var(--text-primary);font-size:.95rem;font-weight:600;text-align:center;outline:none;transition:border-color .2s}.al-duration-custom:focus,.al-duration-custom.active{border-color:var(--color-primary)}.al-duration-custom::placeholder{font-weight:400;color:var(--text-tertiary)}.al-notes{width:100%;padding:10px 12px;border-radius:10px;border:1.5px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2);background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);color:var(--text-primary);font-size:.9rem;font-family:inherit;resize:none;outline:none;transition:border-color .2s;box-sizing:border-box}.al-notes:focus{border-color:var(--color-primary)}.al-notes::placeholder{color:var(--text-tertiary)}.al-calories-row{display:flex;align-items:center;gap:8px;margin-bottom:14px}.al-calories-input{flex:1;max-width:120px;padding:10px 14px;border-radius:10px;border:1.5px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2);background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);color:var(--text-primary);font-size:.9rem;font-family:Plus Jakarta Sans,sans-serif;text-align:center;outline:none;transition:border-color .2s;-moz-appearance:textfield}.al-calories-input::-webkit-outer-spin-button,.al-calories-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.al-calories-input:focus{border-color:var(--color-primary)}.al-calories-input::placeholder{color:var(--text-tertiary)}.al-calories-unit{font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:500;color:var(--text-tertiary)}.al-save-btn{width:100%;margin-top:20px;padding:14px;border-radius:12px;border:none;background:var(--color-primary);color:var(--text-on-primary, #fff);font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .2s}.al-save-btn:hover:not(:disabled){opacity:.9}.al-save-btn:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .al-modal{background:#1e1e1ed9}@media(min-width:481px){.al-overlay{align-items:center}.al-modal{border-radius:20px;max-height:80vh;border-bottom:1px solid var(--border-color)}}.nut-hub-page{min-height:100vh;background:var(--bg-body);display:flex;flex-direction:column}.nut-hub-loading{display:flex;align-items:center;justify-content:center;flex:1;min-height:200px}.nut-hub-main{flex:1;padding:0 16px calc(80px + var(--safe-area-bottom, 0px));max-width:500px;margin:0 auto;width:100%}.nhub-setup-prompt{text-align:center;padding:60px 20px}.nhub-setup-icon{width:56px;height:56px;margin:0 auto 16px;color:var(--color-primary);opacity:.7}.nhub-setup-icon svg{width:100%;height:100%}.nhub-setup-prompt h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:800;color:var(--text-primary);margin:0 0 8px}.nhub-setup-prompt p{font-size:.85rem;color:var(--text-secondary);margin:0 0 24px;line-height:1.4}.nhub-setup-btn{padding:14px 32px;border:none;border-radius:14px;background:var(--color-primary);color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.95rem;cursor:pointer;box-shadow:var(--shadow-primary);transition:transform .15s;-webkit-tap-highlight-color:transparent}.nhub-setup-btn:active{transform:scale(.97)}.nhub-top-section{padding:16px 0 8px}.nhub-greeting-row{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}.nhub-greeting h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.35rem;font-weight:800;color:var(--text-primary);margin:0 0 2px}.nhub-greeting p{font-size:.8rem;color:var(--text-secondary);margin:0}.nhub-streak{display:flex;align-items:center;gap:4px;background:linear-gradient(135deg,#fbbf241f,#f59e0b14);border:1px solid rgba(245,158,11,.2);border-radius:12px;padding:8px 12px;flex-shrink:0}.nhub-streak-flame{width:20px;height:20px;color:#f59e0b;display:flex;align-items:center}.nhub-streak-flame svg{width:100%;height:100%}.nhub-streak-count{font-family:Plus Jakarta Sans,sans-serif;font-weight:800;font-size:1.05rem;color:#f59e0b;line-height:1}.nhub-streak-label{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-secondary);font-weight:500}.nhub-rings-row{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-bottom:14px}.nhub-macro-cta{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px 16px;margin-bottom:14px;border:1px dashed var(--border-color);border-radius:12px;background:transparent;color:var(--color-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease}.nhub-macro-cta:active{background:var(--color-primary-light);border-color:var(--color-primary)}.nhub-ring-wrap{display:flex;flex-direction:column;align-items:center;position:relative}.nhub-ring-svg{width:68px;height:68px;transform:rotate(-90deg)}.nhub-ring-track{fill:none;stroke:var(--border-color);stroke-width:8;stroke-linecap:round}.nhub-ring-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .6s ease-out}.nhub-ring-center{position:absolute;top:0;left:50%;transform:translate(-50%);width:68px;height:68px;display:flex;align-items:center;justify-content:center;pointer-events:none;gap:1px}.nhub-ring-value{font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:800;line-height:1}.nhub-ring-unit{font-family:Inter,sans-serif;font-size:.5rem;color:var(--text-tertiary);font-weight:500}.nhub-ring-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--text-secondary);margin-top:2px}.nhub-ring-pct{font-family:Plus Jakarta Sans,sans-serif;font-size:.55rem;font-weight:700;margin-top:1px}.nhub-nudge{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);border:1px solid rgba(var(--color-primary-rgb, 184, 49, 61),.12);color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.78rem;font-weight:500;line-height:1.3;margin-bottom:4px}.nhub-nudge svg{flex-shrink:0;color:var(--color-primary)}.nhub-nudge--complete{background:var(--color-success-bg, rgba(20, 184, 166, .08));border-color:#14b8a633}.nhub-nudge--complete svg{color:var(--color-success, #14b8a6)}.nhub-section-header{display:flex;align-items:baseline;gap:8px;margin-bottom:10px}.nhub-section-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:700;color:var(--text-primary)}.nhub-section-subtitle{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-tertiary);font-weight:500}.nhub-favs-section{padding:14px 0 6px}.nhub-favs-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.nhub-favs-scroll::-webkit-scrollbar{display:none}.nhub-fav-chip{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 14px;background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s;flex-shrink:0;min-width:80px;-webkit-tap-highlight-color:transparent}.nhub-fav-chip:active{transform:scale(.95);border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.04)}@media(hover:hover){.nhub-fav-chip:hover{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(var(--color-primary-rgb, 184, 49, 61),.1)}}.nhub-fav-name{font-family:Plus Jakarta Sans,sans-serif;font-size:.72rem;font-weight:600;color:var(--text-primary);max-width:90px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nhub-fav-cal{font-family:Inter,sans-serif;font-size:.6rem;color:var(--text-tertiary);font-weight:500}.nhub-meals-section{padding:14px 0 6px}.nhub-meals-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.nhub-meal-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 6px 12px;background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:14px;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.nhub-meal-card:active{transform:scale(.96)}.nhub-meal-card:focus{outline:none}.nhub-meal-card:focus:not(:focus-visible){border-color:var(--border-color);background:var(--bg-card);transform:none}@media(hover:hover){.nhub-meal-card:hover{border-color:var(--color-primary)}}.nhub-meal-card--filled{border-color:#14b8a640;background:#14b8a60a}.nhub-meal-card--filled:focus:not(:focus-visible){border-color:#14b8a640;background:#14b8a60a}.nhub-meal-icon{width:22px;height:22px;color:var(--text-secondary)}.nhub-meal-icon svg{width:100%;height:100%}.nhub-meal-card--filled .nhub-meal-icon{color:var(--color-success, #14b8a6)}.nhub-meal-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.62rem;font-weight:600;color:var(--text-primary);text-align:center}.nhub-meal-cal{font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:700;color:var(--color-success, #14b8a6)}.nhub-meal-empty{font-family:Inter,sans-serif;font-size:.6rem;font-weight:600;color:var(--text-tertiary)}.nhub-week-section{padding:14px 0 6px}.nhub-week-bars{display:flex;gap:6px;align-items:flex-end;height:80px;padding:0 4px}.nhub-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.nhub-bar-track{flex:1;width:100%;max-width:28px;background:var(--border-color);border-radius:6px;position:relative;overflow:hidden;display:flex;align-items:flex-end}.nhub-bar-fill{width:100%;border-radius:6px;transition:height .5s ease-out;min-height:0}.nhub-bar-good{background:var(--color-success, #14b8a6)}.nhub-bar-mid{background:var(--color-warning, #f59e0b)}.nhub-bar-low{background:rgba(var(--color-primary-rgb, 184, 49, 61),.5)}.nhub-bar-empty{background:transparent}.nhub-bar-day{font-family:Plus Jakarta Sans,sans-serif;font-size:.6rem;font-weight:600;color:var(--text-tertiary)}.nhub-bar-today .nhub-bar-day{color:var(--color-primary);font-weight:800}.nhub-bar-today .nhub-bar-track{border:1px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2)}.nhub-actions-section{display:flex;flex-direction:column;gap:12px;padding:14px 0 20px}.nut-hub-card{display:flex;align-items:center;gap:14px;padding:18px 16px;background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:16px;cursor:pointer;transition:all .2s;text-align:left;width:100%}.nut-hub-card:active{transform:scale(.98)}.nut-hub-card:focus{outline:none}.nut-hub-card:focus:not(:focus-visible){border-color:var(--border-color);transform:none}@media(hover:hover){.nut-hub-card:hover{border-color:var(--color-primary);box-shadow:0 4px 16px rgba(var(--color-primary-rgb, 184, 49, 61),.12)}}.nut-hub-card--locked{cursor:default;opacity:.7}.nut-hub-card--locked:active{transform:none}@media(hover:hover){.nut-hub-card--locked:hover{border-color:var(--border-color);box-shadow:none}}.nut-hub-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nut-hub-card-icon--manual{background:rgba(var(--color-primary-rgb, 184, 49, 61),.1);color:var(--color-primary)}.nut-hub-card-icon--ai{background:linear-gradient(135deg,#38b6ff26,#8b5cf626);color:#8b5cf6}.nut-hub-card-body{flex:1;min-width:0}.nut-hub-card-title-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.nut-hub-card-body h3{font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.nut-hub-card-title-row h3{margin-bottom:0}.nut-hub-card-body p{font-size:.75rem;color:var(--text-secondary);margin:0;line-height:1.35}.nut-hub-card-arrow{flex-shrink:0;color:var(--text-tertiary)}.nut-hub-card-lock{flex-shrink:0;color:var(--text-tertiary);opacity:.5}.nut-hub-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:6px;font-size:.6rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.nut-hub-badge--beta{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff}.nut-hub-coming-soon{display:inline-block;margin-top:6px;font-size:.7rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em}.nut-hub-beta-access{display:inline-block;margin-top:6px;font-size:.7rem;font-weight:700;color:#8b5cf6;letter-spacing:.02em}.nhub-toast{position:fixed;bottom:calc(80px + var(--safe-area-bottom, 0px) + 12px);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--color-success, #14b8a6);color:var(--text-on-primary, #fff);border-radius:12px;font-family:Inter,sans-serif;font-size:.82rem;font-weight:600;box-shadow:0 8px 24px #0003;z-index:1100;white-space:nowrap;animation:nhub-toast-in .3s ease-out}@keyframes nhub-toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.nhub-toast svg{flex-shrink:0}[data-theme=dark] .nhub-streak{background:linear-gradient(135deg,#fbbf241a,#f59e0b0f);border-color:#f59e0b26}[data-theme=dark] .nhub-fav-chip,[data-theme=dark] .nhub-meal-card{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .nhub-meal-card--filled{border-color:#2dd4bf33;background:#2dd4bf0f}[data-theme=dark] .nhub-meal-card--filled:focus:not(:focus-visible){border-color:#2dd4bf33;background:#2dd4bf0f}[data-theme=dark] .nhub-meal-card:focus:not(:focus-visible){border-color:#ffffff0f;background:#1e1e1ecc}[data-theme=dark] .nut-hub-card:focus:not(:focus-visible){border-color:#ffffff0f}[data-theme=dark] .nhub-meal-card--filled .nhub-meal-icon,[data-theme=dark] .nhub-meal-cal{color:#2dd4bf}[data-theme=dark] .nut-hub-card{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .nhub-nudge{background:#da3f4f0f;border-color:#da3f4f1f}[data-theme=dark] .nhub-nudge--complete{background:#2dd4bf0f;border-color:#2dd4bf26}[data-theme=dark] .nhub-bar-track{background:#ffffff0f}[data-theme=dark] .nhub-bar-good{background:var(--color-success, #2dd4bf)}@media(min-width:400px){.nhub-ring-svg,.nhub-ring-center{width:76px;height:76px}.nhub-ring-value{font-size:.9rem}.nhub-meal-card{padding:16px 8px 14px}.nhub-fav-chip{padding:10px 16px;min-width:90px}}.nhub-fab{position:fixed;bottom:calc(64px + var(--safe-area-bottom));right:max(18px,env(safe-area-inset-right,0px));width:54px;height:54px;border-radius:50%;border:2px solid rgba(255,255,255,.35);background:var(--color-primary);color:var(--text-on-primary, #fff);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #00000059,0 0 0 3px rgba(var(--color-primary-rgb, 184, 49, 61),.3);cursor:pointer;z-index:1000;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s ease,opacity .3s ease;-webkit-tap-highlight-color:transparent}.nhub-fab:active{transform:scale(.92)}.nhub-fab-hidden{opacity:0;pointer-events:none;transform:scale(.8)}.nhub-fab-overlay{position:fixed;inset:0;z-index:999;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;animation:nhubFabOverlayIn .2s ease}@keyframes nhubFabOverlayIn{0%{opacity:0}to{opacity:1}}.nhub-fab-sheet{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:480px;padding:20px 20px 32px;padding-bottom:calc(32px + var(--safe-area-bottom));animation:nhubFabSheetIn .3s ease;border:1px solid var(--border-color);box-shadow:0 -8px 32px #0000004d}@keyframes nhubFabSheetIn{0%{transform:translateY(100%)}to{transform:translateY(0)}}[data-theme=dark] .nhub-fab-sheet{background:#1a1a1a;border-color:#ffffff14}.nhub-fab-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.nhub-fab-header h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1.05rem;font-weight:800;color:var(--text-primary);margin:0}.nhub-fab-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-card-elevated, #f0f0f0);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.nhub-fab-close:hover{background:var(--border-color)}.nhub-fab-meals{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:16px}.nhub-fab-meal-btn{padding:8px 4px;border-radius:10px;border:1.5px solid var(--border-color);background:none;font-family:Plus Jakarta Sans,sans-serif;font-size:.78rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.nhub-fab-meal-btn.active{background:var(--color-primary);color:var(--text-on-primary);border-color:var(--color-primary);font-weight:700}.nhub-fab-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.nhub-fab-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 12px;border-radius:14px;border:1.5px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2);background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.nhub-fab-item:active{transform:scale(.95)}.nhub-fab-item:nth-child(1){animation:nhubFabItemIn .3s .03s both}.nhub-fab-item:nth-child(2){animation:nhubFabItemIn .3s .06s both}.nhub-fab-item:nth-child(3){animation:nhubFabItemIn .3s .09s both}.nhub-fab-item:nth-child(4){animation:nhubFabItemIn .3s .12s both}@keyframes nhubFabItemIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.nhub-fab-item-icon{width:36px;height:36px;border-radius:10px;background:rgba(var(--color-primary-rgb, 184, 49, 61),.12);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.nhub-fab-item-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.78rem;font-weight:700;color:var(--text-primary);text-align:center}[data-theme=dark] .nhub-fab-item{border-color:rgba(var(--color-primary-rgb, 218, 63, 79),.25);background:rgba(var(--color-primary-rgb, 218, 63, 79),.08)}[data-theme=dark] .nhub-fab-item-icon{background:rgba(var(--color-primary-rgb, 218, 63, 79),.15)}[data-theme=dark] .nhub-fab-meal-btn{border-color:#ffffff1a}@media(min-width:600px){.nhub-fab-overlay{align-items:center}.nhub-fab-sheet{border-radius:20px;max-width:400px}}.nhub-quick-row{display:flex;gap:8px;padding:0 0 8px}.nhub-copy-day-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:10px;border:1px solid var(--border-color);background:none;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.nhub-copy-day-btn:active{transform:scale(.96)}.nhub-qa-overlay{position:fixed;inset:0;z-index:1099;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:nhubFabOverlayIn .15s ease}.nhub-qa-picker{position:fixed;bottom:calc(80px + var(--safe-area-bottom, 0px) + 20px);left:50%;transform:translate(-50%);z-index:1100;background:var(--bg-card, #fff);border:1px solid var(--border-color);border-radius:16px;padding:14px 16px 12px;width:calc(100% - 32px);max-width:360px;box-shadow:0 12px 40px #00000040;animation:nhubQaIn .2s ease}@keyframes nhubQaIn{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}[data-theme=dark] .nhub-qa-picker{background:#1e1e1e;border-color:#ffffff14}.nhub-qa-picker-label{font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-secondary);margin:0 0 10px;text-align:center}.nhub-qa-picker-label strong{color:var(--text-primary);font-weight:700}.nhub-qa-picker-options{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.nhub-qa-picker-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 4px;border-radius:12px;border:1.5px solid var(--border-color);background:none;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.nhub-qa-picker-btn:active{transform:scale(.95);border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.06)}.nhub-qa-picker-icon{width:20px;height:20px;color:var(--text-secondary)}.nhub-qa-picker-icon svg{width:100%;height:100%}.nhub-qa-picker-btn span:last-child{font-family:Plus Jakarta Sans,sans-serif;font-size:.68rem;font-weight:600;color:var(--text-primary)}.nut-loading-inline{display:flex;align-items:center;justify-content:center;min-height:60vh}.nut-loading-inline .cb-loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.nut-page{min-height:100vh;background:var(--bg-body);padding-bottom:calc(80px + var(--safe-area-bottom));display:flex;flex-direction:column}[data-theme=dark] .nut-page{--bg-card: #1e1e1e;--bg-card-elevated: #2d2d2d}.nut-dark-zone{background:var(--bg-body);padding-bottom:32px;position:relative;overflow:hidden}.nut-dark-zone:after{content:"";position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;background:radial-gradient(circle,rgba(var(--color-primary-rgb),.12) 0%,rgba(var(--color-primary-rgb),.04) 40%,transparent 70%);pointer-events:none;z-index:0}.nut-dark-content{max-width:600px;margin:0 auto;padding:12px 20px 0;position:relative;z-index:1}.nut-light-zone{flex:1;background:var(--bg-body);position:relative;z-index:2;padding-bottom:40px}.nut-light-content{max-width:600px;margin:0 auto;padding:24px 20px}.nut-main{max-width:600px;margin:0 auto;padding:20px 20px calc(80px + var(--safe-area-bottom))}.nut-week-strip{margin-bottom:20px}.nut-week-header{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:14px}.nut-week-arrow{width:28px;height:28px;border-radius:50%;border:1px solid var(--border-color);background:transparent;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.nut-week-arrow:hover:not(:disabled){border-color:var(--color-primary);color:var(--text-primary)}.nut-week-arrow:disabled{opacity:.25;cursor:not-allowed}.nut-week-month-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:700;color:var(--text-primary);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .2s}.nut-week-month-label:hover{background:#8080801a}.nut-week-days{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.nut-week-day{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 4px 10px;background:transparent;border:none;border-radius:14px;cursor:pointer;transition:all .2s}.nut-week-day:hover:not(:disabled):not(.selected){background:#8080801a}.nut-week-day-letter{font-family:Plus Jakarta Sans,sans-serif;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary)}.nut-week-day-num{font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.nut-week-day.selected .nut-week-day-num{background:var(--color-primary);color:var(--text-on-primary);font-weight:700}.nut-week-day.selected .nut-week-day-letter{color:var(--color-primary)}.nut-week-day.today:not(.selected) .nut-week-day-num{border:1.5px solid var(--color-primary);color:var(--color-primary)}.nut-settings-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:8px;transition:all .2s}.nut-settings-btn:hover{color:var(--text-primary);background:#8080801a}.nut-setup-intro{margin-bottom:24px}.nut-setup-intro h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.5rem;color:var(--text-primary);margin:0 0 8px}.nut-setup-intro p{font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-secondary);margin:0}.nut-calc-form{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:24px 20px;box-shadow:var(--shadow-glow)}[data-theme=dark] .nut-calc-form{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nut-form-group{margin-bottom:18px}.nut-form-group label{display:block;font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.nut-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.nut-form-group input[type=number],.nut-form-group input[type=text],.nut-form-group select{width:100%;padding:12px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-primary);outline:none;transition:border-color .2s;box-sizing:border-box}.nut-form-group input:focus,.nut-form-group select:focus{border-color:var(--color-primary)}.nut-toggle-group{display:flex;gap:0;border-radius:10px;overflow:hidden;border:1px solid var(--border-color)}.nut-toggle-group button{flex:1;padding:10px;background:var(--bg-secondary);border:none;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s}.nut-toggle-group button.active{background:var(--color-primary);color:var(--text-on-primary)}.nut-input-unit{display:flex;gap:8px;align-items:center}.nut-input-unit input{flex:1;min-width:0}.nut-unit-toggle{display:flex;border-radius:8px;overflow:hidden;border:1px solid var(--border-color);flex-shrink:0}.nut-unit-toggle button{padding:10px 12px;background:var(--bg-secondary);border:none;font-family:Inter,sans-serif;font-size:.75rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s}.nut-unit-toggle button.active{background:var(--color-primary);color:var(--text-on-primary)}.nut-height-imperial{display:flex;gap:6px;flex:1}.nut-height-imperial input{flex:1;min-width:0}.nut-goal-options{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.nut-goal-options button{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s;font-family:Inter,sans-serif;color:var(--text-secondary)}.nut-goal-options button.active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb),.08);color:var(--color-primary)}.nut-goal-icon{font-family:Plus Jakarta Sans,sans-serif;font-size:1.2rem;font-weight:700}.nut-goal-options button span:last-child{font-size:.75rem;font-weight:600}.nut-deficit-options{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.nut-deficit-options button{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 8px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s;font-family:Inter,sans-serif;color:var(--text-secondary)}.nut-deficit-options button.active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb),.08);color:var(--color-primary)}.nut-deficit-options button strong{font-size:.8rem}.nut-deficit-options button span{font-size:.7rem;opacity:.7}.nut-calc-btn{width:100%;padding:14px;background:var(--color-primary);color:var(--text-on-primary);border:none;border-radius:12px;font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:6px}.nut-calc-btn:disabled{opacity:.4;cursor:not-allowed}.nut-calc-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.nut-calc-results{margin-top:24px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:24px 20px;box-shadow:var(--shadow-glow)}[data-theme=dark] .nut-calc-results{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nut-calc-results h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;color:var(--text-primary);text-align:center;margin:0 0 20px}.nut-calc-rings{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.nut-calc-info{border-top:1px solid var(--border-color);padding-top:16px;margin-bottom:16px}.nut-calc-info-row{display:flex;justify-content:space-between;padding:8px 0;font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-secondary)}.nut-calc-info-row span:last-child{font-weight:600;color:var(--text-primary)}.nut-save-targets-btn{width:100%;padding:14px;background:var(--color-primary);color:var(--text-on-primary);border:none;border-radius:12px;font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.nut-save-targets-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.nut-rings-row{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:8px 0 0}.nut-rings-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:20px 16px;box-shadow:var(--shadow-glow)}[data-theme=dark] .nut-rings-grid{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nut-rings-row .nut-ring-wrap{align-items:center}.nut-rings-row .nut-ring-svg,.nut-rings-row .nut-ring-center{width:76px;height:76px}.nut-rings-row .nut-ring-value{font-size:.85rem;font-weight:800}.nut-rings-row .nut-ring-target{font-size:.5rem;color:var(--text-tertiary)}.nut-rings-row .nut-ring-label{font-size:.5rem;margin-top:2px}.nut-rings-row .nut-ring-pct{font-size:.55rem;color:var(--text-secondary);margin-top:2px;font-weight:700}.nut-ring-wrap{position:relative;display:flex;flex-direction:column;align-items:center}.nut-ring-svg{width:130px;height:130px;transform:rotate(-90deg)}.nut-arc-track{fill:none;stroke:var(--border-color);stroke-width:24;stroke-linecap:round}.nut-arc-fill{fill:none;stroke-width:24;stroke-linecap:round;transition:stroke-dashoffset .5s ease-out}.nut-ring-center{position:absolute;top:0;left:50%;transform:translate(-50%);width:130px;height:130px;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.nut-ring-value{font-family:Plus Jakarta Sans,sans-serif;font-size:1.15rem;font-weight:700;line-height:1}.nut-ring-target{font-family:Inter,sans-serif;font-size:.6rem;color:var(--text-tertiary);margin-top:2px}.nut-ring-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.nut-ring-pct{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:700;margin-top:4px}.nut-meal-selector{display:flex;gap:6px;margin-bottom:14px}.nut-meal-pill{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 6px;background:var(--bg-card);border:1.5px solid rgba(0,0,0,.06);border-radius:14px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:600;color:var(--text-secondary);letter-spacing:.3px;box-shadow:var(--shadow-glow)}[data-theme=dark] .nut-meal-pill{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nut-meal-pill:active{transform:scale(.97);transition:transform .1s ease}.nut-meal-icon{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center}.nut-meal-icon svg{width:18px;height:18px}.nut-meal-icon-breakfast{background:radial-gradient(circle at 30% 30%,#ff98002e,#ff98000f);color:#ff9800}.nut-meal-icon-lunch{background:radial-gradient(circle at 30% 30%,#f59e0b2e,#f59e0b0f);color:#f59e0b}.nut-meal-icon-dinner{background:radial-gradient(circle at 30% 30%,#673ab729,#673ab70d);color:#7c3aed}.nut-meal-icon-snacks{background:radial-gradient(circle at 30% 30%,#e91e6329,#e91e630d);color:#e91e63}.nut-meal-pill.active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb),.08);color:var(--color-primary)}.nut-meal-pill:hover:not(.active){border-color:rgba(var(--color-primary-rgb),.15);transform:translateY(-1px)}.nut-meals-list{display:flex;flex-direction:column;gap:14px}.nut-meal-card{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-glow)}[data-theme=dark] .nut-meal-card{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nut-meal-card-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border-color)}.nut-meal-card-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nut-meal-card-icon svg{width:16px;height:16px}.nut-meal-card-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:700;color:var(--text-primary);flex:1}.nut-meal-card-cal{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:600;color:var(--color-primary)}.nut-meal-add-btn{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--color-primary);background:transparent;color:var(--color-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.nut-meal-add-btn:hover{background:var(--color-primary);color:var(--text-on-primary)}.nut-meal-add-btn:active{transform:scale(.9)}.nut-add-picker-backdrop{position:fixed;inset:0;background:var(--overlay-bg);z-index:999;animation:pickerFadeIn .2s ease-out}@keyframes pickerFadeIn{0%{opacity:0}to{opacity:1}}@keyframes pickerSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.nut-add-picker{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-radius:20px 20px 0 0;padding:12px 20px 28px;box-shadow:0 -4px 24px #00000026;z-index:1000;animation:pickerSlideUp .25s ease-out}.nut-add-picker-handle{width:36px;height:4px;background:var(--border-color);border-radius:2px;margin:0 auto 14px}.nut-add-picker-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:700;color:var(--text-primary);text-align:center;margin:0 0 16px}.nut-add-picker-options{display:grid;grid-template-columns:1fr 1fr;gap:10px}.nut-add-picker-options button{display:flex;align-items:center;gap:10px;padding:14px 16px;border:1px solid var(--border-color);border-radius:14px;background:var(--bg-card);cursor:pointer;transition:transform .15s,background .15s;-webkit-tap-highlight-color:transparent;font-family:inherit}.nut-add-picker-options button:active{transform:scale(.96)}.nut-add-picker-options button svg{width:24px;height:24px;flex-shrink:0}.nut-add-picker-options button:nth-child(1){color:var(--color-primary)}.nut-add-picker-options button:nth-child(2){color:#2196f3}.nut-add-picker-options button:nth-child(3){color:#4caf50}.nut-add-picker-options button:nth-child(4){color:#ff9800}.nut-add-picker-options button span{font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:600}[data-theme=dark] .nut-add-picker{background:#1e1e1ef2;border-top:1px solid rgba(255,255,255,.06);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .nut-add-picker-options button{background:#282828cc;border-color:#ffffff14}.nut-meal-bars{padding:10px 16px 8px;display:flex;flex-direction:column;gap:5px;border-bottom:1px solid var(--border-color)}.nut-meal-bar-row{display:flex;align-items:center;gap:8px}.nut-meal-bar-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:700;width:12px;text-align:center;flex-shrink:0}.nut-meal-bar-track{flex:1;height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.nut-meal-bar-fill{height:100%;border-radius:3px;transition:width .4s ease-out;min-width:0}.bar-protein{background:#14b8a6}.bar-carbs{background:#f59e0b}.bar-fats{background:#8b5cf6}.bar-cals{background:var(--color-primary)}[data-theme=dark] .bar-protein{background:#2dd4bf}[data-theme=dark] .bar-carbs{background:#fbbf24}[data-theme=dark] .bar-fats{background:#a78bfa}.nut-meal-bar-val{font-family:Inter,sans-serif;font-size:.65rem;font-weight:600;color:var(--text-tertiary);width:32px;text-align:right;flex-shrink:0}.nut-meal-empty{padding:16px;text-align:center}.nut-meal-empty p{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-tertiary);margin:0}.nut-meal-card .nut-log-list{padding:0;gap:0}.nut-meal-card .nut-log-item{border-radius:0;box-shadow:none;border-bottom:1px solid var(--border-color);padding:10px 16px}.nut-meal-card .nut-log-item:last-child{border-bottom:none}.nut-meal-card-totals{display:flex;justify-content:center;gap:14px;padding:8px 16px;background:var(--bg-secondary);font-size:.7rem;font-weight:600}.nut-card-actions{grid-column:1 / -1;display:flex;justify-content:center;gap:6px;margin-top:4px;padding-top:14px;border-top:1px solid rgba(0,0,0,.06)}[data-theme=dark] .nut-card-actions{border-top-color:#ffffff14}.nut-card-action{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 14px;border:none;border-radius:12px;background:transparent;cursor:pointer;transition:background .2s,transform .15s;font-family:Plus Jakarta Sans,sans-serif}.nut-card-action svg{width:22px;height:22px}.nut-card-action span{font-size:.62rem;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.nut-action-scan{color:var(--color-primary)}.nut-action-search{color:#2196f3}.nut-action-manual{color:#4caf50}.nut-action-fav{color:#ff9800}.nut-card-action:hover{background:#0000000a}[data-theme=dark] .nut-card-action:hover{background:#ffffff0f}.nut-card-action:active{transform:scale(.92);transition:transform .1s ease}.nut-quick-row{display:flex;gap:10px;margin-bottom:16px}.nut-copy-day-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:12px;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000000f;font-family:Inter,sans-serif;font-size:.8rem;font-weight:600;color:var(--color-primary);white-space:nowrap}[data-theme=dark] .nut-copy-day-btn{background:#1e1e1ecc;border-color:#ffffff0f}.nut-copy-day-btn:hover{border-color:var(--color-primary)}.nut-copy-day-btn:active{transform:scale(.98)}.nut-copy-from-popup{width:90%;max-width:360px;background:var(--bg-card);border-radius:20px;padding:20px;margin:auto}[data-theme=dark] .nut-copy-from-popup{background:#1e1e1e;border:1px solid rgba(255,255,255,.08)}.nut-copy-from-header{display:flex;align-items:center;gap:8px;margin-bottom:4px;color:var(--color-primary)}.nut-copy-from-header span{font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;color:var(--text-primary);flex:1}.nut-copy-from-hint{font-family:Inter,sans-serif;font-size:.75rem;color:var(--text-secondary);margin:0 0 16px}.nut-copy-from-popup .nut-cal-header{margin-bottom:10px}.nut-copy-from-popup .nut-cal-day.selected{background:var(--text-secondary);opacity:.4}.nut-copy-from-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 0 4px;font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-secondary)}.nut-date-nav{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:16px;margin-top:4px}.nut-date-arrow{width:36px;height:36px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.nut-date-arrow:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.nut-date-arrow:disabled{opacity:.3;cursor:not-allowed}.nut-date-label{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:600}.nut-date-label svg{color:var(--color-primary);flex-shrink:0}.nut-date-label:hover{border-color:var(--color-primary)}.nut-calendar{background:var(--bg-card);border-radius:16px;padding:16px;margin-bottom:20px;box-shadow:var(--shadow-glow)}.nut-cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.nut-cal-header span{font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:700;color:var(--text-primary)}.nut-cal-header button{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-secondary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.nut-cal-header button:hover:not(:disabled){color:var(--color-primary)}.nut-cal-header button:disabled{opacity:.3;cursor:not-allowed}.nut-cal-days-header{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:6px}.nut-cal-days-header span{font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;padding:4px 0}.nut-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.nut-cal-day{aspect-ratio:1;border-radius:50%;border:none;background:transparent;font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.nut-cal-day:hover:not(:disabled):not(.selected){background:var(--bg-secondary)}.nut-cal-day.today{border:1.5px solid var(--color-primary);font-weight:700}.nut-cal-day.selected{background:var(--color-primary);color:var(--text-on-primary);font-weight:700}.nut-log-summary{display:flex;justify-content:center;gap:14px;padding:12px;background:var(--bg-secondary);border-radius:10px;margin-top:10px;font-size:.8rem;font-weight:600}.nut-log-section h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 12px}.nut-log-empty{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:30px 20px;text-align:center;box-shadow:var(--shadow-glow)}[data-theme=dark] .nut-log-empty{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nut-log-empty p{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-tertiary);margin:0}.nut-log-list{display:flex;flex-direction:column;gap:8px}.nut-log-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s}.nut-log-item:active{background:var(--bg-secondary)}.nut-log-item-info{flex:1;min-width:0}.nut-log-item-name{display:block;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nut-log-item-serving{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-tertiary)}.nut-log-item-macros{display:flex;gap:6px;flex-shrink:0}.nut-macro-p{font-family:Inter,sans-serif;font-size:.75rem;font-weight:600;color:#14b8a6}.nut-macro-c{font-family:Inter,sans-serif;font-size:.75rem;font-weight:600;color:#f59e0b}.nut-macro-f{font-family:Inter,sans-serif;font-size:.75rem;font-weight:600;color:#8b5cf6}.nut-macro-cal{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:600;color:var(--color-primary)}[data-theme=dark] .nut-macro-p{color:#2dd4bf}[data-theme=dark] .nut-macro-c{color:#fbbf24}[data-theme=dark] .nut-macro-f{color:#a78bfa}.nut-log-delete{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:6px;transition:all .2s;flex-shrink:0}.nut-log-delete:hover{color:#e53e3e;background:#e53e3e14}.nut-modal-overlay{position:fixed;inset:0;background:#0009;z-index:1000;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto}.nut-search-panel{width:100%;max-width:600px;max-height:90vh;max-height:90dvh;overflow-y:auto;background:var(--bg-card);border-radius:0 0 20px 20px;padding-top:max(0px,var(--safe-area-top));flex-shrink:0}.nut-search-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 0}.nut-search-header h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0}.nut-search-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:8px;margin:-8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.nut-modal{width:100%;max-width:600px;max-height:90vh;max-height:90dvh;overflow-y:auto;background:var(--bg-card);border-radius:0 0 20px 20px;padding:24px 20px;padding-top:max(24px,var(--safe-area-top));padding-bottom:24px;flex-shrink:0}.nut-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.nut-modal-header h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.nut-modal-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:8px;margin:-8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.nut-scan-area{text-align:center}.nut-scanner-wrapper{position:relative;width:100%;max-height:220px;border-radius:12px;overflow:hidden;margin-bottom:16px;background:#000}.nut-scanner-view{width:100%;position:relative}.nut-scanner-view video{width:100%;display:block;border-radius:12px;object-fit:cover;max-height:220px}.nut-scanner-view canvas{position:absolute;top:0;left:0;width:100%;height:100%}.nut-scanner-view canvas.drawingBuffer{display:none}.nut-scan-line{position:absolute;left:10%;right:10%;height:2px;background:var(--color-primary);box-shadow:0 0 8px rgba(var(--color-primary-rgb),.8),0 0 20px rgba(var(--color-primary-rgb),.4);z-index:10;animation:scanLine 2s ease-in-out infinite;pointer-events:none}@keyframes scanLine{0%,to{top:25%;opacity:.9}50%{top:75%;opacity:1}}.nut-scan-detected-overlay{position:absolute;inset:0;background:#000000bf;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:20;border-radius:12px}.nut-scan-detected-tick{width:48px;height:48px}.nut-scan-detected-label{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:#4caf50;margin:0}.nut-scan-detected-code{font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;color:#fff9;letter-spacing:2px;margin:0}.nut-scan-start-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;background:var(--color-primary);color:var(--text-on-primary);border:none;border-radius:12px;font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer}.nut-scan-start-btn svg{width:22px;height:22px}.nut-scan-hint{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-secondary)}.nut-barcode-divider{display:flex;align-items:center;gap:12px;margin:20px 0 16px}.nut-barcode-divider:before,.nut-barcode-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.nut-barcode-divider span{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-tertiary);white-space:nowrap}.nut-barcode-manual{display:flex;gap:8px}.nut-barcode-manual input{flex:1;padding:12px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-primary);outline:none}.nut-barcode-manual input:focus{border-color:var(--color-primary)}.nut-barcode-manual button{padding:12px 18px;background:var(--color-primary);color:var(--text-on-primary);border:none;border-radius:10px;font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;flex-shrink:0;transition:all .2s}.nut-barcode-manual button:disabled{opacity:.5;cursor:not-allowed}.nut-off-credit{font-family:Inter,sans-serif;font-size:.68rem;color:var(--text-tertiary);text-align:center;margin-top:16px;opacity:.7}.nut-off-credit a{color:var(--text-tertiary);text-decoration:underline}.nut-product-result{text-align:center}.nut-product-img{width:80px;height:80px;object-fit:contain;border-radius:10px;margin-bottom:12px}.nut-product-result h4{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.nut-product-brand{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-tertiary);margin:0 0 12px}.nut-product-per{font-family:Inter,sans-serif;font-size:.75rem;color:var(--text-tertiary);margin:0 0 8px}.nut-product-macros{display:flex;justify-content:center;gap:12px;margin-bottom:16px;font-size:.85rem}.nut-serving-adjust{display:flex;align-items:center;gap:10px;justify-content:center;margin-bottom:12px}.nut-serving-adjust label{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-secondary)}.nut-serving-adjust input{width:80px;padding:8px 10px;text-align:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-primary);outline:none}.nut-serving-adjust input:focus{border-color:var(--color-primary)}.nut-quick-amounts{display:flex;justify-content:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.nut-quick-btn{padding:6px 14px;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.nut-quick-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.nut-quick-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--text-on-primary)}.nut-mode-toggle{display:flex;gap:0;margin-bottom:12px;border-radius:10px;overflow:hidden;border:1px solid var(--border-color)}.nut-mode-toggle button{flex:1;padding:8px 12px;border:none;background:var(--bg-secondary);color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.nut-mode-toggle button.active{background:var(--color-primary);color:var(--text-on-primary);font-weight:600}.nut-portion-stepper{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:14px;padding:10px 0}.nut-stepper-btn{width:44px;height:44px;border-radius:50%;border:2px solid var(--color-primary);background:transparent;color:var(--color-primary);font-size:1.4rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.nut-stepper-btn:hover{background:var(--color-primary);color:var(--text-on-primary)}.nut-stepper-btn:active{transform:scale(.92)}.nut-stepper-display{display:flex;flex-direction:column;align-items:center;min-width:100px}.nut-stepper-count{font-family:Inter,sans-serif;font-size:1.8rem;font-weight:700;color:var(--text-primary);line-height:1.1}.nut-stepper-label{font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;color:var(--text-secondary);text-transform:capitalize}.nut-stepper-weight{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-secondary);opacity:.7;margin-top:2px}.nut-product-total{font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:16px;padding:10px;background:var(--bg-secondary);border-radius:10px}.nut-product-actions{display:flex;gap:10px}.nut-btn-primary{flex:1;padding:12px;background:var(--color-primary);color:var(--text-on-primary);border:none;border-radius:10px;font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.nut-btn-primary:disabled{opacity:.4;cursor:not-allowed}.nut-btn-primary:not(:disabled):hover{transform:translateY(-1px)}.nut-btn-secondary{flex:1;padding:12px;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:10px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.nut-btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.nut-btn-danger{flex:0 0 auto;padding:12px 20px;background:none;color:#ef4444;border:1px solid #ef4444;border-radius:10px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.nut-btn-danger:active{background:#ef44441a}.nut-edit-actions{display:flex;gap:10px;margin-top:16px}.nut-edit-modal .nut-manual-form{margin-top:0}.nut-search-bar{display:flex;gap:8px;margin-bottom:16px}.nut-search-bar input{flex:1;padding:12px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-primary);outline:none}.nut-search-bar input:focus{border-color:var(--color-primary)}.nut-search-bar button{padding:12px 18px;background:var(--color-primary);color:var(--text-on-primary);border:none;border-radius:10px;font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;flex-shrink:0}.nut-search-bar button:disabled{opacity:.5}.nut-search-country-hint{font-size:.75rem;color:var(--text-tertiary);margin:-10px 0 10px 2px}.nut-search-results{display:flex;flex-direction:column;gap:6px;max-height:50vh;overflow-y:auto}.nut-search-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;text-align:left;transition:all .2s;font-family:inherit}.nut-search-item:hover{border-color:var(--color-primary)}.nut-search-item img{width:40px;height:40px;object-fit:contain;border-radius:8px;flex-shrink:0}.nut-search-item-info{display:flex;flex-direction:column;min-width:0}.nut-search-item-name{font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nut-search-item-brand{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-tertiary)}.nut-search-item-macros{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-secondary);margin-top:2px}.nut-search-empty{text-align:center;font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-tertiary);padding:20px}.nut-search-loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:36px 16px 28px;gap:10px}.nut-search-loading-tip{font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:600;color:var(--color-primary);text-align:center;margin:0;min-height:1.4em;line-height:1.4;padding:0 4px}.nut-search-loading-msg{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-tertiary);text-align:center;margin:0 0 4px;min-height:1.3em}.nut-search-loading-bar-track{width:100%;height:22px;background:var(--bg-secondary);border-radius:11px;overflow:hidden;border:1px solid var(--border-color)}.nut-search-loading-bar-fill{height:100%;background:var(--color-primary);border-radius:11px;transition:width .15s linear;display:flex;align-items:center;justify-content:flex-end;min-width:36px}.nut-search-loading-percent{font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:700;color:var(--text-on-primary);padding-right:8px;white-space:nowrap}.nut-recent-area{padding:8px 0}.nut-recent-list{display:flex;flex-direction:column;gap:6px}.nut-recent-item-row{display:flex;align-items:center;gap:6px}.nut-fav-star{flex-shrink:0;width:36px;height:36px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text-secondary);opacity:.4;transition:all .2s;padding:0}.nut-fav-star:hover{opacity:.7}.nut-fav-star.active{color:#ff9800;opacity:1}.nut-fav-star.log{width:28px;height:28px;opacity:.3}.nut-fav-star.log.active{color:#ff9800;opacity:1}.nut-fav-star.confirm{width:40px;height:40px;opacity:.35}.nut-fav-star.confirm.active{color:#ff9800;opacity:1}.nut-product-name-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.nut-product-name-row h4{margin:0;flex:1;min-width:0}.nut-recent-item{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-primary);cursor:pointer;transition:all .2s;text-align:left;flex:1;min-width:0;font-family:Inter,sans-serif}.nut-recent-item:hover{background:var(--bg-secondary);border-color:rgba(var(--color-primary-rgb),.2)}.nut-recent-item:active{transform:scale(.98)}.nut-recent-item-info{flex:1;display:flex;flex-direction:column;min-width:0}.nut-recent-item-name{font-size:.88rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nut-recent-item-serving{font-size:.72rem;color:var(--text-secondary);margin-top:1px}.nut-recent-item-macros{font-size:.78rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.nut-manual-form{display:flex;flex-direction:column;gap:4px}.nut-manual-macros{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}.nut-manual-macros .nut-form-group{margin-bottom:0}@media(min-width:400px){.nut-ring-svg,.nut-ring-center{width:140px;height:140px}.nut-ring-value{font-size:1.2rem}.nut-rings-row .nut-ring-svg,.nut-rings-row .nut-ring-center{width:90px;height:90px}.nut-rings-row .nut-ring-value{font-size:.9rem}.nut-rings-row .nut-ring-target,.nut-rings-row .nut-ring-label{font-size:.52rem}}@media(max-width:380px){.nut-rings-grid{gap:10px}.nut-ring-svg,.nut-ring-center{width:115px;height:115px}.nut-ring-value{font-size:.95rem}.nut-ring-target{font-size:.55rem}.nut-goal-options,.nut-deficit-options{grid-template-columns:1fr}.nut-rings-row .nut-ring-svg,.nut-rings-row .nut-ring-center{width:66px;height:66px}.nut-rings-row .nut-ring-value{font-size:.7rem}.nut-rings-row .nut-ring-target,.nut-rings-row .nut-ring-label{font-size:.45rem}.nut-week-day-num{width:28px;height:28px;font-size:.78rem}.nut-week-day-letter{font-size:.55rem}}.bc-overlay{position:fixed;inset:0;background:#000000d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:bcFadeIn .4s ease-out}@keyframes bcFadeIn{0%{opacity:0}to{opacity:1}}.bc-confetti{position:absolute;inset:0;overflow:hidden;pointer-events:none}.bc-confetti-piece{position:absolute;top:-12px;left:var(--x, 50%);background:var(--color, #A12F3A);animation:bcConfettiFall var(--duration, 2.5s) ease-in var(--delay, 0s) both}.bc-shape-0{border-radius:2px}.bc-shape-1{border-radius:50%}.bc-shape-2{border-radius:1px;height:2px!important}@keyframes bcConfettiFall{0%{transform:translateY(0) translate(0) rotate(0);opacity:1}85%{opacity:1}to{transform:translateY(100vh) translate(var(--drift, 0px)) rotate(var(--spin, 360deg));opacity:0}}.bc-content{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 24px;z-index:1}.bc-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(var(--color-primary-rgb),.35) 0%,transparent 70%);animation:bcGlow 1.8s ease-out .2s both;pointer-events:none}@keyframes bcGlow{0%{transform:translate(-50%,-60%) scale(.5);opacity:0}50%{opacity:.6}to{transform:translate(-50%,-60%) scale(1.8);opacity:0}}.bc-badge-img{width:180px;height:180px;object-fit:contain;filter:drop-shadow(0 0 40px rgba(var(--color-primary-rgb),.4));animation:bcBadgeBounce .8s cubic-bezier(.175,.885,.32,1.275) .2s both}@keyframes bcBadgeBounce{0%{transform:scale(0);opacity:0}50%{transform:scale(1.15)}70%{transform:scale(.95)}to{transform:scale(1);opacity:1}}.bc-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.5rem;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:2px;margin:8px 0 0;text-shadow:0 0 20px rgba(var(--color-primary-rgb),.4);animation:bcTextSlide .6s ease-out .6s both}.bc-name{font-family:Inter,sans-serif;font-size:1.1rem;font-weight:700;color:#fff;margin:0;animation:bcTextSlide .6s ease-out .75s both}.bc-desc{font-family:Inter,sans-serif;font-size:.85rem;color:#fff9;text-align:center;margin:0;max-width:280px;line-height:1.4;animation:bcTextSlide .6s ease-out .9s both}.bc-dismiss{background:none;border:none;font-family:Inter,sans-serif;font-size:.75rem;color:#ffffff4d;cursor:pointer;padding:12px 20px;margin-top:16px;animation:bcTextSlide .6s ease-out 1.2s both;-webkit-tap-highlight-color:transparent}@keyframes bcTextSlide{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.bc-confetti-piece{display:none}.bc-badge-img{animation:bcFadeOnly .3s ease-out .1s both}.bc-title,.bc-name,.bc-desc,.bc-dismiss{animation:bcFadeOnly .3s ease-out .2s both}}@keyframes bcFadeOnly{0%{opacity:0}to{opacity:1}}@keyframes spinRing{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulseBorder{0%,to{border-color:var(--color-primary)}50%{border-color:rgba(var(--color-primary-rgb),.3)}}.wk-loading-inline{display:flex;align-items:center;justify-content:center;min-height:60vh}.wk-loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.wk-page{min-height:100vh;background:var(--bg-body);padding-bottom:calc(80px + var(--safe-area-bottom))}.wk-page-center{display:flex;flex-direction:column;align-items:center;justify-content:center;padding-bottom:0}.wk-page-dark{background:var(--bg-body)}.wk-page-workout{background:var(--bg-body);padding-top:max(var(--safe-area-top),16px);padding-bottom:0;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;max-width:600px;margin:0 auto}.wk-main{max-width:600px;margin:0 auto;padding:0 16px calc(80px + var(--safe-area-bottom))}.wk-page .nut-back-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.9rem;cursor:pointer;padding:16px 0 8px;-webkit-tap-highlight-color:transparent}.wk-page .nut-back-btn:hover{color:var(--color-primary)}.wk-menu-heading{text-align:center;padding:4px 0 16px}.wk-menu-heading h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:800;color:var(--text-primary);margin:0;letter-spacing:-.3px}.wk-menu-heading p{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-tertiary);margin:4px 0 0;letter-spacing:.5px}.wk-active-prog-placeholder{height:88px;margin-bottom:20px;border-radius:16px;background:transparent}.wk-active-prog{display:flex;align-items:center;gap:16px;width:100%;padding:16px 18px;background:radial-gradient(circle at center,rgba(var(--color-primary-rgb),.7),rgba(var(--color-primary-rgb),.25));border:none;border-radius:16px;cursor:pointer;margin-bottom:20px;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-primary);transition:transform .15s,box-shadow .15s;font-family:inherit}.wk-active-prog:active{transform:scale(.98)}.wk-active-prog-ring{position:relative;width:56px;height:56px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.wk-active-prog-ring svg{position:absolute;inset:0;width:100%;height:100%}.wk-ap-tick-filled{stroke:#fff;filter:drop-shadow(0 0 2px rgba(255,255,255,.5))}.wk-ap-tick-empty{stroke:#ffffff40}.wk-ap-pct{position:relative;z-index:1;font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:700;color:#fff}.wk-active-prog-info{display:flex;flex-direction:column;gap:2px;text-align:left}.wk-ap-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.55rem;font-weight:700;color:#ffffffb3;letter-spacing:1.5px;text-transform:uppercase}.wk-ap-name{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:#fff}.wk-ap-cta{font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;color:#ffffffd9}.wk-hero-card{position:relative;display:flex;width:100%;aspect-ratio:16 / 9;border:none;border-radius:20px;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;font-family:inherit;box-shadow:var(--shadow-lg);transition:transform .2s ease}.wk-hero-card+.wk-hero-card{margin-top:16px}.wk-hero-card:active{transform:scale(.98)}.wk-hero-bg{position:absolute;inset:-10px;width:calc(100% + 20px);height:calc(100% + 20px);object-fit:cover;z-index:0;transition:transform .4s ease}.wk-hero-card:hover .wk-hero-bg{transform:scale(1.03)}.wk-free-card-premium .wk-free-card-overlay{position:absolute;inset:0;background:linear-gradient(180deg,#0000001a,#000000a6);z-index:1}.wk-free-card-content{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#fff}.wk-free-card-content svg{opacity:.9}.wk-free-card-label{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;text-align:center;line-height:1.3}.wk-hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(var(--color-primary-rgb),.15),rgba(var(--color-primary-rgb),.3) 30%,#0000008c,#000000d9 80%,#000000f2);z-index:1}[data-theme=dark] .wk-hero-overlay{background:linear-gradient(160deg,#c75f6b26,#c75f6b33 30%,#0009,#000000e6 80%,#000000f7)}.wk-hero-content{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:space-between;width:100%;padding:20px;min-height:280px}.wk-hero-top{display:flex;align-items:center;gap:10px}.wk-hero-ring{position:relative;width:64px;height:64px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wk-hero-ring svg{position:absolute;inset:0;width:100%;height:100%}.wk-hero-tick-filled{stroke:var(--color-primary);filter:drop-shadow(0 0 2px rgba(var(--color-primary-rgb),.5))}.wk-hero-tick-empty{stroke:#fff3}.wk-hero-ring-stat{position:relative;z-index:1;font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:#fff;line-height:1}.wk-hero-ring-stat small{font-size:.6rem;font-weight:500;color:#ffffff80}.wk-hero-week-label{font-family:Inter,sans-serif;font-size:.7rem;font-weight:500;color:#fff9;text-transform:uppercase;letter-spacing:1px}.wk-hero-bottom{display:flex;flex-direction:column;gap:6px}.wk-hero-bottom h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1.4rem;font-weight:800;color:#fff;margin:0;letter-spacing:1px}.wk-hero-bottom p{font-family:Inter,sans-serif;font-size:.8rem;color:#ffffffb3;margin:0;line-height:1.3}.wk-hero-go{display:inline-block;margin-top:4px;font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:700;color:var(--color-primary);letter-spacing:1px}[data-theme=dark] .wk-hero-go{color:var(--color-primary)}.wk-section-header{display:flex;align-items:baseline;justify-content:space-between;padding:24px 0 12px}.wk-section-header h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.wk-section-count{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-tertiary)}.wk-prog-scroll-wrap{position:relative}.wk-prog-scroll{display:flex;gap:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scroll-padding-left:16px;padding:4px 16px 24px;margin:0 -16px;scrollbar-width:none}.wk-prog-scroll::-webkit-scrollbar{display:none}.wk-prog-img-card{position:relative;flex:0 0 85%;border:none;border-radius:20px;overflow:hidden;cursor:pointer;scroll-snap-align:start;-webkit-tap-highlight-color:transparent;padding:0;background:none;box-shadow:var(--shadow-lg);transition:transform .2s ease}.wk-prog-img-card:active{transform:scale(.98)}.wk-prog-img{display:block;width:100%;height:auto;border-radius:20px}.wk-prog-hero-card{position:relative;flex:0 0 85%;display:flex;aspect-ratio:16 / 9;border:none;border-radius:20px;overflow:hidden;cursor:pointer;scroll-snap-align:start;-webkit-tap-highlight-color:transparent;font-family:inherit;box-shadow:var(--shadow-lg);transition:transform .2s ease}.wk-prog-hero-card:active{transform:scale(.98)}.wk-prog-hero-bg{position:absolute;inset:-10px;width:calc(100% + 20px);height:calc(100% + 20px);object-fit:cover;z-index:0;transition:transform .4s ease}.wk-prog-hero-card:hover .wk-prog-hero-bg{transform:scale(1.03)}.wk-prog-hero-overlay{position:absolute;inset:0;z-index:1}.wk-prog-hero-content{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:space-between;width:100%;padding:20px}.wk-prog-hero-top{display:flex;align-items:center;gap:10px}.wk-prog-hero-badge{font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:700;color:#fff;background:#ffffff26;padding:4px 10px;border-radius:8px;letter-spacing:1px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.wk-prog-hero-level{font-family:Inter,sans-serif;font-size:.7rem;font-weight:500;color:#fff9;text-transform:uppercase;letter-spacing:.5px}.wk-prog-hero-bottom{display:flex;flex-direction:column;gap:6px}.wk-prog-hero-bottom h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:800;color:#fff;margin:0;letter-spacing:1px;line-height:1.2}.wk-prog-hero-bottom p{font-family:Inter,sans-serif;font-size:.8rem;color:#ffffffb3;margin:0;line-height:1.3}.wk-prog-hero-go{display:inline-block;margin-top:4px;font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:700;color:#ffffffd9;letter-spacing:1px}.wk-swipe-arrow{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(var(--color-primary-rgb),.85);color:#fff;box-shadow:0 0 12px rgba(var(--color-primary-rgb),.6),0 0 24px rgba(var(--color-primary-rgb),.3);pointer-events:none;z-index:5}.wk-swipe-arrow svg{width:20px;height:20px}.wk-muscle-grid{display:flex;flex-direction:column;gap:12px;padding-bottom:32px}.wk-muscle-hero-card{position:relative;display:flex;width:100%;aspect-ratio:16 / 9;border:none;border-radius:16px;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;font-family:inherit;box-shadow:var(--shadow-glow);transition:transform .2s ease;padding:0}.wk-muscle-thumb-img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.wk-muscle-hero-card:active{transform:scale(.97)}.wk-muscle-hero-bg{position:absolute;inset:-10px;width:calc(100% + 20px);height:calc(100% + 20px);object-fit:cover;z-index:0;transition:transform .4s ease}.wk-muscle-hero-card:hover .wk-muscle-hero-bg{transform:scale(1.05)}.wk-muscle-hero-overlay{position:absolute;inset:0;z-index:1}.wk-muscle-hero-content{position:relative;z-index:2;display:flex;flex-direction:row;align-items:center;width:100%;padding:20px;gap:14px;min-height:140px}.wk-muscle-hero-icon{width:48px;height:48px;border-radius:50%;background:#ffffff1f;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.wk-muscle-hero-icon svg{width:24px;height:24px;color:#fff}.wk-muscle-hero-text{display:flex;flex-direction:column;gap:4px}.wk-muscle-hero-name{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.5px;text-align:left}.wk-muscle-hero-soon{font-family:Inter,sans-serif;font-size:.6rem;font-weight:500;color:#fff9;background:#ffffff1f;padding:3px 10px;border-radius:8px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.wk-muscle-hero-count{font-family:Inter,sans-serif;font-size:.7rem;font-weight:500;color:#ffffffa6;text-align:left}.mg-sessions-header{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 0 24px}.mg-sessions-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center}.mg-sessions-icon svg{width:32px;height:32px;color:#fff}.mg-sessions-header h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.4rem;font-weight:800;color:var(--text-primary);margin:0}.mg-sessions-header p{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-tertiary);margin:0}.mg-sessions-list{display:flex;flex-direction:column;gap:12px;padding-bottom:32px}.mg-session-card{display:flex;align-items:center;justify-content:space-between;padding:20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;font-family:inherit;text-align:left;box-shadow:var(--shadow-glow)}.mg-session-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.mg-session-card:active{transform:scale(.98)}.mg-session-info{display:flex;flex-direction:column;gap:4px;flex:1}.mg-session-info h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.mg-session-info p{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-secondary);margin:0}.mg-session-meta{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}.mg-session-tag{font-family:Inter,sans-serif;font-size:.6rem;font-weight:600;color:var(--text-tertiary);background:var(--bg-body);padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.3px}.mg-session-tag.mg-tag-strength{color:var(--color-primary);background:var(--color-primary-light)}.mg-session-tag.mg-tag-interval{color:#42a5f5;background:#42a5f51a}.mg-session-arrow{color:var(--text-tertiary);flex-shrink:0;margin-left:12px}.mg-session-card:hover .mg-session-arrow{color:var(--color-primary)}.mg-overview-main{padding-bottom:calc(100px + var(--safe-area-bottom))}.mg-overview-hero{width:100%;aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.mg-overview-hero-content{display:flex;align-items:center;justify-content:center}.mg-overview-hero-icon{width:64px;height:64px;color:#ffffff40}.mg-overview-hero-img{width:100%;height:100%;object-fit:cover}.mg-overview-header{padding:20px 16px 0}.mg-overview-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.mg-overview-title-row h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.5rem;font-weight:800;color:var(--text-primary);margin:0}.mg-overview-level{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--color-primary);color:#fff;padding:3px 10px;border-radius:20px}.mg-overview-desc{font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-secondary);margin-top:6px}.mg-overview-section{padding:16px 16px 0}.mg-overview-section h3{font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0 0 10px;display:flex;align-items:center;gap:8px}.mg-overview-section h3 svg{color:var(--color-primary);flex-shrink:0}.mg-overview-section>p{font-family:Inter,sans-serif;font-size:.88rem;line-height:1.6;color:var(--text-secondary);margin:0}.mg-overview-tips{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.mg-overview-tips li{font-family:Inter,sans-serif;font-size:.85rem;line-height:1.5;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;position:relative;padding:10px 12px 10px 32px}.mg-overview-tips li:before{content:"✓";position:absolute;left:12px;top:10px;color:var(--color-primary);font-weight:700;font-size:.8rem}.mg-overview-exercises{display:flex;flex-direction:column;gap:6px}.mg-overview-exercise{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px}.mg-overview-ex-num{width:28px;height:28px;border-radius:50%;background:var(--color-primary);color:#fff;font-family:Inter,sans-serif;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mg-overview-ex-info{display:flex;flex-direction:column;gap:2px;min-width:0}.mg-overview-ex-name{font-family:Plus Jakarta Sans,sans-serif;font-size:.88rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mg-overview-ex-detail{font-family:Inter,sans-serif;font-size:.75rem;color:var(--text-secondary)}.mg-overview-start-btn{position:fixed;bottom:20px;left:16px;right:16px;max-width:600px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;background:var(--color-primary);color:var(--text-on-primary);border:none;border-radius:14px;font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:700;cursor:pointer;box-shadow:0 4px 20px rgba(var(--color-primary-rgb),.35);transition:transform .15s ease,box-shadow .15s ease;z-index:10}.mg-overview-start-btn:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(var(--color-primary-rgb),.45)}.mg-overview-start-btn:active{transform:scale(.98)}.mg-session-progress{height:4px;background:var(--border-color);width:100%}.mg-session-progress-fill{height:100%;background:var(--color-primary);transition:width .4s ease;border-radius:0 2px 2px 0}.mg-header-info{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-secondary)}.mg-video-container{position:relative;margin:8px 12px 4px;border-radius:14px;overflow:hidden;background:#000;cursor:pointer;max-height:240px}.mg-video{display:block;width:100%;max-height:240px;object-fit:cover}.mg-video-overlay{position:absolute;inset:0;background:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;transition:opacity .3s ease}.mg-play-icon{filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}.mg-video-hint{font-family:Inter,sans-serif;font-size:.75rem;color:#ffffffb3}.mg-video-placeholder{margin:8px 12px 4px;border-radius:14px;background:var(--bg-card);border:2px dashed var(--border-color);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:140px;color:var(--text-tertiary)}.mg-video-placeholder span{font-family:Inter,sans-serif;font-size:.8rem;font-weight:500}.mg-exercise-card{margin:16px 0 32px;padding:24px 20px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:var(--shadow-glow)}.mg-ex-name{font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:700;color:var(--text-primary);text-align:center;margin:0}.mg-ex-type-badge{font-family:Inter,sans-serif;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:4px 12px;border-radius:8px}.mg-ex-type-badge.weighted{color:var(--color-primary);background:var(--color-primary-light)}.mg-ex-type-badge.reps{color:#42a5f5;background:#42a5f51a}.mg-ex-type-badge.timed{color:#ff7043;background:#ff704326}.mg-ex-set-info{display:flex;flex-direction:column;align-items:center;gap:2px}.mg-ex-set-num{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary)}.mg-ex-target{font-family:Inter,sans-serif;font-size:.75rem;color:var(--text-tertiary)}.mg-input-area{display:flex;gap:12px;width:100%;max-width:280px}.mg-input-group{flex:1;display:flex;flex-direction:column;gap:4px}.mg-input-group.mg-input-single{max-width:140px}.mg-input-group label{font-family:Inter,sans-serif;font-size:.7rem;font-weight:600;color:var(--text-tertiary);text-align:center;text-transform:uppercase;letter-spacing:.5px}.mg-input{width:100%;padding:12px;background:var(--bg-body);border:2px solid var(--border-color);border-radius:12px;font-family:Plus Jakarta Sans,sans-serif;font-size:1.4rem;font-weight:700;color:var(--text-primary);text-align:center;outline:none;transition:border-color .2s ease;-webkit-appearance:none}.mg-input:focus{border-color:var(--color-primary)}.mg-timer-area{display:flex;flex-direction:column;align-items:center;gap:12px}.mg-timer-display{width:140px;height:140px;border-radius:50%;border:4px solid var(--border-color);display:flex;align-items:center;justify-content:center;transition:border-color .3s ease}.mg-timer-value{font-family:Plus Jakarta Sans,sans-serif;font-size:2.5rem;font-weight:900;color:var(--text-primary)}.mg-timer-btn{padding:10px 32px;background:var(--color-primary);color:#fff;border:none;border-radius:12px;font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.mg-timer-stop{background:#f44336}.mg-log-set-btn{width:100%;max-width:280px;padding:14px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:14px;font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-primary);-webkit-tap-highlight-color:transparent}.mg-log-set-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(var(--color-primary-rgb),.5)}.mg-log-set-btn:active{transform:translateY(0)}.mg-completed-sets{width:100%;max-width:280px;display:flex;flex-direction:column;gap:4px;padding-top:4px}.mg-completed-set{display:flex;align-items:center;gap:8px;font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-secondary);padding:4px 0}.mg-completed-set-check{color:#4caf50;font-weight:700}.mg-complete-session-name{font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-tertiary);margin:-12px 0 0}.mg-badge-celebration{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;cursor:pointer}.mg-badge-celebration-card{background:var(--bg-card);border:2px solid rgba(245,158,11,.3);border-radius:20px;padding:36px 28px;display:flex;flex-direction:column;align-items:center;gap:16px;max-width:320px;width:100%;box-shadow:0 0 40px #f59e0b26}.mg-badge-celebration-icon{width:56px;height:56px;margin:0 auto;color:#f59e0b}.mg-badge-celebration-icon svg{width:100%;height:100%}.mg-badge-celebration-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:700;color:var(--text-primary);margin:0;text-align:center}.mg-badge-celebration-list{display:flex;flex-direction:column;gap:8px;width:100%}.mg-badge-celebration-item{font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;color:#f59e0b;background:#f59e0b1a;border:1px solid rgba(245,158,11,.25);padding:10px 16px;border-radius:10px;text-align:center}.mg-badge-share-row{display:flex;gap:8px;margin-top:12px}.mg-badge-share-btn{display:flex;align-items:center;gap:5px;padding:8px 14px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.25);border-radius:50px;color:#f59e0b;font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s ease,transform .15s ease}.mg-badge-share-btn svg{width:14px;height:14px;flex-shrink:0}.mg-badge-share-btn:active{transform:scale(.95)}.mg-badge-celebration-dismiss{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:8px 16px}.mg-preview-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0;text-align:center;padding-top:8px}[data-theme=dark] .mg-session-card,[data-theme=dark] .mg-exercise-card,[data-theme=dark] .mg-overview-exercise,[data-theme=dark] .mg-overview-tips li{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .wk-active-prog{background:radial-gradient(circle at center,rgba(var(--color-primary-rgb),.7),rgba(var(--color-primary-rgb),.25));box-shadow:0 1px 3px #0003,0 4px 12px #00000026}[data-theme=light] .wk-active-prog{background:radial-gradient(circle at center,var(--color-primary) 0%,var(--color-primary-dark) 100%)}.wk-setup-main{padding-bottom:calc(100px + var(--safe-area-bottom))}.wk-stats-row{display:flex;justify-content:center;align-items:flex-end;gap:16px;padding:4px 0 16px}.wk-stat-item{display:flex;flex-direction:column;align-items:center;gap:6px}.wk-stat-ring{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.wk-stat-large .wk-stat-ring{width:100px;height:100px}.wk-stat-ring svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.wk-stat-track{fill:none;stroke:#96969633;stroke-width:12;stroke-linecap:round}.wk-stat-fill{fill:none;stroke-width:12;stroke-linecap:round}.wk-stat-value{position:relative;z-index:1;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.85rem}.wk-stat-large .wk-stat-value{font-size:1rem}.wk-equip-options{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.wk-equip-options>:last-child:nth-child(odd){grid-column:1 / -1}.wk-equip-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 10px;min-height:72px;background:radial-gradient(circle at center,var(--bg-body) 0%,var(--bg-card) 100%);border:none;border-radius:14px;cursor:pointer;transition:background .2s ease,box-shadow .2s ease,opacity .2s ease;-webkit-tap-highlight-color:transparent;font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:600;color:var(--text-primary);box-shadow:0 2px 8px #0000001a}.wk-equip-btn:hover{box-shadow:0 2px 10px rgba(var(--color-primary-rgb),.12)}.wk-equip-btn.active{background:radial-gradient(circle at center,rgba(var(--color-primary-rgb),.7),rgba(var(--color-primary-rgb),.25));color:var(--text-primary);box-shadow:none}.wk-equip-options:has(.wk-equip-btn.active) .wk-equip-btn:not(.active),.wk-focus-grid:has(.wk-equip-btn.active) .wk-equip-btn:not(.active){opacity:.55}.wk-equip-icon{width:28px;height:28px;color:var(--text-primary);transition:color .2s ease}.wk-equip-btn.active .wk-equip-icon{color:var(--text-primary)}.wk-focus-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.wk-focus-grid>:last-child:nth-child(odd){grid-column:1 / -1}.wk-focus-grid .wk-equip-btn{max-width:none;width:auto}.wk-setup-flow{display:flex;flex-direction:column;gap:16px}.wk-setup-section{padding:0}.wk-setup-section h2{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:600;color:var(--text-tertiary);margin:0 0 8px;text-align:left;text-transform:uppercase;letter-spacing:1px}.wk-level-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.wk-level-cards>:last-child:nth-child(odd){grid-column:1 / -1}.wk-level-card{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:72px;padding:12px 14px;background:radial-gradient(circle at center,var(--bg-body) 0%,var(--bg-card) 100%);border:none;border-radius:14px;cursor:pointer;transition:background .2s ease,box-shadow .2s ease,opacity .2s ease;-webkit-tap-highlight-color:transparent;font-family:inherit;box-shadow:0 2px 8px #0000001a}.wk-level-card:hover{box-shadow:0 2px 10px rgba(var(--color-primary-rgb),.12)}.wk-level-card.active{background:radial-gradient(circle at center,rgba(var(--color-primary-rgb),.7),rgba(var(--color-primary-rgb),.25));box-shadow:none}.wk-level-cards:has(.wk-level-card.active) .wk-level-card:not(.active){opacity:.55}.wk-level-name{font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;color:var(--text-primary)}.wk-level-desc{font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:500;color:var(--text-primary);letter-spacing:.5px;opacity:.7}.wk-level-card.active .wk-level-name{color:var(--text-primary)}.wk-time-options{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.wk-time-options>:last-child:nth-child(odd){grid-column:1 / -1}.wk-time-btn{display:flex;align-items:center;justify-content:center;gap:3px;min-height:72px;padding:10px 14px;background:radial-gradient(circle at center,var(--bg-body) 0%,var(--bg-card) 100%);border:none;border-radius:14px;cursor:pointer;transition:background .2s ease,box-shadow .2s ease,opacity .2s ease;-webkit-tap-highlight-color:transparent;font-family:inherit;box-shadow:0 2px 8px #0000001a}.wk-time-btn:hover{box-shadow:0 2px 10px rgba(var(--color-primary-rgb),.12)}.wk-time-btn.active{background:radial-gradient(circle at center,rgba(var(--color-primary-rgb),.7),rgba(var(--color-primary-rgb),.25));box-shadow:none}.wk-time-options:has(.wk-time-btn.active) .wk-time-btn:not(.active){opacity:.55}.wk-time-num{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:var(--text-primary);line-height:1}.wk-time-unit{font-family:Inter,sans-serif;font-size:.6rem;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;opacity:.7}.wk-time-btn.active .wk-time-num{color:var(--text-primary)}.wk-setup-summary{text-align:center;margin-top:0;padding-bottom:8px}.wk-setup-summary span{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:600;letter-spacing:1px;color:var(--text-tertiary);text-transform:uppercase}[data-theme=dark] .wk-equip-btn,[data-theme=dark] .wk-level-card,[data-theme=dark] .wk-time-btn{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .wk-equip-btn.active,[data-theme=dark] .wk-level-card.active,[data-theme=dark] .wk-time-btn.active{background:radial-gradient(circle at center,rgba(var(--color-primary-rgb),.7),rgba(var(--color-primary-rgb),.25));border-color:#ffffff14}@keyframes goGlow{0%,to{box-shadow:0 4px 20px rgba(var(--color-primary-rgb),.4)}50%{box-shadow:0 4px 28px rgba(var(--color-primary-rgb),.65)}}.wk-go-sticky{position:fixed;bottom:0;left:0;right:0;padding:12px 16px calc(20px + var(--safe-area-bottom));display:flex;justify-content:center;background:linear-gradient(to top,var(--bg-body) 60%,transparent);z-index:10;pointer-events:none}.wk-randomise-btn{pointer-events:auto;display:block;width:100%;max-width:320px;padding:16px 24px;background:var(--color-primary);color:var(--text-on-primary);border:none;border-radius:14px;font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-primary);-webkit-tap-highlight-color:transparent;letter-spacing:.3px;animation:goGlow 2.5s ease-in-out infinite}.wk-randomise-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(var(--color-primary-rgb),.5)}.wk-randomise-btn:active{transform:translateY(0);animation:none}.wk-randomise-btn:disabled{opacity:.6;cursor:wait;animation:none}.wk-time-btn.locked{opacity:.35;cursor:not-allowed;position:relative}.wk-time-btn.locked .wk-time-unit{display:flex;align-items:center;justify-content:center}.wk-time-btn.locked .wk-time-unit svg{opacity:.7}.wk-free-limit-msg{text-align:center;font-size:.82rem;color:var(--text-secondary);margin:0 0 10px;line-height:1.4}.wk-spin-container{display:flex;flex-direction:column;align-items:center;gap:24px}.wk-spin-ring{position:relative;width:240px;height:240px;display:flex;align-items:center;justify-content:center}.wk-spin-svg{position:absolute;top:0;left:0;width:100%;height:100%;animation:spinRing 2s linear infinite}.wk-spin-tick{stroke:var(--border-color)}.wk-spin-logo{position:relative;z-index:1;width:80px;height:80px;border-radius:50%;border:3px solid var(--color-primary);object-fit:cover;box-shadow:0 4px 16px #0000004d;animation:pulseBorder 1.5s ease-in-out infinite}.wk-spin-text{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:600;color:var(--text-secondary);letter-spacing:.5px}.wk-preview-stats{display:flex;justify-content:center;gap:10px;padding:16px 0}.wk-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;min-width:70px}.wk-stat-val{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700;color:var(--color-primary)}.wk-stat-label{font-family:Inter,sans-serif;font-size:.65rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.wk-preview-list{display:flex;flex-direction:column;gap:10px;padding:0 0 16px}.wk-preview-item{display:flex;align-items:center;gap:14px;padding:12px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent}.wk-preview-item:active{border-color:var(--color-primary);box-shadow:0 0 8px #bf374433}[data-theme=dark] .wk-stat,[data-theme=dark] .wk-preview-item,[data-theme=dark] .wk-btn-secondary,[data-theme=dark] .wk-preview-modal{background:#1e1e1ecc;border-color:#ffffff0f;box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .wk-preview-item:active{border-color:var(--color-primary);box-shadow:0 0 8px #bf37444d}.wk-preview-num{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center}.wk-preview-name{font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:600;color:var(--text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wk-preview-thumb{flex-shrink:0;width:48px;height:48px;border-radius:8px;overflow:hidden;background:var(--bg-tertiary, #1a1a1a)}.wk-preview-thumb img,.wk-preview-thumb video{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.wk-preview-play{flex-shrink:0;color:var(--text-primary);opacity:.85;transition:opacity .2s ease,color .2s ease}.wk-preview-item:active .wk-preview-play{opacity:1;color:var(--color-primary)}.wk-preview-modal-backdrop{position:fixed;inset:0;z-index:9999;background:#000000bf;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.wk-preview-modal{position:relative;width:88%;max-width:400px;background:var(--bg-card);border-radius:16px;overflow:hidden;box-shadow:0 20px 60px #00000080}.wk-preview-modal-close{position:absolute;top:10px;right:10px;z-index:2;width:34px;height:34px;border-radius:50%;border:none;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}.wk-preview-modal-video{width:100%;aspect-ratio:4 / 3;background:#000}.wk-preview-modal-video img,.wk-preview-modal-video video{width:100%;height:100%;object-fit:contain;display:block}.wk-preview-modal-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:700;color:var(--text-primary);text-align:center;padding:14px 16px;margin:0}.wk-preview-actions{display:flex;flex-direction:column;gap:10px;padding-bottom:16px}.wk-preview-actions-row{display:flex;gap:10px}.wk-btn-half{flex:1;justify-content:center}.wk-btn-full{width:100%;justify-content:center}.wk-btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 22px;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color);border-radius:14px;font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.wk-btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.wk-btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:var(--color-primary);color:var(--text-on-primary);border:none;border-radius:14px;font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-primary);-webkit-tap-highlight-color:transparent}.wk-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(var(--color-primary-rgb),.5)}.wk-btn-primary:active{transform:translateY(0)}.wk-countdown-big{display:flex;flex-direction:column;align-items:center;gap:12px}.wk-countdown-num{font-family:Plus Jakarta Sans,sans-serif;font-size:7rem;font-weight:900;color:var(--color-primary);line-height:1;text-shadow:0 0 40px rgba(var(--color-primary-rgb),.5)}.wk-countdown-label{font-family:Plus Jakarta Sans,sans-serif;font-size:1.2rem;font-weight:700;color:var(--text-tertiary);letter-spacing:4px;text-transform:uppercase}.wk-spotify{flex-shrink:0;padding:12px 12px 0;line-height:0}.wk-spotify iframe{display:block;border:none;border-radius:12px}.wk-video-container{position:relative;width:100%;aspect-ratio:16 / 9;background:#000;overflow:hidden;flex-shrink:0;margin:12px 12px 0;width:calc(100% - 24px);border-radius:12px;max-height:340px}.wk-video{width:100%;height:100%;object-fit:cover;display:block;border-radius:12px}.wk-back-row{width:calc(100% - 24px);margin:6px 12px 0;display:flex;justify-content:flex-start}.wk-back-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--text-secondary);font-size:.8rem;padding:4px 8px;border-radius:6px;cursor:pointer;opacity:.7;transition:opacity .2s}.wk-back-btn:hover{opacity:1}.wk-rest-screen{position:relative;width:100%;height:100%;overflow:hidden;background:linear-gradient(135deg,#1a1a2e,#16213e)}.wk-rest-preview{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.7}.wk-rest-overlay{position:absolute;inset:0;background:#0a0a1e33}.wk-rest-text{position:absolute;bottom:16px;left:16px;display:flex;flex-direction:column;align-items:flex-start;gap:4px}.wk-rest-label{font-family:Plus Jakarta Sans,sans-serif;font-size:1.6rem;font-weight:900;color:#42a5f5;letter-spacing:6px;text-shadow:0 0 20px rgba(66,165,245,.5),0 2px 8px rgba(0,0,0,.7)}.wk-rest-next{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.wk-rest-next-tag{font-family:Plus Jakarta Sans,sans-serif;font-size:.6rem;font-weight:700;letter-spacing:3px;color:#42a5f5d9;text-transform:uppercase;text-shadow:0 1px 6px rgba(0,0,0,.7)}.wk-rest-next-name{font-family:Inter,sans-serif;font-size:1rem;font-weight:600;color:#fffffff2;text-shadow:0 1px 6px rgba(0,0,0,.7)}.wk-exercise-info{text-align:center;padding:14px 16px 4px}.wk-exercise-counter{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:500;color:var(--text-tertiary);letter-spacing:1px}.wk-exercise-name{font-family:Plus Jakarta Sans,sans-serif;font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:4px 0 2px}.wk-round-label{font-family:Inter,sans-serif;font-size:.75rem;color:var(--text-tertiary)}.wk-timer-section{display:flex;justify-content:center;padding:10px 0;flex:1;align-items:center}.wk-timer-ring-wrap{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center}.wk-ring-svg{position:absolute;top:0;left:0;width:100%;height:100%}.wk-tick-empty{stroke:var(--border-color)}.wk-tick-filled.wk-tick-work{stroke:var(--color-primary);filter:drop-shadow(0 0 2px rgba(var(--color-primary-rgb),.5))}.wk-tick-filled.wk-tick-rest{stroke:#42a5f5;filter:drop-shadow(0 0 2px rgba(66,165,245,.5))}.wk-timer-center{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:4px}.wk-timer-time{font-family:Plus Jakarta Sans,sans-serif;font-size:3rem;font-weight:900;color:var(--text-primary);line-height:1}.wk-timer-phase{font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:700;letter-spacing:3px;text-transform:uppercase}.wk-timer-phase.work{color:var(--color-primary)}.wk-timer-phase.rest{color:#42a5f5}.wk-controls{display:flex;align-items:center;justify-content:center;gap:20px;padding:10px 0 16px}.wk-ctrl-btn{border-radius:50%;border:2px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.wk-ctrl-btn:hover{background:var(--bg-card-elevated);border-color:var(--text-tertiary)}.wk-ctrl-btn:active{transform:scale(.95)}.wk-ctrl-pause{width:68px;height:68px}.wk-ctrl-skip,.wk-ctrl-stop{width:50px;height:50px}.wk-ctrl-skip{border-color:var(--text-tertiary);color:var(--text-secondary)}.wk-ctrl-skip:hover{color:var(--color-primary);border-color:var(--color-primary)}.wk-ctrl-stop{border-color:#f443364d;color:#f44336}.wk-ctrl-stop:hover{border-color:#f4433680;background:#f443361a}.wk-progress-bar{width:100%;height:4px;background:var(--border-color);overflow:hidden}.wk-progress-fill{height:100%;background:var(--color-primary);transition:width .5s ease;border-radius:0 2px 2px 0}.wk-complete{display:flex;flex-direction:column;align-items:center;gap:20px;padding:0 20px}.wk-complete-ring{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center}.wk-complete-svg{position:absolute;top:0;left:0;width:100%;height:100%}.wk-tick-complete{stroke:transparent}.wk-complete-center{position:relative;z-index:1;display:flex;align-items:center;justify-content:center}.wk-complete-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.6rem;font-weight:700;color:var(--text-primary);text-align:center}.wk-complete-stats{display:flex;gap:12px;justify-content:center}.wk-complete-stats .wk-stat{min-width:80px}.wk-complete-actions{padding-top:12px}.wk-page .toast-notification{position:fixed;bottom:32px;left:50%;transform:translate(-50%);padding:12px 24px;border-radius:12px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:500;color:#fff;z-index:1000;display:flex;align-items:center;gap:8px;box-shadow:0 8px 24px #0003}.wk-page .toast-notification.info{background:var(--bg-card-elevated);color:var(--text-primary);border:1px solid var(--border-color)}.wk-page .toast-notification.error{background:var(--color-error)}@media(min-width:400px){.wk-stat-ring{width:90px;height:90px}.wk-stat-value{font-size:.95rem}.wk-stats-row{gap:24px}.wk-hero-card{aspect-ratio:16 / 9}.wk-hero-content{min-height:300px}.wk-hero-bottom h3{font-size:1.5rem}.wk-prog-hero-card{aspect-ratio:16 / 9}.wk-prog-hero-bottom h3{font-size:1.4rem}.wk-timer-ring-wrap{width:220px;height:220px}.wk-timer-time{font-size:3.5rem}.wk-exercise-name{font-size:1.35rem}.wk-spin-ring{width:280px;height:280px}.wk-spin-logo{width:90px;height:90px}.wk-preview-stats{gap:12px}.wk-stat{min-width:80px;padding:14px 16px}}@media(min-width:500px){.wk-main{padding:0 24px}.wk-prog-scroll{margin:0 -24px;padding:4px 24px 24px}}@media(max-height:680px){.wk-timer-ring-wrap{width:170px;height:170px}.wk-timer-time{font-size:2.5rem}.wk-exercise-info{padding:10px 16px 2px}.wk-exercise-name{font-size:1.1rem}.wk-controls{padding:6px 0 12px}.wk-ctrl-pause{width:58px;height:58px}.wk-ctrl-skip,.wk-ctrl-stop{width:44px;height:44px}}[data-theme=light] .wk-equip-btn.active,[data-theme=light] .wk-level-card.active,[data-theme=light] .wk-time-btn.active{background:radial-gradient(circle at center,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;box-shadow:none}[data-theme=light] .wk-equip-btn.active .wk-equip-icon,[data-theme=light] .wk-level-card.active .wk-level-name,[data-theme=light] .wk-level-card.active .wk-level-desc,[data-theme=light] .wk-time-btn.active .wk-time-num,[data-theme=light] .wk-time-btn.active .wk-time-unit{color:#fff}.cb-premium-badge{display:inline-block;font-size:.55rem;font-weight:700;letter-spacing:.05em;background:var(--color-primary);color:#fff;padding:2px 6px;border-radius:4px;vertical-align:middle;margin-left:6px}.cb-upgrade-teaser{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px;background:none;border:1px dashed var(--border-color);border-radius:8px;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.85rem;cursor:pointer;margin-bottom:16px}.cb-upgrade-teaser:hover{color:var(--color-primary);border-color:var(--color-primary)}.wk-hub-heading{text-align:center;padding:4px 0 16px}.wk-hub-heading h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:800;color:var(--text-primary);margin:0;letter-spacing:-.3px}.wk-hub-heading p{color:var(--text-secondary);font-size:.85rem;margin:4px 0 0}.wk-hub-launch-zone{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.wk-hub-card{position:relative;display:flex;align-items:center;gap:14px;padding:18px 16px;min-height:88px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;cursor:pointer;text-align:left;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;overflow:hidden;-webkit-tap-highlight-color:transparent;font-family:inherit;box-shadow:var(--shadow-glow)}[data-theme=dark] .wk-hub-card{border:1px solid rgba(255,255,255,.06)}.wk-hub-card:active{transform:scale(.97);transition:transform .1s ease}.wk-hub-card:disabled{opacity:.5;cursor:not-allowed}.wk-hub-card-icon{flex-shrink:0;width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary)}.wk-hub-card-icon--primary{background:var(--color-primary);color:var(--text-on-primary)}.wk-hub-card-body{flex:1;min-width:0}.wk-hub-card-body h3{font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wk-hub-card-body p{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-tertiary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wk-hub-card-arrow{flex-shrink:0;color:var(--text-tertiary);opacity:.25}.wk-hub-card-locked{opacity:.5;cursor:default}.wk-hub-card-locked .wk-hub-card-icon{background:#8080801a;color:var(--text-tertiary)}.wk-hub-coming-soon-badge{flex-shrink:0;font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:700;text-transform:uppercase;color:var(--text-tertiary);background:var(--bg-card-elevated);padding:4px 8px;border-radius:6px;letter-spacing:.5px}.wk-hub-tip{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:rgba(var(--color-primary-rgb),.06);border-left:3px solid rgba(var(--color-primary-rgb),.35);border-radius:0 12px 12px 0;font-family:Inter,sans-serif;font-size:.8rem;font-style:italic;color:var(--text-tertiary, var(--text-secondary));line-height:1.5}.wk-hub-tip svg{flex-shrink:0;margin-top:2px;color:var(--color-primary);opacity:.7}.wk-hub-new-glow{position:relative;overflow:visible;animation:hubNewGlow 1.8s ease-in-out 2}@keyframes hubNewGlow{0%,to{box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.25)}50%{box-shadow:0 4px 20px rgba(var(--color-primary-rgb),.5),0 0 0 4px rgba(var(--color-primary-rgb),.1)}}.wk-hub-focus-pill{display:inline-flex;align-items:center;padding:2px 8px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;border-radius:6px;background:color-mix(in srgb,var(--pill-color) 14%,transparent);color:var(--pill-color);line-height:1.6;flex-shrink:0}.wk-hub-saved-tags{display:flex;align-items:center;gap:6px;margin-top:2px;flex-wrap:wrap}.wk-hub-recent-tags{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.wk-hub-empty-enhanced{flex-direction:column;gap:6px;padding:28px 20px}.wk-hub-empty-icon{color:var(--text-secondary);opacity:.35;margin-bottom:2px}.wk-hub-empty-enhanced p{margin:0}.wk-hub-empty-enhanced p strong{color:var(--text-primary);font-size:.9rem}.wk-hub-empty-sub{font-size:.78rem;color:var(--text-secondary);opacity:.8}.wk-hub-section{margin-bottom:24px}.wk-hub-section-title{display:flex;align-items:center;gap:8px;font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:700;color:var(--text-primary);margin:0 0 12px;padding-left:12px;border-left:3px solid var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.wk-hub-section--saved .wk-hub-section-title{border-left-color:var(--color-primary)}.wk-hub-section--recent .wk-hub-section-title{border-left-color:#64b5f6}.wk-hub-section-title svg{color:var(--text-secondary)}.wk-hub-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--color-primary);color:#fff;font-family:Inter,sans-serif;font-size:.7rem;font-weight:700;border-radius:10px;margin-left:4px}.wk-hub-empty{display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg-card);border:1px dashed var(--border-color);border-radius:12px}.wk-hub-empty p{color:var(--text-secondary);font-size:.85rem;text-align:center;margin:0;line-height:1.5}.wk-hub-saved-categories{display:flex;flex-direction:column;gap:10px}.wk-hub-saved-cat{border-radius:14px;overflow:hidden}.wk-hub-saved-cat-header{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;border-radius:14px;border:1.5px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2);background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:border-color .2s,background .2s;font-family:inherit;text-align:left}@media(hover:hover){.wk-hub-saved-cat-header:hover{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.12)}}.wk-hub-saved-cat--open .wk-hub-saved-cat-header{border-radius:14px 14px 0 0;border-color:rgba(var(--color-primary-rgb, 184, 49, 61),.3)}.wk-hub-saved-cat-icon{width:44px;height:44px;border-radius:50%;background:rgba(var(--color-primary-rgb, 184, 49, 61),.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}.wk-hub-saved-cat-name{flex:1;font-size:.88rem;font-weight:600;color:var(--text-primary)}.wk-hub-saved-cat-chevron{color:var(--text-secondary);transition:transform .25s ease;flex-shrink:0}.wk-hub-saved-cat-chevron-open{transform:rotate(180deg)}.wk-hub-saved-cat-dropdown{display:flex;flex-direction:column;gap:6px;padding:8px 10px 10px;border:1.5px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2);border-top:none;border-radius:0 0 14px 14px;background:rgba(var(--color-primary-rgb, 184, 49, 61),.03)}.wk-hub-saved-cat-dropdown .wk-hub-saved-card{border-radius:10px}.wk-hub-saved-list{display:flex;flex-direction:column;gap:8px}.wk-hub-saved-card{display:flex;align-items:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.wk-hub-saved-main{flex:1;display:flex;align-items:center;gap:12px;padding:12px 14px;background:none;border:none;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}.wk-hub-saved-main:active{background:rgba(var(--color-primary-rgb),.06)}.wk-hub-saved-main svg{color:var(--color-primary);flex-shrink:0}.wk-hub-saved-info{flex:1;min-width:0}.wk-hub-saved-name{display:block;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wk-hub-saved-meta{font-size:.72rem;color:var(--text-secondary)}.wk-hub-saved-equip{display:block;font-size:.7rem;color:var(--text-tertiary, var(--text-secondary));margin-top:1px}.wk-hub-saved-delete{display:flex;align-items:center;justify-content:center;width:40px;align-self:stretch;background:none;border:none;border-left:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color .15s,background .15s}.wk-hub-saved-delete:hover{color:#e53e3e;background:#e53e3e0f}.wk-hub-recent-list{display:flex;flex-direction:column;gap:6px}.wk-hub-recent-card{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s,border-color .2s;font-family:inherit;text-align:left}.wk-hub-recent-card:active{transform:scale(.97);border-color:rgba(var(--color-primary-rgb),.3)}.wk-hub-recent-info{min-width:0;flex:1}.wk-hub-recent-focus{display:block;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary)}.wk-hub-recent-meta{font-size:.72rem;color:var(--text-secondary)}.wk-hub-recent-action{display:flex;align-items:center;gap:4px;flex-shrink:0;margin-left:8px}.wk-hub-recent-action svg{color:var(--text-secondary);opacity:.5}.wk-hub-recent-time{font-size:.72rem;color:var(--text-secondary);flex-shrink:0}.wk-fab{position:fixed;bottom:calc(64px + var(--safe-area-bottom));right:max(18px,env(safe-area-inset-right,0px));width:54px;height:54px;border-radius:50%;background:var(--color-primary);color:var(--text-on-primary, white);border:none;padding:0;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #00000059,0 0 0 3px rgba(var(--color-primary-rgb, 184, 49, 61),.3);cursor:pointer;z-index:1000;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s ease,opacity .3s ease}.wk-fab:active{transform:scale(.92)}.wk-fab.wk-fab-hidden{opacity:0;pointer-events:none;transform:scale(.5)}.wk-fab svg{transition:transform .3s cubic-bezier(.4,0,.2,1)}.wk-fab.wk-fab-open{box-shadow:0 6px 20px #0006}.wk-fab-overlay{position:fixed;inset:0;z-index:999;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:wkFabOverlayIn .2s ease;display:flex;align-items:flex-end;justify-content:center}@keyframes wkFabOverlayIn{0%{opacity:0}to{opacity:1}}.wk-fab-sheet{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:480px;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column;padding:20px 20px 32px;animation:wkFabSheetIn .3s ease;border:1px solid var(--border-color);border-bottom:none;box-shadow:0 -8px 32px #0000004d}@keyframes wkFabSheetIn{0%{transform:translateY(100%)}to{transform:translateY(0)}}.wk-fab-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-shrink:0}.wk-fab-header h3{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin:0;flex:1;text-align:center}.wk-fab-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .2s}.wk-fab-close:hover{background:var(--bg-hover)}.wk-fab-header:before{content:"";width:32px}.wk-fab-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.wk-fab-body .wk-hub-section{margin-bottom:16px}@media(min-width:481px){.wk-fab-overlay{align-items:center}.wk-fab-sheet{border-radius:20px;border-bottom:1px solid var(--border-color);max-height:80vh}}[data-theme=dark] .wk-fab-sheet{background:#1e1e1e}.wk-btn-save{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color);border-radius:10px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .15s,border-color .2s;-webkit-tap-highlight-color:transparent}.wk-btn-save:active{transform:scale(.95)}.wk-btn-save:hover{border-color:var(--color-primary)}.wk-btn-save svg{color:var(--color-primary)}.wk-save-modal-backdrop{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:9999;padding:16px}.wk-save-modal{background:#fff;border-radius:16px;padding:24px;width:100%;max-width:360px;text-align:center;box-shadow:0 8px 32px #0000004d}.wk-save-modal h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700;color:#1a1a1a;margin:0 0 8px}.wk-save-modal p{font-size:.82rem;color:#555;margin:0 0 16px;line-height:1.4}.wk-save-modal .wk-save-input{width:100%;padding:10px 12px;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;font-family:Inter,sans-serif;font-size:.9rem;color:#1a1a1a;outline:none;transition:border-color .2s;box-sizing:border-box}.wk-save-modal .byo-custom-type-btn{background:#f5f5f5;border-color:#ddd;color:#555}.wk-save-modal .byo-custom-type-btn.byo-custom-type-active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.08);color:var(--color-primary)}.wk-save-input{width:100%;padding:10px 12px;background:var(--bg-body);border:1px solid var(--border-color);border-radius:8px;font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-primary);outline:none;transition:border-color .2s;box-sizing:border-box}.wk-save-input:focus{border-color:var(--color-primary)}.wk-save-modal-actions{display:flex;gap:10px;margin-top:16px}.wk-save-modal-actions .wk-btn-secondary,.wk-save-modal-actions .wk-btn-primary{flex:1}.wk-complete-save-btn{position:fixed;bottom:100px;left:50%;transform:translate(-50%);z-index:10000;display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:#ffffff26;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:24px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;transition:transform .15s,background .2s;-webkit-tap-highlight-color:transparent}.wk-complete-save-btn:active{transform:translate(-50%) scale(.95)}.wk-complete-save-btn:hover{background:#ffffff40}.wk-complete-save-btn svg{color:#fff}[data-mono=true][data-theme=dark] .wk-hub-count{color:#111}.wk-hub-byo-section{margin-top:8px}.wk-hub-byo-list{padding:0 16px;display:flex;flex-direction:column;gap:8px}.wk-hub-byo-card{display:flex;align-items:center;border-radius:14px;border:1px solid var(--border-color);background:var(--bg-card);overflow:hidden;animation:fadeSlideIn .3s ease-out both}.wk-hub-byo-main{flex:1;display:flex;align-items:center;gap:12px;padding:14px 16px;border:none;background:transparent;cursor:pointer;min-width:0}.wk-hub-byo-icon{width:40px;height:40px;border-radius:10px;background:rgba(var(--color-primary-rgb, 184, 49, 61),.08);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.wk-hub-byo-info{flex:1;min-width:0;text-align:left}.wk-hub-byo-name{display:block;font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wk-hub-byo-meta{display:block;font-size:.72rem;color:var(--text-tertiary);margin-top:2px}.wk-hub-byo-begin{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.wk-hub-byo-delete{padding:14px;border:none;border-left:1px solid var(--border-light);background:transparent;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center}.wk-hub-byo-delete:active{background:#dc354514;color:#dc3545}.byo-mode-grid{display:flex;flex-direction:column;gap:12px;padding:0 16px;margin-bottom:24px}.byo-mode-card{display:flex;flex-direction:row;align-items:center;gap:16px;padding:20px;border-radius:16px;border:1.5px solid var(--border-color);background:var(--bg-card);cursor:pointer;transition:all .2s;text-align:left;width:100%}.byo-mode-card h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.byo-mode-card p{font-size:.78rem;color:var(--text-secondary);margin:0;line-height:1.3}.byo-mode-active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.08)}.byo-mode-card-text{flex:1;min-width:0}.byo-mode-icon{width:52px;height:52px;border-radius:50%;background:rgba(var(--color-primary-rgb, 184, 49, 61),.08);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.byo-continue-btn{margin:0 16px 24px;width:calc(100% - 32px);display:flex;align-items:center;justify-content:center;gap:6px}.byo-pick-main{padding-bottom:140px}.byo-pick-count{background:var(--color-primary);color:#fff;font-size:.75rem;font-weight:700;min-width:22px;height:22px;border-radius:11px;display:flex;align-items:center;justify-content:center;padding:0 6px}[data-mono=true][data-theme=dark] .byo-pick-count{color:var(--text-on-primary)}.byo-level-row{display:flex;gap:8px;padding:0 16px 16px}.byo-level-btn{flex:1;padding:10px 8px;border-radius:12px;border:1.5px solid var(--border-color);background:var(--bg-card);cursor:pointer;text-align:center;transition:all .2s}.byo-level-active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.08)}.byo-level-label{display:block;font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;color:var(--text-primary)}.byo-level-desc{display:block;font-size:.65rem;color:var(--text-tertiary);margin-top:2px}.byo-group{margin:0 16px 8px;border-radius:14px;border:1px solid var(--border-color);overflow:hidden}.byo-group-header{display:flex;align-items:center;width:100%;padding:14px 16px;background:var(--bg-card);border:none;cursor:pointer;gap:8px}.byo-group-label{flex:1;text-align:left;font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary);text-transform:uppercase}.byo-group-badge{background:var(--color-primary);color:#fff;font-size:.7rem;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px}[data-mono=true][data-theme=dark] .byo-group-badge{color:var(--text-on-primary)}.byo-group-chevron{color:var(--text-tertiary);transition:transform .2s}.byo-group-chevron-open{transform:rotate(180deg)}.byo-muscle-filters{display:flex;flex-wrap:wrap;gap:6px;padding:10px 16px;border-bottom:1px solid var(--border-light)}.byo-muscle-chip{padding:5px 12px;border-radius:16px;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s}.byo-muscle-chip-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}[data-mono=true][data-theme=dark] .byo-muscle-chip-active{color:var(--text-on-primary)}.byo-subgroups{border-top:1px solid var(--border-color)}.byo-subgroup{border-bottom:1px solid var(--border-light)}.byo-subgroup:last-child{border-bottom:none}.byo-subgroup-header{display:flex;align-items:center;width:100%;padding:12px 16px 12px 28px;background:var(--bg-card);border:none;cursor:pointer;gap:8px}.byo-subgroup-label{flex:1;text-align:left;font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:600;color:var(--text-secondary)}.byo-search-bar{display:flex;align-items:center;gap:8px;margin:0 16px 8px;padding:10px 14px;border-radius:12px;border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--text-tertiary)}.byo-search-input{flex:1;border:none;background:transparent;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;outline:none}.byo-search-input::placeholder{color:var(--text-tertiary)}.byo-search-clear{border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;padding:0;display:flex;align-items:center}.byo-add-custom-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin:0 16px 10px;padding:10px 16px;border-radius:12px;border:1.5px dashed var(--border-color);background:transparent;color:var(--text-secondary);font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:600;cursor:pointer;width:calc(100% - 32px);transition:border-color .2s,color .2s}.byo-add-custom-btn:active{border-color:var(--color-primary);color:var(--color-primary)}.byo-custom-type-row{display:flex;gap:8px;margin-top:12px}.byo-custom-type-btn{flex:1;padding:8px 6px;border-radius:8px;border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s}.byo-custom-type-btn.byo-custom-type-active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.08);color:var(--color-primary)}.byo-search-empty{text-align:center;padding:32px 16px;font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;color:var(--text-tertiary)}.byo-search-results{padding-top:4px}.byo-exercise-list{display:flex;flex-direction:column;gap:6px;padding:8px 16px 14px;background:var(--bg-body)}.byo-exercise-row{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:12px;border:1.5px solid var(--border-color);background:var(--bg-card);cursor:pointer;transition:border-color .2s}.byo-exercise-row.byo-exercise-selected{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.byo-exercise-thumb-sm{position:relative;width:48px;height:48px;border-radius:8px;background:var(--bg-body);overflow:hidden;flex-shrink:0}.byo-exercise-thumb-sm img,.byo-exercise-thumb-sm video{width:100%;height:100%;object-fit:cover;display:block}.byo-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.byo-thumb-play-sm{position:absolute;bottom:2px;right:2px;width:20px;height:20px;border-radius:50%;background:#0000008c;display:flex;align-items:center;justify-content:center;color:#fff}.byo-exercise-name{flex:1;text-align:left;font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:500;color:var(--text-primary);line-height:1.25}.static-thumb-wrap{width:100%;height:100%}.static-thumb-wrap img,.static-thumb-wrap video,.static-thumb-wrap canvas{width:100%;height:100%;object-fit:cover;display:block}.byo-exercise-check{color:var(--color-primary);flex-shrink:0}.byo-pick-footer{position:fixed;bottom:0;left:0;right:0;padding:12px 16px calc(var(--safe-area-bottom) + 76px);background:var(--bg-body);border-top:1px solid var(--border-color);z-index:100}.byo-start-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:6px}.byo-config-card{display:flex;align-items:center;justify-content:space-between;margin:0 16px 10px;padding:14px 16px;border-radius:14px;border:1px solid var(--border-color);background:var(--bg-card)}.byo-config-info{flex:1;min-width:0}.byo-config-name{display:block;font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary);line-height:1.3}.byo-config-meta{display:block;font-size:.72rem;color:var(--text-tertiary);margin-top:2px}.byo-config-stepper{display:flex;align-items:center;gap:4px;flex-shrink:0}.byo-stepper-btn{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--border-color);background:var(--bg-card);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);transition:all .15s}.byo-stepper-btn:disabled{opacity:.3;cursor:not-allowed}.byo-stepper-btn:active:not(:disabled){background:rgba(var(--color-primary-rgb, 184, 49, 61),.1);border-color:var(--color-primary)}.byo-stepper-value{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700;color:var(--text-primary);min-width:32px;text-align:center}.byo-save-form{padding:0 16px}.byo-save-input{width:100%;padding:14px 16px;border-radius:12px;border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;outline:none;transition:border-color .2s;margin-bottom:20px;box-sizing:border-box}.byo-save-input:focus{border-color:var(--color-primary)}.byo-save-summary{border-radius:12px;border:1px solid var(--border-color);background:var(--bg-card);overflow:hidden;margin-bottom:24px}.byo-save-summary-row{display:flex;justify-content:space-between;padding:12px 16px;font-size:.82rem;color:var(--text-secondary);border-bottom:1px solid var(--border-light)}.byo-save-summary-row:last-child{border-bottom:none}.byo-save-summary-row span:last-child{font-weight:600;color:var(--text-primary)}.byo-save-btn{width:100%}.byo-begin-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}.byo-sets-main{padding-bottom:calc(100px + var(--safe-area-bottom))}.byo-set-card{margin:0 16px 16px;border-radius:14px;border:1px solid var(--border-color);background:var(--bg-card);overflow:hidden}.byo-set-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-color)}.byo-set-header h3{font-family:Plus Jakarta Sans,sans-serif;font-size:.88rem;font-weight:600;color:var(--text-primary);margin:0}.byo-set-type{font-size:.72rem;color:var(--text-tertiary);text-transform:capitalize;background:var(--bg-card-elevated);padding:3px 8px;border-radius:6px}.byo-set-rows{padding:8px 16px 4px}.byo-set-row{display:flex;align-items:center;gap:10px;padding:6px 0}.byo-set-row-header{padding-bottom:4px;border-bottom:1px solid var(--border-light);margin-bottom:4px}.byo-set-row-header span{font-size:.7rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase}.byo-set-num{width:28px;text-align:center;font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;color:var(--text-secondary);flex-shrink:0}.byo-set-input{flex:1;padding:8px 10px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-size:.85rem;font-family:Plus Jakarta Sans,sans-serif;text-align:center;-moz-appearance:textfield}.byo-set-input::-webkit-outer-spin-button,.byo-set-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.byo-set-weight{flex:1;max-width:90px}.byo-set-reps{width:65px;flex-shrink:0;flex-grow:0}.byo-reps-tap{cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:600;font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;color:var(--text-primary);transition:background .15s}.byo-reps-tap:active{background:rgba(var(--color-primary-rgb),.1)}.byo-reps-placeholder{color:var(--text-tertiary);font-weight:400}.reps-picker-backdrop{position:fixed;inset:0;z-index:10000;background:#00000080;display:flex;align-items:flex-end;justify-content:center;animation:cbFabOverlayIn .15s ease forwards}.reps-picker-sheet{background:#fff;border-radius:18px 18px 0 0;width:100%;max-width:420px;animation:repsSheetIn .25s ease forwards;overflow:hidden}@keyframes repsSheetIn{0%{transform:translateY(100%)}to{transform:translateY(0)}}.reps-picker-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid #eee}.reps-picker-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:700;color:#1a1a1a}.reps-picker-cancel,.reps-picker-done{background:none;border:none;font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;padding:4px 8px}.reps-picker-cancel{color:#999}.reps-picker-done{color:var(--color-primary)}.reps-picker-drum-wrapper{position:relative;display:flex;justify-content:center;padding:16px 0 24px}.reps-picker-highlight{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:44px;border-radius:10px;background:rgba(var(--color-primary-rgb),.1);border:2px solid var(--color-primary);pointer-events:none;z-index:1}.reps-picker-scroll{overflow-y:auto;scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch;width:100px;position:relative;z-index:2;scrollbar-width:none;-ms-overflow-style:none}.reps-picker-scroll::-webkit-scrollbar{display:none}.reps-picker-item{display:flex;align-items:center;justify-content:center;scroll-snap-align:center;font-family:Plus Jakarta Sans,sans-serif;font-size:1.2rem;font-weight:500;color:#bbb;transition:color .1s,font-size .1s;user-select:none;-webkit-user-select:none}.reps-picker-item-active{color:#1a1a1a;font-weight:700;font-size:1.5rem}[data-theme=dark] .reps-picker-sheet{background:#1e1e1e}[data-theme=dark] .reps-picker-header{border-bottom-color:#333}[data-theme=dark] .reps-picker-title{color:#fff}[data-theme=dark] .reps-picker-cancel{color:#666}[data-theme=dark] .reps-picker-item{color:#555}[data-theme=dark] .reps-picker-item-active{color:#fff}[data-theme=dark] .reps-picker-highlight{background:rgba(var(--color-primary-rgb),.15)}[data-mono=true][data-theme=dark] .reps-picker-sheet{background:#1a1a1a}.byo-set-invisible{visibility:hidden}.byo-set-del{width:32px;flex-shrink:0}.byo-set-del-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.byo-set-del-btn:active{background:#f443361a;color:var(--color-error)}.byo-add-set-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;border:none;border-top:1px solid var(--border-color);background:transparent;color:var(--color-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.byo-add-set-btn:active{background:rgba(var(--color-primary-rgb, 184, 49, 61),.06)}.byo-sets-footer{position:fixed;bottom:0;left:0;right:0;padding:12px 16px calc(var(--safe-area-bottom) + 76px);background:var(--bg-body);border-top:1px solid var(--border-color);z-index:100}.byo-complete-btn{width:100%}.byo-unit-toggle{display:flex;gap:0;margin:0 16px 12px;border-radius:10px;border:1px solid var(--border-color);overflow:hidden;width:fit-content}.byo-unit-btn{padding:7px 18px;border:none;background:var(--bg-card);color:var(--text-secondary);font-family:Plus Jakarta Sans,sans-serif;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.byo-unit-btn+.byo-unit-btn{border-left:1px solid var(--border-color)}.byo-unit-active{background:var(--color-primary);color:#fff}[data-mono=true][data-theme=dark] .byo-unit-active{color:var(--text-on-primary)}.byo-smart-tip{display:flex;align-items:flex-start;gap:10px;margin:0 16px 16px;padding:12px 14px;border-radius:12px;background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);border:1px solid rgba(var(--color-primary-rgb, 184, 49, 61),.15)}.byo-smart-tip svg{flex-shrink:0;color:var(--color-primary);margin-top:1px}.byo-smart-tip span{font-family:Plus Jakarta Sans,sans-serif;font-size:.78rem;color:var(--text-secondary);line-height:1.4}.wk-landing-main{display:flex;flex-direction:column;max-width:500px;margin:0 auto;width:100%}.wk-landing-cards{display:flex;flex-direction:column;gap:14px;width:100%;max-width:440px;margin-bottom:28px}.wk-landing-card{display:flex;align-items:center;gap:14px;padding:20px 16px;background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:16px;cursor:pointer;transition:all .2s;text-align:left;width:100%}.wk-landing-card:active{transform:scale(.98)}@media(hover:hover){.wk-landing-card:hover{border-color:var(--color-primary);box-shadow:0 4px 16px rgba(var(--color-primary-rgb, 184, 49, 61),.12)}}.wk-landing-card-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wk-landing-card-icon--randomiser{background:none;padding:0;overflow:hidden}.wk-landing-logo{width:56px;height:56px;object-fit:cover;border-radius:14px}.wk-landing-card-icon--byo{background:rgba(var(--color-primary-rgb, 184, 49, 61),.1);color:var(--color-primary);overflow:hidden}.wk-landing-byo-photo{width:100%;height:100%;object-fit:cover;border-radius:14px}.wk-landing-card-body{flex:1;min-width:0}.wk-landing-card-body h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.wk-landing-card-body p{font-size:.8rem;color:var(--text-secondary);margin:0;line-height:1.35}.wk-landing-card-arrow{flex-shrink:0;color:var(--text-tertiary)}.wk-landing-card:focus{outline:none}.wk-landing-card:focus:not(:focus-visible){border-color:var(--border-color);transform:none}[data-theme=dark] .wk-landing-card:focus:not(:focus-visible){border-color:#ffffff0f}.wk-landing-stats{margin-top:8px}.wkl-top{padding:16px 0 4px}.wkl-tabs{display:flex;background:var(--bg-secondary, rgba(0,0,0,.04));border-radius:10px;padding:3px;margin-bottom:18px;gap:2px}.wkl-tab{flex:1;padding:7px 0;border:none;border-radius:8px;background:transparent;font-family:Plus Jakarta Sans,sans-serif;font-size:.78rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.wkl-tab--active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 4px #00000014}[data-theme=dark] .wkl-tabs{background:#ffffff0f}[data-theme=dark] .wkl-tab--active{background:#ffffff1a;box-shadow:0 1px 4px #0000004d}.wkl-greeting-row{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.wkl-greeting h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.35rem;font-weight:800;color:var(--text-primary);margin:0 0 2px}.wkl-greeting p{font-size:.8rem;color:var(--text-secondary);margin:0}.wkl-stats-row{display:flex;justify-content:center;gap:16px;margin-bottom:14px}.wkl-stat{display:flex;flex-direction:column;align-items:center;position:relative}.wkl-stat--hero .wkl-stat-svg,.wkl-stat--hero .wkl-stat-center{width:80px;height:80px}.wkl-stat--hero .wkl-stat-value{font-size:1rem}.wkl-stat-svg{width:68px;height:68px;transform:rotate(-90deg)}.wkl-stat-track{fill:none;stroke:var(--border-color);stroke-width:8;stroke-linecap:round}.wkl-stat-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .6s ease-out}.wkl-stat-center{position:absolute;top:0;left:50%;transform:translate(-50%);width:68px;height:68px;display:flex;align-items:center;justify-content:center;pointer-events:none}.wkl-stat-value{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:800;line-height:1}.wkl-stat-of{font-size:.65em;opacity:.6;font-weight:600}.wkl-stat-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--text-secondary);margin-top:4px}.wkl-stat-value--sm{font-size:.7rem}.wkl-levels{display:flex;gap:10px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px}[data-theme=dark] .wkl-levels{background:#1e1e1ecc;border-color:#ffffff0f}.wkl-level-item{flex:1;display:flex;flex-direction:column;gap:4px}.wkl-level-bar-track{height:4px;border-radius:2px;background:var(--border-color);overflow:hidden}.wkl-level-bar-fill{height:100%;border-radius:2px;transition:width .4s ease-out;min-width:2px}.wkl-level-meta{display:flex;justify-content:space-between;align-items:baseline}.wkl-level-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.2px}.wkl-level-count{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:800;color:var(--text-primary)}.wkl-recent-section{padding:14px 0 6px}.wkl-recent-list{display:flex;flex-direction:column;gap:8px}.wkl-recent-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px}.wkl-recent-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wkl-recent-icon--randomiser{background:rgba(var(--color-primary-rgb, 184, 49, 61),.1);color:var(--color-primary)}.wkl-recent-icon--byo{background:#14b8a61a;color:var(--color-success, #14b8a6)}.wkl-recent-icon--activity{background:#3b82f61a;color:#3b82f6}.wkl-recent-icon--programme{background:#8b5cf61a;color:#8b5cf6}.wkl-recent-info{flex:1;min-width:0}.wkl-recent-name{display:block;font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:600;color:var(--text-primary)}.wkl-recent-time{font-family:Inter,sans-serif;font-size:.68rem;color:var(--text-tertiary)}.wkl-recent-stat{font-family:Plus Jakarta Sans,sans-serif;font-size:.78rem;font-weight:700;color:var(--color-primary);flex-shrink:0}[data-theme=dark] .wkl-recent-item{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .wkl-recent-icon--byo{background:#2dd4bf1a;color:var(--color-success, #2dd4bf)}[data-theme=dark] .wkl-recent-icon--activity{background:#60a5fa1a;color:#60a5fa}@media(min-width:400px){.wkl-stat--hero .wkl-stat-svg,.wkl-stat--hero .wkl-stat-center{width:90px;height:90px}.wkl-stat-svg,.wkl-stat-center{width:74px;height:74px}}.wk-fab-count{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:600;color:var(--text-secondary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.08);border-radius:10px;padding:1px 7px;margin-top:2px}.wk-saved-overlay-backdrop{position:fixed;inset:0;z-index:1001;background:#000000d9;display:flex;align-items:center;justify-content:center;padding:16px;animation:cbFabOverlayIn .2s ease forwards}.wk-saved-overlay-card{background:#fff;border-radius:18px;width:100%;max-width:400px;max-height:75vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d;animation:cbFabSheetIn .3s ease forwards}.wk-saved-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid #eee}.wk-saved-overlay-header h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:#1a1a1a;margin:0;flex:1;text-align:center}.wk-saved-overlay-back{background:none;border:none;color:#555;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.wk-byo-fab-tabs{display:flex;gap:0;padding:0 16px;border-bottom:1px solid #eee}.wk-byo-fab-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 0;background:none;border:none;border-bottom:2.5px solid transparent;font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:600;color:#999;cursor:pointer;transition:all .2s}.wk-byo-fab-tab:hover{color:#666}.wk-byo-fab-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.wk-byo-fab-tab svg{flex-shrink:0}.wk-byo-fab-tab-count{background:rgba(var(--color-primary-rgb),.12);color:var(--color-primary);font-size:.7rem;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}[data-theme=dark] .wk-byo-fab-tabs{border-bottom-color:#333}[data-theme=dark] .wk-byo-fab-tab{color:#666}[data-theme=dark] .wk-byo-fab-tab:hover{color:#aaa}[data-theme=dark] .wk-byo-fab-tab-active{color:var(--color-primary)}[data-theme=dark] .wk-byo-fab-tab-count{background:rgba(var(--color-primary-rgb),.2)}.wk-saved-overlay-list{overflow-y:auto;padding:12px 16px 16px;flex:1}.wk-saved-overlay-item{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid #f0f0f0;animation:cbFabItemIn .3s both}.wk-saved-overlay-item:last-child{border-bottom:none}.wk-saved-overlay-main{flex:1;display:flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;text-align:left;padding:4px 0;min-width:0}.wk-saved-overlay-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.wk-saved-overlay-name{font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:600;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wk-saved-overlay-meta{font-size:.75rem;color:#777}.wk-saved-overlay-equip{font-size:.7rem;color:#999}.wk-saved-overlay-ago{font-size:.72rem;color:#999;white-space:nowrap;flex-shrink:0}.wk-saved-overlay-main svg{flex-shrink:0;color:var(--color-primary)}.wk-saved-overlay-delete{background:none;border:none;color:#ccc;cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s}.wk-saved-overlay-delete:hover{color:var(--color-primary)}[data-theme=dark] .wk-saved-overlay-card{background:#1e1e1e}[data-theme=dark] .wk-saved-overlay-header{border-bottom-color:#333}[data-theme=dark] .wk-saved-overlay-header h3{color:#fff}[data-theme=dark] .wk-saved-overlay-back{color:#aaa}[data-theme=dark] .wk-saved-overlay-name{color:#f0f0f0}[data-theme=dark] .wk-saved-overlay-meta{color:#aaa}[data-theme=dark] .wk-saved-overlay-equip,[data-theme=dark] .wk-saved-overlay-ago{color:#888}[data-theme=dark] .wk-saved-overlay-item{border-bottom-color:#333}[data-theme=dark] .wk-saved-overlay-delete{color:#555}[data-mono=true][data-theme=dark] .wk-saved-overlay-card{background:#1a1a1a}[data-mono=true][data-theme=dark] .wk-saved-overlay-name{color:#e8e8e8}[data-mono=true][data-theme=dark] .wk-saved-overlay-meta{color:#999}.byo-save-category-section{margin-top:16px}.byo-save-category-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px;display:block}.byo-save-category-grid{display:flex;flex-wrap:wrap;gap:8px}.byo-save-category-btn{display:flex;align-items:center;gap:5px;padding:7px 12px;border-radius:10px;border:1.5px solid var(--border-color);background:var(--bg-card);font-family:Plus Jakarta Sans,sans-serif;font-size:.78rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s}.byo-save-category-btn:active{transform:scale(.95)}.byo-save-category-btn.byo-save-category-active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.08);color:var(--color-primary)}.byo-save-category-modal .byo-save-category-label{color:#555}.byo-save-category-modal .byo-save-category-btn{background:#f5f5f5;border-color:#ddd;color:#555}.byo-save-category-modal .byo-save-category-btn.byo-save-category-active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.08);color:var(--color-primary)}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes cbFabOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes cbFabSheetIn{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes cbFabItemIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.wc-hold-page{position:fixed;inset:0;z-index:1500;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:24px;background:#0000;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);animation:wcHoldOverlayIn .4s ease-out forwards;overflow:hidden}@keyframes wcHoldOverlayIn{0%{background:#0000;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px)}to{background:#000000d9;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}}.wc-hold-glow{position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(var(--color-primary-rgb),.12) 0%,rgba(var(--color-primary-rgb),.04) 40%,transparent 70%);pointer-events:none;animation:wcGlowFloat 4s ease-in-out infinite}@keyframes wcGlowFloat{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.08);opacity:1}}.wc-hold-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;color:#ffffffb3;text-transform:uppercase;letter-spacing:2px;margin:0 0 24px;position:relative;z-index:1;animation:wcHintPulse 2.5s ease-in-out infinite}@keyframes wcHintPulse{0%,to{opacity:.5}50%{opacity:1}}.wc-hold-ring-touch{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;transition:transform .2s ease;border-radius:50%;z-index:1}.wc-hold-ring-touch:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}.wc-holding{transform:scale(1.06)}.wc-hold-ring-glow{position:absolute;inset:-16px;border-radius:50%;background:radial-gradient(circle,rgba(var(--color-primary-rgb),.15) 0%,transparent 70%);animation:wcRingGlow 2s ease-in-out infinite;pointer-events:none}@keyframes wcRingGlow{0%,to{transform:scale(.9);opacity:.5}50%{transform:scale(1.1);opacity:1}}.wc-holding .wc-hold-ring-glow{animation:none;transform:scale(1.15);opacity:1}.wc-hold-ring-svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.wc-hold-ring-track{fill:none;stroke:#ffffff26;stroke-width:6;stroke-linecap:round}.wc-hold-ring-fill{fill:none;stroke:#fff;stroke-width:6;stroke-linecap:round;transition:none}.wc-hold-logo{position:relative;z-index:1;width:80%;height:80%;border-radius:50%;object-fit:cover;pointer-events:none;filter:blur(8px) grayscale(1);animation:wcLogoPulse 2.5s ease-in-out infinite}@keyframes wcLogoPulse{0%,to{filter:blur(8px) grayscale(1);transform:scale(1)}50%{filter:blur(4px) grayscale(.5);transform:scale(1.04)}}.wc-holding .wc-hold-logo{animation:none}.wc-celeb-overlay{position:fixed;inset:0;z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0000;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);animation:wcOverlayIn .3s ease-out forwards}.wc-celeb-dismissing{animation:wcOverlayOut .3s ease-in forwards}@keyframes wcOverlayIn{0%{background:#0000;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px)}to{background:#000000d9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}}@keyframes wcOverlayOut{0%{opacity:1}to{opacity:0}}.wc-celeb-confetti{position:absolute;inset:0;overflow:hidden;pointer-events:none}.wc-celeb-confetti-piece{position:absolute;top:-12px;left:var(--x, 50%);background:var(--color, var(--color-primary));animation:wcConfettiFall var(--duration, 2.5s) ease-in var(--delay, 0s) both}.wc-confetti-shape-0{border-radius:2px}.wc-confetti-shape-1{border-radius:50%}.wc-confetti-shape-2{border-radius:1px;height:2px!important}@keyframes wcConfettiFall{0%{transform:translateY(0) translate(0) rotate(0);opacity:1}85%{opacity:1}to{transform:translateY(100vh) translate(var(--drift, 0px)) rotate(var(--spin, 360deg));opacity:0}}.wc-celeb-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;padding:0 32px;max-width:360px;width:100%}.wc-celeb-logo-frame{width:130px;height:130px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px rgba(var(--color-primary-rgb),.5),0 0 40px rgba(var(--color-primary-rgb),.3);animation:wcLogoIn .5s cubic-bezier(.34,1.56,.64,1) .2s both,wcGlowPulse 2s ease-in-out infinite .7s;margin-top:-10vh}.wc-celeb-logo-img{width:100%;height:100%;object-fit:cover;display:block}@keyframes wcLogoIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes wcGlowPulse{0%,to{box-shadow:0 0 20px rgba(var(--color-primary-rgb),.3),0 0 40px rgba(var(--color-primary-rgb),.15)}50%{box-shadow:0 0 25px rgba(var(--color-primary-rgb),.6),0 0 50px rgba(var(--color-primary-rgb),.3)}}.wc-celeb-heading{font-family:Plus Jakarta Sans,sans-serif;font-size:1.5rem;font-weight:700;color:#fff;text-align:center;margin:24px 0 0;opacity:0;animation:wcTextIn .4s ease-out .6s forwards}.wc-celeb-subtext{font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:600;color:#ffffffb3;text-align:center;margin:6px 0 0;opacity:0;animation:wcTextIn .4s ease-out .7s forwards}.wc-celeb-quote{font-family:Inter,sans-serif;font-size:.85rem;color:#ffffff80;text-align:center;margin:8px 0 0;font-style:italic;opacity:0;animation:wcTextIn .4s ease-out .8s forwards}.wc-celeb-stats-row{display:flex;gap:24px;margin-top:24px;opacity:0;animation:wcTextIn .4s ease-out .9s forwards}.wc-celeb-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.wc-celeb-stat-val{font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:700;color:#fff}.wc-celeb-stat-label{font-family:Inter,sans-serif;font-size:.65rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}@keyframes wcTextIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.wc-celeb-btn{margin-top:32px;padding:14px 48px;background:var(--color-primary);color:var(--text-on-primary);border:none;border-radius:50px;font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;cursor:pointer;letter-spacing:.5px;transition:transform .15s ease,opacity .15s ease;-webkit-tap-highlight-color:transparent;opacity:0;animation:wcTextIn .4s ease-out 1s forwards}.wc-celeb-btn:hover{transform:scale(1.03)}.wc-celeb-btn:active{transform:scale(.97)}.wc-celeb-btn:focus-visible{outline:2px solid #fff;outline-offset:3px}.wc-feeling-section{margin-top:20px;opacity:0;animation:wcTextIn .4s ease-out .92s forwards}.wc-feeling-label{font-family:Inter,sans-serif;font-size:.75rem;color:#ffffff80;text-transform:uppercase;letter-spacing:1px;text-align:center;margin:0 0 10px}.wc-feeling-row{display:flex;gap:8px;justify-content:center}.wc-feeling-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 10px;background:#ffffff0f;border:1.5px solid rgba(255,255,255,.12);border-radius:12px;cursor:pointer;transition:all .15s ease;-webkit-tap-highlight-color:transparent}.wc-feeling-btn:active{transform:scale(.92)}.wc-feeling-icon{font-size:1.4rem;line-height:1}.wc-feeling-text{font-family:Inter,sans-serif;font-size:.6rem;color:#ffffff80;font-weight:500}.wc-feeling-selected{background:rgba(var(--color-primary-rgb),.25);border-color:var(--color-primary)}.wc-feeling-selected .wc-feeling-text{color:#fff}.wc-share-row{display:flex;gap:10px;margin-top:24px;opacity:0;animation:wcTextIn .4s ease-out .95s forwards}.wc-share-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:50px;color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s ease,transform .15s ease;-webkit-tap-highlight-color:transparent}.wc-share-btn svg{width:16px;height:16px;flex-shrink:0}.wc-share-btn:hover{background:#ffffff2e}.wc-share-btn:active{transform:scale(.95)}.wc-share-journey{background:#ffd7001f;border-color:#ffd7004d;color:gold}.wc-share-journey:hover{background:#ffd70038}.wc-share-done{opacity:.6;cursor:default}.wc-share-done:hover{background:#ffd7001f}.wc-share-done:active{transform:none}.wc-share-toast{position:fixed;bottom:40px;left:50%;transform:translate(-50%);padding:10px 24px;background:#ffffff26;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:50px;color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;z-index:2100;animation:wcToastIn .3s ease-out forwards}@keyframes wcToastIn{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(prefers-reduced-motion:reduce){.wc-celeb-confetti-piece{display:none}.wc-celeb-logo-frame{animation:wcFadeOnly .3s ease-out .1s both}.wc-celeb-heading,.wc-celeb-subtext,.wc-celeb-quote,.wc-celeb-stats-row,.wc-share-row,.wc-celeb-btn{animation:wcFadeOnly .3s ease-out .2s both}.wc-holding{transform:none}.wc-hold-page{animation:none;background:#000000b3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.wc-hold-glow,.wc-hold-ring-glow{animation:none}.wc-hold-hint{animation:none;opacity:.7}.wc-hold-stats{animation:wcFadeOnly .3s ease-out both}}@keyframes wcFadeOnly{0%{opacity:0}to{opacity:1}}@media(min-width:400px){.wc-hold-ring-touch{width:240px;height:240px}.wc-hold-label{font-size:.95rem;letter-spacing:2.5px;margin-bottom:32px}.wc-celeb-logo-frame{width:140px;height:140px}.wc-celeb-heading{font-size:1.6rem}}.cbc-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-body)}.cbc-loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.cbc-loading-inline{display:flex;align-items:center;justify-content:center;min-height:60vh}.cbc-page{min-height:100vh;background:var(--bg-body);padding-bottom:calc(80px + var(--safe-area-bottom))}.cbc-main{max-width:600px;margin:0 auto;padding:0 16px calc(80px + var(--safe-area-bottom))}.cbc-hero{display:flex;flex-direction:column;align-items:center;padding:24px 0 8px}.cbc-progress-ring{position:relative;width:160px;height:160px;display:flex;align-items:center;justify-content:center}.cbc-progress-ring svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.cbc-arc-track{fill:none;stroke:#96969633;stroke-width:24;stroke-linecap:round}.cbc-arc-fill{fill:none;stroke:var(--color-primary);stroke-width:24;stroke-linecap:round;transition:stroke-dashoffset .6s ease-out}.cbc-ring-complete .cbc-arc-fill{filter:drop-shadow(0 0 6px rgba(var(--color-primary-rgb),.5))}.cbc-ring-center{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}.cbc-ring-count{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.8rem;color:var(--text-primary);line-height:1}.cbc-ring-divider{font-weight:400;font-size:1.2rem;color:var(--text-tertiary);margin:0 1px}.cbc-ring-label{font-family:Inter,sans-serif;font-size:.65rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-tertiary);margin-top:4px}.cbc-hero-tagline{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-secondary);text-align:center;margin-top:14px;font-weight:500;line-height:1.3}.cbc-streak-card{display:flex;align-items:center;gap:12px;margin:12px 0 4px;padding:14px 18px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;box-shadow:var(--shadow-glow)}[data-theme=dark] .cbc-streak-card{background:#1e1e1ecc;border-color:#ffffff0f;box-shadow:0 1px 3px #0003,0 4px 12px #00000026}.cbc-streak-icon{width:44px;height:44px;border-radius:12px;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.cbc-streak-info{flex:1;display:flex;align-items:baseline;gap:6px}.cbc-streak-count{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.3rem;color:var(--color-primary)}.cbc-streak-label{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-secondary)}.cbc-streak-best{display:flex;flex-direction:column;align-items:center;padding:6px 12px;background:rgba(var(--color-primary-rgb),.06);border-radius:10px}.cbc-streak-best-val{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1rem;color:var(--text-primary)}.cbc-streak-best-label{font-family:Inter,sans-serif;font-size:.55rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary)}.cbc-section{padding:16px 0}.cbc-section-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:14px;text-transform:uppercase;letter-spacing:.5px}.cbc-habits-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.cbc-habit-tile{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 14px 16px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:20px;transition:transform .2s ease,box-shadow .2s ease,background .25s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;-webkit-touch-callout:none;user-select:none;overflow:visible;box-shadow:var(--shadow-glow)}.cbc-habit-done{background:var(--bg-card)}[data-theme=dark] .cbc-habit-tile{background:#1e1e1ecc;border-color:#ffffff0f;box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .cbc-habit-done{background:#1e1e1ecc}.cbc-habit-ring-touch{position:relative;width:100px;height:100px;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:none;-webkit-tap-highlight-color:transparent;transition:transform .2s ease;border-radius:50%}.cbc-habit-ring-touch:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}.cbc-holding{transform:scale(1.05)}.cbc-habit-just-checked .cbc-habit-ring-touch{animation:ringCompleteBounce .4s ease-out}@keyframes ringCompleteBounce{0%{transform:scale(1.05)}40%{transform:scale(1.12)}to{transform:scale(1)}}.cbc-habit-ring-svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.cbc-habit-ring-track{fill:none;stroke:#96969626;stroke-width:10;stroke-linecap:round}.cbc-habit-ring-fill{fill:none;stroke-width:10;stroke-linecap:round;transition:none}.cbc-ring-completed .cbc-habit-ring-fill{transition:stroke-dashoffset .3s ease-out}.cbc-habit-ring-icon{position:relative;z-index:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;opacity:.4;filter:grayscale(.3);transition:opacity .25s ease,filter .25s ease}.cbc-habit-ring-icon svg{width:32px;height:32px}.cbc-ring-completed .cbc-habit-ring-icon{opacity:1;filter:brightness(1.3) grayscale(0)}.cbc-habit-glow-orb{position:absolute;width:60%;height:60%;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--habit-color) 40%,transparent) 0%,color-mix(in srgb,var(--habit-color) 15%,transparent) 50%,transparent 70%);z-index:0;animation:glowOrbIn .4s ease-out forwards,glowBreath 2.5s ease-in-out .4s infinite;pointer-events:none}@keyframes glowOrbIn{0%{opacity:0;transform:scale(.4)}60%{opacity:1;transform:scale(1.15)}to{opacity:1;transform:scale(1)}}@keyframes glowBreath{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.12);opacity:.8}}.cbc-habit-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary);transition:color .2s;letter-spacing:.3px;text-align:center;line-height:1.2}.cbc-habit-done .cbc-habit-label{color:var(--text-primary)}.cbc-habit-done-tag{font-family:Plus Jakarta Sans,sans-serif;font-size:.68rem;font-weight:600;color:#4caf50;text-transform:uppercase;letter-spacing:.5px}.cbc-habit-hold-hint{font-family:Inter,sans-serif;font-size:.68rem;color:var(--text-tertiary);letter-spacing:.3px}.cbc-habit-delete{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-tap-highlight-color:transparent;opacity:.4;z-index:2}.cbc-habit-delete:hover{background:#d32f2f1a;color:#d32f2f;opacity:1}.cbc-add-tile{cursor:pointer;border:2px dashed var(--border-color);background:transparent;box-shadow:none}.cbc-add-tile:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.cbc-add-tile:hover .cbc-habit-label,.cbc-add-tile:hover .cbc-habit-hold-hint{color:var(--color-primary)}.cbc-add-ring{width:100px;height:100px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);color:var(--color-primary);transition:all .2s ease}[data-theme=dark] .cbc-add-tile{border-color:#ffffff1a;background:transparent}[data-theme=dark] .cbc-add-tile:hover{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb),.08)}.cbc-unlock-tile{cursor:pointer;border:2px dashed var(--color-primary);background:var(--color-primary-light);box-shadow:none}.cbc-unlock-tile:active{transform:scale(.96)}.cbc-unlock-ring{width:100px;height:100px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(var(--color-primary-rgb),.15);color:var(--color-primary);transition:all .2s ease}.cbc-unlock-tile .cbc-habit-label{color:var(--color-primary);font-weight:700}.cbc-unlock-tile .cbc-habit-hold-hint{color:var(--color-primary);opacity:.75}[data-theme=dark] .cbc-unlock-tile{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb),.08)}.cbc-habit-locked{opacity:.35;filter:grayscale(.6);pointer-events:none;-webkit-user-select:none;user-select:none}.cbc-modal-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.cbc-modal{background:var(--bg-card);border-radius:20px;padding:28px 24px;max-width:340px;width:100%;box-shadow:0 20px 60px #0000004d}[data-theme=dark] .cbc-modal{background:#1e1e1ef2;border:1px solid rgba(255,255,255,.06)}.cbc-modal-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.cbc-modal-desc{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-secondary);margin:0 0 16px}.cbc-saved-habits{margin-bottom:16px}.cbc-saved-label{display:block;font-family:Inter,sans-serif;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-tertiary);margin-bottom:8px}.cbc-saved-chips{display:flex;flex-wrap:wrap;gap:8px}.cbc-saved-chip{display:inline-flex;align-items:center;border-radius:20px;background:#99313c1a;border:1px solid rgba(153,49,60,.25);overflow:hidden;transition:all .2s}[data-theme=dark] .cbc-saved-chip{background:#e8475a1f;border-color:#e8475a40}.cbc-saved-chip-add{padding:7px 4px 7px 14px;background:none;border:none;color:var(--color-primary);font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent;white-space:nowrap}.cbc-saved-chip-remove{padding:7px 10px 7px 4px;background:none;border:none;color:var(--text-tertiary);font-size:1rem;line-height:1;cursor:pointer;-webkit-tap-highlight-color:transparent;opacity:.6;transition:opacity .2s}.cbc-saved-chip-remove:hover{opacity:1;color:#d32f2f}.cbc-modal-input{width:100%;padding:14px;border:2px solid var(--border-color);border-radius:12px;font-family:Inter,sans-serif;font-size:1rem;font-weight:500;color:var(--text-primary);background:var(--bg-input);outline:none;transition:border-color .2s;box-sizing:border-box;-webkit-appearance:none;margin-bottom:20px}.cbc-modal-input:focus{border-color:var(--color-primary)}.cbc-modal-input::placeholder{color:var(--text-tertiary)}.cbc-modal-actions{display:flex;gap:12px}.cbc-modal-cancel{flex:1;padding:14px;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);border-radius:10px;font-family:Inter,sans-serif;font-size:.95rem;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.cbc-modal-cancel:hover{border-color:var(--text-tertiary);color:var(--text-primary)}.cbc-modal-save{flex:1;padding:14px;background:var(--color-primary);border:none;color:var(--text-on-primary);border-radius:10px;font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.cbc-modal-save:hover:not(:disabled){background:var(--color-primary-dark)}.cbc-modal-save:disabled{opacity:.5;cursor:not-allowed}.cbc-modal-delete{flex:1;padding:14px;background:#d32f2f;border:none;color:#fff;border-radius:10px;font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.cbc-modal-delete:hover{background:#b71c1c}.cbc-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cbc-section-header .cbc-section-title{margin-bottom:0}.cbc-section-badge{font-family:Plus Jakarta Sans,sans-serif;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-primary);background:rgba(var(--color-primary-rgb),.1);padding:4px 10px;border-radius:10px}.cbc-weekly-card{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:16px;box-shadow:var(--shadow-glow)}[data-theme=dark] .cbc-weekly-card{background:#1e1e1ecc;border-color:#ffffff0f;box-shadow:0 1px 3px #0003,0 4px 12px #00000026}.cbc-weekly-header{display:grid;grid-template-columns:1fr repeat(7,28px);gap:4px;align-items:center;padding-bottom:8px;margin-bottom:4px;border-bottom:1px solid rgba(150,150,150,.1)}.cbc-weekly-day-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.55rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;text-align:center}.cbc-today-label{color:var(--color-primary)}.cbc-weekly-row{display:grid;grid-template-columns:1fr repeat(7,28px);gap:4px;align-items:center;padding:8px 0}.cbc-weekly-row+.cbc-weekly-row{border-top:1px solid rgba(150,150,150,.06)}.cbc-weekly-habit-name{font-family:Inter,sans-serif;font-size:.7rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cbc-weekly-dot{width:12px;height:12px;border-radius:50%;background:#9696961f;border:1.5px solid rgba(150,150,150,.2);margin:0 auto;transition:all .2s ease}.cbc-dot-done{border-color:transparent}.cbc-dot-today:not(.cbc-dot-done){border-color:var(--color-primary);border-style:dashed}.cbc-week-summary{margin-top:14px;padding-top:12px;border-top:1px solid rgba(150,150,150,.1);display:flex;flex-direction:column;gap:6px}.cbc-week-summary-bar{width:100%;height:5px;background:#9696961f;border-radius:3px;overflow:hidden}.cbc-week-summary-fill{height:100%;background:linear-gradient(90deg,var(--color-primary-dark),var(--color-primary));border-radius:3px;transition:width .4s ease}.cbc-week-summary-text{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-tertiary);text-align:center}.cbc-cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cbc-cal-nav-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;border:none;background:var(--bg-card);color:var(--text-primary);cursor:pointer;transition:background .15s ease;box-shadow:0 1px 3px #00000014}.cbc-cal-nav-btn:active{background:rgba(var(--color-primary-rgb),.12)}[data-theme=dark] .cbc-cal-nav-btn{background:#1e1e1ecc;box-shadow:0 1px 3px #0003}.cbc-calendar-card{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:16px;box-shadow:var(--shadow-glow)}[data-theme=dark] .cbc-calendar-card{background:#1e1e1ecc;border-color:#ffffff0f;box-shadow:0 1px 3px #0003,0 4px 12px #00000026}.cbc-cal-header{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}.cbc-cal-day-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.55rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;text-align:center}.cbc-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cbc-cal-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-family:Inter,sans-serif;font-size:.65rem;font-weight:500;border-radius:8px;color:var(--text-secondary);transition:all .15s ease}.cbc-cal-empty{background:transparent}.cbc-cal-heat-future{color:var(--text-tertiary);opacity:.3}.cbc-cal-heat-0{background:#96969614}.cbc-cal-heat-1{background:rgba(var(--color-primary-rgb),.12);color:var(--text-primary)}.cbc-cal-heat-2{background:rgba(var(--color-primary-rgb),.25);color:var(--text-primary)}.cbc-cal-heat-3{background:rgba(var(--color-primary-rgb),.45);color:var(--text-on-primary)}.cbc-cal-heat-4{background:var(--color-primary);color:var(--text-on-primary);font-weight:700}.cbc-cal-today{outline:2px solid var(--color-primary);outline-offset:-1px}.cbc-cal-perfect{box-shadow:0 0 8px rgba(var(--color-primary-rgb),.3)}.cbc-cal-legend{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:12px}.cbc-cal-legend-label{font-family:Inter,sans-serif;font-size:.55rem;color:var(--text-tertiary);margin:0 2px}.cbc-cal-legend-swatch{width:14px;height:14px;border-radius:3px}.cbc-cal-legend-swatch.cbc-cal-heat-0{background:#96969614;border:1px solid rgba(150,150,150,.15)}.cbc-cal-legend-swatch.cbc-cal-heat-1{background:rgba(var(--color-primary-rgb),.12)}.cbc-cal-legend-swatch.cbc-cal-heat-2{background:rgba(var(--color-primary-rgb),.25)}.cbc-cal-legend-swatch.cbc-cal-heat-3{background:rgba(var(--color-primary-rgb),.45)}.cbc-cal-legend-swatch.cbc-cal-heat-4{background:var(--color-primary)}.toast-notification{position:fixed;bottom:80px;left:50%;transform:translate(-50%);padding:12px 24px;border-radius:12px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:500;color:#fff;background:#333;z-index:1000;display:flex;align-items:center;gap:8px;box-shadow:0 8px 24px #0003;animation:toast-slide-in .3s ease-out;max-width:85%;text-align:center}@keyframes toast-slide-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.toast-notification.success{background:#2e7d32}.toast-notification.error{background:#c62828}.cbc-habit-just-checked{z-index:5}.cbc-particles{position:absolute;top:50%;left:50%;width:0;height:0;pointer-events:none;z-index:10}.cbc-particle{position:absolute;width:var(--size, 5px);height:var(--size, 5px);background:var(--particle-color, var(--color-primary));border-radius:50%;animation:particleBurst var(--duration, .5s) ease-out forwards}@keyframes particleBurst{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(var(--tx, 0),var(--ty, 0)) scale(0);opacity:0}}.cbc-celeb-overlay{position:fixed;inset:0;z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0000;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);animation:celebOverlayIn .3s ease-out forwards}.cbc-celeb-dismissing{animation:celebOverlayOut .3s ease-in forwards}@keyframes celebOverlayIn{0%{background:#0000;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px)}to{background:#000000d9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}}@keyframes celebOverlayOut{0%{opacity:1}to{opacity:0}}.cbc-celeb-confetti{position:absolute;inset:0;overflow:hidden;pointer-events:none}.cbc-celeb-confetti-piece{position:absolute;top:-12px;left:var(--x, 50%);background:var(--color, var(--color-primary));animation:celebConfettiFall var(--duration, 2.5s) ease-in var(--delay, 0s) both}.cbc-confetti-shape-0{border-radius:2px}.cbc-confetti-shape-1{border-radius:50%}.cbc-confetti-shape-2{border-radius:1px;height:2px!important}@keyframes celebConfettiFall{0%{transform:translateY(0) translate(0) rotate(0);opacity:1}85%{opacity:1}to{transform:translateY(100vh) translate(var(--drift, 0px)) rotate(var(--spin, 360deg));opacity:0}}.cbc-celeb-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;padding:0 32px;max-width:340px;width:100%}.cbc-celeb-logo-frame{width:130px;height:130px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px rgba(var(--color-primary-rgb),.5),0 0 40px rgba(var(--color-primary-rgb),.3);animation:celebLogoIn .5s cubic-bezier(.34,1.56,.64,1) .2s both,celebGlowPulse 2s ease-in-out infinite .7s;margin-top:-10vh}.cbc-celeb-logo-img{width:100%;height:100%;object-fit:cover;display:block}@keyframes celebLogoIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes celebGlowPulse{0%,to{box-shadow:0 0 20px rgba(var(--color-primary-rgb),.3),0 0 40px rgba(var(--color-primary-rgb),.15)}50%{box-shadow:0 0 25px rgba(var(--color-primary-rgb),.6),0 0 50px rgba(var(--color-primary-rgb),.3)}}.cbc-celeb-heading{font-family:Plus Jakarta Sans,sans-serif;font-size:1.5rem;font-weight:700;color:#fff;text-align:center;margin:24px 0 0;opacity:0;animation:celebTextIn .4s ease-out .6s forwards}.cbc-celeb-subtext{font-family:Inter,sans-serif;font-size:.95rem;color:#ffffffb3;text-align:center;margin:10px 0 0;opacity:0;animation:celebTextIn .4s ease-out .8s forwards}.cbc-celeb-stats{font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;color:#ffffff80;text-align:center;margin:8px 0 0;opacity:0;animation:celebTextIn .4s ease-out .9s forwards}@keyframes celebTextIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cbc-celeb-btn{margin-top:32px;padding:14px 48px;background:var(--color-primary);color:var(--text-on-primary);border:none;border-radius:50px;font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;cursor:pointer;letter-spacing:.5px;transition:transform .15s ease,opacity .15s ease;-webkit-tap-highlight-color:transparent;opacity:0;animation:celebTextIn .4s ease-out 1s forwards}.cbc-celeb-btn:hover{transform:scale(1.03)}.cbc-celeb-btn:active{transform:scale(.97)}.cbc-celeb-btn:focus-visible{outline:2px solid #fff;outline-offset:3px}@media(prefers-reduced-motion:reduce){.cbc-celeb-confetti-piece{display:none}.cbc-celeb-logo-frame{animation:celebFadeOnly .3s ease-out .1s both}.cbc-celeb-heading,.cbc-celeb-subtext,.cbc-celeb-stats,.cbc-celeb-btn{animation:celebFadeOnly .3s ease-out .2s both}.cbc-holding{transform:none}.cbc-habit-just-checked .cbc-habit-ring-touch{animation:none}.cbc-habit-glow-orb{animation:celebFadeOnly .3s ease-out both}}@keyframes celebFadeOnly{0%{opacity:0}to{opacity:1}}@media(min-width:400px){.cbc-progress-ring{width:180px;height:180px}.cbc-ring-count{font-size:2rem}.cbc-habit-ring-touch,.cbc-add-ring,.cbc-unlock-ring{width:110px;height:110px}.cbc-habits-grid{gap:16px}.cbc-weekly-header,.cbc-weekly-row{grid-template-columns:1fr repeat(7,32px)}.cbc-weekly-dot{width:14px;height:14px}.cbc-celeb-logo-frame{width:140px;height:140px}.cbc-celeb-heading{font-size:1.6rem}}@media(min-width:500px){.cbc-main{padding:0 24px calc(80px + var(--safe-area-bottom))}}.cbc-premium-card{display:flex;align-items:center;gap:12px;width:100%;margin-top:16px;padding:16px;background:var(--bg-card);border:1px dashed var(--border-color);border-radius:14px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:border-color .2s;color:var(--text-tertiary)}.cbc-premium-card:active{border-color:var(--color-primary)}.cbc-premium-card>svg:first-child{flex-shrink:0;color:var(--color-primary)}.cbc-premium-card>svg:last-child{flex-shrink:0;color:var(--text-tertiary)}.cbc-premium-card-text{flex:1;display:flex;flex-direction:column;gap:2px;text-align:left}.cbc-premium-card-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.85rem;color:var(--text-primary)}.cbc-premium-card-desc{font-family:Inter,sans-serif;font-size:.75rem;color:var(--text-tertiary);line-height:1.3}[data-theme=dark] .cbc-premium-card{background:#1e1e1ecc;border-color:#ffffff14}.bdy-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-body)}.bdy-spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.bdy-page{min-height:100vh;background:var(--bg-body);padding-bottom:calc(80px + var(--safe-area-bottom))}.bdy-main{max-width:600px;margin:0 auto;padding:0 16px calc(80px + var(--safe-area-bottom))}.bdy-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.3rem;color:var(--text-primary);margin:16px 0 12px;text-align:center}.bdy-leaderboard-link{display:flex;align-items:center;justify-content:center;gap:6px;margin:0 auto 14px;padding:0;background:none;border:none;color:var(--color-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:opacity .2s;-webkit-tap-highlight-color:transparent}.bdy-leaderboard-link:active{opacity:.7}.bdy-tabs{display:flex;gap:6px;padding:0 0 16px}.bdy-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 8px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-card);color:var(--text-tertiary);font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent;position:relative}.bdy-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--text-on-primary)}.bdy-tab:active{transform:scale(.97)}.bdy-tab-badge{position:absolute;top:-4px;right:-4px;background:var(--color-error);color:#fff;font-size:.6rem;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.bdy-section-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-tertiary);margin:4px 0 10px;padding-left:4px}.bdy-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.bdy-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-glow)}.bdy-card:active{transform:scale(.98)}.bdy-avatar{width:44px;height:44px;border-radius:50%;border:2px solid var(--border-color);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg-card-elevated);flex-shrink:0;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.85rem;color:var(--text-secondary)}.bdy-avatar img{width:100%;height:100%;object-fit:cover}.bdy-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.bdy-card-name{font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bdy-card-sub{font-family:Inter,sans-serif;font-size:.75rem;color:var(--text-tertiary)}.bdy-card-badge{font-family:Plus Jakarta Sans,sans-serif;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-success);background:#4caf501f;padding:2px 8px;border-radius:6px;width:fit-content}.bdy-add-btn,.bdy-accept-btn,.bdy-decline-btn,.bdy-view-btn{width:36px;height:36px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:transform .15s;-webkit-tap-highlight-color:transparent}.bdy-add-btn{background:var(--color-primary);color:var(--text-on-primary)}.bdy-accept-btn{background:var(--color-success);color:var(--text-on-primary)}.bdy-decline-btn{background:#f443361a;color:var(--color-error)}.bdy-view-btn{background:var(--color-primary-light);color:var(--color-primary)}.bdy-add-btn:active,.bdy-accept-btn:active,.bdy-decline-btn:active,.bdy-view-btn:active{transform:scale(.9)}.bdy-add-btn:disabled,.bdy-accept-btn:disabled,.bdy-decline-btn:disabled,.bdy-view-btn:disabled{opacity:.5;cursor:not-allowed}.bdy-action-pair{display:flex;gap:8px;flex-shrink:0}.bdy-cancel-btn{padding:6px 14px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:600;cursor:pointer;flex-shrink:0;transition:transform .15s;-webkit-tap-highlight-color:transparent}.bdy-cancel-btn:active{transform:scale(.95)}.bdy-cancel-btn:disabled{opacity:.5;cursor:not-allowed}.bdy-pending-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:600;color:var(--text-tertiary);padding:6px 12px;border-radius:8px;background:var(--bg-card-elevated);flex-shrink:0}.bdy-status-icon{flex-shrink:0;display:flex;align-items:center}.bdy-btn-spinner{width:16px;height:16px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .6s linear infinite;opacity:.7}.bdy-search-bar{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;margin-bottom:16px;color:var(--text-tertiary)}.bdy-search-bar input{flex:1;border:none;background:transparent;font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-primary);outline:none}.bdy-search-bar input::placeholder{color:var(--text-tertiary)}.bdy-search-clear{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px;display:flex;align-items:center}.bdy-empty{text-align:center;padding:48px 20px;color:var(--text-tertiary)}.bdy-empty svg{opacity:.4;margin-bottom:12px}.bdy-empty h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;color:var(--text-primary);margin:0 0 6px}.bdy-empty p{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-tertiary);margin:0}.bdy-empty-sm{padding:24px 20px}.bdy-empty-btn{margin-top:16px;padding:12px 28px;border:none;border-radius:12px;background:var(--color-primary);color:var(--text-on-primary);font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.85rem;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent}.bdy-empty-btn:active{transform:scale(.97)}.bdy-content-loading{display:flex;align-items:center;justify-content:center;padding:80px 0}.bdy-page .toast-notification{position:fixed;bottom:80px;left:50%;transform:translate(-50%);padding:12px 24px;border-radius:12px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;color:#fff;z-index:1100;display:flex;align-items:center;gap:8px;box-shadow:0 8px 24px #0003;white-space:nowrap}.bdy-page .toast-notification.success{background:var(--color-success)}.bdy-page .toast-notification.error{background:var(--color-error)}.bdy-page .toast-notification.info{background:var(--color-info)}.bdy-page .toast-icon{width:18px;height:18px;display:flex;align-items:center;flex-shrink:0}.bdy-page .toast-icon svg{width:100%;height:100%}@media(min-width:400px){.bdy-tab{font-size:.8rem;padding:12px 10px}.bdy-avatar{width:48px;height:48px}}.bdy-feed-toggle{display:flex;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:3px;margin-bottom:14px}.bdy-feed-toggle-btn{flex:1;padding:8px 12px;border:none;border-radius:10px;background:transparent;color:var(--text-tertiary);font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.bdy-feed-toggle-btn.active{background:var(--color-primary);color:var(--text-on-primary);box-shadow:0 2px 8px #00000026}.bdy-feed-toggle-btn:not(.active):hover{color:var(--text-secondary)}.bdy-announcement-post{border-left:3px solid var(--color-primary)}.bdy-announcement-avatar{border-color:var(--color-primary)!important;background:#fff!important}.bdy-announcement-badge{font-family:Plus Jakarta Sans,sans-serif;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--color-primary);background:rgba(var(--color-primary-rgb),.1);padding:3px 8px;border-radius:6px;flex-shrink:0}.bdy-announcement-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:700;color:var(--text-primary);margin:0 0 6px}[data-theme=dark] .bdy-feed-toggle{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.bdy-feed-list{display:flex;flex-direction:column;gap:14px}.bdy-feed-post{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:16px;box-shadow:var(--shadow-glow)}.bdy-feed-post-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.bdy-feed-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;background:rgba(var(--color-primary-rgb),.12);display:flex;align-items:center;justify-content:center;border:2px solid rgba(var(--color-primary-rgb),.2);cursor:pointer}.bdy-feed-avatar img{width:100%;height:100%;object-fit:cover}.bdy-feed-avatar span{font-family:Inter,sans-serif;font-size:.6rem;font-weight:700;color:var(--color-primary)}.bdy-feed-meta{flex:1;display:flex;flex-direction:column;gap:1px;cursor:pointer}.bdy-feed-name{font-family:Inter,sans-serif;font-size:.85rem;font-weight:700;color:var(--text-primary)}.bdy-feed-time{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-tertiary)}.bdy-feed-delete-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s,background .2s;-webkit-tap-highlight-color:transparent;flex-shrink:0}.bdy-feed-delete-btn:active{background:#ef44441a;color:#ef4444}.bdy-feed-content{font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-primary);line-height:1.5;margin:0 0 10px;white-space:pre-wrap;word-break:break-word}.bdy-feed-image{border-radius:12px;overflow:hidden;margin-bottom:10px}.bdy-feed-image img{width:100%;display:block;border-radius:12px}.bdy-feed-card{border-radius:14px;padding:20px 16px 14px;margin-bottom:10px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 4px #0000000f;display:flex;flex-direction:column;align-items:center;text-align:center}.bdy-feed-card-logo{width:72px;height:72px;border-radius:50%;overflow:hidden;border:2px solid rgba(var(--color-primary-rgb),.25);margin-bottom:12px;flex-shrink:0;background:#fff}.bdy-feed-card-logo img{width:100%;height:100%;object-fit:cover;display:block}.bdy-feed-card-badge{border-color:#ffc10766}.bdy-feed-card-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:700;color:var(--text-primary);margin:0 0 4px;text-transform:uppercase;letter-spacing:.3px}.bdy-feed-card-stats{font-family:Inter,sans-serif;font-size:.74rem;font-weight:500;color:var(--text-secondary);margin:0}.bdy-feed-card-cta{font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;color:var(--text-primary);margin:10px 0 0;line-height:1.35}.bdy-feed-actions{display:flex;align-items:center;gap:4px;padding-top:8px;border-top:1px solid rgba(150,150,150,.12)}.bdy-feed-action-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border:none;border-radius:10px;background:transparent;color:var(--text-tertiary);font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;cursor:pointer;transition:color .2s,background .15s;-webkit-tap-highlight-color:transparent}.bdy-feed-action-btn:active{background:#9696961a}.bdy-feed-action-btn.liked{color:#ef4444}.bdy-feed-action-btn.active{color:var(--color-primary)}.bdy-feed-comments{margin-top:12px;padding-top:10px;border-top:1px solid rgba(150,150,150,.1);display:flex;flex-direction:column;gap:10px;animation:bdyFeedFadeIn .2s ease-out}@keyframes bdyFeedFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.bdy-feed-comment{display:flex;gap:8px;align-items:flex-start}.bdy-feed-comment-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden;flex-shrink:0;background:rgba(var(--color-primary-rgb),.1);display:flex;align-items:center;justify-content:center}.bdy-feed-comment-avatar img{width:100%;height:100%;object-fit:cover}.bdy-feed-comment-avatar span{font-family:Inter,sans-serif;font-size:.5rem;font-weight:700;color:var(--color-primary)}.bdy-feed-comment-body{flex:1;min-width:0}.bdy-feed-comment-bubble{display:inline-flex;flex-direction:column;gap:2px;background:#96969614;border-radius:12px;padding:8px 12px}.bdy-feed-comment-name{font-family:Inter,sans-serif;font-size:.72rem;font-weight:700;color:var(--text-primary)}.bdy-feed-comment-text{font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-secondary);line-height:1.4;word-break:break-word}.bdy-feed-comment-time{font-family:Inter,sans-serif;font-size:.62rem;color:var(--text-tertiary)}.bdy-feed-no-comments{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-tertiary);text-align:center;margin:4px 0}.bdy-feed-comment-img{max-width:200px;max-height:150px;border-radius:8px;margin-top:6px;object-fit:cover}.bdy-feed-comment-row{display:flex;align-items:center;gap:10px;margin-left:12px;margin-top:2px}.bdy-feed-comment-reply-btn{background:none;border:none;padding:0;font-family:Inter,sans-serif;font-size:.62rem;font-weight:600;color:var(--text-tertiary);cursor:pointer;-webkit-tap-highlight-color:transparent}.bdy-feed-comment-reply-btn:hover{color:var(--color-primary)}.bdy-feed-comment-del-btn{background:none;border:none;padding:2px 0;cursor:pointer;color:var(--text-tertiary);display:flex;align-items:center;gap:3px;opacity:.7;font-family:Inter,sans-serif;font-size:.72rem;transition:opacity .15s,color .15s;-webkit-tap-highlight-color:transparent}.bdy-feed-comment:hover .bdy-feed-comment-del-btn{opacity:1}.bdy-feed-comment-del-btn:hover,.bdy-feed-comment-del-btn:active{color:#e74c3c;opacity:1}.bdy-feed-comment-reply-tag{display:inline-flex;align-items:center;gap:3px;font-family:Inter,sans-serif;font-size:.68rem;color:var(--color-primary);margin-bottom:1px}.bdy-feed-replying{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;border-radius:10px;background:rgba(var(--color-primary-rgb),.08);font-family:Inter,sans-serif;font-size:.72rem;color:var(--text-secondary)}.bdy-feed-replying button{background:none;border:none;cursor:pointer;color:var(--text-tertiary);display:flex;align-items:center;padding:2px;-webkit-tap-highlight-color:transparent}.bdy-feed-comment-img-preview{position:relative;display:inline-block}.bdy-feed-comment-img-preview img{max-width:120px;max-height:80px;border-radius:8px;object-fit:cover}.bdy-feed-comment-img-preview button{position:absolute;top:-4px;right:-4px;width:20px;height:20px;border-radius:50%;background:#0009;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}.bdy-feed-comment-input{display:flex;align-items:center;gap:8px;margin-top:4px}.bdy-feed-comment-img-btn{background:none;border:none;padding:0;cursor:pointer;color:var(--text-tertiary);display:flex;align-items:center;flex-shrink:0;transition:color .15s;-webkit-tap-highlight-color:transparent}.bdy-feed-comment-img-btn:hover{color:var(--color-primary)}.bdy-feed-comment-input input{flex:1;border:1px solid rgba(150,150,150,.2);border-radius:22px;padding:10px 16px;font-family:Inter,sans-serif;font-size:.88rem;color:var(--text-primary);background:transparent;outline:none;transition:border-color .2s}.bdy-feed-comment-input input:focus{border-color:rgba(var(--color-primary-rgb),.4)}.bdy-feed-comment-input input::placeholder{color:var(--text-tertiary)}.bdy-feed-comment-input button:last-child{background:none;border:none;cursor:pointer;display:flex;align-items:center;padding:4px;flex-shrink:0;-webkit-tap-highlight-color:transparent}.bdy-feed-comment-input button:last-child:disabled{opacity:.4;cursor:not-allowed}.bdy-feed-mention-dropdown{position:absolute;left:0;right:0;bottom:100%;margin-bottom:6px;background:var(--bg-card, #1a1a2e);border:1px solid var(--border-color, #2a2a3e);border-radius:12px;box-shadow:0 4px 20px #00000059;z-index:50;overflow:hidden;max-height:200px;overflow-y:auto}.bdy-feed-mention-option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;border-bottom:1px solid rgba(150,150,150,.1);color:var(--text-primary, #fff);font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;cursor:pointer;text-align:left;transition:background .15s}.bdy-feed-mention-option:last-child{border-bottom:none}.bdy-feed-mention-option:hover,.bdy-feed-mention-option:active{background:rgba(var(--color-primary-rgb),.1)}.bdy-feed-mention-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden;flex-shrink:0;background:rgba(var(--color-primary-rgb),.15);display:flex;align-items:center;justify-content:center}.bdy-feed-mention-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.bdy-feed-mention-avatar span{font-size:.65rem;font-weight:700;color:var(--color-primary)}.bdy-page .mention-highlight{color:var(--color-primary);font-weight:600}[data-theme=dark] .bdy-feed-post{background:#1e1e1ecc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-color:#ffffff0f;box-shadow:0 1px 3px #0003,0 4px 12px #00000026}[data-theme=dark] .bdy-feed-card{background:#1e1e1ed9;border-color:#ffffff0f;box-shadow:0 2px 8px #0000004d}[data-theme=dark] .bdy-feed-card-logo{border-color:rgba(var(--color-primary-rgb),.4)}[data-theme=dark] .bdy-feed-comment-bubble{background:#ffffff0f}[data-theme=dark] .bdy-feed-mention-dropdown{background:#1e1e1efa;border-color:#ffffff1a}[data-theme=light] .bdy-feed-mention-dropdown{background:#fff;border-color:#e0e0e0;box-shadow:0 4px 20px #0000001f}[data-theme=light] .bdy-feed-mention-option:hover,[data-theme=light] .bdy-feed-mention-option:active{background:#0000000a}[data-theme=dark] .bdy-tab{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .bdy-tab.active{background:var(--color-primary);border-color:var(--color-primary)}[data-theme=dark] .bdy-card{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .bdy-search-bar{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.bdy-fab{position:fixed;bottom:calc(64px + var(--safe-area-bottom));right:max(18px,env(safe-area-inset-right,0px));width:54px;height:54px;border-radius:50%;border:2px solid rgba(255,255,255,.35);background:var(--color-primary);color:var(--text-on-primary, #fff);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #00000059,0 0 0 3px rgba(var(--color-primary-rgb, 184, 49, 61),.3);cursor:pointer;z-index:1000;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s ease,opacity .3s ease}.bdy-fab:active{transform:scale(.92)}.bdy-fab.bdy-fab-hidden{opacity:0;pointer-events:none;transform:scale(.5)}.bdy-fab svg{transition:transform .3s cubic-bezier(.4,0,.2,1)}.bdy-fab.bdy-fab-open{box-shadow:0 6px 20px #0006}.bdy-fab-overlay{position:fixed;inset:0;z-index:999;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;animation:bdyFabOverlayIn .2s ease}@keyframes bdyFabOverlayIn{0%{opacity:0}to{opacity:1}}.bdy-fab-sheet{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:480px;padding:20px 20px 32px;padding-bottom:calc(32px + var(--safe-area-bottom));animation:bdyFabSheetIn .3s ease;border:1px solid var(--border-color);border-bottom:none;box-shadow:0 -8px 32px #0000004d}@keyframes bdyFabSheetIn{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bdy-fab-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.bdy-fab-header h3{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin:0;flex:1;text-align:center}.bdy-fab-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.bdy-fab-close:hover{background:var(--bg-hover)}.bdy-fab-header:before{content:"";width:32px}.bdy-fab-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.bdy-fab-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border-radius:14px;border:1.5px solid rgba(var(--color-primary-rgb, 184, 49, 61),.2);background:rgba(var(--color-primary-rgb, 184, 49, 61),.06);cursor:pointer;transition:all .2s}.bdy-fab-item:hover,.bdy-fab-item:active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 184, 49, 61),.12)}.bdy-fab-item:active{transform:scale(.95)}.bdy-fab-item-icon{width:44px;height:44px;border-radius:50%;background:rgba(var(--color-primary-rgb, 184, 49, 61),.08);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.bdy-fab-item-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:500;color:var(--text-primary);text-align:center;line-height:1.2}.bdy-fab-item:nth-child(1){animation:bdyFabItemIn .3s .03s both}.bdy-fab-item:nth-child(2){animation:bdyFabItemIn .3s .06s both}@keyframes bdyFabItemIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(min-width:481px){.bdy-fab-overlay{align-items:center}.bdy-fab-sheet{border-radius:20px;border-bottom:1px solid var(--border-color);max-height:80vh}}.bdy-free-limit-msg{text-align:center;font-size:.82rem;color:var(--text-secondary);margin:0 0 12px;line-height:1.4;padding:10px 16px;background:var(--bg-card);border-radius:10px;border:1px solid var(--border-color)}.bdy-upgrade-link{color:var(--color-primary);font-weight:600;cursor:pointer}[data-theme=dark] .bdy-fab-sheet{background:#1e1e1e}.prf-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-body)}.prf-spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.prf-page{min-height:100vh;background:var(--bg-body);padding-bottom:calc(80px + var(--safe-area-bottom))}.prf-main{max-width:600px;margin:0 auto;padding:0 16px calc(80px + var(--safe-area-bottom))}.prf-hero{position:relative;display:flex;flex-direction:column;align-items:center;padding:24px 0 20px}.prf-avatar-lg{width:96px;height:96px;border-radius:50%;border:none;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg-card-elevated);font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.8rem;color:var(--text-secondary);margin-bottom:12px;box-shadow:0 4px 16px #0003}.prf-avatar-lg.tappable{cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s}.prf-avatar-lg.tappable:active{transform:scale(.94)}.prf-avatar-lg img{width:100%;height:100%;object-fit:cover}.prf-name{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.2rem;color:var(--text-primary);margin:0 0 4px;text-align:center}.prf-you-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-primary);background:var(--color-primary-light);padding:3px 10px;border-radius:6px}.prf-buddy-action{margin-top:14px}.prf-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 24px;border-radius:12px;border:none;font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.85rem;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent}.prf-btn:active{transform:scale(.97)}.prf-btn:disabled{opacity:.5;cursor:not-allowed}.prf-btn-primary{background:var(--color-primary);color:var(--text-on-primary, #fff)}.prf-btn-success{background:var(--color-success);color:#fff}.prf-btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color)}.prf-btn-danger{background:#f443361a;color:var(--color-error);border:1px solid rgba(244,67,54,.2)}.prf-btn-pair{display:flex;gap:10px}.prf-btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.prf-btn-spinner.dark{border-color:#00000026;border-top-color:var(--text-secondary)}.prf-stats{display:flex;gap:8px;margin-bottom:24px}.prf-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:18px 8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px}.prf-stat-value{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.15rem;color:var(--text-primary)}.prf-stats .prf-stat:nth-child(1){border-top:3px solid var(--color-primary)}.prf-stats .prf-stat:nth-child(2){border-top:3px solid var(--color-primary)}.prf-stats .prf-stat:nth-child(3){border-top:3px solid var(--color-primary)}.prf-stat-unit{font-size:.7rem;color:var(--text-tertiary);margin-left:2px}.prf-stat-label{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-tertiary);margin-top:4px}.prf-section{margin-bottom:24px}.prf-section-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.85rem;color:var(--text-primary);margin:0 0 12px;padding-left:4px}.prf-badges{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:10px}.prf-badge{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 4px 10px;border-radius:14px;background:var(--bg-card);border:1px solid var(--border-color)}.prf-badge.locked{opacity:.35}.prf-badge.unlocked{border-color:rgba(var(--color-primary-rgb, 161, 47, 58),.25)}.prf-badge-icon{display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.prf-badge.locked .prf-badge-icon{color:var(--text-tertiary)}.prf-badge-icon svg{width:24px;height:24px}.prf-badge-name{font-family:Inter,sans-serif;font-size:.6rem;font-weight:600;color:var(--text-secondary);text-align:center;line-height:1.1}.prf-badges-count{font-family:Inter,sans-serif;font-size:.75rem;color:var(--text-tertiary);text-align:center;margin:10px 0 0}.prf-stats-loading{display:flex;align-items:center;justify-content:center;padding:24px 0}.prf-info-row{display:flex;gap:8px;margin-bottom:16px}.prf-info-card{flex:1;display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px}.prf-info-icon{width:34px;height:34px;border-radius:10px;background:rgba(var(--color-primary-rgb, 161, 47, 58),.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-primary)}.prf-info-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.prf-info-label{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.72rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.prf-info-value{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.9rem;color:var(--text-primary)}.prf-info-sub{font-family:Inter,sans-serif;font-size:.65rem;color:var(--text-tertiary)}.prf-info-progress-bar{width:100%;height:4px;background:#96969626;border-radius:2px;overflow:hidden}.prf-info-progress-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .6s ease}.prf-info-card.info-habit .prf-info-icon{background:rgba(var(--color-primary-rgb, 161, 47, 58),.1);color:var(--color-primary)}[data-theme=dark] .prf-info-card{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.prf-pb-list{display:flex;flex-direction:column;gap:6px}.prf-pb-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px}.prf-pb-rank{width:24px;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.7rem;color:#f9a825;text-align:center;flex-shrink:0}.prf-pb-name{flex:1;font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.8rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.prf-pb-weight{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.82rem;color:var(--text-primary);flex-shrink:0}.prf-pb-unit{font-size:.65rem;color:var(--text-tertiary);margin-left:1px;margin-right:2px}[data-theme=dark] .prf-pb-item{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.prf-badge-row{display:flex;flex-wrap:wrap;gap:6px}.prf-badge-chip{display:inline-flex;flex-direction:column;align-items:center;gap:4px;padding:8px;background:var(--bg-card);border:1px solid rgba(var(--color-primary-rgb, 161, 47, 58),.2);border-radius:14px}.prf-badge-chip{cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s}.prf-badge-chip:active{transform:scale(.92)}.prf-badge-chip-img{width:40px;height:40px;object-fit:contain;flex-shrink:0}.prf-badge-chip span{font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.6rem;white-space:nowrap;color:var(--text-secondary)}[data-theme=dark] .prf-badge-chip{background:#1e1e1ecc;border-color:#ffffff14}.prf-badge-overlay{position:fixed;inset:0;z-index:9999;background:#000000d9;display:flex;align-items:center;justify-content:center;animation:prf-overlay-in .2s ease}@keyframes prf-overlay-in{0%{opacity:0}to{opacity:1}}.prf-badge-overlay-content{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 24px;animation:prf-overlay-scale .25s ease}@keyframes prf-overlay-scale{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.prf-badge-overlay-img{width:200px;height:200px;object-fit:contain}.prf-badge-overlay-desc{font-family:Inter,sans-serif;font-size:1rem;color:#fffc;text-align:center;margin:0}.prf-badge-overlay-close{background:none;border:none;font-family:Inter,sans-serif;font-size:.8rem;color:#fff6;cursor:pointer;padding:8px 16px;margin-top:8px}.prf-photo-overlay{position:fixed;inset:0;z-index:9999;background:#000000d9;display:flex;align-items:center;justify-content:center;padding:24px;animation:prf-overlay-in .2s ease;cursor:pointer;-webkit-tap-highlight-color:transparent}.prf-photo-overlay-img{width:75vw;height:75vw;max-width:360px;max-height:360px;border-radius:50%;object-fit:cover;animation:prf-overlay-scale .25s ease;box-shadow:0 8px 40px #0006}.prf-manage-wrap{position:absolute;top:18px;right:4px}.prf-manage-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s;-webkit-tap-highlight-color:transparent}.prf-manage-btn:active{background:#9696961f;color:var(--text-secondary)}.prf-buddy-label{display:inline-flex;align-items:center;gap:5px;font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.75rem;color:var(--color-success);padding:6px 14px;border-radius:20px;background:#2e7d3214;border:1px solid rgba(46,125,50,.15)}[data-theme=dark] .prf-buddy-label{background:#2e7d321f;border-color:#2e7d3233}.prf-private{display:flex;flex-direction:column;align-items:center;text-align:center;padding:40px 24px;margin:16px 0;border-radius:16px;background:#9696960d;border:1px solid rgba(150,150,150,.1)}.prf-private-icon{width:56px;height:56px;border-radius:50%;background:#96969614;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);margin-bottom:14px}.prf-private-title{font-family:Inter,sans-serif;font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 6px}.prf-private-text{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-tertiary);margin:0;max-width:260px;line-height:1.4}.prf-badges-section{margin-bottom:20px}.prf-badges-tally{font-family:Inter,sans-serif;font-size:.7rem;font-weight:500;color:var(--text-tertiary);margin-left:6px}.prf-badges-carousel{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.prf-badges-carousel::-webkit-scrollbar{display:none}.prf-carousel-badge{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0;scroll-snap-align:start;background:var(--bg-card);border:1px solid rgba(255,193,7,.25);border-radius:14px;padding:10px 10px 8px;width:80px;cursor:pointer;transition:transform .15s,box-shadow .2s;-webkit-tap-highlight-color:transparent;box-shadow:0 1px 3px #0000000f}.prf-carousel-badge:active{transform:scale(.94)}[data-theme=dark] .prf-carousel-badge{background:#1e1e1ecc;border-color:#ffc10733;box-shadow:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.prf-carousel-badge-img{width:52px;height:52px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,193,7,.3)}.prf-carousel-badge-name{font-family:Plus Jakarta Sans,sans-serif;font-size:.58rem;font-weight:600;color:var(--text-secondary);text-align:center;line-height:1.15;max-width:100%;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.prf-badge-overlay-name{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1rem;color:#fff;margin:0;text-align:center}.prf-confirm-overlay{position:fixed;inset:0;z-index:9999;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:24px;animation:prf-overlay-in .2s ease}.prf-confirm-card{background:var(--bg-card);border-radius:20px;padding:28px 24px 20px;max-width:300px;width:100%;text-align:center;animation:prf-overlay-scale .25s ease;box-shadow:0 8px 32px #0003}[data-theme=dark] .prf-confirm-card{background:var(--bg-card-elevated);border:1px solid rgba(255,255,255,.08)}[data-mono=true][data-theme=light] .prf-confirm-card{background:#f5f5f5}[data-mono=true][data-theme=dark] .prf-confirm-card{background:#1a1a1f}.prf-confirm-icon{width:48px;height:48px;border-radius:50%;background:#96969614;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:var(--text-tertiary)}.prf-confirm-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.95rem;color:var(--text-primary);margin:0 0 8px}.prf-confirm-text{font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-secondary);line-height:1.4;margin:0 0 20px}.prf-confirm-actions{display:flex;gap:10px}.prf-confirm-btn{flex:1;padding:10px 16px;border-radius:12px;border:none;font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.82rem;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent}.prf-confirm-btn:active{transform:scale(.97)}.prf-confirm-cancel{background:var(--bg-body);color:var(--text-secondary);border:1px solid var(--border-color)}.prf-confirm-remove{background:#9696961a;color:var(--text-secondary)}.prf-confirm-remove:disabled{opacity:.5}.prf-page .toast-notification{position:fixed;bottom:90px;left:50%;transform:translate(-50%);padding:12px 20px;border-radius:12px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;color:#fff;z-index:1100;display:flex;align-items:center;gap:8px;box-shadow:0 8px 24px #0003;max-width:calc(100vw - 32px);word-break:break-word}.prf-page .toast-notification.success{background:var(--color-success)}.prf-page .toast-notification.error{background:var(--color-error)}.prf-page .toast-notification.info{background:var(--color-info)}.prf-page .toast-icon{width:18px;height:18px;display:flex;align-items:center;flex-shrink:0}.prf-page .toast-icon svg{width:100%;height:100%}@media(min-width:400px){.prf-avatar-lg{width:110px;height:110px;font-size:2rem}.prf-stat-value{font-size:1.25rem}.prf-badges{grid-template-columns:repeat(auto-fill,minmax(72px,1fr))}}[data-theme=dark] .prf-stat{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);box-shadow:0 1px 3px #0003,0 4px 12px #00000026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .prf-badge{background:#1e1e1ecc;border:1px solid rgba(255,255,255,.06);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.journey-compose{display:flex;gap:12px;padding:14px 16px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;margin-bottom:16px;box-shadow:var(--shadow-glow)}[data-theme=dark] .journey-compose{background:#1e1e1ecc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-color:#ffffff0f;box-shadow:0 1px 3px #0003,0 4px 12px #00000026}.journey-compose-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;background:rgba(var(--color-primary-rgb, 161, 47, 58),.12);display:flex;align-items:center;justify-content:center;border:2px solid rgba(var(--color-primary-rgb, 161, 47, 58),.25)}.journey-compose-avatar img{width:100%;height:100%;object-fit:cover}.journey-compose-avatar span{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:700;color:var(--color-primary)}.journey-compose-body{flex:1;display:flex;flex-direction:column;gap:8px}.journey-compose-body textarea{width:100%;border:none;background:transparent;color:var(--text-primary);font-family:Inter,sans-serif;font-size:.9rem;resize:none;outline:none;padding:8px 0;min-height:36px;max-height:120px;line-height:1.4}.journey-compose-body textarea::placeholder{color:var(--text-tertiary)}.journey-image-preview{position:relative;border-radius:12px;overflow:hidden;max-height:240px}.journey-image-preview img{width:100%;max-height:240px;object-fit:cover;border-radius:12px;display:block}.journey-image-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;border:none;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}.journey-compose-actions{display:flex;align-items:center;justify-content:space-between}.journey-image-btn{width:36px;height:36px;border-radius:10px;border:none;background:transparent;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s,background .15s;-webkit-tap-highlight-color:transparent}.journey-image-btn:active{background:#9696961a;color:var(--color-primary)}.journey-post-btn{padding:8px 20px;border-radius:20px;border:none;background:var(--color-primary);color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.8rem;cursor:pointer;transition:opacity .2s,transform .15s;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;min-width:70px}.journey-post-btn:active{transform:scale(.95)}.journey-post-btn:disabled{opacity:.5;cursor:default}.journey-btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.journey-btn-spinner-sm{width:14px;height:14px;border:2px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}.journey-loading{display:flex;align-items:center;justify-content:center;padding:40px 0}.journey-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px 20px;text-align:center;color:var(--text-tertiary)}.journey-empty p{font-family:Inter,sans-serif;font-size:.85rem;margin:0}.journey-list{display:flex;flex-direction:column;gap:16px}.journey-post{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:16px;box-shadow:var(--shadow-glow)}[data-theme=dark] .journey-post{background:#1e1e1ecc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-color:#ffffff0f;box-shadow:0 1px 3px #0003,0 4px 12px #00000026}.journey-post-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.journey-post-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;background:rgba(var(--color-primary-rgb, 161, 47, 58),.12);display:flex;align-items:center;justify-content:center;border:2px solid rgba(var(--color-primary-rgb, 161, 47, 58),.2)}.journey-post-avatar img{width:100%;height:100%;object-fit:cover}.journey-post-avatar span{font-family:Plus Jakarta Sans,sans-serif;font-size:.6rem;font-weight:700;color:var(--color-primary)}.journey-post-meta{flex:1;display:flex;flex-direction:column;gap:1px}.journey-post-name{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:700;color:var(--text-primary)}.journey-post-time{font-family:Inter,sans-serif;font-size:.7rem;color:var(--text-tertiary)}.journey-delete-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s,background .2s;-webkit-tap-highlight-color:transparent;flex-shrink:0}.journey-delete-btn:active{background:#ef44441a;color:#ef4444}.journey-post-content{font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-primary);line-height:1.5;margin:0 0 10px;white-space:pre-wrap;word-break:break-word}.journey-post-image{border-radius:12px;overflow:hidden;margin-bottom:10px}.journey-post-image img{width:100%;display:block;border-radius:12px}.journey-post-actions{display:flex;align-items:center;gap:4px;padding-top:8px;border-top:1px solid rgba(150,150,150,.12)}.journey-action-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border:none;border-radius:10px;background:transparent;color:var(--text-tertiary);font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;cursor:pointer;transition:color .2s,background .15s;-webkit-tap-highlight-color:transparent}.journey-action-btn:active{background:#9696961a}.journey-action-btn.liked{color:#ef4444}.journey-action-btn.active{color:var(--color-primary)}.journey-comments{margin-top:12px;padding-top:10px;border-top:1px solid rgba(150,150,150,.1);display:flex;flex-direction:column;gap:10px;animation:journeyFadeIn .2s ease-out}@keyframes journeyFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.journey-comment{display:flex;gap:8px;align-items:flex-start}.journey-comment-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden;flex-shrink:0;background:rgba(var(--color-primary-rgb, 161, 47, 58),.1);display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}.journey-comment-avatar img{width:100%;height:100%;object-fit:cover}.journey-comment-avatar span{font-family:Plus Jakarta Sans,sans-serif;font-size:.5rem;font-weight:700;color:var(--color-primary)}.journey-comment-body{flex:1;min-width:0}.journey-comment-bubble{display:inline-flex;flex-direction:column;gap:2px;background:#96969614;border-radius:12px;padding:8px 12px}[data-theme=dark] .journey-comment-bubble{background:#ffffff0f}.journey-comment-name{font-family:Plus Jakarta Sans,sans-serif;font-size:.72rem;font-weight:700;color:var(--text-primary)}.journey-comment-text{font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-secondary);line-height:1.4;word-break:break-word}.journey-comment-time{font-family:Inter,sans-serif;font-size:.62rem;color:var(--text-tertiary);margin-left:12px;margin-top:2px}.journey-no-comments{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-tertiary);text-align:center;margin:4px 0}.journey-comment-input{display:flex;align-items:center;gap:8px;margin-top:4px}.journey-comment-input input{flex:1;border:1px solid rgba(150,150,150,.2);border-radius:20px;padding:8px 14px;font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-primary);background:transparent;outline:none;transition:border-color .2s}.journey-comment-input input:focus{border-color:rgba(var(--color-primary-rgb, 161, 47, 58),.4)}.journey-comment-input input::placeholder{color:var(--text-tertiary)}.journey-comment-input button{width:32px;height:32px;border-radius:50%;border:none;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:opacity .2s,transform .15s;-webkit-tap-highlight-color:transparent}.journey-comment-input button:active{transform:scale(.9)}.journey-comment-input button:disabled{opacity:.4;cursor:default}@media(min-width:400px){.journey-compose{padding:16px 18px}.journey-post{padding:18px}}.journey-card{border-radius:14px;padding:20px 16px 14px;margin-bottom:10px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 4px #0000000f;display:flex;flex-direction:column;align-items:center;text-align:center}[data-theme=dark] .journey-card{background:#1e1e1ed9;border-color:#ffffff0f;box-shadow:0 2px 8px #0000004d}.journey-card-logo-frame{width:72px;height:72px;border-radius:50%;overflow:hidden;border:2px solid rgba(var(--color-primary-rgb),.25);margin-bottom:12px;flex-shrink:0;background:#fff}[data-theme=dark] .journey-card-logo-frame{border-color:rgba(var(--color-primary-rgb),.4)}.journey-card-logo-badge{border-color:#ffc10766}.journey-card-logo-img{width:100%;height:100%;object-fit:cover;display:block}.journey-card-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:700;color:var(--text-primary);margin:0 0 4px;text-transform:uppercase;letter-spacing:.3px}.journey-card-stats-line{font-family:Inter,sans-serif;font-size:.74rem;font-weight:500;color:var(--text-secondary);margin:0}.journey-card-cta{font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;color:var(--text-primary);margin:10px 0 0;line-height:1.35}.journey-card-slogan{font-family:Inter,sans-serif;font-size:.62rem;font-weight:600;color:var(--color-primary);margin:10px 0 0;letter-spacing:.2px}.bldr-page{min-height:100vh;background:var(--bg-body)}.bldr-container{max-width:600px;margin:0 auto;padding:0 16px 120px}.bldr-header{display:flex;align-items:center;gap:10px;padding:14px 0}.bldr-back{background:none;border:none;color:var(--text-secondary);padding:8px;cursor:pointer;border-radius:10px;display:flex;align-items:center}.bldr-back:hover{background:var(--bg-hover)}.bldr-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.bldr-ring-container{display:flex;flex-direction:column;align-items:center;padding:20px 0 12px}.bldr-ring{position:relative;width:260px;height:260px;display:flex;align-items:center;justify-content:center}.bldr-ring-svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:scaleX(-1)}.bldr-tick.remaining{stroke:var(--color-primary)}.bldr-tick.elapsed{stroke:#fff}[data-theme=light] .bldr-tick.elapsed{stroke:#2d2d2d}.bldr-ring-center{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;width:130px;height:130px}.bldr-ring-photo{position:relative;width:120px;height:120px;border-radius:50%;overflow:hidden;border:3px solid var(--color-primary);box-shadow:0 4px 16px #00000059;cursor:pointer;-webkit-tap-highlight-color:transparent}.bldr-ring-photo img{width:100%;height:100%;object-fit:cover}.bldr-photo-overlay{position:absolute;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;border-radius:50%}.bldr-ring-photo:hover .bldr-photo-overlay,.bldr-ring-photo:active .bldr-photo-overlay,.bldr-photo-overlay.uploading{opacity:1}.bldr-photo-spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:bldrSpin .6s linear infinite}@keyframes bldrSpin{to{transform:rotate(360deg)}}.bldr-photo-badge{position:absolute;bottom:2px;right:2px;width:30px;height:30px;border-radius:50%;background:var(--color-primary);border:2px solid var(--bg-body);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;box-shadow:0 2px 6px #0000004d}.bldr-countdown{display:flex;align-items:baseline;justify-content:center;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;margin-top:8px}.bldr-timer-digit{font-size:1.3rem;color:var(--text-primary);min-width:2ch;text-align:center;letter-spacing:1px}.bldr-timer-colon{font-size:1.1rem;color:var(--text-secondary);margin:0 1px;animation:bldrBlink 1s ease-in-out infinite}@keyframes bldrBlink{0%,to{opacity:1}50%{opacity:.2}}.bldr-timer-sec{color:var(--color-primary)}.bldr-ring-label{font-family:Inter,sans-serif;font-size:.65rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin-top:3px}.bldr-tagline{font-family:Inter,sans-serif;font-size:.9rem;color:var(--text-secondary);text-align:center;margin-top:10px;line-height:1.5;max-width:320px;animation:bldrTagFade .6s ease-out}@keyframes bldrTagFade{0%{opacity:0}to{opacity:1}}.bldr-tagline strong{color:var(--color-primary);font-weight:500}.bldr-section{margin-top:24px}.bldr-section-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.bldr-section-desc{font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-secondary);margin:0 0 16px;line-height:1.5}.bldr-widgets-list{display:flex;flex-direction:column;gap:10px}.bldr-widget-card{display:flex;align-items:center;gap:12px;padding:14px 12px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;transition:border-color .2s,box-shadow .2s;box-shadow:var(--shadow-glow)}.bldr-widget-card.active{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 2px 8px #ff6b351a}[data-theme=dark] .bldr-widget-card.active{box-shadow:0 0 0 1px var(--color-primary),0 2px 8px #ff6b3526}.bldr-widget-icon{width:40px;height:40px;border-radius:10px;background:#ff6b3514;color:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}[data-theme=dark] .bldr-widget-icon{background:#ff6b351f}.bldr-widget-card.active .bldr-widget-icon{background:#ff6b3526}[data-theme=dark] .bldr-widget-card.active .bldr-widget-icon{background:#ff6b3533}.bldr-widget-info{flex:1;min-width:0}.bldr-widget-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.88rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:6px}.bldr-premium-tag{font-family:Plus Jakarta Sans,sans-serif;font-size:.55rem;font-weight:700;color:var(--color-primary);background:#ff6b351a;padding:1px 6px;border-radius:4px;letter-spacing:.5px}[data-theme=dark] .bldr-premium-tag{background:#ff6b3526}.bldr-widget-desc{font-family:Inter,sans-serif;font-size:.72rem;color:var(--text-tertiary);margin-top:2px;line-height:1.3}.bldr-widget-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.bldr-widget-order{display:flex;align-items:center;gap:2px}.bldr-order-btn{background:none;border:none;color:var(--text-secondary);width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:6px;transition:background .15s,color .15s}.bldr-order-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--color-primary)}.bldr-order-btn:disabled{opacity:.25;cursor:default}.bldr-order-num{font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:700;color:var(--color-primary);min-width:16px;text-align:center}.bldr-toggle{width:44px;height:24px;border-radius:12px;border:none;background:var(--border-color);cursor:pointer;position:relative;transition:background .25s;padding:0;-webkit-tap-highlight-color:transparent}.bldr-toggle.on{background:var(--color-primary)}.bldr-toggle-thumb{width:20px;height:20px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .25s;box-shadow:0 1px 3px #0003}.bldr-toggle.on .bldr-toggle-thumb{transform:translate(20px)}.bldr-save-wrap{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:10px}.bldr-save-btn{width:100%;max-width:320px;padding:14px 28px;border:none;border-radius:14px;background:var(--color-primary);color:var(--text-on-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s}.bldr-save-btn:active{transform:scale(.97)}.bldr-save-btn:disabled{opacity:.6;cursor:not-allowed}.bldr-save-btn.saved{background:#27ae60}.bldr-view-btn{background:none;border:1px solid var(--border-color);color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;padding:10px 24px;border-radius:12px;cursor:pointer;transition:border-color .15s}.bldr-view-btn:hover{border-color:var(--color-primary)}.bldr-save-error{font-family:Inter,sans-serif;font-size:.8rem;color:#e74c3c;margin:0;text-align:center}.cb-settings{min-height:100vh;background:var(--bg-body);padding-bottom:calc(80px + var(--safe-area-bottom))}.settings-main{max-width:600px;margin:0 auto;padding:0 16px 100px}.settings-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.4rem;color:var(--text-primary);margin:0 0 24px}.settings-section{background:var(--bg-card);border-radius:14px;border:1px solid var(--border-color);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-glow)}.settings-section-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px;display:flex;align-items:center;gap:8px}.settings-section-title svg{color:var(--color-primary);flex-shrink:0}.settings-accent-row{display:flex;gap:12px}.settings-accent-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 0;border-radius:10px;border:2px solid var(--border-color);background:var(--bg-card);cursor:pointer;transition:border-color .2s,background .2s;-webkit-tap-highlight-color:transparent}.settings-accent-option.active{border-color:var(--color-primary);background:var(--color-primary-light)}.settings-accent-dot{width:32px;height:32px;border-radius:50%}.settings-accent-label{font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.75rem;color:var(--text-secondary)}.settings-accent-option.active .settings-accent-label{color:var(--color-primary)}.settings-mono-row{margin-top:14px;padding-top:14px;border-top:1px solid var(--border-color);border-bottom:none;padding-bottom:0}.settings-profile-field{margin-bottom:12px}.settings-profile-label{display:block;font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.8rem;color:var(--text-secondary);margin-bottom:6px}.settings-profile-input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-body);color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:500;outline:none;transition:border-color .2s;box-sizing:border-box}.settings-profile-input:focus{border-color:var(--color-primary)}.settings-profile-input::placeholder{color:var(--text-tertiary)}.settings-profile-save-btn{flex-shrink:0;padding:8px 22px;border-radius:8px;border:none;background:var(--color-primary);color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.8rem;cursor:pointer;transition:opacity .2s}.settings-profile-save-btn:hover{opacity:.85}.settings-profile-save-btn:disabled{opacity:.4;cursor:not-allowed}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--border-color)}.settings-row:last-child{border-bottom:none;padding-bottom:0}.settings-row:first-of-type{padding-top:0}.settings-row-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.settings-row-label{font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.9rem;color:var(--text-primary)}.settings-row-desc{font-size:.75rem;color:var(--text-tertiary);line-height:1.3}.settings-toggle{position:relative;width:48px;height:28px;border-radius:14px;border:none;background:var(--border-color, #333);cursor:pointer;flex-shrink:0;transition:background .25s;padding:0}.settings-toggle.on{background:var(--color-primary, #A12F3A)}.settings-toggle:disabled{opacity:.4;cursor:not-allowed}.settings-toggle.loading{opacity:.6}.settings-toggle-knob{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;transition:transform .25s;pointer-events:none}.settings-toggle.on .settings-toggle-knob{transform:translate(20px)}.settings-link-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--border-color);text-decoration:none;color:inherit;cursor:pointer;transition:opacity .2s}.settings-link-row:last-child{border-bottom:none;padding-bottom:0}.settings-link-row:first-of-type{padding-top:0}.settings-link-row:hover{opacity:.75}.settings-link-row:active{opacity:.5}.settings-link-row svg{color:var(--text-tertiary);flex-shrink:0}.settings-sub-section{margin-top:8px;padding-top:12px;border-top:1px solid var(--border-color)}.settings-sub-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;display:block}.settings-hint{font-size:.75rem;color:var(--text-tertiary);margin:8px 0 0;padding:10px 12px;background:#ffffff0a;border-radius:8px;line-height:1.4}.settings-sub-badge{display:inline-block;padding:2px 10px;border-radius:20px;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px}.settings-sub-badge.active{background:#2e7d3226;color:#4caf50}.settings-sub-badge.cancelled{background:#ff980026;color:#ff9800}.settings-sub-badge.free{background:#ffffff14;color:var(--text-tertiary)}.settings-portal-btn{flex-shrink:0;padding:8px 18px;border-radius:8px;border:1px solid var(--color-primary);background:transparent;color:var(--color-primary);font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.8rem;cursor:pointer;transition:background .2s,opacity .2s}.settings-portal-btn:hover{background:var(--color-primary-light)}.settings-portal-btn:disabled{opacity:.5;cursor:not-allowed}.settings-upgrade-btn{width:100%;margin-top:4px;padding:12px;border-radius:10px;border:none;background:var(--color-primary);color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.85rem;cursor:pointer;transition:opacity .2s}.settings-upgrade-btn:hover{opacity:.85}.settings-upgrade-btn:active{opacity:.7}.settings-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:10px;font-family:Plus Jakarta Sans,sans-serif;font-size:.8rem;font-weight:600;color:#fff;z-index:9999;animation:settingsToastIn .3s ease-out;white-space:nowrap}.settings-toast.success{background:#2e7d32}.settings-toast.error{background:#c62828}.settings-toast.info{background:#333}@keyframes settingsToastIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.ch-page{min-height:100dvh;background:var(--bg-body);color:var(--text-primary);padding-bottom:90px;font-family:Inter,sans-serif}.ch-main{max-width:600px;margin:0 auto;padding:20px 16px}.ch-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.4rem;font-weight:800;color:var(--text-primary);margin:0 0 4px}.ch-subtitle{font-family:Inter,sans-serif;color:var(--text-secondary);font-size:.88rem;margin:0 0 24px}.ch-loading{display:flex;justify-content:center;padding:60px 0}.ch-spinner{width:32px;height:32px;border:3px solid var(--color-primary-light);border-top-color:var(--color-primary);border-radius:50%;animation:ch-spin .7s linear infinite}@keyframes ch-spin{to{transform:rotate(360deg)}}.ch-grid{display:flex;flex-direction:column;gap:12px}.ch-grid-dimmed{opacity:.35;pointer-events:none}.ch-card{position:relative;display:flex;align-items:center;gap:14px;padding:18px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;cursor:pointer;text-align:left;font-family:Inter,sans-serif;transition:transform .15s ease,box-shadow .15s ease;box-shadow:var(--shadow-sm)}[data-theme=dark] .ch-card{box-shadow:none}.ch-card:active{transform:scale(.98)}.ch-card-gated{opacity:.55}.ch-card-locked{cursor:default}.ch-lock-overlay{position:absolute;top:12px;right:12px;color:var(--text-tertiary)}.ch-card-icon{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);border-radius:12px;color:var(--color-primary)}.ch-card-body{flex:1;min-width:0}.ch-card-body h3{font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.3px;margin:0 0 4px}.ch-card-body p{font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-secondary);margin:0;line-height:1.35}.ch-card-tags{display:flex;gap:8px;margin-top:8px}.ch-tag{font-family:Inter,sans-serif;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.ch-tag-dur{color:var(--text-tertiary)}.ch-card-arrow{flex-shrink:0;color:var(--text-tertiary);opacity:.5}.ch-premium-banner{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--color-primary-light);border-radius:12px;margin-bottom:20px;font-family:Inter,sans-serif;font-size:.88rem;font-weight:500;color:var(--color-primary)}.ch-upgrade-link{margin-left:auto;background:var(--color-primary);color:#fff;border:none;border-radius:8px;padding:6px 14px;font-family:Inter,sans-serif;font-size:.82rem;font-weight:600;cursor:pointer}.ch-active-section{display:flex;flex-direction:column;align-items:center;gap:24px}.ch-ring-wrap{position:relative;display:flex;align-items:center;justify-content:center}.ch-ring-svg{display:block}:root{--ch-ring-bg: rgba(0, 0, 0, .06)}[data-theme=dark]{--ch-ring-bg: rgba(255, 255, 255, .08)}.ch-ring-centre{position:absolute;display:flex;flex-direction:column;align-items:center}.ch-ring-num{font-family:Plus Jakarta Sans,sans-serif;font-size:1.8rem;font-weight:700;color:var(--text-primary);line-height:1}.ch-ring-slash{font-family:Inter,sans-serif;font-size:1rem;font-weight:500;color:var(--text-secondary)}.ch-ring-label{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-tertiary);margin-top:4px}.ch-active-info{text-align:center;width:100%}.ch-info-row{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:16px}.ch-info-item{display:flex;flex-direction:column;align-items:center}.ch-info-val{font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:700;color:var(--text-primary)}.ch-info-key{font-family:Inter,sans-serif;font-size:.75rem;color:var(--text-tertiary)}.ch-pace{font-family:Inter,sans-serif;font-size:.82rem;font-weight:600;padding:4px 12px;border-radius:20px}.ch-pace-ontrack{background:#34c7591f;color:#34c759}.ch-pace-ahead{background:#007aff1f;color:#007aff}.ch-pace-behind{background:#ff3b301f;color:#ff3b30}.ch-active-name{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 4px}.ch-active-desc{font-family:Inter,sans-serif;font-size:.88rem;color:var(--text-secondary);margin:0}.ch-give-up{background:none;border:none;color:var(--text-tertiary);font-family:Inter,sans-serif;font-size:.82rem;cursor:pointer;padding:8px 16px;opacity:.6;-webkit-tap-highlight-color:transparent}.ch-give-up:hover{opacity:1}.ch-browse-locked{width:100%;margin-top:12px}.ch-browse-locked-note{text-align:center;font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-tertiary);margin:0 0 12px}.ch-completed-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 0 20px;min-height:calc(100dvh - 240px)}.ch-completed-badge-wrap{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.ch-completed-glow{position:absolute;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(var(--color-primary-rgb),.3) 0%,transparent 70%);animation:ch-glow-pulse 2s ease-in-out infinite;pointer-events:none}@keyframes ch-glow-pulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.3);opacity:.2}}.ch-completed-badge-img{width:200px;height:200px;object-fit:contain;filter:drop-shadow(0 0 30px rgba(var(--color-primary-rgb),.35));animation:ch-badge-appear .8s cubic-bezier(.175,.885,.32,1.275) both;position:relative;z-index:1}@keyframes ch-badge-appear{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}70%{transform:scale(.95)}to{transform:scale(1);opacity:1}}.ch-completed-heading{font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:800;color:var(--text-primary);text-transform:uppercase;letter-spacing:1px;margin:0}.ch-completed-name{font-family:Inter,sans-serif;font-size:1rem;font-weight:600;color:var(--text-secondary);margin:0}.ch-completed-desc{font-family:Inter,sans-serif;font-size:.88rem;color:var(--text-tertiary);text-align:center;margin:0;max-width:280px;line-height:1.4}.ch-completed-count{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-tertiary);margin:0}@media(prefers-reduced-motion:reduce){.ch-completed-badge-img{animation:ch-fade-only .3s ease-out both}.ch-completed-glow{animation:none;opacity:.3}}@keyframes ch-fade-only{0%{opacity:0}to{opacity:1}}.ch-btn{width:100%;max-width:300px;padding:14px 20px;border-radius:12px;border:none;font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s;-webkit-tap-highlight-color:transparent}.ch-btn:disabled{opacity:.5;cursor:not-allowed}.ch-btn-primary{background:var(--color-primary);color:#fff}.ch-btn-secondary{background:transparent;color:var(--text-secondary)}.ch-btn-danger{background:#ff3b30;color:#fff}.ch-modal-backdrop{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.ch-modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;padding:28px 24px;max-width:340px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:0 8px 40px #0000004d}.ch-modal h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.05rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.3px;margin:0}.ch-modal p{font-family:Inter,sans-serif;font-size:.88rem;color:var(--text-secondary);margin:0;line-height:1.4}.ch-modal-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);border-radius:16px;color:var(--color-primary)}.ch-modal-details{display:flex;gap:16px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-secondary)}.ch-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);padding:12px 20px;border-radius:12px;font-family:Inter,sans-serif;font-size:.88rem;font-weight:500;z-index:2000;animation:ch-toast-in .3s ease;max-width:90vw;text-align:center}.ch-toast-success{background:#34c759;color:#fff}.ch-toast-error{background:#ff3b30;color:#fff}.ch-toast-info{background:var(--bg-card);color:var(--text-primary);box-shadow:0 4px 20px #00000026}@keyframes ch-toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.bdg-loading,.bdg-loading-inline{display:flex;align-items:center;justify-content:center;min-height:40vh}.bdg-loading{min-height:100vh;background:var(--bg-body)}.bdg-spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:bdg-spin .8s linear infinite}@keyframes bdg-spin{to{transform:rotate(360deg)}}.bdg-page{min-height:100vh;background:var(--bg-body);padding-bottom:calc(80px + var(--safe-area-bottom))}.bdg-main{max-width:600px;margin:0 auto;padding:0 16px calc(80px + var(--safe-area-bottom))}.bdg-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.4rem;font-weight:800;color:var(--text-primary);margin:20px 0 4px;text-align:center}.bdg-subtitle{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-tertiary);text-align:center;margin:0 0 24px}.bdg-category{margin-bottom:28px}.bdg-category-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.78rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin:0 0 12px;padding-bottom:6px;border-bottom:1px solid var(--border-color)}.bdg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.bdg-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 6px;border:1px solid var(--border-color);border-radius:14px;background:var(--bg-card);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-glow)}.bdg-item:active{transform:scale(.96)}.bdg-item.earned{border-color:#ffd7004d;box-shadow:0 0 12px #ffd70014}.bdg-item.locked{opacity:.5}.bdg-img-wrap{position:relative;width:72px;height:72px;border-radius:50%;overflow:hidden;background:var(--bg-body);display:flex;align-items:center;justify-content:center}.bdg-img{width:100%;height:100%;object-fit:cover}.bdg-item.locked .bdg-img{filter:grayscale(1) brightness(.6)}.bdg-img-placeholder{color:var(--text-tertiary);display:flex;align-items:center;justify-content:center}.bdg-lock-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000059;color:#fff;border-radius:50%}.bdg-name{font-family:Inter,sans-serif;font-size:.68rem;font-weight:600;color:var(--text-primary);text-align:center;line-height:1.2}.bdg-modal-backdrop{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.bdg-modal{background:var(--bg-card);border-radius:20px;padding:32px 24px 24px;text-align:center;max-width:320px;width:100%;border:1px solid var(--border-color);box-shadow:0 8px 40px #0000004d}.bdg-modal-img-wrap{width:120px;height:120px;margin:0 auto 16px;border-radius:50%;overflow:hidden;border:3px solid var(--border-color);display:flex;align-items:center;justify-content:center;background:var(--bg-body)}.bdg-modal-img-wrap.earned{border-color:#ffd70080;box-shadow:0 0 24px #ffd70026}.bdg-modal-img-wrap.locked .bdg-modal-img{filter:grayscale(1) brightness(.5)}.bdg-modal-img{width:100%;height:100%;object-fit:cover}.bdg-modal-placeholder{color:var(--text-tertiary)}.bdg-modal-name{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0 0 8px}.bdg-modal-desc{font-family:Inter,sans-serif;font-size:.85rem;color:var(--text-secondary);margin:0 0 16px;line-height:1.4}.bdg-modal-status{display:inline-flex;align-items:center;gap:6px;font-family:Inter,sans-serif;font-size:.8rem;font-weight:600;padding:6px 14px;border-radius:20px}.bdg-modal-status.earned{color:#34c759;background:#34c7591a;border:1px solid rgba(52,199,89,.2)}.bdg-modal-status.locked{color:var(--text-tertiary);background:#9696961a;border:1px solid rgba(150,150,150,.15)}.bdg-modal-close{display:block;width:100%;margin-top:20px;padding:12px;border:none;border-radius:12px;background:var(--bg-body);color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.88rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}[data-theme=dark] .bdg-item{background:#1e1e1ed9;border-color:#ffffff0f}[data-theme=dark] .bdg-item.earned{border-color:#ffd70033}[data-theme=dark] .bdg-modal{background:#1e1e1ef2;border-color:#ffffff14}.cbm-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-body)}.cbm-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes ringFillIn{0%{stroke-dashoffset:238.76}}.cbm-page{min-height:100vh;background:var(--bg-body);padding-bottom:40px}.cbm-main{max-width:600px;margin:0 auto;padding:0 16px calc(80px + var(--safe-area-bottom))}.cbm-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.15rem;color:var(--text-primary);text-align:center;margin:16px 0 20px}.cbm-remeasure-banner{display:flex;align-items:center;gap:16px;width:100%;padding:16px 18px;background:rgba(var(--color-primary-rgb, 161, 47, 58),.08);border:1px solid rgba(var(--color-primary-rgb, 161, 47, 58),.2);border-radius:16px;cursor:pointer;margin-bottom:24px;-webkit-tap-highlight-color:transparent;box-shadow:none;font-family:inherit;text-align:left}.cbm-remeasure-banner:active{transform:scale(.98)}.cbm-banner-ring{position:relative;width:56px;height:56px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.cbm-banner-ring svg{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg)}.cbm-banner-ring-track{fill:none;stroke:rgba(var(--color-primary-rgb, 161, 47, 58),.2);stroke-width:10;stroke-linecap:round}.cbm-banner-ring-fill{fill:none;stroke:var(--color-primary);stroke-width:10;stroke-linecap:round;animation:ringFillIn 1.6s ease-out}.cbm-banner-ring-val{position:relative;z-index:1;font-family:Plus Jakarta Sans,sans-serif;font-size:.65rem;font-weight:700;color:#4caf50}.cbm-banner-info{display:flex;flex-direction:column;gap:2px}.cbm-banner-label{font-family:Inter,sans-serif;font-size:.55rem;font-weight:700;color:var(--text-tertiary);letter-spacing:1.5px;text-transform:uppercase}.cbm-banner-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;color:var(--text-primary)}.cbm-banner-cta{font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;color:var(--color-primary)}.cbm-setup-card{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:24px 18px;margin-bottom:24px;box-shadow:var(--shadow-glow)}[data-theme=dark] .cbm-setup-card{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.cbm-setup-heading{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1rem;color:var(--text-primary);margin:0 0 8px}.cbm-setup-desc{font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-secondary);line-height:1.4;margin:0 0 20px}.cbm-form-section{margin-bottom:20px}.cbm-form-label{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.8rem;color:var(--text-primary);margin:0 0 4px}.cbm-form-hint{font-family:Inter,sans-serif;font-size:.72rem;color:var(--text-tertiary);margin:0 0 12px;line-height:1.4}.cbm-form-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(150,150,150,.1)}.cbm-form-name{font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;color:var(--text-primary)}.cbm-form-name-wrap{display:flex;align-items:center;gap:8px}.cbm-form-input-wrap{display:flex;align-items:center;gap:4px}.cbm-form-input{width:70px;padding:8px 10px;border:1px solid rgba(150,150,150,.2);border-radius:10px;font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary);background:transparent;text-align:center;outline:none;transition:border-color .2s}.cbm-form-input:focus{border-color:rgba(var(--color-primary-rgb, 161, 47, 58),.4)}.cbm-form-suffix{font-family:Inter,sans-serif;font-size:.72rem;color:var(--text-tertiary);min-width:20px}.cbm-dir-badge{font-family:Inter,sans-serif;font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}.cbm-dir-gain{background:rgba(var(--color-primary-rgb, 161, 47, 58),.1);color:var(--color-primary);border:1px solid rgba(var(--color-primary-rgb, 161, 47, 58),.2)}.cbm-dir-lose{background:#2196f31a;color:#2196f3;border:1px solid rgba(33,150,243,.2)}.cbm-dir-maintain{background:#9696961a;color:var(--text-tertiary);border:1px solid rgba(150,150,150,.2)}.cbm-rings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.cbm-ring-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 4px 10px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;box-shadow:var(--shadow-glow)}[data-theme=dark] .cbm-ring-item{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 1px 3px #0003,0 4px 12px #00000026}.cbm-ring{position:relative;width:64px;height:64px;display:flex;align-items:center;justify-content:center}.cbm-ring svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.cbm-ring-track{fill:none;stroke:rgba(var(--color-primary-rgb, 161, 47, 58),.12);stroke-width:10;stroke-linecap:round}.cbm-ring-fill{fill:none;stroke:var(--color-primary);stroke-width:10;stroke-linecap:round;animation:ringFillIn 1.6s ease-out}.cbm-ring-fill.complete{stroke:var(--color-primary);filter:drop-shadow(0 0 4px rgba(var(--color-primary-rgb, 161, 47, 58),.4))}.cbm-ring-val{position:relative;z-index:1;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.65rem;color:#4caf50}.cbm-ring-val.complete{color:#4caf50}.cbm-ring-name{font-family:Inter,sans-serif;font-size:.6rem;font-weight:600;color:var(--text-secondary);text-align:center;line-height:1.15}.cbm-ring-dir{color:var(--text-tertiary);height:10px;display:flex;align-items:center}@keyframes metricCompleteGlow{0%{filter:drop-shadow(0 0 0 transparent)}40%{filter:drop-shadow(0 0 10px rgba(var(--color-primary-rgb, 161, 47, 58),.5))}to{filter:drop-shadow(0 0 4px rgba(var(--color-primary-rgb, 161, 47, 58),.3))}}.cbm-ring-complete{animation:metricCompleteGlow 1s ease-out forwards}.cbm-details{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.cbm-detail-card{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow-glow)}[data-theme=dark] .cbm-detail-card{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 1px 3px #0003,0 4px 12px #00000026}.cbm-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.cbm-detail-name{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.8rem;color:var(--text-primary)}.cbm-detail-row{display:flex;gap:8px;margin-bottom:10px}.cbm-detail-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.cbm-detail-label{font-family:Inter,sans-serif;font-size:.6rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.cbm-detail-value{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.85rem;color:var(--text-primary)}.cbm-detail-unit{font-size:.6rem;color:var(--text-tertiary);margin-left:1px}.cbm-detail-progress-row{display:flex;align-items:center;gap:10px}.cbm-detail-bar{flex:1;height:6px;background:rgba(var(--color-primary-rgb, 161, 47, 58),.12);border-radius:3px;overflow:hidden}.cbm-detail-bar-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width 1s ease-out}.cbm-detail-pct{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:700;color:#4caf50;min-width:36px;text-align:right}.cbm-detail-change{display:block;font-family:Inter,sans-serif;font-size:.68rem;color:var(--text-tertiary);margin-top:6px}.cbm-actions{display:flex;gap:10px;margin-bottom:28px}.cbm-btn-primary{flex:1;padding:12px 20px;border-radius:14px;border:none;background:var(--color-primary);color:var(--text-on-primary, #fff);font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.85rem;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;gap:6px}.cbm-btn-primary:active{transform:scale(.97)}.cbm-btn-primary:disabled{opacity:.5;cursor:not-allowed}.cbm-btn-secondary{flex:1;padding:12px 20px;border-radius:14px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.85rem;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center}.cbm-btn-secondary:active{transform:scale(.97)}.cbm-btn-spinner{width:18px;height:18px;border:2px solid rgba(var(--color-primary-rgb),.3);border-top-color:var(--text-on-primary, #fff);border-radius:50%;animation:spin .6s linear infinite}.cbm-btn-spinner-sm{width:14px;height:14px;border:2px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}.cbm-section{margin-bottom:28px}.cbm-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cbm-section-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.85rem;color:var(--text-primary);margin:0 0 12px;padding-left:4px}.cbm-section-header .cbm-section-title{margin-bottom:0}.cbm-empty-text{font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-tertiary);text-align:center;padding:20px 0}.cbm-history-list{display:flex;flex-direction:column;gap:8px}.cbm-history-item{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:14px 16px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s;text-align:left;width:100%;box-shadow:var(--shadow-glow)}[data-theme=dark] .cbm-history-item{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.cbm-history-item:active{transform:scale(.98)}.cbm-history-header{display:flex;align-items:center;justify-content:space-between}.cbm-history-date{font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.8rem;color:var(--text-primary)}.cbm-history-chevron{color:var(--text-tertiary);transition:transform .2s;flex-shrink:0}.cbm-history-chevron.open{transform:rotate(180deg)}.cbm-history-detail{margin-top:12px;padding-top:12px;border-top:1px solid rgba(150,150,150,.1);display:flex;flex-direction:column;gap:6px}.cbm-history-metric{display:flex;align-items:center;gap:8px}.cbm-history-metric-name{flex:1;font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-secondary)}.cbm-history-metric-val{font-family:Plus Jakarta Sans,sans-serif;font-size:.78rem;font-weight:600;color:var(--text-primary);min-width:50px;text-align:right}.cbm-history-metric-diff{font-family:Inter,sans-serif;font-size:.68rem;font-weight:600;color:var(--text-tertiary);min-width:36px;text-align:right}.cbm-history-metric-diff.good{color:#4caf50}.cbm-history-metric-diff.bad{color:#f44336}.cbm-photos-list{display:flex;flex-direction:column;gap:16px}.cbm-photo-period{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow-glow)}[data-theme=dark] .cbm-photo-period{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.cbm-photo-period-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.cbm-photo-period-date{font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.75rem;color:var(--text-primary)}.cbm-photo-add-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:10px;border:1px solid rgba(var(--color-primary-rgb, 161, 47, 58),.2);background:rgba(var(--color-primary-rgb, 161, 47, 58),.06);color:var(--color-primary);font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.72rem;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s}.cbm-photo-add-btn:active{transform:scale(.94)}.cbm-photo-add-btn:disabled{opacity:.5}.cbm-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.cbm-photo-thumb{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden}.cbm-photo-thumb img{width:100%;height:100%;object-fit:cover}.cbm-photo-delete{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;border:none;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;opacity:.7}.cbm-photo-delete:active{opacity:1}.cbm-photo-empty{font-family:Inter,sans-serif;font-size:.72rem;color:var(--text-tertiary);text-align:center;padding:8px 0;margin:0}.cbm-compare-btn{padding:6px 14px;border-radius:10px;border:1px solid rgba(var(--color-primary-rgb, 161, 47, 58),.2);background:rgba(var(--color-primary-rgb, 161, 47, 58),.06);color:var(--color-primary);font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.72rem;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s}.cbm-compare-btn:active{transform:scale(.94)}.cbm-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:cbmOverlayIn .2s ease-out}@keyframes cbmOverlayIn{0%{opacity:0}to{opacity:1}}.cbm-overlay-card{background:var(--bg-card-elevated);border-radius:20px;padding:24px 20px;max-width:400px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0000004d;animation:cbmCardIn .25s ease}@keyframes cbmCardIn{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}[data-theme=dark] .cbm-overlay-card{background:var(--bg-card-elevated);border:1px solid rgba(255,255,255,.08)}[data-mono=true][data-theme=light] .cbm-overlay-card{background:#fff}.cbm-overlay-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1rem;color:var(--text-primary);margin:0 0 6px}.cbm-overlay-desc{font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-secondary);margin:0 0 16px}.cbm-overlay-actions{display:flex;gap:10px;margin-top:16px}.cbm-compare-card{max-width:440px}.cbm-compare-selectors{display:flex;gap:12px;margin-bottom:16px}.cbm-compare-select-wrap{flex:1;display:flex;flex-direction:column;gap:4px}.cbm-compare-label{font-family:Inter,sans-serif;font-size:.65rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.cbm-compare-select{padding:8px 10px;border:1px solid rgba(150,150,150,.2);border-radius:10px;font-family:Inter,sans-serif;font-size:.8rem;color:var(--text-primary);background:transparent;outline:none}.cbm-compare-photos{display:flex;gap:10px;margin-bottom:16px}.cbm-compare-photo-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}.cbm-compare-photo-label{font-family:Inter,sans-serif;font-size:.65rem;font-weight:600;color:var(--text-tertiary)}.cbm-compare-photo-zoomable{position:relative;width:100%;aspect-ratio:3/4;border-radius:12px;overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none}.cbm-compare-photo-zoomable .cbm-compare-photo-img{width:100%;height:100%;object-fit:cover;border-radius:0;transition:none;will-change:transform}.cbm-zoom-reset-btn{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;border:none;background:#0000008c;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;z-index:2}.cbm-zoom-reset-btn:active{opacity:.8}.cbm-compare-photo-img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:12px}.cbm-compare-photo-wrap{width:100%;display:flex;flex-direction:column;align-items:center;gap:6px}.cbm-compare-photo-nav{display:flex;align-items:center;gap:8px}.cbm-compare-nav-btn{width:28px;height:28px;border-radius:50%;border:1px solid rgba(150,150,150,.25);background:#96969614;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .15s,opacity .15s}.cbm-compare-nav-btn:active:not(:disabled){background:#96969633}.cbm-compare-nav-btn:disabled{opacity:.3;cursor:default}.cbm-compare-photo-count{font-family:Inter,sans-serif;font-size:.65rem;font-weight:600;color:var(--text-tertiary);min-width:28px;text-align:center}.cbm-compare-photo-empty{width:100%;aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#96969614;font-family:Inter,sans-serif;font-size:.72rem;color:var(--text-tertiary)}.cbm-compare-metrics{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.cbm-compare-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid rgba(150,150,150,.08)}.cbm-compare-metric-name{flex:1;font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-secondary)}.cbm-compare-val{font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:600;color:var(--text-primary);min-width:34px;text-align:center}.cbm-compare-arrow{color:var(--text-tertiary);font-size:.72rem}.cbm-compare-diff{font-family:Inter,sans-serif;font-size:.68rem;font-weight:600;color:var(--text-tertiary);min-width:36px;text-align:right}.cbm-compare-diff.good{color:#4caf50}.cbm-compare-diff.bad{color:#f44336}.cbm-compare-close{width:100%;margin-top:8px}.cbm-page .toast-notification{position:fixed;bottom:90px;left:50%;transform:translate(-50%);padding:12px 20px;border-radius:12px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;color:#fff;z-index:1100;display:flex;align-items:center;gap:8px;box-shadow:0 8px 24px #0003;max-width:calc(100vw - 32px);word-break:break-word}.cbm-page .toast-notification.success{background:var(--color-success)}.cbm-page .toast-notification.error{background:var(--color-error)}.cbm-page .toast-notification.info{background:var(--color-info, #2196f3)}.cbm-page .toast-icon{width:18px;height:18px;display:flex;align-items:center;flex-shrink:0}.cbm-page .toast-icon svg{width:100%;height:100%}@media(min-width:400px){.cbm-ring{width:72px;height:72px}.cbm-ring-val{font-size:.72rem}}.ah-page{min-height:100vh;background:var(--bg-body);padding-bottom:calc(80px + var(--safe-area-bottom))}.ah-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-body)}.ah-loading-spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:ah-spin .8s linear infinite}@keyframes ah-spin{to{transform:rotate(360deg)}}.ah-header{display:flex;align-items:center;justify-content:space-between;padding:calc(16px + var(--safe-area-top)) 16px 8px;position:sticky;top:0;background:var(--bg-body);z-index:10}.ah-header h1{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin:0}.ah-back{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center}.ah-summary{display:flex;align-items:center;justify-content:center;gap:20px;padding:16px;margin:8px 16px 16px;background:var(--bg-card);border-radius:16px;border:1px solid var(--border-color)}.ah-summary-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.ah-summary-value{font-size:1.5rem;font-weight:800;color:var(--color-primary)}.ah-summary-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.ah-summary-divider{width:1px;height:32px;background:var(--border-color)}.ah-list{padding:0 16px}.ah-day-group{margin-bottom:20px}.ah-day-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px}.ah-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-card);border-radius:14px;border:1px solid var(--border-color);margin-bottom:8px}.ah-item-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-bg, rgba(184, 49, 61, .08));border-radius:12px;flex-shrink:0}.ah-item-info{flex:1;min-width:0}.ah-item-name{display:block;font-weight:600;font-size:.95rem;color:var(--text-primary)}.ah-item-meta{display:block;font-size:.8rem;color:var(--text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ah-item-delete{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .2s;flex-shrink:0}.ah-item-delete:hover{color:var(--color-error, #e53e3e)}.ah-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 24px;text-align:center}.ah-empty p{font-size:1rem;font-weight:600;color:var(--text-secondary);margin:0}.ah-empty span{font-size:.85rem;color:var(--text-tertiary)}.ah-skeleton-list{display:flex;flex-direction:column;gap:8px}.ah-skeleton-item{height:64px;border-radius:14px;background:linear-gradient(90deg,var(--bg-card) 25%,var(--border-color) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:ah-shimmer 1.5s infinite}@keyframes ah-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ah-fab{position:fixed;bottom:calc(64px + var(--safe-area-bottom));right:max(18px,env(safe-area-inset-right,0px));width:54px;height:54px;border-radius:50%;border:2px solid rgba(255,255,255,.35);background:var(--color-primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #00000059,0 0 0 3px rgba(var(--color-primary-rgb, 184, 49, 61),.3);transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s ease;z-index:1000}.ah-fab:active{transform:scale(.92)}.ah-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:10px;font-size:.85rem;font-weight:600;z-index:2000;animation:al-fadeIn .2s ease;white-space:nowrap}.ah-toast-success{background:var(--color-success, #38a169);color:#fff}.ah-toast-error{background:var(--color-error, #e53e3e);color:#fff}.ah-toast-info{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.ais-page{min-height:100dvh;background:var(--bg-body);color:var(--text-primary);font-family:Inter,sans-serif;padding-bottom:90px}.ais-loading{display:flex;align-items:center;justify-content:center;min-height:300px}.ais-main{max-width:500px;margin:0 auto;padding:20px 16px}.ais-heading{display:flex;align-items:center;gap:10px;margin-bottom:4px}.ais-heading h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.4rem;font-weight:800;margin:0}.ais-beta-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:6px;font-size:.6rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff}.ais-subtitle{font-size:.85rem;color:var(--text-secondary);margin:0 0 24px}.ais-usage-banner{background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;padding:14px 16px;margin-bottom:16px}.ais-usage-banner--low{border-color:#ff9500;background:#ff95000f}.ais-usage-banner--locked{border-color:#ff3b30;background:#ff3b300f}.ais-usage-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.ais-usage-count{font-size:.82rem;font-weight:700;color:var(--text-primary)}.ais-usage-banner--locked .ais-usage-count{color:#ff3b30}.ais-usage-total{font-size:.72rem;font-weight:600;color:var(--text-tertiary)}.ais-usage-bar{width:100%;height:6px;border-radius:3px;background:var(--border-color);overflow:hidden}.ais-usage-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#8b5cf6,#6366f1);transition:width .4s ease}.ais-usage-banner--low .ais-usage-bar-fill{background:linear-gradient(90deg,#ff9500,#ff6b00)}.ais-usage-banner--locked .ais-usage-bar-fill{background:linear-gradient(90deg,#ff3b30,#ff453a)}.ais-usage-hint{font-size:.72rem;color:var(--text-tertiary);margin:8px 0 0;text-align:center}.ais-upload-section{display:flex;flex-direction:column;align-items:center}.ais-upload-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;width:100%;padding:48px 24px;background:var(--bg-card);border:2px dashed var(--border-color);border-radius:20px;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.ais-upload-btn:active{transform:scale(.98)}@media(hover:hover){.ais-upload-btn:hover{border-color:var(--color-primary);background:var(--color-primary-light)}}.ais-upload-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#38b6ff1f,#8b5cf61f);display:flex;align-items:center;justify-content:center;color:#8b5cf6}.ais-upload-text{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:var(--text-primary)}.ais-upload-hint{font-size:.78rem;color:var(--text-tertiary)}.ais-upload-btn--locked{border-color:#ff3b304d;cursor:default;opacity:.7}.ais-upload-btn--locked:active{transform:none}.ais-upload-icon--locked{background:linear-gradient(135deg,#ff3b301f,#ff453a1f);color:#ff3b30}.ais-recent-section{width:100%;margin-top:24px}.ais-recent-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.03em;margin:0 0 2px}.ais-recent-hint{font-size:.75rem;color:var(--text-tertiary);margin:0 0 12px}.ais-recent-list{display:flex;flex-direction:column;gap:8px}.ais-recent-card{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;text-align:left}.ais-recent-card:active{transform:scale(.98)}@media(hover:hover){.ais-recent-card:hover{border-color:var(--color-primary);background:var(--color-primary-light)}}.ais-recent-thumb{width:48px;height:48px;border-radius:10px;object-fit:cover;flex-shrink:0}.ais-recent-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.ais-recent-label{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ais-recent-macros{font-size:.72rem;font-weight:500;color:var(--text-tertiary)}.ais-recent-arrow{flex-shrink:0;color:var(--text-tertiary)}.ais-recent-meal-tag{font-size:.68rem;font-weight:600;color:var(--text-tertiary);margin-top:1px}.ais-recent-empty{font-size:.82rem;color:var(--text-tertiary);text-align:center;padding:20px 0;margin:0}.ais-category-tabs{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:10px;margin-bottom:2px}.ais-category-tabs::-webkit-scrollbar{display:none}.ais-category-tab{display:flex;align-items:center;gap:4px;white-space:nowrap;padding:6px 12px;border-radius:20px;border:1.5px solid var(--border-color);background:transparent;font-family:Inter,sans-serif;font-size:.72rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;flex-shrink:0}.ais-category-tab--active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.ais-category-count{font-size:.65rem;font-weight:700;opacity:.7}.ais-preview-section{display:flex;flex-direction:column;gap:16px}.ais-preview-img-wrap{position:relative;width:100%;border-radius:16px;overflow:hidden;background:var(--bg-card);border:1px solid var(--border-color)}.ais-preview-img-wrap--dim .ais-preview-img{opacity:.4}.ais-preview-img-wrap--small{max-height:200px}.ais-preview-img{width:100%;max-height:360px;object-fit:cover;display:block}.ais-preview-img-wrap--small .ais-preview-img{max-height:200px}.ais-preview-actions{display:flex;flex-direction:column;gap:10px}.ais-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--color-error-bg);color:var(--color-error);border-radius:12px;font-size:.85rem;font-weight:500}.ais-analysing-section{display:flex;flex-direction:column;align-items:center;gap:20px}.ais-analysing-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.ais-analysing-spinner{width:48px;height:48px;border:3px solid rgba(139,92,246,.2);border-top-color:#8b5cf6;border-radius:50%;animation:ais-spin .7s linear infinite}@keyframes ais-spin{to{transform:rotate(360deg)}}.ais-analysing-msg{font-size:.9rem;font-weight:500;color:var(--text-secondary);text-align:center;animation:ais-msg-fade .4s ease}@keyframes ais-msg-fade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.ais-results-section{display:flex;flex-direction:column;gap:16px;animation:ais-results-in .4s ease}@keyframes ais-results-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ais-confidence{display:inline-flex;align-self:flex-start;padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:600}.ais-confidence--high{background:#34c7591f;color:#34c759}.ais-confidence--medium{background:#ff95001f;color:#ff9500}.ais-confidence--low{background:#ff3b301f;color:#ff3b30}.ais-totals-card{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:20px 12px;box-shadow:var(--shadow-sm)}.ais-total-item{display:flex;flex-direction:column;align-items:center;gap:2px}.ais-total-val{font-family:Plus Jakarta Sans,sans-serif;font-size:1.25rem;font-weight:800;color:var(--text-primary)}.ais-total-label{font-size:.7rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em}.ais-items-list{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:16px;box-shadow:var(--shadow-sm)}.ais-items-list h3{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.03em;margin:0 0 12px}.ais-item-row{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border-light)}.ais-item-row:last-child{border-bottom:none;padding-bottom:0}.ais-item-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.ais-item-name{font-size:.88rem;font-weight:600;color:var(--text-primary)}.ais-item-serving{font-size:.75rem;color:var(--text-tertiary)}.ais-item-macros{display:flex;gap:8px;font-size:.75rem;font-weight:600;color:var(--text-secondary);flex-shrink:0;margin-left:12px}.ais-meal-picker{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:16px;box-shadow:var(--shadow-sm)}.ais-meal-picker h3{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.03em;margin:0 0 10px}.ais-meal-options{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.ais-meal-btn{padding:10px 4px;border-radius:10px;border:1.5px solid var(--border-color);background:transparent;font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.ais-meal-btn--active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.ais-btn{width:100%;padding:14px 20px;border-radius:12px;border:none;font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;gap:8px}.ais-btn:disabled{opacity:.5;cursor:not-allowed}.ais-btn-primary{background:var(--color-primary);color:#fff}.ais-btn-secondary{background:transparent;color:var(--text-secondary)}.ais-result-actions{display:flex;flex-direction:column;gap:8px}.ais-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);padding:12px 20px;border-radius:12px;font-family:Inter,sans-serif;font-size:.88rem;font-weight:500;z-index:2000;animation:ais-toast-in .3s ease;max-width:90vw;text-align:center}.ais-toast--success{background:#34c759;color:#fff}.ais-toast--error{background:#ff3b30;color:#fff}.ais-toast--info{background:var(--bg-card);color:var(--text-primary);box-shadow:0 4px 20px #00000026}@keyframes ais-toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.cht-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-body)}.cht-loading-inline{display:flex;align-items:center;justify-content:center;padding:60px 0}.cht-spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.cht-page{min-height:100vh;background:var(--bg-body);padding-bottom:calc(80px + var(--safe-area-bottom))}.cht-main{max-width:600px;margin:0 auto;padding:0 16px calc(80px + var(--safe-area-bottom))}.cht-page-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.3rem;color:var(--text-primary);margin:16px 0 12px;padding-left:4px}.cht-period-toggle{display:flex;gap:4px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:4px;margin-bottom:16px}[data-theme=dark] .cht-period-toggle{background:#1e1e1ecc;border-color:#ffffff0f}.cht-period-btn{flex:1;padding:8px 16px;border:none;border-radius:10px;background:transparent;font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.78rem;color:var(--text-tertiary);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.cht-period-btn.active{background:var(--color-primary);color:var(--text-on-primary, #fff);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.cht-period-btn:active{transform:scale(.97)}.cht-date-nav{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:16px;padding:0 4px}.cht-date-nav-btn{width:36px;height:36px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s;flex-shrink:0}.cht-date-nav-btn:active{transform:scale(.92)}.cht-date-nav-btn:disabled{opacity:.3;cursor:default}.cht-date-nav-btn:disabled:active{transform:none}[data-theme=dark] .cht-date-nav-btn{background:#1e1e1ecc;border-color:#ffffff14}.cht-date-nav-label{font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.82rem;color:var(--text-primary);text-align:center;flex:1}.cht-summary-card{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;margin-bottom:16px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s;box-shadow:var(--shadow-glow);text-align:left}.cht-summary-card:active{transform:scale(.98)}[data-theme=dark] .cht-summary-card{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 1px 3px #0003,0 4px 12px #00000026}.cht-summary-icon{width:40px;height:40px;border-radius:12px;background:rgba(var(--color-primary-rgb),.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-primary)}.cht-summary-text{flex:1;display:flex;flex-direction:column;gap:2px}.cht-summary-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.82rem;color:var(--text-primary)}.cht-summary-sub{font-family:Inter,sans-serif;font-size:.68rem;color:var(--text-tertiary)}.cht-summary-arrow{flex-shrink:0;color:var(--text-tertiary)}.cht-card{background:var(--bg-card);border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:16px 12px;margin-bottom:16px;box-shadow:var(--shadow-glow);overflow:hidden;position:relative;-webkit-mask-image:-webkit-radial-gradient(white,black)}[data-theme=dark] .cht-card{background:#1e1e1ecc;border-color:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 1px 3px #0003,0 4px 12px #00000026}.cht-card-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.82rem;color:var(--text-primary);margin:0 0 2px;padding-left:4px}.cht-card-subtitle{font-family:Inter,sans-serif;font-size:.65rem;color:var(--text-tertiary);margin:0 0 12px;padding-left:4px}.cht-macro-tabs{display:flex;gap:4px;margin-bottom:12px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:0 4px}.cht-macro-tabs::-webkit-scrollbar{display:none}.cht-macro-tab{padding:5px 10px;border:1px solid var(--border-color);border-radius:8px;background:transparent;font-family:Inter,sans-serif;font-weight:500;font-size:.68rem;color:var(--text-tertiary);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;white-space:nowrap;flex-shrink:0}.cht-macro-tab.active{background:var(--color-primary);color:var(--text-on-primary, #fff);border-color:var(--color-primary)}.cht-macro-tab:active{transform:scale(.95)}[data-theme=dark] .cht-macro-tab{border-color:#ffffff1a}.cht-empty-chart{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 16px}.cht-empty-chart p{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-tertiary);margin:0}.cht-empty-cta{padding:6px 16px;border:none;border-radius:8px;background:var(--color-primary);color:var(--text-on-primary, #fff);font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.72rem;cursor:pointer;-webkit-tap-highlight-color:transparent}.cht-overlay{position:fixed;inset:0;z-index:9999;background:#0009;display:flex;align-items:center;justify-content:center;padding:24px;animation:chtOverlayIn .2s ease}@keyframes chtOverlayIn{0%{opacity:0}to{opacity:1}}.cht-overlay-card{background:var(--bg-card);border-radius:20px;padding:24px 20px;max-width:360px;width:100%;max-height:80vh;overflow-y:auto;animation:chtCardIn .25s ease;box-shadow:0 8px 32px #00000040;position:relative}@keyframes chtCardIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}[data-theme=dark] .cht-overlay-card{background:var(--bg-card-elevated);border:1px solid rgba(255,255,255,.08)}[data-mono=true][data-theme=light] .cht-overlay-card{background:#f5f5f5}[data-mono=true][data-theme=dark] .cht-overlay-card{background:#1a1a1f}.cht-overlay-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;border:none;background:#9696961a;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}.cht-overlay-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1rem;color:var(--text-primary);margin:0 0 20px}.cht-summary-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}.cht-summary-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 8px;background:#9696960d;border-radius:14px;border:1px solid rgba(150,150,150,.08)}[data-theme=dark] .cht-summary-stat{background:#ffffff0a;border-color:#ffffff0f}.cht-summary-stat-value{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.15rem;color:var(--text-primary)}.cht-summary-stat-label{font-family:Inter,sans-serif;font-size:.65rem;color:var(--text-tertiary)}.cht-summary-diff{font-family:Inter,sans-serif;font-size:.62rem;font-weight:600;padding:2px 6px;border-radius:4px;margin-top:2px}.cht-summary-diff.positive{color:var(--color-success);background:#2e7d3214}.cht-summary-diff.negative{color:var(--color-error);background:#d32f2f14}.cht-summary-advice{padding:14px;background:rgba(var(--color-primary-rgb),.05);border:1px solid rgba(var(--color-primary-rgb),.12);border-radius:14px}.cht-advice-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.75rem;color:var(--color-primary);margin:0 0 8px;display:flex;align-items:center;gap:6px}.cht-advice-text{font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-secondary);line-height:1.5;margin:0}.cht-summary-error{font-family:Inter,sans-serif;font-size:.82rem;color:var(--text-tertiary);text-align:center;padding:20px 0;margin:0}.cht-card .recharts-tooltip-wrapper{z-index:10}.cht-card .recharts-legend-item-text{color:var(--text-secondary)!important;font-family:Inter,sans-serif!important;font-size:.68rem!important}@media(min-width:400px){.cht-page-title{font-size:1.4rem}.cht-card{padding:18px 16px}.cht-overlay-card{padding:28px 24px}}[data-hiit-theme=red],.hiit-page:not([data-hiit-theme]){--hiit-bg: var(--color-primary);--hiit-text: #fff;--hiit-text-secondary: rgba(255, 255, 255, .6);--hiit-card: rgba(255, 255, 255, .93);--hiit-card-shadow: 0 2px 12px rgba(0, 0, 0, .08);--hiit-card-border: none;--hiit-card-text: #333;--hiit-card-text-secondary: #999;--hiit-card-divider: #f0f0f0;--hiit-input-bg: #f5f5f5;--hiit-input-bg-subtle: #f0f0f0;--hiit-toggle-off: #ddd;--hiit-pill-bg: rgba(255, 255, 255, .2);--hiit-pill-text: rgba(255, 255, 255, .7);--hiit-pill-active-bg: #fff;--hiit-pill-active-text: var(--color-primary);--hiit-pill-active-shadow: 0 2px 10px rgba(0, 0, 0, .15);--hiit-sidebar-bg: var(--color-primary);--hiit-sidebar-text: #fff;--hiit-sidebar-border: rgba(255, 255, 255, .2);--hiit-sidebar-item-bg: #fff;--hiit-sidebar-item-text: var(--color-primary);--hiit-sidebar-item-active-bg: rgba(255, 255, 255, .95);--hiit-sidebar-item-active-text: var(--color-primary);--hiit-sidebar-sub: rgba(255, 255, 255, .5);--hiit-chevron: #ccc;--hiit-config-active-bg: #fef2f2;--hiit-breakdown-bg: rgba(255, 255, 255, .15);--hiit-breakdown-item-bg: rgba(255, 255, 255, .15);--hiit-breakdown-num: rgba(255, 255, 255, .5);--hiit-breakdown-work: #fff;--hiit-breakdown-rest: rgba(255, 255, 255, .5)}[data-hiit-theme=dark]{--hiit-bg: #111114;--hiit-text: #f0f0f2;--hiit-text-secondary: rgba(255, 255, 255, .4);--hiit-card: #1a1a1f;--hiit-card-shadow: 0 2px 12px rgba(0, 0, 0, .3);--hiit-card-border: 1px solid rgba(255, 255, 255, .06);--hiit-card-text: #f0f0f2;--hiit-card-text-secondary: #a0a0a8;--hiit-card-divider: rgba(255, 255, 255, .06);--hiit-input-bg: rgba(255, 255, 255, .06);--hiit-input-bg-subtle: rgba(255, 255, 255, .04);--hiit-toggle-off: rgba(255, 255, 255, .1);--hiit-pill-bg: rgba(255, 255, 255, .08);--hiit-pill-text: rgba(255, 255, 255, .5);--hiit-pill-active-bg: var(--color-primary);--hiit-pill-active-text: #fff;--hiit-pill-active-shadow: 0 2px 10px rgba(0, 0, 0, .3);--hiit-sidebar-bg: #1a1a1f;--hiit-sidebar-text: #f0f0f2;--hiit-sidebar-border: rgba(255, 255, 255, .06);--hiit-sidebar-item-bg: rgba(255, 255, 255, .06);--hiit-sidebar-item-text: #f0f0f2;--hiit-sidebar-item-active-bg: rgba(255, 255, 255, .1);--hiit-sidebar-item-active-text: #f0f0f2;--hiit-sidebar-sub: rgba(255, 255, 255, .3);--hiit-chevron: rgba(255, 255, 255, .3);--hiit-config-active-bg: rgba(255, 255, 255, .04);--hiit-breakdown-bg: rgba(255, 255, 255, .06);--hiit-breakdown-item-bg: rgba(255, 255, 255, .08);--hiit-breakdown-num: rgba(255, 255, 255, .4);--hiit-breakdown-work: #f0f0f2;--hiit-breakdown-rest: rgba(255, 255, 255, .4)}[data-hiit-theme=light]{--hiit-bg: #f5f5f5;--hiit-text: #333;--hiit-text-secondary: #999;--hiit-card: #ffffff;--hiit-card-shadow: 0 2px 12px rgba(0, 0, 0, .06);--hiit-card-border: none;--hiit-card-text: #333;--hiit-card-text-secondary: #999;--hiit-card-divider: #f0f0f0;--hiit-input-bg: #f0f0f0;--hiit-input-bg-subtle: #f0f0f0;--hiit-toggle-off: #ddd;--hiit-pill-bg: #e8e8e8;--hiit-pill-text: #999;--hiit-pill-active-bg: var(--color-primary);--hiit-pill-active-text: #fff;--hiit-pill-active-shadow: 0 2px 10px rgba(0, 0, 0, .1);--hiit-sidebar-bg: #ffffff;--hiit-sidebar-text: #333;--hiit-sidebar-border: #f0f0f0;--hiit-sidebar-item-bg: #f5f5f5;--hiit-sidebar-item-text: #333;--hiit-sidebar-item-active-bg: var(--color-primary);--hiit-sidebar-item-active-text: #fff;--hiit-sidebar-sub: #999;--hiit-chevron: #ccc;--hiit-config-active-bg: #fef2f2;--hiit-breakdown-bg: rgba(0, 0, 0, .04);--hiit-breakdown-item-bg: rgba(0, 0, 0, .04);--hiit-breakdown-num: #999;--hiit-breakdown-work: #333;--hiit-breakdown-rest: #999}.hiit-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;padding:0 16px;min-height:calc(60px + env(safe-area-inset-top));padding-top:env(safe-area-inset-top);background:var(--hiit-bg);color:var(--hiit-text)}.hiit-hamburger{background:none;border:none;color:var(--hiit-text);cursor:pointer;padding:8px;margin:-8px 12px -8px -8px;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center}.hiit-header-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.2rem;font-weight:700;margin:0 40px 0 0;flex:1;text-align:center}.hiit-sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:99;opacity:0;pointer-events:none;transition:opacity .3s ease}.hiit-sidebar-overlay.open{opacity:1;pointer-events:auto}.hiit-sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:80vw;background:var(--hiit-sidebar-bg);z-index:100;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding-top:env(safe-area-inset-top)}.hiit-sidebar.open{transform:translate(0)}.hiit-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px 16px 16px;border-bottom:1px solid var(--hiit-sidebar-border)}.hiit-sidebar-header h2{font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:800;color:var(--hiit-sidebar-text);margin:0}.hiit-sidebar-close{background:none;border:none;color:var(--hiit-sidebar-text);opacity:.7;cursor:pointer;padding:8px;margin:-8px;-webkit-tap-highlight-color:transparent;display:flex;align-items:center}.hiit-sidebar-close:hover{opacity:1}.hiit-sidebar-list{list-style:none;margin:0;padding:16px 14px;flex:1;display:flex;flex-direction:column;gap:10px}.hiit-sidebar-item{display:flex;align-items:center;gap:14px;width:100%;padding:14px 16px;background:var(--hiit-sidebar-item-bg);border:none;border-radius:14px;color:var(--hiit-sidebar-item-text);font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s,background .15s;-webkit-tap-highlight-color:transparent;text-align:left;box-shadow:0 2px 8px #00000014}.hiit-sidebar-item:hover{transform:scale(1.02);box-shadow:0 4px 12px #0000001f}.hiit-sidebar-item:active{transform:scale(.98)}.hiit-sidebar-item.active{background:var(--hiit-sidebar-item-active-bg);color:var(--hiit-sidebar-item-active-text);font-weight:700;box-shadow:0 4px 14px #00000026}.hiit-sidebar-item.active svg{color:var(--hiit-sidebar-item-active-text)}.hiit-sidebar-item svg{flex-shrink:0;opacity:.7}.hiit-sidebar-item.active svg{opacity:1}.hiit-theme-picker{padding:16px 14px;border-top:1px solid var(--hiit-sidebar-border)}.hiit-theme-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:700;color:var(--hiit-sidebar-text);opacity:.5;text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:12px}.hiit-theme-options{display:flex;gap:10px}.hiit-theme-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;border:2px solid transparent;border-radius:12px;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:border-color .2s,transform .15s}.hiit-theme-btn.active{border-color:var(--color-primary)}.hiit-theme-btn:active{transform:scale(.95)}.hiit-theme-swatch{width:36px;height:36px;border-radius:50%;flex-shrink:0}.hiit-theme-name{font-family:Inter,sans-serif;font-size:.7rem;font-weight:600;color:var(--hiit-sidebar-text);opacity:.6}.hiit-theme-btn.active .hiit-theme-name{opacity:1;color:var(--color-primary)}.hiit-sidebar-footer{border-top:1px solid var(--hiit-sidebar-border);padding:24px 20px;padding-bottom:calc(24px + env(safe-area-inset-bottom));display:flex;flex-direction:column;align-items:center;gap:6px}.hiit-sidebar-logo{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--hiit-sidebar-border);box-shadow:0 2px 12px #0003;background:#fff;margin-bottom:6px}.hiit-sidebar-brand{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:800;color:var(--hiit-sidebar-text);letter-spacing:.5px;text-align:center}.hiit-sidebar-sub{font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;color:var(--hiit-sidebar-sub);letter-spacing:.3px;text-align:center}.hiit-picker-overlay{position:fixed;inset:0;background:var(--overlay-bg);z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:hiitPickerFadeIn .2s ease-out}@keyframes hiitPickerFadeIn{0%{opacity:0}to{opacity:1}}.hiit-picker-panel{width:100%;max-width:500px;max-height:80vh;background:var(--bg-card);border-radius:24px 24px 0 0;display:flex;flex-direction:column;animation:hiitPickerSlideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes hiitPickerSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.hiit-picker-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 12px;border-bottom:1px solid var(--border-light)}.hiit-picker-header h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0}.hiit-picker-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;-webkit-tap-highlight-color:transparent;display:flex}.hiit-picker-body{position:relative;height:392px;overflow:hidden}.hiit-picker-highlight{position:absolute;top:50%;left:16px;right:16px;height:56px;transform:translateY(-50%);background:var(--color-primary-light);border-radius:12px;pointer-events:none;z-index:1}.hiit-picker-list{height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:y mandatory;position:relative;z-index:2}.hiit-picker-list::-webkit-scrollbar{display:none}.hiit-picker-list{-ms-overflow-style:none;scrollbar-width:none}.hiit-picker-item{display:flex;align-items:center;justify-content:center;width:100%;background:none;border:none;font-family:Plus Jakarta Sans,sans-serif;font-size:1.4rem;font-weight:600;color:var(--text-tertiary);cursor:pointer;-webkit-tap-highlight-color:transparent;scroll-snap-align:center;transition:color .15s,font-size .15s}.hiit-picker-item.selected{color:var(--color-primary);font-size:1.8rem;font-weight:800}.hiit-active{min-height:100vh;background:var(--hiit-bg);display:flex;flex-direction:column;align-items:center;padding:20px;padding-top:calc(20px + env(safe-area-inset-top));padding-bottom:calc(20px + env(safe-area-inset-bottom));gap:16px}.hiit-active-phase{font-family:Plus Jakarta Sans,sans-serif;font-size:1.4rem;font-weight:800;color:var(--phase-color);text-transform:uppercase;letter-spacing:2px}.hiit-tracker-cards{width:100%;max-width:380px;display:flex;flex-direction:column;gap:8px}.hiit-tracker-card{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--hiit-card);border:var(--hiit-card-border);border-radius:14px;box-shadow:var(--hiit-card-shadow)}.hiit-tracker-label{font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;color:var(--hiit-card-text)}.hiit-tracker-dots{display:flex;gap:8px;align-items:center}.hiit-tracker-dot{width:12px;height:12px;border-radius:50%;background:var(--hiit-card-divider);transition:background .2s,transform .2s}.hiit-tracker-dot.active{background:var(--hiit-card-text);transform:scale(1.2);box-shadow:0 0 6px #00000026}.hiit-tracker-dot.completed{background:var(--phase-color)}.hiit-active-ring-container{position:relative;width:min(85vw,360px);height:min(85vw,360px);flex-shrink:0}.hiit-active-ring{position:absolute;top:0;left:0;width:100%;height:100%;transform:scaleX(-1)}.hiit-tick.remaining{stroke:var(--phase-color);transition:stroke .3s}.hiit-tick.elapsed{stroke:var(--hiit-text-secondary);transition:stroke .3s}.hiit-active-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.hiit-center-logo{position:absolute;width:65%;height:65%;border-radius:50%;overflow:hidden;box-shadow:0 4px 20px #0006}.hiit-center-logo img{width:100%;height:100%;object-fit:cover}.hiit-center-overlay{position:absolute;width:65%;height:65%;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#0000008c;z-index:1}.hiit-center-info{display:flex;flex-direction:column;align-items:center;gap:2px}.hiit-center-phase-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:900;color:#ffffffe6;text-transform:uppercase;letter-spacing:2px}.hiit-center-time{display:flex;align-items:center;justify-content:center}.hiit-active-time-digits{font-family:Plus Jakarta Sans,sans-serif;font-size:3.2rem;font-weight:900;color:#fff;line-height:1;min-width:2ch;text-align:center;text-shadow:0 2px 8px rgba(0,0,0,.6),0 0 20px var(--phase-color),0 0 40px var(--phase-color);animation:hiitDigitLift 1s ease-in-out infinite}@keyframes hiitDigitLift{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.hiit-active-time-colon{font-family:Plus Jakarta Sans,sans-serif;font-size:3.2rem;font-weight:900;color:#fff;line-height:1;text-shadow:0 2px 8px rgba(0,0,0,.6),0 0 20px var(--phase-color);animation:hiitColonBlink 1s step-start infinite}@keyframes hiitColonBlink{50%{opacity:.3}}.hiit-center-elapsed{display:flex;align-items:center;gap:4px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:700;color:#ffffffbf;margin-top:2px}.hiit-active-done-check{display:flex;align-items:center;justify-content:center;animation:hiitCheckPop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes hiitCheckPop{0%{transform:scale(0)}to{transform:scale(1)}}.hiit-active-info-row{display:flex;flex-direction:column;align-items:center;gap:4px}.hiit-active-exercise-label{font-family:Plus Jakarta Sans,sans-serif;font-size:1.3rem;font-weight:800;color:var(--hiit-text);text-transform:uppercase;letter-spacing:1px}.hiit-active-upnext{font-family:Inter,sans-serif;font-size:.85rem;color:var(--hiit-text-secondary)}.hiit-active-upnext strong{color:var(--phase-color);font-weight:600}.hiit-active-controls{display:flex;align-items:center;gap:28px;margin-top:auto;padding-top:16px}.hiit-ctrl-btn{width:52px;height:52px;border-radius:50%;border:var(--hiit-card-border);background:var(--hiit-card);color:var(--hiit-card-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s;-webkit-tap-highlight-color:transparent;box-shadow:var(--hiit-card-shadow)}.hiit-ctrl-btn:active{transform:scale(.9)}.hiit-ctrl-btn.primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 6px 20px rgba(var(--color-primary-rgb),.4)}.hiit-ctrl-btn.large{width:72px;height:72px}.hiit-ctrl-btn.primary svg{margin-left:2px}.hiit-stop-btn{margin-top:8px;margin-bottom:8px;padding:10px 28px;border:none;border-radius:10px;background:none;color:var(--hiit-text-secondary);font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}[data-hiit-theme=red] .hiit-stop-btn,[data-hiit-theme=dark] .hiit-stop-btn{color:#ffffffb3}.hiit-stop-btn:active{opacity:.7}.hiit-page{min-height:100vh;background:var(--hiit-bg)}.hiit-timer-content{padding:16px;padding-bottom:calc(24px + env(safe-area-inset-bottom));display:flex;flex-direction:column;align-items:center}.hiit-mode-pills{display:flex;gap:6px;width:100%;max-width:500px;margin-bottom:12px}.hiit-mode-pill{flex:1;padding:8px 4px;border:none;border-radius:10px;background:var(--hiit-pill-bg);color:var(--hiit-pill-text);font-family:Plus Jakarta Sans,sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .2s,color .2s,transform .15s;text-align:center}.hiit-mode-pill.active{background:var(--hiit-pill-active-bg);color:var(--hiit-pill-active-text);font-weight:700;box-shadow:var(--hiit-pill-active-shadow)}.hiit-mode-pill.locked{opacity:.5}.hiit-mode-lock{margin-right:3px;vertical-align:-1px}.hiit-mode-pill:active{transform:scale(.96)}.hiit-config-list{width:100%;max-width:500px;display:flex;flex-direction:column;gap:8px}.hiit-config-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 16px;background:var(--hiit-card);border:none;border-radius:14px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s,box-shadow .15s;box-shadow:0 2px 8px #00000014;text-align:left}.hiit-config-row:last-child{border-bottom:none}.hiit-config-row:active{transform:scale(.98)}.hiit-config-left{display:flex;align-items:center;gap:14px}.hiit-config-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.8}.hiit-config-label{font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;color:var(--hiit-card-text)}.hiit-config-right{display:flex;align-items:center;gap:8px}.hiit-config-value{font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:700;color:var(--color-primary)}.hiit-config-toggle-row{cursor:default}.hiit-config-toggle-row:active{background:none}.hiit-mini-switch{position:relative;display:inline-block;width:44px;height:26px;flex-shrink:0}.hiit-mini-switch input{opacity:0;width:0;height:0}.hiit-mini-switch-track{position:absolute;cursor:pointer;inset:0;background:var(--hiit-toggle-off);border-radius:13px;transition:background .25s}.hiit-mini-switch-track:before{content:"";position:absolute;height:20px;width:20px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 3px #0003}.hiit-mini-switch input:checked+.hiit-mini-switch-track{background:var(--color-primary)}.hiit-mini-switch input:checked+.hiit-mini-switch-track:before{transform:translate(18px)}.hiit-breakdown{width:100%;max-width:500px;margin-top:12px;background:var(--hiit-breakdown-bg);border-radius:12px;padding:10px 14px}.hiit-breakdown-title{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:600;color:var(--hiit-text-secondary);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:6px}.hiit-breakdown-list{display:flex;flex-wrap:wrap;gap:8px}.hiit-breakdown-item{display:flex;align-items:center;gap:4px;background:var(--hiit-breakdown-item-bg);border-radius:6px;padding:4px 8px}.hiit-breakdown-num{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;font-weight:800;color:var(--hiit-breakdown-num);min-width:14px}.hiit-breakdown-work{font-family:Inter,sans-serif;font-size:.8rem;font-weight:700;color:var(--hiit-breakdown-work)}.hiit-breakdown-rest{font-family:Inter,sans-serif;font-size:.7rem;color:var(--hiit-breakdown-rest)}.hiit-total-time{display:flex;flex-direction:column;align-items:center;margin-top:20px;gap:2px}.hiit-total-label{font-family:Inter,sans-serif;font-size:.75rem;color:var(--hiit-text-secondary);text-transform:uppercase;letter-spacing:.5px}.hiit-total-value{font-family:Plus Jakarta Sans,sans-serif;font-size:1.8rem;font-weight:900;color:var(--hiit-text)}.hiit-start-btn{width:80px;height:80px;border-radius:50%;border:none;background:var(--hiit-card);cursor:pointer;display:flex;align-items:center;justify-content:center;margin-top:16px;padding:0 0 0 4px;-webkit-tap-highlight-color:transparent;box-shadow:0 4px 20px #00000026;animation:hiitStartPulse 2s ease-in-out infinite}@keyframes hiitStartPulse{0%,to{transform:scale(1);box-shadow:0 0 rgba(var(--color-primary-rgb),.4)}50%{transform:scale(1.05);box-shadow:0 0 0 12px rgba(var(--color-primary-rgb),0)}}.hiit-start-btn:active{animation:none;transform:scale(.92)}.hiit-bottom-actions{display:flex;gap:10px;margin-top:16px;width:100%;max-width:500px;justify-content:center}.hiit-action-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border:none;border-radius:10px;background:var(--hiit-card);color:var(--hiit-card-text-secondary);font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s;box-shadow:var(--hiit-card-shadow)}.hiit-action-btn:active{background:var(--hiit-config-active-bg);color:var(--color-primary)}.hiit-action-btn.saved{color:#4caf50}.hiit-save-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end;justify-content:center}.hiit-save-sheet{width:100%;max-width:500px;background:var(--hiit-card);border-radius:20px 20px 0 0;padding:24px 20px calc(20px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:14px}.hiit-save-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700;color:var(--hiit-card-text);margin:0;text-align:center}.hiit-save-input{width:100%;padding:12px 14px;border:1px solid var(--hiit-card-divider);border-radius:10px;background:var(--hiit-input-bg);color:var(--hiit-card-text);font-family:Inter,sans-serif;font-size:.95rem;outline:none;box-sizing:border-box}.hiit-save-input:focus{border-color:var(--color-primary)}.hiit-save-cats{display:flex;gap:6px;flex-wrap:wrap}.hiit-save-cat{padding:6px 12px;border:none;border-radius:8px;background:var(--hiit-pill-bg);color:var(--hiit-pill-text);font-family:Inter,sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.hiit-save-cat.active{background:var(--hiit-pill-active-bg);color:var(--hiit-pill-active-text)}.hiit-save-preview{display:flex;gap:12px;justify-content:center;font-family:Inter,sans-serif;font-size:.8rem;color:var(--hiit-text-secondary)}.hiit-save-btns{display:flex;gap:10px}.hiit-save-cancel{flex:1;padding:12px;border:1px solid var(--hiit-card-divider);border-radius:10px;background:none;color:var(--hiit-card-text-secondary);font-family:Inter,sans-serif;font-size:.9rem;font-weight:500;cursor:pointer}.hiit-save-confirm{flex:1;padding:12px;border:none;border-radius:10px;background:var(--color-primary);color:#fff;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer}.hiit-save-confirm:disabled{opacity:.4}.hpg-overlay{min-height:calc(100vh - 56px);display:flex;align-items:center;justify-content:center;padding:24px 16px}.hpg-card{background:var(--hiit-card);border-radius:20px;padding:32px 24px;text-align:center;max-width:340px;width:100%;box-shadow:var(--hiit-card-shadow);border:var(--hiit-card-border)}.hpg-icon{width:56px;height:56px;border-radius:50%;background:var(--hiit-input-bg);color:var(--color-primary);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.hpg-title{margin:0 0 8px;font-family:Plus Jakarta Sans,sans-serif;font-size:1.15rem;font-weight:700;color:var(--hiit-card-text)}.hpg-message{margin:0 0 24px;font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;color:var(--hiit-card-text-secondary);line-height:1.5}.hpg-cta{display:block;width:100%;padding:13px;border:none;border-radius:30px;background:var(--color-primary);color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:700;cursor:pointer;box-shadow:0 4px 16px rgba(var(--color-primary-rgb),.35);transition:transform .1s;margin-bottom:12px}.hpg-cta:active{transform:scale(.97)}.hpg-back{background:none;border:none;color:var(--hiit-card-text-secondary);font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;cursor:pointer;padding:8px}.hpg-back:active{opacity:.6}.hlib-content{padding:20px 16px;padding-bottom:calc(40px + env(safe-area-inset-bottom));max-width:500px;margin:0 auto}.hlib-locked{text-align:center;padding:48px 20px}.hlib-locked-icon{color:var(--hiit-text-secondary);margin-bottom:16px}.hlib-locked h3{font-family:Plus Jakarta Sans,sans-serif;font-size:1.2rem;font-weight:800;color:var(--hiit-text);margin:0 0 8px}.hlib-locked p{font-family:Inter,sans-serif;font-size:.9rem;color:var(--hiit-text-secondary);margin:0 0 24px;line-height:1.5}.hlib-upgrade-btn{padding:14px 32px;border:none;border-radius:14px;background:var(--hiit-card);color:var(--color-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;box-shadow:var(--hiit-card-shadow);transition:transform .15s}.hlib-upgrade-btn:active{transform:scale(.96)}.hlib-save-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;border:2px dashed var(--hiit-text-secondary);border-radius:14px;background:none;color:var(--hiit-text);font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:border-color .2s,opacity .2s;opacity:.7}.hlib-save-btn:hover{opacity:1}.hlib-save-btn:active{opacity:.5}.hlib-save-form{background:var(--hiit-card);border-radius:14px;padding:16px;box-shadow:var(--hiit-card-shadow);border:var(--hiit-card-border)}.hlib-save-input{width:100%;padding:12px 14px;border:1.5px solid var(--hiit-card-divider);border-radius:10px;background:var(--hiit-input-bg);color:var(--hiit-card-text);font-family:Inter,sans-serif;font-size:.95rem;outline:none;box-sizing:border-box}.hlib-save-input:focus{border-color:var(--color-primary)}.hlib-save-input::placeholder{color:var(--hiit-card-text-secondary)}.hlib-save-categories{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.hlib-cat-pill{padding:6px 14px;border:1.5px solid var(--hiit-card-divider);border-radius:20px;background:none;color:var(--hiit-card-text-secondary);font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s}.hlib-cat-pill.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.hlib-save-preview{display:flex;gap:12px;margin-top:12px;padding:10px 14px;background:var(--hiit-input-bg);border-radius:10px;font-family:Inter,sans-serif;font-size:.8rem;color:var(--hiit-card-text-secondary)}.hlib-save-actions{display:flex;gap:10px;margin-top:14px}.hlib-cancel-btn{flex:1;padding:12px;border:none;border-radius:10px;background:var(--hiit-input-bg);color:var(--hiit-card-text-secondary);font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.hlib-confirm-btn{flex:1;padding:12px;border:none;border-radius:10px;background:var(--color-primary);color:#fff;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .15s}.hlib-confirm-btn:disabled{opacity:.4}.hlib-filter{display:flex;gap:8px;margin-top:20px;margin-bottom:16px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.hlib-filter::-webkit-scrollbar{display:none}.hlib-filter-pill{flex-shrink:0;padding:8px 16px;border:none;border-radius:20px;background:var(--hiit-pill-bg);color:var(--hiit-pill-text);font-family:Inter,sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .2s,color .2s}.hlib-filter-pill.active{background:var(--hiit-pill-active-bg);color:var(--hiit-pill-active-text)}.hlib-empty{text-align:center;padding:48px 20px}.hlib-empty svg{margin-bottom:16px;opacity:.4;color:var(--hiit-text-secondary)}.hlib-empty h4{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700;color:var(--hiit-text);margin:0 0 6px}.hlib-empty p{font-family:Inter,sans-serif;font-size:.9rem;color:var(--hiit-text-secondary);margin:0;line-height:1.5}.hlib-list{display:flex;flex-direction:column;gap:12px}.hlib-card{background:var(--hiit-card);border-radius:14px;border:var(--hiit-card-border);padding:16px;box-shadow:var(--hiit-card-shadow)}.hlib-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}.hlib-card-info{display:flex;flex-direction:column;gap:2px}.hlib-card-name{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:var(--hiit-card-text)}.hlib-card-category{font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;color:var(--color-primary);text-transform:uppercase;letter-spacing:.3px}.hlib-card-delete{background:none;border:none;color:var(--hiit-card-text-secondary);padding:4px;cursor:pointer;opacity:.5;-webkit-tap-highlight-color:transparent;transition:opacity .15s}.hlib-card-delete:hover{opacity:1;color:var(--color-error)}.hlib-card-details{display:flex;gap:16px;margin-bottom:14px}.hlib-card-stat{display:flex;flex-direction:column;align-items:center;flex:1}.hlib-card-stat-val{font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;color:var(--color-primary)}.hlib-card-stat-lbl{font-family:Inter,sans-serif;font-size:.7rem;color:var(--hiit-card-text-secondary);margin-top:2px}.hlib-load-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;border:none;border-radius:10px;background:var(--color-primary);color:#fff;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s}.hlib-load-btn:active{transform:scale(.97)}.hs-content{padding:20px 16px;padding-bottom:calc(40px + env(safe-area-inset-bottom));max-width:500px;margin:0 auto}.hs-section{background:var(--hiit-card);border-radius:14px;border:var(--hiit-card-border);padding:20px;margin-bottom:16px;box-shadow:var(--hiit-card-shadow)}.hs-section-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.8rem;color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px;display:flex;align-items:center;gap:8px}.hs-section-title svg{color:var(--color-primary);flex-shrink:0}.hs-divider{height:1px;background:var(--hiit-card-divider);margin:14px 0}.hs-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.hs-row-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.hs-row-label{font-family:Plus Jakarta Sans,sans-serif;font-weight:600;font-size:.9rem;color:var(--hiit-card-text)}.hs-row-desc{font-family:Inter,sans-serif;font-size:.75rem;color:var(--hiit-card-text-secondary);line-height:1.3}.hs-value{font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;font-weight:700;color:var(--color-primary);flex-shrink:0}.hs-seg-control{display:flex;background:var(--hiit-input-bg-subtle);border-radius:10px;overflow:hidden;margin-top:10px}.hs-seg-btn{flex:1;padding:10px 8px;border:none;background:none;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;color:var(--hiit-card-text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .2s,color .2s}.hs-seg-btn.active{background:var(--color-primary);color:#fff;font-weight:600;border-radius:8px}.hs-slider{width:100%;height:4px;-webkit-appearance:none;appearance:none;background:var(--hiit-input-bg-subtle);border-radius:2px;outline:none;margin-top:10px}.hs-slider::-webkit-slider-runnable-track{background:linear-gradient(to right,var(--color-primary) 0%,var(--color-primary) var(--val, 100%),var(--hiit-input-bg-subtle) var(--val, 100%),var(--hiit-input-bg-subtle) 100%);border-radius:2px;height:4px}.hs-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 8px #0003;margin-top:-9px}.hs-slider::-moz-range-track{background:var(--hiit-input-bg-subtle);border-radius:2px;height:4px}.hs-slider::-moz-range-progress{background:var(--color-primary);border-radius:2px;height:4px}.hs-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;border:none;background:#fff;cursor:pointer;box-shadow:0 2px 8px #0003}.hs-switch{position:relative;display:inline-block;width:48px;height:28px;flex-shrink:0}.hs-switch input{opacity:0;width:0;height:0}.hs-switch-track{position:absolute;cursor:pointer;inset:0;background:var(--hiit-toggle-off);border-radius:14px;transition:background .25s}.hs-switch-track:before{content:"";position:absolute;height:22px;width:22px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 4px #0003}.hs-switch input:checked+.hs-switch-track{background:var(--color-primary)}.hs-switch input:checked+.hs-switch-track:before{transform:translate(20px)}.hs-day-picker{display:flex;gap:6px;margin-top:10px;margin-bottom:14px}.hs-day-btn{flex:1;aspect-ratio:1;max-width:42px;border-radius:50%;border:1.5px solid var(--hiit-card-divider);background:var(--hiit-input-bg);font-family:Inter,sans-serif;font-size:.6rem;font-weight:600;color:var(--hiit-card-text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,border-color .15s,color .15s;display:flex;align-items:center;justify-content:center}.hs-day-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.hs-time-row{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--hiit-card-divider)}.hs-time-input{background:none;border:none;font-family:Inter,sans-serif;font-size:.9rem;color:var(--color-primary);font-weight:600;cursor:pointer;text-align:right}.hs-time-input::-webkit-calendar-picker-indicator{filter:opacity(.4)}[data-hiit-theme=dark] .hs-time-input::-webkit-calendar-picker-indicator{filter:invert(1) opacity(.4)}.hs-link-row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:0;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent;text-align:left;transition:opacity .15s}.hs-link-row:hover{opacity:.75}.hs-link-row:active{opacity:.5}.hs-link-row svg{color:var(--hiit-chevron);flex-shrink:0}.hs-about{display:flex;flex-direction:column;align-items:center;padding:28px 20px;gap:4px}.hs-about-logo{width:64px;height:64px;border-radius:50%;object-fit:cover;margin-bottom:8px;border:2px solid var(--hiit-card-divider);background:#fff}.hs-about-name{font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:800;color:var(--hiit-card-text)}.hs-about-tagline{font-family:Inter,sans-serif;font-size:.8rem;color:var(--hiit-card-text-secondary);font-weight:500}.hs-about-version{font-family:Inter,sans-serif;font-size:.7rem;color:var(--hiit-card-text-secondary);margin-top:4px;opacity:.6}.hiit-stats-content{padding:20px 16px;padding-bottom:calc(40px + env(safe-area-inset-bottom));max-width:500px;margin:0 auto}.hiit-stats-heading{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;color:var(--hiit-text);margin:0 0 12px}.hiit-seg-control{display:flex;background:var(--hiit-card);border-radius:14px;overflow:hidden;margin-bottom:8px;padding:5px;box-shadow:var(--hiit-card-shadow)}.hiit-seg-btn{flex:1;padding:12px 8px;border:none;background:none;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;color:var(--hiit-card-text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .2s,color .2s}.hiit-seg-btn.active{background:var(--color-primary);color:#fff;font-weight:600;border-radius:8px}.hiit-stats-stack{display:flex;flex-direction:column;gap:12px;margin-top:24px}.hiit-stat-card{display:flex;align-items:center;gap:16px;padding:18px 20px;background:var(--hiit-card);border-radius:16px;box-shadow:var(--hiit-card-shadow)}.hiit-stat-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hiit-stat-icon.green{background:#4caf501f;color:#4caf50}.hiit-stat-icon.red{background:rgba(var(--color-primary-rgb),.12);color:var(--color-primary)}.hiit-stat-icon.blue{background:#2196f31f;color:#2196f3}.hiit-stat-text{display:flex;flex-direction:column;gap:2px}.hiit-stat-label{font-family:Inter,sans-serif;font-size:.8rem;color:var(--hiit-card-text-secondary);line-height:1.2}.hiit-stat-value{font-family:Plus Jakarta Sans,sans-serif;font-size:1.5rem;font-weight:900;color:var(--hiit-card-text);line-height:1}.hp-content{padding:16px;padding-bottom:calc(40px + env(safe-area-inset-bottom));display:flex;flex-direction:column;align-items:center;max-width:440px;margin:0 auto}.hp-hero{text-align:center;margin-bottom:24px}.hp-hero-icon{width:64px;height:64px;border-radius:50%;background:var(--hiit-card);color:var(--hiit-card-text);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;box-shadow:var(--hiit-card-shadow)}.hp-hero-title{margin:0 0 4px;font-family:Plus Jakarta Sans,sans-serif;font-size:1.4rem;font-weight:800;color:var(--hiit-text)}.hp-hero-sub{margin:0;font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem;color:var(--hiit-text-secondary)}.hp-features{width:100%;background:var(--hiit-card);border-radius:16px;padding:12px 16px;margin-bottom:24px;box-shadow:var(--hiit-card-shadow);border:var(--hiit-card-border)}.hp-feature-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--hiit-card-divider)}.hp-feature-row:last-child{border-bottom:none}.hp-feature-icon{flex-shrink:0;width:20px;height:20px;color:var(--color-primary)}.hp-feature-text{font-family:Plus Jakarta Sans,sans-serif;font-size:.85rem;font-weight:500;color:var(--hiit-card-text)}.hp-plans{width:100%;display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.hp-plan-card{position:relative;display:flex;align-items:center;width:100%;background:var(--hiit-card);border:2px solid var(--hiit-card-divider);border-radius:14px;padding:16px;cursor:pointer;transition:all .2s ease;box-shadow:var(--hiit-card-shadow);text-align:left;overflow:visible}.hp-plan-card.selected{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 4px 16px rgba(var(--color-primary-rgb),.25)}.hp-plan-card:active{transform:scale(.98)}.hp-plan-badge{position:absolute;top:-9px;left:14px;background:var(--color-primary);color:#fff;font-size:.6rem;font-weight:700;font-family:Plus Jakarta Sans,sans-serif;padding:3px 10px;border-radius:10px;letter-spacing:.04em;white-space:nowrap;box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.4)}.hp-plan-info{flex:1;display:flex;flex-direction:column;gap:1px}.hp-plan-label{font-family:Plus Jakarta Sans,sans-serif;font-size:.78rem;font-weight:700;color:var(--hiit-card-text);text-transform:uppercase;letter-spacing:.05em}.hp-plan-price{font-family:Plus Jakarta Sans,sans-serif;font-size:1.2rem;font-weight:800;color:var(--hiit-card-text)}.hp-plan-period{font-size:.7rem;font-weight:500;color:var(--hiit-card-text-secondary)}.hp-plan-sub{font-family:Plus Jakarta Sans,sans-serif;font-size:.7rem;color:var(--hiit-card-text-secondary)}.hp-plan-radio{width:22px;height:22px;border-radius:50%;border:2px solid var(--hiit-card-divider);flex-shrink:0;transition:all .2s}.hp-plan-radio.active{border-color:var(--color-primary);background:var(--color-primary);box-shadow:inset 0 0 0 3px var(--hiit-card)}.hp-cta-btn{width:100%;padding:14px;border:none;border-radius:30px;background:var(--color-primary);color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;letter-spacing:.03em;box-shadow:0 6px 24px rgba(var(--color-primary-rgb),.45);transition:transform .1s,opacity .2s;margin-bottom:8px}.hp-cta-btn:active{transform:scale(.97)}.hp-disclaimer{font-family:Plus Jakarta Sans,sans-serif;font-size:.68rem;color:var(--hiit-text-secondary);text-align:center;line-height:1.4;margin:0 0 16px}.hp-account-banner{width:100%;text-align:center}.hp-account-banner p{font-family:Plus Jakarta Sans,sans-serif;font-size:.88rem;color:var(--hiit-text);font-weight:600;margin:0 0 16px}.hp-back-link{background:none;border:none;color:var(--hiit-text-secondary);font-family:Plus Jakarta Sans,sans-serif;font-size:.82rem;cursor:pointer;padding:8px;transition:opacity .2s}.hp-back-link:active{opacity:.6}
